Merge branch 'nunocoracao:main' into main
7
.github/workflows/build.yml
vendored
|
@ -36,6 +36,13 @@ jobs:
|
||||||
push_options: "--dry-run"
|
push_options: "--dry-run"
|
||||||
file_pattern: "assets/lib/katex/*"
|
file_pattern: "assets/lib/katex/*"
|
||||||
commit_message: "📦 Update packaged KaTeX"
|
commit_message: "📦 Update packaged KaTeX"
|
||||||
|
- name: Commit Mermaid changes
|
||||||
|
uses: stefanzweifel/git-auto-commit-action@v5
|
||||||
|
with:
|
||||||
|
branch: "${{ github.head_ref }}"
|
||||||
|
push_options: "--dry-run"
|
||||||
|
file_pattern: "assets/lib/mermaid/*"
|
||||||
|
commit_message: "📦 Update packaged Mermaid"
|
||||||
- run: npm run build
|
- run: npm run build
|
||||||
- name: Commit CSS changes
|
- name: Commit CSS changes
|
||||||
uses: stefanzweifel/git-auto-commit-action@v5
|
uses: stefanzweifel/git-auto-commit-action@v5
|
||||||
|
|
5
.github/workflows/firebase-preview.yml
vendored
|
@ -7,7 +7,10 @@ jobs:
|
||||||
steps:
|
steps:
|
||||||
|
|
||||||
- name: Hugo setup
|
- name: Hugo setup
|
||||||
uses: peaceiris/actions-hugo@v2.6.0
|
uses: peaceiris/actions-hugo@v3.0.0
|
||||||
|
with:
|
||||||
|
hugo-version: 0.120.4
|
||||||
|
extended: true
|
||||||
env:
|
env:
|
||||||
ACTIONS_ALLOW_UNSECURE_COMMANDS: 'true'
|
ACTIONS_ALLOW_UNSECURE_COMMANDS: 'true'
|
||||||
|
|
||||||
|
|
5
.github/workflows/firebase-production.yml
vendored
|
@ -9,7 +9,10 @@ jobs:
|
||||||
steps:
|
steps:
|
||||||
|
|
||||||
- name: Hugo setup
|
- name: Hugo setup
|
||||||
uses: peaceiris/actions-hugo@v2.6.0
|
uses: peaceiris/actions-hugo@v3.0.0
|
||||||
|
with:
|
||||||
|
hugo-version: 0.120.4
|
||||||
|
extended: true
|
||||||
env:
|
env:
|
||||||
ACTIONS_ALLOW_UNSECURE_COMMANDS: 'true'
|
ACTIONS_ALLOW_UNSECURE_COMMANDS: 'true'
|
||||||
|
|
||||||
|
|
53
.github/workflows/hugo-version-update.yml
vendored
Normal file
|
@ -0,0 +1,53 @@
|
||||||
|
name: Update Hugo version
|
||||||
|
|
||||||
|
on:
|
||||||
|
schedule:
|
||||||
|
- cron: '0 6 * * *'
|
||||||
|
|
||||||
|
workflow_dispatch:
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
updateBlowfish:
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
steps:
|
||||||
|
|
||||||
|
- name: Check out code into the Go module directory
|
||||||
|
uses: actions/checkout@v4
|
||||||
|
with:
|
||||||
|
ref: dev
|
||||||
|
submodules: true # Fetch Hugo themes (true OR recursive)
|
||||||
|
fetch-depth: 0 # Fetch all history for .GitInfo and .Lastmod
|
||||||
|
|
||||||
|
- name: Fetch release version
|
||||||
|
id: fetch-release
|
||||||
|
run: |
|
||||||
|
curl -sL https://api.github.com/repos/gohugoio/hugo/releases/latest | \
|
||||||
|
jq -r ".tag_name" > release-versions/hugo-latest.txt
|
||||||
|
|
||||||
|
- name: Check for modified files
|
||||||
|
id: git-check
|
||||||
|
run: echo ::set-output name=modified::$([ -z "`git status --porcelain`" ] && echo "false" || echo "true")
|
||||||
|
|
||||||
|
- name: Update config.toml
|
||||||
|
id: update-config
|
||||||
|
if: steps.git-check.outputs.modified == 'true'
|
||||||
|
run: |
|
||||||
|
cat release-versions/hugo-latest.txt | \
|
||||||
|
while read version; do sed -i'' -E "s/(max = \")[0-9]+\.[0-9]+\.[0-9]+(\")/\1${version#v}\2/g" config.toml; done
|
||||||
|
|
||||||
|
- name: Create Pull Request
|
||||||
|
if: steps.git-check.outputs.modified == 'true'
|
||||||
|
uses: peter-evans/create-pull-request@v6
|
||||||
|
with:
|
||||||
|
commit-message: Update Hugo supported version
|
||||||
|
title: ⚙️ Update Hugo supported version
|
||||||
|
body: |
|
||||||
|
Updates [Hugo][1] support
|
||||||
|
|
||||||
|
Auto-generated by [create-pull-request][2]
|
||||||
|
|
||||||
|
[1]: https://github.com/gohugoio/hugo
|
||||||
|
[2]: https://github.com/peter-evans/create-pull-request
|
||||||
|
labels: dependencies, automated pr
|
||||||
|
branch: hugo-new-version
|
||||||
|
base: dev
|
6
.github/workflows/pages.yml
vendored
|
@ -42,7 +42,7 @@ jobs:
|
||||||
submodules: recursive
|
submodules: recursive
|
||||||
- name: Setup Pages
|
- name: Setup Pages
|
||||||
id: pages
|
id: pages
|
||||||
uses: actions/configure-pages@v3
|
uses: actions/configure-pages@v5
|
||||||
- name: Build with Hugo
|
- name: Build with Hugo
|
||||||
env:
|
env:
|
||||||
# For maximum backward compatibility with Hugo modules
|
# For maximum backward compatibility with Hugo modules
|
||||||
|
@ -51,7 +51,7 @@ jobs:
|
||||||
run: |
|
run: |
|
||||||
hugo --minify -s exampleSite --themesDir ../.. -d ../docs --baseURL https://nunocoracao.github.io/blowfish/
|
hugo --minify -s exampleSite --themesDir ../.. -d ../docs --baseURL https://nunocoracao.github.io/blowfish/
|
||||||
- name: Upload artifact
|
- name: Upload artifact
|
||||||
uses: actions/upload-pages-artifact@v2
|
uses: actions/upload-pages-artifact@v3
|
||||||
with:
|
with:
|
||||||
path: ./docs
|
path: ./docs
|
||||||
|
|
||||||
|
@ -65,4 +65,4 @@ jobs:
|
||||||
steps:
|
steps:
|
||||||
- name: Deploy to GitHub Pages
|
- name: Deploy to GitHub Pages
|
||||||
id: deployment
|
id: deployment
|
||||||
uses: actions/deploy-pages@v2
|
uses: actions/deploy-pages@v4
|
||||||
|
|
2
.github/workflows/stale.yml
vendored
|
@ -18,7 +18,7 @@ jobs:
|
||||||
pull-requests: write
|
pull-requests: write
|
||||||
|
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/stale@v8
|
- uses: actions/stale@v9
|
||||||
with:
|
with:
|
||||||
repo-token: ${{ secrets.GITHUB_TOKEN }}
|
repo-token: ${{ secrets.GITHUB_TOKEN }}
|
||||||
stale-issue-message: 'This issue will be closed since it has been stale for 60 days.'
|
stale-issue-message: 'This issue will be closed since it has been stale for 60 days.'
|
||||||
|
|
2
.github/workflows/test.yml
vendored
|
@ -16,7 +16,7 @@ jobs:
|
||||||
fetch-depth: 0
|
fetch-depth: 0
|
||||||
|
|
||||||
- name: Setup Hugo
|
- name: Setup Hugo
|
||||||
uses: peaceiris/actions-hugo@v2.6.0
|
uses: peaceiris/actions-hugo@v3.0.0
|
||||||
with:
|
with:
|
||||||
hugo-version: "latest"
|
hugo-version: "latest"
|
||||||
|
|
||||||
|
|
3
.gitignore
vendored
|
@ -29,3 +29,6 @@ node_modules
|
||||||
._*
|
._*
|
||||||
.Spotlight-V100
|
.Spotlight-V100
|
||||||
.Trashes
|
.Trashes
|
||||||
|
.idea
|
||||||
|
.Ulysses-Group.plist
|
||||||
|
.Ulysses-Settings.plist
|
|
@ -35,9 +35,9 @@
|
||||||
- Indent using 2 spaces (soft tabs).
|
- Indent using 2 spaces (soft tabs).
|
||||||
- Put spaces between list items (ie. `[1, 2, 3]`, not `[1,2,3]`), around operators (ie. `1 + 1`, not `1+1`) and inside go templating tags (ie. `{{< alert >}}`, not `{{<alert>}}`).
|
- Put spaces between list items (ie. `[1, 2, 3]`, not `[1,2,3]`), around operators (ie. `1 + 1`, not `1+1`) and inside go templating tags (ie. `{{< alert >}}`, not `{{<alert>}}`).
|
||||||
- Avoid code reuse in templates by extracting components into partials.
|
- Avoid code reuse in templates by extracting components into partials.
|
||||||
- Layout code in a logical manner that prioritises readibility.
|
- Layout code in a logical manner that prioritises readability.
|
||||||
- Add comments when the intent of the code isn't immediately apparent or to break up large blocks of logic.
|
- Add comments when the intent of the code isn't immediately apparent or to break up large blocks of logic.
|
||||||
- Use relative paths to assets without including the preceeding slash but, when referring to a folder, including a trailing slash (ie. `static/img/`, not `/static/img/` or `/static/img`).
|
- Use relative paths to assets without including the preceding slash but, when referring to a folder, including a trailing slash (ie. `static/img/`, not `/static/img/` or `/static/img`).
|
||||||
- Any static text must be referenced using the `i18n` methods and included in the localisation assets.
|
- Any static text must be referenced using the `i18n` methods and included in the localisation assets.
|
||||||
- Commit often, preferring incremental changes rather than bundling everything into a single, large commit.
|
- Commit often, preferring incremental changes rather than bundling everything into a single, large commit.
|
||||||
|
|
||||||
|
|
2
LICENSE
|
@ -1,6 +1,6 @@
|
||||||
The MIT License (MIT)
|
The MIT License (MIT)
|
||||||
|
|
||||||
Copyright (c) 2021 James Panther (https://jamespanther.com)
|
Copyright (c) 2022 Nuno Coração (https://nunocoracao.com)
|
||||||
|
|
||||||
Permission is hereby granted, free of charge, to any person obtaining a copy of
|
Permission is hereby granted, free of charge, to any person obtaining a copy of
|
||||||
this software and associated documentation files (the "Software"), to deal in
|
this software and associated documentation files (the "Software"), to deal in
|
||||||
|
|
44
README.md
|
@ -1,8 +1,4 @@
|
||||||
# Blowfish
|
# Blowfish
|
||||||
|
|
||||||
<a href="https://www.buymeacoffee.com/nunocoracao" target="_blank"><img src="https://cdn.buymeacoffee.com/buttons/v2/default-yellow.png" alt="Buy Me A Coffee" style="height: 60px !important;width: 217px !important;" ></a>
|
|
||||||
<a target="_blank" href="http://tee.pub/lic/qwSlWVBL5zc"><img class="nozoom" src="https://img.buymeacoffee.com/button-api/?text=Merch Store &emoji=💎&slug=nunocoracao&button_colour=5F7FFF&font_colour=ffffff&font_family=Lato&outline_colour=000000&coffee_colour=FFDD00" /></a>
|
|
||||||
|
|
||||||
[![Deploy Production to Firebase](https://github.com/nunocoracao/blowfish/actions/workflows/firebase-production.yml/badge.svg)](https://github.com/nunocoracao/blowfish/actions/workflows/firebase-production.yml)
|
[![Deploy Production to Firebase](https://github.com/nunocoracao/blowfish/actions/workflows/firebase-production.yml/badge.svg)](https://github.com/nunocoracao/blowfish/actions/workflows/firebase-production.yml)
|
||||||
[![Deploy Production to GitHub pages](https://github.com/nunocoracao/blowfish/actions/workflows/pages.yml/badge.svg)](https://github.com/nunocoracao/blowfish/actions/workflows/pages.yml)
|
[![Deploy Production to GitHub pages](https://github.com/nunocoracao/blowfish/actions/workflows/pages.yml/badge.svg)](https://github.com/nunocoracao/blowfish/actions/workflows/pages.yml)
|
||||||
[![Minimum Hugo Version](https://img.shields.io/static/v1?label=min-HUGO-version&message=0.87.0&color=blue&logo=hugo)](https://github.com/gohugoio/hugo/releases/tag/v0.87.0)
|
[![Minimum Hugo Version](https://img.shields.io/static/v1?label=min-HUGO-version&message=0.87.0&color=blue&logo=hugo)](https://github.com/gohugoio/hugo/releases/tag/v0.87.0)
|
||||||
|
@ -10,7 +6,10 @@
|
||||||
[![Blowfish](https://img.shields.io/badge/Hugo--Themes-@Blowfish-blue)](https://themes.gohugo.io/themes/blowfish/)
|
[![Blowfish](https://img.shields.io/badge/Hugo--Themes-@Blowfish-blue)](https://themes.gohugo.io/themes/blowfish/)
|
||||||
![code-size](https://img.shields.io/github/languages/code-size/nunocoracao/blowfish)
|
![code-size](https://img.shields.io/github/languages/code-size/nunocoracao/blowfish)
|
||||||
|
|
||||||
Blowfish is designed to be a powerful, lightweight theme for [Hugo](https://gohugo.io). It's built using Tailwind CSS with a clean and minimalist design that prioritises to your content. The theme is a fork of [Congo](https://github.com/jpanther/congo).
|
Blowfish is designed to be a powerful, lightweight theme for [Hugo](https://gohugo.io). It's built using Tailwind CSS with a clean and minimalist design that prioritises to your content.
|
||||||
|
|
||||||
|
![blowfish screenshot](https://github.com/nunocoracao/blowfish/blob/main/images/screenshot.png?raw=true)
|
||||||
|
|
||||||
|
|
||||||
🌏 [Demo site](https://blowfish.page/)
|
🌏 [Demo site](https://blowfish.page/)
|
||||||
📑 [Theme documentation](https://blowfish.page/docs/)
|
📑 [Theme documentation](https://blowfish.page/docs/)
|
||||||
|
@ -18,7 +17,11 @@ Blowfish is designed to be a powerful, lightweight theme for [Hugo](https://gohu
|
||||||
🐛 [Bug reports & issues](https://github.com/nunocoracao/blowfish/issues)
|
🐛 [Bug reports & issues](https://github.com/nunocoracao/blowfish/issues)
|
||||||
💡 [Questions & feature requests](https://github.com/nunocoracao/blowfish/discussions)
|
💡 [Questions & feature requests](https://github.com/nunocoracao/blowfish/discussions)
|
||||||
|
|
||||||
![blowfish logo](https://github.com/nunocoracao/blowfish/blob/main/logo.png?raw=true)
|
|
||||||
|
|
||||||
|
<a href="https://www.buymeacoffee.com/nunocoracao" target="_blank"><img src="https://cdn.buymeacoffee.com/buttons/v2/default-yellow.png" alt="Buy Me A Coffee" style="height: 60px !important;width: 217px !important;" ></a>
|
||||||
|
<a target="_blank" href="http://tee.pub/lic/qwSlWVBL5zc"><img class="nozoom" src="https://img.buymeacoffee.com/button-api/?text=Merch Store &emoji=💎&slug=nunocoracao&button_colour=5F7FFF&font_colour=ffffff&font_family=Lato&outline_colour=000000&coffee_colour=FFDD00" /></a>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
## Features
|
## Features
|
||||||
|
@ -33,10 +36,13 @@ Blowfish is designed to be a powerful, lightweight theme for [Hugo](https://gohu
|
||||||
- Multiple homepage layouts
|
- Multiple homepage layouts
|
||||||
- Multiple authors
|
- Multiple authors
|
||||||
- Series of articles
|
- Series of articles
|
||||||
|
- Date and weight based article sorting
|
||||||
|
- Zen mode for article reading
|
||||||
- Flexible with any content types, taxonomies and menus
|
- Flexible with any content types, taxonomies and menus
|
||||||
- Header and footer menus
|
- Header and footer menus
|
||||||
- Nested menus & sub-navigation menu
|
- Nested menus & sub-navigation menu
|
||||||
- Multilingual content support inlcuding support for RTL languages
|
- Scrollable table of contents
|
||||||
|
- Multilingual content support including support for RTL languages
|
||||||
- Ability to link to posts on third-party websites
|
- Ability to link to posts on third-party websites
|
||||||
- Support for several shortcodes like Gallery, Timeline, GitHub cards, and Carousels
|
- Support for several shortcodes like Gallery, Timeline, GitHub cards, and Carousels
|
||||||
- Buymeacoffee integration
|
- Buymeacoffee integration
|
||||||
|
@ -44,6 +50,7 @@ Blowfish is designed to be a powerful, lightweight theme for [Hugo](https://gohu
|
||||||
- Diagrams and visualisations using Mermaid
|
- Diagrams and visualisations using Mermaid
|
||||||
- Charts using Chart.js
|
- Charts using Chart.js
|
||||||
- TypeIt integration
|
- TypeIt integration
|
||||||
|
- Youtube embeds with performance improvements
|
||||||
- Mathematical notation using KaTeX
|
- Mathematical notation using KaTeX
|
||||||
- SVG icons from FontAwesome 6
|
- SVG icons from FontAwesome 6
|
||||||
- Automatic image resizing using Hugo Pipes
|
- Automatic image resizing using Hugo Pipes
|
||||||
|
@ -58,6 +65,8 @@ Blowfish is designed to be a powerful, lightweight theme for [Hugo](https://gohu
|
||||||
|
|
||||||
---
|
---
|
||||||
|
|
||||||
|
![blowfish logo](https://github.com/nunocoracao/blowfish/blob/main/logo.png?raw=true)
|
||||||
|
|
||||||
## Documentation
|
## Documentation
|
||||||
|
|
||||||
Blowfish has [extensive documentation](https://blowfish.page/docs/) that covers all aspects of the theme. Be sure to [read the docs](https://blowfish.page/docs/) to learn more about how to use the theme and its features.
|
Blowfish has [extensive documentation](https://blowfish.page/docs/) that covers all aspects of the theme. Be sure to [read the docs](https://blowfish.page/docs/) to learn more about how to use the theme and its features.
|
||||||
|
@ -70,6 +79,27 @@ Blowfish supports several installation methods - as a git submodule, a Hugo Modu
|
||||||
|
|
||||||
Detailed instructions for each method can be found in the [Installation](https://blowfish.page/docs/installation) docs. You should consult the documentation for the simplest setup experience. Below is a quick start guide using submodules if you are using git, or Hugo modules if you're already confident installing Hugo themes.
|
Detailed instructions for each method can be found in the [Installation](https://blowfish.page/docs/installation) docs. You should consult the documentation for the simplest setup experience. Below is a quick start guide using submodules if you are using git, or Hugo modules if you're already confident installing Hugo themes.
|
||||||
|
|
||||||
|
### Quick start using Blowfish Tools
|
||||||
|
|
||||||
|
> **Note:** Ensure you have **Node.js**, **Git**, **Go** and **Hugo** installed, and that you have created a new Hugo project before proceeding.
|
||||||
|
|
||||||
|
We just launched a new CLI tool to help you get started with Blowfish. It will create a new Hugo project, install the theme and set up the theme configuration files for you. It's still in beta so please [report any issues you find](https://github.com/nunocoracao/blowfish-tools).
|
||||||
|
|
||||||
|
Install the CLI tool globally using npm (or other package manager):
|
||||||
|
```shell
|
||||||
|
npm i -g blowfish-tools
|
||||||
|
```
|
||||||
|
|
||||||
|
Then run the command `blowfish-tools` to start an interactive run which will guide you through creation and configuration use-cases.
|
||||||
|
```shell
|
||||||
|
blowfish-tools
|
||||||
|
```
|
||||||
|
|
||||||
|
You can also run the command `blowfish-tools new` to create a new Hugo project and install the theme in one go. Check the CLI help for more information.
|
||||||
|
```shell
|
||||||
|
blowfish-tools new mynewsite
|
||||||
|
```
|
||||||
|
|
||||||
### Quick start using git submodules
|
### Quick start using git submodules
|
||||||
|
|
||||||
> **Note:** Ensure you have **Git**, **Go**, and **Hugo** installed, and that you have created a new Hugo project before proceeding.
|
> **Note:** Ensure you have **Git**, **Go**, and **Hugo** installed, and that you have created a new Hugo project before proceeding.
|
||||||
|
|
16
assets/css/components/zen-mode.css
Normal file
|
@ -0,0 +1,16 @@
|
||||||
|
#zen-mode-button {
|
||||||
|
cursor:pointer
|
||||||
|
}
|
||||||
|
|
||||||
|
.zen-mode {
|
||||||
|
position: relative;
|
||||||
|
}
|
||||||
|
|
||||||
|
body.zen-mode-enable {
|
||||||
|
#bmc-wbtn, .author {
|
||||||
|
display:none !important;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -1,5 +1,7 @@
|
||||||
/*! Blowfish | MIT License | https://github.com/nunocoracao/blowfish */
|
/*! Blowfish | MIT License | https://github.com/nunocoracao/blowfish */
|
||||||
|
|
||||||
|
@import 'components/zen-mode.css';
|
||||||
|
|
||||||
@tailwind base;
|
@tailwind base;
|
||||||
@tailwind components;
|
@tailwind components;
|
||||||
@tailwind utilities;
|
@tailwind utilities;
|
||||||
|
@ -111,6 +113,21 @@ body:has(#menu-controller:checked) {
|
||||||
@apply absolute opacity-5 -z-10;
|
@apply absolute opacity-5 -z-10;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Fix long KaTeX equations on mobile (see https://katex.org/docs/issues.html#css-customization) */
|
||||||
|
.katex-display { overflow: auto hidden }
|
||||||
|
|
||||||
|
/* Fix long tables breaking out of article on mobile */
|
||||||
|
table {
|
||||||
|
display: block;
|
||||||
|
overflow: auto;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Fix long inline code sections breaking out of article on mobile */
|
||||||
|
code {
|
||||||
|
word-wrap: break-word; /* All browsers since IE 5.5+ */
|
||||||
|
overflow-wrap: break-word; /* Renamed property in CSS3 draft spec */
|
||||||
|
}
|
||||||
|
|
||||||
/* -- Chroma Highlight -- */
|
/* -- Chroma Highlight -- */
|
||||||
/* Background */
|
/* Background */
|
||||||
.prose .chroma {
|
.prose .chroma {
|
||||||
|
@ -339,6 +356,10 @@ body:has(#menu-controller:checked) {
|
||||||
|
|
||||||
/* Custom */
|
/* Custom */
|
||||||
|
|
||||||
|
pre {
|
||||||
|
text-align: left;
|
||||||
|
}
|
||||||
|
|
||||||
.thumbnail {
|
.thumbnail {
|
||||||
min-width: 300px;
|
min-width: 300px;
|
||||||
height: 180px;
|
height: 180px;
|
||||||
|
@ -400,7 +421,7 @@ body:has(#menu-controller:checked) {
|
||||||
.anchor {
|
.anchor {
|
||||||
display: block;
|
display: block;
|
||||||
position: relative;
|
position: relative;
|
||||||
top: -100px;
|
top: -150px;
|
||||||
height: 0px;
|
height: 0px;
|
||||||
visibility: hidden;
|
visibility: hidden;
|
||||||
}
|
}
|
||||||
|
|
1
assets/icons/bluesky.svg
Normal file
|
@ -0,0 +1 @@
|
||||||
|
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 512 512"><path fill="currentColor" d="M256,232.562c-21.183,-41.196 -78.868,-117.97 -132.503,-155.834c-51.378,-36.272 -70.978,-29.987 -83.828,-24.181c-14.872,6.72 -17.577,29.554 -17.577,42.988c0,13.433 7.365,110.138 12.169,126.281c15.873,53.336 72.376,71.358 124.413,65.574c2.66,-0.395 5.357,-0.759 8.089,-1.097c-2.68,0.429 -5.379,0.796 -8.089,1.097c-76.259,11.294 -143.984,39.085 -55.158,137.972c97.708,101.165 133.908,-21.692 152.484,-83.983c18.576,62.291 39.972,180.718 150.734,83.983c83.174,-83.983 22.851,-126.674 -53.408,-137.969c-2.71,-0.302 -5.409,-0.667 -8.089,-1.096c2.732,0.337 5.429,0.702 8.089,1.096c52.037,5.785 108.54,-12.239 124.413,-65.574c4.804,-16.142 12.169,-112.847 12.169,-126.281c-0,-13.434 -2.705,-36.267 -17.577,-42.988c-12.85,-5.806 -32.45,-12.09 -83.829,24.181c-53.634,37.864 -111.319,114.635 -132.502,155.831Z"/></svg>
|
After Width: | Height: | Size: 898 B |
2
assets/icons/codeberg.svg
Normal file
|
@ -0,0 +1,2 @@
|
||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<svg fill="currentColor" viewBox="0 0 24 24" role="img" xmlns="http://www.w3.org/2000/svg"><path d="M11.955.49A12 12 0 0 0 0 12.49a12 12 0 0 0 1.832 6.373L11.838 5.928a.187.14 0 0 1 .324 0l10.006 12.935A12 12 0 0 0 24 12.49a12 12 0 0 0-12-12 12 12 0 0 0-.045 0zm.375 6.467 4.416 16.553a12 12 0 0 0 5.137-4.213z"/></svg>
|
After Width: | Height: | Size: 359 B |
|
@ -1 +1 @@
|
||||||
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 512 512"><path fill="currentColor" d="M490.3 40.4C512.2 62.27 512.2 97.73 490.3 119.6L460.3 149.7L362.3 51.72L392.4 21.66C414.3-.2135 449.7-.2135 471.6 21.66L490.3 40.4zM172.4 241.7L339.7 74.34L437.7 172.3L270.3 339.6C264.2 345.8 256.7 350.4 248.4 353.2L159.6 382.8C150.1 385.6 141.5 383.4 135 376.1C128.6 370.5 126.4 361 129.2 352.4L158.8 263.6C161.6 255.3 166.2 247.8 172.4 241.7V241.7zM192 63.1C209.7 63.1 224 78.33 224 95.1C224 113.7 209.7 127.1 192 127.1H96C78.33 127.1 64 142.3 64 159.1V416C64 433.7 78.33 448 96 448H352C369.7 448 384 433.7 384 416V319.1C384 302.3 398.3 287.1 416 287.1C433.7 287.1 448 302.3 448 319.1V416C448 469 405 512 352 512H96C42.98 512 0 469 0 416V159.1C0 106.1 42.98 63.1 96 63.1H192z"/></svg>
|
<svg xmlns="http://www.w3.org/2000/svg" height="1em" viewBox="0 0 512 512"><path fill="currentColor" d="M441 58.9L453.1 71c9.4 9.4 9.4 24.6 0 33.9L424 134.1 377.9 88 407 58.9c9.4-9.4 24.6-9.4 33.9 0zM209.8 256.2L344 121.9 390.1 168 255.8 302.2c-2.9 2.9-6.5 5-10.4 6.1l-58.5 16.7 16.7-58.5c1.1-3.9 3.2-7.5 6.1-10.4zM373.1 25L175.8 222.2c-8.7 8.7-15 19.4-18.3 31.1l-28.6 100c-2.4 8.4-.1 17.4 6.1 23.6s15.2 8.5 23.6 6.1l100-28.6c11.8-3.4 22.5-9.7 31.1-18.3L487 138.9c28.1-28.1 28.1-73.7 0-101.8L474.9 25C446.8-3.1 401.2-3.1 373.1 25zM88 64C39.4 64 0 103.4 0 152V424c0 48.6 39.4 88 88 88H360c48.6 0 88-39.4 88-88V312c0-13.3-10.7-24-24-24s-24 10.7-24 24V424c0 22.1-17.9 40-40 40H88c-22.1 0-40-17.9-40-40V152c0-22.1 17.9-40 40-40H200c13.3 0 24-10.7 24-24s-10.7-24-24-24H88z"/></svg>
|
Before Width: | Height: | Size: 778 B After Width: | Height: | Size: 776 B |
3
assets/icons/expand.svg
Normal file
|
@ -0,0 +1,3 @@
|
||||||
|
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 50 50" width="50px" height="50px">
|
||||||
|
<path fill="currentColor" d="M 12.980469 4 C 9.1204688 4 5.9804688 7.14 5.9804688 11 L 6 26 L 9.9804688 26 L 9.9804688 11 C 9.9804688 9.35 11.320469 8 12.980469 8 L 40.019531 8 C 41.679531 8 43.019531 9.35 43.019531 11 L 43.019531 39 C 43.019531 40.65 41.679531 42 40.019531 42 L 29 42 C 29 43.54 28.420938 44.94 27.460938 46 L 40.019531 46 C 43.879531 46 47.019531 42.86 47.019531 39 L 47.019531 11 C 47.019531 7.14 43.879531 4 40.019531 4 L 12.980469 4 z M 7 28 C 4.794 28 3 29.794 3 32 L 3 42 C 3 44.206 4.794 46 7 46 L 23 46 C 25.206 46 27 44.206 27 42 L 27 32 C 27 29.794 25.206 28 23 28 L 7 28 z M 7 32 L 23 32 L 23.001953 42 L 7 42 L 7 32 z"/>
|
||||||
|
</svg>
|
After Width: | Height: | Size: 749 B |
1
assets/icons/itch-io.svg
Normal file
|
@ -0,0 +1 @@
|
||||||
|
<svg xmlns="http://www.w3.org/2000/svg" height="235.452" width="261.728" viewBox="0 0 245.37069 220.73612"><path fill="currentColor" d="M31.99 1.365C21.287 7.72.2 31.945 0 38.298v10.516C0 62.144 12.46 73.86 23.773 73.86c13.584 0 24.902-11.258 24.903-24.62 0 13.362 10.93 24.62 24.515 24.62 13.586 0 24.165-11.258 24.165-24.62 0 13.362 11.622 24.62 25.207 24.62h.246c13.586 0 25.208-11.258 25.208-24.62 0 13.362 10.58 24.62 24.164 24.62 13.585 0 24.515-11.258 24.515-24.62 0 13.362 11.32 24.62 24.903 24.62 11.313 0 23.773-11.714 23.773-25.046V38.298c-.2-6.354-21.287-30.58-31.988-36.933C180.118.197 157.056-.005 122.685 0c-34.37.003-81.228.54-90.697 1.365zm65.194 66.217a28.025 28.025 0 0 1-4.78 6.155c-5.128 5.014-12.157 8.122-19.906 8.122a28.482 28.482 0 0 1-19.948-8.126c-1.858-1.82-3.27-3.766-4.563-6.032l-.006.004c-1.292 2.27-3.092 4.215-4.954 6.037a28.5 28.5 0 0 1-19.948 8.12c-.934 0-1.906-.258-2.692-.528-1.092 11.372-1.553 22.24-1.716 30.164l-.002.045c-.02 4.024-.04 7.333-.06 11.93.21 23.86-2.363 77.334 10.52 90.473 19.964 4.655 56.7 6.775 93.555 6.788h.006c36.854-.013 73.59-2.133 93.554-6.788 12.883-13.14 10.31-66.614 10.52-90.474-.022-4.596-.04-7.905-.06-11.93l-.003-.045c-.162-7.926-.623-18.793-1.715-30.165-.786.27-1.757.528-2.692.528a28.5 28.5 0 0 1-19.948-8.12c-1.862-1.822-3.662-3.766-4.955-6.037l-.006-.004c-1.294 2.266-2.705 4.213-4.563 6.032a28.48 28.48 0 0 1-19.947 8.125c-7.748 0-14.778-3.11-19.906-8.123a28.025 28.025 0 0 1-4.78-6.155 27.99 27.99 0 0 1-4.736 6.155 28.49 28.49 0 0 1-19.95 8.124c-.27 0-.54-.012-.81-.02h-.007c-.27.008-.54.02-.813.02a28.49 28.49 0 0 1-19.95-8.123 27.992 27.992 0 0 1-4.736-6.155zm-20.486 26.49l-.002.01h.015c8.113.017 15.32 0 24.25 9.746 7.028-.737 14.372-1.105 21.722-1.094h.006c7.35-.01 14.694.357 21.723 1.094 8.93-9.747 16.137-9.73 24.25-9.746h.014l-.002-.01c3.833 0 19.166 0 29.85 30.007L210 165.244c8.504 30.624-2.723 31.373-16.727 31.4-20.768-.773-32.267-15.855-32.267-30.935-11.496 1.884-24.907 2.826-38.318 2.827h-.006c-13.412 0-26.823-.943-38.318-2.827 0 15.08-11.5 30.162-32.267 30.935-14.004-.027-25.23-.775-16.726-31.4L46.85 124.08c10.684-30.007 26.017-30.007 29.85-30.007zm45.985 23.582v.006c-.02.02-21.863 20.08-25.79 27.215l14.304-.573v12.474c0 .584 5.74.346 11.486.08h.006c5.744.266 11.485.504 11.485-.08v-12.474l14.304.573c-3.928-7.135-25.79-27.215-25.79-27.215v-.006l-.003.002z"/></svg>
|
After Width: | Height: | Size: 2.3 KiB |
2
assets/icons/language.svg
Normal file
|
@ -0,0 +1,2 @@
|
||||||
|
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 640 512">
|
||||||
|
<path fill="currentColor" d="M0 128C0 92.7 28.7 64 64 64H256h48 16H576c35.3 0 64 28.7 64 64V384c0 35.3-28.7 64-64 64H320 304 256 64c-35.3 0-64-28.7-64-64V128zm320 0V384H576V128H320zM178.3 175.9c-3.2-7.2-10.4-11.9-18.3-11.9s-15.1 4.7-18.3 11.9l-64 144c-4.5 10.1 .1 21.9 10.2 26.4s21.9-.1 26.4-10.2l8.9-20.1h73.6l8.9 20.1c4.5 10.1 16.3 14.6 26.4 10.2s14.6-16.3 10.2-26.4l-64-144zM160 233.2L179 276H141l19-42.8zM448 164c11 0 20 9 20 20v4h44 16c11 0 20 9 20 20s-9 20-20 20h-2l-1.6 4.5c-8.9 24.4-22.4 46.6-39.6 65.4c.9 .6 1.8 1.1 2.7 1.6l18.9 11.3c9.5 5.7 12.5 18 6.9 27.4s-18 12.5-27.4 6.9l-18.9-11.3c-4.5-2.7-8.8-5.5-13.1-8.5c-10.6 7.5-21.9 14-34 19.4l-3.6 1.6c-10.1 4.5-21.9-.1-26.4-10.2s.1-21.9 10.2-26.4l3.6-1.6c6.4-2.9 12.6-6.1 18.5-9.8l-12.2-12.2c-7.8-7.8-7.8-20.5 0-28.3s20.5-7.8 28.3 0l14.6 14.6 .5 .5c12.4-13.1 22.5-28.3 29.8-45H448 376c-11 0-20-9-20-20s9-20 20-20h52v-4c0-11 9-20 20-20z"/></svg>
|
After Width: | Height: | Size: 968 B |
2
assets/icons/threads.svg
Normal file
|
@ -0,0 +1,2 @@
|
||||||
|
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 448 512">
|
||||||
|
<path fill="currentColor" d="M331.5 235.7c2.2 .9 4.2 1.9 6.3 2.8c29.2 14.1 50.6 35.2 61.8 61.4c15.7 36.5 17.2 95.8-30.3 143.2c-36.2 36.2-80.3 52.5-142.6 53h-.3c-70.2-.5-124.1-24.1-160.4-70.2c-32.3-41-48.9-98.1-49.5-169.6V256v-.2C17 184.3 33.6 127.2 65.9 86.2C102.2 40.1 156.2 16.5 226.4 16h.3c70.3 .5 124.9 24 162.3 69.9c18.4 22.7 32 50 40.6 81.7l-40.4 10.8c-7.1-25.8-17.8-47.8-32.2-65.4c-29.2-35.8-73-54.2-130.5-54.6c-57 .5-100.1 18.8-128.2 54.4C72.1 146.1 58.5 194.3 58 256c.5 61.7 14.1 109.9 40.3 143.3c28 35.6 71.2 53.9 128.2 54.4c51.4-.4 85.4-12.6 113.7-40.9c32.3-32.2 31.7-71.8 21.4-95.9c-6.1-14.2-17.1-26-31.9-34.9c-3.7 26.9-11.8 48.3-24.7 64.8c-17.1 21.8-41.4 33.6-72.7 35.3c-23.6 1.3-46.3-4.4-63.9-16c-20.8-13.8-33-34.8-34.3-59.3c-2.5-48.3 35.7-83 95.2-86.4c21.1-1.2 40.9-.3 59.2 2.8c-2.4-14.8-7.3-26.6-14.6-35.2c-10-11.7-25.6-17.7-46.2-17.8H227c-16.6 0-39 4.6-53.3 26.3l-34.4-23.6c19.2-29.1 50.3-45.1 87.8-45.1h.8c62.6 .4 99.9 39.5 103.7 107.7l-.2 .2zm-156 68.8c1.3 25.1 28.4 36.8 54.6 35.3c25.6-1.4 54.6-11.4 59.5-73.2c-13.2-2.9-27.8-4.4-43.4-4.4c-4.8 0-9.6 .1-14.4 .4c-42.9 2.4-57.2 23.2-56.2 41.8l-.1 .1z"/></svg>
|
After Width: | Height: | Size: 1.2 KiB |
1
assets/icons/xing.svg
Normal file
|
@ -0,0 +1 @@
|
||||||
|
<svg role="img" viewBox="0 0 24 24" xmlns="http://www.w3.org/2000/svg"><title>Xing</title><path fill="currentColor" d="M18.188 0c-.517 0-.741.325-.927.66 0 0-7.455 13.224-7.702 13.657.015.024 4.919 9.023 4.919 9.023.17.308.436.66.967.66h3.454c.211 0 .375-.078.463-.22.089-.151.089-.346-.009-.536l-4.879-8.916c-.004-.006-.004-.016 0-.022L22.139.756c.095-.191.097-.387.006-.535C22.056.078 21.894 0 21.686 0h-3.498zM3.648 4.74c-.211 0-.385.074-.473.216-.09.149-.078.339.02.531l2.34 4.05c.004.01.004.016 0 .021L1.86 16.051c-.099.188-.093.381 0 .529.085.142.239.234.45.234h3.461c.518 0 .766-.348.945-.667l3.734-6.609-2.378-4.155c-.172-.315-.434-.659-.962-.659H3.648v.016z"/></svg>
|
After Width: | Height: | Size: 675 B |
574
assets/img/background.svg
Normal file
|
@ -0,0 +1,574 @@
|
||||||
|
<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink"
|
||||||
|
style="margin:auto;background:rgba(NaN, NaN, NaN, 0);display:block;z-index:1;position:relative"
|
||||||
|
width="1084" height="322" preserveAspectRatio="xMidYMid" viewBox="0 0 1084 322">
|
||||||
|
<defs>
|
||||||
|
<pattern id="pid-0.7735807359934106" x="0" y="0" width="345.6" height="345.6"
|
||||||
|
patternUnits="userSpaceOnUse">
|
||||||
|
<g transform="scale(1.35)">
|
||||||
|
<g>
|
||||||
|
<line x1="237.6288884328494" x2="201.39714008747956" y1="119.05338354492488"
|
||||||
|
y2="155.28513189029474" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="237.6288884328494" x2="201.39714008747956" y1="-392.9466164550751"
|
||||||
|
y2="-356.71486810970526" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="493.6288884328494" x2="457.39714008747956" y1="-392.9466164550751"
|
||||||
|
y2="-356.71486810970526" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="749.6288884328494" x2="713.3971400874796" y1="-392.9466164550751"
|
||||||
|
y2="-356.71486810970526" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="237.6288884328494" x2="201.39714008747956" y1="-136.94661645507512"
|
||||||
|
y2="-100.71486810970526" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="493.6288884328494" x2="457.39714008747956" y1="-136.94661645507512"
|
||||||
|
y2="-100.71486810970526" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="749.6288884328494" x2="713.3971400874796" y1="-136.94661645507512"
|
||||||
|
y2="-100.71486810970526" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="237.6288884328494" x2="201.39714008747956" y1="119.05338354492488"
|
||||||
|
y2="155.28513189029474" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="493.6288884328494" x2="457.39714008747956" y1="119.05338354492488"
|
||||||
|
y2="155.28513189029474" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="749.6288884328494" x2="713.3971400874796" y1="119.05338354492488"
|
||||||
|
y2="155.28513189029474" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="244.43797352167968" x2="179.25167385613412" y1="196.21419032492787"
|
||||||
|
y2="261.40048999047343" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="244.43797352167968" x2="179.25167385613412" y1="-315.78580967507213"
|
||||||
|
y2="-250.59951000952657" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="500.4379735216797" x2="435.2516738561341" y1="-315.78580967507213"
|
||||||
|
y2="-250.59951000952657" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="756.4379735216796" x2="691.2516738561342" y1="-315.78580967507213"
|
||||||
|
y2="-250.59951000952657" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="244.43797352167968" x2="179.25167385613412" y1="-59.78580967507213"
|
||||||
|
y2="5.400489990473432" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="500.4379735216797" x2="435.2516738561341" y1="-59.78580967507213"
|
||||||
|
y2="5.400489990473432" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="756.4379735216796" x2="691.2516738561342" y1="-59.78580967507213"
|
||||||
|
y2="5.400489990473432" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="244.43797352167968" x2="179.25167385613412" y1="196.21419032492787"
|
||||||
|
y2="261.40048999047343" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="500.4379735216797" x2="435.2516738561341" y1="196.21419032492787"
|
||||||
|
y2="261.40048999047343" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="756.4379735216796" x2="691.2516738561342" y1="196.21419032492787"
|
||||||
|
y2="261.40048999047343" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="219.6724359102308" x2="209.2181431749452" y1="92.85808081141191"
|
||||||
|
y2="103.31237354669749" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="219.6724359102308" x2="209.2181431749452" y1="-419.1419191885881"
|
||||||
|
y2="-408.6876264533025" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="475.6724359102308" x2="465.2181431749452" y1="-419.1419191885881"
|
||||||
|
y2="-408.6876264533025" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="731.6724359102308" x2="721.2181431749452" y1="-419.1419191885881"
|
||||||
|
y2="-408.6876264533025" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="219.6724359102308" x2="209.2181431749452" y1="-163.14191918858808"
|
||||||
|
y2="-152.68762645330253" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="475.6724359102308" x2="465.2181431749452" y1="-163.14191918858808"
|
||||||
|
y2="-152.68762645330253" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="731.6724359102308" x2="721.2181431749452" y1="-163.14191918858808"
|
||||||
|
y2="-152.68762645330253" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="219.6724359102308" x2="209.2181431749452" y1="92.85808081141191"
|
||||||
|
y2="103.31237354669749" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="475.6724359102308" x2="465.2181431749452" y1="92.85808081141191"
|
||||||
|
y2="103.31237354669749" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="731.6724359102308" x2="721.2181431749452" y1="92.85808081141191"
|
||||||
|
y2="103.31237354669749" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="112.00565118011832" x2="71.15817744773324" y1="56.63419812919665"
|
||||||
|
y2="97.48167186158173" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="112.00565118011832" x2="71.15817744773324" y1="-455.36580187080335"
|
||||||
|
y2="-414.51832813841827" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="368.0056511801183" x2="327.15817744773324" y1="-455.36580187080335"
|
||||||
|
y2="-414.51832813841827" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="624.0056511801183" x2="583.1581774477332" y1="-455.36580187080335"
|
||||||
|
y2="-414.51832813841827" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="112.00565118011832" x2="71.15817744773324" y1="-199.36580187080335"
|
||||||
|
y2="-158.51832813841827" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="368.0056511801183" x2="327.15817744773324" y1="-199.36580187080335"
|
||||||
|
y2="-158.51832813841827" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="624.0056511801183" x2="583.1581774477332" y1="-199.36580187080335"
|
||||||
|
y2="-158.51832813841827" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="112.00565118011832" x2="71.15817744773324" y1="56.63419812919665"
|
||||||
|
y2="97.48167186158173" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="368.0056511801183" x2="327.15817744773324" y1="56.63419812919665"
|
||||||
|
y2="97.48167186158173" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="624.0056511801183" x2="583.1581774477332" y1="56.63419812919665"
|
||||||
|
y2="97.48167186158173" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="60.932966336476014" x2="49.388821076756514" y1="125.65681060957188"
|
||||||
|
y2="137.20095586929136" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="60.932966336476014" x2="49.388821076756514" y1="-386.3431893904281"
|
||||||
|
y2="-374.79904413070864" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="316.932966336476" x2="305.3888210767565" y1="-386.3431893904281"
|
||||||
|
y2="-374.79904413070864" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="572.932966336476" x2="561.3888210767565" y1="-386.3431893904281"
|
||||||
|
y2="-374.79904413070864" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="60.932966336476014" x2="49.388821076756514" y1="-130.3431893904281"
|
||||||
|
y2="-118.79904413070864" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="316.932966336476" x2="305.3888210767565" y1="-130.3431893904281"
|
||||||
|
y2="-118.79904413070864" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="572.932966336476" x2="561.3888210767565" y1="-130.3431893904281"
|
||||||
|
y2="-118.79904413070864" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="60.932966336476014" x2="49.388821076756514" y1="125.65681060957188"
|
||||||
|
y2="137.20095586929136" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="316.932966336476" x2="305.3888210767565" y1="125.65681060957188"
|
||||||
|
y2="137.20095586929136" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="572.932966336476" x2="561.3888210767565" y1="125.65681060957188"
|
||||||
|
y2="137.20095586929136" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="103.78310212459807" x2="35.08486945593138" y1="-2.328164446496814"
|
||||||
|
y2="66.37006822216988" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="103.78310212459807" x2="35.08486945593138" y1="-514.3281644464968"
|
||||||
|
y2="-445.6299317778301" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="359.7831021245981" x2="291.08486945593137" y1="-514.3281644464968"
|
||||||
|
y2="-445.6299317778301" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="615.783102124598" x2="547.0848694559314" y1="-514.3281644464968"
|
||||||
|
y2="-445.6299317778301" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="103.78310212459807" x2="35.08486945593138" y1="-258.3281644464968"
|
||||||
|
y2="-189.6299317778301" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="359.7831021245981" x2="291.08486945593137" y1="-258.3281644464968"
|
||||||
|
y2="-189.6299317778301" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="615.783102124598" x2="547.0848694559314" y1="-258.3281644464968"
|
||||||
|
y2="-189.6299317778301" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="103.78310212459807" x2="35.08486945593138" y1="-2.328164446496814"
|
||||||
|
y2="66.37006822216988" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="359.7831021245981" x2="291.08486945593137" y1="-2.328164446496814"
|
||||||
|
y2="66.37006822216988" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="615.783102124598" x2="547.0848694559314" y1="-2.328164446496814"
|
||||||
|
y2="66.37006822216988" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="103.78310212459807" x2="35.08486945593138" y1="253.67183555350317"
|
||||||
|
y2="322.3700682221699" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="211.69894364075495" x2="194.13528259328754" y1="166.21741462144607"
|
||||||
|
y2="183.78107566891347" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="211.69894364075495" x2="194.13528259328754" y1="-345.7825853785539"
|
||||||
|
y2="-328.21892433108655" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="467.6989436407549" x2="450.13528259328757" y1="-345.7825853785539"
|
||||||
|
y2="-328.21892433108655" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="723.6989436407549" x2="706.1352825932876" y1="-345.7825853785539"
|
||||||
|
y2="-328.21892433108655" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="211.69894364075495" x2="194.13528259328754" y1="-89.78258537855393"
|
||||||
|
y2="-72.21892433108653" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="467.6989436407549" x2="450.13528259328757" y1="-89.78258537855393"
|
||||||
|
y2="-72.21892433108653" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="723.6989436407549" x2="706.1352825932876" y1="-89.78258537855393"
|
||||||
|
y2="-72.21892433108653" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="211.69894364075495" x2="194.13528259328754" y1="166.21741462144607"
|
||||||
|
y2="183.78107566891347" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="467.6989436407549" x2="450.13528259328757" y1="166.21741462144607"
|
||||||
|
y2="183.78107566891347" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="723.6989436407549" x2="706.1352825932876" y1="166.21741462144607"
|
||||||
|
y2="183.78107566891347" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="44.012515207413756" x2="6.2920050630466875" y1="153.79537767995515"
|
||||||
|
y2="191.5158878243222" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="44.012515207413756" x2="6.2920050630466875" y1="-358.20462232004485"
|
||||||
|
y2="-320.4841121756778" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="300.01251520741374" x2="262.2920050630467" y1="-358.20462232004485"
|
||||||
|
y2="-320.4841121756778" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="556.0125152074138" x2="518.2920050630466" y1="-358.20462232004485"
|
||||||
|
y2="-320.4841121756778" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="44.012515207413756" x2="6.2920050630466875" y1="-102.20462232004485"
|
||||||
|
y2="-64.48411217567781" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="300.01251520741374" x2="262.2920050630467" y1="-102.20462232004485"
|
||||||
|
y2="-64.48411217567781" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="556.0125152074138" x2="518.2920050630466" y1="-102.20462232004485"
|
||||||
|
y2="-64.48411217567781" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="44.012515207413756" x2="6.2920050630466875" y1="153.79537767995515"
|
||||||
|
y2="191.5158878243222" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="300.01251520741374" x2="262.2920050630467" y1="153.79537767995515"
|
||||||
|
y2="191.5158878243222" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="556.0125152074138" x2="518.2920050630466" y1="153.79537767995515"
|
||||||
|
y2="191.5158878243222" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="105.49237048043514" x2="31.549625942354083" y1="123.41684480916788"
|
||||||
|
y2="197.35958934724894" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="105.49237048043514" x2="31.549625942354083" y1="-388.58315519083214"
|
||||||
|
y2="-314.64041065275103" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="361.49237048043517" x2="287.54962594235406" y1="-388.58315519083214"
|
||||||
|
y2="-314.64041065275103" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="617.4923704804352" x2="543.549625942354" y1="-388.58315519083214"
|
||||||
|
y2="-314.64041065275103" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="105.49237048043514" x2="31.549625942354083" y1="-132.58315519083212"
|
||||||
|
y2="-58.64041065275106" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="361.49237048043517" x2="287.54962594235406" y1="-132.58315519083212"
|
||||||
|
y2="-58.64041065275106" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="617.4923704804352" x2="543.549625942354" y1="-132.58315519083212"
|
||||||
|
y2="-58.64041065275106" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="105.49237048043514" x2="31.549625942354083" y1="123.41684480916788"
|
||||||
|
y2="197.35958934724894" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="361.49237048043517" x2="287.54962594235406" y1="123.41684480916788"
|
||||||
|
y2="197.35958934724894" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="617.4923704804352" x2="543.549625942354" y1="123.41684480916788"
|
||||||
|
y2="197.35958934724894" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<animateTransform attributeName="transform" type="translate" values="0 0;-256 256"
|
||||||
|
keyTimes="0;1" repeatCount="indefinite" dur="10s"></animateTransform>
|
||||||
|
</g>
|
||||||
|
<g>
|
||||||
|
<line x1="95.73622575770466" x2="50.085335235319484" y1="20.45659654328417"
|
||||||
|
y2="66.10748706566935" stroke-width="15" stroke="#689cc5" stroke-linecap="round"></line>
|
||||||
|
<line x1="95.73622575770466" x2="50.085335235319484" y1="-491.54340345671585"
|
||||||
|
y2="-445.8925129343306" stroke-width="15" stroke="#689cc5" stroke-linecap="round"></line>
|
||||||
|
<line x1="351.7362257577047" x2="306.08533523531946" y1="-491.54340345671585"
|
||||||
|
y2="-445.8925129343306" stroke-width="15" stroke="#689cc5" stroke-linecap="round"></line>
|
||||||
|
<line x1="607.7362257577047" x2="562.0853352353195" y1="-491.54340345671585"
|
||||||
|
y2="-445.8925129343306" stroke-width="15" stroke="#689cc5" stroke-linecap="round"></line>
|
||||||
|
<line x1="95.73622575770466" x2="50.085335235319484" y1="-235.54340345671582"
|
||||||
|
y2="-189.89251293433065" stroke-width="15" stroke="#689cc5" stroke-linecap="round"></line>
|
||||||
|
<line x1="351.7362257577047" x2="306.08533523531946" y1="-235.54340345671582"
|
||||||
|
y2="-189.89251293433065" stroke-width="15" stroke="#689cc5" stroke-linecap="round"></line>
|
||||||
|
<line x1="607.7362257577047" x2="562.0853352353195" y1="-235.54340345671582"
|
||||||
|
y2="-189.89251293433065" stroke-width="15" stroke="#689cc5" stroke-linecap="round"></line>
|
||||||
|
<line x1="95.73622575770466" x2="50.085335235319484" y1="20.45659654328417"
|
||||||
|
y2="66.10748706566935" stroke-width="15" stroke="#689cc5" stroke-linecap="round"></line>
|
||||||
|
<line x1="351.7362257577047" x2="306.08533523531946" y1="20.45659654328417"
|
||||||
|
y2="66.10748706566935" stroke-width="15" stroke="#689cc5" stroke-linecap="round"></line>
|
||||||
|
<line x1="607.7362257577047" x2="562.0853352353195" y1="20.45659654328417"
|
||||||
|
y2="66.10748706566935" stroke-width="15" stroke="#689cc5" stroke-linecap="round"></line>
|
||||||
|
<line x1="263.34308373797757" x2="226.59561736370148" y1="112.42933995479353"
|
||||||
|
y2="149.17680632906962" stroke-width="15" stroke="#689cc5" stroke-linecap="round"></line>
|
||||||
|
<line x1="263.34308373797757" x2="226.59561736370148" y1="-399.57066004520647"
|
||||||
|
y2="-362.8231936709304" stroke-width="15" stroke="#689cc5" stroke-linecap="round"></line>
|
||||||
|
<line x1="519.3430837379776" x2="482.5956173637015" y1="-399.57066004520647"
|
||||||
|
y2="-362.8231936709304" stroke-width="15" stroke="#689cc5" stroke-linecap="round"></line>
|
||||||
|
<line x1="775.3430837379776" x2="738.5956173637014" y1="-399.57066004520647"
|
||||||
|
y2="-362.8231936709304" stroke-width="15" stroke="#689cc5" stroke-linecap="round"></line>
|
||||||
|
<line x1="263.34308373797757" x2="226.59561736370148" y1="-143.57066004520647"
|
||||||
|
y2="-106.82319367093038" stroke-width="15" stroke="#689cc5" stroke-linecap="round"></line>
|
||||||
|
<line x1="519.3430837379776" x2="482.5956173637015" y1="-143.57066004520647"
|
||||||
|
y2="-106.82319367093038" stroke-width="15" stroke="#689cc5" stroke-linecap="round"></line>
|
||||||
|
<line x1="775.3430837379776" x2="738.5956173637014" y1="-143.57066004520647"
|
||||||
|
y2="-106.82319367093038" stroke-width="15" stroke="#689cc5" stroke-linecap="round"></line>
|
||||||
|
<line x1="263.34308373797757" x2="226.59561736370148" y1="112.42933995479353"
|
||||||
|
y2="149.17680632906962" stroke-width="15" stroke="#689cc5" stroke-linecap="round"></line>
|
||||||
|
<line x1="519.3430837379776" x2="482.5956173637015" y1="112.42933995479353"
|
||||||
|
y2="149.17680632906962" stroke-width="15" stroke="#689cc5" stroke-linecap="round"></line>
|
||||||
|
<line x1="775.3430837379776" x2="738.5956173637014" y1="112.42933995479353"
|
||||||
|
y2="149.17680632906962" stroke-width="15" stroke="#689cc5" stroke-linecap="round"></line>
|
||||||
|
<line x1="7.343083737977565" x2="-29.40438263629852" y1="112.42933995479353"
|
||||||
|
y2="149.17680632906962" stroke-width="15" stroke="#689cc5" stroke-linecap="round"></line>
|
||||||
|
<line x1="29.5343611349199" x2="-26.261040392985034" y1="205.16777076655512"
|
||||||
|
y2="260.96317229446004" stroke-width="15" stroke="#689cc5" stroke-linecap="round"></line>
|
||||||
|
<line x1="29.5343611349199" x2="-26.261040392985034" y1="-306.8322292334449"
|
||||||
|
y2="-251.03682770553996" stroke-width="15" stroke="#689cc5" stroke-linecap="round"></line>
|
||||||
|
<line x1="285.5343611349199" x2="229.73895960701498" y1="-306.8322292334449"
|
||||||
|
y2="-251.03682770553996" stroke-width="15" stroke="#689cc5" stroke-linecap="round"></line>
|
||||||
|
<line x1="541.5343611349199" x2="485.738959607015" y1="-306.8322292334449"
|
||||||
|
y2="-251.03682770553996" stroke-width="15" stroke="#689cc5" stroke-linecap="round"></line>
|
||||||
|
<line x1="29.5343611349199" x2="-26.261040392985034" y1="-50.83222923344488"
|
||||||
|
y2="4.963172294460037" stroke-width="15" stroke="#689cc5" stroke-linecap="round"></line>
|
||||||
|
<line x1="285.5343611349199" x2="229.73895960701498" y1="-50.83222923344488"
|
||||||
|
y2="4.963172294460037" stroke-width="15" stroke="#689cc5" stroke-linecap="round"></line>
|
||||||
|
<line x1="541.5343611349199" x2="485.738959607015" y1="-50.83222923344488"
|
||||||
|
y2="4.963172294460037" stroke-width="15" stroke="#689cc5" stroke-linecap="round"></line>
|
||||||
|
<line x1="29.5343611349199" x2="-26.261040392985034" y1="205.16777076655512"
|
||||||
|
y2="260.96317229446004" stroke-width="15" stroke="#689cc5" stroke-linecap="round"></line>
|
||||||
|
<line x1="285.5343611349199" x2="229.73895960701498" y1="205.16777076655512"
|
||||||
|
y2="260.96317229446004" stroke-width="15" stroke="#689cc5" stroke-linecap="round"></line>
|
||||||
|
<line x1="541.5343611349199" x2="485.738959607015" y1="205.16777076655512"
|
||||||
|
y2="260.96317229446004" stroke-width="15" stroke="#689cc5" stroke-linecap="round"></line>
|
||||||
|
<line x1="235.025028503587" x2="173.48946106938683" y1="23.306929884424335"
|
||||||
|
y2="84.84249731862451" stroke-width="15" stroke="#689cc5" stroke-linecap="round"></line>
|
||||||
|
<line x1="235.025028503587" x2="173.48946106938683" y1="-488.69307011557567"
|
||||||
|
y2="-427.1575026813755" stroke-width="15" stroke="#689cc5" stroke-linecap="round"></line>
|
||||||
|
<line x1="491.025028503587" x2="429.48946106938683" y1="-488.69307011557567"
|
||||||
|
y2="-427.1575026813755" stroke-width="15" stroke="#689cc5" stroke-linecap="round"></line>
|
||||||
|
<line x1="747.025028503587" x2="685.4894610693868" y1="-488.69307011557567"
|
||||||
|
y2="-427.1575026813755" stroke-width="15" stroke="#689cc5" stroke-linecap="round"></line>
|
||||||
|
<line x1="235.025028503587" x2="173.48946106938683" y1="-232.69307011557567"
|
||||||
|
y2="-171.1575026813755" stroke-width="15" stroke="#689cc5" stroke-linecap="round"></line>
|
||||||
|
<line x1="491.025028503587" x2="429.48946106938683" y1="-232.69307011557567"
|
||||||
|
y2="-171.1575026813755" stroke-width="15" stroke="#689cc5" stroke-linecap="round"></line>
|
||||||
|
<line x1="747.025028503587" x2="685.4894610693868" y1="-232.69307011557567"
|
||||||
|
y2="-171.1575026813755" stroke-width="15" stroke="#689cc5" stroke-linecap="round"></line>
|
||||||
|
<line x1="235.025028503587" x2="173.48946106938683" y1="23.306929884424335"
|
||||||
|
y2="84.84249731862451" stroke-width="15" stroke="#689cc5" stroke-linecap="round"></line>
|
||||||
|
<line x1="491.025028503587" x2="429.48946106938683" y1="23.306929884424335"
|
||||||
|
y2="84.84249731862451" stroke-width="15" stroke="#689cc5" stroke-linecap="round"></line>
|
||||||
|
<line x1="747.025028503587" x2="685.4894610693868" y1="23.306929884424335"
|
||||||
|
y2="84.84249731862451" stroke-width="15" stroke="#689cc5" stroke-linecap="round"></line>
|
||||||
|
<line x1="225.00990918130768" x2="200.62370409686488" y1="210.1052181599721"
|
||||||
|
y2="234.4914232444149" stroke-width="15" stroke="#689cc5" stroke-linecap="round"></line>
|
||||||
|
<line x1="225.00990918130768" x2="200.62370409686488" y1="-301.8947818400279"
|
||||||
|
y2="-277.50857675558507" stroke-width="15" stroke="#689cc5" stroke-linecap="round"></line>
|
||||||
|
<line x1="481.00990918130765" x2="456.6237040968649" y1="-301.8947818400279"
|
||||||
|
y2="-277.50857675558507" stroke-width="15" stroke="#689cc5" stroke-linecap="round"></line>
|
||||||
|
<line x1="737.0099091813076" x2="712.6237040968649" y1="-301.8947818400279"
|
||||||
|
y2="-277.50857675558507" stroke-width="15" stroke="#689cc5" stroke-linecap="round"></line>
|
||||||
|
<line x1="225.00990918130768" x2="200.62370409686488" y1="-45.89478184002789"
|
||||||
|
y2="-21.508576755585096" stroke-width="15" stroke="#689cc5" stroke-linecap="round"></line>
|
||||||
|
<line x1="481.00990918130765" x2="456.6237040968649" y1="-45.89478184002789"
|
||||||
|
y2="-21.508576755585096" stroke-width="15" stroke="#689cc5" stroke-linecap="round"></line>
|
||||||
|
<line x1="737.0099091813076" x2="712.6237040968649" y1="-45.89478184002789"
|
||||||
|
y2="-21.508576755585096" stroke-width="15" stroke="#689cc5" stroke-linecap="round"></line>
|
||||||
|
<line x1="225.00990918130768" x2="200.62370409686488" y1="210.1052181599721"
|
||||||
|
y2="234.4914232444149" stroke-width="15" stroke="#689cc5" stroke-linecap="round"></line>
|
||||||
|
<line x1="481.00990918130765" x2="456.6237040968649" y1="210.1052181599721"
|
||||||
|
y2="234.4914232444149" stroke-width="15" stroke="#689cc5" stroke-linecap="round"></line>
|
||||||
|
<line x1="737.0099091813076" x2="712.6237040968649" y1="210.1052181599721"
|
||||||
|
y2="234.4914232444149" stroke-width="15" stroke="#689cc5" stroke-linecap="round"></line>
|
||||||
|
<line x1="171.55017713954658" x2="102.05334080042758" y1="78.55895711807653"
|
||||||
|
y2="148.05579345719553" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="171.55017713954658" x2="102.05334080042758" y1="-433.44104288192347"
|
||||||
|
y2="-363.94420654280447" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="427.5501771395466" x2="358.0533408004276" y1="-433.44104288192347"
|
||||||
|
y2="-363.94420654280447" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="683.5501771395466" x2="614.0533408004276" y1="-433.44104288192347"
|
||||||
|
y2="-363.94420654280447" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="171.55017713954658" x2="102.05334080042758" y1="-177.44104288192347"
|
||||||
|
y2="-107.94420654280447" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="427.5501771395466" x2="358.0533408004276" y1="-177.44104288192347"
|
||||||
|
y2="-107.94420654280447" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="683.5501771395466" x2="614.0533408004276" y1="-177.44104288192347"
|
||||||
|
y2="-107.94420654280447" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="171.55017713954658" x2="102.05334080042758" y1="78.55895711807653"
|
||||||
|
y2="148.05579345719553" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="427.5501771395466" x2="358.0533408004276" y1="78.55895711807653"
|
||||||
|
y2="148.05579345719553" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="683.5501771395466" x2="614.0533408004276" y1="78.55895711807653"
|
||||||
|
y2="148.05579345719553" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="258.4358284744095" x2="228.09906783279462" y1="10.646186924515469"
|
||||||
|
y2="40.98294756613034" stroke-width="15" stroke="#689cc5" stroke-linecap="round"></line>
|
||||||
|
<line x1="258.4358284744095" x2="228.09906783279462" y1="-501.35381307548454"
|
||||||
|
y2="-471.01705243386965" stroke-width="15" stroke="#689cc5" stroke-linecap="round"></line>
|
||||||
|
<line x1="514.4358284744095" x2="484.0990678327946" y1="-501.35381307548454"
|
||||||
|
y2="-471.01705243386965" stroke-width="15" stroke="#689cc5" stroke-linecap="round"></line>
|
||||||
|
<line x1="770.4358284744095" x2="740.0990678327946" y1="-501.35381307548454"
|
||||||
|
y2="-471.01705243386965" stroke-width="15" stroke="#689cc5" stroke-linecap="round"></line>
|
||||||
|
<line x1="258.4358284744095" x2="228.09906783279462" y1="-245.35381307548454"
|
||||||
|
y2="-215.01705243386965" stroke-width="15" stroke="#689cc5" stroke-linecap="round"></line>
|
||||||
|
<line x1="514.4358284744095" x2="484.0990678327946" y1="-245.35381307548454"
|
||||||
|
y2="-215.01705243386965" stroke-width="15" stroke="#689cc5" stroke-linecap="round"></line>
|
||||||
|
<line x1="770.4358284744095" x2="740.0990678327946" y1="-245.35381307548454"
|
||||||
|
y2="-215.01705243386965" stroke-width="15" stroke="#689cc5" stroke-linecap="round"></line>
|
||||||
|
<line x1="258.4358284744095" x2="228.09906783279462" y1="10.646186924515469"
|
||||||
|
y2="40.98294756613034" stroke-width="15" stroke="#689cc5" stroke-linecap="round"></line>
|
||||||
|
<line x1="514.4358284744095" x2="484.0990678327946" y1="10.646186924515469"
|
||||||
|
y2="40.98294756613034" stroke-width="15" stroke="#689cc5" stroke-linecap="round"></line>
|
||||||
|
<line x1="770.4358284744095" x2="740.0990678327946" y1="10.646186924515469"
|
||||||
|
y2="40.98294756613034" stroke-width="15" stroke="#689cc5" stroke-linecap="round"></line>
|
||||||
|
<line x1="2.4358284744095045" x2="-27.900932167205383" y1="10.646186924515469"
|
||||||
|
y2="40.98294756613034" stroke-width="15" stroke="#689cc5" stroke-linecap="round"></line>
|
||||||
|
<line x1="35.41624886616098" x2="-5.966808810922494" y1="10.151780697595989"
|
||||||
|
y2="51.53483837467946" stroke-width="15" stroke="#689cc5" stroke-linecap="round"></line>
|
||||||
|
<line x1="35.41624886616098" x2="-5.966808810922494" y1="-501.848219302404"
|
||||||
|
y2="-460.46516162532055" stroke-width="15" stroke="#689cc5" stroke-linecap="round"></line>
|
||||||
|
<line x1="291.41624886616097" x2="250.0331911890775" y1="-501.848219302404"
|
||||||
|
y2="-460.46516162532055" stroke-width="15" stroke="#689cc5" stroke-linecap="round"></line>
|
||||||
|
<line x1="547.416248866161" x2="506.0331911890775" y1="-501.848219302404"
|
||||||
|
y2="-460.46516162532055" stroke-width="15" stroke="#689cc5" stroke-linecap="round"></line>
|
||||||
|
<line x1="35.41624886616098" x2="-5.966808810922494" y1="-245.848219302404"
|
||||||
|
y2="-204.46516162532055" stroke-width="15" stroke="#689cc5" stroke-linecap="round"></line>
|
||||||
|
<line x1="291.41624886616097" x2="250.0331911890775" y1="-245.848219302404"
|
||||||
|
y2="-204.46516162532055" stroke-width="15" stroke="#689cc5" stroke-linecap="round"></line>
|
||||||
|
<line x1="547.416248866161" x2="506.0331911890775" y1="-245.848219302404"
|
||||||
|
y2="-204.46516162532055" stroke-width="15" stroke="#689cc5" stroke-linecap="round"></line>
|
||||||
|
<line x1="35.41624886616098" x2="-5.966808810922494" y1="10.151780697595989"
|
||||||
|
y2="51.53483837467946" stroke-width="15" stroke="#689cc5" stroke-linecap="round"></line>
|
||||||
|
<line x1="291.41624886616097" x2="250.0331911890775" y1="10.151780697595989"
|
||||||
|
y2="51.53483837467946" stroke-width="15" stroke="#689cc5" stroke-linecap="round"></line>
|
||||||
|
<line x1="547.416248866161" x2="506.0331911890775" y1="10.151780697595989"
|
||||||
|
y2="51.53483837467946" stroke-width="15" stroke="#689cc5" stroke-linecap="round"></line>
|
||||||
|
<line x1="90.76285286976488" x2="72.92514980496989" y1="79.79001478147771"
|
||||||
|
y2="97.6277178462727" stroke-width="15" stroke="#5e6fa3" stroke-linecap="round"></line>
|
||||||
|
<line x1="90.76285286976488" x2="72.92514980496989" y1="-432.2099852185223"
|
||||||
|
y2="-414.37228215372727" stroke-width="15" stroke="#5e6fa3" stroke-linecap="round"></line>
|
||||||
|
<line x1="346.76285286976486" x2="328.9251498049699" y1="-432.2099852185223"
|
||||||
|
y2="-414.37228215372727" stroke-width="15" stroke="#5e6fa3" stroke-linecap="round"></line>
|
||||||
|
<line x1="602.7628528697649" x2="584.9251498049699" y1="-432.2099852185223"
|
||||||
|
y2="-414.37228215372727" stroke-width="15" stroke="#5e6fa3" stroke-linecap="round"></line>
|
||||||
|
<line x1="90.76285286976488" x2="72.92514980496989" y1="-176.2099852185223"
|
||||||
|
y2="-158.3722821537273" stroke-width="15" stroke="#5e6fa3" stroke-linecap="round"></line>
|
||||||
|
<line x1="346.76285286976486" x2="328.9251498049699" y1="-176.2099852185223"
|
||||||
|
y2="-158.3722821537273" stroke-width="15" stroke="#5e6fa3" stroke-linecap="round"></line>
|
||||||
|
<line x1="602.7628528697649" x2="584.9251498049699" y1="-176.2099852185223"
|
||||||
|
y2="-158.3722821537273" stroke-width="15" stroke="#5e6fa3" stroke-linecap="round"></line>
|
||||||
|
<line x1="90.76285286976488" x2="72.92514980496989" y1="79.79001478147771"
|
||||||
|
y2="97.6277178462727" stroke-width="15" stroke="#5e6fa3" stroke-linecap="round"></line>
|
||||||
|
<line x1="346.76285286976486" x2="328.9251498049699" y1="79.79001478147771"
|
||||||
|
y2="97.6277178462727" stroke-width="15" stroke="#5e6fa3" stroke-linecap="round"></line>
|
||||||
|
<line x1="602.7628528697649" x2="584.9251498049699" y1="79.79001478147771"
|
||||||
|
y2="97.6277178462727" stroke-width="15" stroke="#5e6fa3" stroke-linecap="round"></line>
|
||||||
|
<animateTransform attributeName="transform" type="translate" values="0 0;-256 256"
|
||||||
|
keyTimes="0;1" repeatCount="indefinite" dur="5s"></animateTransform>
|
||||||
|
</g>
|
||||||
|
<g>
|
||||||
|
<line x1="93.6896305353637" x2="75.71575147590588" y1="83.83758835275793"
|
||||||
|
y2="101.81146741221576" stroke-width="15" stroke="#5e6fa3" stroke-linecap="round"></line>
|
||||||
|
<line x1="93.6896305353637" x2="75.71575147590588" y1="-428.16241164724204"
|
||||||
|
y2="-410.18853258778427" stroke-width="15" stroke="#5e6fa3" stroke-linecap="round"></line>
|
||||||
|
<line x1="349.6896305353637" x2="331.7157514759059" y1="-428.16241164724204"
|
||||||
|
y2="-410.18853258778427" stroke-width="15" stroke="#5e6fa3" stroke-linecap="round"></line>
|
||||||
|
<line x1="605.6896305353637" x2="587.7157514759059" y1="-428.16241164724204"
|
||||||
|
y2="-410.18853258778427" stroke-width="15" stroke="#5e6fa3" stroke-linecap="round"></line>
|
||||||
|
<line x1="93.6896305353637" x2="75.71575147590588" y1="-172.16241164724207"
|
||||||
|
y2="-154.18853258778424" stroke-width="15" stroke="#5e6fa3" stroke-linecap="round"></line>
|
||||||
|
<line x1="349.6896305353637" x2="331.7157514759059" y1="-172.16241164724207"
|
||||||
|
y2="-154.18853258778424" stroke-width="15" stroke="#5e6fa3" stroke-linecap="round"></line>
|
||||||
|
<line x1="605.6896305353637" x2="587.7157514759059" y1="-172.16241164724207"
|
||||||
|
y2="-154.18853258778424" stroke-width="15" stroke="#5e6fa3" stroke-linecap="round"></line>
|
||||||
|
<line x1="93.6896305353637" x2="75.71575147590588" y1="83.83758835275793"
|
||||||
|
y2="101.81146741221576" stroke-width="15" stroke="#5e6fa3" stroke-linecap="round"></line>
|
||||||
|
<line x1="349.6896305353637" x2="331.7157514759059" y1="83.83758835275793"
|
||||||
|
y2="101.81146741221576" stroke-width="15" stroke="#5e6fa3" stroke-linecap="round"></line>
|
||||||
|
<line x1="605.6896305353637" x2="587.7157514759059" y1="83.83758835275793"
|
||||||
|
y2="101.81146741221576" stroke-width="15" stroke="#5e6fa3" stroke-linecap="round"></line>
|
||||||
|
<line x1="207.24941141296466" x2="167.48134532138562" y1="234.55973050121918"
|
||||||
|
y2="274.3277965927982" stroke-width="15" stroke="#5e6fa3" stroke-linecap="round"></line>
|
||||||
|
<line x1="207.24941141296466" x2="167.48134532138562" y1="-277.4402694987808"
|
||||||
|
y2="-237.67220340720178" stroke-width="15" stroke="#5e6fa3" stroke-linecap="round"></line>
|
||||||
|
<line x1="463.24941141296466" x2="423.4813453213856" y1="-277.4402694987808"
|
||||||
|
y2="-237.67220340720178" stroke-width="15" stroke="#5e6fa3" stroke-linecap="round"></line>
|
||||||
|
<line x1="719.2494114129647" x2="679.4813453213856" y1="-277.4402694987808"
|
||||||
|
y2="-237.67220340720178" stroke-width="15" stroke="#5e6fa3" stroke-linecap="round"></line>
|
||||||
|
<line x1="207.24941141296466" x2="167.48134532138562" y1="-21.440269498780822"
|
||||||
|
y2="18.327796592798222" stroke-width="15" stroke="#5e6fa3" stroke-linecap="round"></line>
|
||||||
|
<line x1="463.24941141296466" x2="423.4813453213856" y1="-21.440269498780822"
|
||||||
|
y2="18.327796592798222" stroke-width="15" stroke="#5e6fa3" stroke-linecap="round"></line>
|
||||||
|
<line x1="719.2494114129647" x2="679.4813453213856" y1="-21.440269498780822"
|
||||||
|
y2="18.327796592798222" stroke-width="15" stroke="#5e6fa3" stroke-linecap="round"></line>
|
||||||
|
<line x1="207.24941141296466" x2="167.48134532138562" y1="234.55973050121918"
|
||||||
|
y2="274.3277965927982" stroke-width="15" stroke="#5e6fa3" stroke-linecap="round"></line>
|
||||||
|
<line x1="463.24941141296466" x2="423.4813453213856" y1="234.55973050121918"
|
||||||
|
y2="274.3277965927982" stroke-width="15" stroke="#5e6fa3" stroke-linecap="round"></line>
|
||||||
|
<line x1="719.2494114129647" x2="679.4813453213856" y1="234.55973050121918"
|
||||||
|
y2="274.3277965927982" stroke-width="15" stroke="#5e6fa3" stroke-linecap="round"></line>
|
||||||
|
<line x1="69.19671201083756" x2="20.15599089926107" y1="61.52941038272999"
|
||||||
|
y2="110.57013149430648" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="69.19671201083756" x2="20.15599089926107" y1="-450.47058961727"
|
||||||
|
y2="-401.42986850569355" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="325.1967120108376" x2="276.15599089926104" y1="-450.47058961727"
|
||||||
|
y2="-401.42986850569355" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="581.1967120108376" x2="532.155990899261" y1="-450.47058961727"
|
||||||
|
y2="-401.42986850569355" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="69.19671201083756" x2="20.15599089926107" y1="-194.47058961727"
|
||||||
|
y2="-145.42986850569352" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="325.1967120108376" x2="276.15599089926104" y1="-194.47058961727"
|
||||||
|
y2="-145.42986850569352" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="581.1967120108376" x2="532.155990899261" y1="-194.47058961727"
|
||||||
|
y2="-145.42986850569352" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="69.19671201083756" x2="20.15599089926107" y1="61.52941038272999"
|
||||||
|
y2="110.57013149430648" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="325.1967120108376" x2="276.15599089926104" y1="61.52941038272999"
|
||||||
|
y2="110.57013149430648" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="581.1967120108376" x2="532.155990899261" y1="61.52941038272999"
|
||||||
|
y2="110.57013149430648" stroke-width="15" stroke="#93dbe9" stroke-linecap="round"></line>
|
||||||
|
<line x1="153.36870174443493" x2="103.52218176454608" y1="129.93915864820679"
|
||||||
|
y2="179.78567862809564" stroke-width="15" stroke="#5e6fa3" stroke-linecap="round"></line>
|
||||||
|
<line x1="153.36870174443493" x2="103.52218176454608" y1="-382.0608413517932"
|
||||||
|
y2="-332.21432137190436" stroke-width="15" stroke="#5e6fa3" stroke-linecap="round"></line>
|
||||||
|
<line x1="409.36870174443493" x2="359.5221817645461" y1="-382.0608413517932"
|
||||||
|
y2="-332.21432137190436" stroke-width="15" stroke="#5e6fa3" stroke-linecap="round"></line>
|
||||||
|
<line x1="665.3687017444349" x2="615.5221817645461" y1="-382.0608413517932"
|
||||||
|
y2="-332.21432137190436" stroke-width="15" stroke="#5e6fa3" stroke-linecap="round"></line>
|
||||||
|
<line x1="153.36870174443493" x2="103.52218176454608" y1="-126.06084135179321"
|
||||||
|
y2="-76.21432137190436" stroke-width="15" stroke="#5e6fa3" stroke-linecap="round"></line>
|
||||||
|
<line x1="409.36870174443493" x2="359.5221817645461" y1="-126.06084135179321"
|
||||||
|
y2="-76.21432137190436" stroke-width="15" stroke="#5e6fa3" stroke-linecap="round"></line>
|
||||||
|
<line x1="665.3687017444349" x2="615.5221817645461" y1="-126.06084135179321"
|
||||||
|
y2="-76.21432137190436" stroke-width="15" stroke="#5e6fa3" stroke-linecap="round"></line>
|
||||||
|
<line x1="153.36870174443493" x2="103.52218176454608" y1="129.93915864820679"
|
||||||
|
y2="179.78567862809564" stroke-width="15" stroke="#5e6fa3" stroke-linecap="round"></line>
|
||||||
|
<line x1="409.36870174443493" x2="359.5221817645461" y1="129.93915864820679"
|
||||||
|
y2="179.78567862809564" stroke-width="15" stroke="#5e6fa3" stroke-linecap="round"></line>
|
||||||
|
<line x1="665.3687017444349" x2="615.5221817645461" y1="129.93915864820679"
|
||||||
|
y2="179.78567862809564" stroke-width="15" stroke="#5e6fa3" stroke-linecap="round"></line>
|
||||||
|
<line x1="49.20494471467643" x2="2.7142059537850685" y1="141.75997600855746"
|
||||||
|
y2="188.25071476944882" stroke-width="15" stroke="#5e6fa3" stroke-linecap="round"></line>
|
||||||
|
<line x1="49.20494471467643" x2="2.7142059537850685" y1="-370.2400239914425"
|
||||||
|
y2="-323.7492852305512" stroke-width="15" stroke="#5e6fa3" stroke-linecap="round"></line>
|
||||||
|
<line x1="305.20494471467646" x2="258.71420595378504" y1="-370.2400239914425"
|
||||||
|
y2="-323.7492852305512" stroke-width="15" stroke="#5e6fa3" stroke-linecap="round"></line>
|
||||||
|
<line x1="561.2049447146765" x2="514.714205953785" y1="-370.2400239914425"
|
||||||
|
y2="-323.7492852305512" stroke-width="15" stroke="#5e6fa3" stroke-linecap="round"></line>
|
||||||
|
<line x1="49.20494471467643" x2="2.7142059537850685" y1="-114.24002399144254"
|
||||||
|
y2="-67.74928523055118" stroke-width="15" stroke="#5e6fa3" stroke-linecap="round"></line>
|
||||||
|
<line x1="305.20494471467646" x2="258.71420595378504" y1="-114.24002399144254"
|
||||||
|
y2="-67.74928523055118" stroke-width="15" stroke="#5e6fa3" stroke-linecap="round"></line>
|
||||||
|
<line x1="561.2049447146765" x2="514.714205953785" y1="-114.24002399144254"
|
||||||
|
y2="-67.74928523055118" stroke-width="15" stroke="#5e6fa3" stroke-linecap="round"></line>
|
||||||
|
<line x1="49.20494471467643" x2="2.7142059537850685" y1="141.75997600855746"
|
||||||
|
y2="188.25071476944882" stroke-width="15" stroke="#5e6fa3" stroke-linecap="round"></line>
|
||||||
|
<line x1="305.20494471467646" x2="258.71420595378504" y1="141.75997600855746"
|
||||||
|
y2="188.25071476944882" stroke-width="15" stroke="#5e6fa3" stroke-linecap="round"></line>
|
||||||
|
<line x1="561.2049447146765" x2="514.714205953785" y1="141.75997600855746"
|
||||||
|
y2="188.25071476944882" stroke-width="15" stroke="#5e6fa3" stroke-linecap="round"></line>
|
||||||
|
<line x1="84.6808460539986" x2="32.68305955000314" y1="-7.711036017440037"
|
||||||
|
y2="44.28675048655542" stroke-width="15" stroke="#689cc5" stroke-linecap="round"></line>
|
||||||
|
<line x1="84.6808460539986" x2="32.68305955000314" y1="-519.71103601744"
|
||||||
|
y2="-467.71324951344457" stroke-width="15" stroke="#689cc5" stroke-linecap="round"></line>
|
||||||
|
<line x1="340.6808460539986" x2="288.6830595500031" y1="-519.71103601744"
|
||||||
|
y2="-467.71324951344457" stroke-width="15" stroke="#689cc5" stroke-linecap="round"></line>
|
||||||
|
<line x1="596.6808460539986" x2="544.6830595500031" y1="-519.71103601744"
|
||||||
|
y2="-467.71324951344457" stroke-width="15" stroke="#689cc5" stroke-linecap="round"></line>
|
||||||
|
<line x1="84.6808460539986" x2="32.68305955000314" y1="-263.71103601744005"
|
||||||
|
y2="-211.71324951344457" stroke-width="15" stroke="#689cc5" stroke-linecap="round"></line>
|
||||||
|
<line x1="340.6808460539986" x2="288.6830595500031" y1="-263.71103601744005"
|
||||||
|
y2="-211.71324951344457" stroke-width="15" stroke="#689cc5" stroke-linecap="round"></line>
|
||||||
|
<line x1="596.6808460539986" x2="544.6830595500031" y1="-263.71103601744005"
|
||||||
|
y2="-211.71324951344457" stroke-width="15" stroke="#689cc5" stroke-linecap="round"></line>
|
||||||
|
<line x1="84.6808460539986" x2="32.68305955000314" y1="-7.711036017440037"
|
||||||
|
y2="44.28675048655542" stroke-width="15" stroke="#689cc5" stroke-linecap="round"></line>
|
||||||
|
<line x1="340.6808460539986" x2="288.6830595500031" y1="-7.711036017440037"
|
||||||
|
y2="44.28675048655542" stroke-width="15" stroke="#689cc5" stroke-linecap="round"></line>
|
||||||
|
<line x1="596.6808460539986" x2="544.6830595500031" y1="-7.711036017440037"
|
||||||
|
y2="44.28675048655542" stroke-width="15" stroke="#689cc5" stroke-linecap="round"></line>
|
||||||
|
<line x1="84.6808460539986" x2="32.68305955000314" y1="248.28896398255995"
|
||||||
|
y2="300.28675048655543" stroke-width="15" stroke="#689cc5" stroke-linecap="round"></line>
|
||||||
|
<line x1="225.38342310559023" x2="185.66602314192056" y1="109.68961591653738"
|
||||||
|
y2="149.40701588020704" stroke-width="15" stroke="#5e6fa3" stroke-linecap="round"></line>
|
||||||
|
<line x1="225.38342310559023" x2="185.66602314192056" y1="-402.3103840834626"
|
||||||
|
y2="-362.59298411979296" stroke-width="15" stroke="#5e6fa3" stroke-linecap="round"></line>
|
||||||
|
<line x1="481.3834231055902" x2="441.66602314192056" y1="-402.3103840834626"
|
||||||
|
y2="-362.59298411979296" stroke-width="15" stroke="#5e6fa3" stroke-linecap="round"></line>
|
||||||
|
<line x1="737.3834231055903" x2="697.6660231419205" y1="-402.3103840834626"
|
||||||
|
y2="-362.59298411979296" stroke-width="15" stroke="#5e6fa3" stroke-linecap="round"></line>
|
||||||
|
<line x1="225.38342310559023" x2="185.66602314192056" y1="-146.31038408346262"
|
||||||
|
y2="-106.59298411979296" stroke-width="15" stroke="#5e6fa3" stroke-linecap="round"></line>
|
||||||
|
<line x1="481.3834231055902" x2="441.66602314192056" y1="-146.31038408346262"
|
||||||
|
y2="-106.59298411979296" stroke-width="15" stroke="#5e6fa3" stroke-linecap="round"></line>
|
||||||
|
<line x1="737.3834231055903" x2="697.6660231419205" y1="-146.31038408346262"
|
||||||
|
y2="-106.59298411979296" stroke-width="15" stroke="#5e6fa3" stroke-linecap="round"></line>
|
||||||
|
<line x1="225.38342310559023" x2="185.66602314192056" y1="109.68961591653738"
|
||||||
|
y2="149.40701588020704" stroke-width="15" stroke="#5e6fa3" stroke-linecap="round"></line>
|
||||||
|
<line x1="481.3834231055902" x2="441.66602314192056" y1="109.68961591653738"
|
||||||
|
y2="149.40701588020704" stroke-width="15" stroke="#5e6fa3" stroke-linecap="round"></line>
|
||||||
|
<line x1="737.3834231055903" x2="697.6660231419205" y1="109.68961591653738"
|
||||||
|
y2="149.40701588020704" stroke-width="15" stroke="#5e6fa3" stroke-linecap="round"></line>
|
||||||
|
<line x1="172.83662370669697" x2="103.52581079778793" y1="164.45975635392284"
|
||||||
|
y2="233.77056926283188" stroke-width="15" stroke="#5e6fa3" stroke-linecap="round"></line>
|
||||||
|
<line x1="172.83662370669697" x2="103.52581079778793" y1="-347.54024364607716"
|
||||||
|
y2="-278.2294307371681" stroke-width="15" stroke="#5e6fa3" stroke-linecap="round"></line>
|
||||||
|
<line x1="428.83662370669697" x2="359.5258107977879" y1="-347.54024364607716"
|
||||||
|
y2="-278.2294307371681" stroke-width="15" stroke="#5e6fa3" stroke-linecap="round"></line>
|
||||||
|
<line x1="684.836623706697" x2="615.5258107977879" y1="-347.54024364607716"
|
||||||
|
y2="-278.2294307371681" stroke-width="15" stroke="#5e6fa3" stroke-linecap="round"></line>
|
||||||
|
<line x1="172.83662370669697" x2="103.52581079778793" y1="-91.54024364607716"
|
||||||
|
y2="-22.229430737168116" stroke-width="15" stroke="#5e6fa3" stroke-linecap="round"></line>
|
||||||
|
<line x1="428.83662370669697" x2="359.5258107977879" y1="-91.54024364607716"
|
||||||
|
y2="-22.229430737168116" stroke-width="15" stroke="#5e6fa3" stroke-linecap="round"></line>
|
||||||
|
<line x1="684.836623706697" x2="615.5258107977879" y1="-91.54024364607716"
|
||||||
|
y2="-22.229430737168116" stroke-width="15" stroke="#5e6fa3" stroke-linecap="round"></line>
|
||||||
|
<line x1="172.83662370669697" x2="103.52581079778793" y1="164.45975635392284"
|
||||||
|
y2="233.77056926283188" stroke-width="15" stroke="#5e6fa3" stroke-linecap="round"></line>
|
||||||
|
<line x1="428.83662370669697" x2="359.5258107977879" y1="164.45975635392284"
|
||||||
|
y2="233.77056926283188" stroke-width="15" stroke="#5e6fa3" stroke-linecap="round"></line>
|
||||||
|
<line x1="684.836623706697" x2="615.5258107977879" y1="164.45975635392284"
|
||||||
|
y2="233.77056926283188" stroke-width="15" stroke="#5e6fa3" stroke-linecap="round"></line>
|
||||||
|
<line x1="254.85435949520382" x2="240.10841684705935" y1="-1.209429949430282"
|
||||||
|
y2="13.536512698714214" stroke-width="15" stroke="#5e6fa3" stroke-linecap="round"></line>
|
||||||
|
<line x1="254.85435949520382" x2="240.10841684705935" y1="-513.2094299494303"
|
||||||
|
y2="-498.4634873012858" stroke-width="15" stroke="#5e6fa3" stroke-linecap="round"></line>
|
||||||
|
<line x1="510.8543594952038" x2="496.10841684705935" y1="-513.2094299494303"
|
||||||
|
y2="-498.4634873012858" stroke-width="15" stroke="#5e6fa3" stroke-linecap="round"></line>
|
||||||
|
<line x1="766.8543594952039" x2="752.1084168470593" y1="-513.2094299494303"
|
||||||
|
y2="-498.4634873012858" stroke-width="15" stroke="#5e6fa3" stroke-linecap="round"></line>
|
||||||
|
<line x1="254.85435949520382" x2="240.10841684705935" y1="-257.2094299494303"
|
||||||
|
y2="-242.4634873012858" stroke-width="15" stroke="#5e6fa3" stroke-linecap="round"></line>
|
||||||
|
<line x1="510.8543594952038" x2="496.10841684705935" y1="-257.2094299494303"
|
||||||
|
y2="-242.4634873012858" stroke-width="15" stroke="#5e6fa3" stroke-linecap="round"></line>
|
||||||
|
<line x1="766.8543594952039" x2="752.1084168470593" y1="-257.2094299494303"
|
||||||
|
y2="-242.4634873012858" stroke-width="15" stroke="#5e6fa3" stroke-linecap="round"></line>
|
||||||
|
<line x1="254.85435949520382" x2="240.10841684705935" y1="-1.209429949430282"
|
||||||
|
y2="13.536512698714214" stroke-width="15" stroke="#5e6fa3" stroke-linecap="round"></line>
|
||||||
|
<line x1="510.8543594952038" x2="496.10841684705935" y1="-1.209429949430282"
|
||||||
|
y2="13.536512698714214" stroke-width="15" stroke="#5e6fa3" stroke-linecap="round"></line>
|
||||||
|
<line x1="766.8543594952039" x2="752.1084168470593" y1="-1.209429949430282"
|
||||||
|
y2="13.536512698714214" stroke-width="15" stroke="#5e6fa3" stroke-linecap="round"></line>
|
||||||
|
<line x1="254.85435949520382" x2="240.10841684705935" y1="254.79057005056973"
|
||||||
|
y2="269.5365126987142" stroke-width="15" stroke="#5e6fa3" stroke-linecap="round"></line>
|
||||||
|
<animateTransform attributeName="transform" type="translate" values="0 0;-256 256"
|
||||||
|
keyTimes="0;1" repeatCount="indefinite" dur="10.3333333333333335s"></animateTransform>
|
||||||
|
</g>
|
||||||
|
</g>
|
||||||
|
</pattern>
|
||||||
|
</defs>
|
||||||
|
<rect x="0" y="0" width="1084" height="322" fill="url(#pid-0.7735807359934106)"></rect>
|
||||||
|
</svg>
|
10
assets/img/featured.svg
Normal file
|
@ -0,0 +1,10 @@
|
||||||
|
<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" style="margin:auto;background:rgba(NaN, NaN, NaN, 0);display:block;z-index:1;position:relative" width="1084" height="322" preserveAspectRatio="xMidYMid" viewBox="0 0 1084 322">
|
||||||
|
<defs>
|
||||||
|
<pattern id="pid-0.932876709489723" x="0" y="0" width="307.20000000000005" height="307.20000000000005" patternUnits="userSpaceOnUse">
|
||||||
|
<g transform="scale(1.2000000000000002)"><defs><g id="pat-0.13086180692764704"><polyline fill-rule="evenodd" clip-rule="evenodd" fill="none" stroke="#93dbe9" stroke-width="10" stroke-linecap="round" stroke-linejoin="round" stroke-miterlimit="10" points=" -3,-2 16.5,15.5 31.5,0.5 63.5,32.5 48.5,47.5 31.5,32.5 -0.5,64.5 16.5,79.5 31.5,64.5 47.5,79.5 95.5,32.5 80.5,15.5 95.5,0.5 127.5,32.5 48.5,111.5 31.5,96.5 -0.5,128.5 16.5,143.5 31.5,127.5 63.5,160.5 80.5,143.5 63.5,128.5 159.5,32.5 144.5,15.5 159.5,0.5 175.5,16.5 192,0 208,16 224,0 256,32 240,48 224,32 207.501,48.501 223.5,64.5 207.5,80.5 176.5,47.5 144.5,80.5 159.5,96.5 175.5,80.5 191.5,96.5 159.5,128.5 127.5,96.5 95.5,127.5 111.5,143.5 127.5,127.5 175.5,176.5 159.5,192.5 127.5,160.5 111.5,176.5 95.5,160.5 63.5,192.5 31.5,160.5 16.5,175.5 31.999,191.483 0,224 16,240 32,225 64,256 80,240 64,224 79.667,208.333 95.5,192.5 111.5,207.5 95.5,224.5 111.5,239.5 127.5,256.5 143.5,240.5 127.5,224.5 143.5,208.5 175.5,240.5 191.5,224.5 175.5,208.5 207.5,176.5 224,160 208,144 191.998,160.998 175.5,144.5 207.5,112.5 240,80 256,96 223.5,128.5 256,160 239.5,176.5 256,192 240,208 224,192 207.5,208.5 223.5,224.5 207.5,240.5 223.5,256.5 240,240 259,259" stroke-dasharray="169.36095947265625 20.93225341796875 169.36095947265625 20.93225341796875 169.36095947265625 20.93225341796875 169.36095947265625 20.93225341796875 169.36095947265625 20.93225341796875 169.36095947265625 20.93225341796875 169.36095947265625 20.93225341796875 169.36095947265625 20.93225341796875 169.36095947265625 20.93225341796875 169.36095947265625 20.93225341796875 169.36095947265625 20.93225341796875 169.36095947265625 20.93225341796875 169.36095947265625 20.93225341796875 169.36095947265625 20.93225341796875 169.36095947265625 20.93225341796875">
|
||||||
|
<animate attributeName="stroke-dashoffset" keyTimes="0;1" values="0;190.293212890625" repeatCount="indefinite" dur="7.142857142857142s"></animate>
|
||||||
|
</polyline></g></defs><use xlink:href="#pat-0.13086180692764704" x="0" y="0"></use><use xlink:href="#pat-0.13086180692764704" x="-256" y="0"></use><use xlink:href="#pat-0.13086180692764704" x="256" y="0"></use><use xlink:href="#pat-0.13086180692764704" x="0" y="-256"></use><use xlink:href="#pat-0.13086180692764704" x="0" y="256"></use></g>
|
||||||
|
</pattern>
|
||||||
|
</defs>
|
||||||
|
<rect x="0" y="0" width="1084" height="322" fill="url(#pid-0.932876709489723)"></rect>
|
||||||
|
</svg>
|
After Width: | Height: | Size: 2.7 KiB |
2312
assets/img/fireflies.svg
Normal file
After Width: | Height: | Size: 198 KiB |
24
assets/img/lavalamp.svg
Normal file
After Width: | Height: | Size: 27 KiB |
17
assets/img/rain.svg
Normal file
After Width: | Height: | Size: 85 KiB |
257
assets/img/ripples.svg
Normal file
|
@ -0,0 +1,257 @@
|
||||||
|
<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" style="margin:auto;background:rgba(NaN, NaN, NaN, 0);display:block;z-index:1;position:relative" width="1084" height="322" preserveAspectRatio="xMidYMid" viewBox="0 0 1084 322">
|
||||||
|
<defs>
|
||||||
|
<pattern id="pid-0.2950529742247572" x="0" y="0" width="711.6800000000001" height="711.6800000000001" patternUnits="userSpaceOnUse">
|
||||||
|
<g transform="scale(2.7800000000000002)"><circle cx="180.39755796770348" cy="144.2104368598822" r="0" fill="none" stroke="#5e6fa3" stroke-width="8">
|
||||||
|
<animate attributeName="r" values="0;17.85434406280291" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="12.5s" begin="-44.622752456562516s"></animate>
|
||||||
|
<animate attributeName="opacity" values="1;0" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="12.5s" begin="-44.622752456562516s"></animate>
|
||||||
|
</circle><circle cx="16.825168708189995" cy="32.834595161139454" r="0" fill="none" stroke="#5e6fa3" stroke-width="8">
|
||||||
|
<animate attributeName="r" values="0;50.39487920677064" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="12.5s" begin="-35.52246651250024s"></animate>
|
||||||
|
<animate attributeName="opacity" values="1;0" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="12.5s" begin="-35.52246651250024s"></animate>
|
||||||
|
</circle><circle cx="272.82516870819" cy="32.834595161139454" r="0" fill="none" stroke="#5e6fa3" stroke-width="8">
|
||||||
|
<animate attributeName="r" values="0;50.39487920677064" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="12.5s" begin="-35.52246651250024s"></animate>
|
||||||
|
<animate attributeName="opacity" values="1;0" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="12.5s" begin="-35.52246651250024s"></animate>
|
||||||
|
</circle><circle cx="16.825168708189995" cy="288.8345951611395" r="0" fill="none" stroke="#5e6fa3" stroke-width="8">
|
||||||
|
<animate attributeName="r" values="0;50.39487920677064" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="12.5s" begin="-35.52246651250024s"></animate>
|
||||||
|
<animate attributeName="opacity" values="1;0" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="12.5s" begin="-35.52246651250024s"></animate>
|
||||||
|
</circle><circle cx="272.82516870819" cy="288.8345951611395" r="0" fill="none" stroke="#5e6fa3" stroke-width="8">
|
||||||
|
<animate attributeName="r" values="0;50.39487920677064" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="12.5s" begin="-35.52246651250024s"></animate>
|
||||||
|
<animate attributeName="opacity" values="1;0" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="12.5s" begin="-35.52246651250024s"></animate>
|
||||||
|
</circle><circle cx="133.7281341523537" cy="37.557212373233874" r="0" fill="none" stroke="#689cc5" stroke-width="8">
|
||||||
|
<animate attributeName="r" values="0;24.44944303845901" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="16.666666666666668s" begin="-33.76558939460953s"></animate>
|
||||||
|
<animate attributeName="opacity" values="1;0" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="16.666666666666668s" begin="-33.76558939460953s"></animate>
|
||||||
|
</circle><circle cx="9.311746119524932" cy="139.87259197506899" r="0" fill="none" stroke="#689cc5" stroke-width="8">
|
||||||
|
<animate attributeName="r" values="0;42.09217911991696" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="25s" begin="-16.268240533907207s"></animate>
|
||||||
|
<animate attributeName="opacity" values="1;0" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="25s" begin="-16.268240533907207s"></animate>
|
||||||
|
</circle><circle cx="265.3117461195249" cy="139.87259197506899" r="0" fill="none" stroke="#689cc5" stroke-width="8">
|
||||||
|
<animate attributeName="r" values="0;42.09217911991696" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="25s" begin="-16.268240533907207s"></animate>
|
||||||
|
<animate attributeName="opacity" values="1;0" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="25s" begin="-16.268240533907207s"></animate>
|
||||||
|
</circle><circle cx="228.8288862878399" cy="50.59785782429598" r="0" fill="none" stroke="#93dbe9" stroke-width="8">
|
||||||
|
<animate attributeName="r" values="0;19.868262625397918" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="16.666666666666668s" begin="-23.68489264848651s"></animate>
|
||||||
|
<animate attributeName="opacity" values="1;0" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="16.666666666666668s" begin="-23.68489264848651s"></animate>
|
||||||
|
</circle><circle cx="77.20196271561525" cy="31.611804700405518" r="0" fill="none" stroke="#689cc5" stroke-width="8">
|
||||||
|
<animate attributeName="r" values="0;45.28258812229561" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="25s" begin="-28.661787725688292s"></animate>
|
||||||
|
<animate attributeName="opacity" values="1;0" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="25s" begin="-28.661787725688292s"></animate>
|
||||||
|
</circle><circle cx="77.20196271561525" cy="287.6118047004055" r="0" fill="none" stroke="#689cc5" stroke-width="8">
|
||||||
|
<animate attributeName="r" values="0;45.28258812229561" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="25s" begin="-28.661787725688292s"></animate>
|
||||||
|
<animate attributeName="opacity" values="1;0" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="25s" begin="-28.661787725688292s"></animate>
|
||||||
|
</circle><circle cx="153.86297348533364" cy="53.13721410068965" r="0" fill="none" stroke="#5e6fa3" stroke-width="8">
|
||||||
|
<animate attributeName="r" values="0;56.59657006893606" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="16.666666666666668s" begin="-26.846959941207736s"></animate>
|
||||||
|
<animate attributeName="opacity" values="1;0" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="16.666666666666668s" begin="-26.846959941207736s"></animate>
|
||||||
|
</circle><circle cx="153.86297348533364" cy="309.1372141006897" r="0" fill="none" stroke="#5e6fa3" stroke-width="8">
|
||||||
|
<animate attributeName="r" values="0;56.59657006893606" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="16.666666666666668s" begin="-26.846959941207736s"></animate>
|
||||||
|
<animate attributeName="opacity" values="1;0" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="16.666666666666668s" begin="-26.846959941207736s"></animate>
|
||||||
|
</circle><circle cx="238.25141956589107" cy="242.3948925366868" r="0" fill="none" stroke="#689cc5" stroke-width="8">
|
||||||
|
<animate attributeName="r" values="0;7.110432319564012" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="25s" begin="-22.8377648779141s"></animate>
|
||||||
|
<animate attributeName="opacity" values="1;0" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="25s" begin="-22.8377648779141s"></animate>
|
||||||
|
</circle><circle cx="171.29587360943597" cy="93.62941553592991" r="0" fill="none" stroke="#93dbe9" stroke-width="8">
|
||||||
|
<animate attributeName="r" values="0;64.80517552507085" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="12.5s" begin="-41.081630071778505s"></animate>
|
||||||
|
<animate attributeName="opacity" values="1;0" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="12.5s" begin="-41.081630071778505s"></animate>
|
||||||
|
</circle><circle cx="33.7803997203791" cy="200.65918731382288" r="0" fill="none" stroke="#93dbe9" stroke-width="8">
|
||||||
|
<animate attributeName="r" values="0;23.874060138252702" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="25s" begin="-29.74940953893833s"></animate>
|
||||||
|
<animate attributeName="opacity" values="1;0" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="25s" begin="-29.74940953893833s"></animate>
|
||||||
|
</circle><circle cx="171.68455092137125" cy="208.29640936292603" r="0" fill="none" stroke="#689cc5" stroke-width="8">
|
||||||
|
<animate attributeName="r" values="0;10.804694032911527" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="12.5s" begin="-46.827942545330814s"></animate>
|
||||||
|
<animate attributeName="opacity" values="1;0" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="12.5s" begin="-46.827942545330814s"></animate>
|
||||||
|
</circle><circle cx="79.4759072969399" cy="14.760241106300118" r="0" fill="none" stroke="#5e6fa3" stroke-width="8">
|
||||||
|
<animate attributeName="r" values="0;63.07191175406126" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="12.5s" begin="-38.31065839827809s"></animate>
|
||||||
|
<animate attributeName="opacity" values="1;0" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="12.5s" begin="-38.31065839827809s"></animate>
|
||||||
|
</circle><circle cx="79.4759072969399" cy="270.7602411063001" r="0" fill="none" stroke="#5e6fa3" stroke-width="8">
|
||||||
|
<animate attributeName="r" values="0;63.07191175406126" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="12.5s" begin="-38.31065839827809s"></animate>
|
||||||
|
<animate attributeName="opacity" values="1;0" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="12.5s" begin="-38.31065839827809s"></animate>
|
||||||
|
</circle><circle cx="34.30718832814177" cy="60.207260607353895" r="0" fill="none" stroke="#5e6fa3" stroke-width="8">
|
||||||
|
<animate attributeName="r" values="0;36.85782580252244" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="25s" begin="-33.9202714458405s"></animate>
|
||||||
|
<animate attributeName="opacity" values="1;0" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="25s" begin="-33.9202714458405s"></animate>
|
||||||
|
</circle><circle cx="290.30718832814176" cy="60.207260607353895" r="0" fill="none" stroke="#5e6fa3" stroke-width="8">
|
||||||
|
<animate attributeName="r" values="0;36.85782580252244" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="25s" begin="-33.9202714458405s"></animate>
|
||||||
|
<animate attributeName="opacity" values="1;0" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="25s" begin="-33.9202714458405s"></animate>
|
||||||
|
</circle><circle cx="141.57461629003254" cy="187.07605677907222" r="0" fill="none" stroke="#5e6fa3" stroke-width="8">
|
||||||
|
<animate attributeName="r" values="0;51.82556427519147" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="25s" begin="-39.3497070269789s"></animate>
|
||||||
|
<animate attributeName="opacity" values="1;0" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="25s" begin="-39.3497070269789s"></animate>
|
||||||
|
</circle><circle cx="89.86556463252813" cy="191.98681310799674" r="0" fill="none" stroke="#5e6fa3" stroke-width="8">
|
||||||
|
<animate attributeName="r" values="0;42.52162149867297" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="16.666666666666668s" begin="-17.730611990382005s"></animate>
|
||||||
|
<animate attributeName="opacity" values="1;0" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="16.666666666666668s" begin="-17.730611990382005s"></animate>
|
||||||
|
</circle><circle cx="135.68751640285163" cy="79.13898775934953" r="0" fill="none" stroke="#93dbe9" stroke-width="8">
|
||||||
|
<animate attributeName="r" values="0;13.167119065627332" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="12.5s" begin="-5.604152896601732s"></animate>
|
||||||
|
<animate attributeName="opacity" values="1;0" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="12.5s" begin="-5.604152896601732s"></animate>
|
||||||
|
</circle><circle cx="222.37419164851048" cy="172.5138843825768" r="0" fill="none" stroke="#93dbe9" stroke-width="8">
|
||||||
|
<animate attributeName="r" values="0;30.712438068878654" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="16.666666666666668s" begin="-11.730564332626214s"></animate>
|
||||||
|
<animate attributeName="opacity" values="1;0" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="16.666666666666668s" begin="-11.730564332626214s"></animate>
|
||||||
|
</circle><circle cx="65.37962957434202" cy="71.08214856672792" r="0" fill="none" stroke="#689cc5" stroke-width="8">
|
||||||
|
<animate attributeName="r" values="0;51.390991126295845" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="16.666666666666668s" begin="-38.53817444257383s"></animate>
|
||||||
|
<animate attributeName="opacity" values="1;0" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="16.666666666666668s" begin="-38.53817444257383s"></animate>
|
||||||
|
</circle><circle cx="146.90696443169887" cy="160.58661584710634" r="0" fill="none" stroke="#5e6fa3" stroke-width="8">
|
||||||
|
<animate attributeName="r" values="0;30.874027084269912" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="16.666666666666668s" begin="-48.61529961868726s"></animate>
|
||||||
|
<animate attributeName="opacity" values="1;0" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="16.666666666666668s" begin="-48.61529961868726s"></animate>
|
||||||
|
</circle><circle cx="20.6640150520578" cy="116.652000839832" r="0" fill="none" stroke="#689cc5" stroke-width="8">
|
||||||
|
<animate attributeName="r" values="0;20.32462575632799" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="16.666666666666668s" begin="-16.94818532763218s"></animate>
|
||||||
|
<animate attributeName="opacity" values="1;0" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="16.666666666666668s" begin="-16.94818532763218s"></animate>
|
||||||
|
</circle><circle cx="14.794147949099273" cy="178.87974595952937" r="0" fill="none" stroke="#93dbe9" stroke-width="8">
|
||||||
|
<animate attributeName="r" values="0;62.66357119046049" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="25s" begin="-22.398483724039195s"></animate>
|
||||||
|
<animate attributeName="opacity" values="1;0" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="25s" begin="-22.398483724039195s"></animate>
|
||||||
|
</circle><circle cx="270.7941479490993" cy="178.87974595952937" r="0" fill="none" stroke="#93dbe9" stroke-width="8">
|
||||||
|
<animate attributeName="r" values="0;62.66357119046049" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="25s" begin="-22.398483724039195s"></animate>
|
||||||
|
<animate attributeName="opacity" values="1;0" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="25s" begin="-22.398483724039195s"></animate>
|
||||||
|
</circle><circle cx="31.287373376921607" cy="70.1833739363135" r="0" fill="none" stroke="#5e6fa3" stroke-width="8">
|
||||||
|
<animate attributeName="r" values="0;15.295461964288506" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="12.5s" begin="-13.161686681828998s"></animate>
|
||||||
|
<animate attributeName="opacity" values="1;0" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="12.5s" begin="-13.161686681828998s"></animate>
|
||||||
|
</circle><circle cx="178.84317419706238" cy="167.34091291757605" r="0" fill="none" stroke="#5e6fa3" stroke-width="8">
|
||||||
|
<animate attributeName="r" values="0;62.162205555011425" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="25s" begin="-23.327170625044392s"></animate>
|
||||||
|
<animate attributeName="opacity" values="1;0" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="25s" begin="-23.327170625044392s"></animate>
|
||||||
|
</circle><circle cx="154.05316621664582" cy="55.033341833431564" r="0" fill="none" stroke="#5e6fa3" stroke-width="8">
|
||||||
|
<animate attributeName="r" values="0;39.67588542484934" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="25s" begin="-15.452897657374963s"></animate>
|
||||||
|
<animate attributeName="opacity" values="1;0" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="25s" begin="-15.452897657374963s"></animate>
|
||||||
|
</circle><circle cx="72.19223514179198" cy="135.19246311905093" r="0" fill="none" stroke="#689cc5" stroke-width="8">
|
||||||
|
<animate attributeName="r" values="0;20.804220090813203" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="16.666666666666668s" begin="-45.51768235650617s"></animate>
|
||||||
|
<animate attributeName="opacity" values="1;0" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="16.666666666666668s" begin="-45.51768235650617s"></animate>
|
||||||
|
</circle><circle cx="150.9364802116815" cy="160.51205929354626" r="0" fill="none" stroke="#93dbe9" stroke-width="8">
|
||||||
|
<animate attributeName="r" values="0;36.57407641397833" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="25s" begin="-28.280565367328037s"></animate>
|
||||||
|
<animate attributeName="opacity" values="1;0" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="25s" begin="-28.280565367328037s"></animate>
|
||||||
|
</circle><circle cx="200.40953970115999" cy="54.21097279269783" r="0" fill="none" stroke="#689cc5" stroke-width="8">
|
||||||
|
<animate attributeName="r" values="0;18.303774190487488" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="25s" begin="-16.214535605827784s"></animate>
|
||||||
|
<animate attributeName="opacity" values="1;0" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="25s" begin="-16.214535605827784s"></animate>
|
||||||
|
</circle><circle cx="180.31885618742604" cy="242.78087924898603" r="0" fill="none" stroke="#5e6fa3" stroke-width="8">
|
||||||
|
<animate attributeName="r" values="0;11.71365962730546" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="16.666666666666668s" begin="-33.612535536027956s"></animate>
|
||||||
|
<animate attributeName="opacity" values="1;0" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="16.666666666666668s" begin="-33.612535536027956s"></animate>
|
||||||
|
</circle><circle cx="203.8062010106876" cy="232.68973192108191" r="0" fill="none" stroke="#5e6fa3" stroke-width="8">
|
||||||
|
<animate attributeName="r" values="0;5.455675580739268" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="12.5s" begin="-11.86697370110249s"></animate>
|
||||||
|
<animate attributeName="opacity" values="1;0" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="12.5s" begin="-11.86697370110249s"></animate>
|
||||||
|
</circle><circle cx="171.6066941076269" cy="48.04474014530398" r="0" fill="none" stroke="#5e6fa3" stroke-width="8">
|
||||||
|
<animate attributeName="r" values="0;38.59286259496349" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="16.666666666666668s" begin="-29.250466319872224s"></animate>
|
||||||
|
<animate attributeName="opacity" values="1;0" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="16.666666666666668s" begin="-29.250466319872224s"></animate>
|
||||||
|
</circle><circle cx="125.11525876384411" cy="149.77467373569812" r="0" fill="none" stroke="#5e6fa3" stroke-width="8">
|
||||||
|
<animate attributeName="r" values="0;46.62256816012656" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="12.5s" begin="-10.699532836506153s"></animate>
|
||||||
|
<animate attributeName="opacity" values="1;0" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="12.5s" begin="-10.699532836506153s"></animate>
|
||||||
|
</circle><circle cx="89.16772547042389" cy="100.43557995027065" r="0" fill="none" stroke="#5e6fa3" stroke-width="8">
|
||||||
|
<animate attributeName="r" values="0;50.90728701564909" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="12.5s" begin="-20.057887262682318s"></animate>
|
||||||
|
<animate attributeName="opacity" values="1;0" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="12.5s" begin="-20.057887262682318s"></animate>
|
||||||
|
</circle><circle cx="163.0802387343303" cy="125.70388388233474" r="0" fill="none" stroke="#5e6fa3" stroke-width="8">
|
||||||
|
<animate attributeName="r" values="0;60.89399699890593" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="16.666666666666668s" begin="-29.04746538184899s"></animate>
|
||||||
|
<animate attributeName="opacity" values="1;0" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="16.666666666666668s" begin="-29.04746538184899s"></animate>
|
||||||
|
</circle><circle cx="147.29969577601045" cy="40.152117547871356" r="0" fill="none" stroke="#5e6fa3" stroke-width="8">
|
||||||
|
<animate attributeName="r" values="0;50.17094951058618" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="25s" begin="-8.699383046276775s"></animate>
|
||||||
|
<animate attributeName="opacity" values="1;0" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="25s" begin="-8.699383046276775s"></animate>
|
||||||
|
</circle><circle cx="147.29969577601045" cy="296.15211754787134" r="0" fill="none" stroke="#5e6fa3" stroke-width="8">
|
||||||
|
<animate attributeName="r" values="0;50.17094951058618" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="25s" begin="-8.699383046276775s"></animate>
|
||||||
|
<animate attributeName="opacity" values="1;0" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="25s" begin="-8.699383046276775s"></animate>
|
||||||
|
</circle><circle cx="50.39439200506233" cy="147.3941729324677" r="0" fill="none" stroke="#689cc5" stroke-width="8">
|
||||||
|
<animate attributeName="r" values="0;50.69970142939741" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="16.666666666666668s" begin="-17.544702694456348s"></animate>
|
||||||
|
<animate attributeName="opacity" values="1;0" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="16.666666666666668s" begin="-17.544702694456348s"></animate>
|
||||||
|
</circle><circle cx="306.39439200506234" cy="147.3941729324677" r="0" fill="none" stroke="#689cc5" stroke-width="8">
|
||||||
|
<animate attributeName="r" values="0;50.69970142939741" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="16.666666666666668s" begin="-17.544702694456348s"></animate>
|
||||||
|
<animate attributeName="opacity" values="1;0" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="16.666666666666668s" begin="-17.544702694456348s"></animate>
|
||||||
|
</circle><circle cx="188.7139101584322" cy="210.7115210762685" r="0" fill="none" stroke="#689cc5" stroke-width="8">
|
||||||
|
<animate attributeName="r" values="0;29.504019948829963" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="16.666666666666668s" begin="-32.532647237390165s"></animate>
|
||||||
|
<animate attributeName="opacity" values="1;0" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="16.666666666666668s" begin="-32.532647237390165s"></animate>
|
||||||
|
</circle><circle cx="114.22207446357659" cy="124.76935492926279" r="0" fill="none" stroke="#5e6fa3" stroke-width="8">
|
||||||
|
<animate attributeName="r" values="0;11.986008541965333" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="12.5s" begin="-16.917226446523447s"></animate>
|
||||||
|
<animate attributeName="opacity" values="1;0" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="12.5s" begin="-16.917226446523447s"></animate>
|
||||||
|
</circle><circle cx="194.31954289149434" cy="166.65089356408262" r="0" fill="none" stroke="#5e6fa3" stroke-width="8">
|
||||||
|
<animate attributeName="r" values="0;20.194181381536055" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="25s" begin="-30.020995894146097s"></animate>
|
||||||
|
<animate attributeName="opacity" values="1;0" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="25s" begin="-30.020995894146097s"></animate>
|
||||||
|
</circle><circle cx="184.86541783077774" cy="44.886087590301756" r="0" fill="none" stroke="#93dbe9" stroke-width="8">
|
||||||
|
<animate attributeName="r" values="0;56.99589341531981" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="25s" begin="-36.60809296354671s"></animate>
|
||||||
|
<animate attributeName="opacity" values="1;0" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="25s" begin="-36.60809296354671s"></animate>
|
||||||
|
</circle><circle cx="184.86541783077774" cy="300.88608759030177" r="0" fill="none" stroke="#93dbe9" stroke-width="8">
|
||||||
|
<animate attributeName="r" values="0;56.99589341531981" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="25s" begin="-36.60809296354671s"></animate>
|
||||||
|
<animate attributeName="opacity" values="1;0" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="25s" begin="-36.60809296354671s"></animate>
|
||||||
|
</circle><circle cx="128.6294815429427" cy="20.412863761372066" r="0" fill="none" stroke="#5e6fa3" stroke-width="8">
|
||||||
|
<animate attributeName="r" values="0;58.14291539416182" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="16.666666666666668s" begin="-38.6283523615141s"></animate>
|
||||||
|
<animate attributeName="opacity" values="1;0" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="16.666666666666668s" begin="-38.6283523615141s"></animate>
|
||||||
|
</circle><circle cx="128.6294815429427" cy="276.4128637613721" r="0" fill="none" stroke="#5e6fa3" stroke-width="8">
|
||||||
|
<animate attributeName="r" values="0;58.14291539416182" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="16.666666666666668s" begin="-38.6283523615141s"></animate>
|
||||||
|
<animate attributeName="opacity" values="1;0" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="16.666666666666668s" begin="-38.6283523615141s"></animate>
|
||||||
|
</circle><circle cx="94.65360523910455" cy="237.65373752048882" r="0" fill="none" stroke="#689cc5" stroke-width="8">
|
||||||
|
<animate attributeName="r" values="0;10.872426017373087" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="16.666666666666668s" begin="-17.286612875431295s"></animate>
|
||||||
|
<animate attributeName="opacity" values="1;0" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="16.666666666666668s" begin="-17.286612875431295s"></animate>
|
||||||
|
</circle><circle cx="186.84577473379255" cy="4.291441103039755" r="0" fill="none" stroke="#5e6fa3" stroke-width="8">
|
||||||
|
<animate attributeName="r" values="0;50.03848537207753" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="12.5s" begin="-30.97916037182813s"></animate>
|
||||||
|
<animate attributeName="opacity" values="1;0" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="12.5s" begin="-30.97916037182813s"></animate>
|
||||||
|
</circle><circle cx="186.84577473379255" cy="260.29144110303974" r="0" fill="none" stroke="#5e6fa3" stroke-width="8">
|
||||||
|
<animate attributeName="r" values="0;50.03848537207753" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="12.5s" begin="-30.97916037182813s"></animate>
|
||||||
|
<animate attributeName="opacity" values="1;0" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="12.5s" begin="-30.97916037182813s"></animate>
|
||||||
|
</circle><circle cx="3.1171684515748126" cy="10.536170179400985" r="0" fill="none" stroke="#689cc5" stroke-width="8">
|
||||||
|
<animate attributeName="r" values="0;31.72037969636405" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="25s" begin="-29.18270767825585s"></animate>
|
||||||
|
<animate attributeName="opacity" values="1;0" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="25s" begin="-29.18270767825585s"></animate>
|
||||||
|
</circle><circle cx="259.1171684515748" cy="10.536170179400985" r="0" fill="none" stroke="#689cc5" stroke-width="8">
|
||||||
|
<animate attributeName="r" values="0;31.72037969636405" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="25s" begin="-29.18270767825585s"></animate>
|
||||||
|
<animate attributeName="opacity" values="1;0" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="25s" begin="-29.18270767825585s"></animate>
|
||||||
|
</circle><circle cx="3.1171684515748126" cy="266.536170179401" r="0" fill="none" stroke="#689cc5" stroke-width="8">
|
||||||
|
<animate attributeName="r" values="0;31.72037969636405" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="25s" begin="-29.18270767825585s"></animate>
|
||||||
|
<animate attributeName="opacity" values="1;0" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="25s" begin="-29.18270767825585s"></animate>
|
||||||
|
</circle><circle cx="259.1171684515748" cy="266.536170179401" r="0" fill="none" stroke="#689cc5" stroke-width="8">
|
||||||
|
<animate attributeName="r" values="0;31.72037969636405" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="25s" begin="-29.18270767825585s"></animate>
|
||||||
|
<animate attributeName="opacity" values="1;0" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="25s" begin="-29.18270767825585s"></animate>
|
||||||
|
</circle><circle cx="188.74527992387326" cy="21.78088381944502" r="0" fill="none" stroke="#93dbe9" stroke-width="8">
|
||||||
|
<animate attributeName="r" values="0;24.62604013195285" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="12.5s" begin="-15.60412108402891s"></animate>
|
||||||
|
<animate attributeName="opacity" values="1;0" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="12.5s" begin="-15.60412108402891s"></animate>
|
||||||
|
</circle><circle cx="188.74527992387326" cy="277.780883819445" r="0" fill="none" stroke="#93dbe9" stroke-width="8">
|
||||||
|
<animate attributeName="r" values="0;24.62604013195285" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="12.5s" begin="-15.60412108402891s"></animate>
|
||||||
|
<animate attributeName="opacity" values="1;0" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="12.5s" begin="-15.60412108402891s"></animate>
|
||||||
|
</circle><circle cx="25.856888539646313" cy="42.26884688505775" r="0" fill="none" stroke="#689cc5" stroke-width="8">
|
||||||
|
<animate attributeName="r" values="0;47.95560071224433" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="12.5s" begin="-16.780876976602578s"></animate>
|
||||||
|
<animate attributeName="opacity" values="1;0" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="12.5s" begin="-16.780876976602578s"></animate>
|
||||||
|
</circle><circle cx="281.8568885396463" cy="42.26884688505775" r="0" fill="none" stroke="#689cc5" stroke-width="8">
|
||||||
|
<animate attributeName="r" values="0;47.95560071224433" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="12.5s" begin="-16.780876976602578s"></animate>
|
||||||
|
<animate attributeName="opacity" values="1;0" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="12.5s" begin="-16.780876976602578s"></animate>
|
||||||
|
</circle><circle cx="25.856888539646313" cy="298.26884688505777" r="0" fill="none" stroke="#689cc5" stroke-width="8">
|
||||||
|
<animate attributeName="r" values="0;47.95560071224433" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="12.5s" begin="-16.780876976602578s"></animate>
|
||||||
|
<animate attributeName="opacity" values="1;0" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="12.5s" begin="-16.780876976602578s"></animate>
|
||||||
|
</circle><circle cx="281.8568885396463" cy="298.26884688505777" r="0" fill="none" stroke="#689cc5" stroke-width="8">
|
||||||
|
<animate attributeName="r" values="0;47.95560071224433" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="12.5s" begin="-16.780876976602578s"></animate>
|
||||||
|
<animate attributeName="opacity" values="1;0" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="12.5s" begin="-16.780876976602578s"></animate>
|
||||||
|
</circle><circle cx="80.07378641634132" cy="99.95189316646443" r="0" fill="none" stroke="#93dbe9" stroke-width="8">
|
||||||
|
<animate attributeName="r" values="0;31.25308753538168" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="16.666666666666668s" begin="-44.38933261009856s"></animate>
|
||||||
|
<animate attributeName="opacity" values="1;0" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="16.666666666666668s" begin="-44.38933261009856s"></animate>
|
||||||
|
</circle><circle cx="115.28452115370486" cy="183.50469529806404" r="0" fill="none" stroke="#93dbe9" stroke-width="8">
|
||||||
|
<animate attributeName="r" values="0;43.47190520350591" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="12.5s" begin="-35.01262905715093s"></animate>
|
||||||
|
<animate attributeName="opacity" values="1;0" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="12.5s" begin="-35.01262905715093s"></animate>
|
||||||
|
</circle><circle cx="178.06444021126137" cy="196.65069638203684" r="0" fill="none" stroke="#93dbe9" stroke-width="8">
|
||||||
|
<animate attributeName="r" values="0;55.28300103432255" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="25s" begin="-31.907669721653242s"></animate>
|
||||||
|
<animate attributeName="opacity" values="1;0" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="25s" begin="-31.907669721653242s"></animate>
|
||||||
|
</circle><circle cx="44.16845143857357" cy="102.58764890706274" r="0" fill="none" stroke="#93dbe9" stroke-width="8">
|
||||||
|
<animate attributeName="r" values="0;56.592641937222965" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="16.666666666666668s" begin="-21.452416790316818s"></animate>
|
||||||
|
<animate attributeName="opacity" values="1;0" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="16.666666666666668s" begin="-21.452416790316818s"></animate>
|
||||||
|
</circle><circle cx="300.1684514385736" cy="102.58764890706274" r="0" fill="none" stroke="#93dbe9" stroke-width="8">
|
||||||
|
<animate attributeName="r" values="0;56.592641937222965" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="16.666666666666668s" begin="-21.452416790316818s"></animate>
|
||||||
|
<animate attributeName="opacity" values="1;0" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="16.666666666666668s" begin="-21.452416790316818s"></animate>
|
||||||
|
</circle><circle cx="79.90917564776078" cy="58.24933597303385" r="0" fill="none" stroke="#5e6fa3" stroke-width="8">
|
||||||
|
<animate attributeName="r" values="0;17.76697933939279" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="16.666666666666668s" begin="-6.018058267098058s"></animate>
|
||||||
|
<animate attributeName="opacity" values="1;0" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="16.666666666666668s" begin="-6.018058267098058s"></animate>
|
||||||
|
</circle><circle cx="99.51047224071066" cy="68.21685313096823" r="0" fill="none" stroke="#93dbe9" stroke-width="8">
|
||||||
|
<animate attributeName="r" values="0;32.538025421938485" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="16.666666666666668s" begin="-24.711449309412114s"></animate>
|
||||||
|
<animate attributeName="opacity" values="1;0" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="16.666666666666668s" begin="-24.711449309412114s"></animate>
|
||||||
|
</circle><circle cx="170.23837150372032" cy="80.50555967618685" r="0" fill="none" stroke="#93dbe9" stroke-width="8">
|
||||||
|
<animate attributeName="r" values="0;49.47798543600463" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="25s" begin="-27.302250080429058s"></animate>
|
||||||
|
<animate attributeName="opacity" values="1;0" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="25s" begin="-27.302250080429058s"></animate>
|
||||||
|
</circle><circle cx="146.82045516936643" cy="81.4540879579799" r="0" fill="none" stroke="#93dbe9" stroke-width="8">
|
||||||
|
<animate attributeName="r" values="0;17.51784178229697" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="12.5s" begin="-14.316475870551947s"></animate>
|
||||||
|
<animate attributeName="opacity" values="1;0" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="12.5s" begin="-14.316475870551947s"></animate>
|
||||||
|
</circle><circle cx="85.89692843138472" cy="166.66227056758296" r="0" fill="none" stroke="#5e6fa3" stroke-width="8">
|
||||||
|
<animate attributeName="r" values="0;43.09830041436764" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="12.5s" begin="-25.33233432848061s"></animate>
|
||||||
|
<animate attributeName="opacity" values="1;0" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="12.5s" begin="-25.33233432848061s"></animate>
|
||||||
|
</circle><circle cx="177.2226960369944" cy="175.07899171519415" r="0" fill="none" stroke="#689cc5" stroke-width="8">
|
||||||
|
<animate attributeName="r" values="0;43.73555785023012" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="16.666666666666668s" begin="-25.121497689569683s"></animate>
|
||||||
|
<animate attributeName="opacity" values="1;0" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="16.666666666666668s" begin="-25.121497689569683s"></animate>
|
||||||
|
</circle><circle cx="216.86808064093213" cy="27.577527215605766" r="0" fill="none" stroke="#93dbe9" stroke-width="8">
|
||||||
|
<animate attributeName="r" values="0;4.737877261879547" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="25s" begin="-15.904900634836528s"></animate>
|
||||||
|
<animate attributeName="opacity" values="1;0" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="25s" begin="-15.904900634836528s"></animate>
|
||||||
|
</circle><circle cx="110.04710192749121" cy="180.18493319620214" r="0" fill="none" stroke="#93dbe9" stroke-width="8">
|
||||||
|
<animate attributeName="r" values="0;44.77556931875715" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="25s" begin="-1.5780314591062772s"></animate>
|
||||||
|
<animate attributeName="opacity" values="1;0" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="25s" begin="-1.5780314591062772s"></animate>
|
||||||
|
</circle><circle cx="64.71846547185336" cy="75.44443893159085" r="0" fill="none" stroke="#93dbe9" stroke-width="8">
|
||||||
|
<animate attributeName="r" values="0;9.889551183237941" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="16.666666666666668s" begin="-36.2183301855013s"></animate>
|
||||||
|
<animate attributeName="opacity" values="1;0" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="16.666666666666668s" begin="-36.2183301855013s"></animate>
|
||||||
|
</circle><circle cx="40.659167565439354" cy="80.92354614012416" r="0" fill="none" stroke="#689cc5" stroke-width="8">
|
||||||
|
<animate attributeName="r" values="0;47.03611543920749" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="16.666666666666668s" begin="-40.52530054760075s"></animate>
|
||||||
|
<animate attributeName="opacity" values="1;0" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="16.666666666666668s" begin="-40.52530054760075s"></animate>
|
||||||
|
</circle><circle cx="296.65916756543936" cy="80.92354614012416" r="0" fill="none" stroke="#689cc5" stroke-width="8">
|
||||||
|
<animate attributeName="r" values="0;47.03611543920749" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="16.666666666666668s" begin="-40.52530054760075s"></animate>
|
||||||
|
<animate attributeName="opacity" values="1;0" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="16.666666666666668s" begin="-40.52530054760075s"></animate>
|
||||||
|
</circle><circle cx="158.9398261520183" cy="96.5683673937937" r="0" fill="none" stroke="#689cc5" stroke-width="8">
|
||||||
|
<animate attributeName="r" values="0;9.89977495248037" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="12.5s" begin="-2.5412705195820062s"></animate>
|
||||||
|
<animate attributeName="opacity" values="1;0" keyTimes="0;1" calcMode="spline" repeatCount="indefinite" keySplines="0 0.5 0.5 1" dur="12.5s" begin="-2.5412705195820062s"></animate>
|
||||||
|
</circle></g>
|
||||||
|
</pattern>
|
||||||
|
</defs>
|
||||||
|
<rect x="0" y="0" width="1084" height="322" fill="url(#pid-0.2950529742247572)"></rect>
|
||||||
|
</svg>
|
After Width: | Height: | Size: 42 KiB |
18
assets/img/traffic.svg
Normal file
|
@ -0,0 +1,18 @@
|
||||||
|
<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" style="margin:auto;background:rgba(NaN, NaN, NaN, 0);display:block;z-index:1;position:relative" width="1084" height="322" preserveAspectRatio="xMidYMid" viewBox="0 0 1084 322">
|
||||||
|
<defs>
|
||||||
|
<pattern id="pid-0.32277503320149736" x="0" y="0" width="322.56" height="322.56" patternUnits="userSpaceOnUse">
|
||||||
|
<g transform="scale(1.26)"><g> <line x1="12.8" y1="-268.8" x2="12.8" y2="-217.6" stroke="#d9dbee" stroke-width="21.6" stroke-linecap="round"></line> <line x1="12.8" y1="-12.8" x2="12.8" y2="38.400000000000006" stroke="#d9dbee" stroke-width="21.6" stroke-linecap="round"></line> <line x1="12.8" y1="243.2" x2="12.8" y2="294.4" stroke="#d9dbee" stroke-width="21.6" stroke-linecap="round"></line> <line x1="12.8" y1="-192" x2="12.8" y2="-140.8" stroke="#689cc5" stroke-width="21.6" stroke-linecap="round"></line> <line x1="12.8" y1="64" x2="12.8" y2="115.2" stroke="#689cc5" stroke-width="21.6" stroke-linecap="round"></line> <line x1="12.8" y1="320" x2="12.8" y2="371.2" stroke="#689cc5" stroke-width="21.6" stroke-linecap="round"></line> <line x1="12.8" y1="-115.19999999999999" x2="12.8" y2="-64" stroke="#5e6fa3" stroke-width="21.6" stroke-linecap="round"></line> <line x1="12.8" y1="140.8" x2="12.8" y2="192" stroke="#5e6fa3" stroke-width="21.6" stroke-linecap="round"></line> <line x1="12.8" y1="396.8" x2="12.8" y2="448" stroke="#5e6fa3" stroke-width="21.6" stroke-linecap="round"></line> <line x1="12.8" y1="-38.39999999999998" x2="12.8" y2="38.400000000000034" stroke="#d9dbee" stroke-width="21.6" stroke-linecap="round"></line> <line x1="12.8" y1="217.60000000000002" x2="12.8" y2="294.40000000000003" stroke="#d9dbee" stroke-width="21.6" stroke-linecap="round"></line> <line x1="12.8" y1="473.6" x2="12.8" y2="550.4000000000001" stroke="#d9dbee" stroke-width="21.6" stroke-linecap="round"></line> <animateTransform attributeName="transform" type="translate" repeatCount="indefinite" dur="50s" keyTimes="0;1" values="0 0;0 256"></animateTransform>
|
||||||
|
</g> <g> <line x1="38.400000000000006" y1="-243.2" x2="38.400000000000006" y2="-192" stroke="#b3b7e2" stroke-width="21.6" stroke-linecap="round"></line> <line x1="38.400000000000006" y1="12.8" x2="38.400000000000006" y2="64" stroke="#b3b7e2" stroke-width="21.6" stroke-linecap="round"></line> <line x1="38.400000000000006" y1="268.8" x2="38.400000000000006" y2="320" stroke="#b3b7e2" stroke-width="21.6" stroke-linecap="round"></line> <line x1="38.400000000000006" y1="-166.39999999999998" x2="38.400000000000006" y2="-115.19999999999999" stroke="#93dbe9" stroke-width="21.6" stroke-linecap="round"></line> <line x1="38.400000000000006" y1="89.60000000000001" x2="38.400000000000006" y2="140.8" stroke="#93dbe9" stroke-width="21.6" stroke-linecap="round"></line> <line x1="38.400000000000006" y1="345.6" x2="38.400000000000006" y2="396.8" stroke="#93dbe9" stroke-width="21.6" stroke-linecap="round"></line> <line x1="38.400000000000006" y1="-89.59999999999997" x2="38.400000000000006" y2="-12.799999999999955" stroke="#689cc5" stroke-width="21.6" stroke-linecap="round"></line> <line x1="38.400000000000006" y1="166.40000000000003" x2="38.400000000000006" y2="243.20000000000005" stroke="#689cc5" stroke-width="21.6" stroke-linecap="round"></line> <line x1="38.400000000000006" y1="422.40000000000003" x2="38.400000000000006" y2="499.20000000000005" stroke="#689cc5" stroke-width="21.6" stroke-linecap="round"></line> <animateTransform attributeName="transform" type="translate" repeatCount="indefinite" dur="16.666666666666668s" keyTimes="0;1" values="0 0;0 -256"></animateTransform>
|
||||||
|
</g> <g> <line x1="64" y1="-243.2" x2="64" y2="-192" stroke="#689cc5" stroke-width="21.6" stroke-linecap="round"></line> <line x1="64" y1="12.8" x2="64" y2="64" stroke="#689cc5" stroke-width="21.6" stroke-linecap="round"></line> <line x1="64" y1="268.8" x2="64" y2="320" stroke="#689cc5" stroke-width="21.6" stroke-linecap="round"></line> <line x1="64" y1="-166.39999999999998" x2="64" y2="-115.19999999999999" stroke="#d9dbee" stroke-width="21.6" stroke-linecap="round"></line> <line x1="64" y1="89.60000000000001" x2="64" y2="140.8" stroke="#d9dbee" stroke-width="21.6" stroke-linecap="round"></line> <line x1="64" y1="345.6" x2="64" y2="396.8" stroke="#d9dbee" stroke-width="21.6" stroke-linecap="round"></line> <line x1="64" y1="-89.59999999999997" x2="64" y2="-12.799999999999955" stroke="#191d3a" stroke-width="21.6" stroke-linecap="round"></line> <line x1="64" y1="166.40000000000003" x2="64" y2="243.20000000000005" stroke="#191d3a" stroke-width="21.6" stroke-linecap="round"></line> <line x1="64" y1="422.40000000000003" x2="64" y2="499.20000000000005" stroke="#191d3a" stroke-width="21.6" stroke-linecap="round"></line> <animateTransform attributeName="transform" type="translate" repeatCount="indefinite" dur="25s" keyTimes="0;1" values="0 0;0 -256"></animateTransform>
|
||||||
|
</g> <g> <line x1="89.60000000000001" y1="-243.2" x2="89.60000000000001" y2="-166.39999999999998" stroke="#5e6fa3" stroke-width="21.6" stroke-linecap="round"></line> <line x1="89.60000000000001" y1="12.8" x2="89.60000000000001" y2="89.60000000000001" stroke="#5e6fa3" stroke-width="21.6" stroke-linecap="round"></line> <line x1="89.60000000000001" y1="268.8" x2="89.60000000000001" y2="345.6" stroke="#5e6fa3" stroke-width="21.6" stroke-linecap="round"></line> <line x1="89.60000000000001" y1="-140.8" x2="89.60000000000001" y2="-89.6" stroke="#93dbe9" stroke-width="21.6" stroke-linecap="round"></line> <line x1="89.60000000000001" y1="115.2" x2="89.60000000000001" y2="166.4" stroke="#93dbe9" stroke-width="21.6" stroke-linecap="round"></line> <line x1="89.60000000000001" y1="371.2" x2="89.60000000000001" y2="422.4" stroke="#93dbe9" stroke-width="21.6" stroke-linecap="round"></line> <line x1="89.60000000000001" y1="-63.99999999999997" x2="89.60000000000001" y2="-12.799999999999955" stroke="#191d3a" stroke-width="21.6" stroke-linecap="round"></line> <line x1="89.60000000000001" y1="192.00000000000003" x2="89.60000000000001" y2="243.20000000000005" stroke="#191d3a" stroke-width="21.6" stroke-linecap="round"></line> <line x1="89.60000000000001" y1="448" x2="89.60000000000001" y2="499.20000000000005" stroke="#191d3a" stroke-width="21.6" stroke-linecap="round"></line> <animateTransform attributeName="transform" type="translate" repeatCount="indefinite" dur="16.666666666666668s" keyTimes="0;1" values="0 0;0 -256"></animateTransform>
|
||||||
|
</g> <g> <line x1="115.2" y1="-243.2" x2="115.2" y2="-217.6" stroke="#689cc5" stroke-width="21.6" stroke-linecap="round"></line> <line x1="115.2" y1="12.8" x2="115.2" y2="38.400000000000006" stroke="#689cc5" stroke-width="21.6" stroke-linecap="round"></line> <line x1="115.2" y1="268.8" x2="115.2" y2="294.4" stroke="#689cc5" stroke-width="21.6" stroke-linecap="round"></line> <line x1="115.2" y1="-192" x2="115.2" y2="-140.8" stroke="#93dbe9" stroke-width="21.6" stroke-linecap="round"></line> <line x1="115.2" y1="64" x2="115.2" y2="115.2" stroke="#93dbe9" stroke-width="21.6" stroke-linecap="round"></line> <line x1="115.2" y1="320" x2="115.2" y2="371.2" stroke="#93dbe9" stroke-width="21.6" stroke-linecap="round"></line> <line x1="115.2" y1="-115.19999999999999" x2="115.2" y2="-64" stroke="#689cc5" stroke-width="21.6" stroke-linecap="round"></line> <line x1="115.2" y1="140.8" x2="115.2" y2="192" stroke="#689cc5" stroke-width="21.6" stroke-linecap="round"></line> <line x1="115.2" y1="396.8" x2="115.2" y2="448" stroke="#689cc5" stroke-width="21.6" stroke-linecap="round"></line> <line x1="115.2" y1="-38.39999999999998" x2="115.2" y2="-12.799999999999983" stroke="#b3b7e2" stroke-width="21.6" stroke-linecap="round"></line> <line x1="115.2" y1="217.60000000000002" x2="115.2" y2="243.20000000000002" stroke="#b3b7e2" stroke-width="21.6" stroke-linecap="round"></line> <line x1="115.2" y1="473.6" x2="115.2" y2="499.20000000000005" stroke="#b3b7e2" stroke-width="21.6" stroke-linecap="round"></line> <animateTransform attributeName="transform" type="translate" repeatCount="indefinite" dur="25s" keyTimes="0;1" values="0 0;0 256"></animateTransform>
|
||||||
|
</g> <g> <line x1="140.8" y1="-243.2" x2="140.8" y2="-166.39999999999998" stroke="#689cc5" stroke-width="21.6" stroke-linecap="round"></line> <line x1="140.8" y1="12.8" x2="140.8" y2="89.60000000000001" stroke="#689cc5" stroke-width="21.6" stroke-linecap="round"></line> <line x1="140.8" y1="268.8" x2="140.8" y2="345.6" stroke="#689cc5" stroke-width="21.6" stroke-linecap="round"></line> <line x1="140.8" y1="-140.8" x2="140.8" y2="-115.19999999999999" stroke="#5e6fa3" stroke-width="21.6" stroke-linecap="round"></line> <line x1="140.8" y1="115.2" x2="140.8" y2="140.8" stroke="#5e6fa3" stroke-width="21.6" stroke-linecap="round"></line> <line x1="140.8" y1="371.2" x2="140.8" y2="396.8" stroke="#5e6fa3" stroke-width="21.6" stroke-linecap="round"></line> <line x1="140.8" y1="-89.59999999999997" x2="140.8" y2="-63.99999999999997" stroke="#93dbe9" stroke-width="21.6" stroke-linecap="round"></line> <line x1="140.8" y1="166.40000000000003" x2="140.8" y2="192.00000000000003" stroke="#93dbe9" stroke-width="21.6" stroke-linecap="round"></line> <line x1="140.8" y1="422.40000000000003" x2="140.8" y2="448" stroke="#93dbe9" stroke-width="21.6" stroke-linecap="round"></line> <line x1="140.8" y1="-38.39999999999998" x2="140.8" y2="-12.799999999999983" stroke="#689cc5" stroke-width="21.6" stroke-linecap="round"></line> <line x1="140.8" y1="217.60000000000002" x2="140.8" y2="243.20000000000002" stroke="#689cc5" stroke-width="21.6" stroke-linecap="round"></line> <line x1="140.8" y1="473.6" x2="140.8" y2="499.20000000000005" stroke="#689cc5" stroke-width="21.6" stroke-linecap="round"></line> <animateTransform attributeName="transform" type="translate" repeatCount="indefinite" dur="50s" keyTimes="0;1" values="0 0;0 256"></animateTransform>
|
||||||
|
</g> <g> <line x1="166.40000000000003" y1="-268.8" x2="166.40000000000003" y2="-192" stroke="#689cc5" stroke-width="21.6" stroke-linecap="round"></line> <line x1="166.40000000000003" y1="-12.8" x2="166.40000000000003" y2="64.00000000000001" stroke="#689cc5" stroke-width="21.6" stroke-linecap="round"></line> <line x1="166.40000000000003" y1="243.2" x2="166.40000000000003" y2="320" stroke="#689cc5" stroke-width="21.6" stroke-linecap="round"></line> <line x1="166.40000000000003" y1="-166.39999999999998" x2="166.40000000000003" y2="-89.59999999999997" stroke="#3b4368" stroke-width="21.6" stroke-linecap="round"></line> <line x1="166.40000000000003" y1="89.60000000000001" x2="166.40000000000003" y2="166.40000000000003" stroke="#3b4368" stroke-width="21.6" stroke-linecap="round"></line> <line x1="166.40000000000003" y1="345.6" x2="166.40000000000003" y2="422.40000000000003" stroke="#3b4368" stroke-width="21.6" stroke-linecap="round"></line> <line x1="166.40000000000003" y1="-63.99999999999997" x2="166.40000000000003" y2="64" stroke="#689cc5" stroke-width="21.6" stroke-linecap="round"></line> <line x1="166.40000000000003" y1="192.00000000000003" x2="166.40000000000003" y2="320" stroke="#689cc5" stroke-width="21.6" stroke-linecap="round"></line> <line x1="166.40000000000003" y1="448" x2="166.40000000000003" y2="576" stroke="#689cc5" stroke-width="21.6" stroke-linecap="round"></line> <animateTransform attributeName="transform" type="translate" repeatCount="indefinite" dur="50s" keyTimes="0;1" values="0 0;0 -256"></animateTransform>
|
||||||
|
</g> <g> <line x1="192.00000000000003" y1="-243.2" x2="192.00000000000003" y2="-166.39999999999998" stroke="#3b4368" stroke-width="21.6" stroke-linecap="round"></line> <line x1="192.00000000000003" y1="12.8" x2="192.00000000000003" y2="89.60000000000001" stroke="#3b4368" stroke-width="21.6" stroke-linecap="round"></line> <line x1="192.00000000000003" y1="268.8" x2="192.00000000000003" y2="345.6" stroke="#3b4368" stroke-width="21.6" stroke-linecap="round"></line> <line x1="192.00000000000003" y1="-140.8" x2="192.00000000000003" y2="-64" stroke="#93dbe9" stroke-width="21.6" stroke-linecap="round"></line> <line x1="192.00000000000003" y1="115.2" x2="192.00000000000003" y2="192" stroke="#93dbe9" stroke-width="21.6" stroke-linecap="round"></line> <line x1="192.00000000000003" y1="371.2" x2="192.00000000000003" y2="448" stroke="#93dbe9" stroke-width="21.6" stroke-linecap="round"></line> <line x1="192.00000000000003" y1="-38.39999999999998" x2="192.00000000000003" y2="-12.799999999999983" stroke="#689cc5" stroke-width="21.6" stroke-linecap="round"></line> <line x1="192.00000000000003" y1="217.60000000000002" x2="192.00000000000003" y2="243.20000000000002" stroke="#689cc5" stroke-width="21.6" stroke-linecap="round"></line> <line x1="192.00000000000003" y1="473.6" x2="192.00000000000003" y2="499.20000000000005" stroke="#689cc5" stroke-width="21.6" stroke-linecap="round"></line> <animateTransform attributeName="transform" type="translate" repeatCount="indefinite" dur="16.666666666666668s" keyTimes="0;1" values="0 0;0 -256"></animateTransform>
|
||||||
|
</g> <g> <line x1="217.60000000000002" y1="-243.2" x2="217.60000000000002" y2="-217.6" stroke="#689cc5" stroke-width="21.6" stroke-linecap="round"></line> <line x1="217.60000000000002" y1="12.8" x2="217.60000000000002" y2="38.400000000000006" stroke="#689cc5" stroke-width="21.6" stroke-linecap="round"></line> <line x1="217.60000000000002" y1="268.8" x2="217.60000000000002" y2="294.4" stroke="#689cc5" stroke-width="21.6" stroke-linecap="round"></line> <line x1="217.60000000000002" y1="-192" x2="217.60000000000002" y2="-140.8" stroke="#93dbe9" stroke-width="21.6" stroke-linecap="round"></line> <line x1="217.60000000000002" y1="64" x2="217.60000000000002" y2="115.2" stroke="#93dbe9" stroke-width="21.6" stroke-linecap="round"></line> <line x1="217.60000000000002" y1="320" x2="217.60000000000002" y2="371.2" stroke="#93dbe9" stroke-width="21.6" stroke-linecap="round"></line> <line x1="217.60000000000002" y1="-115.19999999999999" x2="217.60000000000002" y2="-64" stroke="#5e6fa3" stroke-width="21.6" stroke-linecap="round"></line> <line x1="217.60000000000002" y1="140.8" x2="217.60000000000002" y2="192" stroke="#5e6fa3" stroke-width="21.6" stroke-linecap="round"></line> <line x1="217.60000000000002" y1="396.8" x2="217.60000000000002" y2="448" stroke="#5e6fa3" stroke-width="21.6" stroke-linecap="round"></line> <line x1="217.60000000000002" y1="-38.39999999999998" x2="217.60000000000002" y2="-12.799999999999983" stroke="#5e6fa3" stroke-width="21.6" stroke-linecap="round"></line> <line x1="217.60000000000002" y1="217.60000000000002" x2="217.60000000000002" y2="243.20000000000002" stroke="#5e6fa3" stroke-width="21.6" stroke-linecap="round"></line> <line x1="217.60000000000002" y1="473.6" x2="217.60000000000002" y2="499.20000000000005" stroke="#5e6fa3" stroke-width="21.6" stroke-linecap="round"></line> <animateTransform attributeName="transform" type="translate" repeatCount="indefinite" dur="50s" keyTimes="0;1" values="0 0;0 256"></animateTransform>
|
||||||
|
</g> <g> <line x1="243.20000000000002" y1="-243.2" x2="243.20000000000002" y2="-166.39999999999998" stroke="#191d3a" stroke-width="21.6" stroke-linecap="round"></line> <line x1="243.20000000000002" y1="12.8" x2="243.20000000000002" y2="89.60000000000001" stroke="#191d3a" stroke-width="21.6" stroke-linecap="round"></line> <line x1="243.20000000000002" y1="268.8" x2="243.20000000000002" y2="345.6" stroke="#191d3a" stroke-width="21.6" stroke-linecap="round"></line> <line x1="243.20000000000002" y1="-140.8" x2="243.20000000000002" y2="-64" stroke="#93dbe9" stroke-width="21.6" stroke-linecap="round"></line> <line x1="243.20000000000002" y1="115.2" x2="243.20000000000002" y2="192" stroke="#93dbe9" stroke-width="21.6" stroke-linecap="round"></line> <line x1="243.20000000000002" y1="371.2" x2="243.20000000000002" y2="448" stroke="#93dbe9" stroke-width="21.6" stroke-linecap="round"></line> <line x1="243.20000000000002" y1="-38.39999999999998" x2="243.20000000000002" y2="-12.799999999999983" stroke="#d9dbee" stroke-width="21.6" stroke-linecap="round"></line> <line x1="243.20000000000002" y1="217.60000000000002" x2="243.20000000000002" y2="243.20000000000002" stroke="#d9dbee" stroke-width="21.6" stroke-linecap="round"></line> <line x1="243.20000000000002" y1="473.6" x2="243.20000000000002" y2="499.20000000000005" stroke="#d9dbee" stroke-width="21.6" stroke-linecap="round"></line> <animateTransform attributeName="transform" type="translate" repeatCount="indefinite" dur="25s" keyTimes="0;1" values="0 0;0 -256"></animateTransform>
|
||||||
|
</g></g>
|
||||||
|
</pattern>
|
||||||
|
</defs>
|
||||||
|
<rect x="0" y="0" width="1084" height="322" fill="url(#pid-0.32277503320149736)"></rect>
|
||||||
|
</svg>
|
After Width: | Height: | Size: 16 KiB |
24
assets/img/waves.svg
Normal file
|
@ -0,0 +1,24 @@
|
||||||
|
<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" style="margin:auto;background:rgba(NaN, NaN, NaN, 0);display:block;z-index:1;position:relative" width="1084" height="322" preserveAspectRatio="xMidYMid" viewBox="0 0 1084 322">
|
||||||
|
<defs>
|
||||||
|
<pattern id="pid-0.1520523902861448" x="0" y="0" width="665.6" height="665.6" patternUnits="userSpaceOnUse">
|
||||||
|
<g transform="scale(2.6)"><path d="M -256 9.314285714285713 C -192 9.314285714285713 -192 2 -128 2 C -64 2 -64 9.314285714285713 2 9.314285714285713 C 64 9.314285714285713 64 2 128 2 C 192 2 192 9.314285714285713 256 9.314285714285713 L 384 384 L -384 384 L -384 9.314285714285713 Z" fill="none" stroke="#93dbe9" stroke-width="10" transform="translate(0 -36.57142857142857)">
|
||||||
|
<animateTransform attributeName="transform" type="translate" values="256 -36.57142857142857;0 -36.57142857142857;256 -36.57142857142857" keyTimes="0;0.5;1" dur="20s" repeatCount="indefinite" calcMode="spline" begin="0s" keySplines="0.5 0 0.5 1;0.5 0 0.5 1"></animateTransform>
|
||||||
|
</path><path d="M -256 9.314285714285713 C -192 9.314285714285713 -192 2 -128 2 C -64 2 -64 9.314285714285713 2 9.314285714285713 C 64 9.314285714285713 64 2 128 2 C 192 2 192 9.314285714285713 256 9.314285714285713 L 384 384 L -384 384 L -384 9.314285714285713 Z" fill="none" stroke="#689cc5" stroke-width="10" transform="translate(0 0)">
|
||||||
|
<animateTransform attributeName="transform" type="translate" values="0 0;256 0;0 0" keyTimes="0;0.5;1" dur="20s" repeatCount="indefinite" calcMode="spline" begin="-1.4285714285714284s" keySplines="0.5 0 0.5 1;0.5 0 0.5 1"></animateTransform>
|
||||||
|
</path><path d="M -256 9.314285714285713 C -192 9.314285714285713 -192 2 -128 2 C -64 2 -64 9.314285714285713 2 9.314285714285713 C 64 9.314285714285713 64 2 128 2 C 192 2 192 9.314285714285713 256 9.314285714285713 L 384 384 L -384 384 L -384 9.314285714285713 Z" fill="none" stroke="#5e6fa3" stroke-width="10" transform="translate(0 36.57142857142857)">
|
||||||
|
<animateTransform attributeName="transform" type="translate" values="256 36.57142857142857;0 36.57142857142857;256 36.57142857142857" keyTimes="0;0.5;1" dur="20s" repeatCount="indefinite" calcMode="spline" begin="-2.8571428571428568s" keySplines="0.5 0 0.5 1;0.5 0 0.5 1"></animateTransform>
|
||||||
|
</path><path d="M -256 9.314285714285713 C -192 9.314285714285713 -192 2 -128 2 C -64 2 -64 9.314285714285713 2 9.314285714285713 C 64 9.314285714285713 64 2 128 2 C 192 2 192 9.314285714285713 256 9.314285714285713 L 384 384 L -384 384 L -384 9.314285714285713 Z" fill="none" stroke="#3b4368" stroke-width="10" transform="translate(0 73.14285714285714)">
|
||||||
|
<animateTransform attributeName="transform" type="translate" values="0 73.14285714285714;256 73.14285714285714;0 73.14285714285714" keyTimes="0;0.5;1" dur="20s" repeatCount="indefinite" calcMode="spline" begin="-4.285714285714286s" keySplines="0.5 0 0.5 1;0.5 0 0.5 1"></animateTransform>
|
||||||
|
</path><path d="M -256 9.314285714285713 C -192 9.314285714285713 -192 2 -128 2 C -64 2 -64 9.314285714285713 2 9.314285714285713 C 64 9.314285714285713 64 2 128 2 C 192 2 192 9.314285714285713 256 9.314285714285713 L 384 384 L -384 384 L -384 9.314285714285713 Z" fill="none" stroke="#191d3a" stroke-width="10" transform="translate(0 109.71428571428571)">
|
||||||
|
<animateTransform attributeName="transform" type="translate" values="256 109.71428571428571;0 109.71428571428571;256 109.71428571428571" keyTimes="0;0.5;1" dur="20s" repeatCount="indefinite" calcMode="spline" begin="-5.7142857142857135s" keySplines="0.5 0 0.5 1;0.5 0 0.5 1"></animateTransform>
|
||||||
|
</path><path d="M -256 9.314285714285713 C -192 9.314285714285713 -192 2 -128 2 C -64 2 -64 9.314285714285713 2 9.314285714285713 C 64 9.314285714285713 64 2 128 2 C 192 2 192 9.314285714285713 256 9.314285714285713 L 384 384 L -384 384 L -384 9.314285714285713 Z" fill="none" stroke="#d9dbee" stroke-width="10" transform="translate(0 146.28571428571428)">
|
||||||
|
<animateTransform attributeName="transform" type="translate" values="0 146.28571428571428;256 146.28571428571428;0 146.28571428571428" keyTimes="0;0.5;1" dur="20s" repeatCount="indefinite" calcMode="spline" begin="-7.142857142857142s" keySplines="0.5 0 0.5 1;0.5 0 0.5 1"></animateTransform>
|
||||||
|
</path><path d="M -256 9.314285714285713 C -192 9.314285714285713 -192 2 -128 2 C -64 2 -64 9.314285714285713 2 9.314285714285713 C 64 9.314285714285713 64 2 128 2 C 192 2 192 9.314285714285713 256 9.314285714285713 L 384 384 L -384 384 L -384 9.314285714285713 Z" fill="none" stroke="#b3b7e2" stroke-width="10" transform="translate(0 182.85714285714286)">
|
||||||
|
<animateTransform attributeName="transform" type="translate" values="256 182.85714285714286;0 182.85714285714286;256 182.85714285714286" keyTimes="0;0.5;1" dur="20s" repeatCount="indefinite" calcMode="spline" begin="-8.571428571428571s" keySplines="0.5 0 0.5 1;0.5 0 0.5 1"></animateTransform>
|
||||||
|
</path><path d="M -256 9.314285714285713 C -192 9.314285714285713 -192 2 -128 2 C -64 2 -64 9.314285714285713 2 9.314285714285713 C 64 9.314285714285713 64 2 128 2 C 192 2 192 9.314285714285713 256 9.314285714285713 L 384 384 L -384 384 L -384 9.314285714285713 Z" fill="none" stroke="#93dbe9" stroke-width="10" transform="translate(0 219.42857142857142)">
|
||||||
|
<animateTransform attributeName="transform" type="translate" values="0 219.42857142857142;256 219.42857142857142;0 219.42857142857142" keyTimes="0;0.5;1" dur="20s" repeatCount="indefinite" calcMode="spline" begin="0s" keySplines="0.5 0 0.5 1;0.5 0 0.5 1"></animateTransform>
|
||||||
|
</path></g>
|
||||||
|
</pattern>
|
||||||
|
</defs>
|
||||||
|
<rect x="0" y="0" width="1084" height="322" fill="url(#pid-0.1520523902861448)"></rect>
|
||||||
|
</svg>
|
After Width: | Height: | Size: 5.6 KiB |
|
@ -13,7 +13,7 @@ function createCopyButton(highlightDiv) {
|
||||||
}
|
}
|
||||||
|
|
||||||
async function copyCodeToClipboard(button, highlightDiv) {
|
async function copyCodeToClipboard(button, highlightDiv) {
|
||||||
const codeToCopy = highlightDiv.querySelector(":last-child > .chroma > code").innerText;
|
const codeToCopy = highlightDiv.querySelector(":last-child").innerText;
|
||||||
try {
|
try {
|
||||||
result = await navigator.permissions.query({ name: "clipboard-write" });
|
result = await navigator.permissions.query({ name: "clipboard-write" });
|
||||||
if (result.state == "granted" || result.state == "prompt") {
|
if (result.state == "granted" || result.state == "prompt") {
|
||||||
|
|
20
assets/js/mermaid.js
Normal file
|
@ -0,0 +1,20 @@
|
||||||
|
function css(name) {
|
||||||
|
return "rgb(" + getComputedStyle(document.documentElement).getPropertyValue(name) + ")";
|
||||||
|
}
|
||||||
|
|
||||||
|
mermaid.initialize({
|
||||||
|
theme: "base",
|
||||||
|
themeVariables: {
|
||||||
|
background: css("--color-neutral"),
|
||||||
|
primaryColor: css("--color-primary-200"),
|
||||||
|
secondaryColor: css("--color-secondary-200"),
|
||||||
|
tertiaryColor: css("--color-neutral-100"),
|
||||||
|
primaryBorderColor: css("--color-primary-400"),
|
||||||
|
secondaryBorderColor: css("--color-secondary-400"),
|
||||||
|
tertiaryBorderColor: css("--color-neutral-400"),
|
||||||
|
lineColor: css("--color-neutral-600"),
|
||||||
|
fontFamily:
|
||||||
|
"ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,segoe ui,Roboto,helvetica neue,Arial,noto sans,sans-serif",
|
||||||
|
fontSize: "16px",
|
||||||
|
},
|
||||||
|
});
|
|
@ -1,7 +1,9 @@
|
||||||
var liked_page = false
|
var liked_page = false
|
||||||
|
var id = oid ? oid.replaceAll("/", "-") : oid
|
||||||
|
var id_likes = oid_likes ? oid_likes.replaceAll("/", "-") : oid_likes
|
||||||
|
|
||||||
if (typeof auth !== 'undefined') {
|
if (typeof auth !== 'undefined') {
|
||||||
var id = oid ? oid.replaceAll("/", "-") : oid
|
|
||||||
var viewed = localStorage.getItem(id);
|
var viewed = localStorage.getItem(id);
|
||||||
|
|
||||||
if (!viewed) {
|
if (!viewed) {
|
||||||
|
@ -28,14 +30,13 @@ if (typeof auth !== 'undefined') {
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
var id_likes = oid_likes ? oid_likes.replaceAll("/", "-") : oid_likes
|
|
||||||
var liked = localStorage.getItem(id_likes);
|
var liked = localStorage.getItem(id_likes);
|
||||||
|
|
||||||
if (liked) {
|
if (liked) {
|
||||||
liked_page = true
|
liked_page = true
|
||||||
document.querySelectorAll("span[id='likes_button_heart']")[0].style.display = ""
|
document.querySelectorAll("span[id='button_likes_heart']")[0].style.display = ""
|
||||||
document.querySelectorAll("span[id='likes_button_emtpty_heart']")[0].style.display = "none"
|
document.querySelectorAll("span[id='button_likes_emtpty_heart']")[0].style.display = "none"
|
||||||
document.querySelectorAll("span[id='likes_button_text']")[0].innerText = ""
|
document.querySelectorAll("span[id='button_likes_text']")[0].innerText = ""
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -47,9 +48,9 @@ function like_article(id_likes) {
|
||||||
docRef.get().then((doc) => {
|
docRef.get().then((doc) => {
|
||||||
liked_page = true
|
liked_page = true
|
||||||
localStorage.setItem(id_likes, true);
|
localStorage.setItem(id_likes, true);
|
||||||
document.querySelectorAll("span[id='likes_button_heart']")[0].style.display = ""
|
document.querySelectorAll("span[id='button_likes_heart']")[0].style.display = ""
|
||||||
document.querySelectorAll("span[id='likes_button_emtpty_heart']")[0].style.display = "none"
|
document.querySelectorAll("span[id='button_likes_emtpty_heart']")[0].style.display = "none"
|
||||||
document.querySelectorAll("span[id='likes_button_text']")[0].innerText = ""
|
document.querySelectorAll("span[id='button_likes_text']")[0].innerText = ""
|
||||||
if (doc.exists) {
|
if (doc.exists) {
|
||||||
db.collection('likes').doc(id_likes).update({
|
db.collection('likes').doc(id_likes).update({
|
||||||
likes: firebase.firestore.FieldValue.increment(1)
|
likes: firebase.firestore.FieldValue.increment(1)
|
||||||
|
@ -75,9 +76,9 @@ function remove_like_article(id_likes) {
|
||||||
docRef.get().then((doc) => {
|
docRef.get().then((doc) => {
|
||||||
liked_page = false
|
liked_page = false
|
||||||
localStorage.removeItem(id_likes);
|
localStorage.removeItem(id_likes);
|
||||||
document.querySelectorAll("span[id='likes_button_heart']")[0].style.display = "none"
|
document.querySelectorAll("span[id='button_likes_heart']")[0].style.display = "none"
|
||||||
document.querySelectorAll("span[id='likes_button_emtpty_heart']")[0].style.display = ""
|
document.querySelectorAll("span[id='button_likes_emtpty_heart']")[0].style.display = ""
|
||||||
document.querySelectorAll("span[id='likes_button_text']")[0].innerText = "\xa0Like"
|
document.querySelectorAll("span[id='button_likes_text']")[0].innerText = "\xa0Like"
|
||||||
if (doc.exists) {
|
if (doc.exists) {
|
||||||
db.collection('likes').doc(id_likes).update({
|
db.collection('likes').doc(id_likes).update({
|
||||||
likes: firebase.firestore.FieldValue.increment(-1)
|
likes: firebase.firestore.FieldValue.increment(-1)
|
||||||
|
@ -97,7 +98,6 @@ function remove_like_article(id_likes) {
|
||||||
}
|
}
|
||||||
|
|
||||||
function process_article() {
|
function process_article() {
|
||||||
var id_likes = oid_likes ? oid_likes.replaceAll("/", "-") : oid_likes
|
|
||||||
if (!liked_page) {
|
if (!liked_page) {
|
||||||
like_article(id_likes)
|
like_article(id_likes)
|
||||||
} else {
|
} else {
|
||||||
|
|
|
@ -6,12 +6,24 @@ if (typeof auth !== 'undefined') {
|
||||||
return x.toString().replace(/\B(?=(\d{3})+(?!\d))/g, ',');
|
return x.toString().replace(/\B(?=(\d{3})+(?!\d))/g, ',');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function toggleLoaders(node){
|
||||||
|
var classesString = node.className;
|
||||||
|
if(classesString == "") return
|
||||||
|
var classes = classesString.split(" ");
|
||||||
|
for(var i in classes){
|
||||||
|
node.classList.toggle(classes[i])
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
var update_views = function (node, id) {
|
var update_views = function (node, id) {
|
||||||
viewsCollection.doc(id).onSnapshot(doc => {
|
viewsCollection.doc(id).onSnapshot(doc => {
|
||||||
var data = doc.data();
|
var data = doc.data();
|
||||||
if (data) {
|
if (data) {
|
||||||
node.innerText = numberWithCommas(data.views)
|
node.innerText = numberWithCommas(data.views)
|
||||||
|
} else {
|
||||||
|
node.innerText = 0
|
||||||
}
|
}
|
||||||
|
toggleLoaders(node)
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -20,7 +32,11 @@ if (typeof auth !== 'undefined') {
|
||||||
var data = doc.data();
|
var data = doc.data();
|
||||||
if (data) {
|
if (data) {
|
||||||
node.innerText = numberWithCommas(data.likes)
|
node.innerText = numberWithCommas(data.likes)
|
||||||
|
} else {
|
||||||
|
node.innerText = 0
|
||||||
}
|
}
|
||||||
|
toggleLoaders(node)
|
||||||
|
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -63,6 +63,21 @@ document.addEventListener("keydown", function (event) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Enter to get to results
|
||||||
|
if (event.key == "Enter") {
|
||||||
|
if (searchVisible && hasResults) {
|
||||||
|
event.preventDefault();
|
||||||
|
if (document.activeElement == input) {
|
||||||
|
first.focus();
|
||||||
|
} else {
|
||||||
|
document.activeElement.click();
|
||||||
|
}
|
||||||
|
}else{
|
||||||
|
event.preventDefault();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
});
|
});
|
||||||
|
|
||||||
// Update search on each keypress
|
// Update search on each keypress
|
||||||
|
@ -123,6 +138,12 @@ function buildIndex() {
|
||||||
{ name: "content", weight: 0.4 },
|
{ name: "content", weight: 0.4 },
|
||||||
],
|
],
|
||||||
};
|
};
|
||||||
|
/*var finalIndex = [];
|
||||||
|
for (var i in data) {
|
||||||
|
if(data[i].type != "users" && data[i].type != "tags" && data[i].type != "categories"){
|
||||||
|
finalIndex.push(data[i]);
|
||||||
|
}
|
||||||
|
}*/
|
||||||
fuse = new Fuse(data, options);
|
fuse = new Fuse(data, options);
|
||||||
indexed = true;
|
indexed = true;
|
||||||
});
|
});
|
||||||
|
@ -134,13 +155,18 @@ function executeQuery(term) {
|
||||||
|
|
||||||
if (results.length > 0) {
|
if (results.length > 0) {
|
||||||
results.forEach(function (value, key) {
|
results.forEach(function (value, key) {
|
||||||
|
var title = value.item.externalUrl? value.item.title + '<span class="text-xs ml-2 align-center cursor-default text-neutral-400 dark:text-neutral-500">'+value.item.externalUrl+'</span>' : value.item.title;
|
||||||
|
var linkconfig = value.item.externalUrl? 'target="_blank" rel="noopener" href="'+value.item.externalUrl+'"' : 'href="'+value.item.permalink+'"';
|
||||||
resultsHTML =
|
resultsHTML =
|
||||||
resultsHTML +
|
resultsHTML +
|
||||||
`<li class="mb-2">
|
`<li class="mb-2">
|
||||||
<a class="flex items-center px-3 py-2 rounded-md appearance-none bg-neutral-100 dark:bg-neutral-700 focus:bg-primary-100 hover:bg-primary-100 dark:hover:bg-primary-900 dark:focus:bg-primary-900 focus:outline-dotted focus:outline-transparent focus:outline-2" href="${value.item.permalink}" tabindex="0">
|
<a class="flex items-center px-3 py-2 rounded-md appearance-none bg-neutral-100 dark:bg-neutral-700 focus:bg-primary-100 hover:bg-primary-100 dark:hover:bg-primary-900 dark:focus:bg-primary-900 focus:outline-dotted focus:outline-transparent focus:outline-2"
|
||||||
|
${linkconfig} tabindex="0">
|
||||||
<div class="grow">
|
<div class="grow">
|
||||||
<div class="-mb-1 text-lg font-bold">${value.item.title}</div>
|
<div class="-mb-1 text-lg font-bold">
|
||||||
<div class="text-sm text-neutral-500 dark:text-neutral-400">${value.item.section}<span class="px-2 text-primary-500">·</span>${value.item.date}</span></div>
|
${title}
|
||||||
|
</div>
|
||||||
|
<div class="text-sm text-neutral-500 dark:text-neutral-400">${value.item.section}<span class="px-2 text-primary-500">·</span>${value.item.date? value.item.date : ""}</span></div>
|
||||||
<div class="text-sm italic">${value.item.summary}</div>
|
<div class="text-sm italic">${value.item.summary}</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="ml-2 ltr:block rtl:hidden text-neutral-500">→</div>
|
<div class="ml-2 ltr:block rtl:hidden text-neutral-500">→</div>
|
||||||
|
|
22
assets/js/shortcodes/gallery.js
Normal file
|
@ -0,0 +1,22 @@
|
||||||
|
function _getDefaultPackeryOptions() {
|
||||||
|
return {
|
||||||
|
percentPosition: true,
|
||||||
|
gutter: 5,
|
||||||
|
resize: true
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
(function init() {
|
||||||
|
|
||||||
|
$(window).on("load", function () {
|
||||||
|
let packeries = [];
|
||||||
|
let nodeGalleries = document.querySelectorAll('.gallery');
|
||||||
|
|
||||||
|
nodeGalleries.forEach(nodeGallery => {
|
||||||
|
// TODO : implement a reader of Packery configuration _getPackeryOptions; for example by reading data-attribute
|
||||||
|
let packery = new Packery(nodeGallery, _getDefaultPackeryOptions());
|
||||||
|
packeries.push(packery);
|
||||||
|
});
|
||||||
|
console.groupEnd();
|
||||||
|
});
|
||||||
|
})();
|
59
assets/js/zen-mode.js
Normal file
|
@ -0,0 +1,59 @@
|
||||||
|
function _toogleZenMode(zendModeButton) {
|
||||||
|
// Nodes selection
|
||||||
|
const body = document.querySelector('body');
|
||||||
|
const tocRight = document.querySelector('.toc-right');
|
||||||
|
const tocInside = document.querySelector('.toc-inside');
|
||||||
|
const articleContent = document.querySelector('.article-content');
|
||||||
|
const header = document.querySelector('#single_header');
|
||||||
|
|
||||||
|
|
||||||
|
// Add semantic class into body tag
|
||||||
|
body.classList.toggle('zen-mode-enable');
|
||||||
|
|
||||||
|
// Show/Hide 'toc right' and 'toc inside'
|
||||||
|
if (tocRight)
|
||||||
|
tocRight.classList.toggle('lg:block');
|
||||||
|
if (tocInside)
|
||||||
|
tocInside.classList.toggle('lg:hidden');
|
||||||
|
|
||||||
|
// Change width of article content
|
||||||
|
articleContent.classList.toggle('max-w-fit');
|
||||||
|
articleContent.classList.toggle('max-w-prose');
|
||||||
|
|
||||||
|
// Read i18n title from data-attributes
|
||||||
|
const titleI18nDisable = zendModeButton.getAttribute('data-title-i18n-disable');
|
||||||
|
const titleI18nEnable = zendModeButton.getAttribute('data-title-i18n-enable');
|
||||||
|
|
||||||
|
if (body.classList.contains('zen-mode-enable')) {
|
||||||
|
// Persist configuration
|
||||||
|
//localStorage.setItem('blowfish-zen-mode-enabled', 'true');
|
||||||
|
|
||||||
|
// Change title to enable
|
||||||
|
zendModeButton.setAttribute('title', titleI18nEnable)
|
||||||
|
// Auto-scroll to title article
|
||||||
|
window.scrollTo(window.scrollX, header.getBoundingClientRect().top - 90);
|
||||||
|
} else {
|
||||||
|
//localStorage.setItem('blowfish-zen-mode-enabled', 'false');
|
||||||
|
zendModeButton.setAttribute('title', titleI18nDisable);
|
||||||
|
document.querySelector('body').scrollIntoView();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function _registerZendModeButtonClick(zendModeButton) {
|
||||||
|
zendModeButton.addEventListener('click', function (event) {
|
||||||
|
event.preventDefault();
|
||||||
|
|
||||||
|
// Toggle zen-mode
|
||||||
|
_toogleZenMode(zendModeButton);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
(function init() {
|
||||||
|
window.addEventListener("DOMContentLoaded", (event) => {
|
||||||
|
// Register click on 'zen-mode-button' node element
|
||||||
|
const zendModeButton = document.getElementById('zen-mode-button');
|
||||||
|
if (zendModeButton !== null && zendModeButton !== undefined) {
|
||||||
|
_registerZendModeButtonClick(zendModeButton);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
})();
|
8
assets/lib/chart/chart.min.js
vendored
2
assets/lib/katex/auto-render.min.js
vendored
|
@ -1 +1 @@
|
||||||
!function(e,t){"object"==typeof exports&&"object"==typeof module?module.exports=t(require("katex")):"function"==typeof define&&define.amd?define(["katex"],t):"object"==typeof exports?exports.renderMathInElement=t(require("katex")):e.renderMathInElement=t(e.katex)}("undefined"!=typeof self?self:this,(function(e){return function(){"use strict";var t={771:function(t){t.exports=e}},r={};function n(e){var i=r[e];if(void 0!==i)return i.exports;var a=r[e]={exports:{}};return t[e](a,a.exports,n),a.exports}n.n=function(e){var t=e&&e.__esModule?function(){return e.default}:function(){return e};return n.d(t,{a:t}),t},n.d=function(e,t){for(var r in t)n.o(t,r)&&!n.o(e,r)&&Object.defineProperty(e,r,{enumerable:!0,get:t[r]})},n.o=function(e,t){return Object.prototype.hasOwnProperty.call(e,t)};var i={};return function(){n.d(i,{default:function(){return s}});var e=n(771),t=n.n(e),r=function(e,t,r){for(var n=r,i=0,a=e.length;n<t.length;){var o=t[n];if(i<=0&&t.slice(n,n+a)===e)return n;"\\"===o?n++:"{"===o?i++:"}"===o&&i--,n++}return-1},a=/^\\begin{/,o=function(e,t){for(var n,i=[],o=new RegExp("("+t.map((function(e){return e.left.replace(/[-/\\^$*+?.()|[\]{}]/g,"\\$&")})).join("|")+")");-1!==(n=e.search(o));){n>0&&(i.push({type:"text",data:e.slice(0,n)}),e=e.slice(n));var l=t.findIndex((function(t){return e.startsWith(t.left)}));if(-1===(n=r(t[l].right,e,t[l].left.length)))break;var d=e.slice(0,n+t[l].right.length),s=a.test(d)?d:e.slice(t[l].left.length,n);i.push({type:"math",data:s,rawData:d,display:t[l].display}),e=e.slice(n+t[l].right.length)}return""!==e&&i.push({type:"text",data:e}),i},l=function(e,r){var n=o(e,r.delimiters);if(1===n.length&&"text"===n[0].type)return null;for(var i=document.createDocumentFragment(),a=0;a<n.length;a++)if("text"===n[a].type)i.appendChild(document.createTextNode(n[a].data));else{var l=document.createElement("span"),d=n[a].data;r.displayMode=n[a].display;try{r.preProcess&&(d=r.preProcess(d)),t().render(d,l,r)}catch(e){if(!(e instanceof t().ParseError))throw e;r.errorCallback("KaTeX auto-render: Failed to parse `"+n[a].data+"` with ",e),i.appendChild(document.createTextNode(n[a].rawData));continue}i.appendChild(l)}return i},d=function e(t,r){for(var n=0;n<t.childNodes.length;n++){var i=t.childNodes[n];if(3===i.nodeType){for(var a=i.textContent,o=i.nextSibling,d=0;o&&o.nodeType===Node.TEXT_NODE;)a+=o.textContent,o=o.nextSibling,d++;var s=l(a,r);if(s){for(var f=0;f<d;f++)i.nextSibling.remove();n+=s.childNodes.length-1,t.replaceChild(s,i)}else n+=d}else 1===i.nodeType&&function(){var t=" "+i.className+" ";-1===r.ignoredTags.indexOf(i.nodeName.toLowerCase())&&r.ignoredClasses.every((function(e){return-1===t.indexOf(" "+e+" ")}))&&e(i,r)}()}},s=function(e,t){if(!e)throw new Error("No element provided to render");var r={};for(var n in t)t.hasOwnProperty(n)&&(r[n]=t[n]);r.delimiters=r.delimiters||[{left:"$$",right:"$$",display:!0},{left:"\\(",right:"\\)",display:!1},{left:"\\begin{equation}",right:"\\end{equation}",display:!0},{left:"\\begin{align}",right:"\\end{align}",display:!0},{left:"\\begin{alignat}",right:"\\end{alignat}",display:!0},{left:"\\begin{gather}",right:"\\end{gather}",display:!0},{left:"\\begin{CD}",right:"\\end{CD}",display:!0},{left:"\\[",right:"\\]",display:!0}],r.ignoredTags=r.ignoredTags||["script","noscript","style","textarea","pre","code","option"],r.ignoredClasses=r.ignoredClasses||[],r.errorCallback=r.errorCallback||console.error,r.macros=r.macros||{},d(e,r)}}(),i=i.default}()}));
|
!function(e,t){"object"==typeof exports&&"object"==typeof module?module.exports=t(require("katex")):"function"==typeof define&&define.amd?define(["katex"],t):"object"==typeof exports?exports.renderMathInElement=t(require("katex")):e.renderMathInElement=t(e.katex)}("undefined"!=typeof self?self:this,(function(e){return function(){"use strict";var t={771:function(t){t.exports=e}},n={};function r(e){var o=n[e];if(void 0!==o)return o.exports;var i=n[e]={exports:{}};return t[e](i,i.exports,r),i.exports}r.n=function(e){var t=e&&e.__esModule?function(){return e.default}:function(){return e};return r.d(t,{a:t}),t},r.d=function(e,t){for(var n in t)r.o(t,n)&&!r.o(e,n)&&Object.defineProperty(e,n,{enumerable:!0,get:t[n]})},r.o=function(e,t){return Object.prototype.hasOwnProperty.call(e,t)};var o={};return function(){r.d(o,{default:function(){return d}});var e=r(771),t=r.n(e);const n=function(e,t,n){let r=n,o=0;const i=e.length;for(;r<t.length;){const n=t[r];if(o<=0&&t.slice(r,r+i)===e)return r;"\\"===n?r++:"{"===n?o++:"}"===n&&o--,r++}return-1},i=/^\\begin{/;var a=function(e,t){let r;const o=[],a=new RegExp("("+t.map((e=>e.left.replace(/[-/\\^$*+?.()|[\]{}]/g,"\\$&"))).join("|")+")");for(;r=e.search(a),-1!==r;){r>0&&(o.push({type:"text",data:e.slice(0,r)}),e=e.slice(r));const a=t.findIndex((t=>e.startsWith(t.left)));if(r=n(t[a].right,e,t[a].left.length),-1===r)break;const l=e.slice(0,r+t[a].right.length),s=i.test(l)?l:e.slice(t[a].left.length,r);o.push({type:"math",data:s,rawData:l,display:t[a].display}),e=e.slice(r+t[a].right.length)}return""!==e&&o.push({type:"text",data:e}),o};const l=function(e,n){const r=a(e,n.delimiters);if(1===r.length&&"text"===r[0].type)return null;const o=document.createDocumentFragment();for(let e=0;e<r.length;e++)if("text"===r[e].type)o.appendChild(document.createTextNode(r[e].data));else{const i=document.createElement("span");let a=r[e].data;n.displayMode=r[e].display;try{n.preProcess&&(a=n.preProcess(a)),t().render(a,i,n)}catch(i){if(!(i instanceof t().ParseError))throw i;n.errorCallback("KaTeX auto-render: Failed to parse `"+r[e].data+"` with ",i),o.appendChild(document.createTextNode(r[e].rawData));continue}o.appendChild(i)}return o},s=function(e,t){for(let n=0;n<e.childNodes.length;n++){const r=e.childNodes[n];if(3===r.nodeType){let o=r.textContent,i=r.nextSibling,a=0;for(;i&&i.nodeType===Node.TEXT_NODE;)o+=i.textContent,i=i.nextSibling,a++;const s=l(o,t);if(s){for(let e=0;e<a;e++)r.nextSibling.remove();n+=s.childNodes.length-1,e.replaceChild(s,r)}else n+=a}else if(1===r.nodeType){const e=" "+r.className+" ";-1===t.ignoredTags.indexOf(r.nodeName.toLowerCase())&&t.ignoredClasses.every((t=>-1===e.indexOf(" "+t+" ")))&&s(r,t)}}};var d=function(e,t){if(!e)throw new Error("No element provided to render");const n={};for(const e in t)t.hasOwnProperty(e)&&(n[e]=t[e]);n.delimiters=n.delimiters||[{left:"$$",right:"$$",display:!0},{left:"\\(",right:"\\)",display:!1},{left:"\\begin{equation}",right:"\\end{equation}",display:!0},{left:"\\begin{align}",right:"\\end{align}",display:!0},{left:"\\begin{alignat}",right:"\\end{alignat}",display:!0},{left:"\\begin{gather}",right:"\\end{gather}",display:!0},{left:"\\begin{CD}",right:"\\end{CD}",display:!0},{left:"\\[",right:"\\]",display:!0}],n.ignoredTags=n.ignoredTags||["script","noscript","style","textarea","pre","code","option"],n.ignoredClasses=n.ignoredClasses||[],n.errorCallback=n.errorCallback||console.error,n.macros=n.macros||{},s(e,n)}}(),o=o.default}()}));
|
2
assets/lib/katex/katex.min.css
vendored
2
assets/lib/katex/katex.min.js
vendored
95
assets/lib/lite-youtube-embed/lite-yt-embed.css
Normal file
|
@ -0,0 +1,95 @@
|
||||||
|
lite-youtube {
|
||||||
|
background-color: #000;
|
||||||
|
position: relative;
|
||||||
|
display: block;
|
||||||
|
contain: content;
|
||||||
|
background-position: center center;
|
||||||
|
background-size: cover;
|
||||||
|
cursor: pointer;
|
||||||
|
max-width: 720px;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* gradient */
|
||||||
|
lite-youtube::before {
|
||||||
|
content: attr(data-title);
|
||||||
|
display: block;
|
||||||
|
position: absolute;
|
||||||
|
top: 0;
|
||||||
|
/* Pixel-perfect port of YT's gradient PNG, using https://github.com/bluesmoon/pngtocss plus optimizations */
|
||||||
|
background-image: linear-gradient(180deg, rgb(0 0 0 / 67%) 0%, rgb(0 0 0 / 54%) 14%, rgb(0 0 0 / 15%) 54%, rgb(0 0 0 / 5%) 72%, rgb(0 0 0 / 0%) 94%);
|
||||||
|
height: 99px;
|
||||||
|
width: 100%;
|
||||||
|
font-family: "YouTube Noto",Roboto,Arial,Helvetica,sans-serif;
|
||||||
|
color: hsl(0deg 0% 93.33%);
|
||||||
|
text-shadow: 0 0 2px rgba(0,0,0,.5);
|
||||||
|
font-size: 18px;
|
||||||
|
padding: 25px 20px;
|
||||||
|
overflow: hidden;
|
||||||
|
white-space: nowrap;
|
||||||
|
text-overflow: ellipsis;
|
||||||
|
box-sizing: border-box;
|
||||||
|
}
|
||||||
|
|
||||||
|
lite-youtube:hover::before {
|
||||||
|
color: white;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* responsive iframe with a 16:9 aspect ratio
|
||||||
|
thanks https://css-tricks.com/responsive-iframes/
|
||||||
|
*/
|
||||||
|
lite-youtube::after {
|
||||||
|
content: "";
|
||||||
|
display: block;
|
||||||
|
padding-bottom: calc(100% / (16 / 9));
|
||||||
|
}
|
||||||
|
lite-youtube > iframe {
|
||||||
|
width: 100%;
|
||||||
|
height: 100%;
|
||||||
|
position: absolute;
|
||||||
|
top: 0;
|
||||||
|
left: 0;
|
||||||
|
border: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* play button */
|
||||||
|
lite-youtube > .lty-playbtn {
|
||||||
|
display: block;
|
||||||
|
/* Make the button element cover the whole area for a large hover/click target… */
|
||||||
|
width: 100%;
|
||||||
|
height: 100%;
|
||||||
|
/* …but visually it's still the same size */
|
||||||
|
background: no-repeat center/68px 48px;
|
||||||
|
/* YT's actual play button svg */
|
||||||
|
background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 68 48"><path d="M66.52 7.74c-.78-2.93-2.49-5.41-5.42-6.19C55.79.13 34 0 34 0S12.21.13 6.9 1.55c-2.93.78-4.63 3.26-5.42 6.19C.06 13.05 0 24 0 24s.06 10.95 1.48 16.26c.78 2.93 2.49 5.41 5.42 6.19C12.21 47.87 34 48 34 48s21.79-.13 27.1-1.55c2.93-.78 4.64-3.26 5.42-6.19C67.94 34.95 68 24 68 24s-.06-10.95-1.48-16.26z" fill="red"/><path d="M45 24 27 14v20" fill="white"/></svg>');
|
||||||
|
position: absolute;
|
||||||
|
cursor: pointer;
|
||||||
|
z-index: 1;
|
||||||
|
filter: grayscale(100%);
|
||||||
|
transition: filter .1s cubic-bezier(0, 0, 0.2, 1);
|
||||||
|
border: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
lite-youtube:hover > .lty-playbtn,
|
||||||
|
lite-youtube .lty-playbtn:focus {
|
||||||
|
filter: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Post-click styles */
|
||||||
|
lite-youtube.lyt-activated {
|
||||||
|
cursor: unset;
|
||||||
|
}
|
||||||
|
lite-youtube.lyt-activated::before,
|
||||||
|
lite-youtube.lyt-activated > .lty-playbtn {
|
||||||
|
opacity: 0;
|
||||||
|
pointer-events: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
.lyt-visually-hidden {
|
||||||
|
clip: rect(0 0 0 0);
|
||||||
|
clip-path: inset(50%);
|
||||||
|
height: 1px;
|
||||||
|
overflow: hidden;
|
||||||
|
position: absolute;
|
||||||
|
white-space: nowrap;
|
||||||
|
width: 1px;
|
||||||
|
}
|
225
assets/lib/lite-youtube-embed/lite-yt-embed.js
Normal file
|
@ -0,0 +1,225 @@
|
||||||
|
/**
|
||||||
|
* A lightweight youtube embed. Still should feel the same to the user, just MUCH faster to initialize and paint.
|
||||||
|
*
|
||||||
|
* Thx to these as the inspiration
|
||||||
|
* https://storage.googleapis.com/amp-vs-non-amp/youtube-lazy.html
|
||||||
|
* https://autoplay-youtube-player.glitch.me/
|
||||||
|
*
|
||||||
|
* Once built it, I also found these:
|
||||||
|
* https://github.com/ampproject/amphtml/blob/master/extensions/amp-youtube (👍👍)
|
||||||
|
* https://github.com/Daugilas/lazyYT
|
||||||
|
* https://github.com/vb/lazyframe
|
||||||
|
*/
|
||||||
|
class LiteYTEmbed extends HTMLElement {
|
||||||
|
connectedCallback() {
|
||||||
|
this.videoId = this.getAttribute('videoid');
|
||||||
|
|
||||||
|
let playBtnEl = this.querySelector('.lty-playbtn');
|
||||||
|
// A label for the button takes priority over a [playlabel] attribute on the custom-element
|
||||||
|
this.playLabel = (playBtnEl && playBtnEl.textContent.trim()) || this.getAttribute('playlabel') || 'Play';
|
||||||
|
|
||||||
|
this.dataset.title = this.getAttribute('title') || "";
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Lo, the youtube poster image! (aka the thumbnail, image placeholder, etc)
|
||||||
|
*
|
||||||
|
* See https://github.com/paulirish/lite-youtube-embed/blob/master/youtube-thumbnail-urls.md
|
||||||
|
*/
|
||||||
|
if (!this.style.backgroundImage) {
|
||||||
|
this.style.backgroundImage = `url("https://i.ytimg.com/vi/${this.videoId}/hqdefault.jpg")`;
|
||||||
|
this.upgradePosterImage();
|
||||||
|
}
|
||||||
|
|
||||||
|
// Set up play button, and its visually hidden label
|
||||||
|
if (!playBtnEl) {
|
||||||
|
playBtnEl = document.createElement('button');
|
||||||
|
playBtnEl.type = 'button';
|
||||||
|
playBtnEl.classList.add('lty-playbtn');
|
||||||
|
this.append(playBtnEl);
|
||||||
|
}
|
||||||
|
if (!playBtnEl.textContent) {
|
||||||
|
const playBtnLabelEl = document.createElement('span');
|
||||||
|
playBtnLabelEl.className = 'lyt-visually-hidden';
|
||||||
|
playBtnLabelEl.textContent = this.playLabel;
|
||||||
|
playBtnEl.append(playBtnLabelEl);
|
||||||
|
}
|
||||||
|
|
||||||
|
this.addNoscriptIframe();
|
||||||
|
|
||||||
|
playBtnEl.removeAttribute('href');
|
||||||
|
|
||||||
|
// On hover (or tap), warm up the TCP connections we're (likely) about to use.
|
||||||
|
this.addEventListener('pointerover', LiteYTEmbed.warmConnections, {once: true});
|
||||||
|
|
||||||
|
// Once the user clicks, add the real iframe and drop our play button
|
||||||
|
// TODO: In the future we could be like amp-youtube and silently swap in the iframe during idle time
|
||||||
|
// We'd want to only do this for in-viewport or near-viewport ones: https://github.com/ampproject/amphtml/pull/5003
|
||||||
|
this.addEventListener('click', this.activate);
|
||||||
|
|
||||||
|
// Chrome & Edge desktop have no problem with the basic YouTube Embed with ?autoplay=1
|
||||||
|
// However Safari desktop and most/all mobile browsers do not successfully track the user gesture of clicking through the creation/loading of the iframe,
|
||||||
|
// so they don't autoplay automatically. Instead we must load an additional 2 sequential JS files (1KB + 165KB) (un-br) for the YT Player API
|
||||||
|
// TODO: Try loading the the YT API in parallel with our iframe and then attaching/playing it. #82
|
||||||
|
this.needsYTApi = this.hasAttribute("js-api") || navigator.vendor.includes('Apple') || navigator.userAgent.includes('Mobi');
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Add a <link rel={preload | preconnect} ...> to the head
|
||||||
|
*/
|
||||||
|
static addPrefetch(kind, url, as) {
|
||||||
|
const linkEl = document.createElement('link');
|
||||||
|
linkEl.rel = kind;
|
||||||
|
linkEl.href = url;
|
||||||
|
if (as) {
|
||||||
|
linkEl.as = as;
|
||||||
|
}
|
||||||
|
document.head.append(linkEl);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Begin pre-connecting to warm up the iframe load
|
||||||
|
* Since the embed's network requests load within its iframe,
|
||||||
|
* preload/prefetch'ing them outside the iframe will only cause double-downloads.
|
||||||
|
* So, the best we can do is warm up a few connections to origins that are in the critical path.
|
||||||
|
*
|
||||||
|
* Maybe `<link rel=preload as=document>` would work, but it's unsupported: http://crbug.com/593267
|
||||||
|
* But TBH, I don't think it'll happen soon with Site Isolation and split caches adding serious complexity.
|
||||||
|
*/
|
||||||
|
static warmConnections() {
|
||||||
|
if (LiteYTEmbed.preconnected) return;
|
||||||
|
|
||||||
|
// The iframe document and most of its subresources come right off youtube.com
|
||||||
|
LiteYTEmbed.addPrefetch('preconnect', 'https://www.youtube-nocookie.com');
|
||||||
|
// The botguard script is fetched off from google.com
|
||||||
|
LiteYTEmbed.addPrefetch('preconnect', 'https://www.google.com');
|
||||||
|
|
||||||
|
// Not certain if these ad related domains are in the critical path. Could verify with domain-specific throttling.
|
||||||
|
LiteYTEmbed.addPrefetch('preconnect', 'https://googleads.g.doubleclick.net');
|
||||||
|
LiteYTEmbed.addPrefetch('preconnect', 'https://static.doubleclick.net');
|
||||||
|
|
||||||
|
LiteYTEmbed.preconnected = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
fetchYTPlayerApi() {
|
||||||
|
if (window.YT || (window.YT && window.YT.Player)) return;
|
||||||
|
|
||||||
|
this.ytApiPromise = new Promise((res, rej) => {
|
||||||
|
var el = document.createElement('script');
|
||||||
|
el.src = 'https://www.youtube.com/iframe_api';
|
||||||
|
el.async = true;
|
||||||
|
el.onload = _ => {
|
||||||
|
YT.ready(res);
|
||||||
|
};
|
||||||
|
el.onerror = rej;
|
||||||
|
this.append(el);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
/** Return the YT Player API instance. (Public L-YT-E API) */
|
||||||
|
async getYTPlayer() {
|
||||||
|
if(!this.playerPromise) {
|
||||||
|
await this.activate();
|
||||||
|
}
|
||||||
|
|
||||||
|
return this.playerPromise;
|
||||||
|
}
|
||||||
|
|
||||||
|
async addYTPlayerIframe() {
|
||||||
|
this.fetchYTPlayerApi();
|
||||||
|
await this.ytApiPromise;
|
||||||
|
|
||||||
|
const videoPlaceholderEl = document.createElement('div')
|
||||||
|
this.append(videoPlaceholderEl);
|
||||||
|
|
||||||
|
const paramsObj = Object.fromEntries(this.getParams().entries());
|
||||||
|
|
||||||
|
this.playerPromise = new Promise(resolve => {
|
||||||
|
let player = new YT.Player(videoPlaceholderEl, {
|
||||||
|
width: '100%',
|
||||||
|
videoId: this.videoId,
|
||||||
|
playerVars: paramsObj,
|
||||||
|
events: {
|
||||||
|
'onReady': event => {
|
||||||
|
event.target.playVideo();
|
||||||
|
resolve(player);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
// Add the iframe within <noscript> for indexability discoverability. See https://github.com/paulirish/lite-youtube-embed/issues/105
|
||||||
|
addNoscriptIframe() {
|
||||||
|
const iframeEl = this.createBasicIframe();
|
||||||
|
const noscriptEl = document.createElement('noscript');
|
||||||
|
// Appending into noscript isn't equivalant for mysterious reasons: https://html.spec.whatwg.org/multipage/scripting.html#the-noscript-element
|
||||||
|
noscriptEl.innerHTML = iframeEl.outerHTML;
|
||||||
|
this.append(noscriptEl);
|
||||||
|
}
|
||||||
|
|
||||||
|
getParams() {
|
||||||
|
const params = new URLSearchParams(this.getAttribute('params') || []);
|
||||||
|
params.append('autoplay', '1');
|
||||||
|
params.append('playsinline', '1');
|
||||||
|
return params;
|
||||||
|
}
|
||||||
|
|
||||||
|
async activate(){
|
||||||
|
if (this.classList.contains('lyt-activated')) return;
|
||||||
|
this.classList.add('lyt-activated');
|
||||||
|
|
||||||
|
if (this.needsYTApi) {
|
||||||
|
return this.addYTPlayerIframe(this.getParams());
|
||||||
|
}
|
||||||
|
|
||||||
|
const iframeEl = this.createBasicIframe();
|
||||||
|
this.append(iframeEl);
|
||||||
|
|
||||||
|
// Set focus for a11y
|
||||||
|
iframeEl.focus();
|
||||||
|
}
|
||||||
|
|
||||||
|
createBasicIframe(){
|
||||||
|
const iframeEl = document.createElement('iframe');
|
||||||
|
iframeEl.width = 560;
|
||||||
|
iframeEl.height = 315;
|
||||||
|
// No encoding necessary as [title] is safe. https://cheatsheetseries.owasp.org/cheatsheets/Cross_Site_Scripting_Prevention_Cheat_Sheet.html#:~:text=Safe%20HTML%20Attributes%20include
|
||||||
|
iframeEl.title = this.playLabel;
|
||||||
|
iframeEl.allow = 'accelerometer; autoplay; encrypted-media; gyroscope; picture-in-picture';
|
||||||
|
iframeEl.allowFullscreen = true;
|
||||||
|
// AFAIK, the encoding here isn't necessary for XSS, but we'll do it only because this is a URL
|
||||||
|
// https://stackoverflow.com/q/64959723/89484
|
||||||
|
iframeEl.src = `https://www.youtube-nocookie.com/embed/${encodeURIComponent(this.videoId)}?${this.getParams().toString()}`;
|
||||||
|
return iframeEl;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* In the spirit of the `lowsrc` attribute and progressive JPEGs, we'll upgrade the reliable
|
||||||
|
* poster image to a higher resolution one, if it's available.
|
||||||
|
* Interestingly this sddefault webp is often smaller in filesize, but we will still attempt it second
|
||||||
|
* because getting _an_ image in front of the user if our first priority.
|
||||||
|
*
|
||||||
|
* See https://github.com/paulirish/lite-youtube-embed/blob/master/youtube-thumbnail-urls.md for more details
|
||||||
|
*/
|
||||||
|
upgradePosterImage() {
|
||||||
|
// Defer to reduce network contention.
|
||||||
|
setTimeout(() => {
|
||||||
|
const webpUrl = `https://i.ytimg.com/vi_webp/${this.videoId}/sddefault.webp`;
|
||||||
|
const img = new Image();
|
||||||
|
img.fetchPriority = 'low'; // low priority to reduce network contention
|
||||||
|
img.referrerpolicy = 'origin'; // Not 100% sure it's needed, but https://github.com/ampproject/amphtml/pull/3940
|
||||||
|
img.src = webpUrl;
|
||||||
|
img.onload = e => {
|
||||||
|
// A pretty ugly hack since onerror won't fire on YouTube image 404. This is (probably) due to
|
||||||
|
// Youtube's style of returning data even with a 404 status. That data is a 120x90 placeholder image.
|
||||||
|
// … per "annoying yt 404 behavior" in the .md
|
||||||
|
const noAvailablePoster = e.target.naturalHeight == 90 && e.target.naturalWidth == 120;
|
||||||
|
if (noAvailablePoster) return;
|
||||||
|
|
||||||
|
this.style.backgroundImage = `url("${webpUrl}")`;
|
||||||
|
}
|
||||||
|
}, 100);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// Register custom element
|
||||||
|
customElements.define('lite-youtube', LiteYTEmbed);
|
33
assets/lib/mermaid/Diagram.d.ts
vendored
Normal file
|
@ -0,0 +1,33 @@
|
||||||
|
import type { DetailedError } from './utils.js';
|
||||||
|
import type { DiagramDefinition, DiagramMetadata } from './diagram-api/types.js';
|
||||||
|
export type ParseErrorFunction = (err: string | DetailedError | unknown, hash?: any) => void;
|
||||||
|
/**
|
||||||
|
* An object representing a parsed mermaid diagram definition.
|
||||||
|
* @privateRemarks This is exported as part of the public mermaidAPI.
|
||||||
|
*/
|
||||||
|
export declare class Diagram {
|
||||||
|
text: string;
|
||||||
|
metadata: Pick<DiagramMetadata, 'title'>;
|
||||||
|
type: string;
|
||||||
|
parser: DiagramDefinition['parser'];
|
||||||
|
renderer: DiagramDefinition['renderer'];
|
||||||
|
db: DiagramDefinition['db'];
|
||||||
|
private init?;
|
||||||
|
private detectError?;
|
||||||
|
constructor(text: string, metadata?: Pick<DiagramMetadata, 'title'>);
|
||||||
|
parse(): void;
|
||||||
|
render(id: string, version: string): Promise<void>;
|
||||||
|
getParser(): import("./diagram-api/types.js").ParserDefinition;
|
||||||
|
getType(): string;
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* Parse the text asynchronously and generate a Diagram object asynchronously.
|
||||||
|
* **Warning:** This function may be changed in the future.
|
||||||
|
* @alpha
|
||||||
|
* @param text - The mermaid diagram definition.
|
||||||
|
* @param metadata - Diagram metadata, defined in YAML.
|
||||||
|
* @returns A the Promise of a Diagram object.
|
||||||
|
* @throws {@link UnknownDiagramError} if the diagram type can not be found.
|
||||||
|
* @privateRemarks This is exported as part of the public mermaidAPI.
|
||||||
|
*/
|
||||||
|
export declare const getDiagramFromText: (text: string, metadata?: Pick<DiagramMetadata, 'title'>) => Promise<Diagram>;
|
10
assets/lib/mermaid/Tableau10-31042135.js
Normal file
|
@ -0,0 +1,10 @@
|
||||||
|
function colors(specifier) {
|
||||||
|
var n = specifier.length / 6 | 0, colors2 = new Array(n), i = 0;
|
||||||
|
while (i < n)
|
||||||
|
colors2[i] = "#" + specifier.slice(i * 6, ++i * 6);
|
||||||
|
return colors2;
|
||||||
|
}
|
||||||
|
const d3schemeTableau10 = colors("4e79a7f28e2ce1575976b7b259a14fedc949af7aa1ff9da79c755fbab0ab");
|
||||||
|
export {
|
||||||
|
d3schemeTableau10 as d
|
||||||
|
};
|
9
assets/lib/mermaid/Tableau10-558cc280.js
Normal file
|
@ -0,0 +1,9 @@
|
||||||
|
function o(e) {
|
||||||
|
for (var c = e.length / 6 | 0, n = new Array(c), a = 0; a < c; )
|
||||||
|
n[a] = "#" + e.slice(a * 6, ++a * 6);
|
||||||
|
return n;
|
||||||
|
}
|
||||||
|
const r = o("4e79a7f28e2ce1575976b7b259a14fedc949af7aa1ff9da79c755fbab0ab");
|
||||||
|
export {
|
||||||
|
r as d
|
||||||
|
};
|
13
assets/lib/mermaid/__mocks__/mermaidAPI.d.ts
vendored
Normal file
|
@ -0,0 +1,13 @@
|
||||||
|
export declare const mermaidAPI: {
|
||||||
|
render: import("@vitest/spy").Mock<any, any>;
|
||||||
|
parse: (text: string, parseOptions?: import("../mermaidAPI.js").ParseOptions | undefined) => Promise<boolean>;
|
||||||
|
initialize: import("@vitest/spy").Mock<any, any>;
|
||||||
|
getConfig: () => import("../config.type.js").MermaidConfig;
|
||||||
|
setConfig: (conf: import("../config.type.js").MermaidConfig) => import("../config.type.js").MermaidConfig;
|
||||||
|
getSiteConfig: () => import("../config.type.js").MermaidConfig;
|
||||||
|
updateSiteConfig: (conf: import("../config.type.js").MermaidConfig) => import("../config.type.js").MermaidConfig;
|
||||||
|
reset: () => void;
|
||||||
|
globalReset: () => void;
|
||||||
|
defaultConfig: import("../config.type.js").MermaidConfig;
|
||||||
|
};
|
||||||
|
export default mermaidAPI;
|
27
assets/lib/mermaid/accessibility.d.ts
vendored
Normal file
|
@ -0,0 +1,27 @@
|
||||||
|
/**
|
||||||
|
* Accessibility (a11y) functions, types, helpers.
|
||||||
|
*
|
||||||
|
* @see https://www.w3.org/WAI/
|
||||||
|
* @see https://www.w3.org/TR/wai-aria-1.1/
|
||||||
|
* @see https://www.w3.org/TR/svg-aam-1.0/
|
||||||
|
*/
|
||||||
|
import type { D3Element } from './mermaidAPI.js';
|
||||||
|
/**
|
||||||
|
* Add role and aria-roledescription to the svg element.
|
||||||
|
*
|
||||||
|
* @param svg - d3 object that contains the SVG HTML element
|
||||||
|
* @param diagramType - diagram name for to the aria-roledescription
|
||||||
|
*/
|
||||||
|
export declare function setA11yDiagramInfo(svg: D3Element, diagramType: string): void;
|
||||||
|
/**
|
||||||
|
* Add an accessible title and/or description element to a chart.
|
||||||
|
* The title is usually not displayed and the description is never displayed.
|
||||||
|
*
|
||||||
|
* The following charts display their title as a visual and accessibility element: gantt.
|
||||||
|
*
|
||||||
|
* @param svg - d3 node to insert the a11y title and desc info
|
||||||
|
* @param a11yTitle - a11y title. undefined or empty strings mean to skip them
|
||||||
|
* @param a11yDesc - a11y description. undefined or empty strings mean to skip them
|
||||||
|
* @param baseId - id used to construct the a11y title and description id
|
||||||
|
*/
|
||||||
|
export declare function addSVGa11yTitleDescription(svg: D3Element, a11yTitle: string | undefined, a11yDesc: string | undefined, baseId: string): void;
|
1
assets/lib/mermaid/accessibility.spec.d.ts
vendored
Normal file
|
@ -0,0 +1 @@
|
||||||
|
export {};
|
1705
assets/lib/mermaid/add-html-label-3fd8c466.js
Normal file
1
assets/lib/mermaid/add-html-label-3fd8c466.js.map
Normal file
1145
assets/lib/mermaid/add-html-label-6e56ed67.js
Normal file
1
assets/lib/mermaid/add-html-label-6e56ed67.js.map
Normal file
1145
assets/lib/mermaid/add-html-label-ce7f9292.js
Normal file
1
assets/lib/mermaid/add-html-label-ce7f9292.js.map
Normal file
1705
assets/lib/mermaid/add-html-label-f3a0bd34.js
Normal file
1
assets/lib/mermaid/add-html-label-f3a0bd34.js.map
Normal file
85
assets/lib/mermaid/arc-1bd4335b.js
Normal file
|
@ -0,0 +1,85 @@
|
||||||
|
import { c as Q, p as sn } from "./constant-2fe7eae5.js";
|
||||||
|
import { J as en, K as X, N as I, O as rn, P as y, I as ln, Q as z, R as b, T as un, V as t, W as an, X as on, Y as tn } from "./utils-aa888deb.js";
|
||||||
|
function fn(l) {
|
||||||
|
return l.innerRadius;
|
||||||
|
}
|
||||||
|
function cn(l) {
|
||||||
|
return l.outerRadius;
|
||||||
|
}
|
||||||
|
function yn(l) {
|
||||||
|
return l.startAngle;
|
||||||
|
}
|
||||||
|
function gn(l) {
|
||||||
|
return l.endAngle;
|
||||||
|
}
|
||||||
|
function mn(l) {
|
||||||
|
return l && l.padAngle;
|
||||||
|
}
|
||||||
|
function pn(l, x, w, O, h, v, S, r) {
|
||||||
|
var s = w - l, n = O - x, m = S - h, i = r - v, u = i * s - m * n;
|
||||||
|
if (!(u * u < y))
|
||||||
|
return u = (m * (x - v) - i * (l - h)) / u, [l + u * s, x + u * n];
|
||||||
|
}
|
||||||
|
function H(l, x, w, O, h, v, S) {
|
||||||
|
var r = l - w, s = x - O, n = (S ? v : -v) / z(r * r + s * s), m = n * s, i = -n * r, u = l + m, f = x + i, c = w + m, D = O + i, o = (u + c) / 2, E = (f + D) / 2, p = c - u, g = D - f, R = p * p + g * g, J = h - v, P = u * D - c * f, K = (g < 0 ? -1 : 1) * z(tn(0, J * J * R - P * P)), N = (P * g - p * K) / R, d = (-P * p - g * K) / R, A = (P * g + p * K) / R, T = (-P * p + g * K) / R, e = N - o, a = d - E, V = A - o, W = T - E;
|
||||||
|
return e * e + a * a > V * V + W * W && (N = A, d = T), {
|
||||||
|
cx: N,
|
||||||
|
cy: d,
|
||||||
|
x01: -m,
|
||||||
|
y01: -i,
|
||||||
|
x11: N * (h / J - 1),
|
||||||
|
y11: d * (h / J - 1)
|
||||||
|
};
|
||||||
|
}
|
||||||
|
function hn() {
|
||||||
|
var l = fn, x = cn, w = Q(0), O = null, h = yn, v = gn, S = mn, r = null;
|
||||||
|
function s() {
|
||||||
|
var n, m, i = +l.apply(this, arguments), u = +x.apply(this, arguments), f = h.apply(this, arguments) - rn, c = v.apply(this, arguments) - rn, D = un(c - f), o = c > f;
|
||||||
|
if (r || (r = n = sn()), u < i && (m = u, u = i, i = m), !(u > y))
|
||||||
|
r.moveTo(0, 0);
|
||||||
|
else if (D > ln - y)
|
||||||
|
r.moveTo(u * X(f), u * I(f)), r.arc(0, 0, u, f, c, !o), i > y && (r.moveTo(i * X(c), i * I(c)), r.arc(0, 0, i, c, f, o));
|
||||||
|
else {
|
||||||
|
var E = f, p = c, g = f, R = c, J = D, P = D, K = S.apply(this, arguments) / 2, N = K > y && (O ? +O.apply(this, arguments) : z(i * i + u * u)), d = b(un(u - i) / 2, +w.apply(this, arguments)), A = d, T = d, e, a;
|
||||||
|
if (N > y) {
|
||||||
|
var V = an(N / i * I(K)), W = an(N / u * I(K));
|
||||||
|
(J -= V * 2) > y ? (V *= o ? 1 : -1, g += V, R -= V) : (J = 0, g = R = (f + c) / 2), (P -= W * 2) > y ? (W *= o ? 1 : -1, E += W, p -= W) : (P = 0, E = p = (f + c) / 2);
|
||||||
|
}
|
||||||
|
var Y = u * X(E), j = u * I(E), B = i * X(R), C = i * I(R);
|
||||||
|
if (d > y) {
|
||||||
|
var F = u * X(p), G = u * I(p), L = i * X(g), M = i * I(g), q;
|
||||||
|
if (D < en && (q = pn(Y, j, L, M, F, G, B, C))) {
|
||||||
|
var U = Y - q[0], Z = j - q[1], $ = F - q[0], k = G - q[1], _ = 1 / I(on((U * $ + Z * k) / (z(U * U + Z * Z) * z($ * $ + k * k))) / 2), nn = z(q[0] * q[0] + q[1] * q[1]);
|
||||||
|
A = b(d, (i - nn) / (_ - 1)), T = b(d, (u - nn) / (_ + 1));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
P > y ? T > y ? (e = H(L, M, Y, j, u, T, o), a = H(F, G, B, C, u, T, o), r.moveTo(e.cx + e.x01, e.cy + e.y01), T < d ? r.arc(e.cx, e.cy, T, t(e.y01, e.x01), t(a.y01, a.x01), !o) : (r.arc(e.cx, e.cy, T, t(e.y01, e.x01), t(e.y11, e.x11), !o), r.arc(0, 0, u, t(e.cy + e.y11, e.cx + e.x11), t(a.cy + a.y11, a.cx + a.x11), !o), r.arc(a.cx, a.cy, T, t(a.y11, a.x11), t(a.y01, a.x01), !o))) : (r.moveTo(Y, j), r.arc(0, 0, u, E, p, !o)) : r.moveTo(Y, j), !(i > y) || !(J > y) ? r.lineTo(B, C) : A > y ? (e = H(B, C, F, G, i, -A, o), a = H(Y, j, L, M, i, -A, o), r.lineTo(e.cx + e.x01, e.cy + e.y01), A < d ? r.arc(e.cx, e.cy, A, t(e.y01, e.x01), t(a.y01, a.x01), !o) : (r.arc(e.cx, e.cy, A, t(e.y01, e.x01), t(e.y11, e.x11), !o), r.arc(0, 0, i, t(e.cy + e.y11, e.cx + e.x11), t(a.cy + a.y11, a.cx + a.x11), o), r.arc(a.cx, a.cy, A, t(a.y11, a.x11), t(a.y01, a.x01), !o))) : r.arc(0, 0, i, R, g, o);
|
||||||
|
}
|
||||||
|
if (r.closePath(), n)
|
||||||
|
return r = null, n + "" || null;
|
||||||
|
}
|
||||||
|
return s.centroid = function() {
|
||||||
|
var n = (+l.apply(this, arguments) + +x.apply(this, arguments)) / 2, m = (+h.apply(this, arguments) + +v.apply(this, arguments)) / 2 - en / 2;
|
||||||
|
return [X(m) * n, I(m) * n];
|
||||||
|
}, s.innerRadius = function(n) {
|
||||||
|
return arguments.length ? (l = typeof n == "function" ? n : Q(+n), s) : l;
|
||||||
|
}, s.outerRadius = function(n) {
|
||||||
|
return arguments.length ? (x = typeof n == "function" ? n : Q(+n), s) : x;
|
||||||
|
}, s.cornerRadius = function(n) {
|
||||||
|
return arguments.length ? (w = typeof n == "function" ? n : Q(+n), s) : w;
|
||||||
|
}, s.padRadius = function(n) {
|
||||||
|
return arguments.length ? (O = n == null ? null : typeof n == "function" ? n : Q(+n), s) : O;
|
||||||
|
}, s.startAngle = function(n) {
|
||||||
|
return arguments.length ? (h = typeof n == "function" ? n : Q(+n), s) : h;
|
||||||
|
}, s.endAngle = function(n) {
|
||||||
|
return arguments.length ? (v = typeof n == "function" ? n : Q(+n), s) : v;
|
||||||
|
}, s.padAngle = function(n) {
|
||||||
|
return arguments.length ? (S = typeof n == "function" ? n : Q(+n), s) : S;
|
||||||
|
}, s.context = function(n) {
|
||||||
|
return arguments.length ? (r = n ?? null, s) : r;
|
||||||
|
}, s;
|
||||||
|
}
|
||||||
|
export {
|
||||||
|
hn as d
|
||||||
|
};
|
||||||
|
//# sourceMappingURL=arc-1bd4335b.js.map
|
1
assets/lib/mermaid/arc-1bd4335b.js.map
Normal file
86
assets/lib/mermaid/arc-5a3dc2ef.js
Normal file
|
@ -0,0 +1,86 @@
|
||||||
|
import { w as ln, c as H } from "./path-428ebac9.js";
|
||||||
|
import { aw as an, ax as V, ay as D, az as rn, aA as y, V as on, aB as K, aC as _, aD as un, aE as t, aF as sn, aG as tn, aH as fn } from "./mermaid-00886c59.js";
|
||||||
|
function cn(l) {
|
||||||
|
return l.innerRadius;
|
||||||
|
}
|
||||||
|
function yn(l) {
|
||||||
|
return l.outerRadius;
|
||||||
|
}
|
||||||
|
function gn(l) {
|
||||||
|
return l.startAngle;
|
||||||
|
}
|
||||||
|
function mn(l) {
|
||||||
|
return l.endAngle;
|
||||||
|
}
|
||||||
|
function pn(l) {
|
||||||
|
return l && l.padAngle;
|
||||||
|
}
|
||||||
|
function dn(l, h, z, E, v, A, I, a) {
|
||||||
|
var B = z - l, i = E - h, n = I - v, m = a - A, r = m * B - n * i;
|
||||||
|
if (!(r * r < y))
|
||||||
|
return r = (n * (h - A) - m * (l - v)) / r, [l + r * B, h + r * i];
|
||||||
|
}
|
||||||
|
function W(l, h, z, E, v, A, I) {
|
||||||
|
var a = l - z, B = h - E, i = (I ? A : -A) / K(a * a + B * B), n = i * B, m = -i * a, r = l + n, s = h + m, f = z + n, c = E + m, O = (r + f) / 2, o = (s + c) / 2, p = f - r, g = c - s, R = p * p + g * g, T = v - A, w = r * c - f * s, C = (g < 0 ? -1 : 1) * K(fn(0, T * T * R - w * w)), F = (w * g - p * C) / R, G = (-w * p - g * C) / R, P = (w * g + p * C) / R, d = (-w * p + g * C) / R, x = F - O, e = G - o, u = P - O, S = d - o;
|
||||||
|
return x * x + e * e > u * u + S * S && (F = P, G = d), {
|
||||||
|
cx: F,
|
||||||
|
cy: G,
|
||||||
|
x01: -n,
|
||||||
|
y01: -m,
|
||||||
|
x11: F * (v / T - 1),
|
||||||
|
y11: G * (v / T - 1)
|
||||||
|
};
|
||||||
|
}
|
||||||
|
function vn() {
|
||||||
|
var l = cn, h = yn, z = H(0), E = null, v = gn, A = mn, I = pn, a = null, B = ln(i);
|
||||||
|
function i() {
|
||||||
|
var n, m, r = +l.apply(this, arguments), s = +h.apply(this, arguments), f = v.apply(this, arguments) - rn, c = A.apply(this, arguments) - rn, O = un(c - f), o = c > f;
|
||||||
|
if (a || (a = n = B()), s < r && (m = s, s = r, r = m), !(s > y))
|
||||||
|
a.moveTo(0, 0);
|
||||||
|
else if (O > on - y)
|
||||||
|
a.moveTo(s * V(f), s * D(f)), a.arc(0, 0, s, f, c, !o), r > y && (a.moveTo(r * V(c), r * D(c)), a.arc(0, 0, r, c, f, o));
|
||||||
|
else {
|
||||||
|
var p = f, g = c, R = f, T = c, w = O, C = O, F = I.apply(this, arguments) / 2, G = F > y && (E ? +E.apply(this, arguments) : K(r * r + s * s)), P = _(un(s - r) / 2, +z.apply(this, arguments)), d = P, x = P, e, u;
|
||||||
|
if (G > y) {
|
||||||
|
var S = sn(G / r * D(F)), L = sn(G / s * D(F));
|
||||||
|
(w -= S * 2) > y ? (S *= o ? 1 : -1, R += S, T -= S) : (w = 0, R = T = (f + c) / 2), (C -= L * 2) > y ? (L *= o ? 1 : -1, p += L, g -= L) : (C = 0, p = g = (f + c) / 2);
|
||||||
|
}
|
||||||
|
var j = s * V(p), J = s * D(p), M = r * V(T), N = r * D(T);
|
||||||
|
if (P > y) {
|
||||||
|
var Q = s * V(g), U = s * D(g), X = r * V(R), Y = r * D(R), q;
|
||||||
|
if (O < an)
|
||||||
|
if (q = dn(j, J, X, Y, Q, U, M, N)) {
|
||||||
|
var Z = j - q[0], $ = J - q[1], k = Q - q[0], b = U - q[1], nn = 1 / D(tn((Z * k + $ * b) / (K(Z * Z + $ * $) * K(k * k + b * b))) / 2), en = K(q[0] * q[0] + q[1] * q[1]);
|
||||||
|
d = _(P, (r - en) / (nn - 1)), x = _(P, (s - en) / (nn + 1));
|
||||||
|
} else
|
||||||
|
d = x = 0;
|
||||||
|
}
|
||||||
|
C > y ? x > y ? (e = W(X, Y, j, J, s, x, o), u = W(Q, U, M, N, s, x, o), a.moveTo(e.cx + e.x01, e.cy + e.y01), x < P ? a.arc(e.cx, e.cy, x, t(e.y01, e.x01), t(u.y01, u.x01), !o) : (a.arc(e.cx, e.cy, x, t(e.y01, e.x01), t(e.y11, e.x11), !o), a.arc(0, 0, s, t(e.cy + e.y11, e.cx + e.x11), t(u.cy + u.y11, u.cx + u.x11), !o), a.arc(u.cx, u.cy, x, t(u.y11, u.x11), t(u.y01, u.x01), !o))) : (a.moveTo(j, J), a.arc(0, 0, s, p, g, !o)) : a.moveTo(j, J), !(r > y) || !(w > y) ? a.lineTo(M, N) : d > y ? (e = W(M, N, Q, U, r, -d, o), u = W(j, J, X, Y, r, -d, o), a.lineTo(e.cx + e.x01, e.cy + e.y01), d < P ? a.arc(e.cx, e.cy, d, t(e.y01, e.x01), t(u.y01, u.x01), !o) : (a.arc(e.cx, e.cy, d, t(e.y01, e.x01), t(e.y11, e.x11), !o), a.arc(0, 0, r, t(e.cy + e.y11, e.cx + e.x11), t(u.cy + u.y11, u.cx + u.x11), o), a.arc(u.cx, u.cy, d, t(u.y11, u.x11), t(u.y01, u.x01), !o))) : a.arc(0, 0, r, T, R, o);
|
||||||
|
}
|
||||||
|
if (a.closePath(), n)
|
||||||
|
return a = null, n + "" || null;
|
||||||
|
}
|
||||||
|
return i.centroid = function() {
|
||||||
|
var n = (+l.apply(this, arguments) + +h.apply(this, arguments)) / 2, m = (+v.apply(this, arguments) + +A.apply(this, arguments)) / 2 - an / 2;
|
||||||
|
return [V(m) * n, D(m) * n];
|
||||||
|
}, i.innerRadius = function(n) {
|
||||||
|
return arguments.length ? (l = typeof n == "function" ? n : H(+n), i) : l;
|
||||||
|
}, i.outerRadius = function(n) {
|
||||||
|
return arguments.length ? (h = typeof n == "function" ? n : H(+n), i) : h;
|
||||||
|
}, i.cornerRadius = function(n) {
|
||||||
|
return arguments.length ? (z = typeof n == "function" ? n : H(+n), i) : z;
|
||||||
|
}, i.padRadius = function(n) {
|
||||||
|
return arguments.length ? (E = n == null ? null : typeof n == "function" ? n : H(+n), i) : E;
|
||||||
|
}, i.startAngle = function(n) {
|
||||||
|
return arguments.length ? (v = typeof n == "function" ? n : H(+n), i) : v;
|
||||||
|
}, i.endAngle = function(n) {
|
||||||
|
return arguments.length ? (A = typeof n == "function" ? n : H(+n), i) : A;
|
||||||
|
}, i.padAngle = function(n) {
|
||||||
|
return arguments.length ? (I = typeof n == "function" ? n : H(+n), i) : I;
|
||||||
|
}, i.context = function(n) {
|
||||||
|
return arguments.length ? (a = n ?? null, i) : a;
|
||||||
|
}, i;
|
||||||
|
}
|
||||||
|
export {
|
||||||
|
vn as d
|
||||||
|
};
|
148
assets/lib/mermaid/arc-5aa99581.js
Normal file
|
@ -0,0 +1,148 @@
|
||||||
|
import { w as withPath, c as constant } from "./path-39bad7e2.js";
|
||||||
|
import { aw as pi, ax as cos, ay as sin, az as halfPi, aA as epsilon, V as tau, aB as sqrt, aC as min, aD as abs, aE as atan2, aF as asin, aG as acos, aH as max } from "./mermaid-c5809711.js";
|
||||||
|
function arcInnerRadius(d) {
|
||||||
|
return d.innerRadius;
|
||||||
|
}
|
||||||
|
function arcOuterRadius(d) {
|
||||||
|
return d.outerRadius;
|
||||||
|
}
|
||||||
|
function arcStartAngle(d) {
|
||||||
|
return d.startAngle;
|
||||||
|
}
|
||||||
|
function arcEndAngle(d) {
|
||||||
|
return d.endAngle;
|
||||||
|
}
|
||||||
|
function arcPadAngle(d) {
|
||||||
|
return d && d.padAngle;
|
||||||
|
}
|
||||||
|
function intersect(x0, y0, x1, y1, x2, y2, x3, y3) {
|
||||||
|
var x10 = x1 - x0, y10 = y1 - y0, x32 = x3 - x2, y32 = y3 - y2, t = y32 * x10 - x32 * y10;
|
||||||
|
if (t * t < epsilon)
|
||||||
|
return;
|
||||||
|
t = (x32 * (y0 - y2) - y32 * (x0 - x2)) / t;
|
||||||
|
return [x0 + t * x10, y0 + t * y10];
|
||||||
|
}
|
||||||
|
function cornerTangents(x0, y0, x1, y1, r1, rc, cw) {
|
||||||
|
var x01 = x0 - x1, y01 = y0 - y1, lo = (cw ? rc : -rc) / sqrt(x01 * x01 + y01 * y01), ox = lo * y01, oy = -lo * x01, x11 = x0 + ox, y11 = y0 + oy, x10 = x1 + ox, y10 = y1 + oy, x00 = (x11 + x10) / 2, y00 = (y11 + y10) / 2, dx = x10 - x11, dy = y10 - y11, d2 = dx * dx + dy * dy, r = r1 - rc, D = x11 * y10 - x10 * y11, d = (dy < 0 ? -1 : 1) * sqrt(max(0, r * r * d2 - D * D)), cx0 = (D * dy - dx * d) / d2, cy0 = (-D * dx - dy * d) / d2, cx1 = (D * dy + dx * d) / d2, cy1 = (-D * dx + dy * d) / d2, dx0 = cx0 - x00, dy0 = cy0 - y00, dx1 = cx1 - x00, dy1 = cy1 - y00;
|
||||||
|
if (dx0 * dx0 + dy0 * dy0 > dx1 * dx1 + dy1 * dy1)
|
||||||
|
cx0 = cx1, cy0 = cy1;
|
||||||
|
return {
|
||||||
|
cx: cx0,
|
||||||
|
cy: cy0,
|
||||||
|
x01: -ox,
|
||||||
|
y01: -oy,
|
||||||
|
x11: cx0 * (r1 / r - 1),
|
||||||
|
y11: cy0 * (r1 / r - 1)
|
||||||
|
};
|
||||||
|
}
|
||||||
|
function d3arc() {
|
||||||
|
var innerRadius = arcInnerRadius, outerRadius = arcOuterRadius, cornerRadius = constant(0), padRadius = null, startAngle = arcStartAngle, endAngle = arcEndAngle, padAngle = arcPadAngle, context = null, path = withPath(arc);
|
||||||
|
function arc() {
|
||||||
|
var buffer, r, r0 = +innerRadius.apply(this, arguments), r1 = +outerRadius.apply(this, arguments), a0 = startAngle.apply(this, arguments) - halfPi, a1 = endAngle.apply(this, arguments) - halfPi, da = abs(a1 - a0), cw = a1 > a0;
|
||||||
|
if (!context)
|
||||||
|
context = buffer = path();
|
||||||
|
if (r1 < r0)
|
||||||
|
r = r1, r1 = r0, r0 = r;
|
||||||
|
if (!(r1 > epsilon))
|
||||||
|
context.moveTo(0, 0);
|
||||||
|
else if (da > tau - epsilon) {
|
||||||
|
context.moveTo(r1 * cos(a0), r1 * sin(a0));
|
||||||
|
context.arc(0, 0, r1, a0, a1, !cw);
|
||||||
|
if (r0 > epsilon) {
|
||||||
|
context.moveTo(r0 * cos(a1), r0 * sin(a1));
|
||||||
|
context.arc(0, 0, r0, a1, a0, cw);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
var a01 = a0, a11 = a1, a00 = a0, a10 = a1, da0 = da, da1 = da, ap = padAngle.apply(this, arguments) / 2, rp = ap > epsilon && (padRadius ? +padRadius.apply(this, arguments) : sqrt(r0 * r0 + r1 * r1)), rc = min(abs(r1 - r0) / 2, +cornerRadius.apply(this, arguments)), rc0 = rc, rc1 = rc, t0, t1;
|
||||||
|
if (rp > epsilon) {
|
||||||
|
var p0 = asin(rp / r0 * sin(ap)), p1 = asin(rp / r1 * sin(ap));
|
||||||
|
if ((da0 -= p0 * 2) > epsilon)
|
||||||
|
p0 *= cw ? 1 : -1, a00 += p0, a10 -= p0;
|
||||||
|
else
|
||||||
|
da0 = 0, a00 = a10 = (a0 + a1) / 2;
|
||||||
|
if ((da1 -= p1 * 2) > epsilon)
|
||||||
|
p1 *= cw ? 1 : -1, a01 += p1, a11 -= p1;
|
||||||
|
else
|
||||||
|
da1 = 0, a01 = a11 = (a0 + a1) / 2;
|
||||||
|
}
|
||||||
|
var x01 = r1 * cos(a01), y01 = r1 * sin(a01), x10 = r0 * cos(a10), y10 = r0 * sin(a10);
|
||||||
|
if (rc > epsilon) {
|
||||||
|
var x11 = r1 * cos(a11), y11 = r1 * sin(a11), x00 = r0 * cos(a00), y00 = r0 * sin(a00), oc;
|
||||||
|
if (da < pi) {
|
||||||
|
if (oc = intersect(x01, y01, x00, y00, x11, y11, x10, y10)) {
|
||||||
|
var ax = x01 - oc[0], ay = y01 - oc[1], bx = x11 - oc[0], by = y11 - oc[1], kc = 1 / sin(acos((ax * bx + ay * by) / (sqrt(ax * ax + ay * ay) * sqrt(bx * bx + by * by))) / 2), lc = sqrt(oc[0] * oc[0] + oc[1] * oc[1]);
|
||||||
|
rc0 = min(rc, (r0 - lc) / (kc - 1));
|
||||||
|
rc1 = min(rc, (r1 - lc) / (kc + 1));
|
||||||
|
} else {
|
||||||
|
rc0 = rc1 = 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (!(da1 > epsilon))
|
||||||
|
context.moveTo(x01, y01);
|
||||||
|
else if (rc1 > epsilon) {
|
||||||
|
t0 = cornerTangents(x00, y00, x01, y01, r1, rc1, cw);
|
||||||
|
t1 = cornerTangents(x11, y11, x10, y10, r1, rc1, cw);
|
||||||
|
context.moveTo(t0.cx + t0.x01, t0.cy + t0.y01);
|
||||||
|
if (rc1 < rc)
|
||||||
|
context.arc(t0.cx, t0.cy, rc1, atan2(t0.y01, t0.x01), atan2(t1.y01, t1.x01), !cw);
|
||||||
|
else {
|
||||||
|
context.arc(t0.cx, t0.cy, rc1, atan2(t0.y01, t0.x01), atan2(t0.y11, t0.x11), !cw);
|
||||||
|
context.arc(0, 0, r1, atan2(t0.cy + t0.y11, t0.cx + t0.x11), atan2(t1.cy + t1.y11, t1.cx + t1.x11), !cw);
|
||||||
|
context.arc(t1.cx, t1.cy, rc1, atan2(t1.y11, t1.x11), atan2(t1.y01, t1.x01), !cw);
|
||||||
|
}
|
||||||
|
} else
|
||||||
|
context.moveTo(x01, y01), context.arc(0, 0, r1, a01, a11, !cw);
|
||||||
|
if (!(r0 > epsilon) || !(da0 > epsilon))
|
||||||
|
context.lineTo(x10, y10);
|
||||||
|
else if (rc0 > epsilon) {
|
||||||
|
t0 = cornerTangents(x10, y10, x11, y11, r0, -rc0, cw);
|
||||||
|
t1 = cornerTangents(x01, y01, x00, y00, r0, -rc0, cw);
|
||||||
|
context.lineTo(t0.cx + t0.x01, t0.cy + t0.y01);
|
||||||
|
if (rc0 < rc)
|
||||||
|
context.arc(t0.cx, t0.cy, rc0, atan2(t0.y01, t0.x01), atan2(t1.y01, t1.x01), !cw);
|
||||||
|
else {
|
||||||
|
context.arc(t0.cx, t0.cy, rc0, atan2(t0.y01, t0.x01), atan2(t0.y11, t0.x11), !cw);
|
||||||
|
context.arc(0, 0, r0, atan2(t0.cy + t0.y11, t0.cx + t0.x11), atan2(t1.cy + t1.y11, t1.cx + t1.x11), cw);
|
||||||
|
context.arc(t1.cx, t1.cy, rc0, atan2(t1.y11, t1.x11), atan2(t1.y01, t1.x01), !cw);
|
||||||
|
}
|
||||||
|
} else
|
||||||
|
context.arc(0, 0, r0, a10, a00, cw);
|
||||||
|
}
|
||||||
|
context.closePath();
|
||||||
|
if (buffer)
|
||||||
|
return context = null, buffer + "" || null;
|
||||||
|
}
|
||||||
|
arc.centroid = function() {
|
||||||
|
var r = (+innerRadius.apply(this, arguments) + +outerRadius.apply(this, arguments)) / 2, a = (+startAngle.apply(this, arguments) + +endAngle.apply(this, arguments)) / 2 - pi / 2;
|
||||||
|
return [cos(a) * r, sin(a) * r];
|
||||||
|
};
|
||||||
|
arc.innerRadius = function(_) {
|
||||||
|
return arguments.length ? (innerRadius = typeof _ === "function" ? _ : constant(+_), arc) : innerRadius;
|
||||||
|
};
|
||||||
|
arc.outerRadius = function(_) {
|
||||||
|
return arguments.length ? (outerRadius = typeof _ === "function" ? _ : constant(+_), arc) : outerRadius;
|
||||||
|
};
|
||||||
|
arc.cornerRadius = function(_) {
|
||||||
|
return arguments.length ? (cornerRadius = typeof _ === "function" ? _ : constant(+_), arc) : cornerRadius;
|
||||||
|
};
|
||||||
|
arc.padRadius = function(_) {
|
||||||
|
return arguments.length ? (padRadius = _ == null ? null : typeof _ === "function" ? _ : constant(+_), arc) : padRadius;
|
||||||
|
};
|
||||||
|
arc.startAngle = function(_) {
|
||||||
|
return arguments.length ? (startAngle = typeof _ === "function" ? _ : constant(+_), arc) : startAngle;
|
||||||
|
};
|
||||||
|
arc.endAngle = function(_) {
|
||||||
|
return arguments.length ? (endAngle = typeof _ === "function" ? _ : constant(+_), arc) : endAngle;
|
||||||
|
};
|
||||||
|
arc.padAngle = function(_) {
|
||||||
|
return arguments.length ? (padAngle = typeof _ === "function" ? _ : constant(+_), arc) : padAngle;
|
||||||
|
};
|
||||||
|
arc.context = function(_) {
|
||||||
|
return arguments.length ? (context = _ == null ? null : _, arc) : context;
|
||||||
|
};
|
||||||
|
return arc;
|
||||||
|
}
|
||||||
|
export {
|
||||||
|
d3arc as d
|
||||||
|
};
|
145
assets/lib/mermaid/arc-7c943a40.js
Normal file
|
@ -0,0 +1,145 @@
|
||||||
|
import { c as constant, p as path } from "./constant-b644328d.js";
|
||||||
|
import { J as pi, K as cos, N as sin, O as halfPi, P as epsilon, I as tau, Q as sqrt, R as min, T as abs, V as atan2, W as asin, X as acos, Y as max } from "./utils-872dfc50.js";
|
||||||
|
function arcInnerRadius(d) {
|
||||||
|
return d.innerRadius;
|
||||||
|
}
|
||||||
|
function arcOuterRadius(d) {
|
||||||
|
return d.outerRadius;
|
||||||
|
}
|
||||||
|
function arcStartAngle(d) {
|
||||||
|
return d.startAngle;
|
||||||
|
}
|
||||||
|
function arcEndAngle(d) {
|
||||||
|
return d.endAngle;
|
||||||
|
}
|
||||||
|
function arcPadAngle(d) {
|
||||||
|
return d && d.padAngle;
|
||||||
|
}
|
||||||
|
function intersect(x0, y0, x1, y1, x2, y2, x3, y3) {
|
||||||
|
var x10 = x1 - x0, y10 = y1 - y0, x32 = x3 - x2, y32 = y3 - y2, t = y32 * x10 - x32 * y10;
|
||||||
|
if (t * t < epsilon)
|
||||||
|
return;
|
||||||
|
t = (x32 * (y0 - y2) - y32 * (x0 - x2)) / t;
|
||||||
|
return [x0 + t * x10, y0 + t * y10];
|
||||||
|
}
|
||||||
|
function cornerTangents(x0, y0, x1, y1, r1, rc, cw) {
|
||||||
|
var x01 = x0 - x1, y01 = y0 - y1, lo = (cw ? rc : -rc) / sqrt(x01 * x01 + y01 * y01), ox = lo * y01, oy = -lo * x01, x11 = x0 + ox, y11 = y0 + oy, x10 = x1 + ox, y10 = y1 + oy, x00 = (x11 + x10) / 2, y00 = (y11 + y10) / 2, dx = x10 - x11, dy = y10 - y11, d2 = dx * dx + dy * dy, r = r1 - rc, D = x11 * y10 - x10 * y11, d = (dy < 0 ? -1 : 1) * sqrt(max(0, r * r * d2 - D * D)), cx0 = (D * dy - dx * d) / d2, cy0 = (-D * dx - dy * d) / d2, cx1 = (D * dy + dx * d) / d2, cy1 = (-D * dx + dy * d) / d2, dx0 = cx0 - x00, dy0 = cy0 - y00, dx1 = cx1 - x00, dy1 = cy1 - y00;
|
||||||
|
if (dx0 * dx0 + dy0 * dy0 > dx1 * dx1 + dy1 * dy1)
|
||||||
|
cx0 = cx1, cy0 = cy1;
|
||||||
|
return {
|
||||||
|
cx: cx0,
|
||||||
|
cy: cy0,
|
||||||
|
x01: -ox,
|
||||||
|
y01: -oy,
|
||||||
|
x11: cx0 * (r1 / r - 1),
|
||||||
|
y11: cy0 * (r1 / r - 1)
|
||||||
|
};
|
||||||
|
}
|
||||||
|
function d3arc() {
|
||||||
|
var innerRadius = arcInnerRadius, outerRadius = arcOuterRadius, cornerRadius = constant(0), padRadius = null, startAngle = arcStartAngle, endAngle = arcEndAngle, padAngle = arcPadAngle, context = null;
|
||||||
|
function arc() {
|
||||||
|
var buffer, r, r0 = +innerRadius.apply(this, arguments), r1 = +outerRadius.apply(this, arguments), a0 = startAngle.apply(this, arguments) - halfPi, a1 = endAngle.apply(this, arguments) - halfPi, da = abs(a1 - a0), cw = a1 > a0;
|
||||||
|
if (!context)
|
||||||
|
context = buffer = path();
|
||||||
|
if (r1 < r0)
|
||||||
|
r = r1, r1 = r0, r0 = r;
|
||||||
|
if (!(r1 > epsilon))
|
||||||
|
context.moveTo(0, 0);
|
||||||
|
else if (da > tau - epsilon) {
|
||||||
|
context.moveTo(r1 * cos(a0), r1 * sin(a0));
|
||||||
|
context.arc(0, 0, r1, a0, a1, !cw);
|
||||||
|
if (r0 > epsilon) {
|
||||||
|
context.moveTo(r0 * cos(a1), r0 * sin(a1));
|
||||||
|
context.arc(0, 0, r0, a1, a0, cw);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
var a01 = a0, a11 = a1, a00 = a0, a10 = a1, da0 = da, da1 = da, ap = padAngle.apply(this, arguments) / 2, rp = ap > epsilon && (padRadius ? +padRadius.apply(this, arguments) : sqrt(r0 * r0 + r1 * r1)), rc = min(abs(r1 - r0) / 2, +cornerRadius.apply(this, arguments)), rc0 = rc, rc1 = rc, t0, t1;
|
||||||
|
if (rp > epsilon) {
|
||||||
|
var p0 = asin(rp / r0 * sin(ap)), p1 = asin(rp / r1 * sin(ap));
|
||||||
|
if ((da0 -= p0 * 2) > epsilon)
|
||||||
|
p0 *= cw ? 1 : -1, a00 += p0, a10 -= p0;
|
||||||
|
else
|
||||||
|
da0 = 0, a00 = a10 = (a0 + a1) / 2;
|
||||||
|
if ((da1 -= p1 * 2) > epsilon)
|
||||||
|
p1 *= cw ? 1 : -1, a01 += p1, a11 -= p1;
|
||||||
|
else
|
||||||
|
da1 = 0, a01 = a11 = (a0 + a1) / 2;
|
||||||
|
}
|
||||||
|
var x01 = r1 * cos(a01), y01 = r1 * sin(a01), x10 = r0 * cos(a10), y10 = r0 * sin(a10);
|
||||||
|
if (rc > epsilon) {
|
||||||
|
var x11 = r1 * cos(a11), y11 = r1 * sin(a11), x00 = r0 * cos(a00), y00 = r0 * sin(a00), oc;
|
||||||
|
if (da < pi && (oc = intersect(x01, y01, x00, y00, x11, y11, x10, y10))) {
|
||||||
|
var ax = x01 - oc[0], ay = y01 - oc[1], bx = x11 - oc[0], by = y11 - oc[1], kc = 1 / sin(acos((ax * bx + ay * by) / (sqrt(ax * ax + ay * ay) * sqrt(bx * bx + by * by))) / 2), lc = sqrt(oc[0] * oc[0] + oc[1] * oc[1]);
|
||||||
|
rc0 = min(rc, (r0 - lc) / (kc - 1));
|
||||||
|
rc1 = min(rc, (r1 - lc) / (kc + 1));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (!(da1 > epsilon))
|
||||||
|
context.moveTo(x01, y01);
|
||||||
|
else if (rc1 > epsilon) {
|
||||||
|
t0 = cornerTangents(x00, y00, x01, y01, r1, rc1, cw);
|
||||||
|
t1 = cornerTangents(x11, y11, x10, y10, r1, rc1, cw);
|
||||||
|
context.moveTo(t0.cx + t0.x01, t0.cy + t0.y01);
|
||||||
|
if (rc1 < rc)
|
||||||
|
context.arc(t0.cx, t0.cy, rc1, atan2(t0.y01, t0.x01), atan2(t1.y01, t1.x01), !cw);
|
||||||
|
else {
|
||||||
|
context.arc(t0.cx, t0.cy, rc1, atan2(t0.y01, t0.x01), atan2(t0.y11, t0.x11), !cw);
|
||||||
|
context.arc(0, 0, r1, atan2(t0.cy + t0.y11, t0.cx + t0.x11), atan2(t1.cy + t1.y11, t1.cx + t1.x11), !cw);
|
||||||
|
context.arc(t1.cx, t1.cy, rc1, atan2(t1.y11, t1.x11), atan2(t1.y01, t1.x01), !cw);
|
||||||
|
}
|
||||||
|
} else
|
||||||
|
context.moveTo(x01, y01), context.arc(0, 0, r1, a01, a11, !cw);
|
||||||
|
if (!(r0 > epsilon) || !(da0 > epsilon))
|
||||||
|
context.lineTo(x10, y10);
|
||||||
|
else if (rc0 > epsilon) {
|
||||||
|
t0 = cornerTangents(x10, y10, x11, y11, r0, -rc0, cw);
|
||||||
|
t1 = cornerTangents(x01, y01, x00, y00, r0, -rc0, cw);
|
||||||
|
context.lineTo(t0.cx + t0.x01, t0.cy + t0.y01);
|
||||||
|
if (rc0 < rc)
|
||||||
|
context.arc(t0.cx, t0.cy, rc0, atan2(t0.y01, t0.x01), atan2(t1.y01, t1.x01), !cw);
|
||||||
|
else {
|
||||||
|
context.arc(t0.cx, t0.cy, rc0, atan2(t0.y01, t0.x01), atan2(t0.y11, t0.x11), !cw);
|
||||||
|
context.arc(0, 0, r0, atan2(t0.cy + t0.y11, t0.cx + t0.x11), atan2(t1.cy + t1.y11, t1.cx + t1.x11), cw);
|
||||||
|
context.arc(t1.cx, t1.cy, rc0, atan2(t1.y11, t1.x11), atan2(t1.y01, t1.x01), !cw);
|
||||||
|
}
|
||||||
|
} else
|
||||||
|
context.arc(0, 0, r0, a10, a00, cw);
|
||||||
|
}
|
||||||
|
context.closePath();
|
||||||
|
if (buffer)
|
||||||
|
return context = null, buffer + "" || null;
|
||||||
|
}
|
||||||
|
arc.centroid = function() {
|
||||||
|
var r = (+innerRadius.apply(this, arguments) + +outerRadius.apply(this, arguments)) / 2, a = (+startAngle.apply(this, arguments) + +endAngle.apply(this, arguments)) / 2 - pi / 2;
|
||||||
|
return [cos(a) * r, sin(a) * r];
|
||||||
|
};
|
||||||
|
arc.innerRadius = function(_) {
|
||||||
|
return arguments.length ? (innerRadius = typeof _ === "function" ? _ : constant(+_), arc) : innerRadius;
|
||||||
|
};
|
||||||
|
arc.outerRadius = function(_) {
|
||||||
|
return arguments.length ? (outerRadius = typeof _ === "function" ? _ : constant(+_), arc) : outerRadius;
|
||||||
|
};
|
||||||
|
arc.cornerRadius = function(_) {
|
||||||
|
return arguments.length ? (cornerRadius = typeof _ === "function" ? _ : constant(+_), arc) : cornerRadius;
|
||||||
|
};
|
||||||
|
arc.padRadius = function(_) {
|
||||||
|
return arguments.length ? (padRadius = _ == null ? null : typeof _ === "function" ? _ : constant(+_), arc) : padRadius;
|
||||||
|
};
|
||||||
|
arc.startAngle = function(_) {
|
||||||
|
return arguments.length ? (startAngle = typeof _ === "function" ? _ : constant(+_), arc) : startAngle;
|
||||||
|
};
|
||||||
|
arc.endAngle = function(_) {
|
||||||
|
return arguments.length ? (endAngle = typeof _ === "function" ? _ : constant(+_), arc) : endAngle;
|
||||||
|
};
|
||||||
|
arc.padAngle = function(_) {
|
||||||
|
return arguments.length ? (padAngle = typeof _ === "function" ? _ : constant(+_), arc) : padAngle;
|
||||||
|
};
|
||||||
|
arc.context = function(_) {
|
||||||
|
return arguments.length ? (context = _ == null ? null : _, arc) : context;
|
||||||
|
};
|
||||||
|
return arc;
|
||||||
|
}
|
||||||
|
export {
|
||||||
|
d3arc as d
|
||||||
|
};
|
||||||
|
//# sourceMappingURL=arc-7c943a40.js.map
|
1
assets/lib/mermaid/arc-7c943a40.js.map
Normal file
148
assets/lib/mermaid/arc-c0f908ab.js
Normal file
|
@ -0,0 +1,148 @@
|
||||||
|
import { w as withPath, c as constant } from "./path-39bad7e2.js";
|
||||||
|
import { aw as pi, ax as cos, ay as sin, az as halfPi, aA as epsilon, V as tau, aB as sqrt, aC as min, aD as abs, aE as atan2, aF as asin, aG as acos, aH as max } from "./mermaid-dcacb631.js";
|
||||||
|
function arcInnerRadius(d) {
|
||||||
|
return d.innerRadius;
|
||||||
|
}
|
||||||
|
function arcOuterRadius(d) {
|
||||||
|
return d.outerRadius;
|
||||||
|
}
|
||||||
|
function arcStartAngle(d) {
|
||||||
|
return d.startAngle;
|
||||||
|
}
|
||||||
|
function arcEndAngle(d) {
|
||||||
|
return d.endAngle;
|
||||||
|
}
|
||||||
|
function arcPadAngle(d) {
|
||||||
|
return d && d.padAngle;
|
||||||
|
}
|
||||||
|
function intersect(x0, y0, x1, y1, x2, y2, x3, y3) {
|
||||||
|
var x10 = x1 - x0, y10 = y1 - y0, x32 = x3 - x2, y32 = y3 - y2, t = y32 * x10 - x32 * y10;
|
||||||
|
if (t * t < epsilon)
|
||||||
|
return;
|
||||||
|
t = (x32 * (y0 - y2) - y32 * (x0 - x2)) / t;
|
||||||
|
return [x0 + t * x10, y0 + t * y10];
|
||||||
|
}
|
||||||
|
function cornerTangents(x0, y0, x1, y1, r1, rc, cw) {
|
||||||
|
var x01 = x0 - x1, y01 = y0 - y1, lo = (cw ? rc : -rc) / sqrt(x01 * x01 + y01 * y01), ox = lo * y01, oy = -lo * x01, x11 = x0 + ox, y11 = y0 + oy, x10 = x1 + ox, y10 = y1 + oy, x00 = (x11 + x10) / 2, y00 = (y11 + y10) / 2, dx = x10 - x11, dy = y10 - y11, d2 = dx * dx + dy * dy, r = r1 - rc, D = x11 * y10 - x10 * y11, d = (dy < 0 ? -1 : 1) * sqrt(max(0, r * r * d2 - D * D)), cx0 = (D * dy - dx * d) / d2, cy0 = (-D * dx - dy * d) / d2, cx1 = (D * dy + dx * d) / d2, cy1 = (-D * dx + dy * d) / d2, dx0 = cx0 - x00, dy0 = cy0 - y00, dx1 = cx1 - x00, dy1 = cy1 - y00;
|
||||||
|
if (dx0 * dx0 + dy0 * dy0 > dx1 * dx1 + dy1 * dy1)
|
||||||
|
cx0 = cx1, cy0 = cy1;
|
||||||
|
return {
|
||||||
|
cx: cx0,
|
||||||
|
cy: cy0,
|
||||||
|
x01: -ox,
|
||||||
|
y01: -oy,
|
||||||
|
x11: cx0 * (r1 / r - 1),
|
||||||
|
y11: cy0 * (r1 / r - 1)
|
||||||
|
};
|
||||||
|
}
|
||||||
|
function d3arc() {
|
||||||
|
var innerRadius = arcInnerRadius, outerRadius = arcOuterRadius, cornerRadius = constant(0), padRadius = null, startAngle = arcStartAngle, endAngle = arcEndAngle, padAngle = arcPadAngle, context = null, path = withPath(arc);
|
||||||
|
function arc() {
|
||||||
|
var buffer, r, r0 = +innerRadius.apply(this, arguments), r1 = +outerRadius.apply(this, arguments), a0 = startAngle.apply(this, arguments) - halfPi, a1 = endAngle.apply(this, arguments) - halfPi, da = abs(a1 - a0), cw = a1 > a0;
|
||||||
|
if (!context)
|
||||||
|
context = buffer = path();
|
||||||
|
if (r1 < r0)
|
||||||
|
r = r1, r1 = r0, r0 = r;
|
||||||
|
if (!(r1 > epsilon))
|
||||||
|
context.moveTo(0, 0);
|
||||||
|
else if (da > tau - epsilon) {
|
||||||
|
context.moveTo(r1 * cos(a0), r1 * sin(a0));
|
||||||
|
context.arc(0, 0, r1, a0, a1, !cw);
|
||||||
|
if (r0 > epsilon) {
|
||||||
|
context.moveTo(r0 * cos(a1), r0 * sin(a1));
|
||||||
|
context.arc(0, 0, r0, a1, a0, cw);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
var a01 = a0, a11 = a1, a00 = a0, a10 = a1, da0 = da, da1 = da, ap = padAngle.apply(this, arguments) / 2, rp = ap > epsilon && (padRadius ? +padRadius.apply(this, arguments) : sqrt(r0 * r0 + r1 * r1)), rc = min(abs(r1 - r0) / 2, +cornerRadius.apply(this, arguments)), rc0 = rc, rc1 = rc, t0, t1;
|
||||||
|
if (rp > epsilon) {
|
||||||
|
var p0 = asin(rp / r0 * sin(ap)), p1 = asin(rp / r1 * sin(ap));
|
||||||
|
if ((da0 -= p0 * 2) > epsilon)
|
||||||
|
p0 *= cw ? 1 : -1, a00 += p0, a10 -= p0;
|
||||||
|
else
|
||||||
|
da0 = 0, a00 = a10 = (a0 + a1) / 2;
|
||||||
|
if ((da1 -= p1 * 2) > epsilon)
|
||||||
|
p1 *= cw ? 1 : -1, a01 += p1, a11 -= p1;
|
||||||
|
else
|
||||||
|
da1 = 0, a01 = a11 = (a0 + a1) / 2;
|
||||||
|
}
|
||||||
|
var x01 = r1 * cos(a01), y01 = r1 * sin(a01), x10 = r0 * cos(a10), y10 = r0 * sin(a10);
|
||||||
|
if (rc > epsilon) {
|
||||||
|
var x11 = r1 * cos(a11), y11 = r1 * sin(a11), x00 = r0 * cos(a00), y00 = r0 * sin(a00), oc;
|
||||||
|
if (da < pi) {
|
||||||
|
if (oc = intersect(x01, y01, x00, y00, x11, y11, x10, y10)) {
|
||||||
|
var ax = x01 - oc[0], ay = y01 - oc[1], bx = x11 - oc[0], by = y11 - oc[1], kc = 1 / sin(acos((ax * bx + ay * by) / (sqrt(ax * ax + ay * ay) * sqrt(bx * bx + by * by))) / 2), lc = sqrt(oc[0] * oc[0] + oc[1] * oc[1]);
|
||||||
|
rc0 = min(rc, (r0 - lc) / (kc - 1));
|
||||||
|
rc1 = min(rc, (r1 - lc) / (kc + 1));
|
||||||
|
} else {
|
||||||
|
rc0 = rc1 = 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (!(da1 > epsilon))
|
||||||
|
context.moveTo(x01, y01);
|
||||||
|
else if (rc1 > epsilon) {
|
||||||
|
t0 = cornerTangents(x00, y00, x01, y01, r1, rc1, cw);
|
||||||
|
t1 = cornerTangents(x11, y11, x10, y10, r1, rc1, cw);
|
||||||
|
context.moveTo(t0.cx + t0.x01, t0.cy + t0.y01);
|
||||||
|
if (rc1 < rc)
|
||||||
|
context.arc(t0.cx, t0.cy, rc1, atan2(t0.y01, t0.x01), atan2(t1.y01, t1.x01), !cw);
|
||||||
|
else {
|
||||||
|
context.arc(t0.cx, t0.cy, rc1, atan2(t0.y01, t0.x01), atan2(t0.y11, t0.x11), !cw);
|
||||||
|
context.arc(0, 0, r1, atan2(t0.cy + t0.y11, t0.cx + t0.x11), atan2(t1.cy + t1.y11, t1.cx + t1.x11), !cw);
|
||||||
|
context.arc(t1.cx, t1.cy, rc1, atan2(t1.y11, t1.x11), atan2(t1.y01, t1.x01), !cw);
|
||||||
|
}
|
||||||
|
} else
|
||||||
|
context.moveTo(x01, y01), context.arc(0, 0, r1, a01, a11, !cw);
|
||||||
|
if (!(r0 > epsilon) || !(da0 > epsilon))
|
||||||
|
context.lineTo(x10, y10);
|
||||||
|
else if (rc0 > epsilon) {
|
||||||
|
t0 = cornerTangents(x10, y10, x11, y11, r0, -rc0, cw);
|
||||||
|
t1 = cornerTangents(x01, y01, x00, y00, r0, -rc0, cw);
|
||||||
|
context.lineTo(t0.cx + t0.x01, t0.cy + t0.y01);
|
||||||
|
if (rc0 < rc)
|
||||||
|
context.arc(t0.cx, t0.cy, rc0, atan2(t0.y01, t0.x01), atan2(t1.y01, t1.x01), !cw);
|
||||||
|
else {
|
||||||
|
context.arc(t0.cx, t0.cy, rc0, atan2(t0.y01, t0.x01), atan2(t0.y11, t0.x11), !cw);
|
||||||
|
context.arc(0, 0, r0, atan2(t0.cy + t0.y11, t0.cx + t0.x11), atan2(t1.cy + t1.y11, t1.cx + t1.x11), cw);
|
||||||
|
context.arc(t1.cx, t1.cy, rc0, atan2(t1.y11, t1.x11), atan2(t1.y01, t1.x01), !cw);
|
||||||
|
}
|
||||||
|
} else
|
||||||
|
context.arc(0, 0, r0, a10, a00, cw);
|
||||||
|
}
|
||||||
|
context.closePath();
|
||||||
|
if (buffer)
|
||||||
|
return context = null, buffer + "" || null;
|
||||||
|
}
|
||||||
|
arc.centroid = function() {
|
||||||
|
var r = (+innerRadius.apply(this, arguments) + +outerRadius.apply(this, arguments)) / 2, a = (+startAngle.apply(this, arguments) + +endAngle.apply(this, arguments)) / 2 - pi / 2;
|
||||||
|
return [cos(a) * r, sin(a) * r];
|
||||||
|
};
|
||||||
|
arc.innerRadius = function(_) {
|
||||||
|
return arguments.length ? (innerRadius = typeof _ === "function" ? _ : constant(+_), arc) : innerRadius;
|
||||||
|
};
|
||||||
|
arc.outerRadius = function(_) {
|
||||||
|
return arguments.length ? (outerRadius = typeof _ === "function" ? _ : constant(+_), arc) : outerRadius;
|
||||||
|
};
|
||||||
|
arc.cornerRadius = function(_) {
|
||||||
|
return arguments.length ? (cornerRadius = typeof _ === "function" ? _ : constant(+_), arc) : cornerRadius;
|
||||||
|
};
|
||||||
|
arc.padRadius = function(_) {
|
||||||
|
return arguments.length ? (padRadius = _ == null ? null : typeof _ === "function" ? _ : constant(+_), arc) : padRadius;
|
||||||
|
};
|
||||||
|
arc.startAngle = function(_) {
|
||||||
|
return arguments.length ? (startAngle = typeof _ === "function" ? _ : constant(+_), arc) : startAngle;
|
||||||
|
};
|
||||||
|
arc.endAngle = function(_) {
|
||||||
|
return arguments.length ? (endAngle = typeof _ === "function" ? _ : constant(+_), arc) : endAngle;
|
||||||
|
};
|
||||||
|
arc.padAngle = function(_) {
|
||||||
|
return arguments.length ? (padAngle = typeof _ === "function" ? _ : constant(+_), arc) : padAngle;
|
||||||
|
};
|
||||||
|
arc.context = function(_) {
|
||||||
|
return arguments.length ? (context = _ == null ? null : _, arc) : context;
|
||||||
|
};
|
||||||
|
return arc;
|
||||||
|
}
|
||||||
|
export {
|
||||||
|
d3arc as d
|
||||||
|
};
|
86
assets/lib/mermaid/arc-d1f6357e.js
Normal file
|
@ -0,0 +1,86 @@
|
||||||
|
import { w as ln, c as H } from "./path-428ebac9.js";
|
||||||
|
import { aw as an, ax as V, ay as D, az as rn, aA as y, V as on, aB as K, aC as _, aD as un, aE as t, aF as sn, aG as tn, aH as fn } from "./mermaid-9f2aa176.js";
|
||||||
|
function cn(l) {
|
||||||
|
return l.innerRadius;
|
||||||
|
}
|
||||||
|
function yn(l) {
|
||||||
|
return l.outerRadius;
|
||||||
|
}
|
||||||
|
function gn(l) {
|
||||||
|
return l.startAngle;
|
||||||
|
}
|
||||||
|
function mn(l) {
|
||||||
|
return l.endAngle;
|
||||||
|
}
|
||||||
|
function pn(l) {
|
||||||
|
return l && l.padAngle;
|
||||||
|
}
|
||||||
|
function dn(l, h, z, E, v, A, I, a) {
|
||||||
|
var B = z - l, i = E - h, n = I - v, m = a - A, r = m * B - n * i;
|
||||||
|
if (!(r * r < y))
|
||||||
|
return r = (n * (h - A) - m * (l - v)) / r, [l + r * B, h + r * i];
|
||||||
|
}
|
||||||
|
function W(l, h, z, E, v, A, I) {
|
||||||
|
var a = l - z, B = h - E, i = (I ? A : -A) / K(a * a + B * B), n = i * B, m = -i * a, r = l + n, s = h + m, f = z + n, c = E + m, O = (r + f) / 2, o = (s + c) / 2, p = f - r, g = c - s, R = p * p + g * g, T = v - A, w = r * c - f * s, C = (g < 0 ? -1 : 1) * K(fn(0, T * T * R - w * w)), F = (w * g - p * C) / R, G = (-w * p - g * C) / R, P = (w * g + p * C) / R, d = (-w * p + g * C) / R, x = F - O, e = G - o, u = P - O, S = d - o;
|
||||||
|
return x * x + e * e > u * u + S * S && (F = P, G = d), {
|
||||||
|
cx: F,
|
||||||
|
cy: G,
|
||||||
|
x01: -n,
|
||||||
|
y01: -m,
|
||||||
|
x11: F * (v / T - 1),
|
||||||
|
y11: G * (v / T - 1)
|
||||||
|
};
|
||||||
|
}
|
||||||
|
function vn() {
|
||||||
|
var l = cn, h = yn, z = H(0), E = null, v = gn, A = mn, I = pn, a = null, B = ln(i);
|
||||||
|
function i() {
|
||||||
|
var n, m, r = +l.apply(this, arguments), s = +h.apply(this, arguments), f = v.apply(this, arguments) - rn, c = A.apply(this, arguments) - rn, O = un(c - f), o = c > f;
|
||||||
|
if (a || (a = n = B()), s < r && (m = s, s = r, r = m), !(s > y))
|
||||||
|
a.moveTo(0, 0);
|
||||||
|
else if (O > on - y)
|
||||||
|
a.moveTo(s * V(f), s * D(f)), a.arc(0, 0, s, f, c, !o), r > y && (a.moveTo(r * V(c), r * D(c)), a.arc(0, 0, r, c, f, o));
|
||||||
|
else {
|
||||||
|
var p = f, g = c, R = f, T = c, w = O, C = O, F = I.apply(this, arguments) / 2, G = F > y && (E ? +E.apply(this, arguments) : K(r * r + s * s)), P = _(un(s - r) / 2, +z.apply(this, arguments)), d = P, x = P, e, u;
|
||||||
|
if (G > y) {
|
||||||
|
var S = sn(G / r * D(F)), L = sn(G / s * D(F));
|
||||||
|
(w -= S * 2) > y ? (S *= o ? 1 : -1, R += S, T -= S) : (w = 0, R = T = (f + c) / 2), (C -= L * 2) > y ? (L *= o ? 1 : -1, p += L, g -= L) : (C = 0, p = g = (f + c) / 2);
|
||||||
|
}
|
||||||
|
var j = s * V(p), J = s * D(p), M = r * V(T), N = r * D(T);
|
||||||
|
if (P > y) {
|
||||||
|
var Q = s * V(g), U = s * D(g), X = r * V(R), Y = r * D(R), q;
|
||||||
|
if (O < an)
|
||||||
|
if (q = dn(j, J, X, Y, Q, U, M, N)) {
|
||||||
|
var Z = j - q[0], $ = J - q[1], k = Q - q[0], b = U - q[1], nn = 1 / D(tn((Z * k + $ * b) / (K(Z * Z + $ * $) * K(k * k + b * b))) / 2), en = K(q[0] * q[0] + q[1] * q[1]);
|
||||||
|
d = _(P, (r - en) / (nn - 1)), x = _(P, (s - en) / (nn + 1));
|
||||||
|
} else
|
||||||
|
d = x = 0;
|
||||||
|
}
|
||||||
|
C > y ? x > y ? (e = W(X, Y, j, J, s, x, o), u = W(Q, U, M, N, s, x, o), a.moveTo(e.cx + e.x01, e.cy + e.y01), x < P ? a.arc(e.cx, e.cy, x, t(e.y01, e.x01), t(u.y01, u.x01), !o) : (a.arc(e.cx, e.cy, x, t(e.y01, e.x01), t(e.y11, e.x11), !o), a.arc(0, 0, s, t(e.cy + e.y11, e.cx + e.x11), t(u.cy + u.y11, u.cx + u.x11), !o), a.arc(u.cx, u.cy, x, t(u.y11, u.x11), t(u.y01, u.x01), !o))) : (a.moveTo(j, J), a.arc(0, 0, s, p, g, !o)) : a.moveTo(j, J), !(r > y) || !(w > y) ? a.lineTo(M, N) : d > y ? (e = W(M, N, Q, U, r, -d, o), u = W(j, J, X, Y, r, -d, o), a.lineTo(e.cx + e.x01, e.cy + e.y01), d < P ? a.arc(e.cx, e.cy, d, t(e.y01, e.x01), t(u.y01, u.x01), !o) : (a.arc(e.cx, e.cy, d, t(e.y01, e.x01), t(e.y11, e.x11), !o), a.arc(0, 0, r, t(e.cy + e.y11, e.cx + e.x11), t(u.cy + u.y11, u.cx + u.x11), o), a.arc(u.cx, u.cy, d, t(u.y11, u.x11), t(u.y01, u.x01), !o))) : a.arc(0, 0, r, T, R, o);
|
||||||
|
}
|
||||||
|
if (a.closePath(), n)
|
||||||
|
return a = null, n + "" || null;
|
||||||
|
}
|
||||||
|
return i.centroid = function() {
|
||||||
|
var n = (+l.apply(this, arguments) + +h.apply(this, arguments)) / 2, m = (+v.apply(this, arguments) + +A.apply(this, arguments)) / 2 - an / 2;
|
||||||
|
return [V(m) * n, D(m) * n];
|
||||||
|
}, i.innerRadius = function(n) {
|
||||||
|
return arguments.length ? (l = typeof n == "function" ? n : H(+n), i) : l;
|
||||||
|
}, i.outerRadius = function(n) {
|
||||||
|
return arguments.length ? (h = typeof n == "function" ? n : H(+n), i) : h;
|
||||||
|
}, i.cornerRadius = function(n) {
|
||||||
|
return arguments.length ? (z = typeof n == "function" ? n : H(+n), i) : z;
|
||||||
|
}, i.padRadius = function(n) {
|
||||||
|
return arguments.length ? (E = n == null ? null : typeof n == "function" ? n : H(+n), i) : E;
|
||||||
|
}, i.startAngle = function(n) {
|
||||||
|
return arguments.length ? (v = typeof n == "function" ? n : H(+n), i) : v;
|
||||||
|
}, i.endAngle = function(n) {
|
||||||
|
return arguments.length ? (A = typeof n == "function" ? n : H(+n), i) : A;
|
||||||
|
}, i.padAngle = function(n) {
|
||||||
|
return arguments.length ? (I = typeof n == "function" ? n : H(+n), i) : I;
|
||||||
|
}, i.context = function(n) {
|
||||||
|
return arguments.length ? (a = n ?? null, i) : a;
|
||||||
|
}, i;
|
||||||
|
}
|
||||||
|
export {
|
||||||
|
vn as d
|
||||||
|
};
|
6
assets/lib/mermaid/array-2ff2c7a6.js
Normal file
|
@ -0,0 +1,6 @@
|
||||||
|
function t(r) {
|
||||||
|
return typeof r == "object" && "length" in r ? r : Array.from(r);
|
||||||
|
}
|
||||||
|
export {
|
||||||
|
t as a
|
||||||
|
};
|
1
assets/lib/mermaid/array-2ff2c7a6.js.map
Normal file
|
@ -0,0 +1 @@
|
||||||
|
{"version":3,"file":"array-2ff2c7a6.js","sources":["../../../node_modules/.pnpm/d3-shape@3.1.0/node_modules/d3-shape/src/array.js"],"sourcesContent":["export var slice = Array.prototype.slice;\n\nexport default function(x) {\n return typeof x === \"object\" && \"length\" in x\n ? x // Array, TypedArray, NodeList, array-like\n : Array.from(x); // Map, Set, iterable, string, or anything else\n}\n"],"names":["array","x"],"mappings":"AAEe,SAAQA,EAACC,GAAG;AACzB,SAAO,OAAOA,KAAM,YAAY,YAAYA,IACxCA,IACA,MAAM,KAAKA,CAAC;AAClB;"}
|
6
assets/lib/mermaid/array-b7dcf730.js
Normal file
|
@ -0,0 +1,6 @@
|
||||||
|
function array(x) {
|
||||||
|
return typeof x === "object" && "length" in x ? x : Array.from(x);
|
||||||
|
}
|
||||||
|
export {
|
||||||
|
array as a
|
||||||
|
};
|
1
assets/lib/mermaid/array-b7dcf730.js.map
Normal file
|
@ -0,0 +1 @@
|
||||||
|
{"version":3,"file":"array-b7dcf730.js","sources":["../../../node_modules/.pnpm/d3-shape@3.1.0/node_modules/d3-shape/src/array.js"],"sourcesContent":["export var slice = Array.prototype.slice;\n\nexport default function(x) {\n return typeof x === \"object\" && \"length\" in x\n ? x // Array, TypedArray, NodeList, array-like\n : Array.from(x); // Map, Set, iterable, string, or anything else\n}\n"],"names":[],"mappings":"AAEe,SAAQ,MAAC,GAAG;AACzB,SAAO,OAAO,MAAM,YAAY,YAAY,IACxC,IACA,MAAM,KAAK,CAAC;AAClB;"}
|
30
assets/lib/mermaid/assignWithDepth.d.ts
vendored
Normal file
|
@ -0,0 +1,30 @@
|
||||||
|
/**
|
||||||
|
* assignWithDepth Extends the functionality of {@link Object.assign} with the
|
||||||
|
* ability to merge arbitrary-depth objects For each key in src with path `k` (recursively)
|
||||||
|
* performs an Object.assign(dst[`k`], src[`k`]) with a slight change from the typical handling of
|
||||||
|
* undefined for dst[`k`]: instead of raising an error, dst[`k`] is auto-initialized to `{}` and
|
||||||
|
* effectively merged with src[`k`]<p> Additionally, dissimilar types will not clobber unless the
|
||||||
|
* config.clobber parameter === true. Example:
|
||||||
|
*
|
||||||
|
* ```
|
||||||
|
* const config_0 = { foo: { bar: 'bar' }, bar: 'foo' };
|
||||||
|
* const config_1 = { foo: 'foo', bar: 'bar' };
|
||||||
|
* const result = assignWithDepth(config_0, config_1);
|
||||||
|
* console.log(result);
|
||||||
|
* //-> result: { foo: { bar: 'bar' }, bar: 'bar' }
|
||||||
|
* ```
|
||||||
|
*
|
||||||
|
* Traditional Object.assign would have clobbered foo in config_0 with foo in config_1. If src is a
|
||||||
|
* destructured array of objects and dst is not an array, assignWithDepth will apply each element
|
||||||
|
* of src to dst in order.
|
||||||
|
* @param dst - The destination of the merge
|
||||||
|
* @param src - The source object(s) to merge into destination
|
||||||
|
* @param config -
|
||||||
|
* * depth: depth to traverse within src and dst for merging
|
||||||
|
* * clobber: should dissimilar types clobber
|
||||||
|
*/
|
||||||
|
declare const assignWithDepth: (dst: any, src: any, { depth, clobber }?: {
|
||||||
|
depth?: number | undefined;
|
||||||
|
clobber?: boolean | undefined;
|
||||||
|
}) => any;
|
||||||
|
export default assignWithDepth;
|
1230
assets/lib/mermaid/blockDiagram-48276afd.js
Normal file
1230
assets/lib/mermaid/blockDiagram-5dc23a45.js
Normal file
1813
assets/lib/mermaid/blockDiagram-8beecd1f.js
Normal file
1817
assets/lib/mermaid/blockDiagram-91b80b7a.js
Normal file
1822
assets/lib/mermaid/blockDiagram-9f4a6865.js
Normal file
1818
assets/lib/mermaid/blockDiagram-efe38566.js
Normal file
2538
assets/lib/mermaid/c4Diagram-03ae1c00.js
Normal file
1
assets/lib/mermaid/c4Diagram-03ae1c00.js.map
Normal file
1579
assets/lib/mermaid/c4Diagram-1e775db3.js
Normal file
2530
assets/lib/mermaid/c4Diagram-8889d224.js
Normal file
1
assets/lib/mermaid/c4Diagram-8889d224.js.map
Normal file
1626
assets/lib/mermaid/c4Diagram-a7af8508.js
Normal file
1
assets/lib/mermaid/c4Diagram-a7af8508.js.map
Normal file
1626
assets/lib/mermaid/c4Diagram-adf7b82c.js
Normal file
1
assets/lib/mermaid/c4Diagram-adf7b82c.js.map
Normal file
2473
assets/lib/mermaid/c4Diagram-ae766693.js
Normal file
2463
assets/lib/mermaid/c4Diagram-af207393.js
Normal file
2473
assets/lib/mermaid/c4Diagram-b2a90758.js
Normal file
2463
assets/lib/mermaid/c4Diagram-e2511a7a.js
Normal file
1579
assets/lib/mermaid/c4Diagram-e65f60cc.js
Normal file
2538
assets/lib/mermaid/c4Diagram-f9e67060.js
Normal file
1
assets/lib/mermaid/c4Diagram-f9e67060.js.map
Normal file
2530
assets/lib/mermaid/c4Diagram-fa9ef55f.js
Normal file
1
assets/lib/mermaid/c4Diagram-fa9ef55f.js.map
Normal file
5
assets/lib/mermaid/channel-7a9b7149.js
Normal file
|
@ -0,0 +1,5 @@
|
||||||
|
import { aI as o, aJ as r } from "./mermaid-00886c59.js";
|
||||||
|
const s = (a, n) => o.lang.round(r.parse(a)[n]), e = s;
|
||||||
|
export {
|
||||||
|
e as c
|
||||||
|
};
|
8
assets/lib/mermaid/channel-d3ac35ac.js
Normal file
|
@ -0,0 +1,8 @@
|
||||||
|
import { aI as _, aJ as Color } from "./mermaid-c5809711.js";
|
||||||
|
const channel = (color, channel2) => {
|
||||||
|
return _.lang.round(Color.parse(color)[channel2]);
|
||||||
|
};
|
||||||
|
const channel$1 = channel;
|
||||||
|
export {
|
||||||
|
channel$1 as c
|
||||||
|
};
|
5
assets/lib/mermaid/channel-ebbc4130.js
Normal file
|
@ -0,0 +1,5 @@
|
||||||
|
import { aI as o, aJ as r } from "./mermaid-9f2aa176.js";
|
||||||
|
const s = (a, n) => o.lang.round(r.parse(a)[n]), e = s;
|
||||||
|
export {
|
||||||
|
e as c
|
||||||
|
};
|
8
assets/lib/mermaid/channel-f9001828.js
Normal file
|
@ -0,0 +1,8 @@
|
||||||
|
import { aI as _, aJ as Color } from "./mermaid-dcacb631.js";
|
||||||
|
const channel = (color, channel2) => {
|
||||||
|
return _.lang.round(Color.parse(color)[channel2]);
|
||||||
|
};
|
||||||
|
const channel$1 = channel;
|
||||||
|
export {
|
||||||
|
channel$1 as c
|
||||||
|
};
|
97
assets/lib/mermaid/classDiagram-17eafd8a.js
Normal file
|
@ -0,0 +1,97 @@
|
||||||
|
import { p as W, d as M, s as H } from "./styles-55d85316.js";
|
||||||
|
import { g as S, l as d, f as u } from "./config-e567ef17.js";
|
||||||
|
import { G as X, l as Y } from "./layout-d6d8be39.js";
|
||||||
|
import { s as l } from "./svgDraw-c034b55e.js";
|
||||||
|
import { c as Z } from "./setupGraphViewbox-a4603a92.js";
|
||||||
|
import "./utils-aa888deb.js";
|
||||||
|
import "./commonDb-4dc3d465.js";
|
||||||
|
import "./mermaidAPI-04b5c286.js";
|
||||||
|
import "./errorRenderer-a3c4bedb.js";
|
||||||
|
import "./isPlainObject-a5cb4071.js";
|
||||||
|
import "./array-2ff2c7a6.js";
|
||||||
|
import "./constant-2fe7eae5.js";
|
||||||
|
let h = {};
|
||||||
|
const g = 20, p = function(e) {
|
||||||
|
const s = Object.entries(h).find((k) => k[1].label === e);
|
||||||
|
if (s)
|
||||||
|
return s[0];
|
||||||
|
}, D = function(e) {
|
||||||
|
e.append("defs").append("marker").attr("id", "extensionStart").attr("class", "extension").attr("refX", 0).attr("refY", 7).attr("markerWidth", 190).attr("markerHeight", 240).attr("orient", "auto").append("path").attr("d", "M 1,7 L18,13 V 1 Z"), e.append("defs").append("marker").attr("id", "extensionEnd").attr("refX", 19).attr("refY", 7).attr("markerWidth", 20).attr("markerHeight", 28).attr("orient", "auto").append("path").attr("d", "M 1,1 V 13 L18,7 Z"), e.append("defs").append("marker").attr("id", "compositionStart").attr("class", "extension").attr("refX", 0).attr("refY", 7).attr("markerWidth", 190).attr("markerHeight", 240).attr("orient", "auto").append("path").attr("d", "M 18,7 L9,13 L1,7 L9,1 Z"), e.append("defs").append("marker").attr("id", "compositionEnd").attr("refX", 19).attr("refY", 7).attr("markerWidth", 20).attr("markerHeight", 28).attr("orient", "auto").append("path").attr("d", "M 18,7 L9,13 L1,7 L9,1 Z"), e.append("defs").append("marker").attr("id", "aggregationStart").attr("class", "extension").attr("refX", 0).attr("refY", 7).attr("markerWidth", 190).attr("markerHeight", 240).attr("orient", "auto").append("path").attr("d", "M 18,7 L9,13 L1,7 L9,1 Z"), e.append("defs").append("marker").attr("id", "aggregationEnd").attr("refX", 19).attr("refY", 7).attr("markerWidth", 20).attr("markerHeight", 28).attr("orient", "auto").append("path").attr("d", "M 18,7 L9,13 L1,7 L9,1 Z"), e.append("defs").append("marker").attr("id", "dependencyStart").attr("class", "extension").attr("refX", 0).attr("refY", 7).attr("markerWidth", 190).attr("markerHeight", 240).attr("orient", "auto").append("path").attr("d", "M 5,7 L9,13 L1,7 L9,1 Z"), e.append("defs").append("marker").attr("id", "dependencyEnd").attr("refX", 19).attr("refY", 7).attr("markerWidth", 20).attr("markerHeight", 28).attr("orient", "auto").append("path").attr("d", "M 18,7 L9,13 L14,7 L9,1 Z");
|
||||||
|
}, $ = function(e, s, k, a) {
|
||||||
|
const f = S().class;
|
||||||
|
h = {}, d.info("Rendering diagram " + e);
|
||||||
|
const L = S().securityLevel;
|
||||||
|
let y;
|
||||||
|
L === "sandbox" && (y = u("#i" + s));
|
||||||
|
const x = L === "sandbox" ? u(y.nodes()[0].contentDocument.body) : u("body"), n = x.select(`[id='${s}']`);
|
||||||
|
D(n);
|
||||||
|
const r = new X({
|
||||||
|
multigraph: !0
|
||||||
|
});
|
||||||
|
r.setGraph({
|
||||||
|
isMultiGraph: !0
|
||||||
|
}), r.setDefaultEdgeLabel(function() {
|
||||||
|
return {};
|
||||||
|
});
|
||||||
|
const m = a.db.getClasses(), N = Object.keys(m);
|
||||||
|
for (const t of N) {
|
||||||
|
const o = m[t], i = l.drawClass(n, o, f, a);
|
||||||
|
h[i.id] = i, r.setNode(i.id, i), d.info("Org height: " + i.height);
|
||||||
|
}
|
||||||
|
a.db.getRelations().forEach(function(t) {
|
||||||
|
d.info(
|
||||||
|
"tjoho" + p(t.id1) + p(t.id2) + JSON.stringify(t)
|
||||||
|
), r.setEdge(
|
||||||
|
p(t.id1),
|
||||||
|
p(t.id2),
|
||||||
|
{
|
||||||
|
relation: t
|
||||||
|
},
|
||||||
|
t.title || "DEFAULT"
|
||||||
|
);
|
||||||
|
}), a.db.getNotes().forEach(function(t) {
|
||||||
|
d.debug(`Adding note: ${JSON.stringify(t)}`);
|
||||||
|
const o = l.drawNote(n, t, f, a);
|
||||||
|
h[o.id] = o, r.setNode(o.id, o), t.class && t.class in m && r.setEdge(
|
||||||
|
t.id,
|
||||||
|
p(t.class),
|
||||||
|
{
|
||||||
|
relation: {
|
||||||
|
id1: t.id,
|
||||||
|
id2: t.class,
|
||||||
|
relation: {
|
||||||
|
type1: "none",
|
||||||
|
type2: "none",
|
||||||
|
lineType: 10
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"DEFAULT"
|
||||||
|
);
|
||||||
|
}), Y(r), r.nodes().forEach(function(t) {
|
||||||
|
t !== void 0 && r.node(t) !== void 0 && (d.debug("Node " + t + ": " + JSON.stringify(r.node(t))), x.select("#" + (a.db.lookUpDomId(t) || t)).attr(
|
||||||
|
"transform",
|
||||||
|
"translate(" + (r.node(t).x - r.node(t).width / 2) + "," + (r.node(t).y - r.node(t).height / 2) + " )"
|
||||||
|
));
|
||||||
|
}), r.edges().forEach(function(t) {
|
||||||
|
t !== void 0 && r.edge(t) !== void 0 && (d.debug("Edge " + t.v + " -> " + t.w + ": " + JSON.stringify(r.edge(t))), l.drawEdge(n, r.edge(t), r.edge(t).relation, f, a));
|
||||||
|
});
|
||||||
|
const c = n.node().getBBox(), E = c.width + g * 2, b = c.height + g * 2;
|
||||||
|
Z(n, b, E, f.useMaxWidth);
|
||||||
|
const w = `${c.x - g} ${c.y - g} ${E} ${b}`;
|
||||||
|
d.debug(`viewBox ${w}`), n.attr("viewBox", w);
|
||||||
|
}, B = {
|
||||||
|
draw: $
|
||||||
|
}, q = {
|
||||||
|
parser: W,
|
||||||
|
db: M,
|
||||||
|
renderer: B,
|
||||||
|
styles: H,
|
||||||
|
init: (e) => {
|
||||||
|
e.class || (e.class = {}), e.class.arrowMarkerAbsolute = e.arrowMarkerAbsolute, M.clear();
|
||||||
|
}
|
||||||
|
};
|
||||||
|
export {
|
||||||
|
q as diagram
|
||||||
|
};
|
||||||
|
//# sourceMappingURL=classDiagram-17eafd8a.js.map
|