diff --git a/.forgejo/workflows/build_preview.yml b/.forgejo/workflows/build_preview.yml new file mode 100644 index 0000000..36d6eb5 --- /dev/null +++ b/.forgejo/workflows/build_preview.yml @@ -0,0 +1,97 @@ +on: + push: + tags: + - '[0-9]+\.[0-9]+\.[0-9]+-pre\.[0-9]+' + +jobs: + check-tag: + runs-on: docker + steps: + - name: Checking Out Repository Code + uses: https://code.forgejo.org/actions/checkout@v3 + - name: Check if Version in package.json matches Tag + run: | + VERSION=$(npm pkg get version --workspaces=false | tr -d \") + if test $VERSION != "${{ github.ref_name }}"; then + echo "Expected Version is: '${{ github.ref_name }}' actual Version is: '$VERSION'"; + exit 1 + else + echo "Version is: '$VERSION'"; + fi + + checking: + needs: [ check-tag ] + runs-on: docker + container: forgejo.neshweb.net/ci-docker-images/node-alpine-git:latest + steps: + - name: Checkout source code + uses: https://code.forgejo.org/actions/checkout@v3 + - name: Install packages + run: npm i + - name: Run astro check (linting + static analysis) + run: npm run astro check + + build-site: + needs: [ checking ] + if: success() + runs-on: dind + steps: + - name: Set up Docker Buildx + uses: docker/setup-buildx-action@v3 + - name: Log into Docker Package Registry + uses: docker/login-action@v3 + with: + registry: forgejo.neshweb.net + username: ${{ secrets.FORGEJO_USERNAME }} + password: ${{ secrets.FORGEJO_TOKEN }} + - name: Build and push to Docker Package Registry + uses: docker/build-push-action@v5 + with: + push: true + tags: forgejo.neshweb.net/firq/fgo-ta-com-website:${{ github.ref_name }}, forgejo.neshweb.net/firq/fgo-ta-com-website:preview + + create-release: + needs: [ build-site ] + if: success() + runs-on: docker + steps: + - name: Release New Version + uses: https://code.forgejo.org/actions/forgejo-release@v1 + with: + direction: upload + url: https://forgejo.neshweb.net + release-dir: release + token: ${{ secrets.FORGEJO_TOKEN }} + tag: ${{ github.ref_name }} + prerelease: true + + auto-deploy-dockge: + needs: [ build-site ] + if: success() + runs-on: docker + container: forgejo.neshweb.net/firq/dockge-cli:0.1.2 + steps: + - name: Configure Dockge CLI + run: | + dockge host '${{ vars.DOCKGE_HOST }}' + dockge login --user '${{ secrets.DOCKGE_USER }}' --password '${{ secrets.DOCKGE_CREDENTIAL }}' + - name: Check status and redeploy + run: | + dockge status fgo-ta-com-preview + dockge update fgo-ta-com-preview + dockge status fgo-ta-com-preview + + run-unlighthouse: + needs: [ build-site ] + if: success() + runs-on: docker + steps: + - name: Launch workflow + run: | + payload="{\"ref\": \"${GITHUB_REF_NAME}\", \"inputs\": { \"containertag\": \"${GITHUB_REF_NAME}\" }}" + curl -X "POST" \ + -H "accept: application/json" \ + -H "Content-Type: application/json" \ + -H "Authorization: token ${GITHUB_TOKEN}" \ + -d "${payload}" \ + "${GITHUB_API_URL}/repos/${GITHUB_REPOSITORY}/actions/workflows/unlighthouse.yml/dispatches" -v diff --git a/.forgejo/workflows/build_release.yml b/.forgejo/workflows/build_release.yml new file mode 100644 index 0000000..3ebd356 --- /dev/null +++ b/.forgejo/workflows/build_release.yml @@ -0,0 +1,81 @@ +on: + push: + tags: + - '[0-9]+\.[0-9]+\.[0-9]+' + +jobs: + check-tag: + runs-on: docker + steps: + - name: Checking Out Repository Code + uses: https://code.forgejo.org/actions/checkout@v3 + - name: Check if Version in package.json matches Tag + run: | + VERSION=$(npm pkg get version --workspaces=false | tr -d \") + if test $VERSION != "${{ github.ref_name }}"; then + echo "Expected Version is: '${{ github.ref_name }}' actual Version is: '$VERSION'"; + exit 1 + else + echo "Version is: '$VERSION'"; + fi + + checking: + needs: [ check-tag ] + runs-on: docker + container: forgejo.neshweb.net/ci-docker-images/node-alpine-git:latest + steps: + - name: Checkout source code + uses: https://code.forgejo.org/actions/checkout@v3 + - name: Install packages + run: npm i + - name: Run astro check (linting + static analysis) + run: npm run astro check + + build-site: + needs: [ checking ] + if: success() + runs-on: dind + steps: + - name: Set up Docker Buildx + uses: docker/setup-buildx-action@v3 + - name: Log into Docker Package Registry + uses: docker/login-action@v3 + with: + registry: forgejo.neshweb.net + username: ${{ secrets.FORGEJO_USERNAME }} + password: ${{ secrets.FORGEJO_TOKEN }} + - name: Build and push to Docker Package Registry + uses: docker/build-push-action@v5 + with: + push: true + tags: forgejo.neshweb.net/firq/fgo-ta-com-website:${{ github.ref_name }}, forgejo.neshweb.net/firq/fgo-ta-com-website:latest + + create-release: + needs: [ build-site ] + if: success() + runs-on: docker + steps: + - name: Release New Version + uses: https://code.forgejo.org/actions/forgejo-release@v1 + with: + direction: upload + url: https://forgejo.neshweb.net + release-dir: release + token: ${{ secrets.FORGEJO_TOKEN }} + tag: ${{ github.ref_name }} + + auto-deploy-dockge: + needs: [ build-site ] + if: success() + runs-on: docker + container: forgejo.neshweb.net/firq/dockge-cli:0.1.2 + steps: + - name: Configure Dockge CLI + run: | + dockge host '${{ vars.DOCKGE_HOST }}' + dockge login --user '${{ secrets.DOCKGE_USER }}' --password '${{ secrets.DOCKGE_CREDENTIAL }}' + - name: Check status and redeploy + run: | + dockge status fgo-ta-com + dockge update fgo-ta-com + dockge status fgo-ta-com diff --git a/.forgejo/workflows/linting.yml b/.forgejo/workflows/linting.yml new file mode 100644 index 0000000..f68bdf7 --- /dev/null +++ b/.forgejo/workflows/linting.yml @@ -0,0 +1,25 @@ +on: + push: + branches: + - '**' + +jobs: + get-version: + runs-on: docker + steps: + - name: Checking Out Repository Code + uses: https://code.forgejo.org/actions/checkout@v3 + - name: Check if Version in package.json matches Tag + run: | + VERSION=$(npm pkg get version --workspaces=false | tr -d \") + echo "Version is: '$VERSION'"; + astro-check: + runs-on: docker + container: forgejo.neshweb.net/ci-docker-images/node-alpine-git:latest + steps: + - name: Checkout source code + uses: https://code.forgejo.org/actions/checkout@v3 + - name: Install packages + run: npm i + - name: Run astro check (linting + static analysis) + run: npm run astro check diff --git a/.forgejo/workflows/unlighthouse.yml b/.forgejo/workflows/unlighthouse.yml new file mode 100644 index 0000000..1222bce --- /dev/null +++ b/.forgejo/workflows/unlighthouse.yml @@ -0,0 +1,91 @@ +name: Run unlighthouse-tests [Downstream pipeline] +run-name: Run unlighthouse-tests [Downstream pipeline] for version ${{ inputs.containertag }} +on: + workflow_dispatch: + inputs: + containertag: + description: "Tag of the container to test" + default: "preview" + type: "string" + +jobs: + unlighthouse: + runs-on: docker + container: + image: forgejo.neshweb.net/ci-docker-images/unlighthouse:0.3.0 + services: + website: + image: forgejo.neshweb.net/firq/fgo-ta-com-website:${{ inputs.containertag }} + options: >- + --workdir / + steps: + - name: Checkout repository + uses: https://code.forgejo.org/actions/checkout@v3 + - name: Check availability + run: | + while [ "$(curl -o /dev/null -s -w '%{http_code}' http://localhost:8081/)" -ne 200 ]; + do echo "Waiting..."; + sleep 5; + done; + - name: Run unlighthouse + run: unlighthouse-ci --site "http://localhost:8081/" + - name: Replace URLs + run: find ./unlighthouse-reports -type f | xargs sed -i "s|http://localhost:8081|https://preview.fgo-ta.com|g"; + - name: Prepare artifacts + run: cp serve.json unlighthouse-reports + - name: Upload reports + uses: actions/upload-artifact@v3 + with: + name: unlighthouse-reports + path: unlighthouse-reports/ + - name: Upload Dockerfile + uses: actions/upload-artifact@v3 + with: + name: dockerfile + path: Dockerfile.reports + + build-site: + needs: [ unlighthouse ] + if: success() + runs-on: dind + steps: + - name: Downloading static site artifacts + uses: actions/download-artifact@v3 + with: + name: dockerfile + - name: Downloading static site artifacts + uses: actions/download-artifact@v3 + with: + name: unlighthouse-reports + path: reports + - name: Set up Docker Buildx + uses: docker/setup-buildx-action@v3 + - name: Log into Docker Package Registry + uses: docker/login-action@v3 + with: + registry: forgejo.neshweb.net + username: ${{ secrets.FORGEJO_USERNAME }} + password: ${{ secrets.FORGEJO_TOKEN }} + - name: Build and push to Docker Package Registry + uses: docker/build-push-action@v5 + with: + context: . + file: Dockerfile.reports + push: true + tags: forgejo.neshweb.net/firq/fgo-ta-com-website-unlighthouse:latest + + auto-deploy-dockge: + needs: [ build-site ] + if: success() + runs-on: docker + container: forgejo.neshweb.net/firq/dockge-cli:0.1.2 + steps: + - name: Configure Dockge CLI + run: | + dockge host '${{ vars.DOCKGE_HOST }}' + dockge login --user '${{ secrets.DOCKGE_USER }}' --password '${{ secrets.DOCKGE_CREDENTIAL }}' + - name: Check status and redeploy + run: | + dockge status fgo-ta-com-unlighthouse + dockge update fgo-ta-com-unlighthouse + dockge status fgo-ta-com-unlighthouse diff --git a/.gitignore b/.gitignore index 6d4c0aa..1b2b10e 100644 --- a/.gitignore +++ b/.gitignore @@ -19,3 +19,6 @@ pnpm-debug.log* # macOS-specific files .DS_Store + +# Temporary files +.temp/ diff --git a/.gitlab-ci.yml b/.gitlab-ci.yml index b9661ca..b4fafcb 100644 --- a/.gitlab-ci.yml +++ b/.gitlab-ci.yml @@ -66,7 +66,6 @@ deploy-site: - ssh $DEPLOY_USER@$DEPLOY_HOST 'PATH="$HOME/.local/bin:$PATH"; cd fgo-ta_com; find public -maxdepth 1 -printf "%p\n"; screen -S fgo-ta_com-public -dm serve public/ -p 9200' - echo "Website is up on https://fgo-ta.com" - redeploy-site: stage: scripts when: manual diff --git a/.prettierignore b/.prettierignore new file mode 100644 index 0000000..42b7fb8 --- /dev/null +++ b/.prettierignore @@ -0,0 +1,5 @@ +**/.git +**/node_modules +**/.vscode +**/public +**/dist \ No newline at end of file diff --git a/.prettierrc b/.prettierrc new file mode 100644 index 0000000..fa51da2 --- /dev/null +++ b/.prettierrc @@ -0,0 +1,6 @@ +{ + "trailingComma": "es5", + "tabWidth": 2, + "semi": false, + "singleQuote": true +} diff --git a/.vscode/settings.json b/.vscode/settings.json new file mode 100644 index 0000000..3fb7158 --- /dev/null +++ b/.vscode/settings.json @@ -0,0 +1,13 @@ +{ + "files.exclude": { + "**/.git": true, + "**/.svn": true, + "**/.hg": true, + "**/CVS": true, + "**/.DS_Store": true, + "**/Thumbs.db": true, + "**/__pycache__": true, + "**/node_modules": true + }, + "hide-files.files": [] +} \ No newline at end of file diff --git a/Dockerfile b/Dockerfile new file mode 100644 index 0000000..b9ff0a5 --- /dev/null +++ b/Dockerfile @@ -0,0 +1,16 @@ +FROM node:22-alpine AS build +WORKDIR /site +COPY . . +RUN npm i +RUN npm run astro telemetry disable +RUN npm run build + +FROM forgejo.neshweb.net/ci-docker-images/website-serve:2 AS runtime + +COPY --from=build /site/dist /public +COPY --from=build /site/serve.json /public/serve.json + +ENV PORT=8081 +EXPOSE 8081 + +CMD serve public/ -p ${PORT} diff --git a/Dockerfile.reports b/Dockerfile.reports new file mode 100644 index 0000000..f745d5e --- /dev/null +++ b/Dockerfile.reports @@ -0,0 +1,6 @@ +FROM forgejo.neshweb.net/ci-docker-images/website-serve:2 AS runtime + +ADD reports /public + +EXPOSE 8081 +CMD serve public/ -p 8081 diff --git a/README.md b/README.md index 75d44e0..6774015 100644 --- a/README.md +++ b/README.md @@ -1,42 +1,6 @@ -# Astro Starter Kit: Basics +# FGO TA Astro Site -``` -npm create astro@latest -- --template basics -``` - -[](https://stackblitz.com/github/withastro/astro/tree/latest/examples/basics) -[](https://codesandbox.io/p/sandbox/github/withastro/astro/tree/latest/examples/basics) -[](https://codespaces.new/withastro/astro?devcontainer_path=.devcontainer/basics/devcontainer.json) - -> π§βπ **Seasoned astronaut?** Delete this file. Have fun! - - - -## π Project Structure - -Inside of your Astro project, you'll see the following folders and files: - -``` -/ -βββ public/ -β βββ favicon.svg -βββ src/ -β βββ components/ -β β βββ Card.astro -β βββ layouts/ -β β βββ Layout.astro -β βββ pages/ -β βββ index.astro -βββ package.json -``` - -Astro looks for `.astro` or `.md` files in the `src/pages/` directory. Each page is exposed as a route based on its file name. - -There's nothing special about `src/components/`, but that's where we like to put any Astro/React/Vue/Svelte/Preact components. - -Any static assets, like images, can be placed in the `public/` directory. - -## π§ Commands +## Commands All commands are run from the root of the project, from a terminal: @@ -48,7 +12,3 @@ All commands are run from the root of the project, from a terminal: | `npm run preview` | Preview your build locally, before deploying | | `npm run astro ...` | Run CLI commands like `astro add`, `astro check` | | `npm run astro -- --help` | Get help using the Astro CLI | - -## π Want to learn more? - -Feel free to check [our documentation](https://docs.astro.build) or jump into our [Discord server](https://astro.build/chat). diff --git a/astro.config.mjs b/astro.config.mjs index bb1da0e..a00984c 100644 --- a/astro.config.mjs +++ b/astro.config.mjs @@ -1,11 +1,13 @@ +import sitemap from '@astrojs/sitemap'; +import metaTags from "astro-meta-tags"; import { defineConfig } from 'astro/config'; -import sitemap from "@astrojs/sitemap"; export default defineConfig({ sitemap: true, base: '/', - outDir: 'public', - publicDir: 'static', + outDir: 'dist', + publicDir: 'public', site: 'https://fgo-ta.com/', - integrations: [sitemap()] + integrations: [sitemap(), metaTags()], + trailingSlash: "never" }); \ No newline at end of file diff --git a/package-lock.json b/package-lock.json index da077d8..d2af1b8 100644 --- a/package-lock.json +++ b/package-lock.json @@ -1,173 +1,234 @@ { - "name": "fgo-ta_com-website", - "version": "0.0.1", + "name": "fgo-ta-com-website", + "version": "0.2.2-pre.18", "lockfileVersion": 3, "requires": true, "packages": { "": { - "version": "0.0.1", + "name": "fgo-ta-com-website", + "version": "0.2.2-pre.18", "dependencies": { - "@astrojs/sitemap": "^1.4.0", - "astro": "^2.8.3" + "@astro-community/astro-embed-youtube": "^0.5.2", + "@astrojs/check": "^0.9.3", + "@astrojs/sitemap": "^3.1.6", + "@fontsource/work-sans": "^5.0.18", + "astro": "^4.14.3", + "astro-meta-tags": "^0.3.0", + "autoprefixer": "^10.4.19", + "iconoir": "^7.7.0", + "postcss-preset-env": "^9.6.0", + "typescript": "^5.5.3" + }, + "devDependencies": { + "prettier": "^3.1.1", + "prettier-plugin-astro": "^0.12.3" } }, "node_modules/@ampproject/remapping": { - "version": "2.2.1", - "resolved": "https://registry.npmjs.org/@ampproject/remapping/-/remapping-2.2.1.tgz", - "integrity": "sha512-lFMjJTrFL3j7L9yBxwYfCq2k6qqwHyzuUl/XBnif78PWTJYyL/dfowQHWE3sp6U6ZzqWiiIZnpTMO96zhkjwtg==", + "version": "2.3.0", + "resolved": "https://registry.npmjs.org/@ampproject/remapping/-/remapping-2.3.0.tgz", + "integrity": "sha512-30iZtAPgz+LTIYoeivqYo853f02jBYSd5uGnGpkFV0M3xOt9aN73erkgYAmZU43x4VfqcnLxW9Kpg3R5LC4YYw==", "dependencies": { - "@jridgewell/gen-mapping": "^0.3.0", - "@jridgewell/trace-mapping": "^0.3.9" + "@jridgewell/gen-mapping": "^0.3.5", + "@jridgewell/trace-mapping": "^0.3.24" }, "engines": { "node": ">=6.0.0" } }, + "node_modules/@astro-community/astro-embed-youtube": { + "version": "0.5.2", + "resolved": "https://registry.npmjs.org/@astro-community/astro-embed-youtube/-/astro-embed-youtube-0.5.2.tgz", + "integrity": "sha512-cckWcq7mFCmI6uPpIlRolSafSQRYZBOaxIc8DaCUh8+JQAtPF7O4EdpRpZBUcvbARrWEEyHJCWrt0XOGppMniw==", + "dependencies": { + "lite-youtube-embed": "^0.3.2" + }, + "peerDependencies": { + "astro": "^2.0.0 || ^3.0.0-beta || ^4.0.0-beta" + } + }, + "node_modules/@astrojs/check": { + "version": "0.9.3", + "resolved": "https://registry.npmjs.org/@astrojs/check/-/check-0.9.3.tgz", + "integrity": "sha512-I6Dz45bMI5YRbp4yK2LKWsHH3/kkHRGdPGruGkLap6pqxhdcNh7oCgN04Ac+haDfc9ow5BYPGPmEhkwef15GQQ==", + "license": "MIT", + "dependencies": { + "@astrojs/language-server": "^2.14.1", + "chokidar": "^3.5.3", + "fast-glob": "^3.3.1", + "kleur": "^4.1.5", + "yargs": "^17.7.2" + }, + "bin": { + "astro-check": "dist/bin.js" + }, + "peerDependencies": { + "typescript": "^5.0.0" + } + }, "node_modules/@astrojs/compiler": { - "version": "1.5.7", - "resolved": "https://registry.npmjs.org/@astrojs/compiler/-/compiler-1.5.7.tgz", - "integrity": "sha512-dFU7GAMbpTUGPkRoCoMQrGFlTe3qIiQMSOxIXp/nB1Do4My9uogjEmBHdR5Cwr4i6rc5/1R3Od9v8kU/pkHXGQ==" + "version": "2.10.3", + "resolved": "https://registry.npmjs.org/@astrojs/compiler/-/compiler-2.10.3.tgz", + "integrity": "sha512-bL/O7YBxsFt55YHU021oL+xz+B/9HvGNId3F9xURN16aeqDK9juHGktdkCSXz+U4nqFACq6ZFvWomOzhV+zfPw==" }, "node_modules/@astrojs/internal-helpers": { - "version": "0.1.1", - "resolved": "https://registry.npmjs.org/@astrojs/internal-helpers/-/internal-helpers-0.1.1.tgz", - "integrity": "sha512-+LySbvFbjv2nO2m/e78suleQOGEru4Cnx73VsZbrQgB2u7A4ddsQg3P2T0zC0e10jgcT+c6nNlKeLpa6nRhQIg==" + "version": "0.4.1", + "resolved": "https://registry.npmjs.org/@astrojs/internal-helpers/-/internal-helpers-0.4.1.tgz", + "integrity": "sha512-bMf9jFihO8YP940uD70SI/RDzIhUHJAolWVcO1v5PUivxGKvfLZTLTVVxEYzGYyPsA3ivdLNqMnL5VgmQySa+g==" }, "node_modules/@astrojs/language-server": { - "version": "1.0.8", - "resolved": "https://registry.npmjs.org/@astrojs/language-server/-/language-server-1.0.8.tgz", - "integrity": "sha512-gssRxLGb8XnvKpqSzrDW5jdzdFnXD7eBXVkPCkkt2hv7Qzb+SAzv6hVgMok3jDCxpR1aeB+XNd9Qszj2h29iog==", + "version": "2.14.1", + "resolved": "https://registry.npmjs.org/@astrojs/language-server/-/language-server-2.14.1.tgz", + "integrity": "sha512-mkKtCTPRD4dyKdAqIP0zmmPyO/ZABOqFESnaVca47Dg/sAagJnDSEsDUDzNbHFh1+9Dj1o5y4iwNsxJboGdaNg==", + "license": "MIT", "dependencies": { - "@astrojs/compiler": "^1.4.2", - "@jridgewell/trace-mapping": "^0.3.14", - "@vscode/emmet-helper": "^2.8.4", - "events": "^3.3.0", - "prettier": "^2.8.8", - "prettier-plugin-astro": "^0.9.1", - "vscode-css-languageservice": "^6.2.1", - "vscode-html-languageservice": "^5.0.0", - "vscode-languageserver": "^8.0.1", - "vscode-languageserver-protocol": "^3.17.1", - "vscode-languageserver-textdocument": "^1.0.4", - "vscode-languageserver-types": "^3.17.1", - "vscode-uri": "^3.0.3" + "@astrojs/compiler": "^2.10.3", + "@astrojs/yaml2ts": "^0.2.1", + "@jridgewell/sourcemap-codec": "^1.4.15", + "@volar/kit": "~2.4.0", + "@volar/language-core": "~2.4.0", + "@volar/language-server": "~2.4.0", + "@volar/language-service": "~2.4.0", + "@volar/typescript": "~2.4.0", + "fast-glob": "^3.2.12", + "muggle-string": "^0.4.1", + "volar-service-css": "0.0.61", + "volar-service-emmet": "0.0.61", + "volar-service-html": "0.0.61", + "volar-service-prettier": "0.0.61", + "volar-service-typescript": "0.0.61", + "volar-service-typescript-twoslash-queries": "0.0.61", + "volar-service-yaml": "0.0.61", + "vscode-html-languageservice": "^5.2.0", + "vscode-uri": "^3.0.8" }, "bin": { "astro-ls": "bin/nodeServer.js" + }, + "peerDependencies": { + "prettier": "^3.0.0", + "prettier-plugin-astro": ">=0.11.0" + }, + "peerDependenciesMeta": { + "prettier": { + "optional": true + }, + "prettier-plugin-astro": { + "optional": true + } } }, "node_modules/@astrojs/markdown-remark": { - "version": "2.2.1", - "resolved": "https://registry.npmjs.org/@astrojs/markdown-remark/-/markdown-remark-2.2.1.tgz", - "integrity": "sha512-VF0HRv4GpC1XEMLnsKf6jth7JSmlt9qpqP0josQgA2eSpCIAC/Et+y94mgdBIZVBYH/yFnMoIxgKVe93xfO2GA==", + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/@astrojs/markdown-remark/-/markdown-remark-5.2.0.tgz", + "integrity": "sha512-vWGM24KZXz11jR3JO+oqYU3T2qpuOi4uGivJ9SQLCAI01+vEkHC60YJMRvHPc+hwd60F7euNs1PeOEixIIiNQw==", "dependencies": { - "@astrojs/prism": "^2.1.2", - "github-slugger": "^1.4.0", - "import-meta-resolve": "^2.1.0", - "rehype-raw": "^6.1.1", - "rehype-stringify": "^9.0.3", - "remark-gfm": "^3.0.1", - "remark-parse": "^10.0.1", - "remark-rehype": "^10.1.0", - "remark-smartypants": "^2.0.0", - "shiki": "^0.14.1", - "unified": "^10.1.2", - "unist-util-visit": "^4.1.0", - "vfile": "^5.3.2" - }, - "peerDependencies": { - "astro": "^2.5.0" + "@astrojs/prism": "3.1.0", + "github-slugger": "^2.0.0", + "hast-util-from-html": "^2.0.1", + "hast-util-to-text": "^4.0.2", + "import-meta-resolve": "^4.1.0", + "mdast-util-definitions": "^6.0.0", + "rehype-raw": "^7.0.0", + "rehype-stringify": "^10.0.0", + "remark-gfm": "^4.0.0", + "remark-parse": "^11.0.0", + "remark-rehype": "^11.1.0", + "remark-smartypants": "^3.0.2", + "shiki": "^1.10.3", + "unified": "^11.0.5", + "unist-util-remove-position": "^5.0.0", + "unist-util-visit": "^5.0.0", + "unist-util-visit-parents": "^6.0.1", + "vfile": "^6.0.2" } }, - "node_modules/@astrojs/markdown-remark/node_modules/github-slugger": { - "version": "1.5.0", - "resolved": "https://registry.npmjs.org/github-slugger/-/github-slugger-1.5.0.tgz", - "integrity": "sha512-wIh+gKBI9Nshz2o46B0B3f5k/W+WI9ZAv6y5Dn5WJ5SK1t0TnDimB4WE5rmTD05ZAIn8HALCZVmCsvj0w0v0lw==" - }, "node_modules/@astrojs/prism": { - "version": "2.1.2", - "resolved": "https://registry.npmjs.org/@astrojs/prism/-/prism-2.1.2.tgz", - "integrity": "sha512-3antim1gb34689GHRQFJ88JEo93HuZKQBnmxDT5W/nxiNz1p/iRxnCTEhIbJhqMOTRbbo5h2ldm5qSxx+TMFQA==", + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/@astrojs/prism/-/prism-3.1.0.tgz", + "integrity": "sha512-Z9IYjuXSArkAUx3N6xj6+Bnvx8OdUSHA8YoOgyepp3+zJmtVYJIl/I18GozdJVW1p5u/CNpl3Km7/gwTJK85cw==", "dependencies": { - "prismjs": "^1.28.0" + "prismjs": "^1.29.0" }, "engines": { - "node": ">=16.12.0" + "node": "^18.17.1 || ^20.3.0 || >=21.0.0" } }, "node_modules/@astrojs/sitemap": { - "version": "1.4.0", - "resolved": "https://registry.npmjs.org/@astrojs/sitemap/-/sitemap-1.4.0.tgz", - "integrity": "sha512-uTK77kcg7iTiik+u7rTGG6vK4ZWTfYMaVnFndOVQrLzaE5xivmQgIbVLtlN+xRcME5n/m6vYQFJmogFR+elGCw==", + "version": "3.1.6", + "resolved": "https://registry.npmjs.org/@astrojs/sitemap/-/sitemap-3.1.6.tgz", + "integrity": "sha512-1Qp2NvAzVImqA6y+LubKi1DVhve/hXXgFvB0szxiipzh7BvtuKe4oJJ9dXSqaubaTkt4nMa6dv6RCCAYeB6xaQ==", "dependencies": { - "sitemap": "^7.1.1", - "zod": "^3.17.3" + "sitemap": "^7.1.2", + "stream-replace-string": "^2.0.0", + "zod": "^3.23.8" } }, "node_modules/@astrojs/telemetry": { - "version": "2.1.1", - "resolved": "https://registry.npmjs.org/@astrojs/telemetry/-/telemetry-2.1.1.tgz", - "integrity": "sha512-4pRhyeQr0MLB5PKYgkdu+YE8sSpMbHL8dUuslBWBIdgcYjtD1SufPMBI8pgXJ+xlwrQJHKKfK2X1KonHYuOS9A==", + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/@astrojs/telemetry/-/telemetry-3.1.0.tgz", + "integrity": "sha512-/ca/+D8MIKEC8/A9cSaPUqQNZm+Es/ZinRv0ZAzvu2ios7POQSsVD+VOj7/hypWNsNM3T7RpfgNq7H2TU1KEHA==", "dependencies": { - "ci-info": "^3.3.1", + "ci-info": "^4.0.0", "debug": "^4.3.4", "dlv": "^1.1.3", - "dset": "^3.1.2", + "dset": "^3.1.3", "is-docker": "^3.0.0", - "is-wsl": "^2.2.0", - "undici": "^5.22.0", + "is-wsl": "^3.0.0", "which-pm-runs": "^1.1.0" }, "engines": { - "node": ">=16.12.0" + "node": "^18.17.1 || ^20.3.0 || >=21.0.0" } }, - "node_modules/@astrojs/webapi": { - "version": "2.2.0", - "resolved": "https://registry.npmjs.org/@astrojs/webapi/-/webapi-2.2.0.tgz", - "integrity": "sha512-mHAOApWyjqSe5AQMOUD9rsZJqbMQqe3Wosb1a40JV6Okvyxj1G6GTlthwYadWCymq/lbgwh0PLiY8Fr4eFxtuQ==", + "node_modules/@astrojs/yaml2ts": { + "version": "0.2.1", + "resolved": "https://registry.npmjs.org/@astrojs/yaml2ts/-/yaml2ts-0.2.1.tgz", + "integrity": "sha512-CBaNwDQJz20E5WxzQh4thLVfhB3JEEGz72wRA+oJp6fQR37QLAqXZJU0mHC+yqMOQ6oj0GfRPJrz6hjf+zm6zA==", + "license": "MIT", "dependencies": { - "undici": "^5.22.0" + "yaml": "^2.5.0" } }, "node_modules/@babel/code-frame": { - "version": "7.22.5", - "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.22.5.tgz", - "integrity": "sha512-Xmwn266vad+6DAqEB2A6V/CcZVp62BbwVmcOJc2RPuwih1kw02TjQvWVWlcKGbBPd+8/0V5DEkOcizRGYsspYQ==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.24.7.tgz", + "integrity": "sha512-BcYH1CVJBO9tvyIZ2jVeXgSIMvGZ2FDRvDdOIVQyuklNKSsx+eppDEBq/g47Ayw+RqNFE+URvOShmf+f/qwAlA==", "dependencies": { - "@babel/highlight": "^7.22.5" + "@babel/highlight": "^7.24.7", + "picocolors": "^1.0.0" }, "engines": { "node": ">=6.9.0" } }, "node_modules/@babel/compat-data": { - "version": "7.22.9", - "resolved": "https://registry.npmjs.org/@babel/compat-data/-/compat-data-7.22.9.tgz", - "integrity": "sha512-5UamI7xkUcJ3i9qVDS+KFDEK8/7oJ55/sJMB1Ge7IEapr7KfdfV/HErR+koZwOfd+SgtFKOKRhRakdg++DcJpQ==", + "version": "7.25.2", + "resolved": "https://registry.npmjs.org/@babel/compat-data/-/compat-data-7.25.2.tgz", + "integrity": "sha512-bYcppcpKBvX4znYaPEeFau03bp89ShqNMLs+rmdptMw+heSZh9+z84d2YG+K7cYLbWwzdjtDoW/uqZmPjulClQ==", "engines": { "node": ">=6.9.0" } }, "node_modules/@babel/core": { - "version": "7.22.9", - "resolved": "https://registry.npmjs.org/@babel/core/-/core-7.22.9.tgz", - "integrity": "sha512-G2EgeufBcYw27U4hhoIwFcgc1XU7TlXJ3mv04oOv1WCuo900U/anZSPzEqNjwdjgffkk2Gs0AN0dW1CKVLcG7w==", + "version": "7.25.2", + "resolved": "https://registry.npmjs.org/@babel/core/-/core-7.25.2.tgz", + "integrity": "sha512-BBt3opiCOxUr9euZ5/ro/Xv8/V7yJ5bjYMqG/C1YAo8MIKAnumZalCN+msbci3Pigy4lIQfPUpfMM27HMGaYEA==", "dependencies": { "@ampproject/remapping": "^2.2.0", - "@babel/code-frame": "^7.22.5", - "@babel/generator": "^7.22.9", - "@babel/helper-compilation-targets": "^7.22.9", - "@babel/helper-module-transforms": "^7.22.9", - "@babel/helpers": "^7.22.6", - "@babel/parser": "^7.22.7", - "@babel/template": "^7.22.5", - "@babel/traverse": "^7.22.8", - "@babel/types": "^7.22.5", - "convert-source-map": "^1.7.0", + "@babel/code-frame": "^7.24.7", + "@babel/generator": "^7.25.0", + "@babel/helper-compilation-targets": "^7.25.2", + "@babel/helper-module-transforms": "^7.25.2", + "@babel/helpers": "^7.25.0", + "@babel/parser": "^7.25.0", + "@babel/template": "^7.25.0", + "@babel/traverse": "^7.25.2", + "@babel/types": "^7.25.2", + "convert-source-map": "^2.0.0", "debug": "^4.1.0", "gensync": "^1.0.0-beta.2", - "json5": "^2.2.2", + "json5": "^2.2.3", "semver": "^6.3.1" }, "engines": { @@ -187,13 +248,13 @@ } }, "node_modules/@babel/generator": { - "version": "7.22.9", - "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.22.9.tgz", - "integrity": "sha512-KtLMbmicyuK2Ak/FTCJVbDnkN1SlT8/kceFTiuDiiRUUSMnHMidxSCdG4ndkTOHHpoomWe/4xkvHkEOncwjYIw==", + "version": "7.25.0", + "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.25.0.tgz", + "integrity": "sha512-3LEEcj3PVW8pW2R1SR1M89g/qrYk/m/mB/tLqn7dn4sbBUQyTqnlod+II2U4dqiGtUmkcnAmkMDralTFZttRiw==", "dependencies": { - "@babel/types": "^7.22.5", - "@jridgewell/gen-mapping": "^0.3.2", - "@jridgewell/trace-mapping": "^0.3.17", + "@babel/types": "^7.25.0", + "@jridgewell/gen-mapping": "^0.3.5", + "@jridgewell/trace-mapping": "^0.3.25", "jsesc": "^2.5.1" }, "engines": { @@ -201,32 +262,29 @@ } }, "node_modules/@babel/helper-annotate-as-pure": { - "version": "7.22.5", - "resolved": "https://registry.npmjs.org/@babel/helper-annotate-as-pure/-/helper-annotate-as-pure-7.22.5.tgz", - "integrity": "sha512-LvBTxu8bQSQkcyKOU+a1btnNFQ1dMAd0R6PyW3arXes06F6QLWLIrd681bxRPIXlrMGR3XYnW9JyML7dP3qgxg==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/helper-annotate-as-pure/-/helper-annotate-as-pure-7.24.7.tgz", + "integrity": "sha512-BaDeOonYvhdKw+JoMVkAixAAJzG2jVPIwWoKBPdYuY9b452e2rPuI9QPYh3KpofZ3pW2akOmwZLOiOsHMiqRAg==", "dependencies": { - "@babel/types": "^7.22.5" + "@babel/types": "^7.24.7" }, "engines": { "node": ">=6.9.0" } }, "node_modules/@babel/helper-compilation-targets": { - "version": "7.22.9", - "resolved": "https://registry.npmjs.org/@babel/helper-compilation-targets/-/helper-compilation-targets-7.22.9.tgz", - "integrity": "sha512-7qYrNM6HjpnPHJbopxmb8hSPoZ0gsX8IvUS32JGVoy+pU9e5N0nLr1VjJoR6kA4d9dmGLxNYOjeB8sUDal2WMw==", + "version": "7.25.2", + "resolved": "https://registry.npmjs.org/@babel/helper-compilation-targets/-/helper-compilation-targets-7.25.2.tgz", + "integrity": "sha512-U2U5LsSaZ7TAt3cfaymQ8WHh0pxvdHoEk6HVpaexxixjyEquMh0L0YNJNM6CTGKMXV1iksi0iZkGw4AcFkPaaw==", "dependencies": { - "@babel/compat-data": "^7.22.9", - "@babel/helper-validator-option": "^7.22.5", - "browserslist": "^4.21.9", + "@babel/compat-data": "^7.25.2", + "@babel/helper-validator-option": "^7.24.8", + "browserslist": "^4.23.1", "lru-cache": "^5.1.1", "semver": "^6.3.1" }, "engines": { "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0" } }, "node_modules/@babel/helper-compilation-targets/node_modules/semver": { @@ -237,58 +295,27 @@ "semver": "bin/semver.js" } }, - "node_modules/@babel/helper-environment-visitor": { - "version": "7.22.5", - "resolved": "https://registry.npmjs.org/@babel/helper-environment-visitor/-/helper-environment-visitor-7.22.5.tgz", - "integrity": "sha512-XGmhECfVA/5sAt+H+xpSg0mfrHq6FzNr9Oxh7PSEBBRUb/mL7Kz3NICXb194rCqAEdxkhPT1a88teizAFyvk8Q==", - "engines": { - "node": ">=6.9.0" - } - }, - "node_modules/@babel/helper-function-name": { - "version": "7.22.5", - "resolved": "https://registry.npmjs.org/@babel/helper-function-name/-/helper-function-name-7.22.5.tgz", - "integrity": "sha512-wtHSq6jMRE3uF2otvfuD3DIvVhOsSNshQl0Qrd7qC9oQJzHvOL4qQXlQn2916+CXGywIjpGuIkoyZRRxHPiNQQ==", - "dependencies": { - "@babel/template": "^7.22.5", - "@babel/types": "^7.22.5" - }, - "engines": { - "node": ">=6.9.0" - } - }, - "node_modules/@babel/helper-hoist-variables": { - "version": "7.22.5", - "resolved": "https://registry.npmjs.org/@babel/helper-hoist-variables/-/helper-hoist-variables-7.22.5.tgz", - "integrity": "sha512-wGjk9QZVzvknA6yKIUURb8zY3grXCcOZt+/7Wcy8O2uctxhplmUPkOdlgoNhmdVee2c92JXbf1xpMtVNbfoxRw==", - "dependencies": { - "@babel/types": "^7.22.5" - }, - "engines": { - "node": ">=6.9.0" - } - }, "node_modules/@babel/helper-module-imports": { - "version": "7.22.5", - "resolved": "https://registry.npmjs.org/@babel/helper-module-imports/-/helper-module-imports-7.22.5.tgz", - "integrity": "sha512-8Dl6+HD/cKifutF5qGd/8ZJi84QeAKh+CEe1sBzz8UayBBGg1dAIJrdHOcOM5b2MpzWL2yuotJTtGjETq0qjXg==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/helper-module-imports/-/helper-module-imports-7.24.7.tgz", + "integrity": "sha512-8AyH3C+74cgCVVXow/myrynrAGv+nTVg5vKu2nZph9x7RcRwzmh0VFallJuFTZ9mx6u4eSdXZfcOzSqTUm0HCA==", "dependencies": { - "@babel/types": "^7.22.5" + "@babel/traverse": "^7.24.7", + "@babel/types": "^7.24.7" }, "engines": { "node": ">=6.9.0" } }, "node_modules/@babel/helper-module-transforms": { - "version": "7.22.9", - "resolved": "https://registry.npmjs.org/@babel/helper-module-transforms/-/helper-module-transforms-7.22.9.tgz", - "integrity": "sha512-t+WA2Xn5K+rTeGtC8jCsdAH52bjggG5TKRuRrAGNM/mjIbO4GxvlLMFOEz9wXY5I2XQ60PMFsAG2WIcG82dQMQ==", + "version": "7.25.2", + "resolved": "https://registry.npmjs.org/@babel/helper-module-transforms/-/helper-module-transforms-7.25.2.tgz", + "integrity": "sha512-BjyRAbix6j/wv83ftcVJmBt72QtHI56C7JXZoG2xATiLpmoC7dpd8WnkikExHDVPpi/3qCmO6WY1EaXOluiecQ==", "dependencies": { - "@babel/helper-environment-visitor": "^7.22.5", - "@babel/helper-module-imports": "^7.22.5", - "@babel/helper-simple-access": "^7.22.5", - "@babel/helper-split-export-declaration": "^7.22.6", - "@babel/helper-validator-identifier": "^7.22.5" + "@babel/helper-module-imports": "^7.24.7", + "@babel/helper-simple-access": "^7.24.7", + "@babel/helper-validator-identifier": "^7.24.7", + "@babel/traverse": "^7.25.2" }, "engines": { "node": ">=6.9.0" @@ -298,89 +325,82 @@ } }, "node_modules/@babel/helper-plugin-utils": { - "version": "7.22.5", - "resolved": "https://registry.npmjs.org/@babel/helper-plugin-utils/-/helper-plugin-utils-7.22.5.tgz", - "integrity": "sha512-uLls06UVKgFG9QD4OeFYLEGteMIAa5kpTPcFL28yuCIIzsf6ZyKZMllKVOCZFhiZ5ptnwX4mtKdWCBE/uT4amg==", + "version": "7.24.8", + "resolved": "https://registry.npmjs.org/@babel/helper-plugin-utils/-/helper-plugin-utils-7.24.8.tgz", + "integrity": "sha512-FFWx5142D8h2Mgr/iPVGH5G7w6jDn4jUSpZTyDnQO0Yn7Ks2Kuz6Pci8H6MPCoUJegd/UZQ3tAvfLCxQSnWWwg==", "engines": { "node": ">=6.9.0" } }, "node_modules/@babel/helper-simple-access": { - "version": "7.22.5", - "resolved": "https://registry.npmjs.org/@babel/helper-simple-access/-/helper-simple-access-7.22.5.tgz", - "integrity": "sha512-n0H99E/K+Bika3++WNL17POvo4rKWZ7lZEp1Q+fStVbUi8nxPQEBOlTmCOxW/0JsS56SKKQ+ojAe2pHKJHN35w==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/helper-simple-access/-/helper-simple-access-7.24.7.tgz", + "integrity": "sha512-zBAIvbCMh5Ts+b86r/CjU+4XGYIs+R1j951gxI3KmmxBMhCg4oQMsv6ZXQ64XOm/cvzfU1FmoCyt6+owc5QMYg==", "dependencies": { - "@babel/types": "^7.22.5" - }, - "engines": { - "node": ">=6.9.0" - } - }, - "node_modules/@babel/helper-split-export-declaration": { - "version": "7.22.6", - "resolved": "https://registry.npmjs.org/@babel/helper-split-export-declaration/-/helper-split-export-declaration-7.22.6.tgz", - "integrity": "sha512-AsUnxuLhRYsisFiaJwvp1QF+I3KjD5FOxut14q/GzovUe6orHLesW2C7d754kRm53h5gqrz6sFl6sxc4BVtE/g==", - "dependencies": { - "@babel/types": "^7.22.5" + "@babel/traverse": "^7.24.7", + "@babel/types": "^7.24.7" }, "engines": { "node": ">=6.9.0" } }, "node_modules/@babel/helper-string-parser": { - "version": "7.22.5", - "resolved": "https://registry.npmjs.org/@babel/helper-string-parser/-/helper-string-parser-7.22.5.tgz", - "integrity": "sha512-mM4COjgZox8U+JcXQwPijIZLElkgEpO5rsERVDJTc2qfCDfERyob6k5WegS14SX18IIjv+XD+GrqNumY5JRCDw==", + "version": "7.24.8", + "resolved": "https://registry.npmjs.org/@babel/helper-string-parser/-/helper-string-parser-7.24.8.tgz", + "integrity": "sha512-pO9KhhRcuUyGnJWwyEgnRJTSIZHiT+vMD0kPeD+so0l7mxkMT19g3pjY9GTnHySck/hDzq+dtW/4VgnMkippsQ==", "engines": { "node": ">=6.9.0" } }, "node_modules/@babel/helper-validator-identifier": { - "version": "7.22.5", - "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.22.5.tgz", - "integrity": "sha512-aJXu+6lErq8ltp+JhkJUfk1MTGyuA4v7f3pA+BJ5HLfNC6nAQ0Cpi9uOquUj8Hehg0aUiHzWQbOVJGao6ztBAQ==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.24.7.tgz", + "integrity": "sha512-rR+PBcQ1SMQDDyF6X0wxtG8QyLCgUB0eRAGguqRLfkCA87l7yAP7ehq8SNj96OOGTO8OBV70KhuFYcIkHXOg0w==", "engines": { "node": ">=6.9.0" } }, "node_modules/@babel/helper-validator-option": { - "version": "7.22.5", - "resolved": "https://registry.npmjs.org/@babel/helper-validator-option/-/helper-validator-option-7.22.5.tgz", - "integrity": "sha512-R3oB6xlIVKUnxNUxbmgq7pKjxpru24zlimpE8WK47fACIlM0II/Hm1RS8IaOI7NgCr6LNS+jl5l75m20npAziw==", + "version": "7.24.8", + "resolved": "https://registry.npmjs.org/@babel/helper-validator-option/-/helper-validator-option-7.24.8.tgz", + "integrity": "sha512-xb8t9tD1MHLungh/AIoWYN+gVHaB9kwlu8gffXGSt3FFEIT7RjS+xWbc2vUD1UTZdIpKj/ab3rdqJ7ufngyi2Q==", "engines": { "node": ">=6.9.0" } }, "node_modules/@babel/helpers": { - "version": "7.22.6", - "resolved": "https://registry.npmjs.org/@babel/helpers/-/helpers-7.22.6.tgz", - "integrity": "sha512-YjDs6y/fVOYFV8hAf1rxd1QvR9wJe1pDBZ2AREKq/SDayfPzgk0PBnVuTCE5X1acEpMMNOVUqoe+OwiZGJ+OaA==", + "version": "7.25.0", + "resolved": "https://registry.npmjs.org/@babel/helpers/-/helpers-7.25.0.tgz", + "integrity": "sha512-MjgLZ42aCm0oGjJj8CtSM3DB8NOOf8h2l7DCTePJs29u+v7yO/RBX9nShlKMgFnRks/Q4tBAe7Hxnov9VkGwLw==", "dependencies": { - "@babel/template": "^7.22.5", - "@babel/traverse": "^7.22.6", - "@babel/types": "^7.22.5" + "@babel/template": "^7.25.0", + "@babel/types": "^7.25.0" }, "engines": { "node": ">=6.9.0" } }, "node_modules/@babel/highlight": { - "version": "7.22.5", - "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.22.5.tgz", - "integrity": "sha512-BSKlD1hgnedS5XRnGOljZawtag7H1yPfQp0tdNJCHoH6AZ+Pcm9VvkrK59/Yy593Ypg0zMxH2BxD1VPYUQ7UIw==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.24.7.tgz", + "integrity": "sha512-EStJpq4OuY8xYfhGVXngigBJRWxftKX9ksiGDnmlY3o7B/V7KIAc9X4oiK87uPJSc/vs5L869bem5fhZa8caZw==", "dependencies": { - "@babel/helper-validator-identifier": "^7.22.5", - "chalk": "^2.0.0", - "js-tokens": "^4.0.0" + "@babel/helper-validator-identifier": "^7.24.7", + "chalk": "^2.4.2", + "js-tokens": "^4.0.0", + "picocolors": "^1.0.0" }, "engines": { "node": ">=6.9.0" } }, "node_modules/@babel/parser": { - "version": "7.22.7", - "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.22.7.tgz", - "integrity": "sha512-7NF8pOkHP5o2vpmGgNGcfAeCvOYhGLyA3Z4eBQkT1RJlWu47n63bCs93QfJ2hIAFCil7L5P2IWhs1oToVgrL0Q==", + "version": "7.25.3", + "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.25.3.tgz", + "integrity": "sha512-iLTJKDbJ4hMvFPgQwwsVoxtHyWpKKPBrxkANrSYewDPaPpT5py5yeVkgPIJ7XYXhndxJpaA3PyALSXQ7u8e/Dw==", + "dependencies": { + "@babel/types": "^7.25.2" + }, "bin": { "parser": "bin/babel-parser.js" }, @@ -389,11 +409,11 @@ } }, "node_modules/@babel/plugin-syntax-jsx": { - "version": "7.22.5", - "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-jsx/-/plugin-syntax-jsx-7.22.5.tgz", - "integrity": "sha512-gvyP4hZrgrs/wWMaocvxZ44Hw0b3W8Pe+cMxc8V1ULQ07oh8VNbIRaoD1LRZVTvD+0nieDKjfgKg89sD7rrKrg==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-jsx/-/plugin-syntax-jsx-7.24.7.tgz", + "integrity": "sha512-6ddciUPe/mpMnOKv/U+RSd2vvVy+Yw/JfBB0ZHYjEZt9NLHmCUylNYlsbqCCS1Bffjlb0fCwC9Vqz+sBz6PsiQ==", "dependencies": { - "@babel/helper-plugin-utils": "^7.22.5" + "@babel/helper-plugin-utils": "^7.24.7" }, "engines": { "node": ">=6.9.0" @@ -403,15 +423,15 @@ } }, "node_modules/@babel/plugin-transform-react-jsx": { - "version": "7.22.5", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-react-jsx/-/plugin-transform-react-jsx-7.22.5.tgz", - "integrity": "sha512-rog5gZaVbUip5iWDMTYbVM15XQq+RkUKhET/IHR6oizR+JEoN6CAfTTuHcK4vwUyzca30qqHqEpzBOnaRMWYMA==", + "version": "7.25.2", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-react-jsx/-/plugin-transform-react-jsx-7.25.2.tgz", + "integrity": "sha512-KQsqEAVBpU82NM/B/N9j9WOdphom1SZH3R+2V7INrQUH+V9EBFwZsEJl8eBIVeQE62FxJCc70jzEZwqU7RcVqA==", "dependencies": { - "@babel/helper-annotate-as-pure": "^7.22.5", - "@babel/helper-module-imports": "^7.22.5", - "@babel/helper-plugin-utils": "^7.22.5", - "@babel/plugin-syntax-jsx": "^7.22.5", - "@babel/types": "^7.22.5" + "@babel/helper-annotate-as-pure": "^7.24.7", + "@babel/helper-module-imports": "^7.24.7", + "@babel/helper-plugin-utils": "^7.24.8", + "@babel/plugin-syntax-jsx": "^7.24.7", + "@babel/types": "^7.25.2" }, "engines": { "node": ">=6.9.0" @@ -421,32 +441,29 @@ } }, "node_modules/@babel/template": { - "version": "7.22.5", - "resolved": "https://registry.npmjs.org/@babel/template/-/template-7.22.5.tgz", - "integrity": "sha512-X7yV7eiwAxdj9k94NEylvbVHLiVG1nvzCV2EAowhxLTwODV1jl9UzZ48leOC0sH7OnuHrIkllaBgneUykIcZaw==", + "version": "7.25.0", + "resolved": "https://registry.npmjs.org/@babel/template/-/template-7.25.0.tgz", + "integrity": "sha512-aOOgh1/5XzKvg1jvVz7AVrx2piJ2XBi227DHmbY6y+bM9H2FlN+IfecYu4Xl0cNiiVejlsCri89LUsbj8vJD9Q==", "dependencies": { - "@babel/code-frame": "^7.22.5", - "@babel/parser": "^7.22.5", - "@babel/types": "^7.22.5" + "@babel/code-frame": "^7.24.7", + "@babel/parser": "^7.25.0", + "@babel/types": "^7.25.0" }, "engines": { "node": ">=6.9.0" } }, "node_modules/@babel/traverse": { - "version": "7.22.8", - "resolved": "https://registry.npmjs.org/@babel/traverse/-/traverse-7.22.8.tgz", - "integrity": "sha512-y6LPR+wpM2I3qJrsheCTwhIinzkETbplIgPBbwvqPKc+uljeA5gP+3nP8irdYt1mjQaDnlIcG+dw8OjAco4GXw==", + "version": "7.25.3", + "resolved": "https://registry.npmjs.org/@babel/traverse/-/traverse-7.25.3.tgz", + "integrity": "sha512-HefgyP1x754oGCsKmV5reSmtV7IXj/kpaE1XYY+D9G5PvKKoFfSbiS4M77MdjuwlZKDIKFCffq9rPU+H/s3ZdQ==", "dependencies": { - "@babel/code-frame": "^7.22.5", - "@babel/generator": "^7.22.7", - "@babel/helper-environment-visitor": "^7.22.5", - "@babel/helper-function-name": "^7.22.5", - "@babel/helper-hoist-variables": "^7.22.5", - "@babel/helper-split-export-declaration": "^7.22.6", - "@babel/parser": "^7.22.7", - "@babel/types": "^7.22.5", - "debug": "^4.1.0", + "@babel/code-frame": "^7.24.7", + "@babel/generator": "^7.25.0", + "@babel/parser": "^7.25.3", + "@babel/template": "^7.25.0", + "@babel/types": "^7.25.2", + "debug": "^4.3.1", "globals": "^11.1.0" }, "engines": { @@ -454,22 +471,991 @@ } }, "node_modules/@babel/types": { - "version": "7.22.5", - "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.22.5.tgz", - "integrity": "sha512-zo3MIHGOkPOfoRXitsgHLjEXmlDaD/5KU1Uzuc9GNiZPhSqVxVRtxuPaSBZDsYZ9qV88AjtMtWW7ww98loJ9KA==", + "version": "7.25.2", + "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.25.2.tgz", + "integrity": "sha512-YTnYtra7W9e6/oAZEHj0bJehPRUlLH9/fbpT5LfB0NhQXyALCRkRs3zH9v07IYhkgpqX6Z78FnuccZr/l4Fs4Q==", "dependencies": { - "@babel/helper-string-parser": "^7.22.5", - "@babel/helper-validator-identifier": "^7.22.5", + "@babel/helper-string-parser": "^7.24.8", + "@babel/helper-validator-identifier": "^7.24.7", "to-fast-properties": "^2.0.0" }, "engines": { "node": ">=6.9.0" } }, + "node_modules/@csstools/cascade-layer-name-parser": { + "version": "1.0.13", + "resolved": "https://registry.npmjs.org/@csstools/cascade-layer-name-parser/-/cascade-layer-name-parser-1.0.13.tgz", + "integrity": "sha512-MX0yLTwtZzr82sQ0zOjqimpZbzjMaK/h2pmlrLK7DCzlmiZLYFpoO94WmN1akRVo6ll/TdpHb53vihHLUMyvng==", + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/csstools" + }, + { + "type": "opencollective", + "url": "https://opencollective.com/csstools" + } + ], + "engines": { + "node": "^14 || ^16 || >=18" + }, + "peerDependencies": { + "@csstools/css-parser-algorithms": "^2.7.1", + "@csstools/css-tokenizer": "^2.4.1" + } + }, + "node_modules/@csstools/color-helpers": { + "version": "4.2.1", + "resolved": "https://registry.npmjs.org/@csstools/color-helpers/-/color-helpers-4.2.1.tgz", + "integrity": "sha512-CEypeeykO9AN7JWkr1OEOQb0HRzZlPWGwV0Ya6DuVgFdDi6g3ma/cPZ5ZPZM4AWQikDpq/0llnGGlIL+j8afzw==", + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/csstools" + }, + { + "type": "opencollective", + "url": "https://opencollective.com/csstools" + } + ], + "engines": { + "node": "^14 || ^16 || >=18" + } + }, + "node_modules/@csstools/css-calc": { + "version": "1.2.4", + "resolved": "https://registry.npmjs.org/@csstools/css-calc/-/css-calc-1.2.4.tgz", + "integrity": "sha512-tfOuvUQeo7Hz+FcuOd3LfXVp+342pnWUJ7D2y8NUpu1Ww6xnTbHLpz018/y6rtbHifJ3iIEf9ttxXd8KG7nL0Q==", + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/csstools" + }, + { + "type": "opencollective", + "url": "https://opencollective.com/csstools" + } + ], + "engines": { + "node": "^14 || ^16 || >=18" + }, + "peerDependencies": { + "@csstools/css-parser-algorithms": "^2.7.1", + "@csstools/css-tokenizer": "^2.4.1" + } + }, + "node_modules/@csstools/css-color-parser": { + "version": "2.0.5", + "resolved": "https://registry.npmjs.org/@csstools/css-color-parser/-/css-color-parser-2.0.5.tgz", + "integrity": "sha512-lRZSmtl+DSjok3u9hTWpmkxFZnz7stkbZxzKc08aDUsdrWwhSgWo8yq9rq9DaFUtbAyAq2xnH92fj01S+pwIww==", + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/csstools" + }, + { + "type": "opencollective", + "url": "https://opencollective.com/csstools" + } + ], + "dependencies": { + "@csstools/color-helpers": "^4.2.1", + "@csstools/css-calc": "^1.2.4" + }, + "engines": { + "node": "^14 || ^16 || >=18" + }, + "peerDependencies": { + "@csstools/css-parser-algorithms": "^2.7.1", + "@csstools/css-tokenizer": "^2.4.1" + } + }, + "node_modules/@csstools/css-parser-algorithms": { + "version": "2.7.1", + "resolved": "https://registry.npmjs.org/@csstools/css-parser-algorithms/-/css-parser-algorithms-2.7.1.tgz", + "integrity": "sha512-2SJS42gxmACHgikc1WGesXLIT8d/q2l0UFM7TaEeIzdFCE/FPMtTiizcPGGJtlPo2xuQzY09OhrLTzRxqJqwGw==", + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/csstools" + }, + { + "type": "opencollective", + "url": "https://opencollective.com/csstools" + } + ], + "engines": { + "node": "^14 || ^16 || >=18" + }, + "peerDependencies": { + "@csstools/css-tokenizer": "^2.4.1" + } + }, + "node_modules/@csstools/css-tokenizer": { + "version": "2.4.1", + "resolved": "https://registry.npmjs.org/@csstools/css-tokenizer/-/css-tokenizer-2.4.1.tgz", + "integrity": "sha512-eQ9DIktFJBhGjioABJRtUucoWR2mwllurfnM8LuNGAqX3ViZXaUchqk+1s7jjtkFiT9ySdACsFEA3etErkALUg==", + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/csstools" + }, + { + "type": "opencollective", + "url": "https://opencollective.com/csstools" + } + ], + "engines": { + "node": "^14 || ^16 || >=18" + } + }, + "node_modules/@csstools/media-query-list-parser": { + "version": "2.1.13", + "resolved": "https://registry.npmjs.org/@csstools/media-query-list-parser/-/media-query-list-parser-2.1.13.tgz", + "integrity": "sha512-XaHr+16KRU9Gf8XLi3q8kDlI18d5vzKSKCY510Vrtc9iNR0NJzbY9hhTmwhzYZj/ZwGL4VmB3TA9hJW0Um2qFA==", + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/csstools" + }, + { + "type": "opencollective", + "url": "https://opencollective.com/csstools" + } + ], + "engines": { + "node": "^14 || ^16 || >=18" + }, + "peerDependencies": { + "@csstools/css-parser-algorithms": "^2.7.1", + "@csstools/css-tokenizer": "^2.4.1" + } + }, + "node_modules/@csstools/postcss-cascade-layers": { + "version": "4.0.6", + "resolved": "https://registry.npmjs.org/@csstools/postcss-cascade-layers/-/postcss-cascade-layers-4.0.6.tgz", + "integrity": "sha512-Xt00qGAQyqAODFiFEJNkTpSUz5VfYqnDLECdlA/Vv17nl/OIV5QfTRHGAXrBGG5YcJyHpJ+GF9gF/RZvOQz4oA==", + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/csstools" + }, + { + "type": "opencollective", + "url": "https://opencollective.com/csstools" + } + ], + "dependencies": { + "@csstools/selector-specificity": "^3.1.1", + "postcss-selector-parser": "^6.0.13" + }, + "engines": { + "node": "^14 || ^16 || >=18" + }, + "peerDependencies": { + "postcss": "^8.4" + } + }, + "node_modules/@csstools/postcss-color-function": { + "version": "3.0.19", + "resolved": "https://registry.npmjs.org/@csstools/postcss-color-function/-/postcss-color-function-3.0.19.tgz", + "integrity": "sha512-d1OHEXyYGe21G3q88LezWWx31ImEDdmINNDy0LyLNN9ChgN2bPxoubUPiHf9KmwypBMaHmNcMuA/WZOKdZk/Lg==", + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/csstools" + }, + { + "type": "opencollective", + "url": "https://opencollective.com/csstools" + } + ], + "dependencies": { + "@csstools/css-color-parser": "^2.0.4", + "@csstools/css-parser-algorithms": "^2.7.1", + "@csstools/css-tokenizer": "^2.4.1", + "@csstools/postcss-progressive-custom-properties": "^3.3.0", + "@csstools/utilities": "^1.0.0" + }, + "engines": { + "node": "^14 || ^16 || >=18" + }, + "peerDependencies": { + "postcss": "^8.4" + } + }, + "node_modules/@csstools/postcss-color-mix-function": { + "version": "2.0.19", + "resolved": "https://registry.npmjs.org/@csstools/postcss-color-mix-function/-/postcss-color-mix-function-2.0.19.tgz", + "integrity": "sha512-mLvQlMX+keRYr16AuvuV8WYKUwF+D0DiCqlBdvhQ0KYEtcQl9/is9Ssg7RcIys8x0jIn2h1zstS4izckdZj9wg==", + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/csstools" + }, + { + "type": "opencollective", + "url": "https://opencollective.com/csstools" + } + ], + "dependencies": { + "@csstools/css-color-parser": "^2.0.4", + "@csstools/css-parser-algorithms": "^2.7.1", + "@csstools/css-tokenizer": "^2.4.1", + "@csstools/postcss-progressive-custom-properties": "^3.3.0", + "@csstools/utilities": "^1.0.0" + }, + "engines": { + "node": "^14 || ^16 || >=18" + }, + "peerDependencies": { + "postcss": "^8.4" + } + }, + "node_modules/@csstools/postcss-content-alt-text": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/@csstools/postcss-content-alt-text/-/postcss-content-alt-text-1.0.0.tgz", + "integrity": "sha512-SkHdj7EMM/57GVvSxSELpUg7zb5eAndBeuvGwFzYtU06/QXJ/h9fuK7wO5suteJzGhm3GDF/EWPCdWV2h1IGHQ==", + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/csstools" + }, + { + "type": "opencollective", + "url": "https://opencollective.com/csstools" + } + ], + "dependencies": { + "@csstools/css-parser-algorithms": "^2.7.1", + "@csstools/css-tokenizer": "^2.4.1", + "@csstools/postcss-progressive-custom-properties": "^3.3.0", + "@csstools/utilities": "^1.0.0" + }, + "engines": { + "node": "^14 || ^16 || >=18" + }, + "peerDependencies": { + "postcss": "^8.4" + } + }, + "node_modules/@csstools/postcss-exponential-functions": { + "version": "1.0.9", + "resolved": "https://registry.npmjs.org/@csstools/postcss-exponential-functions/-/postcss-exponential-functions-1.0.9.tgz", + "integrity": "sha512-x1Avr15mMeuX7Z5RJUl7DmjhUtg+Amn5DZRD0fQ2TlTFTcJS8U1oxXQ9e5mA62S2RJgUU6db20CRoJyDvae2EQ==", + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/csstools" + }, + { + "type": "opencollective", + "url": "https://opencollective.com/csstools" + } + ], + "dependencies": { + "@csstools/css-calc": "^1.2.4", + "@csstools/css-parser-algorithms": "^2.7.1", + "@csstools/css-tokenizer": "^2.4.1" + }, + "engines": { + "node": "^14 || ^16 || >=18" + }, + "peerDependencies": { + "postcss": "^8.4" + } + }, + "node_modules/@csstools/postcss-font-format-keywords": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/@csstools/postcss-font-format-keywords/-/postcss-font-format-keywords-3.0.2.tgz", + "integrity": "sha512-E0xz2sjm4AMCkXLCFvI/lyl4XO6aN1NCSMMVEOngFDJ+k2rDwfr6NDjWljk1li42jiLNChVX+YFnmfGCigZKXw==", + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/csstools" + }, + { + "type": "opencollective", + "url": "https://opencollective.com/csstools" + } + ], + "dependencies": { + "@csstools/utilities": "^1.0.0", + "postcss-value-parser": "^4.2.0" + }, + "engines": { + "node": "^14 || ^16 || >=18" + }, + "peerDependencies": { + "postcss": "^8.4" + } + }, + "node_modules/@csstools/postcss-gamut-mapping": { + "version": "1.0.11", + "resolved": "https://registry.npmjs.org/@csstools/postcss-gamut-mapping/-/postcss-gamut-mapping-1.0.11.tgz", + "integrity": "sha512-KrHGsUPXRYxboXmJ9wiU/RzDM7y/5uIefLWKFSc36Pok7fxiPyvkSHO51kh+RLZS1W5hbqw9qaa6+tKpTSxa5g==", + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/csstools" + }, + { + "type": "opencollective", + "url": "https://opencollective.com/csstools" + } + ], + "dependencies": { + "@csstools/css-color-parser": "^2.0.4", + "@csstools/css-parser-algorithms": "^2.7.1", + "@csstools/css-tokenizer": "^2.4.1" + }, + "engines": { + "node": "^14 || ^16 || >=18" + }, + "peerDependencies": { + "postcss": "^8.4" + } + }, + "node_modules/@csstools/postcss-gradients-interpolation-method": { + "version": "4.0.20", + "resolved": "https://registry.npmjs.org/@csstools/postcss-gradients-interpolation-method/-/postcss-gradients-interpolation-method-4.0.20.tgz", + "integrity": "sha512-ZFl2JBHano6R20KB5ZrB8KdPM2pVK0u+/3cGQ2T8VubJq982I2LSOvQ4/VtxkAXjkPkk1rXt4AD1ni7UjTZ1Og==", + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/csstools" + }, + { + "type": "opencollective", + "url": "https://opencollective.com/csstools" + } + ], + "dependencies": { + "@csstools/css-color-parser": "^2.0.4", + "@csstools/css-parser-algorithms": "^2.7.1", + "@csstools/css-tokenizer": "^2.4.1", + "@csstools/postcss-progressive-custom-properties": "^3.3.0", + "@csstools/utilities": "^1.0.0" + }, + "engines": { + "node": "^14 || ^16 || >=18" + }, + "peerDependencies": { + "postcss": "^8.4" + } + }, + "node_modules/@csstools/postcss-hwb-function": { + "version": "3.0.18", + "resolved": "https://registry.npmjs.org/@csstools/postcss-hwb-function/-/postcss-hwb-function-3.0.18.tgz", + "integrity": "sha512-3ifnLltR5C7zrJ+g18caxkvSRnu9jBBXCYgnBznRjxm6gQJGnnCO9H6toHfywNdNr/qkiVf2dymERPQLDnjLRQ==", + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/csstools" + }, + { + "type": "opencollective", + "url": "https://opencollective.com/csstools" + } + ], + "dependencies": { + "@csstools/css-color-parser": "^2.0.4", + "@csstools/css-parser-algorithms": "^2.7.1", + "@csstools/css-tokenizer": "^2.4.1", + "@csstools/postcss-progressive-custom-properties": "^3.3.0", + "@csstools/utilities": "^1.0.0" + }, + "engines": { + "node": "^14 || ^16 || >=18" + }, + "peerDependencies": { + "postcss": "^8.4" + } + }, + "node_modules/@csstools/postcss-ic-unit": { + "version": "3.0.7", + "resolved": "https://registry.npmjs.org/@csstools/postcss-ic-unit/-/postcss-ic-unit-3.0.7.tgz", + "integrity": "sha512-YoaNHH2wNZD+c+rHV02l4xQuDpfR8MaL7hD45iJyr+USwvr0LOheeytJ6rq8FN6hXBmEeoJBeXXgGmM8fkhH4g==", + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/csstools" + }, + { + "type": "opencollective", + "url": "https://opencollective.com/csstools" + } + ], + "dependencies": { + "@csstools/postcss-progressive-custom-properties": "^3.3.0", + "@csstools/utilities": "^1.0.0", + "postcss-value-parser": "^4.2.0" + }, + "engines": { + "node": "^14 || ^16 || >=18" + }, + "peerDependencies": { + "postcss": "^8.4" + } + }, + "node_modules/@csstools/postcss-initial": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/@csstools/postcss-initial/-/postcss-initial-1.0.1.tgz", + "integrity": "sha512-wtb+IbUIrIf8CrN6MLQuFR7nlU5C7PwuebfeEXfjthUha1+XZj2RVi+5k/lukToA24sZkYAiSJfHM8uG/UZIdg==", + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/csstools" + }, + { + "type": "opencollective", + "url": "https://opencollective.com/csstools" + } + ], + "engines": { + "node": "^14 || ^16 || >=18" + }, + "peerDependencies": { + "postcss": "^8.4" + } + }, + "node_modules/@csstools/postcss-is-pseudo-class": { + "version": "4.0.8", + "resolved": "https://registry.npmjs.org/@csstools/postcss-is-pseudo-class/-/postcss-is-pseudo-class-4.0.8.tgz", + "integrity": "sha512-0aj591yGlq5Qac+plaWCbn5cpjs5Sh0daovYUKJUOMjIp70prGH/XPLp7QjxtbFXz3CTvb0H9a35dpEuIuUi3Q==", + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/csstools" + }, + { + "type": "opencollective", + "url": "https://opencollective.com/csstools" + } + ], + "dependencies": { + "@csstools/selector-specificity": "^3.1.1", + "postcss-selector-parser": "^6.0.13" + }, + "engines": { + "node": "^14 || ^16 || >=18" + }, + "peerDependencies": { + "postcss": "^8.4" + } + }, + "node_modules/@csstools/postcss-light-dark-function": { + "version": "1.0.8", + "resolved": "https://registry.npmjs.org/@csstools/postcss-light-dark-function/-/postcss-light-dark-function-1.0.8.tgz", + "integrity": "sha512-x0UtpCyVnERsplUeoaY6nEtp1HxTf4lJjoK/ULEm40DraqFfUdUSt76yoOyX5rGY6eeOUOkurHyYlFHVKv/pew==", + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/csstools" + }, + { + "type": "opencollective", + "url": "https://opencollective.com/csstools" + } + ], + "dependencies": { + "@csstools/css-parser-algorithms": "^2.7.1", + "@csstools/css-tokenizer": "^2.4.1", + "@csstools/postcss-progressive-custom-properties": "^3.3.0", + "@csstools/utilities": "^1.0.0" + }, + "engines": { + "node": "^14 || ^16 || >=18" + }, + "peerDependencies": { + "postcss": "^8.4" + } + }, + "node_modules/@csstools/postcss-logical-float-and-clear": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/@csstools/postcss-logical-float-and-clear/-/postcss-logical-float-and-clear-2.0.1.tgz", + "integrity": "sha512-SsrWUNaXKr+e/Uo4R/uIsqJYt3DaggIh/jyZdhy/q8fECoJSKsSMr7nObSLdvoULB69Zb6Bs+sefEIoMG/YfOA==", + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/csstools" + }, + { + "type": "opencollective", + "url": "https://opencollective.com/csstools" + } + ], + "engines": { + "node": "^14 || ^16 || >=18" + }, + "peerDependencies": { + "postcss": "^8.4" + } + }, + "node_modules/@csstools/postcss-logical-overflow": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/@csstools/postcss-logical-overflow/-/postcss-logical-overflow-1.0.1.tgz", + "integrity": "sha512-Kl4lAbMg0iyztEzDhZuQw8Sj9r2uqFDcU1IPl+AAt2nue8K/f1i7ElvKtXkjhIAmKiy5h2EY8Gt/Cqg0pYFDCw==", + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/csstools" + }, + { + "type": "opencollective", + "url": "https://opencollective.com/csstools" + } + ], + "engines": { + "node": "^14 || ^16 || >=18" + }, + "peerDependencies": { + "postcss": "^8.4" + } + }, + "node_modules/@csstools/postcss-logical-overscroll-behavior": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/@csstools/postcss-logical-overscroll-behavior/-/postcss-logical-overscroll-behavior-1.0.1.tgz", + "integrity": "sha512-+kHamNxAnX8ojPCtV8WPcUP3XcqMFBSDuBuvT6MHgq7oX4IQxLIXKx64t7g9LiuJzE7vd06Q9qUYR6bh4YnGpQ==", + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/csstools" + }, + { + "type": "opencollective", + "url": "https://opencollective.com/csstools" + } + ], + "engines": { + "node": "^14 || ^16 || >=18" + }, + "peerDependencies": { + "postcss": "^8.4" + } + }, + "node_modules/@csstools/postcss-logical-resize": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/@csstools/postcss-logical-resize/-/postcss-logical-resize-2.0.1.tgz", + "integrity": "sha512-W5Gtwz7oIuFcKa5SmBjQ2uxr8ZoL7M2bkoIf0T1WeNqljMkBrfw1DDA8/J83k57NQ1kcweJEjkJ04pUkmyee3A==", + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/csstools" + }, + { + "type": "opencollective", + "url": "https://opencollective.com/csstools" + } + ], + "dependencies": { + "postcss-value-parser": "^4.2.0" + }, + "engines": { + "node": "^14 || ^16 || >=18" + }, + "peerDependencies": { + "postcss": "^8.4" + } + }, + "node_modules/@csstools/postcss-logical-viewport-units": { + "version": "2.0.11", + "resolved": "https://registry.npmjs.org/@csstools/postcss-logical-viewport-units/-/postcss-logical-viewport-units-2.0.11.tgz", + "integrity": "sha512-ElITMOGcjQtvouxjd90WmJRIw1J7KMP+M+O87HaVtlgOOlDt1uEPeTeii8qKGe2AiedEp0XOGIo9lidbiU2Ogg==", + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/csstools" + }, + { + "type": "opencollective", + "url": "https://opencollective.com/csstools" + } + ], + "dependencies": { + "@csstools/css-tokenizer": "^2.4.1", + "@csstools/utilities": "^1.0.0" + }, + "engines": { + "node": "^14 || ^16 || >=18" + }, + "peerDependencies": { + "postcss": "^8.4" + } + }, + "node_modules/@csstools/postcss-media-minmax": { + "version": "1.1.8", + "resolved": "https://registry.npmjs.org/@csstools/postcss-media-minmax/-/postcss-media-minmax-1.1.8.tgz", + "integrity": "sha512-KYQCal2i7XPNtHAUxCECdrC7tuxIWQCW+s8eMYs5r5PaAiVTeKwlrkRS096PFgojdNCmHeG0Cb7njtuNswNf+w==", + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/csstools" + }, + { + "type": "opencollective", + "url": "https://opencollective.com/csstools" + } + ], + "dependencies": { + "@csstools/css-calc": "^1.2.4", + "@csstools/css-parser-algorithms": "^2.7.1", + "@csstools/css-tokenizer": "^2.4.1", + "@csstools/media-query-list-parser": "^2.1.13" + }, + "engines": { + "node": "^14 || ^16 || >=18" + }, + "peerDependencies": { + "postcss": "^8.4" + } + }, + "node_modules/@csstools/postcss-media-queries-aspect-ratio-number-values": { + "version": "2.0.11", + "resolved": "https://registry.npmjs.org/@csstools/postcss-media-queries-aspect-ratio-number-values/-/postcss-media-queries-aspect-ratio-number-values-2.0.11.tgz", + "integrity": "sha512-YD6jrib20GRGQcnOu49VJjoAnQ/4249liuz7vTpy/JfgqQ1Dlc5eD4HPUMNLOw9CWey9E6Etxwf/xc/ZF8fECA==", + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/csstools" + }, + { + "type": "opencollective", + "url": "https://opencollective.com/csstools" + } + ], + "dependencies": { + "@csstools/css-parser-algorithms": "^2.7.1", + "@csstools/css-tokenizer": "^2.4.1", + "@csstools/media-query-list-parser": "^2.1.13" + }, + "engines": { + "node": "^14 || ^16 || >=18" + }, + "peerDependencies": { + "postcss": "^8.4" + } + }, + "node_modules/@csstools/postcss-nested-calc": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/@csstools/postcss-nested-calc/-/postcss-nested-calc-3.0.2.tgz", + "integrity": "sha512-ySUmPyawiHSmBW/VI44+IObcKH0v88LqFe0d09Sb3w4B1qjkaROc6d5IA3ll9kjD46IIX/dbO5bwFN/swyoyZA==", + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/csstools" + }, + { + "type": "opencollective", + "url": "https://opencollective.com/csstools" + } + ], + "dependencies": { + "@csstools/utilities": "^1.0.0", + "postcss-value-parser": "^4.2.0" + }, + "engines": { + "node": "^14 || ^16 || >=18" + }, + "peerDependencies": { + "postcss": "^8.4" + } + }, + "node_modules/@csstools/postcss-normalize-display-values": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/@csstools/postcss-normalize-display-values/-/postcss-normalize-display-values-3.0.2.tgz", + "integrity": "sha512-fCapyyT/dUdyPtrelQSIV+d5HqtTgnNP/BEG9IuhgXHt93Wc4CfC1bQ55GzKAjWrZbgakMQ7MLfCXEf3rlZJOw==", + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/csstools" + }, + { + "type": "opencollective", + "url": "https://opencollective.com/csstools" + } + ], + "dependencies": { + "postcss-value-parser": "^4.2.0" + }, + "engines": { + "node": "^14 || ^16 || >=18" + }, + "peerDependencies": { + "postcss": "^8.4" + } + }, + "node_modules/@csstools/postcss-oklab-function": { + "version": "3.0.19", + "resolved": "https://registry.npmjs.org/@csstools/postcss-oklab-function/-/postcss-oklab-function-3.0.19.tgz", + "integrity": "sha512-e3JxXmxjU3jpU7TzZrsNqSX4OHByRC3XjItV3Ieo/JEQmLg5rdOL4lkv/1vp27gXemzfNt44F42k/pn0FpE21Q==", + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/csstools" + }, + { + "type": "opencollective", + "url": "https://opencollective.com/csstools" + } + ], + "dependencies": { + "@csstools/css-color-parser": "^2.0.4", + "@csstools/css-parser-algorithms": "^2.7.1", + "@csstools/css-tokenizer": "^2.4.1", + "@csstools/postcss-progressive-custom-properties": "^3.3.0", + "@csstools/utilities": "^1.0.0" + }, + "engines": { + "node": "^14 || ^16 || >=18" + }, + "peerDependencies": { + "postcss": "^8.4" + } + }, + "node_modules/@csstools/postcss-progressive-custom-properties": { + "version": "3.3.0", + "resolved": "https://registry.npmjs.org/@csstools/postcss-progressive-custom-properties/-/postcss-progressive-custom-properties-3.3.0.tgz", + "integrity": "sha512-W2oV01phnILaRGYPmGFlL2MT/OgYjQDrL9sFlbdikMFi6oQkFki9B86XqEWR7HCsTZFVq7dbzr/o71B75TKkGg==", + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/csstools" + }, + { + "type": "opencollective", + "url": "https://opencollective.com/csstools" + } + ], + "dependencies": { + "postcss-value-parser": "^4.2.0" + }, + "engines": { + "node": "^14 || ^16 || >=18" + }, + "peerDependencies": { + "postcss": "^8.4" + } + }, + "node_modules/@csstools/postcss-relative-color-syntax": { + "version": "2.0.19", + "resolved": "https://registry.npmjs.org/@csstools/postcss-relative-color-syntax/-/postcss-relative-color-syntax-2.0.19.tgz", + "integrity": "sha512-MxUMSNvio1WwuS6WRLlQuv6nNPXwIWUFzBBAvL/tBdWfiKjiJnAa6eSSN5gtaacSqUkQ/Ce5Z1OzLRfeaWhADA==", + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/csstools" + }, + { + "type": "opencollective", + "url": "https://opencollective.com/csstools" + } + ], + "dependencies": { + "@csstools/css-color-parser": "^2.0.4", + "@csstools/css-parser-algorithms": "^2.7.1", + "@csstools/css-tokenizer": "^2.4.1", + "@csstools/postcss-progressive-custom-properties": "^3.3.0", + "@csstools/utilities": "^1.0.0" + }, + "engines": { + "node": "^14 || ^16 || >=18" + }, + "peerDependencies": { + "postcss": "^8.4" + } + }, + "node_modules/@csstools/postcss-scope-pseudo-class": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/@csstools/postcss-scope-pseudo-class/-/postcss-scope-pseudo-class-3.0.1.tgz", + "integrity": "sha512-3ZFonK2gfgqg29gUJ2w7xVw2wFJ1eNWVDONjbzGkm73gJHVCYK5fnCqlLr+N+KbEfv2XbWAO0AaOJCFB6Fer6A==", + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/csstools" + }, + { + "type": "opencollective", + "url": "https://opencollective.com/csstools" + } + ], + "dependencies": { + "postcss-selector-parser": "^6.0.13" + }, + "engines": { + "node": "^14 || ^16 || >=18" + }, + "peerDependencies": { + "postcss": "^8.4" + } + }, + "node_modules/@csstools/postcss-stepped-value-functions": { + "version": "3.0.10", + "resolved": "https://registry.npmjs.org/@csstools/postcss-stepped-value-functions/-/postcss-stepped-value-functions-3.0.10.tgz", + "integrity": "sha512-MZwo0D0TYrQhT5FQzMqfy/nGZ28D1iFtpN7Su1ck5BPHS95+/Y5O9S4kEvo76f2YOsqwYcT8ZGehSI1TnzuX2g==", + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/csstools" + }, + { + "type": "opencollective", + "url": "https://opencollective.com/csstools" + } + ], + "dependencies": { + "@csstools/css-calc": "^1.2.4", + "@csstools/css-parser-algorithms": "^2.7.1", + "@csstools/css-tokenizer": "^2.4.1" + }, + "engines": { + "node": "^14 || ^16 || >=18" + }, + "peerDependencies": { + "postcss": "^8.4" + } + }, + "node_modules/@csstools/postcss-text-decoration-shorthand": { + "version": "3.0.7", + "resolved": "https://registry.npmjs.org/@csstools/postcss-text-decoration-shorthand/-/postcss-text-decoration-shorthand-3.0.7.tgz", + "integrity": "sha512-+cptcsM5r45jntU6VjotnkC9GteFR7BQBfZ5oW7inLCxj7AfLGAzMbZ60hKTP13AULVZBdxky0P8um0IBfLHVA==", + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/csstools" + }, + { + "type": "opencollective", + "url": "https://opencollective.com/csstools" + } + ], + "dependencies": { + "@csstools/color-helpers": "^4.2.1", + "postcss-value-parser": "^4.2.0" + }, + "engines": { + "node": "^14 || ^16 || >=18" + }, + "peerDependencies": { + "postcss": "^8.4" + } + }, + "node_modules/@csstools/postcss-trigonometric-functions": { + "version": "3.0.10", + "resolved": "https://registry.npmjs.org/@csstools/postcss-trigonometric-functions/-/postcss-trigonometric-functions-3.0.10.tgz", + "integrity": "sha512-G9G8moTc2wiad61nY5HfvxLiM/myX0aYK4s1x8MQlPH29WDPxHQM7ghGgvv2qf2xH+rrXhztOmjGHJj4jsEqXw==", + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/csstools" + }, + { + "type": "opencollective", + "url": "https://opencollective.com/csstools" + } + ], + "dependencies": { + "@csstools/css-calc": "^1.2.4", + "@csstools/css-parser-algorithms": "^2.7.1", + "@csstools/css-tokenizer": "^2.4.1" + }, + "engines": { + "node": "^14 || ^16 || >=18" + }, + "peerDependencies": { + "postcss": "^8.4" + } + }, + "node_modules/@csstools/postcss-unset-value": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/@csstools/postcss-unset-value/-/postcss-unset-value-3.0.1.tgz", + "integrity": "sha512-dbDnZ2ja2U8mbPP0Hvmt2RMEGBiF1H7oY6HYSpjteXJGihYwgxgTr6KRbbJ/V6c+4wd51M+9980qG4gKVn5ttg==", + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/csstools" + }, + { + "type": "opencollective", + "url": "https://opencollective.com/csstools" + } + ], + "engines": { + "node": "^14 || ^16 || >=18" + }, + "peerDependencies": { + "postcss": "^8.4" + } + }, + "node_modules/@csstools/selector-resolve-nested": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/@csstools/selector-resolve-nested/-/selector-resolve-nested-1.1.0.tgz", + "integrity": "sha512-uWvSaeRcHyeNenKg8tp17EVDRkpflmdyvbE0DHo6D/GdBb6PDnCYYU6gRpXhtICMGMcahQmj2zGxwFM/WC8hCg==", + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/csstools" + }, + { + "type": "opencollective", + "url": "https://opencollective.com/csstools" + } + ], + "engines": { + "node": "^14 || ^16 || >=18" + }, + "peerDependencies": { + "postcss-selector-parser": "^6.0.13" + } + }, + "node_modules/@csstools/selector-specificity": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/@csstools/selector-specificity/-/selector-specificity-3.1.1.tgz", + "integrity": "sha512-a7cxGcJ2wIlMFLlh8z2ONm+715QkPHiyJcxwQlKOz/03GPw1COpfhcmC9wm4xlZfp//jWHNNMwzjtqHXVWU9KA==", + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/csstools" + }, + { + "type": "opencollective", + "url": "https://opencollective.com/csstools" + } + ], + "engines": { + "node": "^14 || ^16 || >=18" + }, + "peerDependencies": { + "postcss-selector-parser": "^6.0.13" + } + }, + "node_modules/@csstools/utilities": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/@csstools/utilities/-/utilities-1.0.0.tgz", + "integrity": "sha512-tAgvZQe/t2mlvpNosA4+CkMiZ2azISW5WPAcdSalZlEjQvUfghHxfQcrCiK/7/CrfAWVxyM88kGFYO82heIGDg==", + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/csstools" + }, + { + "type": "opencollective", + "url": "https://opencollective.com/csstools" + } + ], + "engines": { + "node": "^14 || ^16 || >=18" + }, + "peerDependencies": { + "postcss": "^8.4" + } + }, "node_modules/@emmetio/abbreviation": { "version": "2.3.3", "resolved": "https://registry.npmjs.org/@emmetio/abbreviation/-/abbreviation-2.3.3.tgz", "integrity": "sha512-mgv58UrU3rh4YgbE/TzgLQwJ3pFsHHhCLqY20aJq+9comytTXUDNGG/SMtSeMJdkpxgXSXunBGLD8Boka3JyVA==", + "license": "MIT", "dependencies": { "@emmetio/scanner": "^1.0.4" } @@ -478,64 +1464,66 @@ "version": "2.1.8", "resolved": "https://registry.npmjs.org/@emmetio/css-abbreviation/-/css-abbreviation-2.1.8.tgz", "integrity": "sha512-s9yjhJ6saOO/uk1V74eifykk2CBYi01STTK3WlXWGOepyKa23ymJ053+DNQjpFcy1ingpaO7AxCcwLvHFY9tuw==", + "license": "MIT", "dependencies": { "@emmetio/scanner": "^1.0.4" } }, + "node_modules/@emmetio/css-parser": { + "version": "0.4.0", + "resolved": "https://registry.npmjs.org/@emmetio/css-parser/-/css-parser-0.4.0.tgz", + "integrity": "sha512-z7wkxRSZgrQHXVzObGkXG+Vmj3uRlpM11oCZ9pbaz0nFejvCDmAiNDpY75+wgXOcffKpj4rzGtwGaZxfJKsJxw==", + "license": "MIT", + "dependencies": { + "@emmetio/stream-reader": "^2.2.0", + "@emmetio/stream-reader-utils": "^0.1.0" + } + }, + "node_modules/@emmetio/html-matcher": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/@emmetio/html-matcher/-/html-matcher-1.3.0.tgz", + "integrity": "sha512-NTbsvppE5eVyBMuyGfVu2CRrLvo7J4YHb6t9sBFLyY03WYhXET37qA4zOYUjBWFCRHO7pS1B9khERtY0f5JXPQ==", + "license": "ISC", + "dependencies": { + "@emmetio/scanner": "^1.0.0" + } + }, "node_modules/@emmetio/scanner": { "version": "1.0.4", "resolved": "https://registry.npmjs.org/@emmetio/scanner/-/scanner-1.0.4.tgz", - "integrity": "sha512-IqRuJtQff7YHHBk4G8YZ45uB9BaAGcwQeVzgj/zj8/UdOhtQpEIupUhSk8dys6spFIWVZVeK20CzGEnqR5SbqA==" + "integrity": "sha512-IqRuJtQff7YHHBk4G8YZ45uB9BaAGcwQeVzgj/zj8/UdOhtQpEIupUhSk8dys6spFIWVZVeK20CzGEnqR5SbqA==", + "license": "MIT" }, - "node_modules/@esbuild/android-arm": { - "version": "0.17.19", - "resolved": "https://registry.npmjs.org/@esbuild/android-arm/-/android-arm-0.17.19.tgz", - "integrity": "sha512-rIKddzqhmav7MSmoFCmDIb6e2W57geRsM94gV2l38fzhXMwq7hZoClug9USI2pFRGL06f4IOPHHpFNOkWieR8A==", - "cpu": [ - "arm" - ], + "node_modules/@emmetio/stream-reader": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/@emmetio/stream-reader/-/stream-reader-2.2.0.tgz", + "integrity": "sha512-fXVXEyFA5Yv3M3n8sUGT7+fvecGrZP4k6FnWWMSZVQf69kAq0LLpaBQLGcPR30m3zMmKYhECP4k/ZkzvhEW5kw==", + "license": "MIT" + }, + "node_modules/@emmetio/stream-reader-utils": { + "version": "0.1.0", + "resolved": "https://registry.npmjs.org/@emmetio/stream-reader-utils/-/stream-reader-utils-0.1.0.tgz", + "integrity": "sha512-ZsZ2I9Vzso3Ho/pjZFsmmZ++FWeEd/txqybHTm4OgaZzdS8V9V/YYWQwg5TC38Z7uLWUV1vavpLLbjJtKubR1A==", + "license": "MIT" + }, + "node_modules/@emnapi/runtime": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/@emnapi/runtime/-/runtime-1.1.1.tgz", + "integrity": "sha512-3bfqkzuR1KLx57nZfjr2NLnFOobvyS0aTszaEGCGqmYMVDRaGvgIZbjGSV/MHSSmLgQ/b9JFHQ5xm5WRZYd+XQ==", "optional": true, - "os": [ - "android" - ], - "engines": { - "node": ">=12" + "dependencies": { + "tslib": "^2.4.0" } }, - "node_modules/@esbuild/android-arm64": { - "version": "0.17.19", - "resolved": "https://registry.npmjs.org/@esbuild/android-arm64/-/android-arm64-0.17.19.tgz", - "integrity": "sha512-KBMWvEZooR7+kzY0BtbTQn0OAYY7CsiydT63pVEaPtVYF0hXbUaOyZog37DKxK7NF3XacBJOpYT4adIJh+avxA==", - "cpu": [ - "arm64" - ], - "optional": true, - "os": [ - "android" - ], - "engines": { - "node": ">=12" - } + "node_modules/@fontsource/work-sans": { + "version": "5.0.18", + "resolved": "https://registry.npmjs.org/@fontsource/work-sans/-/work-sans-5.0.18.tgz", + "integrity": "sha512-kFZEEPfWhALOweNTc+J60Jnok1bNuKC/L6wbM05f716pZFU9AAlKl0zmOYbJSkY4yhpHsYDL/X7A4zF9vPpE2g==" }, - "node_modules/@esbuild/android-x64": { - "version": "0.17.19", - "resolved": "https://registry.npmjs.org/@esbuild/android-x64/-/android-x64-0.17.19.tgz", - "integrity": "sha512-uUTTc4xGNDT7YSArp/zbtmbhO0uEEK9/ETW29Wk1thYUJBz3IVnvgEiEwEa9IeLyvnpKrWK64Utw2bgUmDveww==", - "cpu": [ - "x64" - ], - "optional": true, - "os": [ - "android" - ], - "engines": { - "node": ">=12" - } - }, - "node_modules/@esbuild/darwin-arm64": { - "version": "0.17.19", - "resolved": "https://registry.npmjs.org/@esbuild/darwin-arm64/-/darwin-arm64-0.17.19.tgz", - "integrity": "sha512-80wEoCfF/hFKM6WE1FyBHc9SfUblloAWx6FJkFWTWiCoht9Mc0ARGEM47e67W9rI09YoUxJL68WHfDRYEAvOhg==", + "node_modules/@img/sharp-darwin-arm64": { + "version": "0.33.3", + "resolved": "https://registry.npmjs.org/@img/sharp-darwin-arm64/-/sharp-darwin-arm64-0.33.3.tgz", + "integrity": "sha512-FaNiGX1MrOuJ3hxuNzWgsT/mg5OHG/Izh59WW2mk1UwYHUwtfbhk5QNKYZgxf0pLOhx9ctGiGa2OykD71vOnSw==", "cpu": [ "arm64" ], @@ -544,13 +1532,23 @@ "darwin" ], "engines": { - "node": ">=12" + "glibc": ">=2.26", + "node": "^18.17.0 || ^20.3.0 || >=21.0.0", + "npm": ">=9.6.5", + "pnpm": ">=7.1.0", + "yarn": ">=3.2.0" + }, + "funding": { + "url": "https://opencollective.com/libvips" + }, + "optionalDependencies": { + "@img/sharp-libvips-darwin-arm64": "1.0.2" } }, - "node_modules/@esbuild/darwin-x64": { - "version": "0.17.19", - "resolved": "https://registry.npmjs.org/@esbuild/darwin-x64/-/darwin-x64-0.17.19.tgz", - "integrity": "sha512-IJM4JJsLhRYr9xdtLytPLSH9k/oxR3boaUIYiHkAawtwNOXKE8KoU8tMvryogdcT8AU+Bflmh81Xn6Q0vTZbQw==", + "node_modules/@img/sharp-darwin-x64": { + "version": "0.33.3", + "resolved": "https://registry.npmjs.org/@img/sharp-darwin-x64/-/sharp-darwin-x64-0.33.3.tgz", + "integrity": "sha512-2QeSl7QDK9ru//YBT4sQkoq7L0EAJZA3rtV+v9p8xTKl4U1bUqTIaCnoC7Ctx2kCjQgwFXDasOtPTCT8eCTXvw==", "cpu": [ "x64" ], @@ -559,43 +1557,65 @@ "darwin" ], "engines": { - "node": ">=12" + "glibc": ">=2.26", + "node": "^18.17.0 || ^20.3.0 || >=21.0.0", + "npm": ">=9.6.5", + "pnpm": ">=7.1.0", + "yarn": ">=3.2.0" + }, + "funding": { + "url": "https://opencollective.com/libvips" + }, + "optionalDependencies": { + "@img/sharp-libvips-darwin-x64": "1.0.2" } }, - "node_modules/@esbuild/freebsd-arm64": { - "version": "0.17.19", - "resolved": "https://registry.npmjs.org/@esbuild/freebsd-arm64/-/freebsd-arm64-0.17.19.tgz", - "integrity": "sha512-pBwbc7DufluUeGdjSU5Si+P3SoMF5DQ/F/UmTSb8HXO80ZEAJmrykPyzo1IfNbAoaqw48YRpv8shwd1NoI0jcQ==", + "node_modules/@img/sharp-libvips-darwin-arm64": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/@img/sharp-libvips-darwin-arm64/-/sharp-libvips-darwin-arm64-1.0.2.tgz", + "integrity": "sha512-tcK/41Rq8IKlSaKRCCAuuY3lDJjQnYIW1UXU1kxcEKrfL8WR7N6+rzNoOxoQRJWTAECuKwgAHnPvqXGN8XfkHA==", "cpu": [ "arm64" ], "optional": true, "os": [ - "freebsd" + "darwin" ], "engines": { - "node": ">=12" + "macos": ">=11", + "npm": ">=9.6.5", + "pnpm": ">=7.1.0", + "yarn": ">=3.2.0" + }, + "funding": { + "url": "https://opencollective.com/libvips" } }, - "node_modules/@esbuild/freebsd-x64": { - "version": "0.17.19", - "resolved": "https://registry.npmjs.org/@esbuild/freebsd-x64/-/freebsd-x64-0.17.19.tgz", - "integrity": "sha512-4lu+n8Wk0XlajEhbEffdy2xy53dpR06SlzvhGByyg36qJw6Kpfk7cp45DR/62aPH9mtJRmIyrXAS5UWBrJT6TQ==", + "node_modules/@img/sharp-libvips-darwin-x64": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/@img/sharp-libvips-darwin-x64/-/sharp-libvips-darwin-x64-1.0.2.tgz", + "integrity": "sha512-Ofw+7oaWa0HiiMiKWqqaZbaYV3/UGL2wAPeLuJTx+9cXpCRdvQhCLG0IH8YGwM0yGWGLpsF4Su9vM1o6aer+Fw==", "cpu": [ "x64" ], "optional": true, "os": [ - "freebsd" + "darwin" ], "engines": { - "node": ">=12" + "macos": ">=10.13", + "npm": ">=9.6.5", + "pnpm": ">=7.1.0", + "yarn": ">=3.2.0" + }, + "funding": { + "url": "https://opencollective.com/libvips" } }, - "node_modules/@esbuild/linux-arm": { - "version": "0.17.19", - "resolved": "https://registry.npmjs.org/@esbuild/linux-arm/-/linux-arm-0.17.19.tgz", - "integrity": "sha512-cdmT3KxjlOQ/gZ2cjfrQOtmhG4HJs6hhvm3mWSRDPtZ/lP5oe8FWceS10JaSJC13GBd4eH/haHnqf7hhGNLerA==", + "node_modules/@img/sharp-libvips-linux-arm": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/@img/sharp-libvips-linux-arm/-/sharp-libvips-linux-arm-1.0.2.tgz", + "integrity": "sha512-iLWCvrKgeFoglQxdEwzu1eQV04o8YeYGFXtfWU26Zr2wWT3q3MTzC+QTCO3ZQfWd3doKHT4Pm2kRmLbupT+sZw==", "cpu": [ "arm" ], @@ -604,13 +1624,19 @@ "linux" ], "engines": { - "node": ">=12" + "glibc": ">=2.28", + "npm": ">=9.6.5", + "pnpm": ">=7.1.0", + "yarn": ">=3.2.0" + }, + "funding": { + "url": "https://opencollective.com/libvips" } }, - "node_modules/@esbuild/linux-arm64": { - "version": "0.17.19", - "resolved": "https://registry.npmjs.org/@esbuild/linux-arm64/-/linux-arm64-0.17.19.tgz", - "integrity": "sha512-ct1Tg3WGwd3P+oZYqic+YZF4snNl2bsnMKRkb3ozHmnM0dGWuxcPTTntAF6bOP0Sp4x0PjSF+4uHQ1xvxfRKqg==", + "node_modules/@img/sharp-libvips-linux-arm64": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/@img/sharp-libvips-linux-arm64/-/sharp-libvips-linux-arm64-1.0.2.tgz", + "integrity": "sha512-x7kCt3N00ofFmmkkdshwj3vGPCnmiDh7Gwnd4nUwZln2YjqPxV1NlTyZOvoDWdKQVDL911487HOueBvrpflagw==", "cpu": [ "arm64" ], @@ -619,88 +1645,19 @@ "linux" ], "engines": { - "node": ">=12" + "glibc": ">=2.26", + "npm": ">=9.6.5", + "pnpm": ">=7.1.0", + "yarn": ">=3.2.0" + }, + "funding": { + "url": "https://opencollective.com/libvips" } }, - "node_modules/@esbuild/linux-ia32": { - "version": "0.17.19", - "resolved": "https://registry.npmjs.org/@esbuild/linux-ia32/-/linux-ia32-0.17.19.tgz", - "integrity": "sha512-w4IRhSy1VbsNxHRQpeGCHEmibqdTUx61Vc38APcsRbuVgK0OPEnQ0YD39Brymn96mOx48Y2laBQGqgZ0j9w6SQ==", - "cpu": [ - "ia32" - ], - "optional": true, - "os": [ - "linux" - ], - "engines": { - "node": ">=12" - } - }, - "node_modules/@esbuild/linux-loong64": { - "version": "0.17.19", - "resolved": "https://registry.npmjs.org/@esbuild/linux-loong64/-/linux-loong64-0.17.19.tgz", - "integrity": "sha512-2iAngUbBPMq439a+z//gE+9WBldoMp1s5GWsUSgqHLzLJ9WoZLZhpwWuym0u0u/4XmZ3gpHmzV84PonE+9IIdQ==", - "cpu": [ - "loong64" - ], - "optional": true, - "os": [ - "linux" - ], - "engines": { - "node": ">=12" - } - }, - "node_modules/@esbuild/linux-mips64el": { - "version": "0.17.19", - "resolved": "https://registry.npmjs.org/@esbuild/linux-mips64el/-/linux-mips64el-0.17.19.tgz", - "integrity": "sha512-LKJltc4LVdMKHsrFe4MGNPp0hqDFA1Wpt3jE1gEyM3nKUvOiO//9PheZZHfYRfYl6AwdTH4aTcXSqBerX0ml4A==", - "cpu": [ - "mips64el" - ], - "optional": true, - "os": [ - "linux" - ], - "engines": { - "node": ">=12" - } - }, - "node_modules/@esbuild/linux-ppc64": { - "version": "0.17.19", - "resolved": "https://registry.npmjs.org/@esbuild/linux-ppc64/-/linux-ppc64-0.17.19.tgz", - "integrity": "sha512-/c/DGybs95WXNS8y3Ti/ytqETiW7EU44MEKuCAcpPto3YjQbyK3IQVKfF6nbghD7EcLUGl0NbiL5Rt5DMhn5tg==", - "cpu": [ - "ppc64" - ], - "optional": true, - "os": [ - "linux" - ], - "engines": { - "node": ">=12" - } - }, - "node_modules/@esbuild/linux-riscv64": { - "version": "0.17.19", - "resolved": "https://registry.npmjs.org/@esbuild/linux-riscv64/-/linux-riscv64-0.17.19.tgz", - "integrity": "sha512-FC3nUAWhvFoutlhAkgHf8f5HwFWUL6bYdvLc/TTuxKlvLi3+pPzdZiFKSWz/PF30TB1K19SuCxDTI5KcqASJqA==", - "cpu": [ - "riscv64" - ], - "optional": true, - "os": [ - "linux" - ], - "engines": { - "node": ">=12" - } - }, - "node_modules/@esbuild/linux-s390x": { - "version": "0.17.19", - "resolved": "https://registry.npmjs.org/@esbuild/linux-s390x/-/linux-s390x-0.17.19.tgz", - "integrity": "sha512-IbFsFbxMWLuKEbH+7sTkKzL6NJmG2vRyy6K7JJo55w+8xDk7RElYn6xvXtDW8HCfoKBFK69f3pgBJSUSQPr+4Q==", + "node_modules/@img/sharp-libvips-linux-s390x": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/@img/sharp-libvips-linux-s390x/-/sharp-libvips-linux-s390x-1.0.2.tgz", + "integrity": "sha512-cmhQ1J4qVhfmS6szYW7RT+gLJq9dH2i4maq+qyXayUSn9/3iY2ZeWpbAgSpSVbV2E1JUL2Gg7pwnYQ1h8rQIog==", "cpu": [ "s390x" ], @@ -709,13 +1666,19 @@ "linux" ], "engines": { - "node": ">=12" + "glibc": ">=2.28", + "npm": ">=9.6.5", + "pnpm": ">=7.1.0", + "yarn": ">=3.2.0" + }, + "funding": { + "url": "https://opencollective.com/libvips" } }, - "node_modules/@esbuild/linux-x64": { - "version": "0.17.19", - "resolved": "https://registry.npmjs.org/@esbuild/linux-x64/-/linux-x64-0.17.19.tgz", - "integrity": "sha512-68ngA9lg2H6zkZcyp22tsVt38mlhWde8l3eJLWkyLrp4HwMUr3c1s/M2t7+kHIhvMjglIBrFpncX1SzMckomGw==", + "node_modules/@img/sharp-libvips-linux-x64": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/@img/sharp-libvips-linux-x64/-/sharp-libvips-linux-x64-1.0.2.tgz", + "integrity": "sha512-E441q4Qdb+7yuyiADVi5J+44x8ctlrqn8XgkDTwr4qPJzWkaHwD489iZ4nGDgcuya4iMN3ULV6NwbhRZJ9Z7SQ==", "cpu": [ "x64" ], @@ -724,73 +1687,232 @@ "linux" ], "engines": { - "node": ">=12" + "glibc": ">=2.26", + "npm": ">=9.6.5", + "pnpm": ">=7.1.0", + "yarn": ">=3.2.0" + }, + "funding": { + "url": "https://opencollective.com/libvips" } }, - "node_modules/@esbuild/netbsd-x64": { - "version": "0.17.19", - "resolved": "https://registry.npmjs.org/@esbuild/netbsd-x64/-/netbsd-x64-0.17.19.tgz", - "integrity": "sha512-CwFq42rXCR8TYIjIfpXCbRX0rp1jo6cPIUPSaWwzbVI4aOfX96OXY8M6KNmtPcg7QjYeDmN+DD0Wp3LaBOLf4Q==", - "cpu": [ - "x64" - ], - "optional": true, - "os": [ - "netbsd" - ], - "engines": { - "node": ">=12" - } - }, - "node_modules/@esbuild/openbsd-x64": { - "version": "0.17.19", - "resolved": "https://registry.npmjs.org/@esbuild/openbsd-x64/-/openbsd-x64-0.17.19.tgz", - "integrity": "sha512-cnq5brJYrSZ2CF6c35eCmviIN3k3RczmHz8eYaVlNasVqsNY+JKohZU5MKmaOI+KkllCdzOKKdPs762VCPC20g==", - "cpu": [ - "x64" - ], - "optional": true, - "os": [ - "openbsd" - ], - "engines": { - "node": ">=12" - } - }, - "node_modules/@esbuild/sunos-x64": { - "version": "0.17.19", - "resolved": "https://registry.npmjs.org/@esbuild/sunos-x64/-/sunos-x64-0.17.19.tgz", - "integrity": "sha512-vCRT7yP3zX+bKWFeP/zdS6SqdWB8OIpaRq/mbXQxTGHnIxspRtigpkUcDMlSCOejlHowLqII7K2JKevwyRP2rg==", - "cpu": [ - "x64" - ], - "optional": true, - "os": [ - "sunos" - ], - "engines": { - "node": ">=12" - } - }, - "node_modules/@esbuild/win32-arm64": { - "version": "0.17.19", - "resolved": "https://registry.npmjs.org/@esbuild/win32-arm64/-/win32-arm64-0.17.19.tgz", - "integrity": "sha512-yYx+8jwowUstVdorcMdNlzklLYhPxjniHWFKgRqH7IFlUEa0Umu3KuYplf1HUZZ422e3NU9F4LGb+4O0Kdcaag==", + "node_modules/@img/sharp-libvips-linuxmusl-arm64": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/@img/sharp-libvips-linuxmusl-arm64/-/sharp-libvips-linuxmusl-arm64-1.0.2.tgz", + "integrity": "sha512-3CAkndNpYUrlDqkCM5qhksfE+qSIREVpyoeHIU6jd48SJZViAmznoQQLAv4hVXF7xyUB9zf+G++e2v1ABjCbEQ==", "cpu": [ "arm64" ], "optional": true, "os": [ - "win32" + "linux" ], "engines": { - "node": ">=12" + "musl": ">=1.2.2", + "npm": ">=9.6.5", + "pnpm": ">=7.1.0", + "yarn": ">=3.2.0" + }, + "funding": { + "url": "https://opencollective.com/libvips" } }, - "node_modules/@esbuild/win32-ia32": { - "version": "0.17.19", - "resolved": "https://registry.npmjs.org/@esbuild/win32-ia32/-/win32-ia32-0.17.19.tgz", - "integrity": "sha512-eggDKanJszUtCdlVs0RB+h35wNlb5v4TWEkq4vZcmVt5u/HiDZrTXe2bWFQUez3RgNHwx/x4sk5++4NSSicKkw==", + "node_modules/@img/sharp-libvips-linuxmusl-x64": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/@img/sharp-libvips-linuxmusl-x64/-/sharp-libvips-linuxmusl-x64-1.0.2.tgz", + "integrity": "sha512-VI94Q6khIHqHWNOh6LLdm9s2Ry4zdjWJwH56WoiJU7NTeDwyApdZZ8c+SADC8OH98KWNQXnE01UdJ9CSfZvwZw==", + "cpu": [ + "x64" + ], + "optional": true, + "os": [ + "linux" + ], + "engines": { + "musl": ">=1.2.2", + "npm": ">=9.6.5", + "pnpm": ">=7.1.0", + "yarn": ">=3.2.0" + }, + "funding": { + "url": "https://opencollective.com/libvips" + } + }, + "node_modules/@img/sharp-linux-arm": { + "version": "0.33.3", + "resolved": "https://registry.npmjs.org/@img/sharp-linux-arm/-/sharp-linux-arm-0.33.3.tgz", + "integrity": "sha512-Q7Ee3fFSC9P7vUSqVEF0zccJsZ8GiiCJYGWDdhEjdlOeS9/jdkyJ6sUSPj+bL8VuOYFSbofrW0t/86ceVhx32w==", + "cpu": [ + "arm" + ], + "optional": true, + "os": [ + "linux" + ], + "engines": { + "glibc": ">=2.28", + "node": "^18.17.0 || ^20.3.0 || >=21.0.0", + "npm": ">=9.6.5", + "pnpm": ">=7.1.0", + "yarn": ">=3.2.0" + }, + "funding": { + "url": "https://opencollective.com/libvips" + }, + "optionalDependencies": { + "@img/sharp-libvips-linux-arm": "1.0.2" + } + }, + "node_modules/@img/sharp-linux-arm64": { + "version": "0.33.3", + "resolved": "https://registry.npmjs.org/@img/sharp-linux-arm64/-/sharp-linux-arm64-0.33.3.tgz", + "integrity": "sha512-Zf+sF1jHZJKA6Gor9hoYG2ljr4wo9cY4twaxgFDvlG0Xz9V7sinsPp8pFd1XtlhTzYo0IhDbl3rK7P6MzHpnYA==", + "cpu": [ + "arm64" + ], + "optional": true, + "os": [ + "linux" + ], + "engines": { + "glibc": ">=2.26", + "node": "^18.17.0 || ^20.3.0 || >=21.0.0", + "npm": ">=9.6.5", + "pnpm": ">=7.1.0", + "yarn": ">=3.2.0" + }, + "funding": { + "url": "https://opencollective.com/libvips" + }, + "optionalDependencies": { + "@img/sharp-libvips-linux-arm64": "1.0.2" + } + }, + "node_modules/@img/sharp-linux-s390x": { + "version": "0.33.3", + "resolved": "https://registry.npmjs.org/@img/sharp-linux-s390x/-/sharp-linux-s390x-0.33.3.tgz", + "integrity": "sha512-vFk441DKRFepjhTEH20oBlFrHcLjPfI8B0pMIxGm3+yilKyYeHEVvrZhYFdqIseSclIqbQ3SnZMwEMWonY5XFA==", + "cpu": [ + "s390x" + ], + "optional": true, + "os": [ + "linux" + ], + "engines": { + "glibc": ">=2.28", + "node": "^18.17.0 || ^20.3.0 || >=21.0.0", + "npm": ">=9.6.5", + "pnpm": ">=7.1.0", + "yarn": ">=3.2.0" + }, + "funding": { + "url": "https://opencollective.com/libvips" + }, + "optionalDependencies": { + "@img/sharp-libvips-linux-s390x": "1.0.2" + } + }, + "node_modules/@img/sharp-linux-x64": { + "version": "0.33.3", + "resolved": "https://registry.npmjs.org/@img/sharp-linux-x64/-/sharp-linux-x64-0.33.3.tgz", + "integrity": "sha512-Q4I++herIJxJi+qmbySd072oDPRkCg/SClLEIDh5IL9h1zjhqjv82H0Seupd+q2m0yOfD+/fJnjSoDFtKiHu2g==", + "cpu": [ + "x64" + ], + "optional": true, + "os": [ + "linux" + ], + "engines": { + "glibc": ">=2.26", + "node": "^18.17.0 || ^20.3.0 || >=21.0.0", + "npm": ">=9.6.5", + "pnpm": ">=7.1.0", + "yarn": ">=3.2.0" + }, + "funding": { + "url": "https://opencollective.com/libvips" + }, + "optionalDependencies": { + "@img/sharp-libvips-linux-x64": "1.0.2" + } + }, + "node_modules/@img/sharp-linuxmusl-arm64": { + "version": "0.33.3", + "resolved": "https://registry.npmjs.org/@img/sharp-linuxmusl-arm64/-/sharp-linuxmusl-arm64-0.33.3.tgz", + "integrity": "sha512-qnDccehRDXadhM9PM5hLvcPRYqyFCBN31kq+ErBSZtZlsAc1U4Z85xf/RXv1qolkdu+ibw64fUDaRdktxTNP9A==", + "cpu": [ + "arm64" + ], + "optional": true, + "os": [ + "linux" + ], + "engines": { + "musl": ">=1.2.2", + "node": "^18.17.0 || ^20.3.0 || >=21.0.0", + "npm": ">=9.6.5", + "pnpm": ">=7.1.0", + "yarn": ">=3.2.0" + }, + "funding": { + "url": "https://opencollective.com/libvips" + }, + "optionalDependencies": { + "@img/sharp-libvips-linuxmusl-arm64": "1.0.2" + } + }, + "node_modules/@img/sharp-linuxmusl-x64": { + "version": "0.33.3", + "resolved": "https://registry.npmjs.org/@img/sharp-linuxmusl-x64/-/sharp-linuxmusl-x64-0.33.3.tgz", + "integrity": "sha512-Jhchim8kHWIU/GZ+9poHMWRcefeaxFIs9EBqf9KtcC14Ojk6qua7ghKiPs0sbeLbLj/2IGBtDcxHyjCdYWkk2w==", + "cpu": [ + "x64" + ], + "optional": true, + "os": [ + "linux" + ], + "engines": { + "musl": ">=1.2.2", + "node": "^18.17.0 || ^20.3.0 || >=21.0.0", + "npm": ">=9.6.5", + "pnpm": ">=7.1.0", + "yarn": ">=3.2.0" + }, + "funding": { + "url": "https://opencollective.com/libvips" + }, + "optionalDependencies": { + "@img/sharp-libvips-linuxmusl-x64": "1.0.2" + } + }, + "node_modules/@img/sharp-wasm32": { + "version": "0.33.3", + "resolved": "https://registry.npmjs.org/@img/sharp-wasm32/-/sharp-wasm32-0.33.3.tgz", + "integrity": "sha512-68zivsdJ0koE96stdUfM+gmyaK/NcoSZK5dV5CAjES0FUXS9lchYt8LAB5rTbM7nlWtxaU/2GON0HVN6/ZYJAQ==", + "cpu": [ + "wasm32" + ], + "optional": true, + "dependencies": { + "@emnapi/runtime": "^1.1.0" + }, + "engines": { + "node": "^18.17.0 || ^20.3.0 || >=21.0.0", + "npm": ">=9.6.5", + "pnpm": ">=7.1.0", + "yarn": ">=3.2.0" + }, + "funding": { + "url": "https://opencollective.com/libvips" + } + }, + "node_modules/@img/sharp-win32-ia32": { + "version": "0.33.3", + "resolved": "https://registry.npmjs.org/@img/sharp-win32-ia32/-/sharp-win32-ia32-0.33.3.tgz", + "integrity": "sha512-CyimAduT2whQD8ER4Ux7exKrtfoaUiVr7HG0zZvO0XTFn2idUWljjxv58GxNTkFb8/J9Ub9AqITGkJD6ZginxQ==", "cpu": [ "ia32" ], @@ -799,13 +1921,19 @@ "win32" ], "engines": { - "node": ">=12" + "node": "^18.17.0 || ^20.3.0 || >=21.0.0", + "npm": ">=9.6.5", + "pnpm": ">=7.1.0", + "yarn": ">=3.2.0" + }, + "funding": { + "url": "https://opencollective.com/libvips" } }, - "node_modules/@esbuild/win32-x64": { - "version": "0.17.19", - "resolved": "https://registry.npmjs.org/@esbuild/win32-x64/-/win32-x64-0.17.19.tgz", - "integrity": "sha512-lAhycmKnVOuRYNtRtatQR1LPQf2oYCkRGkSFnseDAKPl8lu5SOsK/e1sXe5a0Pc5kHIHe6P2I/ilntNv2xf3cA==", + "node_modules/@img/sharp-win32-x64": { + "version": "0.33.3", + "resolved": "https://registry.npmjs.org/@img/sharp-win32-x64/-/sharp-win32-x64-0.33.3.tgz", + "integrity": "sha512-viT4fUIDKnli3IfOephGnolMzhz5VaTvDRkYqtZxOMIoMQ4MrAziO7pT1nVnOt2FAm7qW5aa+CCc13aEY6Le0g==", "cpu": [ "x64" ], @@ -814,57 +1942,58 @@ "win32" ], "engines": { - "node": ">=12" + "node": "^18.17.0 || ^20.3.0 || >=21.0.0", + "npm": ">=9.6.5", + "pnpm": ">=7.1.0", + "yarn": ">=3.2.0" + }, + "funding": { + "url": "https://opencollective.com/libvips" } }, "node_modules/@jridgewell/gen-mapping": { - "version": "0.3.3", - "resolved": "https://registry.npmjs.org/@jridgewell/gen-mapping/-/gen-mapping-0.3.3.tgz", - "integrity": "sha512-HLhSWOLRi875zjjMG/r+Nv0oCW8umGb0BgEhyX3dDX3egwZtB8PqLnjz3yedt8R5StBrzcg4aBpnh8UA9D1BoQ==", + "version": "0.3.5", + "resolved": "https://registry.npmjs.org/@jridgewell/gen-mapping/-/gen-mapping-0.3.5.tgz", + "integrity": "sha512-IzL8ZoEDIBRWEzlCcRhOaCupYyN5gdIK+Q6fbFdPDg6HqX6jpkItn7DFIpW9LQzXG6Df9sA7+OKnq0qlz/GaQg==", "dependencies": { - "@jridgewell/set-array": "^1.0.1", + "@jridgewell/set-array": "^1.2.1", "@jridgewell/sourcemap-codec": "^1.4.10", - "@jridgewell/trace-mapping": "^0.3.9" + "@jridgewell/trace-mapping": "^0.3.24" }, "engines": { "node": ">=6.0.0" } }, "node_modules/@jridgewell/resolve-uri": { - "version": "3.1.0", - "resolved": "https://registry.npmjs.org/@jridgewell/resolve-uri/-/resolve-uri-3.1.0.tgz", - "integrity": "sha512-F2msla3tad+Mfht5cJq7LSXcdudKTWCVYUgw6pLFOOHSTtZlj6SWNYAp+AhuqLmWdBO2X5hPrLcu8cVP8fy28w==", + "version": "3.1.2", + "resolved": "https://registry.npmjs.org/@jridgewell/resolve-uri/-/resolve-uri-3.1.2.tgz", + "integrity": "sha512-bRISgCIjP20/tbWSPWMEi54QVPRZExkuD9lJL+UIxUKtwVJA8wW1Trb1jMs1RFXo1CBTNZ/5hpC9QvmKWdopKw==", "engines": { "node": ">=6.0.0" } }, "node_modules/@jridgewell/set-array": { - "version": "1.1.2", - "resolved": "https://registry.npmjs.org/@jridgewell/set-array/-/set-array-1.1.2.tgz", - "integrity": "sha512-xnkseuNADM0gt2bs+BvhO0p78Mk762YnZdsuzFV018NoG1Sj1SCQvpSqa7XUaTam5vAGasABV9qXASMKnFMwMw==", + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/@jridgewell/set-array/-/set-array-1.2.1.tgz", + "integrity": "sha512-R8gLRTZeyp03ymzP/6Lil/28tGeGEzhx1q2k703KGWRAI1VdvPIXdG70VJc2pAMw3NA6JKL5hhFu1sJX0Mnn/A==", "engines": { "node": ">=6.0.0" } }, "node_modules/@jridgewell/sourcemap-codec": { - "version": "1.4.15", - "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.4.15.tgz", - "integrity": "sha512-eF2rxCRulEKXHTRiDrDy6erMYWqNw4LPdQ8UQA4huuxaQsVeRPFl2oM8oDGxMFhJUWZf9McpLtJasDDZb/Bpeg==" + "version": "1.5.0", + "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.5.0.tgz", + "integrity": "sha512-gv3ZRaISU3fjPAgNsriBRqGWQL6quFx04YMPW/zD8XMLsU32mhCCbfbO6KZFLjvYpCZ8zyDEgqsgf+PwPaM7GQ==" }, "node_modules/@jridgewell/trace-mapping": { - "version": "0.3.18", - "resolved": "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.18.tgz", - "integrity": "sha512-w+niJYzMHdd7USdiH2U6869nqhD2nbfZXND5Yp93qIbEmnDNk7PD48o+YchRVpzMU7M6jVCbenTR7PA1FLQ9pA==", + "version": "0.3.25", + "resolved": "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.25.tgz", + "integrity": "sha512-vNk6aEwybGtawWmy/PzwnGDOjCkLWSD2wqvjGGAgOAwCGWySYXfYoxt00IJkTF+8Lb57DwOb3Aa0o9CApepiYQ==", "dependencies": { - "@jridgewell/resolve-uri": "3.1.0", - "@jridgewell/sourcemap-codec": "1.4.14" + "@jridgewell/resolve-uri": "^3.1.0", + "@jridgewell/sourcemap-codec": "^1.4.14" } }, - "node_modules/@jridgewell/trace-mapping/node_modules/@jridgewell/sourcemap-codec": { - "version": "1.4.14", - "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.4.14.tgz", - "integrity": "sha512-XPSJHWmi394fuUuzDnGz1wiKqWfo1yXecHQMRf2l6hztTO+nPru658AyDngaBe7isIxEkRsPR3FZh+s7iVa4Uw==" - }, "node_modules/@nodelib/fs.scandir": { "version": "2.1.5", "resolved": "https://registry.npmjs.org/@nodelib/fs.scandir/-/fs.scandir-2.1.5.tgz", @@ -897,29 +2026,242 @@ "node": ">= 8" } }, - "node_modules/@pkgr/utils": { - "version": "2.4.2", - "resolved": "https://registry.npmjs.org/@pkgr/utils/-/utils-2.4.2.tgz", - "integrity": "sha512-POgTXhjrTfbTV63DiFXav4lBHiICLKKwDeaKn9Nphwj7WH6m0hMMCaJkMyRWjgtPFyRKRVoMXXjczsTQRDEhYw==", + "node_modules/@oslojs/encoding": { + "version": "0.4.1", + "resolved": "https://registry.npmjs.org/@oslojs/encoding/-/encoding-0.4.1.tgz", + "integrity": "sha512-hkjo6MuIK/kQR5CrGNdAPZhS01ZCXuWDRJ187zh6qqF2+yMHZpD9fAYpX8q2bOO6Ryhl3XpCT6kUX76N8hhm4Q==" + }, + "node_modules/@rollup/pluginutils": { + "version": "5.1.0", + "resolved": "https://registry.npmjs.org/@rollup/pluginutils/-/pluginutils-5.1.0.tgz", + "integrity": "sha512-XTIWOPPcpvyKI6L1NHo0lFlCyznUEyPmPY1mc3KpPVDYulHSTvyeLNVW00QTLIAFNhR3kYnJTQHeGqU4M3n09g==", "dependencies": { - "cross-spawn": "^7.0.3", - "fast-glob": "^3.3.0", - "is-glob": "^4.0.3", - "open": "^9.1.0", - "picocolors": "^1.0.0", - "tslib": "^2.6.0" + "@types/estree": "^1.0.0", + "estree-walker": "^2.0.2", + "picomatch": "^2.3.1" }, "engines": { - "node": "^12.20.0 || ^14.18.0 || >=16.0.0" + "node": ">=14.0.0" }, - "funding": { - "url": "https://opencollective.com/unts" + "peerDependencies": { + "rollup": "^1.20.0||^2.0.0||^3.0.0||^4.0.0" + }, + "peerDependenciesMeta": { + "rollup": { + "optional": true + } + } + }, + "node_modules/@rollup/pluginutils/node_modules/estree-walker": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/estree-walker/-/estree-walker-2.0.2.tgz", + "integrity": "sha512-Rfkk/Mp/DL7JVje3u18FxFujQlTNR2q6QfMSMB7AvCBx91NGj/ba3kCfza0f6dVDbw7YlRf/nDrn7pQrCCyQ/w==" + }, + "node_modules/@rollup/rollup-android-arm-eabi": { + "version": "4.17.2", + "resolved": "https://registry.npmjs.org/@rollup/rollup-android-arm-eabi/-/rollup-android-arm-eabi-4.17.2.tgz", + "integrity": "sha512-NM0jFxY8bB8QLkoKxIQeObCaDlJKewVlIEkuyYKm5An1tdVZ966w2+MPQ2l8LBZLjR+SgyV+nRkTIunzOYBMLQ==", + "cpu": [ + "arm" + ], + "optional": true, + "os": [ + "android" + ] + }, + "node_modules/@rollup/rollup-android-arm64": { + "version": "4.17.2", + "resolved": "https://registry.npmjs.org/@rollup/rollup-android-arm64/-/rollup-android-arm64-4.17.2.tgz", + "integrity": "sha512-yeX/Usk7daNIVwkq2uGoq2BYJKZY1JfyLTaHO/jaiSwi/lsf8fTFoQW/n6IdAsx5tx+iotu2zCJwz8MxI6D/Bw==", + "cpu": [ + "arm64" + ], + "optional": true, + "os": [ + "android" + ] + }, + "node_modules/@rollup/rollup-darwin-arm64": { + "version": "4.17.2", + "resolved": "https://registry.npmjs.org/@rollup/rollup-darwin-arm64/-/rollup-darwin-arm64-4.17.2.tgz", + "integrity": "sha512-kcMLpE6uCwls023+kknm71ug7MZOrtXo+y5p/tsg6jltpDtgQY1Eq5sGfHcQfb+lfuKwhBmEURDga9N0ol4YPw==", + "cpu": [ + "arm64" + ], + "optional": true, + "os": [ + "darwin" + ] + }, + "node_modules/@rollup/rollup-darwin-x64": { + "version": "4.17.2", + "resolved": "https://registry.npmjs.org/@rollup/rollup-darwin-x64/-/rollup-darwin-x64-4.17.2.tgz", + "integrity": "sha512-AtKwD0VEx0zWkL0ZjixEkp5tbNLzX+FCqGG1SvOu993HnSz4qDI6S4kGzubrEJAljpVkhRSlg5bzpV//E6ysTQ==", + "cpu": [ + "x64" + ], + "optional": true, + "os": [ + "darwin" + ] + }, + "node_modules/@rollup/rollup-linux-arm-gnueabihf": { + "version": "4.17.2", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm-gnueabihf/-/rollup-linux-arm-gnueabihf-4.17.2.tgz", + "integrity": "sha512-3reX2fUHqN7sffBNqmEyMQVj/CKhIHZd4y631duy0hZqI8Qoqf6lTtmAKvJFYa6bhU95B1D0WgzHkmTg33In0A==", + "cpu": [ + "arm" + ], + "optional": true, + "os": [ + "linux" + ] + }, + "node_modules/@rollup/rollup-linux-arm-musleabihf": { + "version": "4.17.2", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm-musleabihf/-/rollup-linux-arm-musleabihf-4.17.2.tgz", + "integrity": "sha512-uSqpsp91mheRgw96xtyAGP9FW5ChctTFEoXP0r5FAzj/3ZRv3Uxjtc7taRQSaQM/q85KEKjKsZuiZM3GyUivRg==", + "cpu": [ + "arm" + ], + "optional": true, + "os": [ + "linux" + ] + }, + "node_modules/@rollup/rollup-linux-arm64-gnu": { + "version": "4.17.2", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm64-gnu/-/rollup-linux-arm64-gnu-4.17.2.tgz", + "integrity": "sha512-EMMPHkiCRtE8Wdk3Qhtciq6BndLtstqZIroHiiGzB3C5LDJmIZcSzVtLRbwuXuUft1Cnv+9fxuDtDxz3k3EW2A==", + "cpu": [ + "arm64" + ], + "optional": true, + "os": [ + "linux" + ] + }, + "node_modules/@rollup/rollup-linux-arm64-musl": { + "version": "4.17.2", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm64-musl/-/rollup-linux-arm64-musl-4.17.2.tgz", + "integrity": "sha512-NMPylUUZ1i0z/xJUIx6VUhISZDRT+uTWpBcjdv0/zkp7b/bQDF+NfnfdzuTiB1G6HTodgoFa93hp0O1xl+/UbA==", + "cpu": [ + "arm64" + ], + "optional": true, + "os": [ + "linux" + ] + }, + "node_modules/@rollup/rollup-linux-powerpc64le-gnu": { + "version": "4.17.2", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-powerpc64le-gnu/-/rollup-linux-powerpc64le-gnu-4.17.2.tgz", + "integrity": "sha512-T19My13y8uYXPw/L/k0JYaX1fJKFT/PWdXiHr8mTbXWxjVF1t+8Xl31DgBBvEKclw+1b00Chg0hxE2O7bTG7GQ==", + "cpu": [ + "ppc64" + ], + "optional": true, + "os": [ + "linux" + ] + }, + "node_modules/@rollup/rollup-linux-riscv64-gnu": { + "version": "4.17.2", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-riscv64-gnu/-/rollup-linux-riscv64-gnu-4.17.2.tgz", + "integrity": "sha512-BOaNfthf3X3fOWAB+IJ9kxTgPmMqPPH5f5k2DcCsRrBIbWnaJCgX2ll77dV1TdSy9SaXTR5iDXRL8n7AnoP5cg==", + "cpu": [ + "riscv64" + ], + "optional": true, + "os": [ + "linux" + ] + }, + "node_modules/@rollup/rollup-linux-s390x-gnu": { + "version": "4.17.2", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-s390x-gnu/-/rollup-linux-s390x-gnu-4.17.2.tgz", + "integrity": "sha512-W0UP/x7bnn3xN2eYMql2T/+wpASLE5SjObXILTMPUBDB/Fg/FxC+gX4nvCfPBCbNhz51C+HcqQp2qQ4u25ok6g==", + "cpu": [ + "s390x" + ], + "optional": true, + "os": [ + "linux" + ] + }, + "node_modules/@rollup/rollup-linux-x64-gnu": { + "version": "4.17.2", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-x64-gnu/-/rollup-linux-x64-gnu-4.17.2.tgz", + "integrity": "sha512-Hy7pLwByUOuyaFC6mAr7m+oMC+V7qyifzs/nW2OJfC8H4hbCzOX07Ov0VFk/zP3kBsELWNFi7rJtgbKYsav9QQ==", + "cpu": [ + "x64" + ], + "optional": true, + "os": [ + "linux" + ] + }, + "node_modules/@rollup/rollup-linux-x64-musl": { + "version": "4.17.2", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-x64-musl/-/rollup-linux-x64-musl-4.17.2.tgz", + "integrity": "sha512-h1+yTWeYbRdAyJ/jMiVw0l6fOOm/0D1vNLui9iPuqgRGnXA0u21gAqOyB5iHjlM9MMfNOm9RHCQ7zLIzT0x11Q==", + "cpu": [ + "x64" + ], + "optional": true, + "os": [ + "linux" + ] + }, + "node_modules/@rollup/rollup-win32-arm64-msvc": { + "version": "4.17.2", + "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-arm64-msvc/-/rollup-win32-arm64-msvc-4.17.2.tgz", + "integrity": "sha512-tmdtXMfKAjy5+IQsVtDiCfqbynAQE/TQRpWdVataHmhMb9DCoJxp9vLcCBjEQWMiUYxO1QprH/HbY9ragCEFLA==", + "cpu": [ + "arm64" + ], + "optional": true, + "os": [ + "win32" + ] + }, + "node_modules/@rollup/rollup-win32-ia32-msvc": { + "version": "4.17.2", + "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-ia32-msvc/-/rollup-win32-ia32-msvc-4.17.2.tgz", + "integrity": "sha512-7II/QCSTAHuE5vdZaQEwJq2ZACkBpQDOmQsE6D6XUbnBHW8IAhm4eTufL6msLJorzrHDFv3CF8oCA/hSIRuZeQ==", + "cpu": [ + "ia32" + ], + "optional": true, + "os": [ + "win32" + ] + }, + "node_modules/@rollup/rollup-win32-x64-msvc": { + "version": "4.17.2", + "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-x64-msvc/-/rollup-win32-x64-msvc-4.17.2.tgz", + "integrity": "sha512-TGGO7v7qOq4CYmSBVEYpI1Y5xDuCEnbVC5Vth8mOsW0gDSzxNrVERPc790IGHsrT2dQSimgMr9Ub3Y1Jci5/8w==", + "cpu": [ + "x64" + ], + "optional": true, + "os": [ + "win32" + ] + }, + "node_modules/@shikijs/core": { + "version": "1.14.1", + "resolved": "https://registry.npmjs.org/@shikijs/core/-/core-1.14.1.tgz", + "integrity": "sha512-KyHIIpKNaT20FtFPFjCQB5WVSTpLR/n+jQXhWHWVUMm9MaOaG9BGOG0MSyt7yA4+Lm+4c9rTc03tt3nYzeYSfw==", + "license": "MIT", + "dependencies": { + "@types/hast": "^3.0.4" } }, "node_modules/@types/babel__core": { - "version": "7.20.1", - "resolved": "https://registry.npmjs.org/@types/babel__core/-/babel__core-7.20.1.tgz", - "integrity": "sha512-aACu/U/omhdk15O4Nfb+fHgH/z3QsfQzpnvRZhYhThms83ZnAOZz7zZAWO7mn2yyNQaA4xTO8GLK3uqFU4bYYw==", + "version": "7.20.5", + "resolved": "https://registry.npmjs.org/@types/babel__core/-/babel__core-7.20.5.tgz", + "integrity": "sha512-qoQprZvz5wQFJwMDqeseRXWv3rqMvhgpbXFfVyWhbx9X47POIA6i/+dXefEmZKoAgOaTdaIgNSMqMIU61yRyzA==", "dependencies": { "@babel/parser": "^7.20.7", "@babel/types": "^7.20.7", @@ -929,70 +2271,75 @@ } }, "node_modules/@types/babel__generator": { - "version": "7.6.4", - "resolved": "https://registry.npmjs.org/@types/babel__generator/-/babel__generator-7.6.4.tgz", - "integrity": "sha512-tFkciB9j2K755yrTALxD44McOrk+gfpIpvC3sxHjRawj6PfnQxrse4Clq5y/Rq+G3mrBurMax/lG8Qn2t9mSsg==", + "version": "7.6.8", + "resolved": "https://registry.npmjs.org/@types/babel__generator/-/babel__generator-7.6.8.tgz", + "integrity": "sha512-ASsj+tpEDsEiFr1arWrlN6V3mdfjRMZt6LtK/Vp/kreFLnr5QH5+DhvD5nINYZXzwJvXeGq+05iUXcAzVrqWtw==", "dependencies": { "@babel/types": "^7.0.0" } }, "node_modules/@types/babel__template": { - "version": "7.4.1", - "resolved": "https://registry.npmjs.org/@types/babel__template/-/babel__template-7.4.1.tgz", - "integrity": "sha512-azBFKemX6kMg5Io+/rdGT0dkGreboUVR0Cdm3fz9QJWpaQGJRQXl7C+6hOTCZcMll7KFyEQpgbYI2lHdsS4U7g==", + "version": "7.4.4", + "resolved": "https://registry.npmjs.org/@types/babel__template/-/babel__template-7.4.4.tgz", + "integrity": "sha512-h/NUaSyG5EyxBIp8YRxo4RMe2/qQgvyowRwVMzhYhBCONbW8PUsg4lkFMrhgZhUe5z3L3MiLDuvyJ/CaPa2A8A==", "dependencies": { "@babel/parser": "^7.1.0", "@babel/types": "^7.0.0" } }, "node_modules/@types/babel__traverse": { - "version": "7.20.1", - "resolved": "https://registry.npmjs.org/@types/babel__traverse/-/babel__traverse-7.20.1.tgz", - "integrity": "sha512-MitHFXnhtgwsGZWtT68URpOvLN4EREih1u3QtQiN4VdAxWKRVvGCSvw/Qth0M0Qq3pJpnGOu5JaM/ydK7OGbqg==", + "version": "7.20.4", + "resolved": "https://registry.npmjs.org/@types/babel__traverse/-/babel__traverse-7.20.4.tgz", + "integrity": "sha512-mSM/iKUk5fDDrEV/e83qY+Cr3I1+Q3qqTuEn++HAWYjEa1+NxZr6CNrcJGf2ZTnq4HoFGC3zaTPZTobCzCFukA==", "dependencies": { "@babel/types": "^7.20.7" } }, + "node_modules/@types/cookie": { + "version": "0.6.0", + "resolved": "https://registry.npmjs.org/@types/cookie/-/cookie-0.6.0.tgz", + "integrity": "sha512-4Kh9a6B2bQciAhf7FSuMRRkUWecJgJu9nPnx3yzpsfXX/c50REIqpHY4C82bXP90qrLtXtkDxTZosYO3UpOwlA==" + }, "node_modules/@types/debug": { - "version": "4.1.8", - "resolved": "https://registry.npmjs.org/@types/debug/-/debug-4.1.8.tgz", - "integrity": "sha512-/vPO1EPOs306Cvhwv7KfVfYvOJqA/S/AXjaHQiJboCZzcNDb+TIJFN9/2C9DZ//ijSKWioNyUxD792QmDJ+HKQ==", + "version": "4.1.12", + "resolved": "https://registry.npmjs.org/@types/debug/-/debug-4.1.12.tgz", + "integrity": "sha512-vIChWdVG3LG1SMxEvI/AK+FWJthlrqlTu7fbrlywTkkaONwk/UAGaULXRlf8vkzFBLVm0zkMdCquhL5aOjhXPQ==", "dependencies": { "@types/ms": "*" } }, + "node_modules/@types/estree": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/@types/estree/-/estree-1.0.5.tgz", + "integrity": "sha512-/kYRxGDLWzHOB7q+wtSUQlFrtcdUccpfy+X+9iMBpHK8QLLhx2wIPYuS5DYtR9Wa/YlZAbIovy7qVdB1Aq6Lyw==" + }, "node_modules/@types/hast": { - "version": "2.3.5", - "resolved": "https://registry.npmjs.org/@types/hast/-/hast-2.3.5.tgz", - "integrity": "sha512-SvQi0L/lNpThgPoleH53cdjB3y9zpLlVjRbqB3rH8hx1jiRSBGAhyjV3H+URFjNVRqt2EdYNrbZE5IsGlNfpRg==", + "version": "3.0.4", + "resolved": "https://registry.npmjs.org/@types/hast/-/hast-3.0.4.tgz", + "integrity": "sha512-WPs+bbQw5aCj+x6laNGWLH3wviHtoCv/P3+otBhbOhJgG8qtpdAMlTCxLtsTWA7LH1Oh/bFCHsBn0TPS5m30EQ==", "dependencies": { - "@types/unist": "^2" + "@types/unist": "*" } }, - "node_modules/@types/json5": { - "version": "0.0.30", - "resolved": "https://registry.npmjs.org/@types/json5/-/json5-0.0.30.tgz", - "integrity": "sha512-sqm9g7mHlPY/43fcSNrCYfOeX9zkTTK+euO5E6+CVijSMm5tTjkVdwdqRkY3ljjIAf8679vps5jKUoJBCLsMDA==" - }, "node_modules/@types/mdast": { - "version": "3.0.12", - "resolved": "https://registry.npmjs.org/@types/mdast/-/mdast-3.0.12.tgz", - "integrity": "sha512-DT+iNIRNX884cx0/Q1ja7NyUPpZuv0KPyL5rGNxm1WC1OtHstl7n4Jb7nk+xacNShQMbczJjt8uFzznpp6kYBg==", + "version": "4.0.3", + "resolved": "https://registry.npmjs.org/@types/mdast/-/mdast-4.0.3.tgz", + "integrity": "sha512-LsjtqsyF+d2/yFOYaN22dHZI1Cpwkrj+g06G8+qtUKlhovPW89YhqSnfKtMbkgmEtYpH2gydRNULd6y8mciAFg==", "dependencies": { - "@types/unist": "^2" + "@types/unist": "*" } }, "node_modules/@types/ms": { - "version": "0.7.31", - "resolved": "https://registry.npmjs.org/@types/ms/-/ms-0.7.31.tgz", - "integrity": "sha512-iiUgKzV9AuaEkZqkOLDIvlQiL6ltuZd9tGcW3gwpnX8JbuiuhFlEGmmFXEXkN50Cvq7Os88IY2v0dkDqXYWVgA==" + "version": "0.7.34", + "resolved": "https://registry.npmjs.org/@types/ms/-/ms-0.7.34.tgz", + "integrity": "sha512-nG96G3Wp6acyAgJqGasjODb+acrI7KltPiRxzHPXnP3NgI28bpQDRv53olbqGXbfcgF5aiiHmO3xpwEpS5Ld9g==" }, "node_modules/@types/nlcst": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/@types/nlcst/-/nlcst-1.0.1.tgz", - "integrity": "sha512-aVIyXt6pZiiMOtVByE4Y0gf+BLm1Cxc4ZLSK8VRHn1CgkO+kXbQwN/EBhQmhPdBMjFJCMBKtmNW2zWQuFywz8Q==", + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/@types/nlcst/-/nlcst-2.0.3.tgz", + "integrity": "sha512-vSYNSDe6Ix3q+6Z7ri9lyWqgGhJTmzRjZRqyq15N0Z/1/UnVsno9G/N40NBijoYx2seFDIl0+B2mgAb9mezUCA==", "dependencies": { - "@types/unist": "^2" + "@types/unist": "*" } }, "node_modules/@types/node": { @@ -1000,38 +2347,100 @@ "resolved": "https://registry.npmjs.org/@types/node/-/node-17.0.45.tgz", "integrity": "sha512-w+tIMs3rq2afQdsPJlODhoUEKzFP1ayaoyl1CcnwtIlsVe7K7bA1NGm4s3PraqTLlXnbIN84zuBlxBWo1u9BLw==" }, - "node_modules/@types/parse5": { - "version": "6.0.3", - "resolved": "https://registry.npmjs.org/@types/parse5/-/parse5-6.0.3.tgz", - "integrity": "sha512-SuT16Q1K51EAVPz1K29DJ/sXjhSQ0zjvsypYJ6tlwVsRV9jwW5Adq2ch8Dq8kDBCkYnELS7N7VNCSB5nC56t/g==" - }, - "node_modules/@types/resolve": { - "version": "1.20.2", - "resolved": "https://registry.npmjs.org/@types/resolve/-/resolve-1.20.2.tgz", - "integrity": "sha512-60BCwRFOZCQhDncwQdxxeOEEkbc5dIMccYLwbxsS4TUNeVECQ/pBJ0j09mrHOl/JJvpRPGwO9SvE4nR2Nb/a4Q==" - }, "node_modules/@types/sax": { - "version": "1.2.4", - "resolved": "https://registry.npmjs.org/@types/sax/-/sax-1.2.4.tgz", - "integrity": "sha512-pSAff4IAxJjfAXUG6tFkO7dsSbTmf8CtUpfhhZ5VhkRpC4628tJhh3+V6H1E+/Gs9piSzYKT5yzHO5M4GG9jkw==", + "version": "1.2.7", + "resolved": "https://registry.npmjs.org/@types/sax/-/sax-1.2.7.tgz", + "integrity": "sha512-rO73L89PJxeYM3s3pPPjiPgVVcymqU490g0YO5n5By0k2Erzj6tay/4lr1CHAAU4JyOWd1rpQ8bCf6cZfHU96A==", "dependencies": { "@types/node": "*" } }, "node_modules/@types/unist": { - "version": "2.0.7", - "resolved": "https://registry.npmjs.org/@types/unist/-/unist-2.0.7.tgz", - "integrity": "sha512-cputDpIbFgLUaGQn6Vqg3/YsJwxUwHLO13v3i5ouxT4lat0khip9AEWxtERujXV9wxIB1EyF97BSJFt6vpdI8g==" + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/@types/unist/-/unist-3.0.2.tgz", + "integrity": "sha512-dqId9J8K/vGi5Zr7oo212BGii5m3q5Hxlkwy3WpYuKPklmBEvsbMYYyLxAQpSffdLl/gdW0XUpKWFvYmyoWCoQ==" }, - "node_modules/@types/yargs-parser": { - "version": "21.0.0", - "resolved": "https://registry.npmjs.org/@types/yargs-parser/-/yargs-parser-21.0.0.tgz", - "integrity": "sha512-iO9ZQHkZxHn4mSakYV0vFHAVDyEOIJQrV2uZ06HxEPcx+mt8swXoZHIbaaJ2crJYFfErySgktuTZ3BeLz+XmFA==" + "node_modules/@ungap/structured-clone": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/@ungap/structured-clone/-/structured-clone-1.2.0.tgz", + "integrity": "sha512-zuVdFrMJiuCDQUMCzQaD6KL28MjnqqN8XnAqiEq9PNm/hCPTSGfrXCOfwj1ow4LFb/tNymJPwsNbVePc1xFqrQ==" + }, + "node_modules/@volar/kit": { + "version": "2.4.0", + "resolved": "https://registry.npmjs.org/@volar/kit/-/kit-2.4.0.tgz", + "integrity": "sha512-uqwtPKhrbnP+3f8hs+ltDYXLZ6Wdbs54IzkaPocasI4aBhqWLht5qXctE1MqpZU52wbH359E0u9nhxEFmyon+w==", + "license": "MIT", + "dependencies": { + "@volar/language-service": "2.4.0", + "@volar/typescript": "2.4.0", + "typesafe-path": "^0.2.2", + "vscode-languageserver-textdocument": "^1.0.11", + "vscode-uri": "^3.0.8" + }, + "peerDependencies": { + "typescript": "*" + } + }, + "node_modules/@volar/language-core": { + "version": "2.4.0", + "resolved": "https://registry.npmjs.org/@volar/language-core/-/language-core-2.4.0.tgz", + "integrity": "sha512-FTla+khE+sYK0qJP+6hwPAAUwiNHVMph4RUXpxf/FIPKUP61NFrVZorml4mjFShnueR2y9/j8/vnh09YwVdH7A==", + "license": "MIT", + "dependencies": { + "@volar/source-map": "2.4.0" + } + }, + "node_modules/@volar/language-server": { + "version": "2.4.0", + "resolved": "https://registry.npmjs.org/@volar/language-server/-/language-server-2.4.0.tgz", + "integrity": "sha512-rmGIjAxWekWQiGH97Mosb4juiD/hfFYNQKV5Py9r7vDOLSkbIwRhITbwHm88NJKs8P6TNc6w/PfBXN6yjKadJg==", + "license": "MIT", + "dependencies": { + "@volar/language-core": "2.4.0", + "@volar/language-service": "2.4.0", + "@volar/typescript": "2.4.0", + "path-browserify": "^1.0.1", + "request-light": "^0.7.0", + "vscode-languageserver": "^9.0.1", + "vscode-languageserver-protocol": "^3.17.5", + "vscode-languageserver-textdocument": "^1.0.11", + "vscode-uri": "^3.0.8" + } + }, + "node_modules/@volar/language-service": { + "version": "2.4.0", + "resolved": "https://registry.npmjs.org/@volar/language-service/-/language-service-2.4.0.tgz", + "integrity": "sha512-4P3yeQXIL68mLfS3n6P3m02IRg3GnLHUU9k/1PCHEfm5FG9bySkDOc72dbBn2vAa2BxOqm18bmmZXrsWuQ5AOw==", + "license": "MIT", + "dependencies": { + "@volar/language-core": "2.4.0", + "vscode-languageserver-protocol": "^3.17.5", + "vscode-languageserver-textdocument": "^1.0.11", + "vscode-uri": "^3.0.8" + } + }, + "node_modules/@volar/source-map": { + "version": "2.4.0", + "resolved": "https://registry.npmjs.org/@volar/source-map/-/source-map-2.4.0.tgz", + "integrity": "sha512-2ceY8/NEZvN6F44TXw2qRP6AQsvCYhV2bxaBPWxV9HqIfkbRydSksTFObCF1DBDNBfKiZTS8G/4vqV6cvjdOIQ==", + "license": "MIT" + }, + "node_modules/@volar/typescript": { + "version": "2.4.0", + "resolved": "https://registry.npmjs.org/@volar/typescript/-/typescript-2.4.0.tgz", + "integrity": "sha512-9zx3lQWgHmVd+JRRAHUSRiEhe4TlzL7U7e6ulWXOxHH/WNYxzKwCvZD7WYWEZFdw4dHfTD9vUR0yPQO6GilCaQ==", + "license": "MIT", + "dependencies": { + "@volar/language-core": "2.4.0", + "path-browserify": "^1.0.1", + "vscode-uri": "^3.0.8" + } }, "node_modules/@vscode/emmet-helper": { - "version": "2.9.2", - "resolved": "https://registry.npmjs.org/@vscode/emmet-helper/-/emmet-helper-2.9.2.tgz", - "integrity": "sha512-MaGuyW+fa13q3aYsluKqclmh62Hgp0BpKIqS66fCxfOaBcVQ1OnMQxRRgQUYnCkxFISAQlkJ0qWWPyXjro1Qrg==", + "version": "2.9.3", + "resolved": "https://registry.npmjs.org/@vscode/emmet-helper/-/emmet-helper-2.9.3.tgz", + "integrity": "sha512-rB39LHWWPQYYlYfpv9qCoZOVioPCftKXXqrsyqN1mTWZM6dTnONT63Db+03vgrBbHzJN45IrgS/AGxw9iiqfEw==", + "license": "MIT", "dependencies": { "emmet": "^2.4.3", "jsonc-parser": "^2.3.0", @@ -1043,17 +2452,19 @@ "node_modules/@vscode/emmet-helper/node_modules/vscode-uri": { "version": "2.1.2", "resolved": "https://registry.npmjs.org/vscode-uri/-/vscode-uri-2.1.2.tgz", - "integrity": "sha512-8TEXQxlldWAuIODdukIb+TR5s+9Ds40eSJrw+1iDDA9IFORPjMELarNQE3myz5XIkWWpdprmJjm1/SxMlWOC8A==" + "integrity": "sha512-8TEXQxlldWAuIODdukIb+TR5s+9Ds40eSJrw+1iDDA9IFORPjMELarNQE3myz5XIkWWpdprmJjm1/SxMlWOC8A==", + "license": "MIT" }, "node_modules/@vscode/l10n": { - "version": "0.0.14", - "resolved": "https://registry.npmjs.org/@vscode/l10n/-/l10n-0.0.14.tgz", - "integrity": "sha512-/yrv59IEnmh655z1oeDnGcvMYwnEzNzHLgeYcQCkhYX0xBvYWrAuefoiLcPBUkMpJsb46bqQ6Yv4pwTTQ4d3Qg==" + "version": "0.0.18", + "resolved": "https://registry.npmjs.org/@vscode/l10n/-/l10n-0.0.18.tgz", + "integrity": "sha512-KYSIHVmslkaCDyw013pphY+d7x1qV8IZupYfeIfzNA+nsaWHbn5uPuQRvdRFsa9zFzGeudPuoGoZ1Op4jrJXIQ==", + "license": "MIT" }, "node_modules/acorn": { - "version": "8.10.0", - "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.10.0.tgz", - "integrity": "sha512-F0SAmZ8iUtS//m8DmCTA0jlh6TDKkHQyK6xc6V4KDTyZKA9dnvX9/3sRTVQrWm79glUAZbnmmNcdYwUIHWVybw==", + "version": "8.12.1", + "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.12.1.tgz", + "integrity": "sha512-tcpGyI9zbizT9JbV6oYE477V6mTlXvvi0T0G3SNIYE2apm/G5huBa1+K89VGeovbg+jycCrfhl3ADxErOuO6Jg==", "bin": { "acorn": "bin/acorn" }, @@ -1061,6 +2472,22 @@ "node": ">=0.4.0" } }, + "node_modules/ajv": { + "version": "8.17.1", + "resolved": "https://registry.npmjs.org/ajv/-/ajv-8.17.1.tgz", + "integrity": "sha512-B/gBuNg5SiMTrPkC+A2+cW0RszwxYmn6VYxB/inlBStS5nx6xHIt/ehKRhIMhqusl7a8LjQoZnjCs5vhwxOQ1g==", + "license": "MIT", + "dependencies": { + "fast-deep-equal": "^3.1.3", + "fast-uri": "^3.0.1", + "json-schema-traverse": "^1.0.0", + "require-from-string": "^2.0.2" + }, + "funding": { + "type": "github", + "url": "https://github.com/sponsors/epoberezkin" + } + }, "node_modules/ansi-align": { "version": "3.0.1", "resolved": "https://registry.npmjs.org/ansi-align/-/ansi-align-3.0.1.tgz", @@ -1117,11 +2544,6 @@ "url": "https://github.com/chalk/ansi-regex?sponsor=1" } }, - "node_modules/ansi-sequence-parser": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/ansi-sequence-parser/-/ansi-sequence-parser-1.1.0.tgz", - "integrity": "sha512-lEm8mt52to2fT8GhciPCGeCXACSz2UwIN4X2e2LJSnZ5uAbn2/dsYdOmUXq0AtWS5cpAupysIneExOgH0Vd2TQ==" - }, "node_modules/ansi-styles": { "version": "3.2.1", "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", @@ -1155,6 +2577,14 @@ "resolved": "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz", "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==" }, + "node_modules/aria-query": { + "version": "5.3.0", + "resolved": "https://registry.npmjs.org/aria-query/-/aria-query-5.3.0.tgz", + "integrity": "sha512-b0P0sZPKtyu8HkeRAfCq0IfURZK+SuwMjY1UXGBU27wpAiTwQAIlq56IbIO+ytk/JjS1fMR14ee5WBBfKi5J6A==", + "dependencies": { + "dequal": "^2.0.3" + } + }, "node_modules/array-iterate": { "version": "2.0.1", "resolved": "https://registry.npmjs.org/array-iterate/-/array-iterate-2.0.1.tgz", @@ -1165,83 +2595,617 @@ } }, "node_modules/astro": { - "version": "2.8.3", - "resolved": "https://registry.npmjs.org/astro/-/astro-2.8.3.tgz", - "integrity": "sha512-UopGl3WubMnl15TWlR6PTCcH54TooZ+JoAloErfoXQtz4PAvmEEqEVc7tHoJ45iC7rhKgzILsvDhqzitBeRihw==", + "version": "4.14.3", + "resolved": "https://registry.npmjs.org/astro/-/astro-4.14.3.tgz", + "integrity": "sha512-+Hox1EhiS5iHy4pfZaLidpD9x7WVAcgGgjTo1JOYSQ0+a2ZA9mbLtGVEXbUeeYweviNc0ZNHMnI4r9S2e8xnXg==", + "license": "MIT", "dependencies": { - "@astrojs/compiler": "^1.5.3", - "@astrojs/internal-helpers": "^0.1.1", - "@astrojs/language-server": "^1.0.0", - "@astrojs/markdown-remark": "^2.2.1", - "@astrojs/telemetry": "^2.1.1", - "@astrojs/webapi": "^2.2.0", - "@babel/core": "^7.22.5", - "@babel/generator": "^7.22.5", - "@babel/parser": "^7.22.5", - "@babel/plugin-transform-react-jsx": "^7.22.5", - "@babel/traverse": "^7.22.5", - "@babel/types": "^7.22.5", - "@types/babel__core": "^7.20.1", - "@types/yargs-parser": "^21.0.0", - "acorn": "^8.9.0", - "boxen": "^6.2.1", - "chokidar": "^3.5.3", - "ci-info": "^3.8.0", + "@astrojs/compiler": "^2.10.3", + "@astrojs/internal-helpers": "0.4.1", + "@astrojs/markdown-remark": "5.2.0", + "@astrojs/telemetry": "3.1.0", + "@babel/core": "^7.25.2", + "@babel/generator": "^7.25.0", + "@babel/parser": "^7.25.3", + "@babel/plugin-transform-react-jsx": "^7.25.2", + "@babel/traverse": "^7.25.3", + "@babel/types": "^7.25.2", + "@oslojs/encoding": "^0.4.1", + "@rollup/pluginutils": "^5.1.0", + "@types/babel__core": "^7.20.5", + "@types/cookie": "^0.6.0", + "acorn": "^8.12.1", + "aria-query": "^5.3.0", + "axobject-query": "^4.1.0", + "boxen": "7.1.1", + "ci-info": "^4.0.0", + "clsx": "^2.1.1", "common-ancestor-path": "^1.0.1", - "cookie": "^0.5.0", - "debug": "^4.3.4", - "deepmerge-ts": "^4.3.0", - "devalue": "^4.3.2", - "diff": "^5.1.0", - "es-module-lexer": "^1.3.0", - "esbuild": "^0.17.19", - "estree-walker": "3.0.0", - "execa": "^6.1.0", - "fast-glob": "^3.2.12", + "cookie": "^0.6.0", + "cssesc": "^3.0.0", + "debug": "^4.3.6", + "deterministic-object-hash": "^2.0.2", + "devalue": "^5.0.0", + "diff": "^5.2.0", + "dlv": "^1.1.3", + "dset": "^3.1.3", + "es-module-lexer": "^1.5.4", + "esbuild": "^0.21.5", + "estree-walker": "^3.0.3", + "execa": "^8.0.1", + "fast-glob": "^3.3.2", + "flattie": "^1.1.1", "github-slugger": "^2.0.0", "gray-matter": "^4.0.3", "html-escaper": "^3.0.3", + "http-cache-semantics": "^4.1.1", "js-yaml": "^4.1.0", - "kleur": "^4.1.4", - "magic-string": "^0.27.0", - "mime": "^3.0.0", - "ora": "^6.3.1", - "p-limit": "^4.0.0", - "path-to-regexp": "^6.2.1", - "preferred-pm": "^3.0.3", + "kleur": "^4.1.5", + "magic-string": "^0.30.11", + "micromatch": "^4.0.7", + "mrmime": "^2.0.0", + "neotraverse": "^0.6.18", + "ora": "^8.0.1", + "p-limit": "^6.1.0", + "p-queue": "^8.0.1", + "path-to-regexp": "^6.2.2", + "preferred-pm": "^4.0.0", "prompts": "^2.4.2", - "rehype": "^12.0.1", - "semver": "^7.5.3", - "server-destroy": "^1.0.1", - "shiki": "^0.14.1", - "string-width": "^5.1.2", + "rehype": "^13.0.1", + "semver": "^7.6.3", + "shiki": "^1.14.1", + "string-width": "^7.2.0", "strip-ansi": "^7.1.0", - "tsconfig-resolver": "^3.0.1", - "typescript": "*", - "unist-util-visit": "^4.1.2", - "vfile": "^5.3.7", - "vite": "^4.3.9", - "vitefu": "^0.2.4", - "which-pm": "^2.0.0", + "tsconfck": "^3.1.1", + "unist-util-visit": "^5.0.0", + "vfile": "^6.0.2", + "vite": "^5.4.1", + "vitefu": "^0.2.5", + "which-pm": "^3.0.0", + "xxhash-wasm": "^1.0.2", "yargs-parser": "^21.1.1", - "zod": "^3.20.6" + "zod": "^3.23.8", + "zod-to-json-schema": "^3.23.2", + "zod-to-ts": "^1.2.0" }, "bin": { "astro": "astro.js" }, "engines": { - "node": ">=16.12.0", - "npm": ">=6.14.0" + "node": "^18.17.1 || ^20.3.0 || >=21.0.0", + "npm": ">=9.6.5", + "pnpm": ">=7.1.0" + }, + "optionalDependencies": { + "sharp": "^0.33.3" + } + }, + "node_modules/astro-meta-tags": { + "version": "0.3.0", + "resolved": "https://registry.npmjs.org/astro-meta-tags/-/astro-meta-tags-0.3.0.tgz", + "integrity": "sha512-BA8jZncOGz1DkjK4AQHt8mzXurGwhR96CZZlx2wLemRUqKTxft4N2Arg8DK/s49G/9F0g4TuxmiObVkIv/DX8g==", + "peerDependencies": { + "astro": "^4.0.0" + } + }, + "node_modules/astro/node_modules/@esbuild/aix-ppc64": { + "version": "0.21.5", + "resolved": "https://registry.npmjs.org/@esbuild/aix-ppc64/-/aix-ppc64-0.21.5.tgz", + "integrity": "sha512-1SDgH6ZSPTlggy1yI6+Dbkiz8xzpHJEVAlF/AM1tHPLsf5STom9rwtjE4hKAF20FfXXNTFqEYXyJNWh1GiZedQ==", + "cpu": [ + "ppc64" + ], + "optional": true, + "os": [ + "aix" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/astro/node_modules/@esbuild/android-arm": { + "version": "0.21.5", + "resolved": "https://registry.npmjs.org/@esbuild/android-arm/-/android-arm-0.21.5.tgz", + "integrity": "sha512-vCPvzSjpPHEi1siZdlvAlsPxXl7WbOVUBBAowWug4rJHb68Ox8KualB+1ocNvT5fjv6wpkX6o/iEpbDrf68zcg==", + "cpu": [ + "arm" + ], + "optional": true, + "os": [ + "android" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/astro/node_modules/@esbuild/android-arm64": { + "version": "0.21.5", + "resolved": "https://registry.npmjs.org/@esbuild/android-arm64/-/android-arm64-0.21.5.tgz", + "integrity": "sha512-c0uX9VAUBQ7dTDCjq+wdyGLowMdtR/GoC2U5IYk/7D1H1JYC0qseD7+11iMP2mRLN9RcCMRcjC4YMclCzGwS/A==", + "cpu": [ + "arm64" + ], + "optional": true, + "os": [ + "android" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/astro/node_modules/@esbuild/android-x64": { + "version": "0.21.5", + "resolved": "https://registry.npmjs.org/@esbuild/android-x64/-/android-x64-0.21.5.tgz", + "integrity": "sha512-D7aPRUUNHRBwHxzxRvp856rjUHRFW1SdQATKXH2hqA0kAZb1hKmi02OpYRacl0TxIGz/ZmXWlbZgjwWYaCakTA==", + "cpu": [ + "x64" + ], + "optional": true, + "os": [ + "android" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/astro/node_modules/@esbuild/darwin-arm64": { + "version": "0.21.5", + "resolved": "https://registry.npmjs.org/@esbuild/darwin-arm64/-/darwin-arm64-0.21.5.tgz", + "integrity": "sha512-DwqXqZyuk5AiWWf3UfLiRDJ5EDd49zg6O9wclZ7kUMv2WRFr4HKjXp/5t8JZ11QbQfUS6/cRCKGwYhtNAY88kQ==", + "cpu": [ + "arm64" + ], + "optional": true, + "os": [ + "darwin" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/astro/node_modules/@esbuild/darwin-x64": { + "version": "0.21.5", + "resolved": "https://registry.npmjs.org/@esbuild/darwin-x64/-/darwin-x64-0.21.5.tgz", + "integrity": "sha512-se/JjF8NlmKVG4kNIuyWMV/22ZaerB+qaSi5MdrXtd6R08kvs2qCN4C09miupktDitvh8jRFflwGFBQcxZRjbw==", + "cpu": [ + "x64" + ], + "optional": true, + "os": [ + "darwin" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/astro/node_modules/@esbuild/freebsd-arm64": { + "version": "0.21.5", + "resolved": "https://registry.npmjs.org/@esbuild/freebsd-arm64/-/freebsd-arm64-0.21.5.tgz", + "integrity": "sha512-5JcRxxRDUJLX8JXp/wcBCy3pENnCgBR9bN6JsY4OmhfUtIHe3ZW0mawA7+RDAcMLrMIZaf03NlQiX9DGyB8h4g==", + "cpu": [ + "arm64" + ], + "optional": true, + "os": [ + "freebsd" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/astro/node_modules/@esbuild/freebsd-x64": { + "version": "0.21.5", + "resolved": "https://registry.npmjs.org/@esbuild/freebsd-x64/-/freebsd-x64-0.21.5.tgz", + "integrity": "sha512-J95kNBj1zkbMXtHVH29bBriQygMXqoVQOQYA+ISs0/2l3T9/kj42ow2mpqerRBxDJnmkUDCaQT/dfNXWX/ZZCQ==", + "cpu": [ + "x64" + ], + "optional": true, + "os": [ + "freebsd" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/astro/node_modules/@esbuild/linux-arm": { + "version": "0.21.5", + "resolved": "https://registry.npmjs.org/@esbuild/linux-arm/-/linux-arm-0.21.5.tgz", + "integrity": "sha512-bPb5AHZtbeNGjCKVZ9UGqGwo8EUu4cLq68E95A53KlxAPRmUyYv2D6F0uUI65XisGOL1hBP5mTronbgo+0bFcA==", + "cpu": [ + "arm" + ], + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/astro/node_modules/@esbuild/linux-arm64": { + "version": "0.21.5", + "resolved": "https://registry.npmjs.org/@esbuild/linux-arm64/-/linux-arm64-0.21.5.tgz", + "integrity": "sha512-ibKvmyYzKsBeX8d8I7MH/TMfWDXBF3db4qM6sy+7re0YXya+K1cem3on9XgdT2EQGMu4hQyZhan7TeQ8XkGp4Q==", + "cpu": [ + "arm64" + ], + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/astro/node_modules/@esbuild/linux-ia32": { + "version": "0.21.5", + "resolved": "https://registry.npmjs.org/@esbuild/linux-ia32/-/linux-ia32-0.21.5.tgz", + "integrity": "sha512-YvjXDqLRqPDl2dvRODYmmhz4rPeVKYvppfGYKSNGdyZkA01046pLWyRKKI3ax8fbJoK5QbxblURkwK/MWY18Tg==", + "cpu": [ + "ia32" + ], + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/astro/node_modules/@esbuild/linux-loong64": { + "version": "0.21.5", + "resolved": "https://registry.npmjs.org/@esbuild/linux-loong64/-/linux-loong64-0.21.5.tgz", + "integrity": "sha512-uHf1BmMG8qEvzdrzAqg2SIG/02+4/DHB6a9Kbya0XDvwDEKCoC8ZRWI5JJvNdUjtciBGFQ5PuBlpEOXQj+JQSg==", + "cpu": [ + "loong64" + ], + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/astro/node_modules/@esbuild/linux-mips64el": { + "version": "0.21.5", + "resolved": "https://registry.npmjs.org/@esbuild/linux-mips64el/-/linux-mips64el-0.21.5.tgz", + "integrity": "sha512-IajOmO+KJK23bj52dFSNCMsz1QP1DqM6cwLUv3W1QwyxkyIWecfafnI555fvSGqEKwjMXVLokcV5ygHW5b3Jbg==", + "cpu": [ + "mips64el" + ], + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/astro/node_modules/@esbuild/linux-ppc64": { + "version": "0.21.5", + "resolved": "https://registry.npmjs.org/@esbuild/linux-ppc64/-/linux-ppc64-0.21.5.tgz", + "integrity": "sha512-1hHV/Z4OEfMwpLO8rp7CvlhBDnjsC3CttJXIhBi+5Aj5r+MBvy4egg7wCbe//hSsT+RvDAG7s81tAvpL2XAE4w==", + "cpu": [ + "ppc64" + ], + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/astro/node_modules/@esbuild/linux-riscv64": { + "version": "0.21.5", + "resolved": "https://registry.npmjs.org/@esbuild/linux-riscv64/-/linux-riscv64-0.21.5.tgz", + "integrity": "sha512-2HdXDMd9GMgTGrPWnJzP2ALSokE/0O5HhTUvWIbD3YdjME8JwvSCnNGBnTThKGEB91OZhzrJ4qIIxk/SBmyDDA==", + "cpu": [ + "riscv64" + ], + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/astro/node_modules/@esbuild/linux-s390x": { + "version": "0.21.5", + "resolved": "https://registry.npmjs.org/@esbuild/linux-s390x/-/linux-s390x-0.21.5.tgz", + "integrity": "sha512-zus5sxzqBJD3eXxwvjN1yQkRepANgxE9lgOW2qLnmr8ikMTphkjgXu1HR01K4FJg8h1kEEDAqDcZQtbrRnB41A==", + "cpu": [ + "s390x" + ], + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/astro/node_modules/@esbuild/linux-x64": { + "version": "0.21.5", + "resolved": "https://registry.npmjs.org/@esbuild/linux-x64/-/linux-x64-0.21.5.tgz", + "integrity": "sha512-1rYdTpyv03iycF1+BhzrzQJCdOuAOtaqHTWJZCWvijKD2N5Xu0TtVC8/+1faWqcP9iBCWOmjmhoH94dH82BxPQ==", + "cpu": [ + "x64" + ], + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/astro/node_modules/@esbuild/netbsd-x64": { + "version": "0.21.5", + "resolved": "https://registry.npmjs.org/@esbuild/netbsd-x64/-/netbsd-x64-0.21.5.tgz", + "integrity": "sha512-Woi2MXzXjMULccIwMnLciyZH4nCIMpWQAs049KEeMvOcNADVxo0UBIQPfSmxB3CWKedngg7sWZdLvLczpe0tLg==", + "cpu": [ + "x64" + ], + "optional": true, + "os": [ + "netbsd" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/astro/node_modules/@esbuild/openbsd-x64": { + "version": "0.21.5", + "resolved": "https://registry.npmjs.org/@esbuild/openbsd-x64/-/openbsd-x64-0.21.5.tgz", + "integrity": "sha512-HLNNw99xsvx12lFBUwoT8EVCsSvRNDVxNpjZ7bPn947b8gJPzeHWyNVhFsaerc0n3TsbOINvRP2byTZ5LKezow==", + "cpu": [ + "x64" + ], + "optional": true, + "os": [ + "openbsd" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/astro/node_modules/@esbuild/sunos-x64": { + "version": "0.21.5", + "resolved": "https://registry.npmjs.org/@esbuild/sunos-x64/-/sunos-x64-0.21.5.tgz", + "integrity": "sha512-6+gjmFpfy0BHU5Tpptkuh8+uw3mnrvgs+dSPQXQOv3ekbordwnzTVEb4qnIvQcYXq6gzkyTnoZ9dZG+D4garKg==", + "cpu": [ + "x64" + ], + "optional": true, + "os": [ + "sunos" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/astro/node_modules/@esbuild/win32-arm64": { + "version": "0.21.5", + "resolved": "https://registry.npmjs.org/@esbuild/win32-arm64/-/win32-arm64-0.21.5.tgz", + "integrity": "sha512-Z0gOTd75VvXqyq7nsl93zwahcTROgqvuAcYDUr+vOv8uHhNSKROyU961kgtCD1e95IqPKSQKH7tBTslnS3tA8A==", + "cpu": [ + "arm64" + ], + "optional": true, + "os": [ + "win32" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/astro/node_modules/@esbuild/win32-ia32": { + "version": "0.21.5", + "resolved": "https://registry.npmjs.org/@esbuild/win32-ia32/-/win32-ia32-0.21.5.tgz", + "integrity": "sha512-SWXFF1CL2RVNMaVs+BBClwtfZSvDgtL//G/smwAc5oVK/UPu2Gu9tIaRgFmYFFKrmg3SyAjSrElf0TiJ1v8fYA==", + "cpu": [ + "ia32" + ], + "optional": true, + "os": [ + "win32" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/astro/node_modules/@esbuild/win32-x64": { + "version": "0.21.5", + "resolved": "https://registry.npmjs.org/@esbuild/win32-x64/-/win32-x64-0.21.5.tgz", + "integrity": "sha512-tQd/1efJuzPC6rCFwEvLtci/xNFcTZknmXs98FYDfGE4wP9ClFV98nyKrzJKVPMhdDnjzLhdUyMX4PsQAPjwIw==", + "cpu": [ + "x64" + ], + "optional": true, + "os": [ + "win32" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/astro/node_modules/@types/node": { + "version": "20.10.5", + "resolved": "https://registry.npmjs.org/@types/node/-/node-20.10.5.tgz", + "integrity": "sha512-nNPsNE65wjMxEKI93yOP+NPGGBJz/PoN3kZsVLee0XMiJolxSekEVD8wRwBUBqkwc7UWop0edW50yrCQW4CyRw==", + "optional": true, + "peer": true, + "dependencies": { + "undici-types": "~5.26.4" + } + }, + "node_modules/astro/node_modules/esbuild": { + "version": "0.21.5", + "resolved": "https://registry.npmjs.org/esbuild/-/esbuild-0.21.5.tgz", + "integrity": "sha512-mg3OPMV4hXywwpoDxu3Qda5xCKQi+vCTZq8S9J/EpkhB2HzKXq4SNFZE3+NK93JYxc8VMSep+lOUSC/RVKaBqw==", + "hasInstallScript": true, + "bin": { + "esbuild": "bin/esbuild" + }, + "engines": { + "node": ">=12" + }, + "optionalDependencies": { + "@esbuild/aix-ppc64": "0.21.5", + "@esbuild/android-arm": "0.21.5", + "@esbuild/android-arm64": "0.21.5", + "@esbuild/android-x64": "0.21.5", + "@esbuild/darwin-arm64": "0.21.5", + "@esbuild/darwin-x64": "0.21.5", + "@esbuild/freebsd-arm64": "0.21.5", + "@esbuild/freebsd-x64": "0.21.5", + "@esbuild/linux-arm": "0.21.5", + "@esbuild/linux-arm64": "0.21.5", + "@esbuild/linux-ia32": "0.21.5", + "@esbuild/linux-loong64": "0.21.5", + "@esbuild/linux-mips64el": "0.21.5", + "@esbuild/linux-ppc64": "0.21.5", + "@esbuild/linux-riscv64": "0.21.5", + "@esbuild/linux-s390x": "0.21.5", + "@esbuild/linux-x64": "0.21.5", + "@esbuild/netbsd-x64": "0.21.5", + "@esbuild/openbsd-x64": "0.21.5", + "@esbuild/sunos-x64": "0.21.5", + "@esbuild/win32-arm64": "0.21.5", + "@esbuild/win32-ia32": "0.21.5", + "@esbuild/win32-x64": "0.21.5" + } + }, + "node_modules/astro/node_modules/semver": { + "version": "7.6.3", + "resolved": "https://registry.npmjs.org/semver/-/semver-7.6.3.tgz", + "integrity": "sha512-oVekP1cKtI+CTDvHWYFUcMtsK/00wmAEfyqKfNdARm8u1wNVhSgaX7A8d4UuIlUI5e84iEwOhs7ZPYRmzU9U6A==", + "bin": { + "semver": "bin/semver.js" + }, + "engines": { + "node": ">=10" + } + }, + "node_modules/astro/node_modules/vite": { + "version": "5.4.1", + "resolved": "https://registry.npmjs.org/vite/-/vite-5.4.1.tgz", + "integrity": "sha512-1oE6yuNXssjrZdblI9AfBbHCC41nnyoVoEZxQnID6yvQZAFBzxxkqoFLtHUMkYunL8hwOLEjgTuxpkRxvba3kA==", + "dependencies": { + "esbuild": "^0.21.3", + "postcss": "^8.4.41", + "rollup": "^4.13.0" + }, + "bin": { + "vite": "bin/vite.js" + }, + "engines": { + "node": "^18.0.0 || >=20.0.0" + }, + "funding": { + "url": "https://github.com/vitejs/vite?sponsor=1" + }, + "optionalDependencies": { + "fsevents": "~2.3.3" }, "peerDependencies": { - "sharp": ">=0.31.0" + "@types/node": "^18.0.0 || >=20.0.0", + "less": "*", + "lightningcss": "^1.21.0", + "sass": "*", + "sass-embedded": "*", + "stylus": "*", + "sugarss": "*", + "terser": "^5.4.0" }, "peerDependenciesMeta": { - "sharp": { + "@types/node": { + "optional": true + }, + "less": { + "optional": true + }, + "lightningcss": { + "optional": true + }, + "sass": { + "optional": true + }, + "sass-embedded": { + "optional": true + }, + "stylus": { + "optional": true + }, + "sugarss": { + "optional": true + }, + "terser": { "optional": true } } }, + "node_modules/astro/node_modules/vitefu": { + "version": "0.2.5", + "resolved": "https://registry.npmjs.org/vitefu/-/vitefu-0.2.5.tgz", + "integrity": "sha512-SgHtMLoqaeeGnd2evZ849ZbACbnwQCIwRH57t18FxcXoZop0uQu0uzlIhJBlF/eWVzuce0sHeqPcDo+evVcg8Q==", + "peerDependencies": { + "vite": "^3.0.0 || ^4.0.0 || ^5.0.0" + }, + "peerDependenciesMeta": { + "vite": { + "optional": true + } + } + }, + "node_modules/autoprefixer": { + "version": "10.4.19", + "resolved": "https://registry.npmjs.org/autoprefixer/-/autoprefixer-10.4.19.tgz", + "integrity": "sha512-BaENR2+zBZ8xXhM4pUaKUxlVdxZ0EZhjvbopwnXmxRUfqDmwSpC2lAi/QXvx7NRdPCo1WKEcEF6mV64si1z4Ew==", + "funding": [ + { + "type": "opencollective", + "url": "https://opencollective.com/postcss/" + }, + { + "type": "tidelift", + "url": "https://tidelift.com/funding/github/npm/autoprefixer" + }, + { + "type": "github", + "url": "https://github.com/sponsors/ai" + } + ], + "dependencies": { + "browserslist": "^4.23.0", + "caniuse-lite": "^1.0.30001599", + "fraction.js": "^4.3.7", + "normalize-range": "^0.1.2", + "picocolors": "^1.0.0", + "postcss-value-parser": "^4.2.0" + }, + "bin": { + "autoprefixer": "bin/autoprefixer" + }, + "engines": { + "node": "^10 || ^12 || >=14" + }, + "peerDependencies": { + "postcss": "^8.1.0" + } + }, + "node_modules/axobject-query": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/axobject-query/-/axobject-query-4.1.0.tgz", + "integrity": "sha512-qIj0G9wZbMGNLjLmg1PT6v2mE9AH2zlnADJD/2tC6E00hgmhUOfEB6greHPAfLRSufHqROIUTkw6E+M3lH0PTQ==", + "engines": { + "node": ">= 0.4" + } + }, "node_modules/bail": { "version": "2.0.2", "resolved": "https://registry.npmjs.org/bail/-/bail-2.0.2.tgz", @@ -1251,32 +3215,10 @@ "url": "https://github.com/sponsors/wooorm" } }, - "node_modules/base64-js": { - "version": "1.5.1", - "resolved": "https://registry.npmjs.org/base64-js/-/base64-js-1.5.1.tgz", - "integrity": "sha512-AKpaYlHn8t4SVbOHCy+b5+KKgvR4vrsD8vbvrbiQJps7fKDTkjkDry6ji0rUJjC0kzbNePLwzxq8iypo41qeWA==", - "funding": [ - { - "type": "github", - "url": "https://github.com/sponsors/feross" - }, - { - "type": "patreon", - "url": "https://www.patreon.com/feross" - }, - { - "type": "consulting", - "url": "https://feross.org/support" - } - ] - }, - "node_modules/big-integer": { - "version": "1.6.51", - "resolved": "https://registry.npmjs.org/big-integer/-/big-integer-1.6.51.tgz", - "integrity": "sha512-GPEid2Y9QU1Exl1rpO9B2IPJGHPSupF5GnVIP0blYvNOMer2bTvSWs1jGOUg04hTmu67nmLsQ9TBo1puaotBHg==", - "engines": { - "node": ">=0.6" - } + "node_modules/base-64": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/base-64/-/base-64-1.0.0.tgz", + "integrity": "sha512-kwDPIFCGx0NZHog36dj+tHiwP4QMzsZ3AgMViUBKI0+V5n4U0ufTCUMhnQ04diaRI8EX/QcPfql7zlhZ7j4zgg==" }, "node_modules/binary-extensions": { "version": "2.2.0", @@ -1286,127 +3228,74 @@ "node": ">=8" } }, - "node_modules/bl": { - "version": "5.1.0", - "resolved": "https://registry.npmjs.org/bl/-/bl-5.1.0.tgz", - "integrity": "sha512-tv1ZJHLfTDnXE6tMHv73YgSJaWR2AFuPwMntBe7XL/GBFHnT0CLnsHMogfk5+GzCDC5ZWarSCYaIGATZt9dNsQ==", - "dependencies": { - "buffer": "^6.0.3", - "inherits": "^2.0.4", - "readable-stream": "^3.4.0" - } - }, "node_modules/boxen": { - "version": "6.2.1", - "resolved": "https://registry.npmjs.org/boxen/-/boxen-6.2.1.tgz", - "integrity": "sha512-H4PEsJXfFI/Pt8sjDWbHlQPx4zL/bvSQjcilJmaulGt5mLDorHOHpmdXAJcBcmru7PhYSp/cDMWRko4ZUMFkSw==", + "version": "7.1.1", + "resolved": "https://registry.npmjs.org/boxen/-/boxen-7.1.1.tgz", + "integrity": "sha512-2hCgjEmP8YLWQ130n2FerGv7rYpfBmnmp9Uy2Le1vge6X3gZIfSmEzP5QTDElFxcvVcXlEn8Aq6MU/PZygIOog==", "dependencies": { "ansi-align": "^3.0.1", - "camelcase": "^6.2.0", - "chalk": "^4.1.2", + "camelcase": "^7.0.1", + "chalk": "^5.2.0", "cli-boxes": "^3.0.0", - "string-width": "^5.0.1", - "type-fest": "^2.5.0", + "string-width": "^5.1.2", + "type-fest": "^2.13.0", "widest-line": "^4.0.1", - "wrap-ansi": "^8.0.1" + "wrap-ansi": "^8.1.0" }, "engines": { - "node": "^12.20.0 || ^14.13.1 || >=16.0.0" + "node": ">=14.16" }, "funding": { "url": "https://github.com/sponsors/sindresorhus" } }, - "node_modules/boxen/node_modules/ansi-styles": { - "version": "4.3.0", - "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", - "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", - "dependencies": { - "color-convert": "^2.0.1" - }, - "engines": { - "node": ">=8" - }, - "funding": { - "url": "https://github.com/chalk/ansi-styles?sponsor=1" - } - }, "node_modules/boxen/node_modules/chalk": { - "version": "4.1.2", - "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", - "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", - "dependencies": { - "ansi-styles": "^4.1.0", - "supports-color": "^7.1.0" - }, + "version": "5.3.0", + "resolved": "https://registry.npmjs.org/chalk/-/chalk-5.3.0.tgz", + "integrity": "sha512-dLitG79d+GV1Nb/VYcCDFivJeK1hiukt9QjRNVOsUtTy1rR1YJsmpGGTZ3qJos+uw7WmWF4wUwBd9jxjocFC2w==", "engines": { - "node": ">=10" + "node": "^12.17.0 || ^14.13 || >=16.0.0" }, "funding": { "url": "https://github.com/chalk/chalk?sponsor=1" } }, - "node_modules/boxen/node_modules/color-convert": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", - "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", + "node_modules/boxen/node_modules/emoji-regex": { + "version": "9.2.2", + "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-9.2.2.tgz", + "integrity": "sha512-L18DaJsXSUk2+42pv8mLs5jJT2hqFkFE4j21wOmgbUqsZ2hL72NsUU785g9RXgo3s0ZNgVl42TiHp3ZtOv/Vyg==" + }, + "node_modules/boxen/node_modules/string-width": { + "version": "5.1.2", + "resolved": "https://registry.npmjs.org/string-width/-/string-width-5.1.2.tgz", + "integrity": "sha512-HnLOCR3vjcY8beoNLtcjZ5/nxn2afmME6lhrDrebokqMap+XbeW8n9TXpPDOqdGK5qcI3oT0GKTW6wC7EMiVqA==", "dependencies": { - "color-name": "~1.1.4" + "eastasianwidth": "^0.2.0", + "emoji-regex": "^9.2.2", + "strip-ansi": "^7.0.1" }, "engines": { - "node": ">=7.0.0" - } - }, - "node_modules/boxen/node_modules/color-name": { - "version": "1.1.4", - "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", - "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==" - }, - "node_modules/boxen/node_modules/has-flag": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", - "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", - "engines": { - "node": ">=8" - } - }, - "node_modules/boxen/node_modules/supports-color": { - "version": "7.2.0", - "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", - "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", - "dependencies": { - "has-flag": "^4.0.0" + "node": ">=12" }, - "engines": { - "node": ">=8" - } - }, - "node_modules/bplist-parser": { - "version": "0.2.0", - "resolved": "https://registry.npmjs.org/bplist-parser/-/bplist-parser-0.2.0.tgz", - "integrity": "sha512-z0M+byMThzQmD9NILRniCUXYsYpjwnlO8N5uCFaCqIOpqRsJCrQL9NK3JsD67CN5a08nF5oIL2bD6loTdHOuKw==", - "dependencies": { - "big-integer": "^1.6.44" - }, - "engines": { - "node": ">= 5.10.0" + "funding": { + "url": "https://github.com/sponsors/sindresorhus" } }, "node_modules/braces": { - "version": "3.0.2", - "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", - "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", + "version": "3.0.3", + "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.3.tgz", + "integrity": "sha512-yQbXgO/OSZVD2IsiLlro+7Hf6Q18EJrKSEsdoMzKePKXct3gvD8oLcOQdIzGupr5Fj+EDe8gO/lxc1BzfMpxvA==", "dependencies": { - "fill-range": "^7.0.1" + "fill-range": "^7.1.1" }, "engines": { "node": ">=8" } }, "node_modules/browserslist": { - "version": "4.21.9", - "resolved": "https://registry.npmjs.org/browserslist/-/browserslist-4.21.9.tgz", - "integrity": "sha512-M0MFoZzbUrRU4KNfCrDLnvyE7gub+peetoTid3TBIqtunaDJyXlwhakT+/VkvSXcfIzFfK/nkCs4nmyTmxdNSg==", + "version": "4.23.2", + "resolved": "https://registry.npmjs.org/browserslist/-/browserslist-4.23.2.tgz", + "integrity": "sha512-qkqSyistMYdxAcw+CzbZwlBy8AGmS/eEWs+sEV5TnLRGDOL+C5M2EnH6tlZyg0YoAxGJAFKh61En9BR941GnHA==", "funding": [ { "type": "opencollective", @@ -1422,10 +3311,10 @@ } ], "dependencies": { - "caniuse-lite": "^1.0.30001503", - "electron-to-chromium": "^1.4.431", - "node-releases": "^2.0.12", - "update-browserslist-db": "^1.0.11" + "caniuse-lite": "^1.0.30001640", + "electron-to-chromium": "^1.4.820", + "node-releases": "^2.0.14", + "update-browserslist-db": "^1.1.0" }, "bin": { "browserslist": "cli.js" @@ -1434,69 +3323,21 @@ "node": "^6 || ^7 || ^8 || ^9 || ^10 || ^11 || ^12 || >=13.7" } }, - "node_modules/buffer": { - "version": "6.0.3", - "resolved": "https://registry.npmjs.org/buffer/-/buffer-6.0.3.tgz", - "integrity": "sha512-FTiCpNxtwiZZHEZbcbTIcZjERVICn9yq/pDFkTl95/AxzD1naBctN7YO68riM/gLSDY7sdrMby8hofADYuuqOA==", - "funding": [ - { - "type": "github", - "url": "https://github.com/sponsors/feross" - }, - { - "type": "patreon", - "url": "https://www.patreon.com/feross" - }, - { - "type": "consulting", - "url": "https://feross.org/support" - } - ], - "dependencies": { - "base64-js": "^1.3.1", - "ieee754": "^1.2.1" - } - }, - "node_modules/bundle-name": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/bundle-name/-/bundle-name-3.0.0.tgz", - "integrity": "sha512-PKA4BeSvBpQKQ8iPOGCSiell+N8P+Tf1DlwqmYhpe2gAhKPHn8EYOxVT+ShuGmhg8lN8XiSlS80yiExKXrURlw==", - "dependencies": { - "run-applescript": "^5.0.0" - }, - "engines": { - "node": ">=12" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/busboy": { - "version": "1.6.0", - "resolved": "https://registry.npmjs.org/busboy/-/busboy-1.6.0.tgz", - "integrity": "sha512-8SFQbg/0hQ9xy3UNTB0YEnsNBbWfhf7RtnzpL7TkBiTBRfrQ9Fxcnz7VJsleJpyp6rVLvXiuORqjlHi5q+PYuA==", - "dependencies": { - "streamsearch": "^1.1.0" - }, - "engines": { - "node": ">=10.16.0" - } - }, "node_modules/camelcase": { - "version": "6.3.0", - "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-6.3.0.tgz", - "integrity": "sha512-Gmy6FhYlCY7uOElZUSbxo2UCDH8owEk996gkbrpsgGtrJLM3J7jGxl9Ic7Qwwj4ivOE5AWZWRMecDdF7hqGjFA==", + "version": "7.0.1", + "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-7.0.1.tgz", + "integrity": "sha512-xlx1yCK2Oc1APsPXDL2LdlNP6+uu8OCDdhOBSVT279M/S+y75O30C2VuD8T2ogdePBBl7PfPF4504tnLgX3zfw==", "engines": { - "node": ">=10" + "node": ">=14.16" }, "funding": { "url": "https://github.com/sponsors/sindresorhus" } }, "node_modules/caniuse-lite": { - "version": "1.0.30001516", - "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001516.tgz", - "integrity": "sha512-Wmec9pCBY8CWbmI4HsjBeQLqDTqV91nFVR83DnZpYyRnPI1wePDsTg0bGLPC5VU/3OIZV1fmxEea1b+tFKe86g==", + "version": "1.0.30001651", + "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001651.tgz", + "integrity": "sha512-9Cf+Xv1jJNe1xPZLGuUXLNkE1BoDkqRqYyFJ9TDYSqhduqA4hu4oR9HluGoWYQC/aj8WHjsGVV+bwkh0+tegRg==", "funding": [ { "type": "opencollective", @@ -1510,7 +3351,8 @@ "type": "github", "url": "https://github.com/sponsors/ai" } - ] + ], + "license": "CC-BY-4.0" }, "node_modules/ccount": { "version": "2.0.1", @@ -1562,15 +3404,9 @@ } }, "node_modules/chokidar": { - "version": "3.5.3", - "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.5.3.tgz", - "integrity": "sha512-Dr3sfKRP6oTcjf2JmUmFJfeVMvXBdegxB0iVQ5eb2V10uFJUCAS8OByZdVAyVb8xXNz3GjjTgj9kLWsZTqE6kw==", - "funding": [ - { - "type": "individual", - "url": "https://paulmillr.com/funding/" - } - ], + "version": "3.6.0", + "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.6.0.tgz", + "integrity": "sha512-7VT13fmjotKpGipCW9JEQAusEPE+Ei8nl6/g4FBAmIm0GOOLMua9NDDo/DWp0ZAxCr3cPq5ZpBqmPAQgDda2Pw==", "dependencies": { "anymatch": "~3.1.2", "braces": "~3.0.2", @@ -1583,14 +3419,17 @@ "engines": { "node": ">= 8.10.0" }, + "funding": { + "url": "https://paulmillr.com/funding/" + }, "optionalDependencies": { "fsevents": "~2.3.2" } }, "node_modules/ci-info": { - "version": "3.8.0", - "resolved": "https://registry.npmjs.org/ci-info/-/ci-info-3.8.0.tgz", - "integrity": "sha512-eXTggHWSooYhq49F2opQhuHWgzucfF2YgODK4e1566GQs5BIfP30B0oenwBJHfWxAs2fyPB1s7Mg949zLf61Yw==", + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/ci-info/-/ci-info-4.0.0.tgz", + "integrity": "sha512-TdHqgGf9odd8SXNuxtUBVx8Nv+qZOejE6qyqiy5NtbYYQOeFa6zmHkxlPzmaLxWWHsU6nJmB7AETdVPi+2NBUg==", "funding": [ { "type": "github", @@ -1627,9 +3466,9 @@ } }, "node_modules/cli-spinners": { - "version": "2.9.0", - "resolved": "https://registry.npmjs.org/cli-spinners/-/cli-spinners-2.9.0.tgz", - "integrity": "sha512-4/aL9X3Wh0yiMQlE+eeRhWP6vclO3QRtw1JHKIT0FFUs5FjpFmESqtMvYZ0+lbzBw900b95mS0hohy+qn2VK/g==", + "version": "2.9.2", + "resolved": "https://registry.npmjs.org/cli-spinners/-/cli-spinners-2.9.2.tgz", + "integrity": "sha512-ywqV+5MmyL4E7ybXgKys4DugZbX0FC6LnwrhjuykIjnK9k8OQacQ7axGKnjDXWNhns0xot3bZI5h55H8yo9cJg==", "engines": { "node": ">=6" }, @@ -1637,12 +3476,121 @@ "url": "https://github.com/sponsors/sindresorhus" } }, - "node_modules/clone": { - "version": "1.0.4", - "resolved": "https://registry.npmjs.org/clone/-/clone-1.0.4.tgz", - "integrity": "sha512-JQHZ2QMW6l3aH/j6xCqQThY/9OH4D/9ls34cgkUBiEeocRTU04tHfKPBsUK1PqZCUQM7GiA0IIXJSuXHI64Kbg==", + "node_modules/cliui": { + "version": "8.0.1", + "resolved": "https://registry.npmjs.org/cliui/-/cliui-8.0.1.tgz", + "integrity": "sha512-BSeNnyus75C4//NQ9gQt1/csTXyo/8Sb+afLAkzAptFuMsod9HFokGNudZpi/oQV73hnVK+sR+5PVRMd+Dr7YQ==", + "dependencies": { + "string-width": "^4.2.0", + "strip-ansi": "^6.0.1", + "wrap-ansi": "^7.0.0" + }, "engines": { - "node": ">=0.8" + "node": ">=12" + } + }, + "node_modules/cliui/node_modules/ansi-regex": { + "version": "5.0.1", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", + "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", + "engines": { + "node": ">=8" + } + }, + "node_modules/cliui/node_modules/ansi-styles": { + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", + "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", + "dependencies": { + "color-convert": "^2.0.1" + }, + "engines": { + "node": ">=8" + }, + "funding": { + "url": "https://github.com/chalk/ansi-styles?sponsor=1" + } + }, + "node_modules/cliui/node_modules/color-convert": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", + "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", + "dependencies": { + "color-name": "~1.1.4" + }, + "engines": { + "node": ">=7.0.0" + } + }, + "node_modules/cliui/node_modules/color-name": { + "version": "1.1.4", + "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", + "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==" + }, + "node_modules/cliui/node_modules/emoji-regex": { + "version": "8.0.0", + "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", + "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==" + }, + "node_modules/cliui/node_modules/string-width": { + "version": "4.2.3", + "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", + "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", + "dependencies": { + "emoji-regex": "^8.0.0", + "is-fullwidth-code-point": "^3.0.0", + "strip-ansi": "^6.0.1" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/cliui/node_modules/strip-ansi": { + "version": "6.0.1", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", + "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", + "dependencies": { + "ansi-regex": "^5.0.1" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/cliui/node_modules/wrap-ansi": { + "version": "7.0.0", + "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz", + "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==", + "dependencies": { + "ansi-styles": "^4.0.0", + "string-width": "^4.1.0", + "strip-ansi": "^6.0.0" + }, + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/chalk/wrap-ansi?sponsor=1" + } + }, + "node_modules/clsx": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/clsx/-/clsx-2.1.1.tgz", + "integrity": "sha512-eYm0QWBtUrBWZWG0d386OGAw16Z995PiOVo2B7bjWSbHedGl5e0ZWaq65kOGgUSNesEIDkB9ISbTg/JK9dhCZA==", + "engines": { + "node": ">=6" + } + }, + "node_modules/color": { + "version": "4.2.3", + "resolved": "https://registry.npmjs.org/color/-/color-4.2.3.tgz", + "integrity": "sha512-1rXeuUUiGGrykh+CeBdu5Ie7OJwinCgQY0bc7GCRxy5xVHy+moaqkpL/jqQq0MtQOeYcrqEz4abc5f0KtU7W4A==", + "optional": true, + "dependencies": { + "color-convert": "^2.0.1", + "color-string": "^1.9.0" + }, + "engines": { + "node": ">=12.5.0" } }, "node_modules/color-convert": { @@ -1658,6 +3606,34 @@ "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", "integrity": "sha512-72fSenhMw2HZMTVHeCA9KCmpEIbzWiQsjN+BHcBbS9vr1mtt+vJjPdksIBNUmKAW8TFUDPJK5SUU3QhE9NEXDw==" }, + "node_modules/color-string": { + "version": "1.9.1", + "resolved": "https://registry.npmjs.org/color-string/-/color-string-1.9.1.tgz", + "integrity": "sha512-shrVawQFojnZv6xM40anx4CkoDP+fZsw/ZerEMsW/pyzsRbElpsL/DBVW7q3ExxwusdNXI3lXpuhEZkzs8p5Eg==", + "optional": true, + "dependencies": { + "color-name": "^1.0.0", + "simple-swizzle": "^0.2.2" + } + }, + "node_modules/color/node_modules/color-convert": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", + "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", + "optional": true, + "dependencies": { + "color-name": "~1.1.4" + }, + "engines": { + "node": ">=7.0.0" + } + }, + "node_modules/color/node_modules/color-name": { + "version": "1.1.4", + "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", + "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", + "optional": true + }, "node_modules/comma-separated-tokens": { "version": "2.0.3", "resolved": "https://registry.npmjs.org/comma-separated-tokens/-/comma-separated-tokens-2.0.3.tgz", @@ -1673,14 +3649,14 @@ "integrity": "sha512-L3sHRo1pXXEqX8VU28kfgUY+YGsk09hPqZiZmLacNib6XNTCM8ubYeT7ryXQw8asB1sKgcU5lkB7ONug08aB8w==" }, "node_modules/convert-source-map": { - "version": "1.9.0", - "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-1.9.0.tgz", - "integrity": "sha512-ASFBup0Mz1uyiIjANan1jzLQami9z1PoYSZCiiYW2FczPbenXc45FZdBZLzOT+r6+iciuEModtmCti+hjaAk0A==" + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-2.0.0.tgz", + "integrity": "sha512-Kvp459HrV2FEJ1CAsi1Ku+MY3kasH19TFykTz2xWmMeq6bk2NU3XXvfJ+Q61m0xktWwt+1HSYf3JZsTms3aRJg==" }, "node_modules/cookie": { - "version": "0.5.0", - "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.5.0.tgz", - "integrity": "sha512-YZ3GUyn/o8gfKJlnlX7g7xq4gyO6OSuhGPKaaGssGB2qgDUS0gPgtTvoyZLTt9Ab6dC4hfc9dV5arkvc/OCmrw==", + "version": "0.6.0", + "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.6.0.tgz", + "integrity": "sha512-U71cyTamuh1CRNCfpGY6to28lxvNwPG4Guz/EVjgf3Jmzv0vlDp1atT9eS5dDjMYHucpHbWns6Lwf3BKz6svdw==", "engines": { "node": ">= 0.6" } @@ -1698,10 +3674,107 @@ "node": ">= 8" } }, + "node_modules/css-blank-pseudo": { + "version": "6.0.2", + "resolved": "https://registry.npmjs.org/css-blank-pseudo/-/css-blank-pseudo-6.0.2.tgz", + "integrity": "sha512-J/6m+lsqpKPqWHOifAFtKFeGLOzw3jR92rxQcwRUfA/eTuZzKfKlxOmYDx2+tqOPQAueNvBiY8WhAeHu5qNmTg==", + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/csstools" + }, + { + "type": "opencollective", + "url": "https://opencollective.com/csstools" + } + ], + "dependencies": { + "postcss-selector-parser": "^6.0.13" + }, + "engines": { + "node": "^14 || ^16 || >=18" + }, + "peerDependencies": { + "postcss": "^8.4" + } + }, + "node_modules/css-has-pseudo": { + "version": "6.0.5", + "resolved": "https://registry.npmjs.org/css-has-pseudo/-/css-has-pseudo-6.0.5.tgz", + "integrity": "sha512-ZTv6RlvJJZKp32jPYnAJVhowDCrRrHUTAxsYSuUPBEDJjzws6neMnzkRblxtgmv1RgcV5dhH2gn7E3wA9Wt6lw==", + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/csstools" + }, + { + "type": "opencollective", + "url": "https://opencollective.com/csstools" + } + ], + "dependencies": { + "@csstools/selector-specificity": "^3.1.1", + "postcss-selector-parser": "^6.0.13", + "postcss-value-parser": "^4.2.0" + }, + "engines": { + "node": "^14 || ^16 || >=18" + }, + "peerDependencies": { + "postcss": "^8.4" + } + }, + "node_modules/css-prefers-color-scheme": { + "version": "9.0.1", + "resolved": "https://registry.npmjs.org/css-prefers-color-scheme/-/css-prefers-color-scheme-9.0.1.tgz", + "integrity": "sha512-iFit06ochwCKPRiWagbTa1OAWCvWWVdEnIFd8BaRrgO8YrrNh4RAWUQTFcYX5tdFZgFl1DJ3iiULchZyEbnF4g==", + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/csstools" + }, + { + "type": "opencollective", + "url": "https://opencollective.com/csstools" + } + ], + "engines": { + "node": "^14 || ^16 || >=18" + }, + "peerDependencies": { + "postcss": "^8.4" + } + }, + "node_modules/cssdb": { + "version": "8.1.0", + "resolved": "https://registry.npmjs.org/cssdb/-/cssdb-8.1.0.tgz", + "integrity": "sha512-BQN57lfS4dYt2iL0LgyrlDbefZKEtUyrO8rbzrbGrqBk6OoyNTQLF+porY9DrpDBjLo4NEvj2IJttC7vf3x+Ew==", + "funding": [ + { + "type": "opencollective", + "url": "https://opencollective.com/csstools" + }, + { + "type": "github", + "url": "https://github.com/sponsors/csstools" + } + ] + }, + "node_modules/cssesc": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/cssesc/-/cssesc-3.0.0.tgz", + "integrity": "sha512-/Tb/JcjK111nNScGob5MNtsntNM1aCNUDipB/TkwZFhyDrrE47SOx/18wF2bbjgc3ZzCSKW1T5nt5EbFoAz/Vg==", + "bin": { + "cssesc": "bin/cssesc" + }, + "engines": { + "node": ">=4" + } + }, "node_modules/debug": { - "version": "4.3.4", - "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", - "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", + "version": "4.3.6", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.6.tgz", + "integrity": "sha512-O/09Bd4Z1fBrU4VzkhFqVgpPzaGbw6Sm9FEkBT1A/YBXQFGuuSxa1dN2nxgxS34JmKXqYx8CZAwEVoJFImUXIg==", "dependencies": { "ms": "2.1.2" }, @@ -1726,98 +3799,6 @@ "url": "https://github.com/sponsors/wooorm" } }, - "node_modules/deepmerge-ts": { - "version": "4.3.0", - "resolved": "https://registry.npmjs.org/deepmerge-ts/-/deepmerge-ts-4.3.0.tgz", - "integrity": "sha512-if3ZYdkD2dClhnXR5reKtG98cwyaRT1NeugQoAPTTfsOpV9kqyeiBF9Qa5RHjemb3KzD5ulqygv6ED3t5j9eJw==", - "engines": { - "node": ">=12.4.0" - } - }, - "node_modules/default-browser": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/default-browser/-/default-browser-4.0.0.tgz", - "integrity": "sha512-wX5pXO1+BrhMkSbROFsyxUm0i/cJEScyNhA4PPxc41ICuv05ZZB/MX28s8aZx6xjmatvebIapF6hLEKEcpneUA==", - "dependencies": { - "bundle-name": "^3.0.0", - "default-browser-id": "^3.0.0", - "execa": "^7.1.1", - "titleize": "^3.0.0" - }, - "engines": { - "node": ">=14.16" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/default-browser-id": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/default-browser-id/-/default-browser-id-3.0.0.tgz", - "integrity": "sha512-OZ1y3y0SqSICtE8DE4S8YOE9UZOJ8wO16fKWVP5J1Qz42kV9jcnMVFrEE/noXb/ss3Q4pZIH79kxofzyNNtUNA==", - "dependencies": { - "bplist-parser": "^0.2.0", - "untildify": "^4.0.0" - }, - "engines": { - "node": ">=12" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/default-browser/node_modules/execa": { - "version": "7.1.1", - "resolved": "https://registry.npmjs.org/execa/-/execa-7.1.1.tgz", - "integrity": "sha512-wH0eMf/UXckdUYnO21+HDztteVv05rq2GXksxT4fCGeHkBhw1DROXh40wcjMcRqDOWE7iPJ4n3M7e2+YFP+76Q==", - "dependencies": { - "cross-spawn": "^7.0.3", - "get-stream": "^6.0.1", - "human-signals": "^4.3.0", - "is-stream": "^3.0.0", - "merge-stream": "^2.0.0", - "npm-run-path": "^5.1.0", - "onetime": "^6.0.0", - "signal-exit": "^3.0.7", - "strip-final-newline": "^3.0.0" - }, - "engines": { - "node": "^14.18.0 || ^16.14.0 || >=18.0.0" - }, - "funding": { - "url": "https://github.com/sindresorhus/execa?sponsor=1" - } - }, - "node_modules/default-browser/node_modules/human-signals": { - "version": "4.3.1", - "resolved": "https://registry.npmjs.org/human-signals/-/human-signals-4.3.1.tgz", - "integrity": "sha512-nZXjEF2nbo7lIw3mgYjItAfgQXog3OjJogSbKa2CQIIvSGWcKgeJnQlNXip6NglNzYH45nSRiEVimMvYL8DDqQ==", - "engines": { - "node": ">=14.18.0" - } - }, - "node_modules/defaults": { - "version": "1.0.4", - "resolved": "https://registry.npmjs.org/defaults/-/defaults-1.0.4.tgz", - "integrity": "sha512-eFuaLoy/Rxalv2kr+lqMlUnrDWV+3j4pljOIJgLIhI058IQfWJ7vXhyEIHu+HtC738klGALYxOKDO0bQP3tg8A==", - "dependencies": { - "clone": "^1.0.2" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/define-lazy-prop": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/define-lazy-prop/-/define-lazy-prop-3.0.0.tgz", - "integrity": "sha512-N+MeXYoqr3pOgn8xfyRPREN7gHakLYjhsHhWGT3fWAiL4IkAt0iDw14QiiEm2bE30c5XX5q0FtAA3CK5f9/BUg==", - "engines": { - "node": ">=12" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, "node_modules/dequal": { "version": "2.0.3", "resolved": "https://registry.npmjs.org/dequal/-/dequal-2.0.3.tgz", @@ -1826,15 +3807,47 @@ "node": ">=6" } }, + "node_modules/detect-libc": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/detect-libc/-/detect-libc-2.0.3.tgz", + "integrity": "sha512-bwy0MGW55bG41VqxxypOsdSdGqLwXPI/focwgTYCFMbdUiBAxLg9CFzG08sz2aqzknwiX7Hkl0bQENjg8iLByw==", + "optional": true, + "engines": { + "node": ">=8" + } + }, + "node_modules/deterministic-object-hash": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/deterministic-object-hash/-/deterministic-object-hash-2.0.2.tgz", + "integrity": "sha512-KxektNH63SrbfUyDiwXqRb1rLwKt33AmMv+5Nhsw1kqZ13SJBRTgZHtGbE+hH3a1mVW1cz+4pqSWVPAtLVXTzQ==", + "dependencies": { + "base-64": "^1.0.0" + }, + "engines": { + "node": ">=18" + } + }, "node_modules/devalue": { - "version": "4.3.2", - "resolved": "https://registry.npmjs.org/devalue/-/devalue-4.3.2.tgz", - "integrity": "sha512-KqFl6pOgOW+Y6wJgu80rHpo2/3H07vr8ntR9rkkFIRETewbf5GaYYcakYfiKz89K+sLsuPkQIZaXDMjUObZwWg==" + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/devalue/-/devalue-5.0.0.tgz", + "integrity": "sha512-gO+/OMXF7488D+u3ue+G7Y4AA3ZmUnB3eHJXmBTgNHvr4ZNzl36A0ZtG+XCRNYCkYx/bFmw4qtkoFLa+wSrwAA==" + }, + "node_modules/devlop": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/devlop/-/devlop-1.1.0.tgz", + "integrity": "sha512-RWmIqhcFf1lRYBvNmr7qTNuyCt/7/ns2jbpp1+PalgE/rDQcBT0fioSMUpJ93irlUhC5hrg4cYqe6U+0ImW0rA==", + "dependencies": { + "dequal": "^2.0.0" + }, + "funding": { + "type": "github", + "url": "https://github.com/sponsors/wooorm" + } }, "node_modules/diff": { - "version": "5.1.0", - "resolved": "https://registry.npmjs.org/diff/-/diff-5.1.0.tgz", - "integrity": "sha512-D+mk+qE8VC/PAUrlAU34N+VfXev0ghe5ywmpqrawphmVZc1bEfn56uo9qpyGp1p4xpzOHkSW4ztBd6L7Xx4ACw==", + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/diff/-/diff-5.2.0.tgz", + "integrity": "sha512-uIFDxqpRZGZ6ThOk84hEfqWoHx2devRFvpTZcTHur85vImfaxUbTW9Ryh4CpCuDnToOP1CEtXKIgytHBPVff5A==", "engines": { "node": ">=0.3.1" } @@ -1845,9 +3858,9 @@ "integrity": "sha512-+HlytyjlPKnIG8XuRG8WvmBP8xs8P71y+SKKS6ZXWoEgLuePxtDoUEiH7WkdePWrQ5JBpE6aoVqfZfJUQkjXwA==" }, "node_modules/dset": { - "version": "3.1.2", - "resolved": "https://registry.npmjs.org/dset/-/dset-3.1.2.tgz", - "integrity": "sha512-g/M9sqy3oHe477Ar4voQxWtaPIFw1jTdKZuomOjhCcBx9nHUNn0pu6NopuFFrTh/TRZIKEj+76vLWFu9BNKk+Q==", + "version": "3.1.3", + "resolved": "https://registry.npmjs.org/dset/-/dset-3.1.3.tgz", + "integrity": "sha512-20TuZZHCEZ2O71q9/+8BwKwZ0QtD9D8ObhrihJPr+vLLYlSuAU3/zL4cSlgbfeoGHTjCSJBa7NGcrF9/Bx/WJQ==", "engines": { "node": ">=4" } @@ -1858,69 +3871,51 @@ "integrity": "sha512-I88TYZWc9XiYHRQ4/3c5rjjfgkjhLyW2luGIheGERbNQ6OY7yTybanSpDXZa8y7VUP9YmDcYa+eyq4ca7iLqWA==" }, "node_modules/electron-to-chromium": { - "version": "1.4.462", - "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.4.462.tgz", - "integrity": "sha512-ux2LqN9JKRBDKXMT+78jtiBLPiXf+rLtYlsrOg5Qn7uv6Cbg7+9JyIalE3wcqkOdB2wPCUYNWAuL7suKRMHe9w==" + "version": "1.4.828", + "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.4.828.tgz", + "integrity": "sha512-QOIJiWpQJDHAVO4P58pwb133Cwee0nbvy/MV1CwzZVGpkH1RX33N3vsaWRCpR6bF63AAq366neZrRTu7Qlsbbw==" }, "node_modules/emmet": { - "version": "2.4.5", - "resolved": "https://registry.npmjs.org/emmet/-/emmet-2.4.5.tgz", - "integrity": "sha512-xOiVNINJFh0dMik+KzXSEYbAnFLTnadEzanxj7+F15uIf6avQwu3uPa1wI/8AFtOWKZ8lHg7TjC83wXcPhgOPw==", + "version": "2.4.7", + "resolved": "https://registry.npmjs.org/emmet/-/emmet-2.4.7.tgz", + "integrity": "sha512-O5O5QNqtdlnQM2bmKHtJgyChcrFMgQuulI+WdiOw2NArzprUqqxUW6bgYtKvzKgrsYpuLWalOkdhNP+1jluhCA==", + "license": "MIT", + "workspaces": [ + "./packages/scanner", + "./packages/abbreviation", + "./packages/css-abbreviation", + "./" + ], "dependencies": { "@emmetio/abbreviation": "^2.3.3", "@emmetio/css-abbreviation": "^2.1.8" } }, "node_modules/emoji-regex": { - "version": "9.2.2", - "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-9.2.2.tgz", - "integrity": "sha512-L18DaJsXSUk2+42pv8mLs5jJT2hqFkFE4j21wOmgbUqsZ2hL72NsUU785g9RXgo3s0ZNgVl42TiHp3ZtOv/Vyg==" + "version": "10.3.0", + "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-10.3.0.tgz", + "integrity": "sha512-QpLs9D9v9kArv4lfDEgg1X/gN5XLnf/A6l9cs8SPZLRZR3ZkY9+kwIQTxm+fsSej5UMYGE8fdoaZVIBlqG0XTw==" }, - "node_modules/es-module-lexer": { - "version": "1.3.0", - "resolved": "https://registry.npmjs.org/es-module-lexer/-/es-module-lexer-1.3.0.tgz", - "integrity": "sha512-vZK7T0N2CBmBOixhmjdqx2gWVbFZ4DXZ/NyRMZVlJXPa7CyFS+/a4QQsDGDQy9ZfEzxFuNEsMLeQJnKP2p5/JA==" - }, - "node_modules/esbuild": { - "version": "0.17.19", - "resolved": "https://registry.npmjs.org/esbuild/-/esbuild-0.17.19.tgz", - "integrity": "sha512-XQ0jAPFkK/u3LcVRcvVHQcTIqD6E2H1fvZMA5dQPSOWb3suUbWbfbRf94pjc0bNzRYLfIrDRQXr7X+LHIm5oHw==", - "hasInstallScript": true, - "bin": { - "esbuild": "bin/esbuild" - }, + "node_modules/entities": { + "version": "4.5.0", + "resolved": "https://registry.npmjs.org/entities/-/entities-4.5.0.tgz", + "integrity": "sha512-V0hjH4dGPh9Ao5p0MoRY6BVqtwCjhz6vI5LT8AJ55H+4g9/4vbHx1I54fS0XuclLhDHArPQCiMjDxjaL8fPxhw==", "engines": { - "node": ">=12" + "node": ">=0.12" }, - "optionalDependencies": { - "@esbuild/android-arm": "0.17.19", - "@esbuild/android-arm64": "0.17.19", - "@esbuild/android-x64": "0.17.19", - "@esbuild/darwin-arm64": "0.17.19", - "@esbuild/darwin-x64": "0.17.19", - "@esbuild/freebsd-arm64": "0.17.19", - "@esbuild/freebsd-x64": "0.17.19", - "@esbuild/linux-arm": "0.17.19", - "@esbuild/linux-arm64": "0.17.19", - "@esbuild/linux-ia32": "0.17.19", - "@esbuild/linux-loong64": "0.17.19", - "@esbuild/linux-mips64el": "0.17.19", - "@esbuild/linux-ppc64": "0.17.19", - "@esbuild/linux-riscv64": "0.17.19", - "@esbuild/linux-s390x": "0.17.19", - "@esbuild/linux-x64": "0.17.19", - "@esbuild/netbsd-x64": "0.17.19", - "@esbuild/openbsd-x64": "0.17.19", - "@esbuild/sunos-x64": "0.17.19", - "@esbuild/win32-arm64": "0.17.19", - "@esbuild/win32-ia32": "0.17.19", - "@esbuild/win32-x64": "0.17.19" + "funding": { + "url": "https://github.com/fb55/entities?sponsor=1" } }, + "node_modules/es-module-lexer": { + "version": "1.5.4", + "resolved": "https://registry.npmjs.org/es-module-lexer/-/es-module-lexer-1.5.4.tgz", + "integrity": "sha512-MVNK56NiMrOwitFB7cqDwq0CQutbw+0BvLshJSse0MUNU+y1FC3bUS/AQg7oUng+/wKrrki7JfmwtVHkVfPLlw==" + }, "node_modules/escalade": { - "version": "3.1.1", - "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.1.1.tgz", - "integrity": "sha512-k0er2gUkLf8O0zKJiAhmkTnJlTvINGv7ygDNPbeIsX/TJjGJZHuh9B2UxbsaEkmlEo9MfhrSzmhIlhRlI2GXnw==", + "version": "3.1.2", + "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.1.2.tgz", + "integrity": "sha512-ErCHMCae19vR8vQGe50xIsVomy19rg6gFu3+r3jkEO46suLMWBksvVyoGgQV+jOfl84ZSOSlmv6Gxa89PmTGmA==", "engines": { "node": ">=6" } @@ -1946,35 +3941,35 @@ } }, "node_modules/estree-walker": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/estree-walker/-/estree-walker-3.0.0.tgz", - "integrity": "sha512-s6ceX0NFiU/vKPiKvFdR83U1Zffu7upwZsGwpoqfg5rbbq1l50WQ5hCeIvM6E6oD4shUHCYMsiFPns4Jk0YfMQ==" - }, - "node_modules/events": { - "version": "3.3.0", - "resolved": "https://registry.npmjs.org/events/-/events-3.3.0.tgz", - "integrity": "sha512-mQw+2fkQbALzQ7V0MY0IqdnXNOeTtP4r0lN9z7AAawCXgqea7bDii20AYrIBrFd/Hx0M2Ocz6S111CaFkUcb0Q==", - "engines": { - "node": ">=0.8.x" + "version": "3.0.3", + "resolved": "https://registry.npmjs.org/estree-walker/-/estree-walker-3.0.3.tgz", + "integrity": "sha512-7RUKfXgSMMkzt6ZuXmqapOurLGPPfgj6l9uRZ7lRGolvk0y2yocc35LdcxKC5PQZdn2DMqioAQ2NoWcrTKmm6g==", + "dependencies": { + "@types/estree": "^1.0.0" } }, + "node_modules/eventemitter3": { + "version": "5.0.1", + "resolved": "https://registry.npmjs.org/eventemitter3/-/eventemitter3-5.0.1.tgz", + "integrity": "sha512-GWkBvjiSZK87ELrYOSESUYeVIc9mvLLf/nXalMOS5dYrgZq9o5OVkbZAVM06CVxYsCwH9BDZFPlQTlPA1j4ahA==" + }, "node_modules/execa": { - "version": "6.1.0", - "resolved": "https://registry.npmjs.org/execa/-/execa-6.1.0.tgz", - "integrity": "sha512-QVWlX2e50heYJcCPG0iWtf8r0xjEYfz/OYLGDYH+IyjWezzPNxz63qNFOu0l4YftGWuizFVZHHs8PrLU5p2IDA==", + "version": "8.0.1", + "resolved": "https://registry.npmjs.org/execa/-/execa-8.0.1.tgz", + "integrity": "sha512-VyhnebXciFV2DESc+p6B+y0LjSm0krU4OgJN44qFAhBY0TJ+1V61tYD2+wHusZ6F9n5K+vl8k0sTy7PEfV4qpg==", "dependencies": { "cross-spawn": "^7.0.3", - "get-stream": "^6.0.1", - "human-signals": "^3.0.1", + "get-stream": "^8.0.1", + "human-signals": "^5.0.0", "is-stream": "^3.0.0", "merge-stream": "^2.0.0", "npm-run-path": "^5.1.0", "onetime": "^6.0.0", - "signal-exit": "^3.0.7", + "signal-exit": "^4.1.0", "strip-final-newline": "^3.0.0" }, "engines": { - "node": "^12.20.0 || ^14.13.1 || >=16.0.0" + "node": ">=16.17" }, "funding": { "url": "https://github.com/sindresorhus/execa?sponsor=1" @@ -1996,10 +3991,16 @@ "node": ">=0.10.0" } }, + "node_modules/fast-deep-equal": { + "version": "3.1.3", + "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz", + "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==", + "license": "MIT" + }, "node_modules/fast-glob": { - "version": "3.3.0", - "resolved": "https://registry.npmjs.org/fast-glob/-/fast-glob-3.3.0.tgz", - "integrity": "sha512-ChDuvbOypPuNjO8yIDf36x7BlZX1smcUMTTcyoIjycexOxd6DFsKsg21qVBzEmr3G7fUKIRy2/psii+CIUt7FA==", + "version": "3.3.2", + "resolved": "https://registry.npmjs.org/fast-glob/-/fast-glob-3.3.2.tgz", + "integrity": "sha512-oX2ruAFQwf/Orj8m737Y5adxDQO0LAB7/S5MnxCdTNDd4p6BsyIVsv9JQsATbTSq8KHRpLwIHbVlUNatxd+1Ow==", "dependencies": { "@nodelib/fs.stat": "^2.0.2", "@nodelib/fs.walk": "^1.2.3", @@ -2011,18 +4012,24 @@ "node": ">=8.6.0" } }, + "node_modules/fast-uri": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/fast-uri/-/fast-uri-3.0.1.tgz", + "integrity": "sha512-MWipKbbYiYI0UC7cl8m/i/IWTqfC8YXsqjzybjddLsFjStroQzsHXkc73JutMvBiXmOvapk+axIl79ig5t55Bw==", + "license": "MIT" + }, "node_modules/fastq": { - "version": "1.15.0", - "resolved": "https://registry.npmjs.org/fastq/-/fastq-1.15.0.tgz", - "integrity": "sha512-wBrocU2LCXXa+lWBt8RoIRD89Fi8OdABODa/kEnyeyjS5aZO5/GNvI5sEINADqP/h8M29UHTHUb53sUu5Ihqdw==", + "version": "1.16.0", + "resolved": "https://registry.npmjs.org/fastq/-/fastq-1.16.0.tgz", + "integrity": "sha512-ifCoaXsDrsdkWTtiNJX5uzHDsrck5TzfKKDcuFFTIrrc/BS076qgEIfoIy1VeZqViznfKiysPYTh/QeHtnIsYA==", "dependencies": { "reusify": "^1.0.4" } }, "node_modules/fill-range": { - "version": "7.0.1", - "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", - "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", + "version": "7.1.1", + "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.1.1.tgz", + "integrity": "sha512-YsGpe3WHLK8ZYi4tWDg2Jy3ebRz2rXowDxnld4bkQB00cc/1Zw9AWnC0i9ztDJitivtQvaI9KaLyKrc+hBW0yg==", "dependencies": { "to-regex-range": "^5.0.1" }, @@ -2031,15 +4038,23 @@ } }, "node_modules/find-up": { - "version": "5.0.0", - "resolved": "https://registry.npmjs.org/find-up/-/find-up-5.0.0.tgz", - "integrity": "sha512-78/PXT1wlLLDgTzDs7sjq9hzz0vXD+zn+7wypEe4fXQxCmdmqfGsEPQxmiCSQI3ajFV91bVSsvNtrJRiW6nGng==", + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/find-up/-/find-up-4.1.0.tgz", + "integrity": "sha512-PpOwAdQ/YlXQ2vj8a3h8IipDuYRi3wceVQQGYWxNINccq40Anw7BlsEXCMbt1Zt+OLA6Fq9suIpIWD0OsnISlw==", "dependencies": { - "locate-path": "^6.0.0", + "locate-path": "^5.0.0", "path-exists": "^4.0.0" }, "engines": { - "node": ">=10" + "node": ">=8" + } + }, + "node_modules/find-up-simple": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/find-up-simple/-/find-up-simple-1.0.0.tgz", + "integrity": "sha512-q7Us7kcjj2VMePAa02hDAF6d+MzsdsAWEwYyOpwUtlerRBkOEPBCRZrAV4XfcSN8fHAgaD0hP7miwoay6DCprw==", + "engines": { + "node": ">=18" }, "funding": { "url": "https://github.com/sponsors/sindresorhus" @@ -2054,10 +4069,30 @@ "pkg-dir": "^4.2.0" } }, + "node_modules/flattie": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/flattie/-/flattie-1.1.1.tgz", + "integrity": "sha512-9UbaD6XdAL97+k/n+N7JwX46K/M6Zc6KcFYskrYL8wbBV/Uyk0CTAMY0VT+qiK5PM7AIc9aTWYtq65U7T+aCNQ==", + "engines": { + "node": ">=8" + } + }, + "node_modules/fraction.js": { + "version": "4.3.7", + "resolved": "https://registry.npmjs.org/fraction.js/-/fraction.js-4.3.7.tgz", + "integrity": "sha512-ZsDfxO51wGAXREY55a7la9LScWpwv9RxIrYABrlvOFBlH/ShPnrtsXeuUIfXKKOVicNxQ+o8JTbJvjS4M89yew==", + "engines": { + "node": "*" + }, + "funding": { + "type": "patreon", + "url": "https://github.com/sponsors/rawify" + } + }, "node_modules/fsevents": { - "version": "2.3.2", - "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.2.tgz", - "integrity": "sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==", + "version": "2.3.3", + "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.3.tgz", + "integrity": "sha512-5xoDfX+fL7faATnagmWPpbFtwh/R77WmMMqqHGS65C3vvB0YHrgF+B1YmZ3441tMj5n63k0212XNoJwzlhffQw==", "hasInstallScript": true, "optional": true, "os": [ @@ -2067,11 +4102,6 @@ "node": "^8.16.0 || ^10.6.0 || >=11.0.0" } }, - "node_modules/function-bind": { - "version": "1.1.1", - "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", - "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==" - }, "node_modules/gensync": { "version": "1.0.0-beta.2", "resolved": "https://registry.npmjs.org/gensync/-/gensync-1.0.0-beta.2.tgz", @@ -2080,12 +4110,31 @@ "node": ">=6.9.0" } }, - "node_modules/get-stream": { - "version": "6.0.1", - "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-6.0.1.tgz", - "integrity": "sha512-ts6Wi+2j3jQjqi70w5AlN8DFnkSwC+MqmxEzdEALB2qXZYV3X/b1CTfgPLGJNMeAWxdPfU8FO1ms3NUfaHCPYg==", + "node_modules/get-caller-file": { + "version": "2.0.5", + "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-2.0.5.tgz", + "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==", "engines": { - "node": ">=10" + "node": "6.* || 8.* || >= 10.*" + } + }, + "node_modules/get-east-asian-width": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/get-east-asian-width/-/get-east-asian-width-1.2.0.tgz", + "integrity": "sha512-2nk+7SIVb14QrgXFHcm84tD4bKQz0RxPuMT8Ag5KPOq7J5fEmAg0UbXdTOSHqNuHSU28k55qnceesxXRZGzKWA==", + "engines": { + "node": ">=18" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/get-stream": { + "version": "8.0.1", + "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-8.0.1.tgz", + "integrity": "sha512-VaUJspBffn/LMCJVoMvSAdmscJyS1auj5Zulnn5UoYcY531UWmdwhRWkcGKnGU93m5HSXP9LP2usOryrBtQowA==", + "engines": { + "node": ">=16" }, "funding": { "url": "https://github.com/sponsors/sindresorhus" @@ -2154,17 +4203,6 @@ "js-yaml": "bin/js-yaml.js" } }, - "node_modules/has": { - "version": "1.0.3", - "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", - "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", - "dependencies": { - "function-bind": "^1.1.1" - }, - "engines": { - "node": ">= 0.4.0" - } - }, "node_modules/has-flag": { "version": "3.0.0", "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", @@ -2173,17 +4211,35 @@ "node": ">=4" } }, - "node_modules/hast-util-from-parse5": { - "version": "7.1.2", - "resolved": "https://registry.npmjs.org/hast-util-from-parse5/-/hast-util-from-parse5-7.1.2.tgz", - "integrity": "sha512-Nz7FfPBuljzsN3tCQ4kCBKqdNhQE2l0Tn+X1ubgKBPRoiDIu1mL08Cfw4k7q71+Duyaw7DXDN+VTAp4Vh3oCOw==", + "node_modules/hast-util-from-html": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/hast-util-from-html/-/hast-util-from-html-2.0.1.tgz", + "integrity": "sha512-RXQBLMl9kjKVNkJTIO6bZyb2n+cUH8LFaSSzo82jiLT6Tfc+Pt7VQCS+/h3YwG4jaNE2TA2sdJisGWR+aJrp0g==", "dependencies": { - "@types/hast": "^2.0.0", - "@types/unist": "^2.0.0", - "hastscript": "^7.0.0", + "@types/hast": "^3.0.0", + "devlop": "^1.1.0", + "hast-util-from-parse5": "^8.0.0", + "parse5": "^7.0.0", + "vfile": "^6.0.0", + "vfile-message": "^4.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/unified" + } + }, + "node_modules/hast-util-from-parse5": { + "version": "8.0.1", + "resolved": "https://registry.npmjs.org/hast-util-from-parse5/-/hast-util-from-parse5-8.0.1.tgz", + "integrity": "sha512-Er/Iixbc7IEa7r/XLtuG52zoqn/b3Xng/w6aZQ0xGVxzhw5xUFxcRqdPzP6yFi/4HBYRaifaI5fQ1RH8n0ZeOQ==", + "dependencies": { + "@types/hast": "^3.0.0", + "@types/unist": "^3.0.0", + "devlop": "^1.0.0", + "hastscript": "^8.0.0", "property-information": "^6.0.0", - "vfile": "^5.0.0", - "vfile-location": "^4.0.0", + "vfile": "^6.0.0", + "vfile-location": "^5.0.0", "web-namespaces": "^2.0.0" }, "funding": { @@ -2191,12 +4247,24 @@ "url": "https://opencollective.com/unified" } }, - "node_modules/hast-util-parse-selector": { - "version": "3.1.1", - "resolved": "https://registry.npmjs.org/hast-util-parse-selector/-/hast-util-parse-selector-3.1.1.tgz", - "integrity": "sha512-jdlwBjEexy1oGz0aJ2f4GKMaVKkA9jwjr4MjAAI22E5fM/TXVZHuS5OpONtdeIkRKqAaryQ2E9xNQxijoThSZA==", + "node_modules/hast-util-is-element": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/hast-util-is-element/-/hast-util-is-element-3.0.0.tgz", + "integrity": "sha512-Val9mnv2IWpLbNPqc/pUem+a7Ipj2aHacCwgNfTiK0vJKl0LF+4Ba4+v1oPHFpf3bLYmreq0/l3Gud9S5OH42g==", "dependencies": { - "@types/hast": "^2.0.0" + "@types/hast": "^3.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/unified" + } + }, + "node_modules/hast-util-parse-selector": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/hast-util-parse-selector/-/hast-util-parse-selector-4.0.0.tgz", + "integrity": "sha512-wkQCkSYoOGCRKERFWcxMVMOcYE2K1AaNLU8DXS9arxnLOUEWbOXKXiJUNzEpqZ3JOKpnha3jkFrumEjVliDe7A==", + "dependencies": { + "@types/hast": "^3.0.0" }, "funding": { "type": "opencollective", @@ -2204,19 +4272,21 @@ } }, "node_modules/hast-util-raw": { - "version": "7.2.3", - "resolved": "https://registry.npmjs.org/hast-util-raw/-/hast-util-raw-7.2.3.tgz", - "integrity": "sha512-RujVQfVsOrxzPOPSzZFiwofMArbQke6DJjnFfceiEbFh7S05CbPt0cYN+A5YeD3pso0JQk6O1aHBnx9+Pm2uqg==", + "version": "9.0.1", + "resolved": "https://registry.npmjs.org/hast-util-raw/-/hast-util-raw-9.0.1.tgz", + "integrity": "sha512-5m1gmba658Q+lO5uqL5YNGQWeh1MYWZbZmWrM5lncdcuiXuo5E2HT/CIOp0rLF8ksfSwiCVJ3twlgVRyTGThGA==", "dependencies": { - "@types/hast": "^2.0.0", - "@types/parse5": "^6.0.0", - "hast-util-from-parse5": "^7.0.0", - "hast-util-to-parse5": "^7.0.0", - "html-void-elements": "^2.0.0", - "parse5": "^6.0.0", - "unist-util-position": "^4.0.0", - "unist-util-visit": "^4.0.0", - "vfile": "^5.0.0", + "@types/hast": "^3.0.0", + "@types/unist": "^3.0.0", + "@ungap/structured-clone": "^1.0.0", + "hast-util-from-parse5": "^8.0.0", + "hast-util-to-parse5": "^8.0.0", + "html-void-elements": "^3.0.0", + "mdast-util-to-hast": "^13.0.0", + "parse5": "^7.0.0", + "unist-util-position": "^5.0.0", + "unist-util-visit": "^5.0.0", + "vfile": "^6.0.0", "web-namespaces": "^2.0.0", "zwitch": "^2.0.0" }, @@ -2226,17 +4296,18 @@ } }, "node_modules/hast-util-to-html": { - "version": "8.0.4", - "resolved": "https://registry.npmjs.org/hast-util-to-html/-/hast-util-to-html-8.0.4.tgz", - "integrity": "sha512-4tpQTUOr9BMjtYyNlt0P50mH7xj0Ks2xpo8M943Vykljf99HW6EzulIoJP1N3eKOSScEHzyzi9dm7/cn0RfGwA==", + "version": "9.0.0", + "resolved": "https://registry.npmjs.org/hast-util-to-html/-/hast-util-to-html-9.0.0.tgz", + "integrity": "sha512-IVGhNgg7vANuUA2XKrT6sOIIPgaYZnmLx3l/CCOAK0PtgfoHrZwX7jCSYyFxHTrGmC6S9q8aQQekjp4JPZF+cw==", "dependencies": { - "@types/hast": "^2.0.0", - "@types/unist": "^2.0.0", + "@types/hast": "^3.0.0", + "@types/unist": "^3.0.0", "ccount": "^2.0.0", "comma-separated-tokens": "^2.0.0", - "hast-util-raw": "^7.0.0", - "hast-util-whitespace": "^2.0.0", - "html-void-elements": "^2.0.0", + "hast-util-raw": "^9.0.0", + "hast-util-whitespace": "^3.0.0", + "html-void-elements": "^3.0.0", + "mdast-util-to-hast": "^13.0.0", "property-information": "^6.0.0", "space-separated-tokens": "^2.0.0", "stringify-entities": "^4.0.0", @@ -2248,12 +4319,13 @@ } }, "node_modules/hast-util-to-parse5": { - "version": "7.1.0", - "resolved": "https://registry.npmjs.org/hast-util-to-parse5/-/hast-util-to-parse5-7.1.0.tgz", - "integrity": "sha512-YNRgAJkH2Jky5ySkIqFXTQiaqcAtJyVE+D5lkN6CdtOqrnkLfGYYrEcKuHOJZlp+MwjSwuD3fZuawI+sic/RBw==", + "version": "8.0.0", + "resolved": "https://registry.npmjs.org/hast-util-to-parse5/-/hast-util-to-parse5-8.0.0.tgz", + "integrity": "sha512-3KKrV5ZVI8if87DVSi1vDeByYrkGzg4mEfeu4alwgmmIeARiBLKCZS2uw5Gb6nU9x9Yufyj3iudm6i7nl52PFw==", "dependencies": { - "@types/hast": "^2.0.0", + "@types/hast": "^3.0.0", "comma-separated-tokens": "^2.0.0", + "devlop": "^1.0.0", "property-information": "^6.0.0", "space-separated-tokens": "^2.0.0", "web-namespaces": "^2.0.0", @@ -2264,23 +4336,41 @@ "url": "https://opencollective.com/unified" } }, + "node_modules/hast-util-to-text": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/hast-util-to-text/-/hast-util-to-text-4.0.2.tgz", + "integrity": "sha512-KK6y/BN8lbaq654j7JgBydev7wuNMcID54lkRav1P0CaE1e47P72AWWPiGKXTJU271ooYzcvTAn/Zt0REnvc7A==", + "dependencies": { + "@types/hast": "^3.0.0", + "@types/unist": "^3.0.0", + "hast-util-is-element": "^3.0.0", + "unist-util-find-after": "^5.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/unified" + } + }, "node_modules/hast-util-whitespace": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/hast-util-whitespace/-/hast-util-whitespace-2.0.1.tgz", - "integrity": "sha512-nAxA0v8+vXSBDt3AnRUNjyRIQ0rD+ntpbAp4LnPkumc5M9yUbSMa4XDU9Q6etY4f1Wp4bNgvc1yjiZtsTTrSng==", + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/hast-util-whitespace/-/hast-util-whitespace-3.0.0.tgz", + "integrity": "sha512-88JUN06ipLwsnv+dVn+OIYOvAuvBMy/Qoi6O7mQHxdPXpjy+Cd6xRkWwux7DKO+4sYILtLBRIKgsdpS2gQc7qw==", + "dependencies": { + "@types/hast": "^3.0.0" + }, "funding": { "type": "opencollective", "url": "https://opencollective.com/unified" } }, "node_modules/hastscript": { - "version": "7.2.0", - "resolved": "https://registry.npmjs.org/hastscript/-/hastscript-7.2.0.tgz", - "integrity": "sha512-TtYPq24IldU8iKoJQqvZOuhi5CyCQRAbvDOX0x1eW6rsHSxa/1i2CCiptNTotGHJ3VoHRGmqiv6/D3q113ikkw==", + "version": "8.0.0", + "resolved": "https://registry.npmjs.org/hastscript/-/hastscript-8.0.0.tgz", + "integrity": "sha512-dMOtzCEd3ABUeSIISmrETiKuyydk1w0pa+gE/uormcTpSYuaNJPbX1NU3JLyscSLjwAQM8bWMhhIlnCqnRvDTw==", "dependencies": { - "@types/hast": "^2.0.0", + "@types/hast": "^3.0.0", "comma-separated-tokens": "^2.0.0", - "hast-util-parse-selector": "^3.0.0", + "hast-util-parse-selector": "^4.0.0", "property-information": "^6.0.0", "space-separated-tokens": "^2.0.0" }, @@ -2295,54 +4385,50 @@ "integrity": "sha512-RuMffC89BOWQoY0WKGpIhn5gX3iI54O6nRA0yC124NYVtzjmFWBIiFd8M0x+ZdX0P9R4lADg1mgP8C7PxGOWuQ==" }, "node_modules/html-void-elements": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/html-void-elements/-/html-void-elements-2.0.1.tgz", - "integrity": "sha512-0quDb7s97CfemeJAnW9wC0hw78MtW7NU3hqtCD75g2vFlDLt36llsYD7uB7SUzojLMP24N5IatXf7ylGXiGG9A==", + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/html-void-elements/-/html-void-elements-3.0.0.tgz", + "integrity": "sha512-bEqo66MRXsUGxWHV5IP0PUiAWwoEjba4VCzg0LjFJBpchPaTfyfCKTG6bc5F8ucKec3q5y6qOdGyYTSBEvhCrg==", "funding": { "type": "github", "url": "https://github.com/sponsors/wooorm" } }, + "node_modules/http-cache-semantics": { + "version": "4.1.1", + "resolved": "https://registry.npmjs.org/http-cache-semantics/-/http-cache-semantics-4.1.1.tgz", + "integrity": "sha512-er295DKPVsV82j5kw1Gjt+ADA/XYHsajl82cGNQG2eyoPkvgUhX+nDIyelzhIWbbsXP39EHcI6l5tYs2FYqYXQ==" + }, "node_modules/human-signals": { - "version": "3.0.1", - "resolved": "https://registry.npmjs.org/human-signals/-/human-signals-3.0.1.tgz", - "integrity": "sha512-rQLskxnM/5OCldHo+wNXbpVgDn5A17CUoKX+7Sokwaknlq7CdSnphy0W39GU8dw59XiCXmFXDg4fRuckQRKewQ==", + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/human-signals/-/human-signals-5.0.0.tgz", + "integrity": "sha512-AXcZb6vzzrFAUE61HnN4mpLqd/cSIwNQjtNWR0euPm6y0iqx3G4gOXaIDdtdDwZmhwe82LA6+zinmW4UBWVePQ==", "engines": { - "node": ">=12.20.0" + "node": ">=16.17.0" } }, - "node_modules/ieee754": { - "version": "1.2.1", - "resolved": "https://registry.npmjs.org/ieee754/-/ieee754-1.2.1.tgz", - "integrity": "sha512-dcyqhDvX1C46lXZcVqCpK+FtMRQVdIMN6/Df5js2zouUsqG7I6sFxitIC+7KYK29KdXOLHdu9zL4sFnoVQnqaA==", - "funding": [ - { - "type": "github", - "url": "https://github.com/sponsors/feross" - }, - { - "type": "patreon", - "url": "https://www.patreon.com/feross" - }, - { - "type": "consulting", - "url": "https://feross.org/support" - } - ] + "node_modules/iconoir": { + "version": "7.7.0", + "resolved": "https://registry.npmjs.org/iconoir/-/iconoir-7.7.0.tgz", + "integrity": "sha512-OsWErkUrvFW+EQAUkSw1JgVXGCIynVgCGUtrI7PzGcVmhfryFCbWHZceoGRtI2BMfp28J6HxethR86V58sJfnw==", + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/iconoir" + } }, "node_modules/import-meta-resolve": { - "version": "2.2.2", - "resolved": "https://registry.npmjs.org/import-meta-resolve/-/import-meta-resolve-2.2.2.tgz", - "integrity": "sha512-f8KcQ1D80V7RnqVm+/lirO9zkOxjGxhaTC1IPrBGd3MEfNgmNG67tSUO9gTi2F3Blr2Az6g1vocaxzkVnWl9MA==", + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/import-meta-resolve/-/import-meta-resolve-4.1.0.tgz", + "integrity": "sha512-I6fiaX09Xivtk+THaMfAwnA3MVA5Big1WHF1Dfx9hFuvNIWpXnorlkzhcQf6ehrqQiiZECRt1poOAkPmer3ruw==", "funding": { "type": "github", "url": "https://github.com/sponsors/wooorm" } }, - "node_modules/inherits": { - "version": "2.0.4", - "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", - "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==" + "node_modules/is-arrayish": { + "version": "0.3.2", + "resolved": "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.3.2.tgz", + "integrity": "sha512-eVRqCvVlZbuw3GrM63ovNSNAeA1K16kaR/LRY/92w0zxQ5/1YzwblUX652i4Xs9RwAGjW9d9y6X88t8OaAJfWQ==", + "optional": true }, "node_modules/is-binary-path": { "version": "2.1.0", @@ -2355,39 +4441,6 @@ "node": ">=8" } }, - "node_modules/is-buffer": { - "version": "2.0.5", - "resolved": "https://registry.npmjs.org/is-buffer/-/is-buffer-2.0.5.tgz", - "integrity": "sha512-i2R6zNFDwgEHJyQUtJEk0XFi1i0dPFn/oqjK3/vPCcDeJvW5NQ83V8QbicfF1SupOaB0h8ntgBC2YiE7dfyctQ==", - "funding": [ - { - "type": "github", - "url": "https://github.com/sponsors/feross" - }, - { - "type": "patreon", - "url": "https://www.patreon.com/feross" - }, - { - "type": "consulting", - "url": "https://feross.org/support" - } - ], - "engines": { - "node": ">=4" - } - }, - "node_modules/is-core-module": { - "version": "2.12.1", - "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.12.1.tgz", - "integrity": "sha512-Q4ZuBAe2FUsKtyQJoQHlvP8OvBERxO3jEmy1I7hcRXcJBGGHFh/aJBswbXuS9sgrDH2QUO8ilkwNPHvHMd8clg==", - "dependencies": { - "has": "^1.0.3" - }, - "funding": { - "url": "https://github.com/sponsors/ljharb" - } - }, "node_modules/is-docker": { "version": "3.0.0", "resolved": "https://registry.npmjs.org/is-docker/-/is-docker-3.0.0.tgz", @@ -2496,36 +4549,25 @@ } }, "node_modules/is-unicode-supported": { - "version": "1.3.0", - "resolved": "https://registry.npmjs.org/is-unicode-supported/-/is-unicode-supported-1.3.0.tgz", - "integrity": "sha512-43r2mRvz+8JRIKnWJ+3j8JtjRKZ6GmjzfaE/qiBJnikNnYv/6bagRJ1kUhNk8R5EX/GkobD+r+sfxCPJsiKBLQ==", + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/is-unicode-supported/-/is-unicode-supported-2.0.0.tgz", + "integrity": "sha512-FRdAyx5lusK1iHG0TWpVtk9+1i+GjrzRffhDg4ovQ7mcidMQ6mj+MhKPmvh7Xwyv5gIS06ns49CA7Sqg7lC22Q==", "engines": { - "node": ">=12" + "node": ">=18" }, "funding": { "url": "https://github.com/sponsors/sindresorhus" } }, "node_modules/is-wsl": { - "version": "2.2.0", - "resolved": "https://registry.npmjs.org/is-wsl/-/is-wsl-2.2.0.tgz", - "integrity": "sha512-fKzAra0rGJUUBwGBgNkHZuToZcn+TtXHpeCgmkMJMMYx1sQDYaCSyjJBSCa2nH1DGm7s3n1oBnohoVTBaN7Lww==", + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/is-wsl/-/is-wsl-3.1.0.tgz", + "integrity": "sha512-UcVfVfaK4Sc4m7X3dUSoHoozQGBEFeDC+zVo06t98xe8CzHSZZBekNXH+tu0NalHolcJ/QAGqS46Hef7QXBIMw==", "dependencies": { - "is-docker": "^2.0.0" + "is-inside-container": "^1.0.0" }, "engines": { - "node": ">=8" - } - }, - "node_modules/is-wsl/node_modules/is-docker": { - "version": "2.2.1", - "resolved": "https://registry.npmjs.org/is-docker/-/is-docker-2.2.1.tgz", - "integrity": "sha512-F+i2BKsFrH66iaUFc0woD8sLy8getkwTwtOBjvs56Cx4CgJDeKQeqfz8wAYiSb8JOprWhHH5p77PbmYCvvUuXQ==", - "bin": { - "is-docker": "cli.js" - }, - "engines": { - "node": ">=8" + "node": ">=16" }, "funding": { "url": "https://github.com/sponsors/sindresorhus" @@ -2563,6 +4605,12 @@ "node": ">=4" } }, + "node_modules/json-schema-traverse": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-1.0.0.tgz", + "integrity": "sha512-NM8/P9n3XjXhIZn1lLhkFaACTOURQXjWhV4BA/RnOv8xvgqtqpAX9IO4mRQxSx1Rlo4tqzeqb0sOlruaOy3dug==", + "license": "MIT" + }, "node_modules/json5": { "version": "2.2.3", "resolved": "https://registry.npmjs.org/json5/-/json5-2.2.3.tgz", @@ -2577,7 +4625,8 @@ "node_modules/jsonc-parser": { "version": "2.3.1", "resolved": "https://registry.npmjs.org/jsonc-parser/-/jsonc-parser-2.3.1.tgz", - "integrity": "sha512-H8jvkz1O50L3dMZCsLqiuB2tA7muqbSg1AtGEkN0leAqGjsUzDJir3Zwr02BhqdcITPg3ei3mZ+HjMocAknhhg==" + "integrity": "sha512-H8jvkz1O50L3dMZCsLqiuB2tA7muqbSg1AtGEkN0leAqGjsUzDJir3Zwr02BhqdcITPg3ei3mZ+HjMocAknhhg==", + "license": "MIT" }, "node_modules/kind-of": { "version": "6.0.3", @@ -2595,6 +4644,11 @@ "node": ">=6" } }, + "node_modules/lite-youtube-embed": { + "version": "0.3.2", + "resolved": "https://registry.npmjs.org/lite-youtube-embed/-/lite-youtube-embed-0.3.2.tgz", + "integrity": "sha512-b1dgKyF4PHhinonmr3PB172Nj0qQgA/7DE9EmeIXHR1ksnFEC2olWjNJyJGdsN2cleKHRjjsmrziKlwXtPlmLQ==" + }, "node_modules/load-yaml-file": { "version": "0.2.0", "resolved": "https://registry.npmjs.org/load-yaml-file/-/load-yaml-file-0.2.0.tgz", @@ -2629,38 +4683,33 @@ "js-yaml": "bin/js-yaml.js" } }, - "node_modules/load-yaml-file/node_modules/strip-bom": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-3.0.0.tgz", - "integrity": "sha512-vavAMRXOgBVNF6nyEEmL3DBK19iRpDcoIwW+swQ+CbGiu7lju6t+JklA1MHweoWtadgt4ISVUsXLyDq34ddcwA==", + "node_modules/locate-path": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-5.0.0.tgz", + "integrity": "sha512-t7hw9pI+WvuwNJXwk5zVHpyhIqzg2qTlklJOf0mVxGSbe3Fp2VieZcduNYjaLDoy6p9uGpQEGWG87WpMKlNq8g==", + "dependencies": { + "p-locate": "^4.1.0" + }, "engines": { - "node": ">=4" + "node": ">=8" } }, - "node_modules/locate-path": { - "version": "6.0.0", - "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-6.0.0.tgz", - "integrity": "sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw==", - "dependencies": { - "p-locate": "^5.0.0" - }, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } + "node_modules/lodash": { + "version": "4.17.21", + "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.21.tgz", + "integrity": "sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg==", + "license": "MIT" }, "node_modules/log-symbols": { - "version": "5.1.0", - "resolved": "https://registry.npmjs.org/log-symbols/-/log-symbols-5.1.0.tgz", - "integrity": "sha512-l0x2DvrW294C9uDCoQe1VSU4gf529FkSZ6leBl4TiqZH/e+0R7hSfHQBNut2mNygDgHwvYHfFLn6Oxb3VWj2rA==", + "version": "6.0.0", + "resolved": "https://registry.npmjs.org/log-symbols/-/log-symbols-6.0.0.tgz", + "integrity": "sha512-i24m8rpwhmPIS4zscNzK6MSEhk0DUWa/8iYQWxhffV8jkI4Phvs3F+quL5xvS0gdQR0FyTCMMH33Y78dDTzzIw==", "dependencies": { - "chalk": "^5.0.0", - "is-unicode-supported": "^1.1.0" + "chalk": "^5.3.0", + "is-unicode-supported": "^1.3.0" }, "engines": { - "node": ">=12" + "node": ">=18" }, "funding": { "url": "https://github.com/sponsors/sindresorhus" @@ -2677,6 +4726,17 @@ "url": "https://github.com/chalk/chalk?sponsor=1" } }, + "node_modules/log-symbols/node_modules/is-unicode-supported": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/is-unicode-supported/-/is-unicode-supported-1.3.0.tgz", + "integrity": "sha512-43r2mRvz+8JRIKnWJ+3j8JtjRKZ6GmjzfaE/qiBJnikNnYv/6bagRJ1kUhNk8R5EX/GkobD+r+sfxCPJsiKBLQ==", + "engines": { + "node": ">=12" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, "node_modules/longest-streak": { "version": "3.1.0", "resolved": "https://registry.npmjs.org/longest-streak/-/longest-streak-3.1.0.tgz", @@ -2695,14 +4755,11 @@ } }, "node_modules/magic-string": { - "version": "0.27.0", - "resolved": "https://registry.npmjs.org/magic-string/-/magic-string-0.27.0.tgz", - "integrity": "sha512-8UnnX2PeRAPZuN12svgR9j7M1uWMovg/CEnIwIG0LFkXSJJe4PdfUGiTGl8V9bsBHFUtfVINcSyYxd7q+kx9fA==", + "version": "0.30.11", + "resolved": "https://registry.npmjs.org/magic-string/-/magic-string-0.30.11.tgz", + "integrity": "sha512-+Wri9p0QHMy+545hKww7YAu5NyzF8iomPL/RQazugQ9+Ez4Ic3mERMd8ZTX5rfK944j+560ZJi8iAwgak1Ac7A==", "dependencies": { - "@jridgewell/sourcemap-codec": "^1.4.13" - }, - "engines": { - "node": ">=12" + "@jridgewell/sourcemap-codec": "^1.5.0" } }, "node_modules/markdown-table": { @@ -2715,13 +4772,13 @@ } }, "node_modules/mdast-util-definitions": { - "version": "5.1.2", - "resolved": "https://registry.npmjs.org/mdast-util-definitions/-/mdast-util-definitions-5.1.2.tgz", - "integrity": "sha512-8SVPMuHqlPME/z3gqVwWY4zVXn8lqKv/pAhC57FuJ40ImXyBpmO5ukh98zB2v7Blql2FiHjHv9LVztSIqjY+MA==", + "version": "6.0.0", + "resolved": "https://registry.npmjs.org/mdast-util-definitions/-/mdast-util-definitions-6.0.0.tgz", + "integrity": "sha512-scTllyX6pnYNZH/AIp/0ePz6s4cZtARxImwoPJ7kS42n+MnVsI4XbnG6d4ibehRIldYMWM2LD7ImQblVhUejVQ==", "dependencies": { - "@types/mdast": "^3.0.0", - "@types/unist": "^2.0.0", - "unist-util-visit": "^4.0.0" + "@types/mdast": "^4.0.0", + "@types/unist": "^3.0.0", + "unist-util-visit": "^5.0.0" }, "funding": { "type": "opencollective", @@ -2729,14 +4786,14 @@ } }, "node_modules/mdast-util-find-and-replace": { - "version": "2.2.2", - "resolved": "https://registry.npmjs.org/mdast-util-find-and-replace/-/mdast-util-find-and-replace-2.2.2.tgz", - "integrity": "sha512-MTtdFRz/eMDHXzeK6W3dO7mXUlF82Gom4y0oOgvHhh/HXZAGvIQDUvQ0SuUx+j2tv44b8xTHOm8K/9OoRFnXKw==", + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/mdast-util-find-and-replace/-/mdast-util-find-and-replace-3.0.1.tgz", + "integrity": "sha512-SG21kZHGC3XRTSUhtofZkBzZTJNM5ecCi0SK2IMKmSXR8vO3peL+kb1O0z7Zl83jKtutG4k5Wv/W7V3/YHvzPA==", "dependencies": { - "@types/mdast": "^3.0.0", + "@types/mdast": "^4.0.0", "escape-string-regexp": "^5.0.0", - "unist-util-is": "^5.0.0", - "unist-util-visit-parents": "^5.0.0" + "unist-util-is": "^6.0.0", + "unist-util-visit-parents": "^6.0.0" }, "funding": { "type": "opencollective", @@ -2755,22 +4812,22 @@ } }, "node_modules/mdast-util-from-markdown": { - "version": "1.3.1", - "resolved": "https://registry.npmjs.org/mdast-util-from-markdown/-/mdast-util-from-markdown-1.3.1.tgz", - "integrity": "sha512-4xTO/M8c82qBcnQc1tgpNtubGUW/Y1tBQ1B0i5CtSoelOLKFYlElIr3bvgREYYO5iRqbMY1YuqZng0GVOI8Qww==", + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/mdast-util-from-markdown/-/mdast-util-from-markdown-2.0.1.tgz", + "integrity": "sha512-aJEUyzZ6TzlsX2s5B4Of7lN7EQtAxvtradMMglCQDyaTFgse6CmtmdJ15ElnVRlCg1vpNyVtbem0PWzlNieZsA==", "dependencies": { - "@types/mdast": "^3.0.0", - "@types/unist": "^2.0.0", + "@types/mdast": "^4.0.0", + "@types/unist": "^3.0.0", "decode-named-character-reference": "^1.0.0", - "mdast-util-to-string": "^3.1.0", - "micromark": "^3.0.0", - "micromark-util-decode-numeric-character-reference": "^1.0.0", - "micromark-util-decode-string": "^1.0.0", - "micromark-util-normalize-identifier": "^1.0.0", - "micromark-util-symbol": "^1.0.0", - "micromark-util-types": "^1.0.0", - "unist-util-stringify-position": "^3.0.0", - "uvu": "^0.5.0" + "devlop": "^1.0.0", + "mdast-util-to-string": "^4.0.0", + "micromark": "^4.0.0", + "micromark-util-decode-numeric-character-reference": "^2.0.0", + "micromark-util-decode-string": "^2.0.0", + "micromark-util-normalize-identifier": "^2.0.0", + "micromark-util-symbol": "^2.0.0", + "micromark-util-types": "^2.0.0", + "unist-util-stringify-position": "^4.0.0" }, "funding": { "type": "opencollective", @@ -2778,17 +4835,17 @@ } }, "node_modules/mdast-util-gfm": { - "version": "2.0.2", - "resolved": "https://registry.npmjs.org/mdast-util-gfm/-/mdast-util-gfm-2.0.2.tgz", - "integrity": "sha512-qvZ608nBppZ4icQlhQQIAdc6S3Ffj9RGmzwUKUWuEICFnd1LVkN3EktF7ZHAgfcEdvZB5owU9tQgt99e2TlLjg==", + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/mdast-util-gfm/-/mdast-util-gfm-3.0.0.tgz", + "integrity": "sha512-dgQEX5Amaq+DuUqf26jJqSK9qgixgd6rYDHAv4aTBuA92cTknZlKpPfa86Z/s8Dj8xsAQpFfBmPUHWJBWqS4Bw==", "dependencies": { - "mdast-util-from-markdown": "^1.0.0", - "mdast-util-gfm-autolink-literal": "^1.0.0", - "mdast-util-gfm-footnote": "^1.0.0", - "mdast-util-gfm-strikethrough": "^1.0.0", - "mdast-util-gfm-table": "^1.0.0", - "mdast-util-gfm-task-list-item": "^1.0.0", - "mdast-util-to-markdown": "^1.0.0" + "mdast-util-from-markdown": "^2.0.0", + "mdast-util-gfm-autolink-literal": "^2.0.0", + "mdast-util-gfm-footnote": "^2.0.0", + "mdast-util-gfm-strikethrough": "^2.0.0", + "mdast-util-gfm-table": "^2.0.0", + "mdast-util-gfm-task-list-item": "^2.0.0", + "mdast-util-to-markdown": "^2.0.0" }, "funding": { "type": "opencollective", @@ -2796,14 +4853,15 @@ } }, "node_modules/mdast-util-gfm-autolink-literal": { - "version": "1.0.3", - "resolved": "https://registry.npmjs.org/mdast-util-gfm-autolink-literal/-/mdast-util-gfm-autolink-literal-1.0.3.tgz", - "integrity": "sha512-My8KJ57FYEy2W2LyNom4n3E7hKTuQk/0SES0u16tjA9Z3oFkF4RrC/hPAPgjlSpezsOvI8ObcXcElo92wn5IGA==", + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/mdast-util-gfm-autolink-literal/-/mdast-util-gfm-autolink-literal-2.0.0.tgz", + "integrity": "sha512-FyzMsduZZHSc3i0Px3PQcBT4WJY/X/RCtEJKuybiC6sjPqLv7h1yqAkmILZtuxMSsUyaLUWNp71+vQH2zqp5cg==", "dependencies": { - "@types/mdast": "^3.0.0", + "@types/mdast": "^4.0.0", "ccount": "^2.0.0", - "mdast-util-find-and-replace": "^2.0.0", - "micromark-util-character": "^1.0.0" + "devlop": "^1.0.0", + "mdast-util-find-and-replace": "^3.0.0", + "micromark-util-character": "^2.0.0" }, "funding": { "type": "opencollective", @@ -2811,13 +4869,15 @@ } }, "node_modules/mdast-util-gfm-footnote": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/mdast-util-gfm-footnote/-/mdast-util-gfm-footnote-1.0.2.tgz", - "integrity": "sha512-56D19KOGbE00uKVj3sgIykpwKL179QsVFwx/DCW0u/0+URsryacI4MAdNJl0dh+u2PSsD9FtxPFbHCzJ78qJFQ==", + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/mdast-util-gfm-footnote/-/mdast-util-gfm-footnote-2.0.0.tgz", + "integrity": "sha512-5jOT2boTSVkMnQ7LTrd6n/18kqwjmuYqo7JUPe+tRCY6O7dAuTFMtTPauYYrMPpox9hlN0uOx/FL8XvEfG9/mQ==", "dependencies": { - "@types/mdast": "^3.0.0", - "mdast-util-to-markdown": "^1.3.0", - "micromark-util-normalize-identifier": "^1.0.0" + "@types/mdast": "^4.0.0", + "devlop": "^1.1.0", + "mdast-util-from-markdown": "^2.0.0", + "mdast-util-to-markdown": "^2.0.0", + "micromark-util-normalize-identifier": "^2.0.0" }, "funding": { "type": "opencollective", @@ -2825,12 +4885,13 @@ } }, "node_modules/mdast-util-gfm-strikethrough": { - "version": "1.0.3", - "resolved": "https://registry.npmjs.org/mdast-util-gfm-strikethrough/-/mdast-util-gfm-strikethrough-1.0.3.tgz", - "integrity": "sha512-DAPhYzTYrRcXdMjUtUjKvW9z/FNAMTdU0ORyMcbmkwYNbKocDpdk+PX1L1dQgOID/+vVs1uBQ7ElrBQfZ0cuiQ==", + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/mdast-util-gfm-strikethrough/-/mdast-util-gfm-strikethrough-2.0.0.tgz", + "integrity": "sha512-mKKb915TF+OC5ptj5bJ7WFRPdYtuHv0yTRxK2tJvi+BDqbkiG7h7u/9SI89nRAYcmap2xHQL9D+QG/6wSrTtXg==", "dependencies": { - "@types/mdast": "^3.0.0", - "mdast-util-to-markdown": "^1.3.0" + "@types/mdast": "^4.0.0", + "mdast-util-from-markdown": "^2.0.0", + "mdast-util-to-markdown": "^2.0.0" }, "funding": { "type": "opencollective", @@ -2838,14 +4899,15 @@ } }, "node_modules/mdast-util-gfm-table": { - "version": "1.0.7", - "resolved": "https://registry.npmjs.org/mdast-util-gfm-table/-/mdast-util-gfm-table-1.0.7.tgz", - "integrity": "sha512-jjcpmNnQvrmN5Vx7y7lEc2iIOEytYv7rTvu+MeyAsSHTASGCCRA79Igg2uKssgOs1i1po8s3plW0sTu1wkkLGg==", + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/mdast-util-gfm-table/-/mdast-util-gfm-table-2.0.0.tgz", + "integrity": "sha512-78UEvebzz/rJIxLvE7ZtDd/vIQ0RHv+3Mh5DR96p7cS7HsBhYIICDBCu8csTNWNO6tBWfqXPWekRuj2FNOGOZg==", "dependencies": { - "@types/mdast": "^3.0.0", + "@types/mdast": "^4.0.0", + "devlop": "^1.0.0", "markdown-table": "^3.0.0", - "mdast-util-from-markdown": "^1.0.0", - "mdast-util-to-markdown": "^1.3.0" + "mdast-util-from-markdown": "^2.0.0", + "mdast-util-to-markdown": "^2.0.0" }, "funding": { "type": "opencollective", @@ -2853,12 +4915,14 @@ } }, "node_modules/mdast-util-gfm-task-list-item": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/mdast-util-gfm-task-list-item/-/mdast-util-gfm-task-list-item-1.0.2.tgz", - "integrity": "sha512-PFTA1gzfp1B1UaiJVyhJZA1rm0+Tzn690frc/L8vNX1Jop4STZgOE6bxUhnzdVSB+vm2GU1tIsuQcA9bxTQpMQ==", + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/mdast-util-gfm-task-list-item/-/mdast-util-gfm-task-list-item-2.0.0.tgz", + "integrity": "sha512-IrtvNvjxC1o06taBAVJznEnkiHxLFTzgonUdy8hzFVeDun0uTjxxrRGVaNFqkU1wJR3RBPEfsxmU6jDWPofrTQ==", "dependencies": { - "@types/mdast": "^3.0.0", - "mdast-util-to-markdown": "^1.3.0" + "@types/mdast": "^4.0.0", + "devlop": "^1.0.0", + "mdast-util-from-markdown": "^2.0.0", + "mdast-util-to-markdown": "^2.0.0" }, "funding": { "type": "opencollective", @@ -2866,12 +4930,12 @@ } }, "node_modules/mdast-util-phrasing": { - "version": "3.0.1", - "resolved": "https://registry.npmjs.org/mdast-util-phrasing/-/mdast-util-phrasing-3.0.1.tgz", - "integrity": "sha512-WmI1gTXUBJo4/ZmSk79Wcb2HcjPJBzM1nlI/OUWA8yk2X9ik3ffNbBGsU+09BFmXaL1IBb9fiuvq6/KMiNycSg==", + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/mdast-util-phrasing/-/mdast-util-phrasing-4.1.0.tgz", + "integrity": "sha512-TqICwyvJJpBwvGAMZjj4J2n0X8QWp21b9l0o7eXyVJ25YNWYbJDVIyD1bZXE6WtV6RmKJVYmQAKWa0zWOABz2w==", "dependencies": { - "@types/mdast": "^3.0.0", - "unist-util-is": "^5.0.0" + "@types/mdast": "^4.0.0", + "unist-util-is": "^6.0.0" }, "funding": { "type": "opencollective", @@ -2879,18 +4943,18 @@ } }, "node_modules/mdast-util-to-hast": { - "version": "12.3.0", - "resolved": "https://registry.npmjs.org/mdast-util-to-hast/-/mdast-util-to-hast-12.3.0.tgz", - "integrity": "sha512-pits93r8PhnIoU4Vy9bjW39M2jJ6/tdHyja9rrot9uujkN7UTU9SDnE6WNJz/IGyQk3XHX6yNNtrBH6cQzm8Hw==", + "version": "13.0.2", + "resolved": "https://registry.npmjs.org/mdast-util-to-hast/-/mdast-util-to-hast-13.0.2.tgz", + "integrity": "sha512-U5I+500EOOw9e3ZrclN3Is3fRpw8c19SMyNZlZ2IS+7vLsNzb2Om11VpIVOR+/0137GhZsFEF6YiKD5+0Hr2Og==", "dependencies": { - "@types/hast": "^2.0.0", - "@types/mdast": "^3.0.0", - "mdast-util-definitions": "^5.0.0", - "micromark-util-sanitize-uri": "^1.1.0", + "@types/hast": "^3.0.0", + "@types/mdast": "^4.0.0", + "@ungap/structured-clone": "^1.0.0", + "devlop": "^1.0.0", + "micromark-util-sanitize-uri": "^2.0.0", "trim-lines": "^3.0.0", - "unist-util-generated": "^2.0.0", - "unist-util-position": "^4.0.0", - "unist-util-visit": "^4.0.0" + "unist-util-position": "^5.0.0", + "unist-util-visit": "^5.0.0" }, "funding": { "type": "opencollective", @@ -2898,17 +4962,17 @@ } }, "node_modules/mdast-util-to-markdown": { - "version": "1.5.0", - "resolved": "https://registry.npmjs.org/mdast-util-to-markdown/-/mdast-util-to-markdown-1.5.0.tgz", - "integrity": "sha512-bbv7TPv/WC49thZPg3jXuqzuvI45IL2EVAr/KxF0BSdHsU0ceFHOmwQn6evxAh1GaoK/6GQ1wp4R4oW2+LFL/A==", + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/mdast-util-to-markdown/-/mdast-util-to-markdown-2.1.0.tgz", + "integrity": "sha512-SR2VnIEdVNCJbP6y7kVTJgPLifdr8WEU440fQec7qHoHOUz/oJ2jmNRqdDQ3rbiStOXb2mCDGTuwsK5OPUgYlQ==", "dependencies": { - "@types/mdast": "^3.0.0", - "@types/unist": "^2.0.0", + "@types/mdast": "^4.0.0", + "@types/unist": "^3.0.0", "longest-streak": "^3.0.0", - "mdast-util-phrasing": "^3.0.0", - "mdast-util-to-string": "^3.0.0", - "micromark-util-decode-string": "^1.0.0", - "unist-util-visit": "^4.0.0", + "mdast-util-phrasing": "^4.0.0", + "mdast-util-to-string": "^4.0.0", + "micromark-util-decode-string": "^2.0.0", + "unist-util-visit": "^5.0.0", "zwitch": "^2.0.0" }, "funding": { @@ -2917,11 +4981,11 @@ } }, "node_modules/mdast-util-to-string": { - "version": "3.2.0", - "resolved": "https://registry.npmjs.org/mdast-util-to-string/-/mdast-util-to-string-3.2.0.tgz", - "integrity": "sha512-V4Zn/ncyN1QNSqSBxTrMOLpjr+IKdHl2v3KVLoWmDPscP4r9GcCi71gjgvUV1SFSKh92AjAG4peFuBl2/YgCJg==", + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/mdast-util-to-string/-/mdast-util-to-string-4.0.0.tgz", + "integrity": "sha512-0H44vDimn51F0YwvxSJSm0eCDOJTRlmN0R1yBh4HLj9wiV1Dn0QoXGbvFAWj2hSItVTlCmBF1hqKlIyUBVFLPg==", "dependencies": { - "@types/mdast": "^3.0.0" + "@types/mdast": "^4.0.0" }, "funding": { "type": "opencollective", @@ -2942,9 +5006,9 @@ } }, "node_modules/micromark": { - "version": "3.2.0", - "resolved": "https://registry.npmjs.org/micromark/-/micromark-3.2.0.tgz", - "integrity": "sha512-uD66tJj54JLYq0De10AhWycZWGQNUvDI55xPgk2sQM5kn1JYlhbCMTtEeT27+vAhW2FBQxLlOmS3pmA7/2z4aA==", + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/micromark/-/micromark-4.0.0.tgz", + "integrity": "sha512-o/sd0nMof8kYff+TqcDx3VSrgBTcZpSvYcAHIfHhv5VAuNmisCxjhx6YmxS8PFEpb9z5WKWKPdzf0jM23ro3RQ==", "funding": [ { "type": "GitHub Sponsors", @@ -2959,26 +5023,26 @@ "@types/debug": "^4.0.0", "debug": "^4.0.0", "decode-named-character-reference": "^1.0.0", - "micromark-core-commonmark": "^1.0.1", - "micromark-factory-space": "^1.0.0", - "micromark-util-character": "^1.0.0", - "micromark-util-chunked": "^1.0.0", - "micromark-util-combine-extensions": "^1.0.0", - "micromark-util-decode-numeric-character-reference": "^1.0.0", - "micromark-util-encode": "^1.0.0", - "micromark-util-normalize-identifier": "^1.0.0", - "micromark-util-resolve-all": "^1.0.0", - "micromark-util-sanitize-uri": "^1.0.0", - "micromark-util-subtokenize": "^1.0.0", - "micromark-util-symbol": "^1.0.0", - "micromark-util-types": "^1.0.1", - "uvu": "^0.5.0" + "devlop": "^1.0.0", + "micromark-core-commonmark": "^2.0.0", + "micromark-factory-space": "^2.0.0", + "micromark-util-character": "^2.0.0", + "micromark-util-chunked": "^2.0.0", + "micromark-util-combine-extensions": "^2.0.0", + "micromark-util-decode-numeric-character-reference": "^2.0.0", + "micromark-util-encode": "^2.0.0", + "micromark-util-normalize-identifier": "^2.0.0", + "micromark-util-resolve-all": "^2.0.0", + "micromark-util-sanitize-uri": "^2.0.0", + "micromark-util-subtokenize": "^2.0.0", + "micromark-util-symbol": "^2.0.0", + "micromark-util-types": "^2.0.0" } }, "node_modules/micromark-core-commonmark": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/micromark-core-commonmark/-/micromark-core-commonmark-1.1.0.tgz", - "integrity": "sha512-BgHO1aRbolh2hcrzL2d1La37V0Aoz73ymF8rAcKnohLy93titmv62E0gP8Hrx9PKcKrqCZ1BbLGbP3bEhoXYlw==", + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/micromark-core-commonmark/-/micromark-core-commonmark-2.0.1.tgz", + "integrity": "sha512-CUQyKr1e///ZODyD1U3xit6zXwy1a8q2a1S1HKtIlmgvurrEpaw/Y9y6KSIbF8P59cn/NjzHyO+Q2fAyYLQrAA==", "funding": [ { "type": "GitHub Sponsors", @@ -2991,36 +5055,36 @@ ], "dependencies": { "decode-named-character-reference": "^1.0.0", - "micromark-factory-destination": "^1.0.0", - "micromark-factory-label": "^1.0.0", - "micromark-factory-space": "^1.0.0", - "micromark-factory-title": "^1.0.0", - "micromark-factory-whitespace": "^1.0.0", - "micromark-util-character": "^1.0.0", - "micromark-util-chunked": "^1.0.0", - "micromark-util-classify-character": "^1.0.0", - "micromark-util-html-tag-name": "^1.0.0", - "micromark-util-normalize-identifier": "^1.0.0", - "micromark-util-resolve-all": "^1.0.0", - "micromark-util-subtokenize": "^1.0.0", - "micromark-util-symbol": "^1.0.0", - "micromark-util-types": "^1.0.1", - "uvu": "^0.5.0" + "devlop": "^1.0.0", + "micromark-factory-destination": "^2.0.0", + "micromark-factory-label": "^2.0.0", + "micromark-factory-space": "^2.0.0", + "micromark-factory-title": "^2.0.0", + "micromark-factory-whitespace": "^2.0.0", + "micromark-util-character": "^2.0.0", + "micromark-util-chunked": "^2.0.0", + "micromark-util-classify-character": "^2.0.0", + "micromark-util-html-tag-name": "^2.0.0", + "micromark-util-normalize-identifier": "^2.0.0", + "micromark-util-resolve-all": "^2.0.0", + "micromark-util-subtokenize": "^2.0.0", + "micromark-util-symbol": "^2.0.0", + "micromark-util-types": "^2.0.0" } }, "node_modules/micromark-extension-gfm": { - "version": "2.0.3", - "resolved": "https://registry.npmjs.org/micromark-extension-gfm/-/micromark-extension-gfm-2.0.3.tgz", - "integrity": "sha512-vb9OoHqrhCmbRidQv/2+Bc6pkP0FrtlhurxZofvOEy5o8RtuuvTq+RQ1Vw5ZDNrVraQZu3HixESqbG+0iKk/MQ==", + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/micromark-extension-gfm/-/micromark-extension-gfm-3.0.0.tgz", + "integrity": "sha512-vsKArQsicm7t0z2GugkCKtZehqUm31oeGBV/KVSorWSy8ZlNAv7ytjFhvaryUiCUJYqs+NoE6AFhpQvBTM6Q4w==", "dependencies": { - "micromark-extension-gfm-autolink-literal": "^1.0.0", - "micromark-extension-gfm-footnote": "^1.0.0", - "micromark-extension-gfm-strikethrough": "^1.0.0", - "micromark-extension-gfm-table": "^1.0.0", - "micromark-extension-gfm-tagfilter": "^1.0.0", - "micromark-extension-gfm-task-list-item": "^1.0.0", - "micromark-util-combine-extensions": "^1.0.0", - "micromark-util-types": "^1.0.0" + "micromark-extension-gfm-autolink-literal": "^2.0.0", + "micromark-extension-gfm-footnote": "^2.0.0", + "micromark-extension-gfm-strikethrough": "^2.0.0", + "micromark-extension-gfm-table": "^2.0.0", + "micromark-extension-gfm-tagfilter": "^2.0.0", + "micromark-extension-gfm-task-list-item": "^2.0.0", + "micromark-util-combine-extensions": "^2.0.0", + "micromark-util-types": "^2.0.0" }, "funding": { "type": "opencollective", @@ -3028,14 +5092,14 @@ } }, "node_modules/micromark-extension-gfm-autolink-literal": { - "version": "1.0.5", - "resolved": "https://registry.npmjs.org/micromark-extension-gfm-autolink-literal/-/micromark-extension-gfm-autolink-literal-1.0.5.tgz", - "integrity": "sha512-z3wJSLrDf8kRDOh2qBtoTRD53vJ+CWIyo7uyZuxf/JAbNJjiHsOpG1y5wxk8drtv3ETAHutCu6N3thkOOgueWg==", + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/micromark-extension-gfm-autolink-literal/-/micromark-extension-gfm-autolink-literal-2.1.0.tgz", + "integrity": "sha512-oOg7knzhicgQ3t4QCjCWgTmfNhvQbDDnJeVu9v81r7NltNCVmhPy1fJRX27pISafdjL+SVc4d3l48Gb6pbRypw==", "dependencies": { - "micromark-util-character": "^1.0.0", - "micromark-util-sanitize-uri": "^1.0.0", - "micromark-util-symbol": "^1.0.0", - "micromark-util-types": "^1.0.0" + "micromark-util-character": "^2.0.0", + "micromark-util-sanitize-uri": "^2.0.0", + "micromark-util-symbol": "^2.0.0", + "micromark-util-types": "^2.0.0" }, "funding": { "type": "opencollective", @@ -3043,18 +5107,18 @@ } }, "node_modules/micromark-extension-gfm-footnote": { - "version": "1.1.2", - "resolved": "https://registry.npmjs.org/micromark-extension-gfm-footnote/-/micromark-extension-gfm-footnote-1.1.2.tgz", - "integrity": "sha512-Yxn7z7SxgyGWRNa4wzf8AhYYWNrwl5q1Z8ii+CSTTIqVkmGZF1CElX2JI8g5yGoM3GAman9/PVCUFUSJ0kB/8Q==", + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/micromark-extension-gfm-footnote/-/micromark-extension-gfm-footnote-2.1.0.tgz", + "integrity": "sha512-/yPhxI1ntnDNsiHtzLKYnE3vf9JZ6cAisqVDauhp4CEHxlb4uoOTxOCJ+9s51bIB8U1N1FJ1RXOKTIlD5B/gqw==", "dependencies": { - "micromark-core-commonmark": "^1.0.0", - "micromark-factory-space": "^1.0.0", - "micromark-util-character": "^1.0.0", - "micromark-util-normalize-identifier": "^1.0.0", - "micromark-util-sanitize-uri": "^1.0.0", - "micromark-util-symbol": "^1.0.0", - "micromark-util-types": "^1.0.0", - "uvu": "^0.5.0" + "devlop": "^1.0.0", + "micromark-core-commonmark": "^2.0.0", + "micromark-factory-space": "^2.0.0", + "micromark-util-character": "^2.0.0", + "micromark-util-normalize-identifier": "^2.0.0", + "micromark-util-sanitize-uri": "^2.0.0", + "micromark-util-symbol": "^2.0.0", + "micromark-util-types": "^2.0.0" }, "funding": { "type": "opencollective", @@ -3062,16 +5126,16 @@ } }, "node_modules/micromark-extension-gfm-strikethrough": { - "version": "1.0.7", - "resolved": "https://registry.npmjs.org/micromark-extension-gfm-strikethrough/-/micromark-extension-gfm-strikethrough-1.0.7.tgz", - "integrity": "sha512-sX0FawVE1o3abGk3vRjOH50L5TTLr3b5XMqnP9YDRb34M0v5OoZhG+OHFz1OffZ9dlwgpTBKaT4XW/AsUVnSDw==", + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/micromark-extension-gfm-strikethrough/-/micromark-extension-gfm-strikethrough-2.1.0.tgz", + "integrity": "sha512-ADVjpOOkjz1hhkZLlBiYA9cR2Anf8F4HqZUO6e5eDcPQd0Txw5fxLzzxnEkSkfnD0wziSGiv7sYhk/ktvbf1uw==", "dependencies": { - "micromark-util-chunked": "^1.0.0", - "micromark-util-classify-character": "^1.0.0", - "micromark-util-resolve-all": "^1.0.0", - "micromark-util-symbol": "^1.0.0", - "micromark-util-types": "^1.0.0", - "uvu": "^0.5.0" + "devlop": "^1.0.0", + "micromark-util-chunked": "^2.0.0", + "micromark-util-classify-character": "^2.0.0", + "micromark-util-resolve-all": "^2.0.0", + "micromark-util-symbol": "^2.0.0", + "micromark-util-types": "^2.0.0" }, "funding": { "type": "opencollective", @@ -3079,15 +5143,15 @@ } }, "node_modules/micromark-extension-gfm-table": { - "version": "1.0.7", - "resolved": "https://registry.npmjs.org/micromark-extension-gfm-table/-/micromark-extension-gfm-table-1.0.7.tgz", - "integrity": "sha512-3ZORTHtcSnMQEKtAOsBQ9/oHp9096pI/UvdPtN7ehKvrmZZ2+bbWhi0ln+I9drmwXMt5boocn6OlwQzNXeVeqw==", + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/micromark-extension-gfm-table/-/micromark-extension-gfm-table-2.1.0.tgz", + "integrity": "sha512-Ub2ncQv+fwD70/l4ou27b4YzfNaCJOvyX4HxXU15m7mpYY+rjuWzsLIPZHJL253Z643RpbcP1oeIJlQ/SKW67g==", "dependencies": { - "micromark-factory-space": "^1.0.0", - "micromark-util-character": "^1.0.0", - "micromark-util-symbol": "^1.0.0", - "micromark-util-types": "^1.0.0", - "uvu": "^0.5.0" + "devlop": "^1.0.0", + "micromark-factory-space": "^2.0.0", + "micromark-util-character": "^2.0.0", + "micromark-util-symbol": "^2.0.0", + "micromark-util-types": "^2.0.0" }, "funding": { "type": "opencollective", @@ -3095,11 +5159,11 @@ } }, "node_modules/micromark-extension-gfm-tagfilter": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/micromark-extension-gfm-tagfilter/-/micromark-extension-gfm-tagfilter-1.0.2.tgz", - "integrity": "sha512-5XWB9GbAUSHTn8VPU8/1DBXMuKYT5uOgEjJb8gN3mW0PNW5OPHpSdojoqf+iq1xo7vWzw/P8bAHY0n6ijpXF7g==", + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/micromark-extension-gfm-tagfilter/-/micromark-extension-gfm-tagfilter-2.0.0.tgz", + "integrity": "sha512-xHlTOmuCSotIA8TW1mDIM6X2O1SiX5P9IuDtqGonFhEK0qgRI4yeC6vMxEV2dgyr2TiD+2PQ10o+cOhdVAcwfg==", "dependencies": { - "micromark-util-types": "^1.0.0" + "micromark-util-types": "^2.0.0" }, "funding": { "type": "opencollective", @@ -3107,15 +5171,15 @@ } }, "node_modules/micromark-extension-gfm-task-list-item": { - "version": "1.0.5", - "resolved": "https://registry.npmjs.org/micromark-extension-gfm-task-list-item/-/micromark-extension-gfm-task-list-item-1.0.5.tgz", - "integrity": "sha512-RMFXl2uQ0pNQy6Lun2YBYT9g9INXtWJULgbt01D/x8/6yJ2qpKyzdZD3pi6UIkzF++Da49xAelVKUeUMqd5eIQ==", + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/micromark-extension-gfm-task-list-item/-/micromark-extension-gfm-task-list-item-2.1.0.tgz", + "integrity": "sha512-qIBZhqxqI6fjLDYFTBIa4eivDMnP+OZqsNwmQ3xNLE4Cxwc+zfQEfbs6tzAo2Hjq+bh6q5F+Z8/cksrLFYWQQw==", "dependencies": { - "micromark-factory-space": "^1.0.0", - "micromark-util-character": "^1.0.0", - "micromark-util-symbol": "^1.0.0", - "micromark-util-types": "^1.0.0", - "uvu": "^0.5.0" + "devlop": "^1.0.0", + "micromark-factory-space": "^2.0.0", + "micromark-util-character": "^2.0.0", + "micromark-util-symbol": "^2.0.0", + "micromark-util-types": "^2.0.0" }, "funding": { "type": "opencollective", @@ -3123,9 +5187,9 @@ } }, "node_modules/micromark-factory-destination": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/micromark-factory-destination/-/micromark-factory-destination-1.1.0.tgz", - "integrity": "sha512-XaNDROBgx9SgSChd69pjiGKbV+nfHGDPVYFs5dOoDd7ZnMAE+Cuu91BCpsY8RT2NP9vo/B8pds2VQNCLiu0zhg==", + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/micromark-factory-destination/-/micromark-factory-destination-2.0.0.tgz", + "integrity": "sha512-j9DGrQLm/Uhl2tCzcbLhy5kXsgkHUrjJHg4fFAeoMRwJmJerT9aw4FEhIbZStWN8A3qMwOp1uzHr4UL8AInxtA==", "funding": [ { "type": "GitHub Sponsors", @@ -3137,15 +5201,15 @@ } ], "dependencies": { - "micromark-util-character": "^1.0.0", - "micromark-util-symbol": "^1.0.0", - "micromark-util-types": "^1.0.0" + "micromark-util-character": "^2.0.0", + "micromark-util-symbol": "^2.0.0", + "micromark-util-types": "^2.0.0" } }, "node_modules/micromark-factory-label": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/micromark-factory-label/-/micromark-factory-label-1.1.0.tgz", - "integrity": "sha512-OLtyez4vZo/1NjxGhcpDSbHQ+m0IIGnT8BoPamh+7jVlzLJBH98zzuCoUeMxvM6WsNeh8wx8cKvqLiPHEACn0w==", + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/micromark-factory-label/-/micromark-factory-label-2.0.0.tgz", + "integrity": "sha512-RR3i96ohZGde//4WSe/dJsxOX6vxIg9TimLAS3i4EhBAFx8Sm5SmqVfR8E87DPSR31nEAjZfbt91OMZWcNgdZw==", "funding": [ { "type": "GitHub Sponsors", @@ -3157,16 +5221,16 @@ } ], "dependencies": { - "micromark-util-character": "^1.0.0", - "micromark-util-symbol": "^1.0.0", - "micromark-util-types": "^1.0.0", - "uvu": "^0.5.0" + "devlop": "^1.0.0", + "micromark-util-character": "^2.0.0", + "micromark-util-symbol": "^2.0.0", + "micromark-util-types": "^2.0.0" } }, "node_modules/micromark-factory-space": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/micromark-factory-space/-/micromark-factory-space-1.1.0.tgz", - "integrity": "sha512-cRzEj7c0OL4Mw2v6nwzttyOZe8XY/Z8G0rzmWQZTBi/jjwyw/U4uqKtUORXQrR5bAZZnbTI/feRV/R7hc4jQYQ==", + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/micromark-factory-space/-/micromark-factory-space-2.0.0.tgz", + "integrity": "sha512-TKr+LIDX2pkBJXFLzpyPyljzYK3MtmllMUMODTQJIUfDGncESaqB90db9IAUcz4AZAJFdd8U9zOp9ty1458rxg==", "funding": [ { "type": "GitHub Sponsors", @@ -3178,14 +5242,14 @@ } ], "dependencies": { - "micromark-util-character": "^1.0.0", - "micromark-util-types": "^1.0.0" + "micromark-util-character": "^2.0.0", + "micromark-util-types": "^2.0.0" } }, "node_modules/micromark-factory-title": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/micromark-factory-title/-/micromark-factory-title-1.1.0.tgz", - "integrity": "sha512-J7n9R3vMmgjDOCY8NPw55jiyaQnH5kBdV2/UXCtZIpnHH3P6nHUKaH7XXEYuWwx/xUJcawa8plLBEjMPU24HzQ==", + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/micromark-factory-title/-/micromark-factory-title-2.0.0.tgz", + "integrity": "sha512-jY8CSxmpWLOxS+t8W+FG3Xigc0RDQA9bKMY/EwILvsesiRniiVMejYTE4wumNc2f4UbAa4WsHqe3J1QS1sli+A==", "funding": [ { "type": "GitHub Sponsors", @@ -3197,16 +5261,16 @@ } ], "dependencies": { - "micromark-factory-space": "^1.0.0", - "micromark-util-character": "^1.0.0", - "micromark-util-symbol": "^1.0.0", - "micromark-util-types": "^1.0.0" + "micromark-factory-space": "^2.0.0", + "micromark-util-character": "^2.0.0", + "micromark-util-symbol": "^2.0.0", + "micromark-util-types": "^2.0.0" } }, "node_modules/micromark-factory-whitespace": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/micromark-factory-whitespace/-/micromark-factory-whitespace-1.1.0.tgz", - "integrity": "sha512-v2WlmiymVSp5oMg+1Q0N1Lxmt6pMhIHD457whWM7/GUlEks1hI9xj5w3zbc4uuMKXGisksZk8DzP2UyGbGqNsQ==", + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/micromark-factory-whitespace/-/micromark-factory-whitespace-2.0.0.tgz", + "integrity": "sha512-28kbwaBjc5yAI1XadbdPYHX/eDnqaUFVikLwrO7FDnKG7lpgxnvk/XGRhX/PN0mOZ+dBSZ+LgunHS+6tYQAzhA==", "funding": [ { "type": "GitHub Sponsors", @@ -3218,16 +5282,16 @@ } ], "dependencies": { - "micromark-factory-space": "^1.0.0", - "micromark-util-character": "^1.0.0", - "micromark-util-symbol": "^1.0.0", - "micromark-util-types": "^1.0.0" + "micromark-factory-space": "^2.0.0", + "micromark-util-character": "^2.0.0", + "micromark-util-symbol": "^2.0.0", + "micromark-util-types": "^2.0.0" } }, "node_modules/micromark-util-character": { - "version": "1.2.0", - "resolved": "https://registry.npmjs.org/micromark-util-character/-/micromark-util-character-1.2.0.tgz", - "integrity": "sha512-lXraTwcX3yH/vMDaFWCQJP1uIszLVebzUa3ZHdrgxr7KEU/9mL4mVgCpGbyhvNLNlauROiNUq7WN5u7ndbY6xg==", + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/micromark-util-character/-/micromark-util-character-2.0.1.tgz", + "integrity": "sha512-3wgnrmEAJ4T+mGXAUfMvMAbxU9RDG43XmGce4j6CwPtVxB3vfwXSZ6KhFwDzZ3mZHhmPimMAXg71veiBGzeAZw==", "funding": [ { "type": "GitHub Sponsors", @@ -3239,14 +5303,14 @@ } ], "dependencies": { - "micromark-util-symbol": "^1.0.0", - "micromark-util-types": "^1.0.0" + "micromark-util-symbol": "^2.0.0", + "micromark-util-types": "^2.0.0" } }, "node_modules/micromark-util-chunked": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/micromark-util-chunked/-/micromark-util-chunked-1.1.0.tgz", - "integrity": "sha512-Ye01HXpkZPNcV6FiyoW2fGZDUw4Yc7vT0E9Sad83+bEDiCJ1uXu0S3mr8WLpsz3HaG3x2q0HM6CTuPdcZcluFQ==", + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/micromark-util-chunked/-/micromark-util-chunked-2.0.0.tgz", + "integrity": "sha512-anK8SWmNphkXdaKgz5hJvGa7l00qmcaUQoMYsBwDlSKFKjc6gjGXPDw3FNL3Nbwq5L8gE+RCbGqTw49FK5Qyvg==", "funding": [ { "type": "GitHub Sponsors", @@ -3258,13 +5322,13 @@ } ], "dependencies": { - "micromark-util-symbol": "^1.0.0" + "micromark-util-symbol": "^2.0.0" } }, "node_modules/micromark-util-classify-character": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/micromark-util-classify-character/-/micromark-util-classify-character-1.1.0.tgz", - "integrity": "sha512-SL0wLxtKSnklKSUplok1WQFoGhUdWYKggKUiqhX+Swala+BtptGCu5iPRc+xvzJ4PXE/hwM3FNXsfEVgoZsWbw==", + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/micromark-util-classify-character/-/micromark-util-classify-character-2.0.0.tgz", + "integrity": "sha512-S0ze2R9GH+fu41FA7pbSqNWObo/kzwf8rN/+IGlW/4tC6oACOs8B++bh+i9bVyNnwCcuksbFwsBme5OCKXCwIw==", "funding": [ { "type": "GitHub Sponsors", @@ -3276,15 +5340,15 @@ } ], "dependencies": { - "micromark-util-character": "^1.0.0", - "micromark-util-symbol": "^1.0.0", - "micromark-util-types": "^1.0.0" + "micromark-util-character": "^2.0.0", + "micromark-util-symbol": "^2.0.0", + "micromark-util-types": "^2.0.0" } }, "node_modules/micromark-util-combine-extensions": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/micromark-util-combine-extensions/-/micromark-util-combine-extensions-1.1.0.tgz", - "integrity": "sha512-Q20sp4mfNf9yEqDL50WwuWZHUrCO4fEyeDCnMGmG5Pr0Cz15Uo7KBs6jq+dq0EgX4DPwwrh9m0X+zPV1ypFvUA==", + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/micromark-util-combine-extensions/-/micromark-util-combine-extensions-2.0.0.tgz", + "integrity": "sha512-vZZio48k7ON0fVS3CUgFatWHoKbbLTK/rT7pzpJ4Bjp5JjkZeasRfrS9wsBdDJK2cJLHMckXZdzPSSr1B8a4oQ==", "funding": [ { "type": "GitHub Sponsors", @@ -3296,14 +5360,14 @@ } ], "dependencies": { - "micromark-util-chunked": "^1.0.0", - "micromark-util-types": "^1.0.0" + "micromark-util-chunked": "^2.0.0", + "micromark-util-types": "^2.0.0" } }, "node_modules/micromark-util-decode-numeric-character-reference": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/micromark-util-decode-numeric-character-reference/-/micromark-util-decode-numeric-character-reference-1.1.0.tgz", - "integrity": "sha512-m9V0ExGv0jB1OT21mrWcuf4QhP46pH1KkfWy9ZEezqHKAxkj4mPCy3nIH1rkbdMlChLHX531eOrymlwyZIf2iw==", + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/micromark-util-decode-numeric-character-reference/-/micromark-util-decode-numeric-character-reference-2.0.1.tgz", + "integrity": "sha512-bmkNc7z8Wn6kgjZmVHOX3SowGmVdhYS7yBpMnuMnPzDq/6xwVA604DuOXMZTO1lvq01g+Adfa0pE2UKGlxL1XQ==", "funding": [ { "type": "GitHub Sponsors", @@ -3315,13 +5379,13 @@ } ], "dependencies": { - "micromark-util-symbol": "^1.0.0" + "micromark-util-symbol": "^2.0.0" } }, "node_modules/micromark-util-decode-string": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/micromark-util-decode-string/-/micromark-util-decode-string-1.1.0.tgz", - "integrity": "sha512-YphLGCK8gM1tG1bd54azwyrQRjCFcmgj2S2GoJDNnh4vYtnL38JS8M4gpxzOPNyHdNEpheyWXCTnnTDY3N+NVQ==", + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/micromark-util-decode-string/-/micromark-util-decode-string-2.0.0.tgz", + "integrity": "sha512-r4Sc6leeUTn3P6gk20aFMj2ntPwn6qpDZqWvYmAG6NgvFTIlj4WtrAudLi65qYoaGdXYViXYw2pkmn7QnIFasA==", "funding": [ { "type": "GitHub Sponsors", @@ -3334,15 +5398,15 @@ ], "dependencies": { "decode-named-character-reference": "^1.0.0", - "micromark-util-character": "^1.0.0", - "micromark-util-decode-numeric-character-reference": "^1.0.0", - "micromark-util-symbol": "^1.0.0" + "micromark-util-character": "^2.0.0", + "micromark-util-decode-numeric-character-reference": "^2.0.0", + "micromark-util-symbol": "^2.0.0" } }, "node_modules/micromark-util-encode": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/micromark-util-encode/-/micromark-util-encode-1.1.0.tgz", - "integrity": "sha512-EuEzTWSTAj9PA5GOAs992GzNh2dGQO52UvAbtSOMvXTxv3Criqb6IOzJUBCmEqrrXSblJIJBbFFv6zPxpreiJw==", + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/micromark-util-encode/-/micromark-util-encode-2.0.0.tgz", + "integrity": "sha512-pS+ROfCXAGLWCOc8egcBvT0kf27GoWMqtdarNfDcjb6YLuV5cM3ioG45Ys2qOVqeqSbjaKg72vU+Wby3eddPsA==", "funding": [ { "type": "GitHub Sponsors", @@ -3355,9 +5419,9 @@ ] }, "node_modules/micromark-util-html-tag-name": { - "version": "1.2.0", - "resolved": "https://registry.npmjs.org/micromark-util-html-tag-name/-/micromark-util-html-tag-name-1.2.0.tgz", - "integrity": "sha512-VTQzcuQgFUD7yYztuQFKXT49KghjtETQ+Wv/zUjGSGBioZnkA4P1XXZPT1FHeJA6RwRXSF47yvJ1tsJdoxwO+Q==", + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/micromark-util-html-tag-name/-/micromark-util-html-tag-name-2.0.0.tgz", + "integrity": "sha512-xNn4Pqkj2puRhKdKTm8t1YHC/BAjx6CEwRFXntTaRf/x16aqka6ouVoutm+QdkISTlT7e2zU7U4ZdlDLJd2Mcw==", "funding": [ { "type": "GitHub Sponsors", @@ -3370,9 +5434,9 @@ ] }, "node_modules/micromark-util-normalize-identifier": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/micromark-util-normalize-identifier/-/micromark-util-normalize-identifier-1.1.0.tgz", - "integrity": "sha512-N+w5vhqrBihhjdpM8+5Xsxy71QWqGn7HYNUvch71iV2PM7+E3uWGox1Qp90loa1ephtCxG2ftRV/Conitc6P2Q==", + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/micromark-util-normalize-identifier/-/micromark-util-normalize-identifier-2.0.0.tgz", + "integrity": "sha512-2xhYT0sfo85FMrUPtHcPo2rrp1lwbDEEzpx7jiH2xXJLqBuy4H0GgXk5ToU8IEwoROtXuL8ND0ttVa4rNqYK3w==", "funding": [ { "type": "GitHub Sponsors", @@ -3384,13 +5448,13 @@ } ], "dependencies": { - "micromark-util-symbol": "^1.0.0" + "micromark-util-symbol": "^2.0.0" } }, "node_modules/micromark-util-resolve-all": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/micromark-util-resolve-all/-/micromark-util-resolve-all-1.1.0.tgz", - "integrity": "sha512-b/G6BTMSg+bX+xVCshPTPyAu2tmA0E4X98NSR7eIbeC6ycCqCeE7wjfDIgzEbkzdEVJXRtOG4FbEm/uGbCRouA==", + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/micromark-util-resolve-all/-/micromark-util-resolve-all-2.0.0.tgz", + "integrity": "sha512-6KU6qO7DZ7GJkaCgwBNtplXCvGkJToU86ybBAUdavvgsCiG8lSSvYxr9MhwmQ+udpzywHsl4RpGJsYWG1pDOcA==", "funding": [ { "type": "GitHub Sponsors", @@ -3402,13 +5466,13 @@ } ], "dependencies": { - "micromark-util-types": "^1.0.0" + "micromark-util-types": "^2.0.0" } }, "node_modules/micromark-util-sanitize-uri": { - "version": "1.2.0", - "resolved": "https://registry.npmjs.org/micromark-util-sanitize-uri/-/micromark-util-sanitize-uri-1.2.0.tgz", - "integrity": "sha512-QO4GXv0XZfWey4pYFndLUKEAktKkG5kZTdUNaTAkzbuJxn2tNBOr+QtxR2XpWaMhbImT2dPzyLrPXLlPhph34A==", + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/micromark-util-sanitize-uri/-/micromark-util-sanitize-uri-2.0.0.tgz", + "integrity": "sha512-WhYv5UEcZrbAtlsnPuChHUAsu/iBPOVaEVsntLBIdpibO0ddy8OzavZz3iL2xVvBZOpolujSliP65Kq0/7KIYw==", "funding": [ { "type": "GitHub Sponsors", @@ -3420,15 +5484,15 @@ } ], "dependencies": { - "micromark-util-character": "^1.0.0", - "micromark-util-encode": "^1.0.0", - "micromark-util-symbol": "^1.0.0" + "micromark-util-character": "^2.0.0", + "micromark-util-encode": "^2.0.0", + "micromark-util-symbol": "^2.0.0" } }, "node_modules/micromark-util-subtokenize": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/micromark-util-subtokenize/-/micromark-util-subtokenize-1.1.0.tgz", - "integrity": "sha512-kUQHyzRoxvZO2PuLzMt2P/dwVsTiivCK8icYTeR+3WgbuPqfHgPPy7nFKbeqRivBvn/3N3GBiNC+JRTMSxEC7A==", + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/micromark-util-subtokenize/-/micromark-util-subtokenize-2.0.1.tgz", + "integrity": "sha512-jZNtiFl/1aY73yS3UGQkutD0UbhTt68qnRpw2Pifmz5wV9h8gOVsN70v+Lq/f1rKaU/W8pxRe8y8Q9FX1AOe1Q==", "funding": [ { "type": "GitHub Sponsors", @@ -3440,16 +5504,16 @@ } ], "dependencies": { - "micromark-util-chunked": "^1.0.0", - "micromark-util-symbol": "^1.0.0", - "micromark-util-types": "^1.0.0", - "uvu": "^0.5.0" + "devlop": "^1.0.0", + "micromark-util-chunked": "^2.0.0", + "micromark-util-symbol": "^2.0.0", + "micromark-util-types": "^2.0.0" } }, "node_modules/micromark-util-symbol": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/micromark-util-symbol/-/micromark-util-symbol-1.1.0.tgz", - "integrity": "sha512-uEjpEYY6KMs1g7QfJ2eX1SQEV+ZT4rUD3UcF6l57acZvLNK7PBZL+ty82Z1qhK1/yXIY4bdx04FKMgR0g4IAag==", + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/micromark-util-symbol/-/micromark-util-symbol-2.0.0.tgz", + "integrity": "sha512-8JZt9ElZ5kyTnO94muPxIGS8oyElRJaiJO8EzV6ZSyGQ1Is8xwl4Q45qU5UOg+bGH4AikWziz0iN4sFLWs8PGw==", "funding": [ { "type": "GitHub Sponsors", @@ -3462,9 +5526,9 @@ ] }, "node_modules/micromark-util-types": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/micromark-util-types/-/micromark-util-types-1.1.0.tgz", - "integrity": "sha512-ukRBgie8TIAcacscVHSiddHjO4k/q3pnedmzMQ4iwDcK0FtFCohKOlFbaOL/mPgfnPsL3C1ZyxJa4sbWrBl3jg==", + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/micromark-util-types/-/micromark-util-types-2.0.0.tgz", + "integrity": "sha512-oNh6S2WMHWRZrmutsRmDDfkzKtxF+bc2VxLC9dvtrDIRFln627VsFP6fLMgTryGDljgLPjkrzQSDcPrjPyDJ5w==", "funding": [ { "type": "GitHub Sponsors", @@ -3477,28 +5541,17 @@ ] }, "node_modules/micromatch": { - "version": "4.0.5", - "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-4.0.5.tgz", - "integrity": "sha512-DMy+ERcEW2q8Z2Po+WNXuw3c5YaUSFjAO5GsJqfEl7UjvtIuFKO6ZrKvcItdy98dwFI2N1tg3zNIdKaQT+aNdA==", + "version": "4.0.7", + "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-4.0.7.tgz", + "integrity": "sha512-LPP/3KorzCwBxfeUuZmaR6bG2kdeHSbe0P2tY3FLRU4vYrjYz5hI4QZwV0njUx3jeuKe67YukQ1LSPZBKDqO/Q==", "dependencies": { - "braces": "^3.0.2", + "braces": "^3.0.3", "picomatch": "^2.3.1" }, "engines": { "node": ">=8.6" } }, - "node_modules/mime": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/mime/-/mime-3.0.0.tgz", - "integrity": "sha512-jSCU7/VB1loIWBZe14aEYHU/+1UMEHoaO7qxCOVJOw9GgH72VAWppxNcjU+x9a2k3GSIBXNKxXQFqRvvZ7vr3A==", - "bin": { - "mime": "cli.js" - }, - "engines": { - "node": ">=10.0.0" - } - }, "node_modules/mimic-fn": { "version": "4.0.0", "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-4.0.0.tgz", @@ -3510,12 +5563,12 @@ "url": "https://github.com/sponsors/sindresorhus" } }, - "node_modules/mri": { - "version": "1.2.0", - "resolved": "https://registry.npmjs.org/mri/-/mri-1.2.0.tgz", - "integrity": "sha512-tzzskb3bG8LvYGFF/mDTpq3jpI6Q9wc3LEmBaghu+DdCssd1FakN7Bc0hVNmEyGq1bq3RgfkCb3cmQLpNPOroA==", + "node_modules/mrmime": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/mrmime/-/mrmime-2.0.0.tgz", + "integrity": "sha512-eu38+hdgojoyq63s+yTpN4XMBdt5l8HhMhc4VKLO9KM5caLIBvUm4thi7fFaxyTmCKeNnXZ5pAlBwCUnhA09uw==", "engines": { - "node": ">=4" + "node": ">=10" } }, "node_modules/ms": { @@ -3523,10 +5576,16 @@ "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==" }, + "node_modules/muggle-string": { + "version": "0.4.1", + "resolved": "https://registry.npmjs.org/muggle-string/-/muggle-string-0.4.1.tgz", + "integrity": "sha512-VNTrAak/KhO2i8dqqnqnAHOa3cYBwXEZe9h+D5h/1ZqFSTEFHdM65lR7RoIqq3tBBYavsOXV84NoHXZ0AkPyqQ==", + "license": "MIT" + }, "node_modules/nanoid": { - "version": "3.3.6", - "resolved": "https://registry.npmjs.org/nanoid/-/nanoid-3.3.6.tgz", - "integrity": "sha512-BGcqMMJuToF7i1rt+2PWSNVnWIkGCU78jBG3RxO/bZlnZPK2Cmi2QaffxGO/2RvWi9sL+FAiRiXMgsyxQ1DIDA==", + "version": "3.3.7", + "resolved": "https://registry.npmjs.org/nanoid/-/nanoid-3.3.7.tgz", + "integrity": "sha512-eSRppjcPIatRIMC1U6UngP8XFcz8MQWGQdt1MTBQ7NaAmvXDfvNxbvWV3x2y6CdEUciCSsDHDQZbhYaB8QEo2g==", "funding": [ { "type": "github", @@ -3540,12 +5599,20 @@ "node": "^10 || ^12 || ^13.7 || ^14 || >=15.0.1" } }, + "node_modules/neotraverse": { + "version": "0.6.18", + "resolved": "https://registry.npmjs.org/neotraverse/-/neotraverse-0.6.18.tgz", + "integrity": "sha512-Z4SmBUweYa09+o6pG+eASabEpP6QkQ70yHj351pQoEXIs8uHbaU2DWVmzBANKgflPa47A50PtB2+NgRpQvr7vA==", + "engines": { + "node": ">= 10" + } + }, "node_modules/nlcst-to-string": { - "version": "3.1.1", - "resolved": "https://registry.npmjs.org/nlcst-to-string/-/nlcst-to-string-3.1.1.tgz", - "integrity": "sha512-63mVyqaqt0cmn2VcI2aH6kxe1rLAmSROqHMA0i4qqg1tidkfExgpb0FGMikMCn86mw5dFtBtEANfmSSK7TjNHw==", + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/nlcst-to-string/-/nlcst-to-string-4.0.0.tgz", + "integrity": "sha512-YKLBCcUYKAg0FNlOBT6aI91qFmSiFKiluk655WzPF+DDMA02qIyy8uiRqI8QXtcFpEvll12LpL5MXqEmAZ+dcA==", "dependencies": { - "@types/nlcst": "^1.0.0" + "@types/nlcst": "^2.0.0" }, "funding": { "type": "opencollective", @@ -3553,9 +5620,9 @@ } }, "node_modules/node-releases": { - "version": "2.0.13", - "resolved": "https://registry.npmjs.org/node-releases/-/node-releases-2.0.13.tgz", - "integrity": "sha512-uYr7J37ae/ORWdZeQ1xxMJe3NtdmqMC/JZK+geofDrkLUApKRHPd18/TxtBOJ4A0/+uUIliorNrfYV6s1b02eQ==" + "version": "2.0.14", + "resolved": "https://registry.npmjs.org/node-releases/-/node-releases-2.0.14.tgz", + "integrity": "sha512-y10wOWt8yZpqXmOgRo77WaHEmhYQYGNA6y421PKsKYWEK8aW+cqAphborZDhqfyKrbZEN92CN1X2KbafY2s7Yw==" }, "node_modules/normalize-path": { "version": "3.0.0", @@ -3565,6 +5632,14 @@ "node": ">=0.10.0" } }, + "node_modules/normalize-range": { + "version": "0.1.2", + "resolved": "https://registry.npmjs.org/normalize-range/-/normalize-range-0.1.2.tgz", + "integrity": "sha512-bdok/XvKII3nUpklnV6P2hxtMNrCboOjAcyBuQnWEhO665FwrSNRxU+AqpsyvO6LgGYPspN+lu5CLtw4jPRKNA==", + "engines": { + "node": ">=0.10.0" + } + }, "node_modules/npm-run-path": { "version": "5.1.0", "resolved": "https://registry.npmjs.org/npm-run-path/-/npm-run-path-5.1.0.tgz", @@ -3604,40 +5679,23 @@ "url": "https://github.com/sponsors/sindresorhus" } }, - "node_modules/open": { - "version": "9.1.0", - "resolved": "https://registry.npmjs.org/open/-/open-9.1.0.tgz", - "integrity": "sha512-OS+QTnw1/4vrf+9hh1jc1jnYjzSG4ttTBB8UxOwAnInG3Uo4ssetzC1ihqaIHjLJnA5GGlRl6QlZXOTQhRBUvg==", - "dependencies": { - "default-browser": "^4.0.0", - "define-lazy-prop": "^3.0.0", - "is-inside-container": "^1.0.0", - "is-wsl": "^2.2.0" - }, - "engines": { - "node": ">=14.16" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, "node_modules/ora": { - "version": "6.3.1", - "resolved": "https://registry.npmjs.org/ora/-/ora-6.3.1.tgz", - "integrity": "sha512-ERAyNnZOfqM+Ao3RAvIXkYh5joP220yf59gVe2X/cI6SiCxIdi4c9HZKZD8R6q/RDXEje1THBju6iExiSsgJaQ==", + "version": "8.0.1", + "resolved": "https://registry.npmjs.org/ora/-/ora-8.0.1.tgz", + "integrity": "sha512-ANIvzobt1rls2BDny5fWZ3ZVKyD6nscLvfFRpQgfWsythlcsVUC9kL0zq6j2Z5z9wwp1kd7wpsD/T9qNPVLCaQ==", "dependencies": { - "chalk": "^5.0.0", + "chalk": "^5.3.0", "cli-cursor": "^4.0.0", - "cli-spinners": "^2.6.1", + "cli-spinners": "^2.9.2", "is-interactive": "^2.0.0", - "is-unicode-supported": "^1.1.0", - "log-symbols": "^5.1.0", - "stdin-discarder": "^0.1.0", - "strip-ansi": "^7.0.1", - "wcwidth": "^1.0.1" + "is-unicode-supported": "^2.0.0", + "log-symbols": "^6.0.0", + "stdin-discarder": "^0.2.1", + "string-width": "^7.0.0", + "strip-ansi": "^7.1.0" }, "engines": { - "node": "^12.20.0 || ^14.13.1 || >=16.0.0" + "node": ">=18" }, "funding": { "url": "https://github.com/sponsors/sindresorhus" @@ -3655,53 +5713,65 @@ } }, "node_modules/p-limit": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-4.0.0.tgz", - "integrity": "sha512-5b0R4txpzjPWVw/cXXUResoD4hb6U/x9BH08L7nw+GN1sezDzPdxeRvpc9c433fZhBan/wusjbCsqwqm4EIBIQ==", + "version": "6.1.0", + "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-6.1.0.tgz", + "integrity": "sha512-H0jc0q1vOzlEk0TqAKXKZxdl7kX3OFUzCnNVUnq5Pc3DGo0kpeaMuPqxQn235HibwBEb0/pm9dgKTjXy66fBkg==", "dependencies": { - "yocto-queue": "^1.0.0" + "yocto-queue": "^1.1.1" }, "engines": { - "node": "^12.20.0 || ^14.13.1 || >=16.0.0" + "node": ">=18" }, "funding": { "url": "https://github.com/sponsors/sindresorhus" } }, "node_modules/p-locate": { - "version": "5.0.0", - "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-5.0.0.tgz", - "integrity": "sha512-LaNjtRWUBY++zB5nE/NwcaoMylSPk+S+ZHNB1TzdbMJMny6dynpAGt7X/tl/QYq3TIeE6nxHppbo2LGymrG5Pw==", + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-4.1.0.tgz", + "integrity": "sha512-R79ZZ/0wAxKGu3oYMlz8jy/kbhsNrS7SKZ7PxEHBgJ5+F2mtFW2fK2cOtBh1cHYkQsbzFV7I+EoRKe6Yt0oK7A==", "dependencies": { - "p-limit": "^3.0.2" + "p-limit": "^2.2.0" }, "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" + "node": ">=8" } }, "node_modules/p-locate/node_modules/p-limit": { - "version": "3.1.0", - "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-3.1.0.tgz", - "integrity": "sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ==", + "version": "2.3.0", + "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-2.3.0.tgz", + "integrity": "sha512-//88mFWSJx8lxCzwdAABTJL2MyWB12+eIY7MDL2SqLmAkeKU9qxRvWuSyTjm3FUmpBEMuFfckAIqEaVGUDxb6w==", "dependencies": { - "yocto-queue": "^0.1.0" + "p-try": "^2.0.0" }, "engines": { - "node": ">=10" + "node": ">=6" }, "funding": { "url": "https://github.com/sponsors/sindresorhus" } }, - "node_modules/p-locate/node_modules/yocto-queue": { - "version": "0.1.0", - "resolved": "https://registry.npmjs.org/yocto-queue/-/yocto-queue-0.1.0.tgz", - "integrity": "sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q==", + "node_modules/p-queue": { + "version": "8.0.1", + "resolved": "https://registry.npmjs.org/p-queue/-/p-queue-8.0.1.tgz", + "integrity": "sha512-NXzu9aQJTAzbBqOt2hwsR63ea7yvxJc0PwN/zobNAudYfb1B7R08SzB4TsLeSbUCuG467NhnoT0oO6w1qRO+BA==", + "dependencies": { + "eventemitter3": "^5.0.1", + "p-timeout": "^6.1.2" + }, "engines": { - "node": ">=10" + "node": ">=18" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/p-timeout": { + "version": "6.1.2", + "resolved": "https://registry.npmjs.org/p-timeout/-/p-timeout-6.1.2.tgz", + "integrity": "sha512-UbD77BuZ9Bc9aABo74gfXhNvzC9Tx7SxtHSh1fxvx3jTLLYvmVhiQZZrJzqqU0jKbN32kb5VOKiLEQI/3bIjgQ==", + "engines": { + "node": ">=14.16" }, "funding": { "url": "https://github.com/sponsors/sindresorhus" @@ -3716,13 +5786,16 @@ } }, "node_modules/parse-latin": { - "version": "5.0.1", - "resolved": "https://registry.npmjs.org/parse-latin/-/parse-latin-5.0.1.tgz", - "integrity": "sha512-b/K8ExXaWC9t34kKeDV8kGXBkXZ1HCSAZRYE7HR14eA1GlXX5L8iWhs8USJNhQU9q5ci413jCKF0gOyovvyRBg==", + "version": "7.0.0", + "resolved": "https://registry.npmjs.org/parse-latin/-/parse-latin-7.0.0.tgz", + "integrity": "sha512-mhHgobPPua5kZ98EF4HWiH167JWBfl4pvAIXXdbaVohtK7a6YBOy56kvhCqduqyo/f3yrHFWmqmiMg/BkBkYYQ==", "dependencies": { - "nlcst-to-string": "^3.0.0", - "unist-util-modify-children": "^3.0.0", - "unist-util-visit-children": "^2.0.0" + "@types/nlcst": "^2.0.0", + "@types/unist": "^3.0.0", + "nlcst-to-string": "^4.0.0", + "unist-util-modify-children": "^4.0.0", + "unist-util-visit-children": "^3.0.0", + "vfile": "^6.0.0" }, "funding": { "type": "github", @@ -3730,9 +5803,21 @@ } }, "node_modules/parse5": { - "version": "6.0.1", - "resolved": "https://registry.npmjs.org/parse5/-/parse5-6.0.1.tgz", - "integrity": "sha512-Ofn/CTFzRGTTxwpNEs9PP93gXShHcTq255nzRYSKe8AkVpZY7e1fpmTfOyoIvjP5HG7Z2ZM7VS9PPhQGW2pOpw==" + "version": "7.1.2", + "resolved": "https://registry.npmjs.org/parse5/-/parse5-7.1.2.tgz", + "integrity": "sha512-Czj1WaSVpaoj0wbhMzLmWD69anp2WH7FXMB9n1Sy8/ZFF9jolSQVMu1Ij5WIyGmcBmhk7EOndpO4mIpihVqAXw==", + "dependencies": { + "entities": "^4.4.0" + }, + "funding": { + "url": "https://github.com/inikulin/parse5?sponsor=1" + } + }, + "node_modules/path-browserify": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/path-browserify/-/path-browserify-1.0.1.tgz", + "integrity": "sha512-b7uo2UCUOYZcnF/3ID0lulOJi/bafxa1xPe7ZPsammBSpjSWQkjNxlt635YGS2MiR9GjvuXCtz2emr3jbsz98g==", + "license": "MIT" }, "node_modules/path-exists": { "version": "4.0.0", @@ -3750,20 +5835,15 @@ "node": ">=8" } }, - "node_modules/path-parse": { - "version": "1.0.7", - "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.7.tgz", - "integrity": "sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==" - }, "node_modules/path-to-regexp": { - "version": "6.2.1", - "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-6.2.1.tgz", - "integrity": "sha512-JLyh7xT1kizaEvcaXOQwOc2/Yhw6KZOvPf1S8401UyLk86CU79LN3vl7ztXGm/pZ+YjoyAJ4rxmHwbkBXJX+yw==" + "version": "6.2.2", + "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-6.2.2.tgz", + "integrity": "sha512-GQX3SSMokngb36+whdpRXE+3f9V8UzyAorlYvOGx87ufGHehNTn5lCxrKtLyZ4Yl/wEKnNnr98ZzOwwDZV5ogw==" }, "node_modules/picocolors": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/picocolors/-/picocolors-1.0.0.tgz", - "integrity": "sha512-1fygroTLlHu66zi26VoTDv8yRgm0Fccecssto+MhsZ0D/DGW2sm8E8AjW7NU5VVTRt5GxbeZ5qBuJr+HyLYkjQ==" + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/picocolors/-/picocolors-1.0.1.tgz", + "integrity": "sha512-anP1Z8qwhkbmu7MFP5iTt+wQKXgwzf7zTyGlcdzabySa9vd0Xt392U0rVmz9poOaBj0uHJKyyo9/upk0HrEQew==" }, "node_modules/picomatch": { "version": "2.3.1", @@ -3795,58 +5875,10 @@ "node": ">=8" } }, - "node_modules/pkg-dir/node_modules/find-up": { - "version": "4.1.0", - "resolved": "https://registry.npmjs.org/find-up/-/find-up-4.1.0.tgz", - "integrity": "sha512-PpOwAdQ/YlXQ2vj8a3h8IipDuYRi3wceVQQGYWxNINccq40Anw7BlsEXCMbt1Zt+OLA6Fq9suIpIWD0OsnISlw==", - "dependencies": { - "locate-path": "^5.0.0", - "path-exists": "^4.0.0" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/pkg-dir/node_modules/locate-path": { - "version": "5.0.0", - "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-5.0.0.tgz", - "integrity": "sha512-t7hw9pI+WvuwNJXwk5zVHpyhIqzg2qTlklJOf0mVxGSbe3Fp2VieZcduNYjaLDoy6p9uGpQEGWG87WpMKlNq8g==", - "dependencies": { - "p-locate": "^4.1.0" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/pkg-dir/node_modules/p-limit": { - "version": "2.3.0", - "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-2.3.0.tgz", - "integrity": "sha512-//88mFWSJx8lxCzwdAABTJL2MyWB12+eIY7MDL2SqLmAkeKU9qxRvWuSyTjm3FUmpBEMuFfckAIqEaVGUDxb6w==", - "dependencies": { - "p-try": "^2.0.0" - }, - "engines": { - "node": ">=6" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/pkg-dir/node_modules/p-locate": { - "version": "4.1.0", - "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-4.1.0.tgz", - "integrity": "sha512-R79ZZ/0wAxKGu3oYMlz8jy/kbhsNrS7SKZ7PxEHBgJ5+F2mtFW2fK2cOtBh1cHYkQsbzFV7I+EoRKe6Yt0oK7A==", - "dependencies": { - "p-limit": "^2.2.0" - }, - "engines": { - "node": ">=8" - } - }, "node_modules/postcss": { - "version": "8.4.26", - "resolved": "https://registry.npmjs.org/postcss/-/postcss-8.4.26.tgz", - "integrity": "sha512-jrXHFF8iTloAenySjM/ob3gSj7pCu0Ji49hnjqzsgSRa50hkWCKD0HQ+gMNJkW38jBI68MpAAg7ZWwHwX8NMMw==", + "version": "8.4.41", + "resolved": "https://registry.npmjs.org/postcss/-/postcss-8.4.41.tgz", + "integrity": "sha512-TesUflQ0WKZqAvg52PWL6kHgLKP6xB6heTOdoYM0Wt2UHyxNa4K25EZZMgKns3BH1RLVbZCREPpLY0rhnNoHVQ==", "funding": [ { "type": "opencollective", @@ -3862,57 +5894,724 @@ } ], "dependencies": { - "nanoid": "^3.3.6", - "picocolors": "^1.0.0", - "source-map-js": "^1.0.2" + "nanoid": "^3.3.7", + "picocolors": "^1.0.1", + "source-map-js": "^1.2.0" }, "engines": { "node": "^10 || ^12 || >=14" } }, - "node_modules/preferred-pm": { - "version": "3.0.3", - "resolved": "https://registry.npmjs.org/preferred-pm/-/preferred-pm-3.0.3.tgz", - "integrity": "sha512-+wZgbxNES/KlJs9q40F/1sfOd/j7f1O9JaHcW5Dsn3aUUOZg3L2bjpVUcKV2jvtElYfoTuQiNeMfQJ4kwUAhCQ==", + "node_modules/postcss-attribute-case-insensitive": { + "version": "6.0.3", + "resolved": "https://registry.npmjs.org/postcss-attribute-case-insensitive/-/postcss-attribute-case-insensitive-6.0.3.tgz", + "integrity": "sha512-KHkmCILThWBRtg+Jn1owTnHPnFit4OkqS+eKiGEOPIGke54DCeYGJ6r0Fx/HjfE9M9kznApCLcU0DvnPchazMQ==", + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/csstools" + }, + { + "type": "opencollective", + "url": "https://opencollective.com/csstools" + } + ], "dependencies": { - "find-up": "^5.0.0", - "find-yarn-workspace-root2": "1.2.16", - "path-exists": "^4.0.0", - "which-pm": "2.0.0" + "postcss-selector-parser": "^6.0.13" }, "engines": { - "node": ">=10" + "node": "^14 || ^16 || >=18" + }, + "peerDependencies": { + "postcss": "^8.4" + } + }, + "node_modules/postcss-clamp": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/postcss-clamp/-/postcss-clamp-4.1.0.tgz", + "integrity": "sha512-ry4b1Llo/9zz+PKC+030KUnPITTJAHeOwjfAyyB60eT0AorGLdzp52s31OsPRHRf8NchkgFoG2y6fCfn1IV1Ow==", + "dependencies": { + "postcss-value-parser": "^4.2.0" + }, + "engines": { + "node": ">=7.6.0" + }, + "peerDependencies": { + "postcss": "^8.4.6" + } + }, + "node_modules/postcss-color-functional-notation": { + "version": "6.0.14", + "resolved": "https://registry.npmjs.org/postcss-color-functional-notation/-/postcss-color-functional-notation-6.0.14.tgz", + "integrity": "sha512-dNUX+UH4dAozZ8uMHZ3CtCNYw8fyFAmqqdcyxMr7PEdM9jLXV19YscoYO0F25KqZYhmtWKQ+4tKrIZQrwzwg7A==", + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/csstools" + }, + { + "type": "opencollective", + "url": "https://opencollective.com/csstools" + } + ], + "dependencies": { + "@csstools/css-color-parser": "^2.0.4", + "@csstools/css-parser-algorithms": "^2.7.1", + "@csstools/css-tokenizer": "^2.4.1", + "@csstools/postcss-progressive-custom-properties": "^3.3.0", + "@csstools/utilities": "^1.0.0" + }, + "engines": { + "node": "^14 || ^16 || >=18" + }, + "peerDependencies": { + "postcss": "^8.4" + } + }, + "node_modules/postcss-color-hex-alpha": { + "version": "9.0.4", + "resolved": "https://registry.npmjs.org/postcss-color-hex-alpha/-/postcss-color-hex-alpha-9.0.4.tgz", + "integrity": "sha512-XQZm4q4fNFqVCYMGPiBjcqDhuG7Ey2xrl99AnDJMyr5eDASsAGalndVgHZF8i97VFNy1GQeZc4q2ydagGmhelQ==", + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/csstools" + }, + { + "type": "opencollective", + "url": "https://opencollective.com/csstools" + } + ], + "dependencies": { + "@csstools/utilities": "^1.0.0", + "postcss-value-parser": "^4.2.0" + }, + "engines": { + "node": "^14 || ^16 || >=18" + }, + "peerDependencies": { + "postcss": "^8.4" + } + }, + "node_modules/postcss-color-rebeccapurple": { + "version": "9.0.3", + "resolved": "https://registry.npmjs.org/postcss-color-rebeccapurple/-/postcss-color-rebeccapurple-9.0.3.tgz", + "integrity": "sha512-ruBqzEFDYHrcVq3FnW3XHgwRqVMrtEPLBtD7K2YmsLKVc2jbkxzzNEctJKsPCpDZ+LeMHLKRDoSShVefGc+CkQ==", + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/csstools" + }, + { + "type": "opencollective", + "url": "https://opencollective.com/csstools" + } + ], + "dependencies": { + "@csstools/utilities": "^1.0.0", + "postcss-value-parser": "^4.2.0" + }, + "engines": { + "node": "^14 || ^16 || >=18" + }, + "peerDependencies": { + "postcss": "^8.4" + } + }, + "node_modules/postcss-custom-media": { + "version": "10.0.8", + "resolved": "https://registry.npmjs.org/postcss-custom-media/-/postcss-custom-media-10.0.8.tgz", + "integrity": "sha512-V1KgPcmvlGdxTel4/CyQtBJEFhMVpEmRGFrnVtgfGIHj5PJX9vO36eFBxKBeJn+aCDTed70cc+98Mz3J/uVdGQ==", + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/csstools" + }, + { + "type": "opencollective", + "url": "https://opencollective.com/csstools" + } + ], + "dependencies": { + "@csstools/cascade-layer-name-parser": "^1.0.13", + "@csstools/css-parser-algorithms": "^2.7.1", + "@csstools/css-tokenizer": "^2.4.1", + "@csstools/media-query-list-parser": "^2.1.13" + }, + "engines": { + "node": "^14 || ^16 || >=18" + }, + "peerDependencies": { + "postcss": "^8.4" + } + }, + "node_modules/postcss-custom-properties": { + "version": "13.3.12", + "resolved": "https://registry.npmjs.org/postcss-custom-properties/-/postcss-custom-properties-13.3.12.tgz", + "integrity": "sha512-oPn/OVqONB2ZLNqN185LDyaVByELAA/u3l2CS2TS16x2j2XsmV4kd8U49+TMxmUsEU9d8fB/I10E6U7kB0L1BA==", + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/csstools" + }, + { + "type": "opencollective", + "url": "https://opencollective.com/csstools" + } + ], + "dependencies": { + "@csstools/cascade-layer-name-parser": "^1.0.13", + "@csstools/css-parser-algorithms": "^2.7.1", + "@csstools/css-tokenizer": "^2.4.1", + "@csstools/utilities": "^1.0.0", + "postcss-value-parser": "^4.2.0" + }, + "engines": { + "node": "^14 || ^16 || >=18" + }, + "peerDependencies": { + "postcss": "^8.4" + } + }, + "node_modules/postcss-custom-selectors": { + "version": "7.1.12", + "resolved": "https://registry.npmjs.org/postcss-custom-selectors/-/postcss-custom-selectors-7.1.12.tgz", + "integrity": "sha512-ctIoprBMJwByYMGjXG0F7IT2iMF2hnamQ+aWZETyBM0aAlyaYdVZTeUkk8RB+9h9wP+NdN3f01lfvKl2ZSqC0g==", + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/csstools" + }, + { + "type": "opencollective", + "url": "https://opencollective.com/csstools" + } + ], + "dependencies": { + "@csstools/cascade-layer-name-parser": "^1.0.13", + "@csstools/css-parser-algorithms": "^2.7.1", + "@csstools/css-tokenizer": "^2.4.1", + "postcss-selector-parser": "^6.1.0" + }, + "engines": { + "node": "^14 || ^16 || >=18" + }, + "peerDependencies": { + "postcss": "^8.4" + } + }, + "node_modules/postcss-dir-pseudo-class": { + "version": "8.0.1", + "resolved": "https://registry.npmjs.org/postcss-dir-pseudo-class/-/postcss-dir-pseudo-class-8.0.1.tgz", + "integrity": "sha512-uULohfWBBVoFiZXgsQA24JV6FdKIidQ+ZqxOouhWwdE+qJlALbkS5ScB43ZTjPK+xUZZhlaO/NjfCt5h4IKUfw==", + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/csstools" + }, + { + "type": "opencollective", + "url": "https://opencollective.com/csstools" + } + ], + "dependencies": { + "postcss-selector-parser": "^6.0.13" + }, + "engines": { + "node": "^14 || ^16 || >=18" + }, + "peerDependencies": { + "postcss": "^8.4" + } + }, + "node_modules/postcss-double-position-gradients": { + "version": "5.0.7", + "resolved": "https://registry.npmjs.org/postcss-double-position-gradients/-/postcss-double-position-gradients-5.0.7.tgz", + "integrity": "sha512-1xEhjV9u1s4l3iP5lRt1zvMjI/ya8492o9l/ivcxHhkO3nOz16moC4JpMxDUGrOs4R3hX+KWT7gKoV842cwRgg==", + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/csstools" + }, + { + "type": "opencollective", + "url": "https://opencollective.com/csstools" + } + ], + "dependencies": { + "@csstools/postcss-progressive-custom-properties": "^3.3.0", + "@csstools/utilities": "^1.0.0", + "postcss-value-parser": "^4.2.0" + }, + "engines": { + "node": "^14 || ^16 || >=18" + }, + "peerDependencies": { + "postcss": "^8.4" + } + }, + "node_modules/postcss-focus-visible": { + "version": "9.0.1", + "resolved": "https://registry.npmjs.org/postcss-focus-visible/-/postcss-focus-visible-9.0.1.tgz", + "integrity": "sha512-N2VQ5uPz3Z9ZcqI5tmeholn4d+1H14fKXszpjogZIrFbhaq0zNAtq8sAnw6VLiqGbL8YBzsnu7K9bBkTqaRimQ==", + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/csstools" + }, + { + "type": "opencollective", + "url": "https://opencollective.com/csstools" + } + ], + "dependencies": { + "postcss-selector-parser": "^6.0.13" + }, + "engines": { + "node": "^14 || ^16 || >=18" + }, + "peerDependencies": { + "postcss": "^8.4" + } + }, + "node_modules/postcss-focus-within": { + "version": "8.0.1", + "resolved": "https://registry.npmjs.org/postcss-focus-within/-/postcss-focus-within-8.0.1.tgz", + "integrity": "sha512-NFU3xcY/xwNaapVb+1uJ4n23XImoC86JNwkY/uduytSl2s9Ekc2EpzmRR63+ExitnW3Mab3Fba/wRPCT5oDILA==", + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/csstools" + }, + { + "type": "opencollective", + "url": "https://opencollective.com/csstools" + } + ], + "dependencies": { + "postcss-selector-parser": "^6.0.13" + }, + "engines": { + "node": "^14 || ^16 || >=18" + }, + "peerDependencies": { + "postcss": "^8.4" + } + }, + "node_modules/postcss-font-variant": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/postcss-font-variant/-/postcss-font-variant-5.0.0.tgz", + "integrity": "sha512-1fmkBaCALD72CK2a9i468mA/+tr9/1cBxRRMXOUaZqO43oWPR5imcyPjXwuv7PXbCid4ndlP5zWhidQVVa3hmA==", + "peerDependencies": { + "postcss": "^8.1.0" + } + }, + "node_modules/postcss-gap-properties": { + "version": "5.0.1", + "resolved": "https://registry.npmjs.org/postcss-gap-properties/-/postcss-gap-properties-5.0.1.tgz", + "integrity": "sha512-k2z9Cnngc24c0KF4MtMuDdToROYqGMMUQGcE6V0odwjHyOHtaDBlLeRBV70y9/vF7KIbShrTRZ70JjsI1BZyWw==", + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/csstools" + }, + { + "type": "opencollective", + "url": "https://opencollective.com/csstools" + } + ], + "engines": { + "node": "^14 || ^16 || >=18" + }, + "peerDependencies": { + "postcss": "^8.4" + } + }, + "node_modules/postcss-image-set-function": { + "version": "6.0.3", + "resolved": "https://registry.npmjs.org/postcss-image-set-function/-/postcss-image-set-function-6.0.3.tgz", + "integrity": "sha512-i2bXrBYzfbRzFnm+pVuxVePSTCRiNmlfssGI4H0tJQvDue+yywXwUxe68VyzXs7cGtMaH6MCLY6IbCShrSroCw==", + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/csstools" + }, + { + "type": "opencollective", + "url": "https://opencollective.com/csstools" + } + ], + "dependencies": { + "@csstools/utilities": "^1.0.0", + "postcss-value-parser": "^4.2.0" + }, + "engines": { + "node": "^14 || ^16 || >=18" + }, + "peerDependencies": { + "postcss": "^8.4" + } + }, + "node_modules/postcss-lab-function": { + "version": "6.0.19", + "resolved": "https://registry.npmjs.org/postcss-lab-function/-/postcss-lab-function-6.0.19.tgz", + "integrity": "sha512-vwln/mgvFrotJuGV8GFhpAOu9iGf3pvTBr6dLPDmUcqVD5OsQpEFyQMAFTxSxWXGEzBj6ld4pZ/9GDfEpXvo0g==", + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/csstools" + }, + { + "type": "opencollective", + "url": "https://opencollective.com/csstools" + } + ], + "dependencies": { + "@csstools/css-color-parser": "^2.0.4", + "@csstools/css-parser-algorithms": "^2.7.1", + "@csstools/css-tokenizer": "^2.4.1", + "@csstools/postcss-progressive-custom-properties": "^3.3.0", + "@csstools/utilities": "^1.0.0" + }, + "engines": { + "node": "^14 || ^16 || >=18" + }, + "peerDependencies": { + "postcss": "^8.4" + } + }, + "node_modules/postcss-logical": { + "version": "7.0.1", + "resolved": "https://registry.npmjs.org/postcss-logical/-/postcss-logical-7.0.1.tgz", + "integrity": "sha512-8GwUQZE0ri0K0HJHkDv87XOLC8DE0msc+HoWLeKdtjDZEwpZ5xuK3QdV6FhmHSQW40LPkg43QzvATRAI3LsRkg==", + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/csstools" + }, + { + "type": "opencollective", + "url": "https://opencollective.com/csstools" + } + ], + "dependencies": { + "postcss-value-parser": "^4.2.0" + }, + "engines": { + "node": "^14 || ^16 || >=18" + }, + "peerDependencies": { + "postcss": "^8.4" + } + }, + "node_modules/postcss-nesting": { + "version": "12.1.5", + "resolved": "https://registry.npmjs.org/postcss-nesting/-/postcss-nesting-12.1.5.tgz", + "integrity": "sha512-N1NgI1PDCiAGWPTYrwqm8wpjv0bgDmkYHH72pNsqTCv9CObxjxftdYu6AKtGN+pnJa7FQjMm3v4sp8QJbFsYdQ==", + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/csstools" + }, + { + "type": "opencollective", + "url": "https://opencollective.com/csstools" + } + ], + "dependencies": { + "@csstools/selector-resolve-nested": "^1.1.0", + "@csstools/selector-specificity": "^3.1.1", + "postcss-selector-parser": "^6.1.0" + }, + "engines": { + "node": "^14 || ^16 || >=18" + }, + "peerDependencies": { + "postcss": "^8.4" + } + }, + "node_modules/postcss-opacity-percentage": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/postcss-opacity-percentage/-/postcss-opacity-percentage-2.0.0.tgz", + "integrity": "sha512-lyDrCOtntq5Y1JZpBFzIWm2wG9kbEdujpNt4NLannF+J9c8CgFIzPa80YQfdza+Y+yFfzbYj/rfoOsYsooUWTQ==", + "funding": [ + { + "type": "kofi", + "url": "https://ko-fi.com/mrcgrtz" + }, + { + "type": "liberapay", + "url": "https://liberapay.com/mrcgrtz" + } + ], + "engines": { + "node": "^14 || ^16 || >=18" + }, + "peerDependencies": { + "postcss": "^8.2" + } + }, + "node_modules/postcss-overflow-shorthand": { + "version": "5.0.1", + "resolved": "https://registry.npmjs.org/postcss-overflow-shorthand/-/postcss-overflow-shorthand-5.0.1.tgz", + "integrity": "sha512-XzjBYKLd1t6vHsaokMV9URBt2EwC9a7nDhpQpjoPk2HRTSQfokPfyAS/Q7AOrzUu6q+vp/GnrDBGuj/FCaRqrQ==", + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/csstools" + }, + { + "type": "opencollective", + "url": "https://opencollective.com/csstools" + } + ], + "dependencies": { + "postcss-value-parser": "^4.2.0" + }, + "engines": { + "node": "^14 || ^16 || >=18" + }, + "peerDependencies": { + "postcss": "^8.4" + } + }, + "node_modules/postcss-page-break": { + "version": "3.0.4", + "resolved": "https://registry.npmjs.org/postcss-page-break/-/postcss-page-break-3.0.4.tgz", + "integrity": "sha512-1JGu8oCjVXLa9q9rFTo4MbeeA5FMe00/9C7lN4va606Rdb+HkxXtXsmEDrIraQ11fGz/WvKWa8gMuCKkrXpTsQ==", + "peerDependencies": { + "postcss": "^8" + } + }, + "node_modules/postcss-place": { + "version": "9.0.1", + "resolved": "https://registry.npmjs.org/postcss-place/-/postcss-place-9.0.1.tgz", + "integrity": "sha512-JfL+paQOgRQRMoYFc2f73pGuG/Aw3tt4vYMR6UA3cWVMxivviPTnMFnFTczUJOA4K2Zga6xgQVE+PcLs64WC8Q==", + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/csstools" + }, + { + "type": "opencollective", + "url": "https://opencollective.com/csstools" + } + ], + "dependencies": { + "postcss-value-parser": "^4.2.0" + }, + "engines": { + "node": "^14 || ^16 || >=18" + }, + "peerDependencies": { + "postcss": "^8.4" + } + }, + "node_modules/postcss-preset-env": { + "version": "9.6.0", + "resolved": "https://registry.npmjs.org/postcss-preset-env/-/postcss-preset-env-9.6.0.tgz", + "integrity": "sha512-Lxfk4RYjUdwPCYkc321QMdgtdCP34AeI94z+/8kVmqnTIlD4bMRQeGcMZgwz8BxHrzQiFXYIR5d7k/9JMs2MEA==", + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/csstools" + }, + { + "type": "opencollective", + "url": "https://opencollective.com/csstools" + } + ], + "dependencies": { + "@csstools/postcss-cascade-layers": "^4.0.6", + "@csstools/postcss-color-function": "^3.0.19", + "@csstools/postcss-color-mix-function": "^2.0.19", + "@csstools/postcss-content-alt-text": "^1.0.0", + "@csstools/postcss-exponential-functions": "^1.0.9", + "@csstools/postcss-font-format-keywords": "^3.0.2", + "@csstools/postcss-gamut-mapping": "^1.0.11", + "@csstools/postcss-gradients-interpolation-method": "^4.0.20", + "@csstools/postcss-hwb-function": "^3.0.18", + "@csstools/postcss-ic-unit": "^3.0.7", + "@csstools/postcss-initial": "^1.0.1", + "@csstools/postcss-is-pseudo-class": "^4.0.8", + "@csstools/postcss-light-dark-function": "^1.0.8", + "@csstools/postcss-logical-float-and-clear": "^2.0.1", + "@csstools/postcss-logical-overflow": "^1.0.1", + "@csstools/postcss-logical-overscroll-behavior": "^1.0.1", + "@csstools/postcss-logical-resize": "^2.0.1", + "@csstools/postcss-logical-viewport-units": "^2.0.11", + "@csstools/postcss-media-minmax": "^1.1.8", + "@csstools/postcss-media-queries-aspect-ratio-number-values": "^2.0.11", + "@csstools/postcss-nested-calc": "^3.0.2", + "@csstools/postcss-normalize-display-values": "^3.0.2", + "@csstools/postcss-oklab-function": "^3.0.19", + "@csstools/postcss-progressive-custom-properties": "^3.3.0", + "@csstools/postcss-relative-color-syntax": "^2.0.19", + "@csstools/postcss-scope-pseudo-class": "^3.0.1", + "@csstools/postcss-stepped-value-functions": "^3.0.10", + "@csstools/postcss-text-decoration-shorthand": "^3.0.7", + "@csstools/postcss-trigonometric-functions": "^3.0.10", + "@csstools/postcss-unset-value": "^3.0.1", + "autoprefixer": "^10.4.19", + "browserslist": "^4.23.1", + "css-blank-pseudo": "^6.0.2", + "css-has-pseudo": "^6.0.5", + "css-prefers-color-scheme": "^9.0.1", + "cssdb": "^8.1.0", + "postcss-attribute-case-insensitive": "^6.0.3", + "postcss-clamp": "^4.1.0", + "postcss-color-functional-notation": "^6.0.14", + "postcss-color-hex-alpha": "^9.0.4", + "postcss-color-rebeccapurple": "^9.0.3", + "postcss-custom-media": "^10.0.8", + "postcss-custom-properties": "^13.3.12", + "postcss-custom-selectors": "^7.1.12", + "postcss-dir-pseudo-class": "^8.0.1", + "postcss-double-position-gradients": "^5.0.7", + "postcss-focus-visible": "^9.0.1", + "postcss-focus-within": "^8.0.1", + "postcss-font-variant": "^5.0.0", + "postcss-gap-properties": "^5.0.1", + "postcss-image-set-function": "^6.0.3", + "postcss-lab-function": "^6.0.19", + "postcss-logical": "^7.0.1", + "postcss-nesting": "^12.1.5", + "postcss-opacity-percentage": "^2.0.0", + "postcss-overflow-shorthand": "^5.0.1", + "postcss-page-break": "^3.0.4", + "postcss-place": "^9.0.1", + "postcss-pseudo-class-any-link": "^9.0.2", + "postcss-replace-overflow-wrap": "^4.0.0", + "postcss-selector-not": "^7.0.2" + }, + "engines": { + "node": "^14 || ^16 || >=18" + }, + "peerDependencies": { + "postcss": "^8.4" + } + }, + "node_modules/postcss-pseudo-class-any-link": { + "version": "9.0.2", + "resolved": "https://registry.npmjs.org/postcss-pseudo-class-any-link/-/postcss-pseudo-class-any-link-9.0.2.tgz", + "integrity": "sha512-HFSsxIqQ9nA27ahyfH37cRWGk3SYyQLpk0LiWw/UGMV4VKT5YG2ONee4Pz/oFesnK0dn2AjcyequDbIjKJgB0g==", + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/csstools" + }, + { + "type": "opencollective", + "url": "https://opencollective.com/csstools" + } + ], + "dependencies": { + "postcss-selector-parser": "^6.0.13" + }, + "engines": { + "node": "^14 || ^16 || >=18" + }, + "peerDependencies": { + "postcss": "^8.4" + } + }, + "node_modules/postcss-replace-overflow-wrap": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/postcss-replace-overflow-wrap/-/postcss-replace-overflow-wrap-4.0.0.tgz", + "integrity": "sha512-KmF7SBPphT4gPPcKZc7aDkweHiKEEO8cla/GjcBK+ckKxiZslIu3C4GCRW3DNfL0o7yW7kMQu9xlZ1kXRXLXtw==", + "peerDependencies": { + "postcss": "^8.0.3" + } + }, + "node_modules/postcss-selector-not": { + "version": "7.0.2", + "resolved": "https://registry.npmjs.org/postcss-selector-not/-/postcss-selector-not-7.0.2.tgz", + "integrity": "sha512-/SSxf/90Obye49VZIfc0ls4H0P6i6V1iHv0pzZH8SdgvZOPFkF37ef1r5cyWcMflJSFJ5bfuoluTnFnBBFiuSA==", + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/csstools" + }, + { + "type": "opencollective", + "url": "https://opencollective.com/csstools" + } + ], + "dependencies": { + "postcss-selector-parser": "^6.0.13" + }, + "engines": { + "node": "^14 || ^16 || >=18" + }, + "peerDependencies": { + "postcss": "^8.4" + } + }, + "node_modules/postcss-selector-parser": { + "version": "6.1.1", + "resolved": "https://registry.npmjs.org/postcss-selector-parser/-/postcss-selector-parser-6.1.1.tgz", + "integrity": "sha512-b4dlw/9V8A71rLIDsSwVmak9z2DuBUB7CA1/wSdelNEzqsjoSPeADTWNO09lpH49Diy3/JIZ2bSPB1dI3LJCHg==", + "dependencies": { + "cssesc": "^3.0.0", + "util-deprecate": "^1.0.2" + }, + "engines": { + "node": ">=4" + } + }, + "node_modules/postcss-value-parser": { + "version": "4.2.0", + "resolved": "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-4.2.0.tgz", + "integrity": "sha512-1NNCs6uurfkVbeXG4S8JFT9t19m45ICnif8zWLd5oPSZ50QnwMfK+H3jv408d4jw/7Bttv5axS5IiHoLaVNHeQ==" + }, + "node_modules/preferred-pm": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/preferred-pm/-/preferred-pm-4.0.0.tgz", + "integrity": "sha512-gYBeFTZLu055D8Vv3cSPox/0iTPtkzxpLroSYYA7WXgRi31WCJ51Uyl8ZiPeUUjyvs2MBzK+S8v9JVUgHU/Sqw==", + "dependencies": { + "find-up-simple": "^1.0.0", + "find-yarn-workspace-root2": "1.2.16", + "which-pm": "^3.0.0" + }, + "engines": { + "node": ">=18.12" } }, "node_modules/prettier": { - "version": "2.8.8", - "resolved": "https://registry.npmjs.org/prettier/-/prettier-2.8.8.tgz", - "integrity": "sha512-tdN8qQGvNjw4CHbY+XXk0JgCXn9QiF21a55rBe5LJAU+kDyC4WQn4+awm2Xfk2lQMk5fKup9XgzTZtGkjBdP9Q==", + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/prettier/-/prettier-3.1.1.tgz", + "integrity": "sha512-22UbSzg8luF4UuZtzgiUOfcGM8s4tjBv6dJRT7j275NXsy2jb4aJa4NNveul5x4eqlF1wuhuR2RElK71RvmVaw==", + "devOptional": true, "bin": { - "prettier": "bin-prettier.js" + "prettier": "bin/prettier.cjs" }, "engines": { - "node": ">=10.13.0" + "node": ">=14" }, "funding": { "url": "https://github.com/prettier/prettier?sponsor=1" } }, "node_modules/prettier-plugin-astro": { - "version": "0.9.1", - "resolved": "https://registry.npmjs.org/prettier-plugin-astro/-/prettier-plugin-astro-0.9.1.tgz", - "integrity": "sha512-pYZXSbdq0eElvzoIMArzv1SBn1NUXzopjlcnt6Ql8VW32PjC12NovwBjXJ6rh8qQLi7vF8jNqAbraKW03UPfag==", + "version": "0.12.3", + "resolved": "https://registry.npmjs.org/prettier-plugin-astro/-/prettier-plugin-astro-0.12.3.tgz", + "integrity": "sha512-GthUSu3zCvmtVyqlArosez0xE08vSJ0R1sWurxIWpABaCkNGYFANoUdFkqmIo54EV2uPLGcVJzOucWvCjPBWvg==", + "devOptional": true, "dependencies": { - "@astrojs/compiler": "^1.0.1", - "prettier": "^2.8.3", - "sass-formatter": "^0.7.5", - "synckit": "^0.8.4" + "@astrojs/compiler": "^1.5.5", + "prettier": "^3.0.0", + "sass-formatter": "^0.7.6" }, "engines": { - "node": "^14.15.0 || >=16.0.0", - "pnpm": ">=7.14.0" + "node": "^14.15.0 || >=16.0.0" } }, + "node_modules/prettier-plugin-astro/node_modules/@astrojs/compiler": { + "version": "1.8.2", + "resolved": "https://registry.npmjs.org/@astrojs/compiler/-/compiler-1.8.2.tgz", + "integrity": "sha512-o/ObKgtMzl8SlpIdzaxFnt7SATKPxu4oIP/1NL+HDJRzxfJcAkOTAb/ZKMRyULbz4q+1t2/DAebs2Z1QairkZw==", + "devOptional": true + }, "node_modules/prismjs": { "version": "1.29.0", "resolved": "https://registry.npmjs.org/prismjs/-/prismjs-1.29.0.tgz", @@ -3942,9 +6641,9 @@ } }, "node_modules/property-information": { - "version": "6.2.0", - "resolved": "https://registry.npmjs.org/property-information/-/property-information-6.2.0.tgz", - "integrity": "sha512-kma4U7AFCTwpqq5twzC1YVIDXSqg6qQK6JN0smOw8fgRy1OkMi0CYSzFmsy6dnqSenamAtj0CyXMUJ1Mf6oROg==", + "version": "6.4.0", + "resolved": "https://registry.npmjs.org/property-information/-/property-information-6.4.0.tgz", + "integrity": "sha512-9t5qARVofg2xQqKtytzt+lZ4d1Qvj8t5B8fEwXK6qOfgRLgH/b13QlgEyDh033NOS31nXeFbYv7CLUDG1CeifQ==", "funding": { "type": "github", "url": "https://github.com/sponsors/wooorm" @@ -3969,19 +6668,6 @@ } ] }, - "node_modules/readable-stream": { - "version": "3.6.2", - "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-3.6.2.tgz", - "integrity": "sha512-9u/sniCrY3D5WdsERHzHE4G2YCXqoG5FTHUiCC4SIbr6XcLZBY05ya9EKjYek9O5xOAwjGq+1JdGBAS7Q9ScoA==", - "dependencies": { - "inherits": "^2.0.3", - "string_decoder": "^1.1.1", - "util-deprecate": "^1.0.1" - }, - "engines": { - "node": ">= 6" - } - }, "node_modules/readdirp": { "version": "3.6.0", "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz", @@ -3994,14 +6680,14 @@ } }, "node_modules/rehype": { - "version": "12.0.1", - "resolved": "https://registry.npmjs.org/rehype/-/rehype-12.0.1.tgz", - "integrity": "sha512-ey6kAqwLM3X6QnMDILJthGvG1m1ULROS9NT4uG9IDCuv08SFyLlreSuvOa//DgEvbXx62DS6elGVqusWhRUbgw==", + "version": "13.0.1", + "resolved": "https://registry.npmjs.org/rehype/-/rehype-13.0.1.tgz", + "integrity": "sha512-AcSLS2mItY+0fYu9xKxOu1LhUZeBZZBx8//5HKzF+0XP+eP8+6a5MXn2+DW2kfXR6Dtp1FEXMVrjyKAcvcU8vg==", "dependencies": { - "@types/hast": "^2.0.0", - "rehype-parse": "^8.0.0", - "rehype-stringify": "^9.0.0", - "unified": "^10.0.0" + "@types/hast": "^3.0.0", + "rehype-parse": "^9.0.0", + "rehype-stringify": "^10.0.0", + "unified": "^11.0.0" }, "funding": { "type": "opencollective", @@ -4009,14 +6695,13 @@ } }, "node_modules/rehype-parse": { - "version": "8.0.4", - "resolved": "https://registry.npmjs.org/rehype-parse/-/rehype-parse-8.0.4.tgz", - "integrity": "sha512-MJJKONunHjoTh4kc3dsM1v3C9kGrrxvA3U8PxZlP2SjH8RNUSrb+lF7Y0KVaUDnGH2QZ5vAn7ulkiajM9ifuqg==", + "version": "9.0.0", + "resolved": "https://registry.npmjs.org/rehype-parse/-/rehype-parse-9.0.0.tgz", + "integrity": "sha512-WG7nfvmWWkCR++KEkZevZb/uw41E8TsH4DsY9UxsTbIXCVGbAs4S+r8FrQ+OtH5EEQAs+5UxKC42VinkmpA1Yw==", "dependencies": { - "@types/hast": "^2.0.0", - "hast-util-from-parse5": "^7.0.0", - "parse5": "^6.0.0", - "unified": "^10.0.0" + "@types/hast": "^3.0.0", + "hast-util-from-html": "^2.0.0", + "unified": "^11.0.0" }, "funding": { "type": "opencollective", @@ -4024,13 +6709,13 @@ } }, "node_modules/rehype-raw": { - "version": "6.1.1", - "resolved": "https://registry.npmjs.org/rehype-raw/-/rehype-raw-6.1.1.tgz", - "integrity": "sha512-d6AKtisSRtDRX4aSPsJGTfnzrX2ZkHQLE5kiUuGOeEoLpbEulFF4hj0mLPbsa+7vmguDKOVVEQdHKDSwoaIDsQ==", + "version": "7.0.0", + "resolved": "https://registry.npmjs.org/rehype-raw/-/rehype-raw-7.0.0.tgz", + "integrity": "sha512-/aE8hCfKlQeA8LmyeyQvQF3eBiLRGNlfBJEvWH7ivp9sBqs7TNqBL5X3v157rM4IFETqDnIOO+z5M/biZbo9Ww==", "dependencies": { - "@types/hast": "^2.0.0", - "hast-util-raw": "^7.2.0", - "unified": "^10.0.0" + "@types/hast": "^3.0.0", + "hast-util-raw": "^9.0.0", + "vfile": "^6.0.0" }, "funding": { "type": "opencollective", @@ -4038,13 +6723,13 @@ } }, "node_modules/rehype-stringify": { - "version": "9.0.3", - "resolved": "https://registry.npmjs.org/rehype-stringify/-/rehype-stringify-9.0.3.tgz", - "integrity": "sha512-kWiZ1bgyWlgOxpqD5HnxShKAdXtb2IUljn3hQAhySeak6IOQPPt6DeGnsIh4ixm7yKJWzm8TXFuC/lPfcWHJqw==", + "version": "10.0.0", + "resolved": "https://registry.npmjs.org/rehype-stringify/-/rehype-stringify-10.0.0.tgz", + "integrity": "sha512-1TX1i048LooI9QoecrXy7nGFFbFSufxVRAfc6Y9YMRAi56l+oB0zP51mLSV312uRuvVLPV1opSlJmslozR1XHQ==", "dependencies": { - "@types/hast": "^2.0.0", - "hast-util-to-html": "^8.0.0", - "unified": "^10.0.0" + "@types/hast": "^3.0.0", + "hast-util-to-html": "^9.0.0", + "unified": "^11.0.0" }, "funding": { "type": "opencollective", @@ -4052,14 +6737,16 @@ } }, "node_modules/remark-gfm": { - "version": "3.0.1", - "resolved": "https://registry.npmjs.org/remark-gfm/-/remark-gfm-3.0.1.tgz", - "integrity": "sha512-lEFDoi2PICJyNrACFOfDD3JlLkuSbOa5Wd8EPt06HUdptv8Gn0bxYTdbU/XXQ3swAPkEaGxxPN9cbnMHvVu1Ig==", + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/remark-gfm/-/remark-gfm-4.0.0.tgz", + "integrity": "sha512-U92vJgBPkbw4Zfu/IiW2oTZLSL3Zpv+uI7My2eq8JxKgqraFdU8YUGicEJCEgSbeaG+QDFqIcwwfMTOEelPxuA==", "dependencies": { - "@types/mdast": "^3.0.0", - "mdast-util-gfm": "^2.0.0", - "micromark-extension-gfm": "^2.0.0", - "unified": "^10.0.0" + "@types/mdast": "^4.0.0", + "mdast-util-gfm": "^3.0.0", + "micromark-extension-gfm": "^3.0.0", + "remark-parse": "^11.0.0", + "remark-stringify": "^11.0.0", + "unified": "^11.0.0" }, "funding": { "type": "opencollective", @@ -4067,13 +6754,14 @@ } }, "node_modules/remark-parse": { - "version": "10.0.2", - "resolved": "https://registry.npmjs.org/remark-parse/-/remark-parse-10.0.2.tgz", - "integrity": "sha512-3ydxgHa/ZQzG8LvC7jTXccARYDcRld3VfcgIIFs7bI6vbRSxJJmzgLEIIoYKyrfhaY+ujuWaf/PJiMZXoiCXgw==", + "version": "11.0.0", + "resolved": "https://registry.npmjs.org/remark-parse/-/remark-parse-11.0.0.tgz", + "integrity": "sha512-FCxlKLNGknS5ba/1lmpYijMUzX2esxW5xQqjWxw2eHFfS2MSdaHVINFmhjo+qN1WhZhNimq0dZATN9pH0IDrpA==", "dependencies": { - "@types/mdast": "^3.0.0", - "mdast-util-from-markdown": "^1.0.0", - "unified": "^10.0.0" + "@types/mdast": "^4.0.0", + "mdast-util-from-markdown": "^2.0.0", + "micromark-util-types": "^2.0.0", + "unified": "^11.0.0" }, "funding": { "type": "opencollective", @@ -4081,14 +6769,15 @@ } }, "node_modules/remark-rehype": { - "version": "10.1.0", - "resolved": "https://registry.npmjs.org/remark-rehype/-/remark-rehype-10.1.0.tgz", - "integrity": "sha512-EFmR5zppdBp0WQeDVZ/b66CWJipB2q2VLNFMabzDSGR66Z2fQii83G5gTBbgGEnEEA0QRussvrFHxk1HWGJskw==", + "version": "11.1.0", + "resolved": "https://registry.npmjs.org/remark-rehype/-/remark-rehype-11.1.0.tgz", + "integrity": "sha512-z3tJrAs2kIs1AqIIy6pzHmAHlF1hWQ+OdY4/hv+Wxe35EhyLKcajL33iUEn3ScxtFox9nUvRufR/Zre8Q08H/g==", "dependencies": { - "@types/hast": "^2.0.0", - "@types/mdast": "^3.0.0", - "mdast-util-to-hast": "^12.1.0", - "unified": "^10.0.0" + "@types/hast": "^3.0.0", + "@types/mdast": "^4.0.0", + "mdast-util-to-hast": "^13.0.0", + "unified": "^11.0.0", + "vfile": "^6.0.0" }, "funding": { "type": "opencollective", @@ -4096,32 +6785,54 @@ } }, "node_modules/remark-smartypants": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/remark-smartypants/-/remark-smartypants-2.0.0.tgz", - "integrity": "sha512-Rc0VDmr/yhnMQIz8n2ACYXlfw/P/XZev884QU1I5u+5DgJls32o97Vc1RbK3pfumLsJomS2yy8eT4Fxj/2MDVA==", + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/remark-smartypants/-/remark-smartypants-3.0.2.tgz", + "integrity": "sha512-ILTWeOriIluwEvPjv67v7Blgrcx+LZOkAUVtKI3putuhlZm84FnqDORNXPPm+HY3NdZOMhyDwZ1E+eZB/Df5dA==", "dependencies": { - "retext": "^8.1.0", - "retext-smartypants": "^5.1.0", - "unist-util-visit": "^4.1.0" + "retext": "^9.0.0", + "retext-smartypants": "^6.0.0", + "unified": "^11.0.4", + "unist-util-visit": "^5.0.0" }, "engines": { - "node": "^12.20.0 || ^14.13.1 || >=16.0.0" + "node": ">=16.0.0" } }, - "node_modules/resolve": { - "version": "1.22.2", - "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.22.2.tgz", - "integrity": "sha512-Sb+mjNHOULsBv818T40qSPeRiuWLyaGMa5ewydRLFimneixmVy2zdivRl+AF6jaYPC8ERxGDmFSiqui6SfPd+g==", + "node_modules/remark-stringify": { + "version": "11.0.0", + "resolved": "https://registry.npmjs.org/remark-stringify/-/remark-stringify-11.0.0.tgz", + "integrity": "sha512-1OSmLd3awB/t8qdoEOMazZkNsfVTeY4fTsgzcQFdXNq8ToTN4ZGwrMnlda4K6smTFKD+GRV6O48i6Z4iKgPPpw==", "dependencies": { - "is-core-module": "^2.11.0", - "path-parse": "^1.0.7", - "supports-preserve-symlinks-flag": "^1.0.0" - }, - "bin": { - "resolve": "bin/resolve" + "@types/mdast": "^4.0.0", + "mdast-util-to-markdown": "^2.0.0", + "unified": "^11.0.0" }, "funding": { - "url": "https://github.com/sponsors/ljharb" + "type": "opencollective", + "url": "https://opencollective.com/unified" + } + }, + "node_modules/request-light": { + "version": "0.7.0", + "resolved": "https://registry.npmjs.org/request-light/-/request-light-0.7.0.tgz", + "integrity": "sha512-lMbBMrDoxgsyO+yB3sDcrDuX85yYt7sS8BfQd11jtbW/z5ZWgLZRcEGLsLoYw7I0WSUGQBs8CC8ScIxkTX1+6Q==", + "license": "MIT" + }, + "node_modules/require-directory": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz", + "integrity": "sha512-fGxEI7+wsG9xrvdjsrlmL22OMTTiHRwAMroiEeMgq8gzoLC/PQr7RsRDSTLUg/bZAZtF+TVIkHc6/4RIKrui+Q==", + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/require-from-string": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/require-from-string/-/require-from-string-2.0.2.tgz", + "integrity": "sha512-Xf0nWe6RseziFMu+Ap9biiUbmplq6S9/p+7w7YXP/JBHhrUDDUhwa+vANyubuqfZWTveU//DYVGsDG7RKL/vEw==", + "license": "MIT", + "engines": { + "node": ">=0.10.0" } }, "node_modules/restore-cursor": { @@ -4161,15 +6872,20 @@ "url": "https://github.com/sponsors/sindresorhus" } }, + "node_modules/restore-cursor/node_modules/signal-exit": { + "version": "3.0.7", + "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.7.tgz", + "integrity": "sha512-wnD2ZE+l+SPC/uoS0vXeE9L1+0wuaMqKlfz9AMUo38JsyLSBWSFcHR1Rri62LZc12vLr1gb3jl7iwQhgwpAbGQ==" + }, "node_modules/retext": { - "version": "8.1.0", - "resolved": "https://registry.npmjs.org/retext/-/retext-8.1.0.tgz", - "integrity": "sha512-N9/Kq7YTn6ZpzfiGW45WfEGJqFf1IM1q8OsRa1CGzIebCJBNCANDRmOrholiDRGKo/We7ofKR4SEvcGAWEMD3Q==", + "version": "9.0.0", + "resolved": "https://registry.npmjs.org/retext/-/retext-9.0.0.tgz", + "integrity": "sha512-sbMDcpHCNjvlheSgMfEcVrZko3cDzdbe1x/e7G66dFp0Ff7Mldvi2uv6JkJQzdRcvLYE8CA8Oe8siQx8ZOgTcA==", "dependencies": { - "@types/nlcst": "^1.0.0", - "retext-latin": "^3.0.0", - "retext-stringify": "^3.0.0", - "unified": "^10.0.0" + "@types/nlcst": "^2.0.0", + "retext-latin": "^4.0.0", + "retext-stringify": "^4.0.0", + "unified": "^11.0.0" }, "funding": { "type": "opencollective", @@ -4177,14 +6893,13 @@ } }, "node_modules/retext-latin": { - "version": "3.1.0", - "resolved": "https://registry.npmjs.org/retext-latin/-/retext-latin-3.1.0.tgz", - "integrity": "sha512-5MrD1tuebzO8ppsja5eEu+ZbBeUNCjoEarn70tkXOS7Bdsdf6tNahsv2bY0Z8VooFF6cw7/6S+d3yI/TMlMVVQ==", + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/retext-latin/-/retext-latin-4.0.0.tgz", + "integrity": "sha512-hv9woG7Fy0M9IlRQloq/N6atV82NxLGveq+3H2WOi79dtIYWN8OaxogDm77f8YnVXJL2VD3bbqowu5E3EMhBYA==", "dependencies": { - "@types/nlcst": "^1.0.0", - "parse-latin": "^5.0.0", - "unherit": "^3.0.0", - "unified": "^10.0.0" + "@types/nlcst": "^2.0.0", + "parse-latin": "^7.0.0", + "unified": "^11.0.0" }, "funding": { "type": "opencollective", @@ -4192,14 +6907,13 @@ } }, "node_modules/retext-smartypants": { - "version": "5.2.0", - "resolved": "https://registry.npmjs.org/retext-smartypants/-/retext-smartypants-5.2.0.tgz", - "integrity": "sha512-Do8oM+SsjrbzT2UNIKgheP0hgUQTDDQYyZaIY3kfq0pdFzoPk+ZClYJ+OERNXveog4xf1pZL4PfRxNoVL7a/jw==", + "version": "6.1.0", + "resolved": "https://registry.npmjs.org/retext-smartypants/-/retext-smartypants-6.1.0.tgz", + "integrity": "sha512-LDPXg95346bqFZnDMHo0S7Rq5p64+B+N8Vz733+wPMDtwb9rCOs9LIdIEhrUOU+TAywX9St+ocQWJt8wrzivcQ==", "dependencies": { - "@types/nlcst": "^1.0.0", - "nlcst-to-string": "^3.0.0", - "unified": "^10.0.0", - "unist-util-visit": "^4.0.0" + "@types/nlcst": "^2.0.0", + "nlcst-to-string": "^4.0.0", + "unist-util-visit": "^5.0.0" }, "funding": { "type": "opencollective", @@ -4207,13 +6921,13 @@ } }, "node_modules/retext-stringify": { - "version": "3.1.0", - "resolved": "https://registry.npmjs.org/retext-stringify/-/retext-stringify-3.1.0.tgz", - "integrity": "sha512-767TLOaoXFXyOnjx/EggXlb37ZD2u4P1n0GJqVdpipqACsQP+20W+BNpMYrlJkq7hxffnFk+jc6mAK9qrbuB8w==", + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/retext-stringify/-/retext-stringify-4.0.0.tgz", + "integrity": "sha512-rtfN/0o8kL1e+78+uxPTqu1Klt0yPzKuQ2BfWwwfgIUSayyzxpM1PJzkKt4V8803uB9qSy32MvI7Xep9khTpiA==", "dependencies": { - "@types/nlcst": "^1.0.0", - "nlcst-to-string": "^3.0.0", - "unified": "^10.0.0" + "@types/nlcst": "^2.0.0", + "nlcst-to-string": "^4.0.0", + "unified": "^11.0.0" }, "funding": { "type": "opencollective", @@ -4230,116 +6944,39 @@ } }, "node_modules/rollup": { - "version": "3.26.3", - "resolved": "https://registry.npmjs.org/rollup/-/rollup-3.26.3.tgz", - "integrity": "sha512-7Tin0C8l86TkpcMtXvQu6saWH93nhG3dGQ1/+l5V2TDMceTxO7kDiK6GzbfLWNNxqJXm591PcEZUozZm51ogwQ==", + "version": "4.17.2", + "resolved": "https://registry.npmjs.org/rollup/-/rollup-4.17.2.tgz", + "integrity": "sha512-/9ClTJPByC0U4zNLowV1tMBe8yMEAxewtR3cUNX5BoEpGH3dQEWpJLr6CLp0fPdYRF/fzVOgvDb1zXuakwF5kQ==", + "dependencies": { + "@types/estree": "1.0.5" + }, "bin": { "rollup": "dist/bin/rollup" }, "engines": { - "node": ">=14.18.0", + "node": ">=18.0.0", "npm": ">=8.0.0" }, "optionalDependencies": { + "@rollup/rollup-android-arm-eabi": "4.17.2", + "@rollup/rollup-android-arm64": "4.17.2", + "@rollup/rollup-darwin-arm64": "4.17.2", + "@rollup/rollup-darwin-x64": "4.17.2", + "@rollup/rollup-linux-arm-gnueabihf": "4.17.2", + "@rollup/rollup-linux-arm-musleabihf": "4.17.2", + "@rollup/rollup-linux-arm64-gnu": "4.17.2", + "@rollup/rollup-linux-arm64-musl": "4.17.2", + "@rollup/rollup-linux-powerpc64le-gnu": "4.17.2", + "@rollup/rollup-linux-riscv64-gnu": "4.17.2", + "@rollup/rollup-linux-s390x-gnu": "4.17.2", + "@rollup/rollup-linux-x64-gnu": "4.17.2", + "@rollup/rollup-linux-x64-musl": "4.17.2", + "@rollup/rollup-win32-arm64-msvc": "4.17.2", + "@rollup/rollup-win32-ia32-msvc": "4.17.2", + "@rollup/rollup-win32-x64-msvc": "4.17.2", "fsevents": "~2.3.2" } }, - "node_modules/run-applescript": { - "version": "5.0.0", - "resolved": "https://registry.npmjs.org/run-applescript/-/run-applescript-5.0.0.tgz", - "integrity": "sha512-XcT5rBksx1QdIhlFOCtgZkB99ZEouFZ1E2Kc2LHqNW13U3/74YGdkQRmThTwxy4QIyookibDKYZOPqX//6BlAg==", - "dependencies": { - "execa": "^5.0.0" - }, - "engines": { - "node": ">=12" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/run-applescript/node_modules/execa": { - "version": "5.1.1", - "resolved": "https://registry.npmjs.org/execa/-/execa-5.1.1.tgz", - "integrity": "sha512-8uSpZZocAZRBAPIEINJj3Lo9HyGitllczc27Eh5YYojjMFMn8yHMDMaUHE2Jqfq05D/wucwI4JGURyXt1vchyg==", - "dependencies": { - "cross-spawn": "^7.0.3", - "get-stream": "^6.0.0", - "human-signals": "^2.1.0", - "is-stream": "^2.0.0", - "merge-stream": "^2.0.0", - "npm-run-path": "^4.0.1", - "onetime": "^5.1.2", - "signal-exit": "^3.0.3", - "strip-final-newline": "^2.0.0" - }, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/sindresorhus/execa?sponsor=1" - } - }, - "node_modules/run-applescript/node_modules/human-signals": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/human-signals/-/human-signals-2.1.0.tgz", - "integrity": "sha512-B4FFZ6q/T2jhhksgkbEW3HBvWIfDW85snkQgawt07S7J5QXTk6BkNV+0yAeZrM5QpMAdYlocGoljn0sJ/WQkFw==", - "engines": { - "node": ">=10.17.0" - } - }, - "node_modules/run-applescript/node_modules/is-stream": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/is-stream/-/is-stream-2.0.1.tgz", - "integrity": "sha512-hFoiJiTl63nn+kstHGBtewWSKnQLpyb155KHheA1l39uvtO9nWIop1p3udqPcUd/xbF1VLMO4n7OI6p7RbngDg==", - "engines": { - "node": ">=8" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/run-applescript/node_modules/mimic-fn": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-2.1.0.tgz", - "integrity": "sha512-OqbOk5oEQeAZ8WXWydlu9HJjz9WVdEIvamMCcXmuqUYjTknH/sqsWvhQ3vgwKFRR1HpjvNBKQ37nbJgYzGqGcg==", - "engines": { - "node": ">=6" - } - }, - "node_modules/run-applescript/node_modules/npm-run-path": { - "version": "4.0.1", - "resolved": "https://registry.npmjs.org/npm-run-path/-/npm-run-path-4.0.1.tgz", - "integrity": "sha512-S48WzZW777zhNIrn7gxOlISNAqi9ZC/uQFnRdbeIHhZhCA6UqpkOT8T1G7BvfdgP4Er8gF4sUbaS0i7QvIfCWw==", - "dependencies": { - "path-key": "^3.0.0" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/run-applescript/node_modules/onetime": { - "version": "5.1.2", - "resolved": "https://registry.npmjs.org/onetime/-/onetime-5.1.2.tgz", - "integrity": "sha512-kbpaSSGJTWdAY5KPVeMOKXSrPtr8C8C7wodJbcsd51jRnmD+GZu8Y0VoU6Dm5Z4vWr0Ig/1NKuWRKf7j5aaYSg==", - "dependencies": { - "mimic-fn": "^2.1.0" - }, - "engines": { - "node": ">=6" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/run-applescript/node_modules/strip-final-newline": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/strip-final-newline/-/strip-final-newline-2.0.0.tgz", - "integrity": "sha512-BrpvfNAE3dcvq7ll3xVumzjKjZQ5tI1sEUIKr3Uoks0XUl45St3FlatVqef9prk4jRDzhW6WZg+3bk93y6pLjA==", - "engines": { - "node": ">=6" - } - }, "node_modules/run-parallel": { "version": "1.2.0", "resolved": "https://registry.npmjs.org/run-parallel/-/run-parallel-1.2.0.tgz", @@ -4365,50 +7002,22 @@ "node_modules/s.color": { "version": "0.0.15", "resolved": "https://registry.npmjs.org/s.color/-/s.color-0.0.15.tgz", - "integrity": "sha512-AUNrbEUHeKY8XsYr/DYpl+qk5+aM+DChopnWOPEzn8YKzOhv4l2zH6LzZms3tOZP3wwdOyc0RmTciyi46HLIuA==" - }, - "node_modules/sade": { - "version": "1.8.1", - "resolved": "https://registry.npmjs.org/sade/-/sade-1.8.1.tgz", - "integrity": "sha512-xal3CZX1Xlo/k4ApwCFrHVACi9fBqJ7V+mwhBsuf/1IOKbBy098Fex+Wa/5QMubw09pSZ/u8EY8PWgevJsXp1A==", - "dependencies": { - "mri": "^1.1.0" - }, - "engines": { - "node": ">=6" - } - }, - "node_modules/safe-buffer": { - "version": "5.2.1", - "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", - "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==", - "funding": [ - { - "type": "github", - "url": "https://github.com/sponsors/feross" - }, - { - "type": "patreon", - "url": "https://www.patreon.com/feross" - }, - { - "type": "consulting", - "url": "https://feross.org/support" - } - ] + "integrity": "sha512-AUNrbEUHeKY8XsYr/DYpl+qk5+aM+DChopnWOPEzn8YKzOhv4l2zH6LzZms3tOZP3wwdOyc0RmTciyi46HLIuA==", + "devOptional": true }, "node_modules/sass-formatter": { - "version": "0.7.6", - "resolved": "https://registry.npmjs.org/sass-formatter/-/sass-formatter-0.7.6.tgz", - "integrity": "sha512-hXdxU6PCkiV3XAiSnX+XLqz2ohHoEnVUlrd8LEVMAI80uB1+OTScIkH9n6qQwImZpTye1r1WG1rbGUteHNhoHg==", + "version": "0.7.8", + "resolved": "https://registry.npmjs.org/sass-formatter/-/sass-formatter-0.7.8.tgz", + "integrity": "sha512-7fI2a8THglflhhYis7k06eUf92VQuJoXzEs2KRP0r1bluFxKFvLx0Ns7c478oYGM0fPfrr846ZRWVi2MAgHt9Q==", + "devOptional": true, "dependencies": { "suf-log": "^2.5.3" } }, "node_modules/sax": { - "version": "1.2.4", - "resolved": "https://registry.npmjs.org/sax/-/sax-1.2.4.tgz", - "integrity": "sha512-NqVDv9TpANUjFm0N8uM5GxL36UgKi9/atZw+x7YFnQ8ckwFGKrl4xX4yWtrey3UJm5nP1kUbnYgLopqWNSRhWw==" + "version": "1.4.1", + "resolved": "https://registry.npmjs.org/sax/-/sax-1.4.1.tgz", + "integrity": "sha512-+aWOz7yVScEGoKNd4PA10LZ8sk0A/z5+nXQG5giUO5rprX9jgYsTdov9qCchZiPIZezbZH+jRut8nPodFAX4Jg==" }, "node_modules/section-matter": { "version": "1.0.0", @@ -4423,12 +7032,9 @@ } }, "node_modules/semver": { - "version": "7.5.4", - "resolved": "https://registry.npmjs.org/semver/-/semver-7.5.4.tgz", - "integrity": "sha512-1bCSESV6Pv+i21Hvpxp3Dx+pSD8lIPt8uVjRrxAUt/nbswYc+tK6Y2btiULjd4+fnq15PX+nqQDC7Oft7WkwcA==", - "dependencies": { - "lru-cache": "^6.0.0" - }, + "version": "7.6.2", + "resolved": "https://registry.npmjs.org/semver/-/semver-7.6.2.tgz", + "integrity": "sha512-FNAIBWCx9qcRhoHcgcJ0gvU7SN1lYU2ZXuSfl04bSC5OpvDHFyJCjdNHomPXxjQlCBU67YW64PzY7/VIEH7F2w==", "bin": { "semver": "bin/semver.js" }, @@ -4436,27 +7042,46 @@ "node": ">=10" } }, - "node_modules/semver/node_modules/lru-cache": { - "version": "6.0.0", - "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", - "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", + "node_modules/sharp": { + "version": "0.33.3", + "resolved": "https://registry.npmjs.org/sharp/-/sharp-0.33.3.tgz", + "integrity": "sha512-vHUeXJU1UvlO/BNwTpT0x/r53WkLUVxrmb5JTgW92fdFCFk0ispLMAeu/jPO2vjkXM1fYUi3K7/qcLF47pwM1A==", + "hasInstallScript": true, + "optional": true, "dependencies": { - "yallist": "^4.0.0" + "color": "^4.2.3", + "detect-libc": "^2.0.3", + "semver": "^7.6.0" }, "engines": { - "node": ">=10" + "libvips": ">=8.15.2", + "node": "^18.17.0 || ^20.3.0 || >=21.0.0" + }, + "funding": { + "url": "https://opencollective.com/libvips" + }, + "optionalDependencies": { + "@img/sharp-darwin-arm64": "0.33.3", + "@img/sharp-darwin-x64": "0.33.3", + "@img/sharp-libvips-darwin-arm64": "1.0.2", + "@img/sharp-libvips-darwin-x64": "1.0.2", + "@img/sharp-libvips-linux-arm": "1.0.2", + "@img/sharp-libvips-linux-arm64": "1.0.2", + "@img/sharp-libvips-linux-s390x": "1.0.2", + "@img/sharp-libvips-linux-x64": "1.0.2", + "@img/sharp-libvips-linuxmusl-arm64": "1.0.2", + "@img/sharp-libvips-linuxmusl-x64": "1.0.2", + "@img/sharp-linux-arm": "0.33.3", + "@img/sharp-linux-arm64": "0.33.3", + "@img/sharp-linux-s390x": "0.33.3", + "@img/sharp-linux-x64": "0.33.3", + "@img/sharp-linuxmusl-arm64": "0.33.3", + "@img/sharp-linuxmusl-x64": "0.33.3", + "@img/sharp-wasm32": "0.33.3", + "@img/sharp-win32-ia32": "0.33.3", + "@img/sharp-win32-x64": "0.33.3" } }, - "node_modules/semver/node_modules/yallist": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", - "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==" - }, - "node_modules/server-destroy": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/server-destroy/-/server-destroy-1.0.1.tgz", - "integrity": "sha512-rb+9B5YBIEzYcD6x2VKidaa+cqYBJQKnU4oe4E3ANwRRN56yk/ua1YCJT1n21NTS8w6CcOclAKNP3PhdCXKYtQ==" - }, "node_modules/shebang-command": { "version": "2.0.0", "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", @@ -4477,25 +7102,34 @@ } }, "node_modules/shiki": { - "version": "0.14.3", - "resolved": "https://registry.npmjs.org/shiki/-/shiki-0.14.3.tgz", - "integrity": "sha512-U3S/a+b0KS+UkTyMjoNojvTgrBHjgp7L6ovhFVZsXmBGnVdQ4K4U9oK0z63w538S91ATngv1vXigHCSWOwnr+g==", + "version": "1.14.1", + "resolved": "https://registry.npmjs.org/shiki/-/shiki-1.14.1.tgz", + "integrity": "sha512-FujAN40NEejeXdzPt+3sZ3F2dx1U24BY2XTY01+MG8mbxCiA2XukXdcbyMyLAHJ/1AUUnQd1tZlvIjefWWEJeA==", + "license": "MIT", "dependencies": { - "ansi-sequence-parser": "^1.1.0", - "jsonc-parser": "^3.2.0", - "vscode-oniguruma": "^1.7.0", - "vscode-textmate": "^8.0.0" + "@shikijs/core": "1.14.1", + "@types/hast": "^3.0.4" } }, - "node_modules/shiki/node_modules/jsonc-parser": { - "version": "3.2.0", - "resolved": "https://registry.npmjs.org/jsonc-parser/-/jsonc-parser-3.2.0.tgz", - "integrity": "sha512-gfFQZrcTc8CnKXp6Y4/CBT3fTc0OVuDofpre4aEeEpSBPV5X5v4+Vmx+8snU7RLPrNHPKSgLxGo9YuQzz20o+w==" - }, "node_modules/signal-exit": { - "version": "3.0.7", - "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.7.tgz", - "integrity": "sha512-wnD2ZE+l+SPC/uoS0vXeE9L1+0wuaMqKlfz9AMUo38JsyLSBWSFcHR1Rri62LZc12vLr1gb3jl7iwQhgwpAbGQ==" + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-4.1.0.tgz", + "integrity": "sha512-bzyZ1e88w9O1iNJbKnOlvYTrWPDl46O1bG0D3XInv+9tkPrxrN8jUUTiFlDkkmKWgn1M6CfIA13SuGqOa9Korw==", + "engines": { + "node": ">=14" + }, + "funding": { + "url": "https://github.com/sponsors/isaacs" + } + }, + "node_modules/simple-swizzle": { + "version": "0.2.2", + "resolved": "https://registry.npmjs.org/simple-swizzle/-/simple-swizzle-0.2.2.tgz", + "integrity": "sha512-JA//kQgZtbuY83m+xT+tXJkmJncGMTFT+C+g2h2R9uxkYIrE2yy9sgmcLhCnw57/WSD+Eh3J97FPEDFnbXnDUg==", + "optional": true, + "dependencies": { + "is-arrayish": "^0.3.1" + } }, "node_modules/sisteransi": { "version": "1.0.5", @@ -4503,9 +7137,9 @@ "integrity": "sha512-bLGGlR1QxBcynn2d5YmDX4MGjlZvy2MRBDRNHLJ8VI6l6+9FUiyTFNJ0IveOSP0bcXgVDPRcfGqA0pjaqUpfVg==" }, "node_modules/sitemap": { - "version": "7.1.1", - "resolved": "https://registry.npmjs.org/sitemap/-/sitemap-7.1.1.tgz", - "integrity": "sha512-mK3aFtjz4VdJN0igpIJrinf3EO8U8mxOPsTBzSsy06UtjZQJ3YY3o3Xa7zSc5nMqcMrRwlChHZ18Kxg0caiPBg==", + "version": "7.1.2", + "resolved": "https://registry.npmjs.org/sitemap/-/sitemap-7.1.2.tgz", + "integrity": "sha512-ARCqzHJ0p4gWt+j7NlU5eDlIO9+Rkr/JhPFZKKQ1l5GCus7rJH4UdrlVAh0xC/gDS/Qir2UMxqYNHtsKr2rpCw==", "dependencies": { "@types/node": "^17.0.5", "@types/sax": "^1.2.1", @@ -4521,9 +7155,9 @@ } }, "node_modules/source-map-js": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/source-map-js/-/source-map-js-1.0.2.tgz", - "integrity": "sha512-R0XvVJ9WusLiqTCEiGCmICCMplcCkIwwR11mOSD9CR5u+IXYdiseeEuXCVAjS54zqwkLcPNnmU4OeJ6tUrWhDw==", + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/source-map-js/-/source-map-js-1.2.0.tgz", + "integrity": "sha512-itJW8lvSA0TXEphiRoawsCksnlf8SyvmFzIhltqAHluXd88pkCd+cXJVHTDwdCr0IzwptSm035IHQktUu1QUMg==", "engines": { "node": ">=0.10.0" } @@ -4543,46 +7177,32 @@ "integrity": "sha512-D9cPgkvLlV3t3IzL0D0YLvGA9Ahk4PcvVwUbN0dSGr1aP0Nrt4AEnTUbuGvquEC0mA64Gqt1fzirlRs5ibXx8g==" }, "node_modules/stdin-discarder": { - "version": "0.1.0", - "resolved": "https://registry.npmjs.org/stdin-discarder/-/stdin-discarder-0.1.0.tgz", - "integrity": "sha512-xhV7w8S+bUwlPTb4bAOUQhv8/cSS5offJuX8GQGq32ONF0ZtDWKfkdomM3HMRA+LhX6um/FZ0COqlwsjD53LeQ==", - "dependencies": { - "bl": "^5.0.0" - }, + "version": "0.2.2", + "resolved": "https://registry.npmjs.org/stdin-discarder/-/stdin-discarder-0.2.2.tgz", + "integrity": "sha512-UhDfHmA92YAlNnCfhmq0VeNL5bDbiZGg7sZ2IvPsXubGkiNa9EC+tUTsjBRsYUAz87btI6/1wf4XoVvQ3uRnmQ==", "engines": { - "node": "^12.20.0 || ^14.13.1 || >=16.0.0" + "node": ">=18" }, "funding": { "url": "https://github.com/sponsors/sindresorhus" } }, - "node_modules/streamsearch": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/streamsearch/-/streamsearch-1.1.0.tgz", - "integrity": "sha512-Mcc5wHehp9aXz1ax6bZUyY5afg9u2rv5cqQI3mRrYkGC8rW2hM02jWuwjtL++LS5qinSyhj2QfLyNsuc+VsExg==", - "engines": { - "node": ">=10.0.0" - } - }, - "node_modules/string_decoder": { - "version": "1.3.0", - "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.3.0.tgz", - "integrity": "sha512-hkRX8U1WjJFd8LsDJ2yQ/wWWxaopEsABU1XfkM8A+j0+85JAGppt16cr1Whg6KIbb4okU6Mql6BOj+uup/wKeA==", - "dependencies": { - "safe-buffer": "~5.2.0" - } + "node_modules/stream-replace-string": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/stream-replace-string/-/stream-replace-string-2.0.0.tgz", + "integrity": "sha512-TlnjJ1C0QrmxRNrON00JvaFFlNh5TTG00APw23j74ET7gkQpTASi6/L2fuiav8pzK715HXtUeClpBTw2NPSn6w==" }, "node_modules/string-width": { - "version": "5.1.2", - "resolved": "https://registry.npmjs.org/string-width/-/string-width-5.1.2.tgz", - "integrity": "sha512-HnLOCR3vjcY8beoNLtcjZ5/nxn2afmME6lhrDrebokqMap+XbeW8n9TXpPDOqdGK5qcI3oT0GKTW6wC7EMiVqA==", + "version": "7.2.0", + "resolved": "https://registry.npmjs.org/string-width/-/string-width-7.2.0.tgz", + "integrity": "sha512-tsaTIkKW9b4N+AEj+SVA+WhJzV7/zMhcSu78mLKWSk7cXMOSHsBKFWUs0fWwq8QyK3MgJBQRX6Gbi4kYbdvGkQ==", "dependencies": { - "eastasianwidth": "^0.2.0", - "emoji-regex": "^9.2.2", - "strip-ansi": "^7.0.1" + "emoji-regex": "^10.3.0", + "get-east-asian-width": "^1.0.0", + "strip-ansi": "^7.1.0" }, "engines": { - "node": ">=12" + "node": ">=18" }, "funding": { "url": "https://github.com/sponsors/sindresorhus" @@ -4616,11 +7236,11 @@ } }, "node_modules/strip-bom": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-4.0.0.tgz", - "integrity": "sha512-3xurFv5tEgii33Zi8Jtp55wEIILR9eh34FAW00PZf+JnSsTmV/ioewSgQl97JHvgjoRGwPShsWm+IdrxB35d0w==", + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-3.0.0.tgz", + "integrity": "sha512-vavAMRXOgBVNF6nyEEmL3DBK19iRpDcoIwW+swQ+CbGiu7lju6t+JklA1MHweoWtadgt4ISVUsXLyDq34ddcwA==", "engines": { - "node": ">=8" + "node": ">=4" } }, "node_modules/strip-bom-string": { @@ -4646,6 +7266,7 @@ "version": "2.5.3", "resolved": "https://registry.npmjs.org/suf-log/-/suf-log-2.5.3.tgz", "integrity": "sha512-KvC8OPjzdNOe+xQ4XWJV2whQA0aM1kGVczMQ8+dStAO6KfEB140JEVQ9dE76ONZ0/Ylf67ni4tILPJB41U0eow==", + "devOptional": true, "dependencies": { "s.color": "0.0.15" } @@ -4661,43 +7282,6 @@ "node": ">=4" } }, - "node_modules/supports-preserve-symlinks-flag": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz", - "integrity": "sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w==", - "engines": { - "node": ">= 0.4" - }, - "funding": { - "url": "https://github.com/sponsors/ljharb" - } - }, - "node_modules/synckit": { - "version": "0.8.5", - "resolved": "https://registry.npmjs.org/synckit/-/synckit-0.8.5.tgz", - "integrity": "sha512-L1dapNV6vu2s/4Sputv8xGsCdAVlb5nRDMFU/E27D44l5U6cw1g0dGd45uLc+OXjNMmF4ntiMdCimzcjFKQI8Q==", - "dependencies": { - "@pkgr/utils": "^2.3.1", - "tslib": "^2.5.0" - }, - "engines": { - "node": "^14.18.0 || >=16.0.0" - }, - "funding": { - "url": "https://opencollective.com/unts" - } - }, - "node_modules/titleize": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/titleize/-/titleize-3.0.0.tgz", - "integrity": "sha512-KxVu8EYHDPBdUYdKZdKtU2aj2XfEx9AfjXxE/Aj0vT06w2icA09Vus1rh6eSu1y01akYg6BjIK/hxyLJINoMLQ==", - "engines": { - "node": ">=12" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, "node_modules/to-fast-properties": { "version": "2.0.0", "resolved": "https://registry.npmjs.org/to-fast-properties/-/to-fast-properties-2.0.0.tgz", @@ -4735,37 +7319,30 @@ "url": "https://github.com/sponsors/wooorm" } }, - "node_modules/tsconfig-resolver": { - "version": "3.0.1", - "resolved": "https://registry.npmjs.org/tsconfig-resolver/-/tsconfig-resolver-3.0.1.tgz", - "integrity": "sha512-ZHqlstlQF449v8glscGRXzL6l2dZvASPCdXJRWG4gHEZlUVx2Jtmr+a2zeVG4LCsKhDXKRj5R3h0C/98UcVAQg==", - "dependencies": { - "@types/json5": "^0.0.30", - "@types/resolve": "^1.17.0", - "json5": "^2.1.3", - "resolve": "^1.17.0", - "strip-bom": "^4.0.0", - "type-fest": "^0.13.1" + "node_modules/tsconfck": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/tsconfck/-/tsconfck-3.1.1.tgz", + "integrity": "sha512-00eoI6WY57SvZEVjm13stEVE90VkEdJAFGgpFLTsZbJyW/LwFQ7uQxJHWpZ2hzSWgCPKc9AnBnNP+0X7o3hAmQ==", + "bin": { + "tsconfck": "bin/tsconfck.js" }, - "funding": { - "url": "https://github.com/sponsors/ifiokjr" - } - }, - "node_modules/tsconfig-resolver/node_modules/type-fest": { - "version": "0.13.1", - "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.13.1.tgz", - "integrity": "sha512-34R7HTnG0XIJcBSn5XhDd7nNFPRcXYRZrBB2O2jdKqYODldSzBAqzsWoZYYvduky73toYS/ESqxPvkDf/F0XMg==", "engines": { - "node": ">=10" + "node": "^18 || >=20" }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" + "peerDependencies": { + "typescript": "^5.0.0" + }, + "peerDependenciesMeta": { + "typescript": { + "optional": true + } } }, "node_modules/tslib": { - "version": "2.6.0", - "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.6.0.tgz", - "integrity": "sha512-7At1WUettjcSRHXCyYtTselblcHl9PJFFVKiCAy/bY97+BPZXSQ2wbq0P9s8tK2G7dFQfNnlJnPAiArVBVBsfA==" + "version": "2.6.2", + "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.6.2.tgz", + "integrity": "sha512-AEYxH93jGFPn/a2iVAwW87VuUIkR1FVUKB77NwMF7nBTDkDrrT/Hpt/IrCJ0QXhW27jTBDcf5ZY7w6RiqTMw2Q==", + "optional": true }, "node_modules/type-fest": { "version": "2.19.0", @@ -4778,10 +7355,16 @@ "url": "https://github.com/sponsors/sindresorhus" } }, + "node_modules/typesafe-path": { + "version": "0.2.2", + "resolved": "https://registry.npmjs.org/typesafe-path/-/typesafe-path-0.2.2.tgz", + "integrity": "sha512-OJabfkAg1WLZSqJAJ0Z6Sdt3utnbzr/jh+NAHoyWHJe8CMSy79Gm085094M9nvTPy22KzTVn5Zq5mbapCI/hPA==", + "license": "MIT" + }, "node_modules/typescript": { - "version": "5.1.6", - "resolved": "https://registry.npmjs.org/typescript/-/typescript-5.1.6.tgz", - "integrity": "sha512-zaWCozRZ6DLEWAWFrVDz1H6FVXzUSfTy5FUMWsQlU8Ym5JP9eO4xkTIROFCQvhQf61z6O/G6ugw3SgAnvvm+HA==", + "version": "5.5.3", + "resolved": "https://registry.npmjs.org/typescript/-/typescript-5.5.3.tgz", + "integrity": "sha512-/hreyEujaB0w76zKo6717l3L0o/qEUtRgdvUBvlkhoWeOVMjMuHNHk0BRBzikzuGDqNmPQbg5ifMEqsHLiIUcQ==", "bin": { "tsc": "bin/tsc", "tsserver": "bin/tsserver" @@ -4790,59 +7373,59 @@ "node": ">=14.17" } }, - "node_modules/undici": { - "version": "5.22.1", - "resolved": "https://registry.npmjs.org/undici/-/undici-5.22.1.tgz", - "integrity": "sha512-Ji2IJhFXZY0x/0tVBXeQwgPlLWw13GVzpsWPQ3rV50IFMMof2I55PZZxtm4P6iNq+L5znYN9nSTAq0ZyE6lSJw==", + "node_modules/typescript-auto-import-cache": { + "version": "0.3.3", + "resolved": "https://registry.npmjs.org/typescript-auto-import-cache/-/typescript-auto-import-cache-0.3.3.tgz", + "integrity": "sha512-ojEC7+Ci1ij9eE6hp8Jl9VUNnsEKzztktP5gtYNRMrTmfXVwA1PITYYAkpxCvvupdSYa/Re51B6KMcv1CTZEUA==", + "license": "MIT", "dependencies": { - "busboy": "^1.6.0" - }, - "engines": { - "node": ">=14.0" + "semver": "^7.3.8" } }, - "node_modules/unherit": { - "version": "3.0.1", - "resolved": "https://registry.npmjs.org/unherit/-/unherit-3.0.1.tgz", - "integrity": "sha512-akOOQ/Yln8a2sgcLj4U0Jmx0R5jpIg2IUyRrWOzmEbjBtGzBdHtSeFKgoEcoH4KYIG/Pb8GQ/BwtYm0GCq1Sqg==", - "funding": { - "type": "github", - "url": "https://github.com/sponsors/wooorm" - } + "node_modules/undici-types": { + "version": "5.26.5", + "resolved": "https://registry.npmjs.org/undici-types/-/undici-types-5.26.5.tgz", + "integrity": "sha512-JlCMO+ehdEIKqlFxk6IfVoAUVmgz7cU7zD/h9XZ0qzeosSHmUJVOzSQvvYSYWXkFXC+IfLKSIffhv0sVZup6pA==", + "optional": true, + "peer": true }, "node_modules/unified": { - "version": "10.1.2", - "resolved": "https://registry.npmjs.org/unified/-/unified-10.1.2.tgz", - "integrity": "sha512-pUSWAi/RAnVy1Pif2kAoeWNBa3JVrx0MId2LASj8G+7AiHWoKZNTomq6LG326T68U7/e263X6fTdcXIy7XnF7Q==", + "version": "11.0.5", + "resolved": "https://registry.npmjs.org/unified/-/unified-11.0.5.tgz", + "integrity": "sha512-xKvGhPWw3k84Qjh8bI3ZeJjqnyadK+GEFtazSfZv/rKeTkTjOJho6mFqh2SM96iIcZokxiOpg78GazTSg8+KHA==", "dependencies": { - "@types/unist": "^2.0.0", + "@types/unist": "^3.0.0", "bail": "^2.0.0", + "devlop": "^1.0.0", "extend": "^3.0.0", - "is-buffer": "^2.0.0", "is-plain-obj": "^4.0.0", "trough": "^2.0.0", - "vfile": "^5.0.0" + "vfile": "^6.0.0" }, "funding": { "type": "opencollective", "url": "https://opencollective.com/unified" } }, - "node_modules/unist-util-generated": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/unist-util-generated/-/unist-util-generated-2.0.1.tgz", - "integrity": "sha512-qF72kLmPxAw0oN2fwpWIqbXAVyEqUzDHMsbtPvOudIlUzXYFIeQIuxXQCRCFh22B7cixvU0MG7m3MW8FTq/S+A==", + "node_modules/unist-util-find-after": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/unist-util-find-after/-/unist-util-find-after-5.0.0.tgz", + "integrity": "sha512-amQa0Ep2m6hE2g72AugUItjbuM8X8cGQnFoHk0pGfrFeT9GZhzN5SW8nRsiGKK7Aif4CrACPENkA6P/Lw6fHGQ==", + "dependencies": { + "@types/unist": "^3.0.0", + "unist-util-is": "^6.0.0" + }, "funding": { "type": "opencollective", "url": "https://opencollective.com/unified" } }, "node_modules/unist-util-is": { - "version": "5.2.1", - "resolved": "https://registry.npmjs.org/unist-util-is/-/unist-util-is-5.2.1.tgz", - "integrity": "sha512-u9njyyfEh43npf1M+yGKDGVPbY/JWEemg5nH05ncKPfi+kBbKBJoTdsogMu33uhytuLlv9y0O7GH7fEdwLdLQw==", + "version": "6.0.0", + "resolved": "https://registry.npmjs.org/unist-util-is/-/unist-util-is-6.0.0.tgz", + "integrity": "sha512-2qCTHimwdxLfz+YzdGfkqNlH0tLi9xjTnHddPmJwtIG9MGsdbutfTc4P+haPD7l7Cjxf/WZj+we5qfVPvvxfYw==", "dependencies": { - "@types/unist": "^2.0.0" + "@types/unist": "^3.0.0" }, "funding": { "type": "opencollective", @@ -4850,11 +7433,11 @@ } }, "node_modules/unist-util-modify-children": { - "version": "3.1.1", - "resolved": "https://registry.npmjs.org/unist-util-modify-children/-/unist-util-modify-children-3.1.1.tgz", - "integrity": "sha512-yXi4Lm+TG5VG+qvokP6tpnk+r1EPwyYL04JWDxLvgvPV40jANh7nm3udk65OOWquvbMDe+PL9+LmkxDpTv/7BA==", + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/unist-util-modify-children/-/unist-util-modify-children-4.0.0.tgz", + "integrity": "sha512-+tdN5fGNddvsQdIzUF3Xx82CU9sMM+fA0dLgR9vOmT0oPT2jH+P1nd5lSqfCfXAw+93NhcXNY2qqvTUtE4cQkw==", "dependencies": { - "@types/unist": "^2.0.0", + "@types/unist": "^3.0.0", "array-iterate": "^2.0.0" }, "funding": { @@ -4863,11 +7446,24 @@ } }, "node_modules/unist-util-position": { - "version": "4.0.4", - "resolved": "https://registry.npmjs.org/unist-util-position/-/unist-util-position-4.0.4.tgz", - "integrity": "sha512-kUBE91efOWfIVBo8xzh/uZQ7p9ffYRtUbMRZBNFYwf0RK8koUMx6dGUfwylLOKmaT2cs4wSW96QoYUSXAyEtpg==", + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/unist-util-position/-/unist-util-position-5.0.0.tgz", + "integrity": "sha512-fucsC7HjXvkB5R3kTCO7kUjRdrS0BJt3M/FPxmHMBOm8JQi2BsHAHFsy27E0EolP8rp0NzXsJ+jNPyDWvOJZPA==", "dependencies": { - "@types/unist": "^2.0.0" + "@types/unist": "^3.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/unified" + } + }, + "node_modules/unist-util-remove-position": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/unist-util-remove-position/-/unist-util-remove-position-5.0.0.tgz", + "integrity": "sha512-Hp5Kh3wLxv0PHj9m2yZhhLt58KzPtEYKQQ4yxfYFEO7EvHwzyDYnduhHnY1mDxoqr7VUwVuHXk9RXKIiYS1N8Q==", + "dependencies": { + "@types/unist": "^3.0.0", + "unist-util-visit": "^5.0.0" }, "funding": { "type": "opencollective", @@ -4875,11 +7471,11 @@ } }, "node_modules/unist-util-stringify-position": { - "version": "3.0.3", - "resolved": "https://registry.npmjs.org/unist-util-stringify-position/-/unist-util-stringify-position-3.0.3.tgz", - "integrity": "sha512-k5GzIBZ/QatR8N5X2y+drfpWG8IDBzdnVj6OInRNWm1oXrzydiaAT2OQiA8DPRRZyAKb9b6I2a6PxYklZD0gKg==", + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/unist-util-stringify-position/-/unist-util-stringify-position-4.0.0.tgz", + "integrity": "sha512-0ASV06AAoKCDkS2+xw5RXJywruurpbC4JZSm7nr7MOt1ojAzvyyaO+UxZf18j8FCF6kmzCZKcAgN/yu2gm2XgQ==", "dependencies": { - "@types/unist": "^2.0.0" + "@types/unist": "^3.0.0" }, "funding": { "type": "opencollective", @@ -4887,13 +7483,13 @@ } }, "node_modules/unist-util-visit": { - "version": "4.1.2", - "resolved": "https://registry.npmjs.org/unist-util-visit/-/unist-util-visit-4.1.2.tgz", - "integrity": "sha512-MSd8OUGISqHdVvfY9TPhyK2VdUrPgxkUtWSuMHF6XAAFuL4LokseigBnZtPnJMu+FbynTkFNnFlyjxpVKujMRg==", + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/unist-util-visit/-/unist-util-visit-5.0.0.tgz", + "integrity": "sha512-MR04uvD+07cwl/yhVuVWAtw+3GOR/knlL55Nd/wAdblk27GCVt3lqpTivy/tkJcZoNPzTwS1Y+KMojlLDhoTzg==", "dependencies": { - "@types/unist": "^2.0.0", - "unist-util-is": "^5.0.0", - "unist-util-visit-parents": "^5.1.1" + "@types/unist": "^3.0.0", + "unist-util-is": "^6.0.0", + "unist-util-visit-parents": "^6.0.0" }, "funding": { "type": "opencollective", @@ -4901,11 +7497,11 @@ } }, "node_modules/unist-util-visit-children": { - "version": "2.0.2", - "resolved": "https://registry.npmjs.org/unist-util-visit-children/-/unist-util-visit-children-2.0.2.tgz", - "integrity": "sha512-+LWpMFqyUwLGpsQxpumsQ9o9DG2VGLFrpz+rpVXYIEdPy57GSy5HioC0g3bg/8WP9oCLlapQtklOzQ8uLS496Q==", + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/unist-util-visit-children/-/unist-util-visit-children-3.0.0.tgz", + "integrity": "sha512-RgmdTfSBOg04sdPcpTSD1jzoNBjt9a80/ZCzp5cI9n1qPzLZWF9YdvWGN2zmTumP1HWhXKdUWexjy/Wy/lJ7tA==", "dependencies": { - "@types/unist": "^2.0.0" + "@types/unist": "^3.0.0" }, "funding": { "type": "opencollective", @@ -4913,30 +7509,22 @@ } }, "node_modules/unist-util-visit-parents": { - "version": "5.1.3", - "resolved": "https://registry.npmjs.org/unist-util-visit-parents/-/unist-util-visit-parents-5.1.3.tgz", - "integrity": "sha512-x6+y8g7wWMyQhL1iZfhIPhDAs7Xwbn9nRosDXl7qoPTSCy0yNxnKc+hWokFifWQIDGi154rdUqKvbCa4+1kLhg==", + "version": "6.0.1", + "resolved": "https://registry.npmjs.org/unist-util-visit-parents/-/unist-util-visit-parents-6.0.1.tgz", + "integrity": "sha512-L/PqWzfTP9lzzEa6CKs0k2nARxTdZduw3zyh8d2NVBnsyvHjSX4TWse388YrrQKbvI8w20fGjGlhgT96WwKykw==", "dependencies": { - "@types/unist": "^2.0.0", - "unist-util-is": "^5.0.0" + "@types/unist": "^3.0.0", + "unist-util-is": "^6.0.0" }, "funding": { "type": "opencollective", "url": "https://opencollective.com/unified" } }, - "node_modules/untildify": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/untildify/-/untildify-4.0.0.tgz", - "integrity": "sha512-KK8xQ1mkzZeg9inewmFVDNkg3l5LUhoq9kN6iWYB/CC9YMG8HA+c1Q8HwDe6dEX7kErrEVNVBO3fWsVq5iDgtw==", - "engines": { - "node": ">=8" - } - }, "node_modules/update-browserslist-db": { - "version": "1.0.11", - "resolved": "https://registry.npmjs.org/update-browserslist-db/-/update-browserslist-db-1.0.11.tgz", - "integrity": "sha512-dCwEFf0/oT85M1fHBg4F0jtLwJrutGoHSQXCh7u4o2t1drG+c0a9Flnqww6XUKSfQMPpJBRjU8d4RXB09qtvaA==", + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/update-browserslist-db/-/update-browserslist-db-1.1.0.tgz", + "integrity": "sha512-EdRAaAyk2cUE1wOf2DkEhzxqOQvFOoRJFNS6NeyJ01Gp2beMRpBAINjM2iDXE3KCuKhwnvHIQCJm6ThL2Z+HzQ==", "funding": [ { "type": "opencollective", @@ -4952,8 +7540,8 @@ } ], "dependencies": { - "escalade": "^3.1.1", - "picocolors": "^1.0.0" + "escalade": "^3.1.2", + "picocolors": "^1.0.1" }, "bin": { "update-browserslist-db": "cli.js" @@ -4967,32 +7555,14 @@ "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", "integrity": "sha512-EPD5q1uXyFxJpCrLnCc1nHnq3gOa6DZBocAIiI2TaSCA7VCJ1UJDMagCzIkXNsUYfD1daK//LTEQ8xiIbrHtcw==" }, - "node_modules/uvu": { - "version": "0.5.6", - "resolved": "https://registry.npmjs.org/uvu/-/uvu-0.5.6.tgz", - "integrity": "sha512-+g8ENReyr8YsOc6fv/NVJs2vFdHBnBNdfE49rshrTzDWOlUx4Gq7KOS2GD8eqhy2j+Ejq29+SbKH8yjkAqXqoA==", - "dependencies": { - "dequal": "^2.0.0", - "diff": "^5.0.0", - "kleur": "^4.0.3", - "sade": "^1.7.3" - }, - "bin": { - "uvu": "bin.js" - }, - "engines": { - "node": ">=8" - } - }, "node_modules/vfile": { - "version": "5.3.7", - "resolved": "https://registry.npmjs.org/vfile/-/vfile-5.3.7.tgz", - "integrity": "sha512-r7qlzkgErKjobAmyNIkkSpizsFPYiUPuJb5pNW1RB4JcYVZhs4lIbVqk8XPk033CV/1z8ss5pkax8SuhGpcG8g==", + "version": "6.0.2", + "resolved": "https://registry.npmjs.org/vfile/-/vfile-6.0.2.tgz", + "integrity": "sha512-zND7NlS8rJYb/sPqkb13ZvbbUoExdbi4w3SfRrMq6R3FvnLQmmfpajJNITuuYm6AZ5uao9vy4BAos3EXBPf2rg==", "dependencies": { - "@types/unist": "^2.0.0", - "is-buffer": "^2.0.0", - "unist-util-stringify-position": "^3.0.0", - "vfile-message": "^3.0.0" + "@types/unist": "^3.0.0", + "unist-util-stringify-position": "^4.0.0", + "vfile-message": "^4.0.0" }, "funding": { "type": "opencollective", @@ -5000,12 +7570,12 @@ } }, "node_modules/vfile-location": { - "version": "4.1.0", - "resolved": "https://registry.npmjs.org/vfile-location/-/vfile-location-4.1.0.tgz", - "integrity": "sha512-YF23YMyASIIJXpktBa4vIGLJ5Gs88UB/XePgqPmTa7cDA+JeO3yclbpheQYCHjVHBn/yePzrXuygIL+xbvRYHw==", + "version": "5.0.2", + "resolved": "https://registry.npmjs.org/vfile-location/-/vfile-location-5.0.2.tgz", + "integrity": "sha512-NXPYyxyBSH7zB5U6+3uDdd6Nybz6o6/od9rk8bp9H8GR3L+cm/fC0uUTbqBmUTnMCUDslAGBOIKNfvvb+gGlDg==", "dependencies": { - "@types/unist": "^2.0.0", - "vfile": "^5.0.0" + "@types/unist": "^3.0.0", + "vfile": "^6.0.0" }, "funding": { "type": "opencollective", @@ -5013,533 +7583,254 @@ } }, "node_modules/vfile-message": { - "version": "3.1.4", - "resolved": "https://registry.npmjs.org/vfile-message/-/vfile-message-3.1.4.tgz", - "integrity": "sha512-fa0Z6P8HUrQN4BZaX05SIVXic+7kE3b05PWAtPuYP9QLHsLKYR7/AlLW3NtOrpXRLeawpDLMsVkmk5DG0NXgWw==", + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/vfile-message/-/vfile-message-4.0.2.tgz", + "integrity": "sha512-jRDZ1IMLttGj41KcZvlrYAaI3CfqpLpfpf+Mfig13viT6NKvRzWZ+lXz0Y5D60w6uJIBAOGq9mSHf0gktF0duw==", "dependencies": { - "@types/unist": "^2.0.0", - "unist-util-stringify-position": "^3.0.0" + "@types/unist": "^3.0.0", + "unist-util-stringify-position": "^4.0.0" }, "funding": { "type": "opencollective", "url": "https://opencollective.com/unified" } }, - "node_modules/vite": { - "version": "4.4.4", - "resolved": "https://registry.npmjs.org/vite/-/vite-4.4.4.tgz", - "integrity": "sha512-4mvsTxjkveWrKDJI70QmelfVqTm+ihFAb6+xf4sjEU2TmUCTlVX87tmg/QooPEMQb/lM9qGHT99ebqPziEd3wg==", + "node_modules/volar-service-css": { + "version": "0.0.61", + "resolved": "https://registry.npmjs.org/volar-service-css/-/volar-service-css-0.0.61.tgz", + "integrity": "sha512-Ct9L/w+IB1JU8F4jofcNCGoHy6TF83aiapfZq9A0qYYpq+Kk5dH+ONS+rVZSsuhsunq8UvAuF8Gk6B8IFLfniw==", + "license": "MIT", "dependencies": { - "esbuild": "^0.18.10", - "postcss": "^8.4.25", - "rollup": "^3.25.2" - }, - "bin": { - "vite": "bin/vite.js" - }, - "engines": { - "node": "^14.18.0 || >=16.0.0" - }, - "funding": { - "url": "https://github.com/vitejs/vite?sponsor=1" - }, - "optionalDependencies": { - "fsevents": "~2.3.2" + "vscode-css-languageservice": "^6.3.0", + "vscode-languageserver-textdocument": "^1.0.11", + "vscode-uri": "^3.0.8" }, "peerDependencies": { - "@types/node": ">= 14", - "less": "*", - "lightningcss": "^1.21.0", - "sass": "*", - "stylus": "*", - "sugarss": "*", - "terser": "^5.4.0" + "@volar/language-service": "~2.4.0" }, "peerDependenciesMeta": { - "@types/node": { - "optional": true - }, - "less": { - "optional": true - }, - "lightningcss": { - "optional": true - }, - "sass": { - "optional": true - }, - "stylus": { - "optional": true - }, - "sugarss": { - "optional": true - }, - "terser": { + "@volar/language-service": { "optional": true } } }, - "node_modules/vite/node_modules/@esbuild/android-arm": { - "version": "0.18.13", - "resolved": "https://registry.npmjs.org/@esbuild/android-arm/-/android-arm-0.18.13.tgz", - "integrity": "sha512-KwqFhxRFMKZINHzCqf8eKxE0XqWlAVPRxwy6rc7CbVFxzUWB2sA/s3hbMZeemPdhN3fKBkqOaFhTbS8xJXYIWQ==", - "cpu": [ - "arm" - ], - "optional": true, - "os": [ - "android" - ], - "engines": { - "node": ">=12" - } - }, - "node_modules/vite/node_modules/@esbuild/android-arm64": { - "version": "0.18.13", - "resolved": "https://registry.npmjs.org/@esbuild/android-arm64/-/android-arm64-0.18.13.tgz", - "integrity": "sha512-j7NhycJUoUAG5kAzGf4fPWfd17N6SM3o1X6MlXVqfHvs2buFraCJzos9vbeWjLxOyBKHyPOnuCuipbhvbYtTAg==", - "cpu": [ - "arm64" - ], - "optional": true, - "os": [ - "android" - ], - "engines": { - "node": ">=12" - } - }, - "node_modules/vite/node_modules/@esbuild/android-x64": { - "version": "0.18.13", - "resolved": "https://registry.npmjs.org/@esbuild/android-x64/-/android-x64-0.18.13.tgz", - "integrity": "sha512-M2eZkRxR6WnWfVELHmv6MUoHbOqnzoTVSIxgtsyhm/NsgmL+uTmag/VVzdXvmahak1I6sOb1K/2movco5ikDJg==", - "cpu": [ - "x64" - ], - "optional": true, - "os": [ - "android" - ], - "engines": { - "node": ">=12" - } - }, - "node_modules/vite/node_modules/@esbuild/darwin-arm64": { - "version": "0.18.13", - "resolved": "https://registry.npmjs.org/@esbuild/darwin-arm64/-/darwin-arm64-0.18.13.tgz", - "integrity": "sha512-f5goG30YgR1GU+fxtaBRdSW3SBG9pZW834Mmhxa6terzcboz7P2R0k4lDxlkP7NYRIIdBbWp+VgwQbmMH4yV7w==", - "cpu": [ - "arm64" - ], - "optional": true, - "os": [ - "darwin" - ], - "engines": { - "node": ">=12" - } - }, - "node_modules/vite/node_modules/@esbuild/darwin-x64": { - "version": "0.18.13", - "resolved": "https://registry.npmjs.org/@esbuild/darwin-x64/-/darwin-x64-0.18.13.tgz", - "integrity": "sha512-RIrxoKH5Eo+yE5BtaAIMZaiKutPhZjw+j0OCh8WdvKEKJQteacq0myZvBDLU+hOzQOZWJeDnuQ2xgSScKf1Ovw==", - "cpu": [ - "x64" - ], - "optional": true, - "os": [ - "darwin" - ], - "engines": { - "node": ">=12" - } - }, - "node_modules/vite/node_modules/@esbuild/freebsd-arm64": { - "version": "0.18.13", - "resolved": "https://registry.npmjs.org/@esbuild/freebsd-arm64/-/freebsd-arm64-0.18.13.tgz", - "integrity": "sha512-AfRPhHWmj9jGyLgW/2FkYERKmYR+IjYxf2rtSLmhOrPGFh0KCETFzSjx/JX/HJnvIqHt/DRQD/KAaVsUKoI3Xg==", - "cpu": [ - "arm64" - ], - "optional": true, - "os": [ - "freebsd" - ], - "engines": { - "node": ">=12" - } - }, - "node_modules/vite/node_modules/@esbuild/freebsd-x64": { - "version": "0.18.13", - "resolved": "https://registry.npmjs.org/@esbuild/freebsd-x64/-/freebsd-x64-0.18.13.tgz", - "integrity": "sha512-pGzWWZJBInhIgdEwzn8VHUBang8UvFKsvjDkeJ2oyY5gZtAM6BaxK0QLCuZY+qoj/nx/lIaItH425rm/hloETA==", - "cpu": [ - "x64" - ], - "optional": true, - "os": [ - "freebsd" - ], - "engines": { - "node": ">=12" - } - }, - "node_modules/vite/node_modules/@esbuild/linux-arm": { - "version": "0.18.13", - "resolved": "https://registry.npmjs.org/@esbuild/linux-arm/-/linux-arm-0.18.13.tgz", - "integrity": "sha512-4iMxLRMCxGyk7lEvkkvrxw4aJeC93YIIrfbBlUJ062kilUUnAiMb81eEkVvCVoh3ON283ans7+OQkuy1uHW+Hw==", - "cpu": [ - "arm" - ], - "optional": true, - "os": [ - "linux" - ], - "engines": { - "node": ">=12" - } - }, - "node_modules/vite/node_modules/@esbuild/linux-arm64": { - "version": "0.18.13", - "resolved": "https://registry.npmjs.org/@esbuild/linux-arm64/-/linux-arm64-0.18.13.tgz", - "integrity": "sha512-hCzZbVJEHV7QM77fHPv2qgBcWxgglGFGCxk6KfQx6PsVIdi1u09X7IvgE9QKqm38OpkzaAkPnnPqwRsltvLkIQ==", - "cpu": [ - "arm64" - ], - "optional": true, - "os": [ - "linux" - ], - "engines": { - "node": ">=12" - } - }, - "node_modules/vite/node_modules/@esbuild/linux-ia32": { - "version": "0.18.13", - "resolved": "https://registry.npmjs.org/@esbuild/linux-ia32/-/linux-ia32-0.18.13.tgz", - "integrity": "sha512-I3OKGbynl3AAIO6onXNrup/ttToE6Rv2XYfFgLK/wnr2J+1g+7k4asLrE+n7VMhaqX+BUnyWkCu27rl+62Adug==", - "cpu": [ - "ia32" - ], - "optional": true, - "os": [ - "linux" - ], - "engines": { - "node": ">=12" - } - }, - "node_modules/vite/node_modules/@esbuild/linux-loong64": { - "version": "0.18.13", - "resolved": "https://registry.npmjs.org/@esbuild/linux-loong64/-/linux-loong64-0.18.13.tgz", - "integrity": "sha512-8pcKDApAsKc6WW51ZEVidSGwGbebYw2qKnO1VyD8xd6JN0RN6EUXfhXmDk9Vc4/U3Y4AoFTexQewQDJGsBXBpg==", - "cpu": [ - "loong64" - ], - "optional": true, - "os": [ - "linux" - ], - "engines": { - "node": ">=12" - } - }, - "node_modules/vite/node_modules/@esbuild/linux-mips64el": { - "version": "0.18.13", - "resolved": "https://registry.npmjs.org/@esbuild/linux-mips64el/-/linux-mips64el-0.18.13.tgz", - "integrity": "sha512-6GU+J1PLiVqWx8yoCK4Z0GnfKyCGIH5L2KQipxOtbNPBs+qNDcMJr9euxnyJ6FkRPyMwaSkjejzPSISD9hb+gg==", - "cpu": [ - "mips64el" - ], - "optional": true, - "os": [ - "linux" - ], - "engines": { - "node": ">=12" - } - }, - "node_modules/vite/node_modules/@esbuild/linux-ppc64": { - "version": "0.18.13", - "resolved": "https://registry.npmjs.org/@esbuild/linux-ppc64/-/linux-ppc64-0.18.13.tgz", - "integrity": "sha512-pfn/OGZ8tyR8YCV7MlLl5hAit2cmS+j/ZZg9DdH0uxdCoJpV7+5DbuXrR+es4ayRVKIcfS9TTMCs60vqQDmh+w==", - "cpu": [ - "ppc64" - ], - "optional": true, - "os": [ - "linux" - ], - "engines": { - "node": ">=12" - } - }, - "node_modules/vite/node_modules/@esbuild/linux-riscv64": { - "version": "0.18.13", - "resolved": "https://registry.npmjs.org/@esbuild/linux-riscv64/-/linux-riscv64-0.18.13.tgz", - "integrity": "sha512-aIbhU3LPg0lOSCfVeGHbmGYIqOtW6+yzO+Nfv57YblEK01oj0mFMtvDJlOaeAZ6z0FZ9D13oahi5aIl9JFphGg==", - "cpu": [ - "riscv64" - ], - "optional": true, - "os": [ - "linux" - ], - "engines": { - "node": ">=12" - } - }, - "node_modules/vite/node_modules/@esbuild/linux-s390x": { - "version": "0.18.13", - "resolved": "https://registry.npmjs.org/@esbuild/linux-s390x/-/linux-s390x-0.18.13.tgz", - "integrity": "sha512-Pct1QwF2sp+5LVi4Iu5Y+6JsGaV2Z2vm4O9Dd7XZ5tKYxEHjFtb140fiMcl5HM1iuv6xXO8O1Vrb1iJxHlv8UA==", - "cpu": [ - "s390x" - ], - "optional": true, - "os": [ - "linux" - ], - "engines": { - "node": ">=12" - } - }, - "node_modules/vite/node_modules/@esbuild/linux-x64": { - "version": "0.18.13", - "resolved": "https://registry.npmjs.org/@esbuild/linux-x64/-/linux-x64-0.18.13.tgz", - "integrity": "sha512-zTrIP0KzYP7O0+3ZnmzvUKgGtUvf4+piY8PIO3V8/GfmVd3ZyHJGz7Ht0np3P1wz+I8qJ4rjwJKqqEAbIEPngA==", - "cpu": [ - "x64" - ], - "optional": true, - "os": [ - "linux" - ], - "engines": { - "node": ">=12" - } - }, - "node_modules/vite/node_modules/@esbuild/netbsd-x64": { - "version": "0.18.13", - "resolved": "https://registry.npmjs.org/@esbuild/netbsd-x64/-/netbsd-x64-0.18.13.tgz", - "integrity": "sha512-I6zs10TZeaHDYoGxENuksxE1sxqZpCp+agYeW039yqFwh3MgVvdmXL5NMveImOC6AtpLvE4xG5ujVic4NWFIDQ==", - "cpu": [ - "x64" - ], - "optional": true, - "os": [ - "netbsd" - ], - "engines": { - "node": ">=12" - } - }, - "node_modules/vite/node_modules/@esbuild/openbsd-x64": { - "version": "0.18.13", - "resolved": "https://registry.npmjs.org/@esbuild/openbsd-x64/-/openbsd-x64-0.18.13.tgz", - "integrity": "sha512-W5C5nczhrt1y1xPG5bV+0M12p2vetOGlvs43LH8SopQ3z2AseIROu09VgRqydx5qFN7y9qCbpgHLx0kb0TcW7g==", - "cpu": [ - "x64" - ], - "optional": true, - "os": [ - "openbsd" - ], - "engines": { - "node": ">=12" - } - }, - "node_modules/vite/node_modules/@esbuild/sunos-x64": { - "version": "0.18.13", - "resolved": "https://registry.npmjs.org/@esbuild/sunos-x64/-/sunos-x64-0.18.13.tgz", - "integrity": "sha512-X/xzuw4Hzpo/yq3YsfBbIsipNgmsm8mE/QeWbdGdTTeZ77fjxI2K0KP3AlhZ6gU3zKTw1bKoZTuKLnqcJ537qw==", - "cpu": [ - "x64" - ], - "optional": true, - "os": [ - "sunos" - ], - "engines": { - "node": ">=12" - } - }, - "node_modules/vite/node_modules/@esbuild/win32-arm64": { - "version": "0.18.13", - "resolved": "https://registry.npmjs.org/@esbuild/win32-arm64/-/win32-arm64-0.18.13.tgz", - "integrity": "sha512-4CGYdRQT/ILd+yLLE5i4VApMPfGE0RPc/wFQhlluDQCK09+b4JDbxzzjpgQqTPrdnP7r5KUtGVGZYclYiPuHrw==", - "cpu": [ - "arm64" - ], - "optional": true, - "os": [ - "win32" - ], - "engines": { - "node": ">=12" - } - }, - "node_modules/vite/node_modules/@esbuild/win32-ia32": { - "version": "0.18.13", - "resolved": "https://registry.npmjs.org/@esbuild/win32-ia32/-/win32-ia32-0.18.13.tgz", - "integrity": "sha512-D+wKZaRhQI+MUGMH+DbEr4owC2D7XnF+uyGiZk38QbgzLcofFqIOwFs7ELmIeU45CQgfHNy9Q+LKW3cE8g37Kg==", - "cpu": [ - "ia32" - ], - "optional": true, - "os": [ - "win32" - ], - "engines": { - "node": ">=12" - } - }, - "node_modules/vite/node_modules/@esbuild/win32-x64": { - "version": "0.18.13", - "resolved": "https://registry.npmjs.org/@esbuild/win32-x64/-/win32-x64-0.18.13.tgz", - "integrity": "sha512-iVl6lehAfJS+VmpF3exKpNQ8b0eucf5VWfzR8S7xFve64NBNz2jPUgx1X93/kfnkfgP737O+i1k54SVQS7uVZA==", - "cpu": [ - "x64" - ], - "optional": true, - "os": [ - "win32" - ], - "engines": { - "node": ">=12" - } - }, - "node_modules/vite/node_modules/esbuild": { - "version": "0.18.13", - "resolved": "https://registry.npmjs.org/esbuild/-/esbuild-0.18.13.tgz", - "integrity": "sha512-vhg/WR/Oiu4oUIkVhmfcc23G6/zWuEQKFS+yiosSHe4aN6+DQRXIfeloYGibIfVhkr4wyfuVsGNLr+sQU1rWWw==", - "hasInstallScript": true, - "bin": { - "esbuild": "bin/esbuild" + "node_modules/volar-service-emmet": { + "version": "0.0.61", + "resolved": "https://registry.npmjs.org/volar-service-emmet/-/volar-service-emmet-0.0.61.tgz", + "integrity": "sha512-iiYqBxjjcekqrRruw4COQHZME6EZYWVbkHjHDbULpml3g8HGJHzpAMkj9tXNCPxf36A+f1oUYjsvZt36qPg4cg==", + "license": "MIT", + "dependencies": { + "@emmetio/css-parser": "^0.4.0", + "@emmetio/html-matcher": "^1.3.0", + "@vscode/emmet-helper": "^2.9.3", + "vscode-uri": "^3.0.8" }, - "engines": { - "node": ">=12" - }, - "optionalDependencies": { - "@esbuild/android-arm": "0.18.13", - "@esbuild/android-arm64": "0.18.13", - "@esbuild/android-x64": "0.18.13", - "@esbuild/darwin-arm64": "0.18.13", - "@esbuild/darwin-x64": "0.18.13", - "@esbuild/freebsd-arm64": "0.18.13", - "@esbuild/freebsd-x64": "0.18.13", - "@esbuild/linux-arm": "0.18.13", - "@esbuild/linux-arm64": "0.18.13", - "@esbuild/linux-ia32": "0.18.13", - "@esbuild/linux-loong64": "0.18.13", - "@esbuild/linux-mips64el": "0.18.13", - "@esbuild/linux-ppc64": "0.18.13", - "@esbuild/linux-riscv64": "0.18.13", - "@esbuild/linux-s390x": "0.18.13", - "@esbuild/linux-x64": "0.18.13", - "@esbuild/netbsd-x64": "0.18.13", - "@esbuild/openbsd-x64": "0.18.13", - "@esbuild/sunos-x64": "0.18.13", - "@esbuild/win32-arm64": "0.18.13", - "@esbuild/win32-ia32": "0.18.13", - "@esbuild/win32-x64": "0.18.13" - } - }, - "node_modules/vitefu": { - "version": "0.2.4", - "resolved": "https://registry.npmjs.org/vitefu/-/vitefu-0.2.4.tgz", - "integrity": "sha512-fanAXjSaf9xXtOOeno8wZXIhgia+CZury481LsDaV++lSvcU2R9Ch2bPh3PYFyoHW+w9LqAeYRISVQjUIew14g==", "peerDependencies": { - "vite": "^3.0.0 || ^4.0.0" + "@volar/language-service": "~2.4.0" }, "peerDependenciesMeta": { - "vite": { + "@volar/language-service": { + "optional": true + } + } + }, + "node_modules/volar-service-html": { + "version": "0.0.61", + "resolved": "https://registry.npmjs.org/volar-service-html/-/volar-service-html-0.0.61.tgz", + "integrity": "sha512-yFE+YmmgqIL5HI4ORqP++IYb1QaGcv+xBboI0WkCxJJ/M35HZj7f5rbT3eQ24ECLXFbFCFanckwyWJVz5KmN3Q==", + "license": "MIT", + "dependencies": { + "vscode-html-languageservice": "^5.3.0", + "vscode-languageserver-textdocument": "^1.0.11", + "vscode-uri": "^3.0.8" + }, + "peerDependencies": { + "@volar/language-service": "~2.4.0" + }, + "peerDependenciesMeta": { + "@volar/language-service": { + "optional": true + } + } + }, + "node_modules/volar-service-prettier": { + "version": "0.0.61", + "resolved": "https://registry.npmjs.org/volar-service-prettier/-/volar-service-prettier-0.0.61.tgz", + "integrity": "sha512-F612nql5I0IS8HxXemCGvOR2Uxd4XooIwqYVUvk7WSBxP/+xu1jYvE3QJ7EVpl8Ty3S4SxPXYiYTsG3bi+gzIQ==", + "license": "MIT", + "dependencies": { + "vscode-uri": "^3.0.8" + }, + "peerDependencies": { + "@volar/language-service": "~2.4.0", + "prettier": "^2.2 || ^3.0" + }, + "peerDependenciesMeta": { + "@volar/language-service": { + "optional": true + }, + "prettier": { + "optional": true + } + } + }, + "node_modules/volar-service-typescript": { + "version": "0.0.61", + "resolved": "https://registry.npmjs.org/volar-service-typescript/-/volar-service-typescript-0.0.61.tgz", + "integrity": "sha512-4kRHxVbW7wFBHZWRU6yWxTgiKETBDIJNwmJUAWeP0mHaKpnDGj/astdRFKqGFRYVeEYl45lcUPhdJyrzanjsdQ==", + "license": "MIT", + "dependencies": { + "path-browserify": "^1.0.1", + "semver": "^7.6.2", + "typescript-auto-import-cache": "^0.3.3", + "vscode-languageserver-textdocument": "^1.0.11", + "vscode-nls": "^5.2.0", + "vscode-uri": "^3.0.8" + }, + "peerDependencies": { + "@volar/language-service": "~2.4.0" + }, + "peerDependenciesMeta": { + "@volar/language-service": { + "optional": true + } + } + }, + "node_modules/volar-service-typescript-twoslash-queries": { + "version": "0.0.61", + "resolved": "https://registry.npmjs.org/volar-service-typescript-twoslash-queries/-/volar-service-typescript-twoslash-queries-0.0.61.tgz", + "integrity": "sha512-99FICGrEF0r1E2tV+SvprHPw9Knyg7BdW2fUch0tf59kG+KG+Tj4tL6tUg+cy8f23O/VXlmsWFMIE+bx1dXPnQ==", + "license": "MIT", + "dependencies": { + "vscode-uri": "^3.0.8" + }, + "peerDependencies": { + "@volar/language-service": "~2.4.0" + }, + "peerDependenciesMeta": { + "@volar/language-service": { + "optional": true + } + } + }, + "node_modules/volar-service-yaml": { + "version": "0.0.61", + "resolved": "https://registry.npmjs.org/volar-service-yaml/-/volar-service-yaml-0.0.61.tgz", + "integrity": "sha512-L+gbDiLDQQ1rZUbJ3mf3doDsoQUa8OZM/xdpk/unMg1Vz24Zmi2Ign8GrZyBD7bRoIQDwOH9gdktGDKzRPpUNw==", + "license": "MIT", + "dependencies": { + "vscode-uri": "^3.0.8", + "yaml-language-server": "~1.15.0" + }, + "peerDependencies": { + "@volar/language-service": "~2.4.0" + }, + "peerDependenciesMeta": { + "@volar/language-service": { "optional": true } } }, "node_modules/vscode-css-languageservice": { - "version": "6.2.6", - "resolved": "https://registry.npmjs.org/vscode-css-languageservice/-/vscode-css-languageservice-6.2.6.tgz", - "integrity": "sha512-SA2WkeOecIpUiEbZnjOsP/fI5CRITZEiQGSHXKiDQDwLApfKcnLhZwMtOBbIifSzESVcQa7b/shX/nbnF4NoCg==", + "version": "6.3.0", + "resolved": "https://registry.npmjs.org/vscode-css-languageservice/-/vscode-css-languageservice-6.3.0.tgz", + "integrity": "sha512-nU92imtkgzpCL0xikrIb8WvedV553F2BENzgz23wFuok/HLN5BeQmroMy26pUwFxV2eV8oNRmYCUv8iO7kSMhw==", + "license": "MIT", "dependencies": { - "@vscode/l10n": "^0.0.14", - "vscode-languageserver-textdocument": "^1.0.8", - "vscode-languageserver-types": "^3.17.3", - "vscode-uri": "^3.0.7" + "@vscode/l10n": "^0.0.18", + "vscode-languageserver-textdocument": "^1.0.11", + "vscode-languageserver-types": "3.17.5", + "vscode-uri": "^3.0.8" } }, "node_modules/vscode-html-languageservice": { - "version": "5.0.6", - "resolved": "https://registry.npmjs.org/vscode-html-languageservice/-/vscode-html-languageservice-5.0.6.tgz", - "integrity": "sha512-gCixNg6fjPO7+kwSMBAVXcwDRHdjz1WOyNfI0n5Wx0J7dfHG8ggb3zD1FI8E2daTZrwS1cooOiSoc1Xxph4qRQ==", + "version": "5.3.0", + "resolved": "https://registry.npmjs.org/vscode-html-languageservice/-/vscode-html-languageservice-5.3.0.tgz", + "integrity": "sha512-C4Z3KsP5Ih+fjHpiBc5jxmvCl+4iEwvXegIrzu2F5pktbWvQaBT3YkVPk8N+QlSSMk8oCG6PKtZ/Sq2YHb5e8g==", + "license": "MIT", "dependencies": { - "@vscode/l10n": "^0.0.14", - "vscode-languageserver-textdocument": "^1.0.8", - "vscode-languageserver-types": "^3.17.3", - "vscode-uri": "^3.0.7" + "@vscode/l10n": "^0.0.18", + "vscode-languageserver-textdocument": "^1.0.11", + "vscode-languageserver-types": "^3.17.5", + "vscode-uri": "^3.0.8" } }, + "node_modules/vscode-json-languageservice": { + "version": "4.1.8", + "resolved": "https://registry.npmjs.org/vscode-json-languageservice/-/vscode-json-languageservice-4.1.8.tgz", + "integrity": "sha512-0vSpg6Xd9hfV+eZAaYN63xVVMOTmJ4GgHxXnkLCh+9RsQBkWKIghzLhW2B9ebfG+LQQg8uLtsQ2aUKjTgE+QOg==", + "license": "MIT", + "dependencies": { + "jsonc-parser": "^3.0.0", + "vscode-languageserver-textdocument": "^1.0.1", + "vscode-languageserver-types": "^3.16.0", + "vscode-nls": "^5.0.0", + "vscode-uri": "^3.0.2" + }, + "engines": { + "npm": ">=7.0.0" + } + }, + "node_modules/vscode-json-languageservice/node_modules/jsonc-parser": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/jsonc-parser/-/jsonc-parser-3.3.1.tgz", + "integrity": "sha512-HUgH65KyejrUFPvHFPbqOY0rsFip3Bo5wb4ngvdi1EpCYWUQDC5V+Y7mZws+DLkr4M//zQJoanu1SP+87Dv1oQ==", + "license": "MIT" + }, "node_modules/vscode-jsonrpc": { - "version": "8.1.0", - "resolved": "https://registry.npmjs.org/vscode-jsonrpc/-/vscode-jsonrpc-8.1.0.tgz", - "integrity": "sha512-6TDy/abTQk+zDGYazgbIPc+4JoXdwC8NHU9Pbn4UJP1fehUyZmM4RHp5IthX7A6L5KS30PRui+j+tbbMMMafdw==", + "version": "8.2.0", + "resolved": "https://registry.npmjs.org/vscode-jsonrpc/-/vscode-jsonrpc-8.2.0.tgz", + "integrity": "sha512-C+r0eKJUIfiDIfwJhria30+TYWPtuHJXHtI7J0YlOmKAo7ogxP20T0zxB7HZQIFhIyvoBPwWskjxrvAtfjyZfA==", + "license": "MIT", "engines": { "node": ">=14.0.0" } }, "node_modules/vscode-languageserver": { - "version": "8.1.0", - "resolved": "https://registry.npmjs.org/vscode-languageserver/-/vscode-languageserver-8.1.0.tgz", - "integrity": "sha512-eUt8f1z2N2IEUDBsKaNapkz7jl5QpskN2Y0G01T/ItMxBxw1fJwvtySGB9QMecatne8jFIWJGWI61dWjyTLQsw==", + "version": "9.0.1", + "resolved": "https://registry.npmjs.org/vscode-languageserver/-/vscode-languageserver-9.0.1.tgz", + "integrity": "sha512-woByF3PDpkHFUreUa7Hos7+pUWdeWMXRd26+ZX2A8cFx6v/JPTtd4/uN0/jB6XQHYaOlHbio03NTHCqrgG5n7g==", + "license": "MIT", "dependencies": { - "vscode-languageserver-protocol": "3.17.3" + "vscode-languageserver-protocol": "3.17.5" }, "bin": { "installServerIntoExtension": "bin/installServerIntoExtension" } }, "node_modules/vscode-languageserver-protocol": { - "version": "3.17.3", - "resolved": "https://registry.npmjs.org/vscode-languageserver-protocol/-/vscode-languageserver-protocol-3.17.3.tgz", - "integrity": "sha512-924/h0AqsMtA5yK22GgMtCYiMdCOtWTSGgUOkgEDX+wk2b0x4sAfLiO4NxBxqbiVtz7K7/1/RgVrVI0NClZwqA==", + "version": "3.17.5", + "resolved": "https://registry.npmjs.org/vscode-languageserver-protocol/-/vscode-languageserver-protocol-3.17.5.tgz", + "integrity": "sha512-mb1bvRJN8SVznADSGWM9u/b07H7Ecg0I3OgXDuLdn307rl/J3A9YD6/eYOssqhecL27hK1IPZAsaqh00i/Jljg==", + "license": "MIT", "dependencies": { - "vscode-jsonrpc": "8.1.0", - "vscode-languageserver-types": "3.17.3" + "vscode-jsonrpc": "8.2.0", + "vscode-languageserver-types": "3.17.5" } }, "node_modules/vscode-languageserver-textdocument": { - "version": "1.0.8", - "resolved": "https://registry.npmjs.org/vscode-languageserver-textdocument/-/vscode-languageserver-textdocument-1.0.8.tgz", - "integrity": "sha512-1bonkGqQs5/fxGT5UchTgjGVnfysL0O8v1AYMBjqTbWQTFn721zaPGDYFkOKtfDgFiSgXM3KwaG3FMGfW4Ed9Q==" + "version": "1.0.12", + "resolved": "https://registry.npmjs.org/vscode-languageserver-textdocument/-/vscode-languageserver-textdocument-1.0.12.tgz", + "integrity": "sha512-cxWNPesCnQCcMPeenjKKsOCKQZ/L6Tv19DTRIGuLWe32lyzWhihGVJ/rcckZXJxfdKCFvRLS3fpBIsV/ZGX4zA==", + "license": "MIT" }, "node_modules/vscode-languageserver-types": { - "version": "3.17.3", - "resolved": "https://registry.npmjs.org/vscode-languageserver-types/-/vscode-languageserver-types-3.17.3.tgz", - "integrity": "sha512-SYU4z1dL0PyIMd4Vj8YOqFvHu7Hz/enbWtpfnVbJHU4Nd1YNYx8u0ennumc6h48GQNeOLxmwySmnADouT/AuZA==" + "version": "3.17.5", + "resolved": "https://registry.npmjs.org/vscode-languageserver-types/-/vscode-languageserver-types-3.17.5.tgz", + "integrity": "sha512-Ld1VelNuX9pdF39h2Hgaeb5hEZM2Z3jUrrMgWQAu82jMtZp7p3vJT3BzToKtZI7NgQssZje5o0zryOrhQvzQAg==", + "license": "MIT" }, - "node_modules/vscode-oniguruma": { - "version": "1.7.0", - "resolved": "https://registry.npmjs.org/vscode-oniguruma/-/vscode-oniguruma-1.7.0.tgz", - "integrity": "sha512-L9WMGRfrjOhgHSdOYgCt/yRMsXzLDJSL7BPrOZt73gU0iWO4mpqzqQzOz5srxqTvMBaR0XZTSrVWo4j55Rc6cA==" - }, - "node_modules/vscode-textmate": { - "version": "8.0.0", - "resolved": "https://registry.npmjs.org/vscode-textmate/-/vscode-textmate-8.0.0.tgz", - "integrity": "sha512-AFbieoL7a5LMqcnOF04ji+rpXadgOXnZsxQr//r83kLPr7biP7am3g9zbaZIaBGwBRWeSvoMD4mgPdX3e4NWBg==" + "node_modules/vscode-nls": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/vscode-nls/-/vscode-nls-5.2.0.tgz", + "integrity": "sha512-RAaHx7B14ZU04EU31pT+rKz2/zSl7xMsfIZuo8pd+KZO6PXtQmpevpq3vxvWNcrGbdmhM/rr5Uw5Mz+NBfhVng==", + "license": "MIT" }, "node_modules/vscode-uri": { - "version": "3.0.7", - "resolved": "https://registry.npmjs.org/vscode-uri/-/vscode-uri-3.0.7.tgz", - "integrity": "sha512-eOpPHogvorZRobNqJGhapa0JdwaxpjVvyBp0QIUMRMSf8ZAlqOdEquKuRmw9Qwu0qXtJIWqFtMkmvJjUZmMjVA==" - }, - "node_modules/wcwidth": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/wcwidth/-/wcwidth-1.0.1.tgz", - "integrity": "sha512-XHPEwS0q6TaxcvG85+8EYkbiCux2XtWG2mkc47Ng2A77BQu9+DqIOJldST4HgPkuea7dvKSj5VgX3P1d4rW8Tg==", - "dependencies": { - "defaults": "^1.0.3" - } + "version": "3.0.8", + "resolved": "https://registry.npmjs.org/vscode-uri/-/vscode-uri-3.0.8.tgz", + "integrity": "sha512-AyFQ0EVmsOZOlAnxoFOGOq1SQDWAB7C6aqMGS23svWAllfOaxbuFvcT8D1i8z3Gyn8fraVeZNNmN6e9bxxXkKw==", + "license": "MIT" }, "node_modules/web-namespaces": { "version": "2.0.1", @@ -5565,15 +7856,14 @@ } }, "node_modules/which-pm": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/which-pm/-/which-pm-2.0.0.tgz", - "integrity": "sha512-Lhs9Pmyph0p5n5Z3mVnN0yWcbQYUAD7rbQUiMsQxOJ3T57k7RFe35SUwWMf7dsbDZks1uOmw4AecB/JMDj3v/w==", + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/which-pm/-/which-pm-3.0.0.tgz", + "integrity": "sha512-ysVYmw6+ZBhx3+ZkcPwRuJi38ZOTLJJ33PSHaitLxSKUMsh0LkKd0nC69zZCwt5D+AYUcMK2hhw4yWny20vSGg==", "dependencies": { - "load-yaml-file": "^0.2.0", - "path-exists": "^4.0.0" + "load-yaml-file": "^0.2.0" }, "engines": { - "node": ">=8.15" + "node": ">=18.12" } }, "node_modules/which-pm-runs": { @@ -5598,6 +7888,27 @@ "url": "https://github.com/sponsors/sindresorhus" } }, + "node_modules/widest-line/node_modules/emoji-regex": { + "version": "9.2.2", + "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-9.2.2.tgz", + "integrity": "sha512-L18DaJsXSUk2+42pv8mLs5jJT2hqFkFE4j21wOmgbUqsZ2hL72NsUU785g9RXgo3s0ZNgVl42TiHp3ZtOv/Vyg==" + }, + "node_modules/widest-line/node_modules/string-width": { + "version": "5.1.2", + "resolved": "https://registry.npmjs.org/string-width/-/string-width-5.1.2.tgz", + "integrity": "sha512-HnLOCR3vjcY8beoNLtcjZ5/nxn2afmME6lhrDrebokqMap+XbeW8n9TXpPDOqdGK5qcI3oT0GKTW6wC7EMiVqA==", + "dependencies": { + "eastasianwidth": "^0.2.0", + "emoji-regex": "^9.2.2", + "strip-ansi": "^7.0.1" + }, + "engines": { + "node": ">=12" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, "node_modules/wrap-ansi": { "version": "8.1.0", "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-8.1.0.tgz", @@ -5625,11 +7936,166 @@ "url": "https://github.com/chalk/ansi-styles?sponsor=1" } }, + "node_modules/wrap-ansi/node_modules/emoji-regex": { + "version": "9.2.2", + "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-9.2.2.tgz", + "integrity": "sha512-L18DaJsXSUk2+42pv8mLs5jJT2hqFkFE4j21wOmgbUqsZ2hL72NsUU785g9RXgo3s0ZNgVl42TiHp3ZtOv/Vyg==" + }, + "node_modules/wrap-ansi/node_modules/string-width": { + "version": "5.1.2", + "resolved": "https://registry.npmjs.org/string-width/-/string-width-5.1.2.tgz", + "integrity": "sha512-HnLOCR3vjcY8beoNLtcjZ5/nxn2afmME6lhrDrebokqMap+XbeW8n9TXpPDOqdGK5qcI3oT0GKTW6wC7EMiVqA==", + "dependencies": { + "eastasianwidth": "^0.2.0", + "emoji-regex": "^9.2.2", + "strip-ansi": "^7.0.1" + }, + "engines": { + "node": ">=12" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/xxhash-wasm": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/xxhash-wasm/-/xxhash-wasm-1.0.2.tgz", + "integrity": "sha512-ibF0Or+FivM9lNrg+HGJfVX8WJqgo+kCLDc4vx6xMeTce7Aj+DLttKbxxRR/gNLSAelRc1omAPlJ77N/Jem07A==" + }, + "node_modules/y18n": { + "version": "5.0.8", + "resolved": "https://registry.npmjs.org/y18n/-/y18n-5.0.8.tgz", + "integrity": "sha512-0pfFzegeDWJHJIAmTLRP2DwHjdF5s7jo9tuztdQxAhINCdvS+3nGINqPd00AphqJR/0LhANUS6/+7SCb98YOfA==", + "engines": { + "node": ">=10" + } + }, "node_modules/yallist": { "version": "3.1.1", "resolved": "https://registry.npmjs.org/yallist/-/yallist-3.1.1.tgz", "integrity": "sha512-a4UGQaWPH59mOXUYnAG2ewncQS4i4F43Tv3JoAM+s2VDAmS9NsK8GpDMLrCHPksFT7h3K6TOoUNn2pb7RoXx4g==" }, + "node_modules/yaml": { + "version": "2.5.0", + "resolved": "https://registry.npmjs.org/yaml/-/yaml-2.5.0.tgz", + "integrity": "sha512-2wWLbGbYDiSqqIKoPjar3MPgB94ErzCtrNE1FdqGuaO0pi2JGjmE8aW8TDZwzU7vuxcGRdL/4gPQwQ7hD5AMSw==", + "license": "ISC", + "bin": { + "yaml": "bin.mjs" + }, + "engines": { + "node": ">= 14" + } + }, + "node_modules/yaml-language-server": { + "version": "1.15.0", + "resolved": "https://registry.npmjs.org/yaml-language-server/-/yaml-language-server-1.15.0.tgz", + "integrity": "sha512-N47AqBDCMQmh6mBLmI6oqxryHRzi33aPFPsJhYy3VTUGCdLHYjGh4FZzpUjRlphaADBBkDmnkM/++KNIOHi5Rw==", + "license": "MIT", + "dependencies": { + "ajv": "^8.11.0", + "lodash": "4.17.21", + "request-light": "^0.5.7", + "vscode-json-languageservice": "4.1.8", + "vscode-languageserver": "^7.0.0", + "vscode-languageserver-textdocument": "^1.0.1", + "vscode-languageserver-types": "^3.16.0", + "vscode-nls": "^5.0.0", + "vscode-uri": "^3.0.2", + "yaml": "2.2.2" + }, + "bin": { + "yaml-language-server": "bin/yaml-language-server" + }, + "optionalDependencies": { + "prettier": "2.8.7" + } + }, + "node_modules/yaml-language-server/node_modules/prettier": { + "version": "2.8.7", + "resolved": "https://registry.npmjs.org/prettier/-/prettier-2.8.7.tgz", + "integrity": "sha512-yPngTo3aXUUmyuTjeTUT75txrf+aMh9FiD7q9ZE/i6r0bPb22g4FsE6Y338PQX1bmfy08i9QQCB7/rcUAVntfw==", + "license": "MIT", + "optional": true, + "bin": { + "prettier": "bin-prettier.js" + }, + "engines": { + "node": ">=10.13.0" + }, + "funding": { + "url": "https://github.com/prettier/prettier?sponsor=1" + } + }, + "node_modules/yaml-language-server/node_modules/request-light": { + "version": "0.5.8", + "resolved": "https://registry.npmjs.org/request-light/-/request-light-0.5.8.tgz", + "integrity": "sha512-3Zjgh+8b5fhRJBQZoy+zbVKpAQGLyka0MPgW3zruTF4dFFJ8Fqcfu9YsAvi/rvdcaTeWG3MkbZv4WKxAn/84Lg==", + "license": "MIT" + }, + "node_modules/yaml-language-server/node_modules/vscode-jsonrpc": { + "version": "6.0.0", + "resolved": "https://registry.npmjs.org/vscode-jsonrpc/-/vscode-jsonrpc-6.0.0.tgz", + "integrity": "sha512-wnJA4BnEjOSyFMvjZdpiOwhSq9uDoK8e/kpRJDTaMYzwlkrhG1fwDIZI94CLsLzlCK5cIbMMtFlJlfR57Lavmg==", + "license": "MIT", + "engines": { + "node": ">=8.0.0 || >=10.0.0" + } + }, + "node_modules/yaml-language-server/node_modules/vscode-languageserver": { + "version": "7.0.0", + "resolved": "https://registry.npmjs.org/vscode-languageserver/-/vscode-languageserver-7.0.0.tgz", + "integrity": "sha512-60HTx5ID+fLRcgdHfmz0LDZAXYEV68fzwG0JWwEPBode9NuMYTIxuYXPg4ngO8i8+Ou0lM7y6GzaYWbiDL0drw==", + "license": "MIT", + "dependencies": { + "vscode-languageserver-protocol": "3.16.0" + }, + "bin": { + "installServerIntoExtension": "bin/installServerIntoExtension" + } + }, + "node_modules/yaml-language-server/node_modules/vscode-languageserver-protocol": { + "version": "3.16.0", + "resolved": "https://registry.npmjs.org/vscode-languageserver-protocol/-/vscode-languageserver-protocol-3.16.0.tgz", + "integrity": "sha512-sdeUoAawceQdgIfTI+sdcwkiK2KU+2cbEYA0agzM2uqaUy2UpnnGHtWTHVEtS0ES4zHU0eMFRGN+oQgDxlD66A==", + "license": "MIT", + "dependencies": { + "vscode-jsonrpc": "6.0.0", + "vscode-languageserver-types": "3.16.0" + } + }, + "node_modules/yaml-language-server/node_modules/vscode-languageserver-types": { + "version": "3.16.0", + "resolved": "https://registry.npmjs.org/vscode-languageserver-types/-/vscode-languageserver-types-3.16.0.tgz", + "integrity": "sha512-k8luDIWJWyenLc5ToFQQMaSrqCHiLwyKPHKPQZ5zz21vM+vIVUSvsRpcbiECH4WR88K2XZqc4ScRcZ7nk/jbeA==", + "license": "MIT" + }, + "node_modules/yaml-language-server/node_modules/yaml": { + "version": "2.2.2", + "resolved": "https://registry.npmjs.org/yaml/-/yaml-2.2.2.tgz", + "integrity": "sha512-CBKFWExMn46Foo4cldiChEzn7S7SRV+wqiluAb6xmueD/fGyRHIhX8m14vVGgeFWjN540nKCNVj6P21eQjgTuA==", + "license": "ISC", + "engines": { + "node": ">= 14" + } + }, + "node_modules/yargs": { + "version": "17.7.2", + "resolved": "https://registry.npmjs.org/yargs/-/yargs-17.7.2.tgz", + "integrity": "sha512-7dSzzRQ++CKnNI/krKnYRV7JKKPUXMEh61soaHKg9mrWEhzFWhFnxPxGl+69cD1Ou63C13NUPCnmIcrvqCuM6w==", + "dependencies": { + "cliui": "^8.0.1", + "escalade": "^3.1.1", + "get-caller-file": "^2.0.5", + "require-directory": "^2.1.1", + "string-width": "^4.2.3", + "y18n": "^5.0.5", + "yargs-parser": "^21.1.1" + }, + "engines": { + "node": ">=12" + } + }, "node_modules/yargs-parser": { "version": "21.1.1", "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-21.1.1.tgz", @@ -5638,10 +8104,47 @@ "node": ">=12" } }, + "node_modules/yargs/node_modules/ansi-regex": { + "version": "5.0.1", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", + "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", + "engines": { + "node": ">=8" + } + }, + "node_modules/yargs/node_modules/emoji-regex": { + "version": "8.0.0", + "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", + "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==" + }, + "node_modules/yargs/node_modules/string-width": { + "version": "4.2.3", + "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", + "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", + "dependencies": { + "emoji-regex": "^8.0.0", + "is-fullwidth-code-point": "^3.0.0", + "strip-ansi": "^6.0.1" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/yargs/node_modules/strip-ansi": { + "version": "6.0.1", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", + "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", + "dependencies": { + "ansi-regex": "^5.0.1" + }, + "engines": { + "node": ">=8" + } + }, "node_modules/yocto-queue": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/yocto-queue/-/yocto-queue-1.0.0.tgz", - "integrity": "sha512-9bnSc/HEW2uRy67wc+T8UwauLuPJVn28jb+GtJY16iiKWyvmYJRXVT4UamsAEGQfPohgr2q4Tq0sQbQlxTfi1g==", + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/yocto-queue/-/yocto-queue-1.1.1.tgz", + "integrity": "sha512-b4JR1PFR10y1mKjhHY9LaGo6tmrgjit7hxVIeAmyMw3jegXR4dhYqLaQF5zMXZxY7tLpMyJeLjr1C4rLmkVe8g==", "engines": { "node": ">=12.20" }, @@ -5650,13 +8153,30 @@ } }, "node_modules/zod": { - "version": "3.21.4", - "resolved": "https://registry.npmjs.org/zod/-/zod-3.21.4.tgz", - "integrity": "sha512-m46AKbrzKVzOzs/DZgVnG5H55N1sv1M8qZU3A8RIKbs3mrACDNeIOeilDymVb2HdmP8uwshOCF4uJ8uM9rCqJw==", + "version": "3.23.8", + "resolved": "https://registry.npmjs.org/zod/-/zod-3.23.8.tgz", + "integrity": "sha512-XBx9AXhXktjUqnepgTiE5flcKIYWi/rme0Eaj+5Y0lftuGBq+jyRu/md4WnuxqgP1ubdpNCsYEYPxrzVHD8d6g==", "funding": { "url": "https://github.com/sponsors/colinhacks" } }, + "node_modules/zod-to-json-schema": { + "version": "3.23.2", + "resolved": "https://registry.npmjs.org/zod-to-json-schema/-/zod-to-json-schema-3.23.2.tgz", + "integrity": "sha512-uSt90Gzc/tUfyNqxnjlfBs8W6WSGpNBv0rVsNxP/BVSMHMKGdthPYff4xtCHYloJGM0CFxFsb3NbC0eqPhfImw==", + "peerDependencies": { + "zod": "^3.23.3" + } + }, + "node_modules/zod-to-ts": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/zod-to-ts/-/zod-to-ts-1.2.0.tgz", + "integrity": "sha512-x30XE43V+InwGpvTySRNz9kB7qFU8DlyEy7BsSTCHPH1R0QasMmHWZDCzYm6bVXtj/9NNJAZF3jW8rzFvH5OFA==", + "peerDependencies": { + "typescript": "^4.9.4 || ^5.0.2", + "zod": "^3" + } + }, "node_modules/zwitch": { "version": "2.0.4", "resolved": "https://registry.npmjs.org/zwitch/-/zwitch-2.0.4.tgz", diff --git a/package.json b/package.json index 47fc2dd..0420254 100644 --- a/package.json +++ b/package.json @@ -1,7 +1,7 @@ { - "name": "", + "name": "fgo-ta-com-website", "type": "module", - "version": "0.0.1", + "version": "0.2.2-pre.22", "scripts": { "dev": "astro dev", "start": "astro dev", @@ -10,7 +10,23 @@ "astro": "astro" }, "dependencies": { - "@astrojs/sitemap": "^1.4.0", - "astro": "^2.8.3" + "@astro-community/astro-embed-youtube": "^0.5.2", + "@astrojs/check": "^0.9.3", + "@astrojs/sitemap": "^3.1.6", + "@fontsource/work-sans": "^5.0.18", + "astro": "^4.14.3", + "astro-meta-tags": "^0.3.0", + "autoprefixer": "^10.4.19", + "iconoir": "^7.7.0", + "postcss-preset-env": "^9.6.0", + "typescript": "^5.5.3" + }, + "browserslist": [ + "last 2 versions", + ">0.5% and not dead" + ], + "devDependencies": { + "prettier": "^3.1.1", + "prettier-plugin-astro": "^0.12.3" } } diff --git a/postcss.config.cjs b/postcss.config.cjs new file mode 100644 index 0000000..5fd8746 --- /dev/null +++ b/postcss.config.cjs @@ -0,0 +1,13 @@ +module.exports = { + plugins: { + "postcss-preset-env": { + autoprefixer: { flexbox: "no-2009" }, + stage: 2, + features: { + "custom-properties": false, + "custom-media-queries": true, + "nesting-rules": true + } + } + } +}; \ No newline at end of file diff --git a/static/assets/favicon.ico b/public/favicon.ico similarity index 100% rename from static/assets/favicon.ico rename to public/favicon.ico diff --git a/public/favicon.svg b/public/favicon.svg deleted file mode 100644 index f157bd1..0000000 --- a/public/favicon.svg +++ /dev/null @@ -1,9 +0,0 @@ -<svg xmlns="http://www.w3.org/2000/svg" fill="none" viewBox="0 0 128 128"> - <path d="M50.4 78.5a75.1 75.1 0 0 0-28.5 6.9l24.2-65.7c.7-2 1.9-3.2 3.4-3.2h29c1.5 0 2.7 1.2 3.4 3.2l24.2 65.7s-11.6-7-28.5-7L67 45.5c-.4-1.7-1.6-2.8-2.9-2.8-1.3 0-2.5 1.1-2.9 2.7L50.4 78.5Zm-1.1 28.2Zm-4.2-20.2c-2 6.6-.6 15.8 4.2 20.2a17.5 17.5 0 0 1 .2-.7 5.5 5.5 0 0 1 5.7-4.5c2.8.1 4.3 1.5 4.7 4.7.2 1.1.2 2.3.2 3.5v.4c0 2.7.7 5.2 2.2 7.4a13 13 0 0 0 5.7 4.9v-.3l-.2-.3c-1.8-5.6-.5-9.5 4.4-12.8l1.5-1a73 73 0 0 0 3.2-2.2 16 16 0 0 0 6.8-11.4c.3-2 .1-4-.6-6l-.8.6-1.6 1a37 37 0 0 1-22.4 2.7c-5-.7-9.7-2-13.2-6.2Z" /> - <style> - path { fill: #000; } - @media (prefers-color-scheme: dark) { - path { fill: #FFF; } - } - </style> -</svg> diff --git a/public/robots.txt b/public/robots.txt new file mode 100644 index 0000000..5d991bc --- /dev/null +++ b/public/robots.txt @@ -0,0 +1,7 @@ +user-agent:* +Disallow: /assets/data/ + +User-agent: GPTBot +Disallow: / + +Sitemap: https://fgo-ta.com/sitemap-index.xml \ No newline at end of file diff --git a/serve.json b/serve.json index 3eba146..4b422d7 100644 --- a/serve.json +++ b/serve.json @@ -4,17 +4,31 @@ "etag": true, "headers": [ { - "source" : "**/*.@(jpg|jpeg|gif|png|webp|svg)", - "headers" : [{ - "key" : "Cache-Control", - "value" : "no-cache" - }] - }, { - "source" : "404.html", - "headers" : [{ - "key" : "Cache-Control", - "value" : "no-cache" - }] + "source": "**/*.@(jpg|jpeg|gif|png|webp|svg)", + "headers": [ + { + "key": "Cache-Control", + "value": "no-cache" + } + ] + }, + { + "source": "**/*.woff2", + "headers": [ + { + "key": "Cache-Control", + "value": "no-cache" + } + ] + }, + { + "source": "404.html", + "headers": [ + { + "key": "Cache-Control", + "value": "no-cache" + } + ] } ] } diff --git a/static/assets/embed.png b/src/assets/embed.png similarity index 100% rename from static/assets/embed.png rename to src/assets/embed.png diff --git a/src/assets/lizsad.png b/src/assets/lizsad.png new file mode 100644 index 0000000..4401324 Binary files /dev/null and b/src/assets/lizsad.png differ diff --git a/static/assets/logo.svg b/src/assets/logo.svg similarity index 100% rename from static/assets/logo.svg rename to src/assets/logo.svg diff --git a/src/assets/shishousad.webp b/src/assets/shishousad.webp new file mode 100644 index 0000000..41bb76d Binary files /dev/null and b/src/assets/shishousad.webp differ diff --git a/src/assets/ta_servants/106.png b/src/assets/ta_servants/106.png new file mode 100644 index 0000000..3e16834 Binary files /dev/null and b/src/assets/ta_servants/106.png differ diff --git a/src/assets/ta_servants/11.png b/src/assets/ta_servants/11.png new file mode 100644 index 0000000..ee2ca96 Binary files /dev/null and b/src/assets/ta_servants/11.png differ diff --git a/src/assets/ta_servants/113.png b/src/assets/ta_servants/113.png new file mode 100644 index 0000000..0369e96 Binary files /dev/null and b/src/assets/ta_servants/113.png differ diff --git a/src/assets/ta_servants/115.png b/src/assets/ta_servants/115.png new file mode 100644 index 0000000..c8ab566 Binary files /dev/null and b/src/assets/ta_servants/115.png differ diff --git a/src/assets/ta_servants/118.png b/src/assets/ta_servants/118.png new file mode 100644 index 0000000..457fca3 Binary files /dev/null and b/src/assets/ta_servants/118.png differ diff --git a/src/assets/ta_servants/12.png b/src/assets/ta_servants/12.png new file mode 100644 index 0000000..b62a43f Binary files /dev/null and b/src/assets/ta_servants/12.png differ diff --git a/src/assets/ta_servants/126.png b/src/assets/ta_servants/126.png new file mode 100644 index 0000000..a79c204 Binary files /dev/null and b/src/assets/ta_servants/126.png differ diff --git a/src/assets/ta_servants/128.png b/src/assets/ta_servants/128.png new file mode 100644 index 0000000..c7bfa87 Binary files /dev/null and b/src/assets/ta_servants/128.png differ diff --git a/src/assets/ta_servants/133.png b/src/assets/ta_servants/133.png new file mode 100644 index 0000000..95cc502 Binary files /dev/null and b/src/assets/ta_servants/133.png differ diff --git a/src/assets/ta_servants/134.png b/src/assets/ta_servants/134.png new file mode 100644 index 0000000..2c7fd05 Binary files /dev/null and b/src/assets/ta_servants/134.png differ diff --git a/src/assets/ta_servants/136.png b/src/assets/ta_servants/136.png new file mode 100644 index 0000000..0993d84 Binary files /dev/null and b/src/assets/ta_servants/136.png differ diff --git a/src/assets/ta_servants/139.png b/src/assets/ta_servants/139.png new file mode 100644 index 0000000..77deafa Binary files /dev/null and b/src/assets/ta_servants/139.png differ diff --git a/src/assets/ta_servants/141.png b/src/assets/ta_servants/141.png new file mode 100644 index 0000000..843c097 Binary files /dev/null and b/src/assets/ta_servants/141.png differ diff --git a/src/assets/ta_servants/142.png b/src/assets/ta_servants/142.png new file mode 100644 index 0000000..cd4dc61 Binary files /dev/null and b/src/assets/ta_servants/142.png differ diff --git a/src/assets/ta_servants/143.png b/src/assets/ta_servants/143.png new file mode 100644 index 0000000..10b36f6 Binary files /dev/null and b/src/assets/ta_servants/143.png differ diff --git a/src/assets/ta_servants/145.png b/src/assets/ta_servants/145.png new file mode 100644 index 0000000..38eaa48 Binary files /dev/null and b/src/assets/ta_servants/145.png differ diff --git a/src/assets/ta_servants/148.png b/src/assets/ta_servants/148.png new file mode 100644 index 0000000..ddb66ff Binary files /dev/null and b/src/assets/ta_servants/148.png differ diff --git a/src/assets/ta_servants/150.png b/src/assets/ta_servants/150.png new file mode 100644 index 0000000..ba25882 Binary files /dev/null and b/src/assets/ta_servants/150.png differ diff --git a/src/assets/ta_servants/153.png b/src/assets/ta_servants/153.png new file mode 100644 index 0000000..0166148 Binary files /dev/null and b/src/assets/ta_servants/153.png differ diff --git a/src/assets/ta_servants/155.png b/src/assets/ta_servants/155.png new file mode 100644 index 0000000..5396d46 Binary files /dev/null and b/src/assets/ta_servants/155.png differ diff --git a/src/assets/ta_servants/16.png b/src/assets/ta_servants/16.png new file mode 100644 index 0000000..7c0ab54 Binary files /dev/null and b/src/assets/ta_servants/16.png differ diff --git a/src/assets/ta_servants/163.png b/src/assets/ta_servants/163.png new file mode 100644 index 0000000..874b113 Binary files /dev/null and b/src/assets/ta_servants/163.png differ diff --git a/src/assets/ta_servants/165.png b/src/assets/ta_servants/165.png new file mode 100644 index 0000000..2967a38 Binary files /dev/null and b/src/assets/ta_servants/165.png differ diff --git a/src/assets/ta_servants/167.png b/src/assets/ta_servants/167.png new file mode 100644 index 0000000..6bd7753 Binary files /dev/null and b/src/assets/ta_servants/167.png differ diff --git a/src/assets/ta_servants/175.png b/src/assets/ta_servants/175.png new file mode 100644 index 0000000..a194918 Binary files /dev/null and b/src/assets/ta_servants/175.png differ diff --git a/src/assets/ta_servants/182.png b/src/assets/ta_servants/182.png new file mode 100644 index 0000000..c363e1d Binary files /dev/null and b/src/assets/ta_servants/182.png differ diff --git a/src/assets/ta_servants/195.png b/src/assets/ta_servants/195.png new file mode 100644 index 0000000..126f7b2 Binary files /dev/null and b/src/assets/ta_servants/195.png differ diff --git a/src/assets/ta_servants/196.png b/src/assets/ta_servants/196.png new file mode 100644 index 0000000..19a4f2a Binary files /dev/null and b/src/assets/ta_servants/196.png differ diff --git a/src/assets/ta_servants/198.png b/src/assets/ta_servants/198.png new file mode 100644 index 0000000..055e5af Binary files /dev/null and b/src/assets/ta_servants/198.png differ diff --git a/src/assets/ta_servants/2.png b/src/assets/ta_servants/2.png new file mode 100644 index 0000000..8bc4482 Binary files /dev/null and b/src/assets/ta_servants/2.png differ diff --git a/src/assets/ta_servants/200.png b/src/assets/ta_servants/200.png new file mode 100644 index 0000000..cbe7c1f Binary files /dev/null and b/src/assets/ta_servants/200.png differ diff --git a/src/assets/ta_servants/201.png b/src/assets/ta_servants/201.png new file mode 100644 index 0000000..752e206 Binary files /dev/null and b/src/assets/ta_servants/201.png differ diff --git a/src/assets/ta_servants/205.png b/src/assets/ta_servants/205.png new file mode 100644 index 0000000..61ae19d Binary files /dev/null and b/src/assets/ta_servants/205.png differ diff --git a/src/assets/ta_servants/209.png b/src/assets/ta_servants/209.png new file mode 100644 index 0000000..91505e1 Binary files /dev/null and b/src/assets/ta_servants/209.png differ diff --git a/src/assets/ta_servants/213.png b/src/assets/ta_servants/213.png new file mode 100644 index 0000000..f2284f1 Binary files /dev/null and b/src/assets/ta_servants/213.png differ diff --git a/src/assets/ta_servants/215.png b/src/assets/ta_servants/215.png new file mode 100644 index 0000000..915d2a2 Binary files /dev/null and b/src/assets/ta_servants/215.png differ diff --git a/src/assets/ta_servants/216.png b/src/assets/ta_servants/216.png new file mode 100644 index 0000000..950ee44 Binary files /dev/null and b/src/assets/ta_servants/216.png differ diff --git a/src/assets/ta_servants/219.png b/src/assets/ta_servants/219.png new file mode 100644 index 0000000..1893dfa Binary files /dev/null and b/src/assets/ta_servants/219.png differ diff --git a/src/assets/ta_servants/220.png b/src/assets/ta_servants/220.png new file mode 100644 index 0000000..e999124 Binary files /dev/null and b/src/assets/ta_servants/220.png differ diff --git a/src/assets/ta_servants/223.png b/src/assets/ta_servants/223.png new file mode 100644 index 0000000..750aa38 Binary files /dev/null and b/src/assets/ta_servants/223.png differ diff --git a/src/assets/ta_servants/224.png b/src/assets/ta_servants/224.png new file mode 100644 index 0000000..3726ca1 Binary files /dev/null and b/src/assets/ta_servants/224.png differ diff --git a/src/assets/ta_servants/225.png b/src/assets/ta_servants/225.png new file mode 100644 index 0000000..1956677 Binary files /dev/null and b/src/assets/ta_servants/225.png differ diff --git a/src/assets/ta_servants/226.png b/src/assets/ta_servants/226.png new file mode 100644 index 0000000..35b9a22 Binary files /dev/null and b/src/assets/ta_servants/226.png differ diff --git a/src/assets/ta_servants/231.png b/src/assets/ta_servants/231.png new file mode 100644 index 0000000..c7bb35e Binary files /dev/null and b/src/assets/ta_servants/231.png differ diff --git a/src/assets/ta_servants/232.png b/src/assets/ta_servants/232.png new file mode 100644 index 0000000..8ba56d2 Binary files /dev/null and b/src/assets/ta_servants/232.png differ diff --git a/src/assets/ta_servants/234.png b/src/assets/ta_servants/234.png new file mode 100644 index 0000000..785de5c Binary files /dev/null and b/src/assets/ta_servants/234.png differ diff --git a/src/assets/ta_servants/235.png b/src/assets/ta_servants/235.png new file mode 100644 index 0000000..f9642e3 Binary files /dev/null and b/src/assets/ta_servants/235.png differ diff --git a/src/assets/ta_servants/238.png b/src/assets/ta_servants/238.png new file mode 100644 index 0000000..2460563 Binary files /dev/null and b/src/assets/ta_servants/238.png differ diff --git a/src/assets/ta_servants/239.png b/src/assets/ta_servants/239.png new file mode 100644 index 0000000..8b74e9c Binary files /dev/null and b/src/assets/ta_servants/239.png differ diff --git a/src/assets/ta_servants/242.png b/src/assets/ta_servants/242.png new file mode 100644 index 0000000..113f1f7 Binary files /dev/null and b/src/assets/ta_servants/242.png differ diff --git a/src/assets/ta_servants/247.png b/src/assets/ta_servants/247.png new file mode 100644 index 0000000..89d41e7 Binary files /dev/null and b/src/assets/ta_servants/247.png differ diff --git a/src/assets/ta_servants/250.png b/src/assets/ta_servants/250.png new file mode 100644 index 0000000..666e89b Binary files /dev/null and b/src/assets/ta_servants/250.png differ diff --git a/src/assets/ta_servants/252.png b/src/assets/ta_servants/252.png new file mode 100644 index 0000000..071bf02 Binary files /dev/null and b/src/assets/ta_servants/252.png differ diff --git a/src/assets/ta_servants/253.png b/src/assets/ta_servants/253.png new file mode 100644 index 0000000..151d00a Binary files /dev/null and b/src/assets/ta_servants/253.png differ diff --git a/src/assets/ta_servants/258.png b/src/assets/ta_servants/258.png new file mode 100644 index 0000000..332f02d Binary files /dev/null and b/src/assets/ta_servants/258.png differ diff --git a/src/assets/ta_servants/259.png b/src/assets/ta_servants/259.png new file mode 100644 index 0000000..f827cb1 Binary files /dev/null and b/src/assets/ta_servants/259.png differ diff --git a/src/assets/ta_servants/261.png b/src/assets/ta_servants/261.png new file mode 100644 index 0000000..e3d7c02 Binary files /dev/null and b/src/assets/ta_servants/261.png differ diff --git a/src/assets/ta_servants/264.png b/src/assets/ta_servants/264.png new file mode 100644 index 0000000..7e57b53 Binary files /dev/null and b/src/assets/ta_servants/264.png differ diff --git a/src/assets/ta_servants/266.png b/src/assets/ta_servants/266.png new file mode 100644 index 0000000..49658c6 Binary files /dev/null and b/src/assets/ta_servants/266.png differ diff --git a/src/assets/ta_servants/268.png b/src/assets/ta_servants/268.png new file mode 100644 index 0000000..1134e1c Binary files /dev/null and b/src/assets/ta_servants/268.png differ diff --git a/src/assets/ta_servants/275.png b/src/assets/ta_servants/275.png new file mode 100644 index 0000000..c83fecd Binary files /dev/null and b/src/assets/ta_servants/275.png differ diff --git a/src/assets/ta_servants/276.png b/src/assets/ta_servants/276.png new file mode 100644 index 0000000..1360f4e Binary files /dev/null and b/src/assets/ta_servants/276.png differ diff --git a/src/assets/ta_servants/277.png b/src/assets/ta_servants/277.png new file mode 100644 index 0000000..353f84b Binary files /dev/null and b/src/assets/ta_servants/277.png differ diff --git a/src/assets/ta_servants/278.png b/src/assets/ta_servants/278.png new file mode 100644 index 0000000..d4ddf90 Binary files /dev/null and b/src/assets/ta_servants/278.png differ diff --git a/src/assets/ta_servants/280.png b/src/assets/ta_servants/280.png new file mode 100644 index 0000000..2fb27b6 Binary files /dev/null and b/src/assets/ta_servants/280.png differ diff --git a/src/assets/ta_servants/281.png b/src/assets/ta_servants/281.png new file mode 100644 index 0000000..d2cb6a1 Binary files /dev/null and b/src/assets/ta_servants/281.png differ diff --git a/src/assets/ta_servants/282.png b/src/assets/ta_servants/282.png new file mode 100644 index 0000000..8414ea7 Binary files /dev/null and b/src/assets/ta_servants/282.png differ diff --git a/src/assets/ta_servants/284.png b/src/assets/ta_servants/284.png new file mode 100644 index 0000000..3961d7c Binary files /dev/null and b/src/assets/ta_servants/284.png differ diff --git a/src/assets/ta_servants/285.png b/src/assets/ta_servants/285.png new file mode 100644 index 0000000..30e11f4 Binary files /dev/null and b/src/assets/ta_servants/285.png differ diff --git a/src/assets/ta_servants/286.png b/src/assets/ta_servants/286.png new file mode 100644 index 0000000..3d95c52 Binary files /dev/null and b/src/assets/ta_servants/286.png differ diff --git a/src/assets/ta_servants/288.png b/src/assets/ta_servants/288.png new file mode 100644 index 0000000..09292ee Binary files /dev/null and b/src/assets/ta_servants/288.png differ diff --git a/src/assets/ta_servants/293.png b/src/assets/ta_servants/293.png new file mode 100644 index 0000000..614c51a Binary files /dev/null and b/src/assets/ta_servants/293.png differ diff --git a/src/assets/ta_servants/295.png b/src/assets/ta_servants/295.png new file mode 100644 index 0000000..3d79402 Binary files /dev/null and b/src/assets/ta_servants/295.png differ diff --git a/src/assets/ta_servants/297.png b/src/assets/ta_servants/297.png new file mode 100644 index 0000000..e66904a Binary files /dev/null and b/src/assets/ta_servants/297.png differ diff --git a/src/assets/ta_servants/299.png b/src/assets/ta_servants/299.png new file mode 100644 index 0000000..93c1e5e Binary files /dev/null and b/src/assets/ta_servants/299.png differ diff --git a/src/assets/ta_servants/3.png b/src/assets/ta_servants/3.png new file mode 100644 index 0000000..8266292 Binary files /dev/null and b/src/assets/ta_servants/3.png differ diff --git a/src/assets/ta_servants/300.png b/src/assets/ta_servants/300.png new file mode 100644 index 0000000..0f767a4 Binary files /dev/null and b/src/assets/ta_servants/300.png differ diff --git a/src/assets/ta_servants/302.png b/src/assets/ta_servants/302.png new file mode 100644 index 0000000..3985532 Binary files /dev/null and b/src/assets/ta_servants/302.png differ diff --git a/src/assets/ta_servants/303.png b/src/assets/ta_servants/303.png new file mode 100644 index 0000000..4731883 Binary files /dev/null and b/src/assets/ta_servants/303.png differ diff --git a/src/assets/ta_servants/305.png b/src/assets/ta_servants/305.png new file mode 100644 index 0000000..5f84cc4 Binary files /dev/null and b/src/assets/ta_servants/305.png differ diff --git a/src/assets/ta_servants/306.png b/src/assets/ta_servants/306.png new file mode 100644 index 0000000..7cd98eb Binary files /dev/null and b/src/assets/ta_servants/306.png differ diff --git a/src/assets/ta_servants/307.png b/src/assets/ta_servants/307.png new file mode 100644 index 0000000..c4efd35 Binary files /dev/null and b/src/assets/ta_servants/307.png differ diff --git a/src/assets/ta_servants/308.png b/src/assets/ta_servants/308.png new file mode 100644 index 0000000..496b05f Binary files /dev/null and b/src/assets/ta_servants/308.png differ diff --git a/src/assets/ta_servants/309.png b/src/assets/ta_servants/309.png new file mode 100644 index 0000000..395635d Binary files /dev/null and b/src/assets/ta_servants/309.png differ diff --git a/src/assets/ta_servants/310.png b/src/assets/ta_servants/310.png new file mode 100644 index 0000000..e37fdd6 Binary files /dev/null and b/src/assets/ta_servants/310.png differ diff --git a/src/assets/ta_servants/311.png b/src/assets/ta_servants/311.png new file mode 100644 index 0000000..7970c11 Binary files /dev/null and b/src/assets/ta_servants/311.png differ diff --git a/src/assets/ta_servants/312_aoe.png b/src/assets/ta_servants/312_aoe.png new file mode 100644 index 0000000..8573acf Binary files /dev/null and b/src/assets/ta_servants/312_aoe.png differ diff --git a/src/assets/ta_servants/312_st.png b/src/assets/ta_servants/312_st.png new file mode 100644 index 0000000..6f8288a Binary files /dev/null and b/src/assets/ta_servants/312_st.png differ diff --git a/src/assets/ta_servants/313.png b/src/assets/ta_servants/313.png new file mode 100644 index 0000000..35dd541 Binary files /dev/null and b/src/assets/ta_servants/313.png differ diff --git a/src/assets/ta_servants/314.png b/src/assets/ta_servants/314.png new file mode 100644 index 0000000..36bfc8f Binary files /dev/null and b/src/assets/ta_servants/314.png differ diff --git a/src/assets/ta_servants/317.png b/src/assets/ta_servants/317.png new file mode 100644 index 0000000..9b44557 Binary files /dev/null and b/src/assets/ta_servants/317.png differ diff --git a/src/assets/ta_servants/319.png b/src/assets/ta_servants/319.png new file mode 100644 index 0000000..df552af Binary files /dev/null and b/src/assets/ta_servants/319.png differ diff --git a/src/assets/ta_servants/320.png b/src/assets/ta_servants/320.png new file mode 100644 index 0000000..429805a Binary files /dev/null and b/src/assets/ta_servants/320.png differ diff --git a/src/assets/ta_servants/321.png b/src/assets/ta_servants/321.png new file mode 100644 index 0000000..6d36914 Binary files /dev/null and b/src/assets/ta_servants/321.png differ diff --git a/src/assets/ta_servants/322.png b/src/assets/ta_servants/322.png new file mode 100644 index 0000000..49fb45d Binary files /dev/null and b/src/assets/ta_servants/322.png differ diff --git a/src/assets/ta_servants/323.png b/src/assets/ta_servants/323.png new file mode 100644 index 0000000..e45c33c Binary files /dev/null and b/src/assets/ta_servants/323.png differ diff --git a/src/assets/ta_servants/325.png b/src/assets/ta_servants/325.png new file mode 100644 index 0000000..d37e003 Binary files /dev/null and b/src/assets/ta_servants/325.png differ diff --git a/src/assets/ta_servants/326.png b/src/assets/ta_servants/326.png new file mode 100644 index 0000000..3c6d279 Binary files /dev/null and b/src/assets/ta_servants/326.png differ diff --git a/src/assets/ta_servants/327.png b/src/assets/ta_servants/327.png new file mode 100644 index 0000000..0cf0df2 Binary files /dev/null and b/src/assets/ta_servants/327.png differ diff --git a/src/assets/ta_servants/329.png b/src/assets/ta_servants/329.png new file mode 100644 index 0000000..c0c86d1 Binary files /dev/null and b/src/assets/ta_servants/329.png differ diff --git a/src/assets/ta_servants/33.png b/src/assets/ta_servants/33.png new file mode 100644 index 0000000..bad7673 Binary files /dev/null and b/src/assets/ta_servants/33.png differ diff --git a/src/assets/ta_servants/331.png b/src/assets/ta_servants/331.png new file mode 100644 index 0000000..6aa244e Binary files /dev/null and b/src/assets/ta_servants/331.png differ diff --git a/src/assets/ta_servants/334.png b/src/assets/ta_servants/334.png new file mode 100644 index 0000000..8e3dc1c Binary files /dev/null and b/src/assets/ta_servants/334.png differ diff --git a/src/assets/ta_servants/336.png b/src/assets/ta_servants/336.png new file mode 100644 index 0000000..b592c59 Binary files /dev/null and b/src/assets/ta_servants/336.png differ diff --git a/src/assets/ta_servants/338.png b/src/assets/ta_servants/338.png new file mode 100644 index 0000000..ffd792a Binary files /dev/null and b/src/assets/ta_servants/338.png differ diff --git a/src/assets/ta_servants/340.png b/src/assets/ta_servants/340.png new file mode 100644 index 0000000..63b9e36 Binary files /dev/null and b/src/assets/ta_servants/340.png differ diff --git a/src/assets/ta_servants/348.png b/src/assets/ta_servants/348.png new file mode 100644 index 0000000..3d1f76f Binary files /dev/null and b/src/assets/ta_servants/348.png differ diff --git a/src/assets/ta_servants/350.png b/src/assets/ta_servants/350.png new file mode 100644 index 0000000..b05ef3a Binary files /dev/null and b/src/assets/ta_servants/350.png differ diff --git a/src/assets/ta_servants/351.png b/src/assets/ta_servants/351.png new file mode 100644 index 0000000..7f5dff2 Binary files /dev/null and b/src/assets/ta_servants/351.png differ diff --git a/src/assets/ta_servants/355.png b/src/assets/ta_servants/355.png new file mode 100644 index 0000000..f46378c Binary files /dev/null and b/src/assets/ta_servants/355.png differ diff --git a/src/assets/ta_servants/357.png b/src/assets/ta_servants/357.png new file mode 100644 index 0000000..2039468 Binary files /dev/null and b/src/assets/ta_servants/357.png differ diff --git a/src/assets/ta_servants/38.png b/src/assets/ta_servants/38.png new file mode 100644 index 0000000..74580cb Binary files /dev/null and b/src/assets/ta_servants/38.png differ diff --git a/src/assets/ta_servants/39.png b/src/assets/ta_servants/39.png new file mode 100644 index 0000000..2a635fe Binary files /dev/null and b/src/assets/ta_servants/39.png differ diff --git a/src/assets/ta_servants/4.png b/src/assets/ta_servants/4.png new file mode 100644 index 0000000..8fc615f Binary files /dev/null and b/src/assets/ta_servants/4.png differ diff --git a/src/assets/ta_servants/41.png b/src/assets/ta_servants/41.png new file mode 100644 index 0000000..2b51d71 Binary files /dev/null and b/src/assets/ta_servants/41.png differ diff --git a/src/assets/ta_servants/5.png b/src/assets/ta_servants/5.png new file mode 100644 index 0000000..4edf94e Binary files /dev/null and b/src/assets/ta_servants/5.png differ diff --git a/src/assets/ta_servants/51.png b/src/assets/ta_servants/51.png new file mode 100644 index 0000000..582b2e6 Binary files /dev/null and b/src/assets/ta_servants/51.png differ diff --git a/src/assets/ta_servants/55.png b/src/assets/ta_servants/55.png new file mode 100644 index 0000000..16e2696 Binary files /dev/null and b/src/assets/ta_servants/55.png differ diff --git a/src/assets/ta_servants/58.png b/src/assets/ta_servants/58.png new file mode 100644 index 0000000..e68596c Binary files /dev/null and b/src/assets/ta_servants/58.png differ diff --git a/src/assets/ta_servants/6.png b/src/assets/ta_servants/6.png new file mode 100644 index 0000000..53ec41c Binary files /dev/null and b/src/assets/ta_servants/6.png differ diff --git a/src/assets/ta_servants/62.png b/src/assets/ta_servants/62.png new file mode 100644 index 0000000..9f3b112 Binary files /dev/null and b/src/assets/ta_servants/62.png differ diff --git a/src/assets/ta_servants/65.png b/src/assets/ta_servants/65.png new file mode 100644 index 0000000..dd64533 Binary files /dev/null and b/src/assets/ta_servants/65.png differ diff --git a/src/assets/ta_servants/68.png b/src/assets/ta_servants/68.png new file mode 100644 index 0000000..a3af138 Binary files /dev/null and b/src/assets/ta_servants/68.png differ diff --git a/src/assets/ta_servants/70.png b/src/assets/ta_servants/70.png new file mode 100644 index 0000000..9485dd9 Binary files /dev/null and b/src/assets/ta_servants/70.png differ diff --git a/src/assets/ta_servants/70_bunny.png b/src/assets/ta_servants/70_bunny.png new file mode 100644 index 0000000..bc196ed Binary files /dev/null and b/src/assets/ta_servants/70_bunny.png differ diff --git a/src/assets/ta_servants/8.png b/src/assets/ta_servants/8.png new file mode 100644 index 0000000..a9295f5 Binary files /dev/null and b/src/assets/ta_servants/8.png differ diff --git a/src/assets/ta_servants/81.png b/src/assets/ta_servants/81.png new file mode 100644 index 0000000..6af150a Binary files /dev/null and b/src/assets/ta_servants/81.png differ diff --git a/src/assets/ta_servants/85.png b/src/assets/ta_servants/85.png new file mode 100644 index 0000000..f221c05 Binary files /dev/null and b/src/assets/ta_servants/85.png differ diff --git a/src/assets/ta_servants/86.png b/src/assets/ta_servants/86.png new file mode 100644 index 0000000..59891e3 Binary files /dev/null and b/src/assets/ta_servants/86.png differ diff --git a/src/assets/ta_servants/88.png b/src/assets/ta_servants/88.png new file mode 100644 index 0000000..73bedac Binary files /dev/null and b/src/assets/ta_servants/88.png differ diff --git a/src/assets/ta_servants/90.png b/src/assets/ta_servants/90.png new file mode 100644 index 0000000..79e8c3d Binary files /dev/null and b/src/assets/ta_servants/90.png differ diff --git a/src/assets/ta_servants/93.png b/src/assets/ta_servants/93.png new file mode 100644 index 0000000..684b0c3 Binary files /dev/null and b/src/assets/ta_servants/93.png differ diff --git a/src/assets/ta_servants/96.png b/src/assets/ta_servants/96.png new file mode 100644 index 0000000..66a42a0 Binary files /dev/null and b/src/assets/ta_servants/96.png differ diff --git a/src/assets/ta_servants/98.png b/src/assets/ta_servants/98.png new file mode 100644 index 0000000..7b5572f Binary files /dev/null and b/src/assets/ta_servants/98.png differ diff --git a/src/components/Card.astro b/src/components/Card.astro deleted file mode 100644 index a1e0ccf..0000000 --- a/src/components/Card.astro +++ /dev/null @@ -1,63 +0,0 @@ ---- -interface Props { - title: string; - body: string; - href: string; -} - -const { href, title, body } = Astro.props; ---- - -<li class="link-card"> - <a href={href}> - <h2> - {title} - <span>→</span> - </h2> - <p> - {body} - </p> - </a> -</li> -<style> - .link-card { - list-style: none; - display: flex; - padding: 0.25rem; - background-color: white; - background-image: none; - background-size: 400%; - border-radius: 0.6rem; - background-position: 100%; - transition: background-position 0.6s cubic-bezier(0.22, 1, 0.36, 1); - box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -2px rgba(0, 0, 0, 0.1); - } - - .link-card > a { - width: 100%; - text-decoration: none; - line-height: 1.4; - padding: 1rem 1.3rem; - border-radius: 0.35rem; - color: #111; - background-color: white; - opacity: 0.8; - } - h2 { - margin: 0; - font-size: 1.25rem; - transition: color 0.6s cubic-bezier(0.22, 1, 0.36, 1); - } - p { - margin-top: 0.5rem; - margin-bottom: 0; - color: #444; - } - .link-card:is(:hover, :focus-within) { - background-position: 0; - background-image: var(--accent-gradient); - } - .link-card:is(:hover, :focus-within) h2 { - color: rgb(var(--accent)); - } -</style> diff --git a/src/components/genericHero.astro b/src/components/genericHero.astro new file mode 100644 index 0000000..190949f --- /dev/null +++ b/src/components/genericHero.astro @@ -0,0 +1,32 @@ +--- +export interface Props { + text: string +} +const { text } = Astro.props +--- + +<div> + {text} +</div> + +<style> + div { + display: flex; + width: 100%; + max-height: auto; + background-color: var(--c-duskgray); + text-align: center; + justify-content: center; + color: white; + font-size: 2.75rem; + letter-spacing: 0.075em; + padding: 2rem 0rem; + font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif; + font-weight: bolder; + } + @media (min-width: 900px) { + div { + font-size: 4.5rem; + } + } +</style> diff --git a/src/components/hero.astro b/src/components/hero.astro index 7b8ff45..e81458a 100644 --- a/src/components/hero.astro +++ b/src/components/hero.astro @@ -1,34 +1,62 @@ --- +import packagejson from '../../package.json' +export interface Props { + fadeout?: boolean +} +const { fadeout } = Astro.props +const display = fadeout ? "": "display: none" + +const version = packagejson.version +const release = `https://forgejo.neshweb.net/Firq/fgo-ta-com-website/releases/tag/${version}` --- <div> <span> - This site is a WIP project by Firq. + This site is a project by Firq. <br /> - In the future, it will be used to catalogue information around FGO TA and the - game in general. + <a href="https://firq.dev" target="_blank" rel="noopener noreferrer" + >Feel free to check out my personal site.</a + > <br /> - <a href="https://firq.dev" target="_blank" rel="noopener noreferrer">Feel free to check out my own site.</a> + <span class="version" + >Website version: <a + href={release} + target="_blank" + rel="noopener noreferrer">{version}</a + ></span + > </span> - <slot /> + <div class="fade" style={display}></div> </div> <style> div { display: flex; width: 100%; - height: 5em; - background-color: var(--c-gray); + flex-wrap: nowrap; + flex-flow: column; + background-color: var(--c-darkergray); text-align: center; align-items: center; justify-content: center; color: white; font-size: 1.5em; - padding: 2rem 0rem; - margin-top: 7.5rem; + padding: 2rem 0rem 0rem 0rem; } a { text-align: center; text-decoration: none; + color: var(--c-darkpurple); + } + + .fade { + margin-top: 3rem; + background: linear-gradient(to bottom, transparent, var(--c-lightgray)); + height: 2.5rem; + width: 100%; + } + + .version { + font-size: 0.65em; } </style> diff --git a/src/components/listings/eventListingLine.astro b/src/components/listings/eventListingLine.astro new file mode 100644 index 0000000..a538be4 --- /dev/null +++ b/src/components/listings/eventListingLine.astro @@ -0,0 +1,121 @@ +--- +export interface Props { + title: string + releaseDate: Date + shortdescription: string + link: string, + hlcolor: string, +} + +const options_date: Intl.DateTimeFormatOptions = { + year: 'numeric', + month: 'long', + day: '2-digit', +} + +const { releaseDate, title, link, hlcolor } = Astro.props +const render_date = releaseDate.toLocaleDateString('en-GB', options_date) +--- + +<a href={link} target="_blank" rel="noopener noreferrer"> + <div class="circle"></div> + <article> + <h2>{title}</h2> + <h3>{render_date}</h3> + <!-- <p>{shortdescription}</p> --> + </article> +</a> + +<style define:vars={{ hlcolor }}> + .circle { + display: none; + } + + a { + align-items: center; + justify-content: center; + display: flex; + text-decoration: none; + height: fit-content; + margin: 0px 0.5rem; + width: 100%; + } + p { + color: white; + text-align: left; + font-size: 1em; + margin: 0px 0.5em; + } + article > h2 { + margin: 0px 0.5rem; + color: var(--hlcolor); + font-size: 1.2rem; + line-height: normal; + text-decoration: none; + } + article > h3 { + margin: 0px 0.5rem; + color: white; + font-size: 1rem; + line-height: normal; + text-decoration: none; + } + article { + display: flex; + flex: 1; + flex-wrap: wrap; + flex-direction: column; + align-items: center; + align-content: center; + justify-content: center; + background: var(--c-duskgray); /* linear-gradient(175deg, var(--c-duskgray), var(--c-duskgray), var(--c-duskgray), var(--hlcolor)); */ + padding: 10px; + text-align: center; + transition: transform var(--speed) var(--ease); + min-height: 100%; + border-radius: 1.25rem; + border-style: solid; + border-width: 2px; + border-color: var(--c-darkergray); + } + + a:hover > article { + transform: scaleY(102.5%) scaleX(101%); + transition: transform var(--speed) var(--ease); + } + + @media (min-width: 900px) { + .circle { + margin: 1rem 0.5rem 1rem 0.5rem; + position: relative; + display: flex; + visibility: visible; + height: 1rem; + width: 1rem; + background-color: var(--c-darkpurple); + border-style: solid; + border-width: 0.25rem; + border-color: var(--c-lightgray); + border-radius: 40%; + transition: transform var(--speed) var(--ease); + } + + a:hover > .circle { + height: 1.25rem; + width: 1.25rem; + translate: -0.125rem; + margin-right: 4px; + } + + a:hover article { + border-color: var(--hlcolor); + transform: none; + } + + article { + align-items: flex-start; + align-content: flex-start; + margin-left: 0.5rem; + } + } +</style> diff --git a/src/components/listings/questListingCard.astro b/src/components/listings/questListingCard.astro new file mode 100644 index 0000000..b31f660 --- /dev/null +++ b/src/components/listings/questListingCard.astro @@ -0,0 +1,149 @@ +--- +export interface Props { + baseurl: string + slug: string + title: string + releaseDate: Date + shortdescription: string +} + +const options_date: Intl.DateTimeFormatOptions = { + year: 'numeric', + month: 'long', + day: '2-digit', +} + +const { shortdescription, releaseDate, slug, title, baseurl } = Astro.props +const url = `/${baseurl}/${slug}` +const render_date = releaseDate.toLocaleDateString( + 'en-GB', + options_date +) +--- + +<a href={url} rel="noopener noreferrer"> + <div class="circle"></div> + <article> + <h2>{title}</h2> + <h3>{render_date}</h3> + <p>{shortdescription}</p> + </article> +</a> + +<style> + .circle { + display: none; + } + + a { + align-items: center; + justify-content: center; + display: flex; + text-decoration: none; + height: auto; + margin: 0.5rem; + width: 100%; + } + p { + color: white; + text-align: left; + font-size: 1.1em; + margin: 0.5em; + } + article > h2 { + margin: 0.3rem 0.5rem; + color: var(--c-darkpurple); + font-size: 1.5rem; + line-height: normal; + text-decoration: none; + } + article > h3 { + margin: 0.2em 0.5rem; + color: white; + font-size: 1rem; + line-height: normal; + text-decoration: none; + } + article { + display: flex; + flex: 1; + flex-wrap: wrap; + flex-direction: column; + align-items: center; + align-content: center; + justify-content: center; + background-color: var(--c-darkergray); + padding: 10px; + text-align: center; + transition: transform var(--speed) var(--ease); + min-height: 100%; + border-radius: 1.25rem; + } + + a:hover > article { + transform: scaleY(102.5%) scaleX(101%); + transition: transform var(--speed) var(--ease); + } + + @media (min-width: 900px) { + .circle { + margin: 1rem 0.5rem 1rem 0.5rem; + position: relative; + display: flex; + visibility: visible; + height: 1.5rem; + width: 1.5rem; + border-radius: 40%; + background-color: var(--c-darkpurple); + transition: transform var(--speed) var(--ease); + } + + a:hover > .circle { + height: 1.75rem; + width: 1.75rem; + translate: -0.125rem; + margin-right: 0.825rem; + } + + a:hover article { + border-color: var(--c-darkpurple); + } + + article { + border-style: solid; + border-width: 2px; + border-color: var(--c-darkergray); + align-items: flex-start; + align-content: flex-start; + margin-left: 0.5rem; + } + } + + @media (min-width: 1500px) { + .circle { + display: none; + } + + article { + margin: unset; + flex-wrap: nowrap; + min-height: 12rem; + align-items: center; + justify-content: flex-start; + } + + a { + width: 30.5%; + align-items: unset; + } + + p { + text-align: justify; + padding: 0rem 0.5rem; + } + + h2 { + text-align: center; + } + } +</style> diff --git a/src/components/listings/questListingLine.astro b/src/components/listings/questListingLine.astro new file mode 100644 index 0000000..6bd5775 --- /dev/null +++ b/src/components/listings/questListingLine.astro @@ -0,0 +1,125 @@ +--- +export interface Props { + baseurl: string + slug: string + title: string + releaseDate: Date + shortdescription: string +} + +const options_date: Intl.DateTimeFormatOptions = { + year: 'numeric', + month: 'long', + day: '2-digit', +} + +const { shortdescription, releaseDate, slug, title, baseurl } = Astro.props +const url = `/${baseurl}/${slug}` +const render_date = releaseDate.toLocaleDateString( + 'en-GB', + options_date +) +--- + +<a href={url} rel="noopener noreferrer"> + <div class="circle"></div> + <article> + <h2>{title}</h2> + <h3>{render_date}</h3> + <p>{shortdescription}</p> + </article> +</a> + +<style> + .circle { + display: none; + } + + a { + align-items: center; + justify-content: center; + display: flex; + text-decoration: none; + height: fit-content; + margin: 0px 0.5rem; + width: 100%; + } + p { + color: white; + text-align: left; + font-size: 1.1em; + margin: 0.5em; + } + article > h2 { + margin: 0.3rem 0.5rem; + color: var(--c-darkpurple); + font-size: 1.5rem; + line-height: normal; + text-decoration: none; + } + article > h3 { + margin: 0.2em 0.5rem; + color: white; + font-size: 1rem; + line-height: normal; + text-decoration: none; + } + article { + display: flex; + flex: 1; + flex-wrap: wrap; + flex-direction: column; + align-items: center; + align-content: center; + justify-content: center; + background-color: var(--c-darkergray); + padding: 10px; + text-align: center; + transition: transform var(--speed) var(--ease); + min-height: 100%; + border-radius: 1.25rem; + } + + a:hover > article { + transform: scaleY(102.5%) scaleX(101%); + transition: transform var(--speed) var(--ease); + } + + @media (min-width: 900px) { + .circle { + margin: 1rem 0.5rem 1rem 0.5rem; + position: relative; + display: flex; + visibility: visible; + height: 1rem; + width: 1rem; + background-color: var(--c-darkpurple); + border-style: solid; + border-width: 0.25rem; + border-color: var(--c-lightgray); + border-radius: 40%; + transition: transform var(--speed) var(--ease); + } + + a:hover > .circle { + height: 1.25rem; + width: 1.25rem; + translate: -0.125rem; + margin-right: 4px; + } + + a:hover article { + border-color: var(--c-darkpurple); + transform: none; + } + + article { + border-style: solid; + border-width: 2px; + border-color: var(--c-darkergray); + align-items: flex-start; + align-content: flex-start; + margin-left: 0.5rem; + } + } +</style> diff --git a/src/components/navbar.astro b/src/components/navbar.astro index bed56e2..5838c8f 100644 --- a/src/components/navbar.astro +++ b/src/components/navbar.astro @@ -1,36 +1,48 @@ --- +import { Image } from 'astro:assets' +import logo from '../assets/logo.svg' +import hamburger from 'iconoir/icons/menu.svg' +const hamburger_src_url = `url("${hamburger.src}")` --- <header> - <a href="/" rel="noopener noreferrer" aria-label="Home"> - <img src="/assets/logo.svg" alt="" /> + <a href="/" rel="noopener noreferrer" aria-label="Home" role="button"> + <Image src={logo} alt="" loading="eager"/> + <span class="visually-hidden">Logo</span> </a> <ul class="desktop"> - <slot /> + <slot name="desktop" /> </ul> - <button class="mobile" aria-label="Navigation Button" tabindex="0" onclick="this.focus()"> + <button + class="mobile" + aria-label="Navigation Button" + tabindex="0" + onclick="this.focus()" + role="button" + > <ul> - <slot /> + <slot name="mobile" /> </ul> <div class="placeholder"></div> - <i class="iconoir-menu"></i> + <div class="hamburger-menu" role="navigation"></div> </button> </header> -<style> +<style define:vars={{ hamburger_src_url }}> header { z-index: 1000; position: sticky; top: 0px; - background-color: var(--c-darkgray); + background-color: var(--c-darkergray); display: flex; height: auto; width: 100%; align-items: flex-start; line-height: 1.5em; + border-bottom: 2px solid var(--c-darkpurple) ; } header > a { - padding-left: 16px; + margin-left: 16px; padding-top: 8px; display: block; height: 48px; @@ -56,7 +68,7 @@ line-height: 1.5em; } .mobile > ul { - background-color: var(--c-darkgray); + background-color: var(--c-darkergray); align-items: center; flex-wrap: wrap; flex-direction: column; @@ -73,22 +85,12 @@ .mobile { display: flex; - background-color: var(--c-darkgray); + background-color: var(--c-darkergray); border: 0px; width: 100%; height: 64px; } - .mobile > i { - position: static; - color: white; - font-weight: bold; - font-size: 2em; - align-self: flex-start; - padding-right: 1em; - padding-top: 1.15rem; - } - .mobile > ul { display: none; padding: 0px; @@ -111,6 +113,18 @@ justify-self: top; } + .hamburger-menu { + mask: var(--hamburger_src_url) no-repeat center; + mask-size: cover; + background-color: white; + width: 2.25rem; + height: 2.25rem; + position: static; + align-self: flex-start; + margin-right: 1rem; + margin-top: 0.825rem; + } + @media (min-width: 1140px) { .mobile { display: none; diff --git a/src/components/navbarEntry.astro b/src/components/navbarEntry.astro index 6da80f4..a3ee4d6 100644 --- a/src/components/navbarEntry.astro +++ b/src/components/navbarEntry.astro @@ -1,12 +1,13 @@ --- export interface Props { currentPage?: string + navtype: 'mobile' | 'desktop' link: string text: string - icon: string + icon: ImageMetadata } -const { icon, text, link, currentPage } = Astro.props +const { icon, text, link, navtype, currentPage } = Astro.props let currPage = '' const slug = link.replace(new RegExp('/', 'g'), '') @@ -17,7 +18,10 @@ if (currentPage === slug) { currPage = 'current' } +const icon_src_url = `url("${icon.src}")` const fulllink = `/${slug}` + +let extraattributes = navtype === 'mobile' ? { tabindex: '0' } : {} --- <li> @@ -26,14 +30,15 @@ const fulllink = `/${slug}` rel="noopener noreferrer" aria-label={text} class={currPage} - tabindex="0" + role="button" + {...extraattributes} > - <i class={icon}></i> + <div class="icon"></div> {text} </a> </li> -<style> +<style define:vars={{ icon_src_url }}> li { align-items: center; justify-content: center; @@ -41,7 +46,9 @@ const fulllink = `/${slug}` display: flex; width: 200px; } + li > a { + display: inline-flex; color: white; text-decoration: none; justify-content: center; @@ -49,11 +56,29 @@ const fulllink = `/${slug}` font-size: 1.4em; height: 100%; font-weight: bold; + gap: 0.2em; } + li > a:hover { - color: var(--c-purplepink); + color: var(--c-purplepink) !important; } + + li > a:hover > .icon { + background-color: var(--c-purplepink) !important; + } + .current { - color: var(--c-darkpurple); + color: var(--c-darkpurple) !important; + } + + .current > .icon { + background-color: var(--c-darkpurple) !important; + } + + .icon { + mask: var(--icon_src_url) no-repeat center; + background-color: white; + width: 1.4em; + height: 1.4em; } </style> diff --git a/src/components/smallTitle.astro b/src/components/smallTitle.astro new file mode 100644 index 0000000..d214f84 --- /dev/null +++ b/src/components/smallTitle.astro @@ -0,0 +1,118 @@ +--- +import '@fontsource/work-sans/800.css' +import '@fontsource/work-sans/600.css' +export interface Props { + maintext: string + subtext: string + fadeout?: boolean + baseurl?: string + returnbutton?: boolean +} +const { maintext, subtext, fadeout, baseurl, returnbutton } = Astro.props +const displayFadeout = fadeout ? "": "display: none" +const displayBackButton = returnbutton ? "": "display: none" + +let text +if (baseurl) { + text = baseurl?.split("/").pop() + text = text?.replace("-", " ").replace("-", ".") + text = text?.includes('eq 20') ? text?.replace("eq", "EQ") : text +} + +--- + +<div class="wrap"> + <div class="head">{maintext}</div> + <div class="sub">{subtext}</div> + <a href=`/${baseurl}` style={displayBackButton}><< Back to {text}</a> + <div class="fade" style={displayFadeout}></div> +</div> + +<style> + a { + font-weight: 600; + font-family: 'Work Sans', 'Helvetica Neue', Helvetica, Helvetica, Arial, sans-serif; + color: white; + margin: 1rem 0px 0px; + padding: 0.5rem 0.75rem; + text-decoration: none; + background-color: var(--c-lightgray); + border-radius: 10px; + border-style: solid; + border-width: 2px; + border-color: var(--c-lightgray); + text-transform: capitalize; + } + + a:hover { + border-color: var(--c-darkpurple); + } + + .wrap { + position: relative; + width: 100%; + display: flex; + text-align: center; + align-items: center; + flex-wrap: wrap; + flex-direction: column; + color: var(--c-lighter); + background-color: var(--c-darkergray); + } + + .fade { + margin-top: 2rem; + background: linear-gradient(to bottom, transparent, var(--c-lightgray)); + height: 2.5rem; + width: 100%; + } + + .head { + hyphens: auto; + padding-top: 2rem; + font-size: 3rem; + font-weight: 800; + font-family: 'Work Sans', 'Helvetica Neue', Helvetica, Helvetica, Arial, + sans-serif; + } + + .sub { + padding-left: 0.5rem; + padding-right: 0.5rem; + font-size: 1rem; + font-weight: 600; + font-family: 'Work Sans', 'Helvetica Neue', Helvetica, Helvetica, Arial, + sans-serif; + } + + .head { + color: var(--c-darkpurple); + } + + @supports (background-clip: text) { + .head { + background: linear-gradient(125deg, var(--c-darkpurple), var(--c-purplepink), var(--c-reddish) ); + background-clip: text; + color: transparent; + } + } + + @media (min-width: 620px) { + .head { + hyphens: none; + font-size: 4rem; + } + .sub { + font-size: 1rem; + } + } + + @media (min-width: 1000px) { + .head { + font-size: 6rem; + } + .sub { + font-size: 1rem; + } + } +</style> diff --git a/src/components/taCard.astro b/src/components/taCard.astro new file mode 100644 index 0000000..0c31bac --- /dev/null +++ b/src/components/taCard.astro @@ -0,0 +1,260 @@ +--- +import { Image } from 'astro:assets' +import { plsLoadImage } from '../utils/tools' +import type { GlobImage } from '../types/generic' +export interface Props { + title: string + link: string + date: Date + servant: string + turns: string + runner: string +} + +const { turns, runner, date, servant, link, title } = Astro.props + +const options_date: Intl.DateTimeFormatOptions = { + year: 'numeric', + month: '2-digit', + day: '2-digit', +} + +const servantImagePath = `/src/assets/ta_servants/${servant}.png` +const servant_images = import.meta.glob<GlobImage>( + '/src/assets/ta_servants/*.png' +) +const loaded_image = plsLoadImage(servant_images, servantImagePath) + +const formatted_date = date.toLocaleDateString('de-DE', options_date) +const arialabel = `By ${runner} β’ ${formatted_date} ${turns}` +--- + +<a href={link} target="_blank" rel="noopener noreferrer" aria-label={arialabel}> + <article> + <Image src={loaded_image} alt="" class="icon" /> + <div class="title desktop"> + <h2>{title}</h2> + </div> + <p class="desktop"> + <span> + By {runner}<br /> β’ <br /> + {formatted_date} + </span> + </p> + <div class="mobile"> + <h2>{title}</h2> + <span> + β’<br />By {runner}<br />{formatted_date} + </span> + </div> + <div class="expand-on-hover"> + <h2>{turns}</h2> + </div> + </article> +</a> + +<style> + div { + display: none; + } + + span { + display: flex; + } + + a { + text-decoration: none; + } + + .mobile { + width: 12rem; + height: 8rem; + padding: unset; + margin: unset; + display: flex; + flex-flow: column; + color: white; + align-items: center; + padding-left: 0.75rem; + justify-content: center; + } + + .mobile > h2 { + margin: 0%; + font-size: 1.25rem; + text-align: center; + } + + .mobile span { + font-size: 1.05rem; + font-weight: bold; + } + + article { + background-color: var(--c-darkergray); + border-color: var(--c-darkgray); + padding: 1rem 1.5rem; + text-align: center; + transition: transform var(--speed) var(--ease); + height: auto; + max-width: 100%; + border-radius: 1.25rem; + --size-value: 7rem; + display: flex; + align-items: center; + justify-content: space-around; + } + + @media (max-width: 1139px) { + .desktop { + border: 0; + clip: rect(0 0 0 0); + height: 1px; + margin: -1px; + overflow: hidden; + padding: 0; + position: absolute; + width: 1px; + } + } + + @media (min-width: 625px) { + article { + width: 15rem; + justify-content: center; + padding: 1rem; + } + + a { + width: unset; + } + + .mobile > h2 { + font-size: 1.05rem; + } + + .mobile span { + font-size: 0.9rem; + } + } + + @media (min-width: 1140px) { + .mobile { + display: none; + } + + article { + max-width: 8rem; + flex-direction: column; + padding-bottom: 1.5rem; + } + + .expand-on-hover { + display: flex; + flex-direction: row; + flex-wrap: wrap; + align-items: center; + justify-content: space-evenly; + background-color: var(--c-duskgray); + z-index: 99; + transform: scaleY(0); + transform-origin: top; + position: absolute; + top: 90%; + left: 0px; + right: 0px; + color: white; + border-radius: 0px 0px 1.25rem 1.25rem; + } + + article > .icon { + margin: 0.5rem; + } + } + + .desktop span { + align-items: center; + height: 3.75rem; + } + article:hover { + transform: scale(var(--hover-scale)); + } + + article > .icon { + border-radius: 1.25rem; + width: var(--size-value); + height: var(--size-value); + } + + article:hover .title { + display: flex; + position: absolute; + align-items: center; + justify-content: center; + text-align: center; + background-color: var(--c-darkgray); + height: calc(var(--size-value) + 0.1rem); + width: calc(var(--size-value) + 0.1rem); + opacity: 90%; + border-radius: 1.25rem; + top: 1.45em; + } + + article:hover .title h2 { + margin: 0; + display: inline-flex; + font-weight: bold; + color: white; + font-size: 18px; + line-height: 150%; + padding: 0.5rem; + } + + article .title h2 { + display: none; + } + + article .title { + display: none; + } + + .icon { + display: flex; + justify-content: center; + align-items: center; + } + + p { + display: flex; + text-align: center; + justify-content: center; + align-items: center; + line-height: 100%; + text-decoration: none; + color: white; + font-size: 1rem; + font-weight: bold; + padding-top: 0.5rem; + margin: 0.5rem 0px; + flex-wrap: wrap; + flex-direction: column; + } + + .expand-on-hover img { + width: 3rem; + height: 3rem; + margin-top: 0.5rem; + margin-bottom: 0.5rem; + border-radius: 0.5rem; + } + + .expand-on-hover h2 { + margin: 0.5rem; + } + + article:hover .expand-on-hover { + transform: scaleY(1); + transition: transform 200ms ease-in-out; + background-color: var(--c-duskgray); + } +</style> diff --git a/src/components/title.astro b/src/components/title.astro new file mode 100644 index 0000000..abf6197 --- /dev/null +++ b/src/components/title.astro @@ -0,0 +1,86 @@ +--- +import '@fontsource/work-sans/800.css' +export interface Props { + maintext: string + subtext: string + fadeout?: boolean +} +const { maintext, subtext, fadeout } = Astro.props +const display = fadeout ? "": "display: none" +--- + +<div class="wrap"> + <div class="head">{maintext}</div> + <div class="sub">{subtext}</div> + <div class="fade" style={display}></div> +</div> + +<style> + .wrap { + position: relative; + width: 100%; + display: flex; + text-align: center; + align-items: center; + flex-wrap: wrap; + flex-direction: column; + color: var(--c-lighter); + background-color: var(--c-darkergray); + } + + .fade { + margin-top: 2rem; + background: linear-gradient(to bottom, transparent, var(--c-lightgray)); + height: 2.5rem; + width: 100%; + } + + .head { + hyphens: auto; + padding-top: 2rem; + font-size: 4rem; + font-weight: 800; + font-family: 'Work Sans', 'Helvetica Neue', Helvetica, Helvetica, Arial, + sans-serif; + } + + .sub { + padding-left: 0.5rem; + padding-right: 0.5rem; + font-size: 1.5rem; + font-weight: 800; + font-family: 'Work Sans', 'Helvetica Neue', Helvetica, Helvetica, Arial, + sans-serif; + } + + .head { + color: var(--c-darkpurple); + } + + @supports (background-clip: text) { + .head { + background: linear-gradient(125deg, var(--c-darkpurple), var(--c-purplepink), var(--c-reddish) ); + background-clip: text; + color: transparent; + } + } + + @media (min-width: 620px) { + .head { + hyphens: none; + font-size: 6rem; + } + .sub { + font-size: 1.5rem; + } + } + + @media (min-width: 1000px) { + .head { + font-size: 8rem; + } + .sub { + font-size: 2rem; + } + } +</style> diff --git a/src/content/.template.json b/src/content/.template.json new file mode 100644 index 0000000..0c724d3 --- /dev/null +++ b/src/content/.template.json @@ -0,0 +1,24 @@ +{ + "info": { + "title": "", + "releaseDate": "YYYY-MM-DD", + "shortdescription": "", + "releaseNumber": 1 + }, + "quests": [ + { + "questTitle": "", + "description": "", + "data": [ + { + "title": "Skadi 3T", + "link": "", + "date": "YYYY-MM-DD", + "servant": "skadi", + "turns": "3T", + "runner": "Firq" + } + ] + } + ] +} diff --git a/src/content/changes/appends-120.json b/src/content/changes/appends-120.json new file mode 100644 index 0000000..0baa342 --- /dev/null +++ b/src/content/changes/appends-120.json @@ -0,0 +1,12 @@ +{ + "$schema": "../../../.astro/collections/changes.schema.json", + "info": { + "title": "Appends and Level 120", + "releaseDate": "2022-05-23", + "shortdescription": "Release of Append Skills and increased level cap of 120 with the Servant Coins Update", + "releaseNumber": 1, + "type": "event" + }, + "link": "https://fategrandorder.fandom.com/wiki/FGO_Summer_2021_Event_Revival_(US)#Game_Updates", + "color": "#d4af37" +} diff --git a/src/content/changes/castoria.json b/src/content/changes/castoria.json new file mode 100644 index 0000000..f5a6402 --- /dev/null +++ b/src/content/changes/castoria.json @@ -0,0 +1,12 @@ +{ + "$schema": "../../../.astro/collections/changes.schema.json", + "info": { + "title": "Castoria", + "releaseDate": "2022-07-04", + "shortdescription": "Release of Castoria during the 5rd Anniversary of the game", + "releaseNumber": 1, + "type": "event" + }, + "link": "https://apps.atlasacademy.io/db/NA/servant/284/", + "color": "#0b67fb" +} diff --git a/src/content/changes/koyan.json b/src/content/changes/koyan.json new file mode 100644 index 0000000..239598c --- /dev/null +++ b/src/content/changes/koyan.json @@ -0,0 +1,12 @@ +{ + "$schema": "../../../.astro/collections/changes.schema.json", + "info": { + "title": "Koyanskaya of Light", + "releaseDate": "2023-07-03", + "shortdescription": "Release of Koyanskaya of Light during the 6th Anniversary of the game", + "releaseNumber": 1, + "type": "event" + }, + "link": "https://apps.atlasacademy.io/db/NA/servant/314/", + "color": "#f7281f" +} diff --git a/src/content/changes/oberon.json b/src/content/changes/oberon.json new file mode 100644 index 0000000..725dbbb --- /dev/null +++ b/src/content/changes/oberon.json @@ -0,0 +1,12 @@ +{ + "$schema": "../../../.astro/collections/changes.schema.json", + "info": { + "title": "Oberon", + "releaseDate": "2023-07-10", + "shortdescription": "Release of Oberon during the Lostbelt 6 Conclusion Campaign", + "releaseNumber": 1, + "type": "event" + }, + "link": "https://apps.atlasacademy.io/db/NA/servant/316/", + "color": "#f7281f" +} diff --git a/src/content/changes/skadi.json b/src/content/changes/skadi.json new file mode 100644 index 0000000..19575cd --- /dev/null +++ b/src/content/changes/skadi.json @@ -0,0 +1,12 @@ +{ + "$schema": "../../../.astro/collections/changes.schema.json", + "info": { + "title": "Scathach-Skadi", + "releaseDate": "2020-07-06", + "shortdescription": "Release of Scathach-Skadi during the 3rd Anniversary of the game", + "releaseNumber": 1, + "type": "event" + }, + "link": "https://apps.atlasacademy.io/db/NA/servant/215/", + "color": "#0eb31d" +} diff --git a/src/content/changes/summer-skadi.json b/src/content/changes/summer-skadi.json new file mode 100644 index 0000000..e6ac541 --- /dev/null +++ b/src/content/changes/summer-skadi.json @@ -0,0 +1,12 @@ +{ + "$schema": "../../../.astro/collections/changes.schema.json", + "info": { + "title": "Scathach-Skadi (Ruler)", + "releaseDate": "2024-07-24", + "shortdescription": "Release of Scathach-Skadi (Ruler) during the Arctic Summer World Event", + "releaseNumber": 1, + "type": "event" + }, + "link": "https://apps.atlasacademy.io/db/NA/servant/357/", + "color": "#0eb31d" +} diff --git a/src/content/config.ts b/src/content/config.ts new file mode 100644 index 0000000..14ecdfb --- /dev/null +++ b/src/content/config.ts @@ -0,0 +1,58 @@ +import { z, defineCollection } from 'astro:content' + +// Individual TA entries +const entry = z.object({ + title: z.string(), + link: z.string().url(), + date: z.string().transform((str) => new Date(str)), + servant: z.string(), + turns: z.string(), + runner: z.string(), +}) + +// Individual quest info block +const quest = z.object({ + questTitle: z.string(), + description: z.string(), + data: z.array(entry), +}) + +// Basic info block for page +const info = z.object({ + title: z.string(), + releaseDate: z.string().transform((str) => new Date(str)), + shortdescription: z.string(), + releaseNumber: z.number().default(1), + type: z.enum(["quest", "event", "group"]).default("quest") +}) + +// Combined ta data collection schema +const taData = defineCollection({ + type: 'data', + schema: z.object({ + info: info, + quests: z.array(quest), + }), +}) + +const groupDescription = defineCollection({ + type: 'data', + schema: z.object({ info: info }), +}) + +const changes = defineCollection({ + type: 'data', + schema: z.object({ + info: info, + link: z.string().url(), + color: z.string(), + }), +}) + +export const collections = { + taInfoData: taData, + teslafest: taData, + groups: groupDescription, + teslafestgroups: groupDescription, + changes: changes, +} diff --git a/src/content/groups/lostbelt-6-5.json b/src/content/groups/lostbelt-6-5.json new file mode 100644 index 0000000..c291d45 --- /dev/null +++ b/src/content/groups/lostbelt-6-5.json @@ -0,0 +1,11 @@ +{ + "$schema": "../../../.astro/collections/groups.schema.json", + "info": { + "title": "Lostbelt 6.5 - Traum", + "releaseDate": "2024-05-13", + "shortdescription": "An Interlude of sorts that brings some new challenging content centered around a nation build of servants", + "releaseNumber": 1, + "type": "group" + } + } + \ No newline at end of file diff --git a/src/content/groups/lostbelt-6.json b/src/content/groups/lostbelt-6.json new file mode 100644 index 0000000..b1a6047 --- /dev/null +++ b/src/content/groups/lostbelt-6.json @@ -0,0 +1,10 @@ +{ + "$schema": "../../../.astro/collections/groups.schema.json", + "info": { + "title": "Lostbelt 6 - Avalon le Fae", + "releaseDate": "2023-06-06", + "shortdescription": "The 6th Lostbelt, the journey into the Fairy Kingdom of Queen Morgan - do you have what it takes for some of the most difficult content of this game?", + "releaseNumber": 1, + "type": "group" + } +} diff --git a/src/content/taInfoData/arctic-summer-world.json b/src/content/taInfoData/arctic-summer-world.json new file mode 100644 index 0000000..7642a91 --- /dev/null +++ b/src/content/taInfoData/arctic-summer-world.json @@ -0,0 +1,274 @@ +{ + "$schema": "../../../.astro/collections/taInfoData.schema.json", + "info": { + "title": "Arctic Summer World", + "releaseDate": "2024-07-24", + "shortdescription": "An expedition to the endless summer festival at the North Pole, orchestrated by Skadi - what could possibly happen here?", + "releaseNumber": 1, + "type": "quest" + }, + "quests": [ + { + "questTitle": "Arctic Summer Memory", + "description": "Battling against the Valkyries and the whole cast of the event - definitely a fun experience", + "data": [ + { + "title": "Summer Skadi 4T (FLO)", + "link": "https://www.youtube.com/watch?v=VD2FOa9lymE", + "date": "2024-07-28", + "servant": "357", + "turns": "4T", + "runner": "Firq" + }, + { + "title": "Summer Skadi 4T (Lvl. 2)", + "link": "https://www.youtube.com/watch?v=ozgDQF_vMPQ", + "date": "2024-07-27", + "servant": "357", + "turns": "4T", + "runner": "Requiem" + }, + { + "title": "Summer Jeanne 4T", + "link": "https://www.youtube.com/watch?v=9inDbuA-mDo", + "date": "2024-07-25", + "servant": "216", + "turns": "4T", + "runner": "im poketar" + }, + { + "title": "Summer Ibuki 4T (FLO NDCE)", + "link": "https://www.youtube.com/watch?v=Yp1aN6d_Daw", + "date": "2024-07-25", + "servant": "355", + "turns": "4T", + "runner": "ahelpfulhamster" + }, + { + "title": "Gilgamesh Caster 4T", + "link": "https://www.youtube.com/watch?v=ut-VcCeB_1o", + "date": "2024-07-25", + "servant": "145", + "turns": "4T", + "runner": "Gorgeous P." + }, + { + "title": "Dantes 4T (FLO NDCE)", + "link": "https://www.youtube.com/watch?v=tH7BUI5C3oA", + "date": "2024-07-25", + "servant": "96", + "turns": "4T", + "runner": "Akise" + }, + { + "title": "Cu Alter 4T (NDCE)", + "link": "https://www.youtube.com/watch?v=DII1lPGAGR4", + "date": "2024-07-25", + "servant": "98", + "turns": "4T", + "runner": "Volcanicz" + }, + { + "title": "Arcueid 4T (NDCE)", + "link": "https://www.youtube.com/watch?v=avMiU2rU7Y4", + "date": "2024-07-25", + "servant": "351", + "turns": "4T", + "runner": "QyTheQTΟ" + }, + { + "title": "Morgan 4T (FLO NDCE)", + "link": "https://www.youtube.com/watch?v=zT1cm4jxEtY", + "date": "2024-07-25", + "servant": "309", + "turns": "4T", + "runner": "Felt" + }, + { + "title": "Morgan 4T (4man NDCE)", + "link": "https://www.youtube.com/watch?v=UJP79G_yge4", + "date": "2024-07-25", + "servant": "309", + "turns": "4T", + "runner": "Loki" + }, + { + "title": "Taigong Wang 4T", + "link": "https://www.youtube.com/watch?v=B1tNm-LRlOs", + "date": "2024-07-25", + "servant": "331", + "turns": "4T", + "runner": "Ise(Kai)" + }, + { + "title": "Melt Summer 4T", + "link": "https://www.youtube.com/watch?v=Upqg_OTScNs", + "date": "2024-07-26", + "servant": "266", + "turns": "4T", + "runner": "CarmFGO" + }, + { + "title": "Shishou Summer 4T", + "link": "https://www.youtube.com/watch?v=Gd46UzjslPs", + "date": "2024-07-26", + "servant": "133", + "turns": "4T", + "runner": "Lyud" + }, + { + "title": "Minamoto-no-Tametomo 4T (No CE)", + "link": "https://www.youtube.com/watch?v=iaVGp-HuoDg", + "date": "2024-07-26", + "servant": "350", + "turns": "4T", + "runner": "ProbablyAParrot" + }, + { + "title": "Bazett 4T (4man)", + "link": "https://www.youtube.com/watch?v=5q7x738BzkQ", + "date": "2024-07-26", + "servant": "336", + "turns": "4T", + "runner": "TokuHer0" + }, + { + "title": "Voyager 4T", + "link": "https://www.youtube.com/watch?v=ciPBOisUtYg", + "date": "2024-07-26", + "servant": "281", + "turns": "4T", + "runner": "Ise(Kai)" + }, + { + "title": "Arjuna Alter 4T (FLO NoCE)", + "link": "https://www.youtube.com/watch?v=ARXYYGCT8A8", + "date": "2024-07-26", + "servant": "247", + "turns": "4T", + "runner": "Akise" + }, + { + "title": "Summer Ibuki 4T (FLO NoCE)", + "link": "https://www.youtube.com/watch?v=D2oi0OskXKU", + "date": "2024-07-26", + "servant": "355", + "turns": "4T", + "runner": "Tinesh" + }, + { + "title": "Melusine 4T (No RNG)", + "link": "https://www.youtube.com/watch?v=D2oi0OskXKU", + "date": "2024-07-26", + "servant": "312_st", + "turns": "4T", + "runner": "Felt" + }, + { + "title": "Taira 4T (NoCE)", + "link": "https://www.youtube.com/watch?v=Y-EhbiRbeCc", + "date": "2024-07-27", + "servant": "303", + "turns": "4T", + "runner": "Felt" + }, + { + "title": "Voyager 4T (4man)", + "link": "https://www.youtube.com/watch?v=L0jSQWOeN6s", + "date": "2024-07-27", + "servant": "281", + "turns": "4T", + "runner": "Kamager III" + }, + { + "title": "BB Summer 4T (FLO)", + "link": "https://www.youtube.com/watch?v=Lz3YltEipd0", + "date": "2024-07-27", + "servant": "220", + "turns": "4T", + "runner": "Zoropp" + }, + { + "title": "Jalter 4T (NoCE)", + "link": "https://www.youtube.com/watch?v=0AJ4w09VlT4", + "date": "2024-07-28", + "servant": "106", + "turns": "4T", + "runner": "Ray" + }, + { + "title": "Gilgamesh 4T", + "link": "https://www.youtube.com/watch?v=ZwH32UR-CIU", + "date": "2024-07-28", + "servant": "12", + "turns": "4T", + "runner": "Mikazuki" + }, + { + "title": "Artoria 4T", + "link": "https://www.youtube.com/watch?v=pfRJBE5JupA", + "date": "2024-07-28", + "servant": "2", + "turns": "4T", + "runner": "HardChibi" + }, + { + "title": "Melusine 4T (NoCEs)", + "link": "https://www.youtube.com/watch?v=9-S91YIDqug", + "date": "2024-07-28", + "servant": "312_aoe", + "turns": "4T", + "runner": "TokuHer0" + }, + { + "title": "Taisui Xingjun 4T", + "link": "https://www.youtube.com/watch?v=95HdMeysR1A", + "date": "2024-07-28", + "servant": "338", + "turns": "4T", + "runner": "Kamager III" + }, + { + "title": "Nero (Caster) 4T (NoCE)", + "link": "https://www.youtube.com/watch?v=f1UvMBeE7-I", + "date": "2024-07-28", + "servant": "175", + "turns": "4T", + "runner": "Lutrec" + }, + { + "title": "Zhang Jue 4T (FLO)", + "link": "https://www.youtube.com/watch?v=T3BEI-04dmI", + "date": "2024-07-29", + "servant": "348", + "turns": "4T", + "runner": "L11" + }, + { + "title": "Galatea 4T", + "link": "https://www.youtube.com/watch?v=mL1und2p5Wc", + "date": "2024-07-29", + "servant": "306", + "turns": "4T", + "runner": "Hentai Daddy" + }, + { + "title": "Summer Okitan 4T", + "link": "https://www.youtube.com/watch?v=o1Ai-YCvo08", + "date": "2024-07-29", + "servant": "317", + "turns": "4T", + "runner": "TokuHer0" + }, + { + "title": "Summer Jalter 4T (NDCE)", + "link": "https://x.com/santoryuiai3/status/1817969764972847614", + "date": "2024-07-29", + "servant": "219", + "turns": "4T", + "runner": "Ray" + } + ] + } + ] +} diff --git a/src/content/taInfoData/beast4l.json b/src/content/taInfoData/beast4l.json new file mode 100644 index 0000000..003f3ee --- /dev/null +++ b/src/content/taInfoData/beast4l.json @@ -0,0 +1,161 @@ +{ + "$schema": "../../../.astro/collections/taInfoData.schema.json", + "info": { + "title": "Beast IV:L", + "releaseDate": "2023-12-26", + "shortdescription": "An interesting conclusion to Tunguska to say the least", + "type": "quest" + }, + "quests": [ + { + "questTitle": "Beast IV:L", + "description": "An interesting conclusion to Tunguska to say the least - A really annoying fight with a lot of field effects, including a permanent 40% Buff Success Rate down, as well as 80% Special Defense and 2 full turns of Invincibility. And still - the TA community showed Koyanskaya that she wasn't fit for being a beast in no time.", + "data": [ + { + "title": "Shishou 4T (No MLB DMG CE)", + "link": "https://www.youtube.com/watch?v=brz21NKMMsY", + "date": "2023-12-31", + "servant": "70_bunny", + "turns": "4T", + "runner": "Firq" + }, + { + "title": "Shishou 4T (No DMG CE)", + "link": "https://www.youtube.com/watch?v=J0l-psWpokQ", + "date": "2023-12-28", + "servant": "70", + "turns": "4T", + "runner": "Requiem" + }, + { + "title": "Amakusa 4T", + "link": "https://www.youtube.com/watch?v=ud5JZ__Hk4I", + "date": "2023-12-31", + "servant": "93", + "turns": "4T", + "runner": "Yier" + }, + { + "title": "Romulus 4T (NoMash NoCE)", + "link": "https://www.youtube.com/watch?v=e0DJEXpysSQ", + "date": "2023-12-28", + "servant": "280", + "turns": "4T", + "runner": "Sakazuki" + }, + { + "title": "Melt 4T", + "link": "https://www.youtube.com/watch?v=c7K5ra2CAxs", + "date": "2023-12-31", + "servant": "163", + "turns": "4T", + "runner": "Zectry" + }, + { + "title": "Okuni 4T", + "link": "https://www.youtube.com/watch?v=eg5OeQrhQMk", + "date": "2023-12-29", + "servant": "327", + "turns": "4T", + "runner": "QP Dangerous" + }, + { + "title": "Kama 4T", + "link": "https://www.youtube.com/watch?v=9sm8XBglEgo", + "date": "2023-12-29", + "servant": "239", + "turns": "4T", + "runner": "Requiem" + }, + { + "title": "Melusine 4T (FLO)", + "link": "https://www.youtube.com/watch?v=XHjExMEg3vQ", + "date": "2024-01-01", + "servant": "312_aoe", + "turns": "4T", + "runner": "Zectry" + }, + { + "title": "Gilgamesh 4T", + "link": "https://www.youtube.com/watch?v=SrDvEaFx3ko", + "date": "2023-12-31", + "servant": "12", + "turns": "4T", + "runner": "Yier" + }, + { + "title": "Astrea 4T", + "link": "https://www.youtube.com/watch?v=kw4E_mCxkKc", + "date": "2023-12-30", + "servant": "242", + "turns": "4T", + "runner": "Alastair Hale" + }, + { + "title": "Kijyo Koyo 4T (Solo)", + "link": "https://www.youtube.com/watch?v=tAUA7Fn_HYo", + "date": "2023-12-29", + "servant": "282", + "turns": "4T", + "runner": "MCR" + }, + { + "title": "Tamamo Solo 30T", + "link": "https://www.youtube.com/watch?v=2wUcojRXTlw", + "date": "2023-12-27", + "servant": "62", + "turns": "30T", + "runner": "Mitsunee" + }, + { + "title": "Dual Taigong Wang 4T", + "link": "https://www.youtube.com/watch?v=3jU3Az7iM7E", + "date": "2023-12-27", + "servant": "331", + "turns": "4T", + "runner": "Ryougi Bobby" + }, + { + "title": "Ibuki 4T", + "link": "https://www.youtube.com/watch?v=dgJfgMHAOpI", + "date": "2023-12-29", + "servant": "299", + "turns": "4T", + "runner": "Martyr Kuga" + }, + { + "title": "Ozymandias 4T", + "link": "https://www.youtube.com/watch?v=Y8qYY875M_I", + "date": "2023-12-28", + "servant": "118", + "turns": "4T", + "runner": "Kusanagi" + }, + { + "title": "Arjuna Alter 4T", + "link": "https://www.youtube.com/watch?v=OTfM7WQl5uI", + "date": "2023-12-28", + "servant": "247", + "turns": "4T", + "runner": "Akise" + }, + { + "title": "Galatea 4T", + "link": "https://www.youtube.com/watch?v=GKCZtn815wA", + "date": "2023-12-30", + "servant": "306", + "turns": "4T", + "runner": "Hentai Daddi" + }, + { + "title": "Summer Kiara 4T", + "link": "https://www.youtube.com/watch?v=b46JRNUIdrM", + "date": "2023-12-28", + "servant": "285", + "turns": "4T", + "runner": "Felt" + } + ] + } + ] +} diff --git a/src/content/taInfoData/case-files-rerun.json b/src/content/taInfoData/case-files-rerun.json new file mode 100644 index 0000000..948acf1 --- /dev/null +++ b/src/content/taInfoData/case-files-rerun.json @@ -0,0 +1,342 @@ +{ + "$schema": "../../../.astro/collections/taInfoData.schema.json", + "info": { + "title": "Case Files Rerun 2024", + "releaseDate": "2024-01-10", + "shortdescription": "The rerun of the collaboration event with the Case Files franchise - and the return of old challenges as well as a new challenge quest.", + "releaseNumber": 1, + "type": "quest" + }, + "quests": [ + { + "questTitle": "Another Master and Servant", + "description": "A battle against a Master and Servant duo - Waver and Alexander", + "data": [ + { + "title": "Shishou 3T", + "link": "https://www.youtube.com/watch?v=j1fFbkfYtvo", + "date": "2024-01-22", + "servant": "70_bunny", + "turns": "3T", + "runner": "Firq" + }, + { + "title": "Shishou 3T (FLO)", + "link": "https://www.youtube.com/watch?v=Sszw_x7IqVU", + "date": "2024-01-23", + "servant": "70_bunny", + "turns": "3T", + "runner": "Firq" + }, + { + "title": "Muramasa 3T", + "link": "https://www.youtube.com/watch?v=IyOXmmY9wy8", + "date": "2024-01-21", + "servant": "302", + "turns": "3T", + "runner": "Loki" + }, + { + "title": "Artoria 3T", + "link": "https://www.youtube.com/watch?v=UnFsH4t0A4Y", + "date": "2024-01-22", + "servant": "2", + "turns": "3T", + "runner": "HardChibi" + }, + { + "title": "Salter 3T", + "link": "https://www.youtube.com/watch?v=K_8iF_EHP1g", + "date": "2024-01-21", + "servant": "3", + "turns": "3T", + "runner": "im poketar" + }, + { + "title": "Sei 3T", + "link": "https://www.youtube.com/watch?v=kCajUN2Lz2Q", + "date": "2024-01-24", + "servant": "276", + "turns": "3T", + "runner": "crimsonmage" + }, + { + "title": "Cindereli 3T", + "link": "https://www.youtube.com/watch?v=BPc7RTY_c7M", + "date": "2024-01-21", + "servant": "326", + "turns": "3T", + "runner": "Alastair Hale" + }, + { + "title": "Kama 3T (FLO)", + "link": "https://www.youtube.com/watch?v=-4dDZV7ijeM", + "date": "2024-01-22", + "servant": "239", + "turns": "3T", + "runner": "Requiem" + }, + { + "title": "MHXA 3T", + "link": "https://www.youtube.com/watch?v=TfWsR-hVULo", + "date": "2024-01-20", + "servant": "155", + "turns": "3T", + "runner": "Ayumi" + }, + { + "title": "Morgan 3T (6 Cost)", + "link": "https://www.youtube.com/watch?v=zXQ_FrnBh0k", + "date": "2024-01-20", + "servant": "309", + "turns": "3T", + "runner": "Ray" + }, + { + "title": "Astrea 3T (FLO)", + "link": "https://www.youtube.com/watch?v=kwqjMhYrQHY", + "date": "2024-01-20", + "servant": "242", + "turns": "3T", + "runner": "Alastair Hale" + }, + { + "title": "Van Gogh 3T", + "link": "https://www.youtube.com/watch?v=VbSXl8GthwM", + "date": "2024-01-20", + "servant": "295", + "turns": "3T", + "runner": "Alastair Hale" + }, + { + "title": "Hokusai 3T", + "link": "https://www.youtube.com/watch?v=CIzUCIN-ft4", + "date": "2024-01-24", + "servant": "198", + "turns": "3T", + "runner": "inv4der" + }, + { + "title": "Okita Alter 3T (FLO)", + "link": "https://www.youtube.com/watch?v=qkah__8XWJk", + "date": "2024-01-20", + "servant": "209", + "turns": "3T", + "runner": "TokuHer0" + }, + { + "title": "Summer BB 3T (FLO NoCE)", + "link": "https://www.youtube.com/watch?v=VAEjvL34hsc", + "date": "2024-01-21", + "servant": "220", + "turns": "3T", + "runner": "Felt" + }, + { + "title": "Kijyo Koyo 3T (FLO NoCE)", + "link": "https://www.youtube.com/watch?v=A5-VRkAx__o", + "date": "2024-01-19", + "servant": "282", + "turns": "3T", + "runner": "MCR" + } + ] + }, + { + "questTitle": "Case - Train Tea Party", + "description": "A showdown against both Reines and Gray on top of a train ", + "data": [ + { + "title": "Artoria 3T", + "link": "https://www.youtube.com/watch?v=FQ6Zb_kzrWs", + "date": "2024-01-21", + "servant": "2", + "turns": "3T", + "runner": "HardChibi" + }, + { + "title": "Artoria 3T (FLO)", + "link": "https://www.youtube.com/watch?v=uKercpWUnGs&t=216s", + "date": "2024-01-19", + "servant": "2", + "turns": "3T", + "runner": "Fu Windsword" + }, + { + "title": "Altera 3T", + "link": "https://www.youtube.com/watch?v=WcHpHfFnVrY", + "date": "2024-01-24", + "servant": "8", + "turns": "3T", + "runner": "Lyud" + }, + { + "title": "Saber Lily 3T", + "link": "https://www.youtube.com/watch?v=jCwTbmLsGcA", + "date": "2024-01-18", + "servant": "4", + "turns": "3T", + "runner": "Ayumi" + }, + { + "title": "Gilgamesh 3T (NoCE)", + "link": "https://www.youtube.com/watch?v=nWeZ9lo2iYI", + "date": "2024-01-18", + "servant": "12", + "turns": "3T", + "runner": "Kusanagi" + }, + { + "title": "Sei 3T", + "link": "https://www.youtube.com/watch?v=BEGortNzIsQ", + "date": "2024-01-23", + "servant": "276", + "turns": "3T", + "runner": "inv4der" + }, + { + "title": "Melusine 3T (FLO NoCE)", + "link": "https://www.youtube.com/watch?v=OgoteFJL85A", + "date": "2024-01-21", + "servant": "312_aoe", + "turns": "3T", + "runner": "TokuHer0" + }, + { + "title": "Melusine 3T (FLO)", + "link": "https://www.youtube.com/watch?v=PTtm_c7F5Ro", + "date": "2024-01-18", + "servant": "312_aoe", + "turns": "3T", + "runner": "Felt" + }, + { + "title": "Ivan 3T", + "link": "https://www.youtube.com/watch?v=shsogSLclv4", + "date": "2024-01-24", + "servant": "205", + "turns": "3T", + "runner": "ProbablyAParrot" + }, + { + "title": "Gong 3T", + "link": "https://www.youtube.com/watch?v=bc5LvCQO56I&t=244s", + "date": "2024-01-23", + "servant": "258", + "turns": "3T", + "runner": "BadLuck" + }, + { + "title": "Morgan 3T (NoCEs)", + "link": "https://www.youtube.com/watch?v=y4XnMyqVGK8", + "date": "2024-01-18", + "servant": "309", + "turns": "3T", + "runner": "Loki" + }, + { + "title": "Morgan 3T (Lvl 50)", + "link": "https://www.youtube.com/watch?v=MQ2b6FFPMf8", + "date": "2024-01-18", + "servant": "309", + "turns": "3T", + "runner": "Ray" + }, + { + "title": "Okita Alter 3T (FLO NoCEs)", + "link": "https://www.youtube.com/watch?v=7Htl-Ld6f-Q", + "date": "2024-01-21", + "servant": "209", + "turns": "3T", + "runner": "TokuHer0" + }, + { + "title": "Kingprotea 3T (FLO)", + "link": "https://www.youtube.com/watch?v=iarswRjrKAI", + "date": "2024-01-21", + "servant": "238", + "turns": "3T", + "runner": "Akise" + }, + { + "title": "Koyan of Dark 3T", + "link": "https://www.youtube.com/watch?v=h_jsUQeOXi8", + "date": "2024-01-21", + "servant": "334", + "turns": "3T", + "runner": "Alastair Hale" + }, + { + "title": "Voyager 3T", + "link": "https://www.youtube.com/watch?v=kQ2pRFR3ZmM", + "date": "2024-01-20", + "servant": "281", + "turns": "3T", + "runner": "Ise(Kai)" + }, + { + "title": "Scathach 5T (4Man)", + "link": "https://www.youtube.com/watch?v=IIk5ypPq9dM", + "date": "2024-01-23", + "servant": "70", + "turns": "5T", + "runner": "Requiem" + }, + { + "title": "Li Shuwen 5T (NoCE)", + "link": "https://www.youtube.com/watch?v=BHNTmj56Adk", + "date": "2024-01-24", + "servant": "235", + "turns": "5T", + "runner": "Alastair Hale" + }, + { + "title": "Charlotte 5T", + "link": "https://www.youtube.com/watch?v=aOuK9RhZSFk", + "date": "2024-01-20", + "servant": "259", + "turns": "5T", + "runner": "xy sunder" + }, + { + "title": "Taira 5T (FLO BCE)", + "link": "https://www.youtube.com/watch?v=A5F8Rb26tNY", + "date": "2024-01-22", + "servant": "303", + "turns": "5T", + "runner": "Felt" + }, + { + "title": "Melt 5T (FLO NoCE)", + "link": "https://www.youtube.com/watch?v=-WRocbYbzpE", + "date": "2024-01-23", + "servant": "163", + "turns": "5T", + "runner": "xy sunder" + }, + { + "title": "MHXA 5T (FLO NoCE)", + "link": "https://www.youtube.com/watch?v=qFESCN59RFA", + "date": "2024-01-22", + "servant": "155", + "turns": "5T", + "runner": "Ayumi" + } + ] + }, + { + "questTitle": "Barbartos", + "description": "The return of the giant candy cane", + "data": [ + { + "title": "Skadi 1T", + "link": "https://www.youtube.com/watch?v=ic-wva9H0Ic", + "date": "2024-01-16", + "servant": "215", + "turns": "1T", + "runner": "Firq" + } + ] + } + ] +} diff --git a/src/content/taInfoData/devilish-bodhisattva.json b/src/content/taInfoData/devilish-bodhisattva.json new file mode 100644 index 0000000..38bcf7a --- /dev/null +++ b/src/content/taInfoData/devilish-bodhisattva.json @@ -0,0 +1,130 @@ +{ + "$schema": "../../../.astro/collections/taInfoData.schema.json", + "info": { + "title": "Devilish Bodhisattva", + "releaseDate": "2019-04-23", + "shortdescription": "One of the most infamous fights in FGO, Full Power Beast III:R", + "releaseNumber": 1, + "type": "quest" + }, + "quests": [ + { + "questTitle": "Devilish Bodhisattva", + "description": "One of the most infamous fights in FGO, Full Power Beast III:R ... but the racers make even this fight look easy at times, clearning it with the most diverse roster of servants ever seen.", + "data": [ + { + "title": "Shishou 7T (NoDupes)", + "link": "https://www.youtube.com/watch?v=d1ftVeitR6c", + "date": "2022-07-09", + "servant": "70", + "turns": "7T", + "runner": "Firq" + }, + { + "title": "Summer Skadi 7T", + "link": "https://www.youtube.com/watch?v=7HPLGs_LPzs", + "date": "2024-07-25", + "servant": "357", + "turns": "7T", + "runner": "Firq" + }, + { + "title": "Shishou 7T", + "link": "https://www.youtube.com/watch?v=nYV4jwgpuR0", + "date": "2022-07-14", + "servant": "70", + "turns": "7T", + "runner": "KOG" + }, + { + "title": "Shishou 7T", + "link": "https://www.youtube.com/watch?v=jKoSw1XM6-c", + "date": "2022-07-07", + "servant": "70", + "turns": "7T", + "runner": "Requiem" + }, + { + "title": "Jalter 7T", + "link": "https://www.youtube.com/watch?v=U5wsl09_VVQ", + "date": "2023-03-21", + "servant": "106", + "turns": "7T", + "runner": "Ray" + }, + { + "title": "Jalter 7T (NoCE)", + "link": "https://www.youtube.com/watch?v=RPtMHOxQfjs", + "date": "2023-11-29", + "servant": "106", + "turns": "7T", + "runner": "Ray" + }, + { + "title": "Taira 7T (NoCE)", + "link": "https://www.youtube.com/watch?v=mg8f8TD5AEQ", + "date": "2023-08-20", + "servant": "303", + "turns": "7T", + "runner": "Felt" + }, + { + "title": "Astrea 7T", + "link": "https://www.youtube.com/watch?v=aWg9LCcZxro", + "date": "2023-08-22", + "servant": "242", + "turns": "7T", + "runner": "Alastair Hale" + }, + { + "title": "Astrea 7T (No Castoria)", + "link": "https://www.youtube.com/watch?v=fEJTDScu238", + "date": "2023-01-01", + "servant": "242", + "turns": "7T", + "runner": "Alastair Hale" + }, + { + "title": "Dioscuri 7T", + "link": "https://www.youtube.com/watch?v=El9D-LskMHU", + "date": "2022-06-25", + "servant": "278", + "turns": "7T", + "runner": "Sou" + }, + { + "title": "Maou Nobu 7T", + "link": "https://www.youtube.com/watch?v=CGGJ7WA6Gqg", + "date": "2022-12-30", + "servant": "250", + "turns": "7T", + "runner": "Haru" + }, + { + "title": "Sitonai 7T", + "link": "https://www.youtube.com/watch?v=RJSedKUyKn0", + "date": "2022-10-26", + "servant": "224", + "turns": "7T", + "runner": "Alastair Hale" + }, + { + "title": "Charlotte 7T", + "link": "https://www.youtube.com/watch?v=2DhDcxAcUTo", + "date": "2022-07-07", + "servant": "259", + "turns": "7T", + "runner": "Dante09" + }, + { + "title": "MHXA 7T", + "link": "https://www.youtube.com/watch?v=xGHiUL4HR08", + "date": "2023-06-13", + "servant": "155", + "turns": "7T", + "runner": "Ayumi" + } + ] + } + ] +} diff --git a/src/content/taInfoData/lostbelt-6-5/kiyohime.json b/src/content/taInfoData/lostbelt-6-5/kiyohime.json new file mode 100644 index 0000000..125d5a5 --- /dev/null +++ b/src/content/taInfoData/lostbelt-6-5/kiyohime.json @@ -0,0 +1,49 @@ +{ + "$schema": "../../../../.astro/collections/taInfoData.schema.json", + "info": { + "title": "Kiyohime", + "releaseDate": "2024-05-13", + "shortdescription": "Help, there is an angry dragon snek that wants to burn me for slightly lying to her", + "releaseNumber": 2 + }, + "quests": [ + { + "questTitle": "Kiyohime", + "description": "", + "data": [ + { + "title": "S.Karna Karna Arjuna Junao 5T", + "link": "https://youtu.be/f039x5OIl6E", + "date": "2024-05-18", + "servant": "247", + "turns": "5T", + "runner": "Akise" + }, + { + "title": "Baobhan Arash Habetrot 5T", + "link": "https://www.youtube.com/watch?v=a7V5W8MkxO8", + "date": "2024-05-31", + "servant": "311", + "turns": "5T", + "runner": "Mikazuki" + }, + { + "title": "Cindereli Habenya Douman Arash 5T", + "link": "https://www.youtube.com/watch?v=7Z0Fn8tBV4E", + "date": "2024-05-14", + "servant": "326", + "turns": "5T", + "runner": "Loki" + }, + { + "title": "Daikokuten 5T", + "link": "https://www.youtube.com/watch?v=Q7v_joSJmNg", + "date": "2024-05-20", + "servant": "340", + "turns": "5T", + "runner": "TokuHer0" + } + ] + } + ] +} diff --git a/src/content/taInfoData/lostbelt-6-5/kriemhild.json b/src/content/taInfoData/lostbelt-6-5/kriemhild.json new file mode 100644 index 0000000..da1ebc5 --- /dev/null +++ b/src/content/taInfoData/lostbelt-6-5/kriemhild.json @@ -0,0 +1,153 @@ +{ + "$schema": "../../../../.astro/collections/taInfoData.schema.json", + "info": { + "title": "Kriemhild", + "releaseDate": "2024-05-13", + "shortdescription": "Trying to get Kriemhild acting sane when she's a Berserker and pitted against her husband - Challenge Impossible", + "releaseNumber": 3 + }, + "quests": [ + { + "questTitle": "Kriemhild", + "description": "", + "data": [ + { + "title": "Nero Bride 3T (FLO)", + "link": "https://www.youtube.com/watch?v=iEOhDVhIKkw", + "date": "2024-05-22", + "servant": "90", + "turns": "3T", + "runner": "Lutrec" + }, + { + "title": "Saber Diarmuid 3T", + "link": "https://www.youtube.com/watch?v=aBBY-smKj2I", + "date": "2024-05-27", + "servant": "223", + "turns": "3T", + "runner": "Volcanicz" + }, + { + "title": "Muramasa 3T", + "link": "https://www.youtube.com/watch?v=Wejdo62W9Ng", + "date": "2024-05-16", + "servant": "302", + "turns": "3T", + "runner": "Loki" + }, + { + "title": "Artoria 3T (FLO)", + "link": "https://www.youtube.com/watch?v=qkZji1N7oLs", + "date": "2024-05-25", + "servant": "2", + "turns": "3T", + "runner": "Fu Windsword" + }, + { + "title": "Siegfried 3T (NPC)", + "link": "https://www.youtube.com/watch?v=BSPUS2kQyeE", + "date": "2024-05-20", + "servant": "6", + "turns": "3T", + "runner": "TokuHer0" + }, + { + "title": "Jeanne Summer 3T", + "link": "https://www.youtube.com/watch?v=_1GgmzU8SJI", + "date": "2024-05-18", + "servant": "216", + "turns": "3T", + "runner": "im poketar" + }, + { + "title": "Emiya 3T", + "link": "https://www.youtube.com/watch?v=hEuWchiPUcM", + "date": "2024-05-18", + "servant": "11", + "turns": "3T", + "runner": "Volcanicz" + }, + { + "title": "Melusine 3T (Solo)", + "link": "https://www.youtube.com/watch?v=pH7iLqMKamE", + "date": "2024-05-16", + "servant": "312_st", + "turns": "3T", + "runner": "Felt" + }, + { + "title": "Kagetora 3T (FLO)", + "link": "https://www.youtube.com/watch?v=j_S20-UZbqo", + "date": "2024-05-22", + "servant": "252", + "turns": "3T", + "runner": "Volcanicz" + }, + { + "title": "Cindereli 3T", + "link": "https://www.youtube.com/watch?v=H_mUuNrZE0I", + "date": "2024-05-16", + "servant": "326", + "turns": "3T", + "runner": "Loki" + }, + { + "title": "Rider Ishtar 3T", + "link": "https://www.youtube.com/watch?v=9jHuxjH6puw", + "date": "2024-05-19", + "servant": "182", + "turns": "3T", + "runner": "Volcanicz" + }, + { + "title": "Cu Caster 3T (FLO)", + "link": "https://www.youtube.com/watch?v=N9ZZ-nuePmA", + "date": "2024-05-22", + "servant": "38", + "turns": "3T", + "runner": "Akise" + }, + { + "title": "Skadi 3T", + "link": "https://www.youtube.com/watch?v=YrvWmFTgMUE", + "date": "2024-05-17", + "servant": "215", + "turns": "3T", + "runner": "Firq" + }, + { + "title": "Merlin 3T", + "link": "https://www.youtube.com/watch?v=kPtC0P-XHag", + "date": "2024-05-20", + "servant": "150", + "turns": "3T", + "runner": "Ise(Kai)" + }, + { + "title": "Morgan 3T", + "link": "https://www.youtube.com/watch?v=hJyf-FFRQUw", + "date": "2024-05-15", + "servant": "309", + "turns": "3T", + "runner": "Loki" + }, + { + "title": "Astrea 3T (Lvl. 2)", + "link": "https://www.youtube.com/watch?v=EPZUkzN9ySQ", + "date": "2024-05-19", + "servant": "242", + "turns": "3T", + "runner": "Alastair Hale" + }, + { + "title": "Summer BB 3T (4man)", + "link": "https://www.youtube.com/watch?v=k7btt-Vti2I", + "date": "2024-05-21", + "servant": "220", + "turns": "3T", + "runner": "Volcanicz" + } + ] + } + ] +} diff --git a/src/content/taInfoData/lostbelt-6-5/moriarty.json b/src/content/taInfoData/lostbelt-6-5/moriarty.json new file mode 100644 index 0000000..1a8b5a8 --- /dev/null +++ b/src/content/taInfoData/lostbelt-6-5/moriarty.json @@ -0,0 +1,81 @@ +{ + "$schema": "../../../../.astro/collections/taInfoData.schema.json", + "info": { + "title": "Moriarty", + "releaseDate": "2024-05-13", + "shortdescription": "The epic showdown at the Reichenbach Falls - A worthy finale against the Big Bad Evil of this Lostbelt", + "releaseNumber": 4 + }, + "quests": [ + { + "questTitle": "Moriarty", + "description": "", + "data": [ + { + "title": "Nero Bride 4T", + "link": "https://www.youtube.com/watch?v=wWM5yvCeiIA", + "date": "2024-05-25", + "servant": "90", + "turns": "4T", + "runner": "Lutrec" + }, + { + "title": "Morgan 4T", + "link": "https://www.youtube.com/watch?v=42pTDuQwsQg", + "date": "2024-05-16", + "servant": "309", + "turns": "4T", + "runner": "Loki" + }, + { + "title": "Arjuna Alter 4T (FLO)", + "link": "https://www.youtube.com/watch?v=egmZQvRseX8", + "date": "2024-05-23", + "servant": "247", + "turns": "4T", + "runner": "Akise" + }, + { + "title": "Da Vinci Ruler 4T", + "link": "https://www.youtube.com/watch?v=LUFHZXy0F14", + "date": "2024-05-27", + "servant": "320", + "turns": "4T", + "runner": "Lutrec" + }, + { + "title": "Taira 4T", + "link": "https://www.youtube.com/watch?v=qU_9PFh04Og", + "date": "2024-05-19", + "servant": "303", + "turns": "4T", + "runner": "Patrick Bandeira" + }, + { + "title": "Taira 4T (Solo)", + "link": "https://www.youtube.com/watch?v=PaTeIqKSdVA", + "date": "2024-05-16", + "servant": "303", + "turns": "4T", + "runner": "Felt" + }, + { + "title": "Bazett 3T", + "link": "https://www.youtube.com/watch?v=_7vDBCqLlhU", + "date": "2024-05-21", + "servant": "336", + "turns": "3T", + "runner": "TokuHer0" + }, + { + "title": "Kiara 4T", + "link": "https://www.youtube.com/watch?v=gEa8VJOy2Eg", + "date": "2024-05-19", + "servant": "167", + "turns": "4T", + "runner": "im poketar" + } + ] + } + ] +} diff --git a/src/content/taInfoData/lostbelt-6-5/zhang-jue.json b/src/content/taInfoData/lostbelt-6-5/zhang-jue.json new file mode 100644 index 0000000..d470713 --- /dev/null +++ b/src/content/taInfoData/lostbelt-6-5/zhang-jue.json @@ -0,0 +1,65 @@ +{ + "$schema": "../../../../.astro/collections/taInfoData.schema.json", + "info": { + "title": "Zhang Jue", + "releaseDate": "2024-05-13", + "shortdescription": "A fight against a general that uses his servants as meat shields - what a way trying to survive an assassination.", + "releaseNumber": 1 + }, + "quests": [ + { + "questTitle": "Zhang Jue", + "description": "", + "data": [ + { + "title": "Skadi 2T", + "link": "https://youtu.be/OtNYsaM13G4", + "date": "2024-05-14", + "servant": "215", + "turns": "2T", + "runner": "Firq" + }, + { + "title": "Baobhan 2T", + "link": "https://www.youtube.com/watch?v=GmUUF0aiXik", + "date": "2024-05-18", + "servant": "311", + "turns": "2T", + "runner": "Mikazuki" + }, + { + "title": "Melusine 2T", + "link": "https://www.youtube.com/watch?v=9X5Znfw6dWk", + "date": "2024-05-20", + "servant": "312_aoe", + "turns": "2T", + "runner": "TokuHer0" + }, + { + "title": "Nero (Caster) 2T", + "link": "https://www.youtube.com/watch?v=-rK9rpJIFDA", + "date": "2024-05-20", + "servant": "175", + "turns": "2T", + "runner": "Lutrec" + }, + { + "title": "Morgan 2T", + "link": "https://www.youtube.com/watch?v=8mg123LnifQ", + "date": "2024-05-14", + "servant": "309", + "turns": "2T", + "runner": "Loki" + }, + { + "title": "Bazett 1T", + "link": "https://www.youtube.com/watch?v=Zgn8tlXStiI", + "date": "2024-05-22", + "servant": "336", + "turns": "1T", + "runner": "Mikazuki" + } + ] + } + ] +} diff --git a/src/content/taInfoData/lostbelt-6/albion.json b/src/content/taInfoData/lostbelt-6/albion.json new file mode 100644 index 0000000..66be8dc --- /dev/null +++ b/src/content/taInfoData/lostbelt-6/albion.json @@ -0,0 +1,138 @@ +{ + "$schema": "../../../../.astro/collections/taInfoData.schema.json", + "info": { + "title": "Albion", + "releaseDate": "2023-07-10", + "shortdescription": "Albion shows up with a new mechanic, but will it be enough?", + "releaseNumber": 1, + "type": "quest" + }, + "quests": [ + { + "questTitle": "Albion", + "description": "Albion shows up with a new mechanic, but will it be enough? No, because the mechanics are only seen as a small challenge and were quickly rendered a sideeffect during this quest - to the dismay of Melusine", + "data": [ + { + "title": "Musashi 3T", + "link": "https://www.youtube.com/watch?v=iVdQPoouI_Y", + "date": "2023-07-10", + "servant": "153", + "turns": "3T", + "runner": "Ray" + }, + { + "title": "Altera 3T (FLO)", + "link": "https://www.youtube.com/watch?v=7pyPtTVbd2A", + "date": "2023-07-13", + "servant": "8", + "turns": "3T", + "runner": "Requiem" + }, + { + "title": "Suzuka 3T (FLO)", + "link": "https://www.youtube.com/watch?v=6ExpIoUJ3aU", + "date": "2023-07-12", + "servant": "165", + "turns": "3T", + "runner": "Firq" + }, + { + "title": "Saber Alter 3T (FLO)", + "link": "https://www.youtube.com/watch?v=5U42nu-vPnk", + "date": "2023-07-12", + "servant": "3", + "turns": "3T", + "runner": "Firq" + }, + { + "title": "Baobhan Sith 3T", + "link": "https://www.youtube.com/watch?v=526KYBolySY", + "date": "2023-07-13", + "servant": "311", + "turns": "3T", + "runner": "Requiem" + }, + { + "title": "Shishou 3T", + "link": "https://www.youtube.com/watch?v=E8fjEYFqrWI", + "date": "2023-07-12", + "servant": "70_bunny", + "turns": "3T", + "runner": "Firq" + }, + { + "title": "Shishou 3T (FLO)", + "link": "https://www.youtube.com/watch?v=ciIkgHr-QPk", + "date": "2023-07-12", + "servant": "70", + "turns": "3T", + "runner": "Requiem" + }, + { + "title": "Ereshkigal 3T", + "link": "https://www.youtube.com/watch?v=wQBe74XTy4Q", + "date": "2023-07-13", + "servant": "196", + "turns": "3T", + "runner": "Conry" + }, + { + "title": "Skadi 3T", + "link": "https://www.youtube.com/watch?v=tejeiYpzfqo", + "date": "2023-07-11", + "servant": "215", + "turns": "3T", + "runner": "Firq" + }, + { + "title": "Kama 3T (FLO)", + "link": "https://www.youtube.com/watch?v=SmnwfrXp1sg", + "date": "2023-07-13", + "servant": "239", + "turns": "3T", + "runner": "Requiem" + }, + { + "title": "Summer Jalter 3T (FLO)", + "link": "https://www.youtube.com/watch?v=-3uDduYI2Cw", + "date": "2023-07-10", + "servant": "219", + "turns": "3T", + "runner": "Kusanagi" + }, + { + "title": "Tamamo Cat 3T", + "link": "https://www.youtube.com/watch?v=Vn6L6Ywin44", + "date": "2023-07-13", + "servant": "58", + "turns": "3T", + "runner": "Requiem" + }, + { + "title": "Cu Alter 3T (FLO)", + "link": "https://www.youtube.com/watch?v=iaR6PdFmmeQ", + "date": "2023-07-13", + "servant": "98", + "turns": "3T", + "runner": "Volcanicz" + }, + { + "title": "Suzuka 3T", + "link": "https://www.youtube.com/watch?v=2dj-55-9Oe8", + "date": "2023-07-12", + "servant": "165", + "turns": "3T", + "runner": "Mitsunee" + }, + { + "title": "Shishou 3T", + "link": "https://www.youtube.com/watch?v=QB8xf7IeLO4", + "date": "2023-07-13", + "servant": "70", + "turns": "3T", + "runner": "KOG" + } + ] + } + ] +} diff --git a/src/content/taInfoData/lostbelt-6/cernunnos.json b/src/content/taInfoData/lostbelt-6/cernunnos.json new file mode 100644 index 0000000..af516a8 --- /dev/null +++ b/src/content/taInfoData/lostbelt-6/cernunnos.json @@ -0,0 +1,106 @@ +{ + "$schema": "../../../../.astro/collections/taInfoData.schema.json", + "info": { + "title": "Cernunnos", + "releaseDate": "2023-07-10", + "shortdescription": "One of FGOs most notorious boss fights due to up to 100% special defense, strong DoT damage and powerful field effects", + "releaseNumber": 2, + "type": "quest" + }, + "quests": [ + { + "questTitle": "Cernunnos", + "description": "One of FGOs most notorious boss fights due to up to 100% special defense, strong DoT damage and powerful field effects - and still, the TA community prevailed and created some of the most amazing runs of all time", + "data": [ + { + "title": "Shishou 4T (No Castoria)", + "link": "https://www.youtube.com/watch?v=WrHudtdfivA", + "date": "2023-07-19", + "servant": "70_bunny", + "turns": "4T", + "runner": "Firq" + }, + { + "title": "Shishou 4T (FLO)", + "link": "https://www.youtube.com/watch?v=O1f-go7uJQM", + "date": "2023-07-19", + "servant": "70", + "turns": "4T", + "runner": "Requiem" + }, + { + "title": "Jalter 4T", + "link": "https://www.youtube.com/watch?v=VGuXstsJa6k", + "date": "2023-07-10", + "servant": "106", + "turns": "4T", + "runner": "Ray" + }, + { + "title": "Altera 4T", + "link": "https://www.youtube.com/watch?v=BrgJT3gC6sg", + "date": "2023-07-13", + "servant": "8", + "turns": "4T", + "runner": "Requiem" + }, + { + "title": "Astrea 4T (4 Slot)", + "link": "https://www.youtube.com/watch?v=0pwUn_bickU", + "date": "2023-07-17", + "servant": "242", + "turns": "4T", + "runner": "Alastair Hale" + }, + { + "title": "Meltryllis 4T (4 Slot)", + "link": "https://www.youtube.com/watch?v=B5uZkC40SQc", + "date": "2023-07-21", + "servant": "163", + "turns": "4T", + "runner": "Zectry" + }, + { + "title": "Kijyo Koyo 4T", + "link": "https://www.youtube.com/watch?v=hea0QSvTbkY", + "date": "2023-07-14", + "servant": "282", + "turns": "4T", + "runner": "MCR" + }, + { + "title": "Charlotte 4T", + "link": "https://www.youtube.com/watch?v=HMD2WLNGxAk", + "date": "2023-07-12", + "servant": "259", + "turns": "4T", + "runner": "Dante09" + }, + { + "title": "Gong 4T (4 NPs)", + "link": "https://www.youtube.com/watch?v=qQ82YA4BeGE", + "date": "2023-07-11", + "servant": "258", + "turns": "4T", + "runner": "BadLuck" + }, + { + "title": "Shishou 4T", + "link": "https://www.youtube.com/watch?v=dArTitWkttA", + "date": "2023-07-13", + "servant": "70", + "turns": "4T", + "runner": "KOG" + }, + { + "title": "Amakusa 4T", + "link": "https://www.youtube.com/watch?v=hRu3EskLExE", + "date": "2023-07-27", + "servant": "93", + "turns": "4T", + "runner": "Yier" + } + ] + } + ] +} diff --git a/src/content/taInfoData/lostbelt-6/morgan.json b/src/content/taInfoData/lostbelt-6/morgan.json new file mode 100644 index 0000000..6b7bc82 --- /dev/null +++ b/src/content/taInfoData/lostbelt-6/morgan.json @@ -0,0 +1,170 @@ +{ + "$schema": "../../../../.astro/collections/taInfoData.schema.json", + "info": { + "title": "Queen Morgan", + "releaseDate": "2023-06-20", + "shortdescription": "The fight against the Lostbelt 6 Queen as the conclusion of LB 6 Part 2", + "releaseNumber": 1, + "type": "quest" + }, + "quests": [ + { + "questTitle": "Queen Morgan", + "description": "The fight against the Lostbelt 6 Queen as the conclusion of LB 6 Part 2 - Interesting field effects and a berserker enemy were making this fight interesting, as Morgan is hitting like an actual truck, meaning support cycling was a lot easier than usual.", + "data": [ + { + "title": "Skadi 3T", + "link": "https://www.youtube.com/watch?v=sQ7HHl1Pb3c", + "date": "2023-06-25", + "servant": "215", + "turns": "3T", + "runner": "Firq" + }, + { + "title": "Shishou 3T", + "link": "https://www.youtube.com/watch?v=7wQ6iabqgEc", + "date": "2023-06-26", + "servant": "70_bunny", + "turns": "3T", + "runner": "Firq" + }, + { + "title": "Shishou 3T", + "link": "https://www.youtube.com/watch?v=peKFxJZzoQ8", + "date": "2023-06-24", + "servant": "70", + "turns": "3T", + "runner": "KOG" + }, + { + "title": "MHXA 3T", + "link": "https://www.youtube.com/watch?v=ezKPe41MP3w", + "date": "2023-06-28", + "servant": "155", + "turns": "3T", + "runner": "Requiem" + }, + { + "title": "NPC Castoria 3T", + "link": "https://www.youtube.com/watch?v=80u9nMp1k3o", + "date": "2023-06-28", + "servant": "284", + "turns": "3T", + "runner": "Requiem" + }, + { + "title": "Shishou 3T (FLO)", + "link": "https://www.youtube.com/watch?v=nDLV_TrnEts", + "date": "2023-06-28", + "servant": "70", + "turns": "3T", + "runner": "Requiem" + }, + { + "title": "Kama 3T (FLO)", + "link": "https://www.youtube.com/watch?v=3hEmzqo84XU", + "date": "2023-06-28", + "servant": "239", + "turns": "3T", + "runner": "Requiem" + }, + { + "title": "Baobhan Sith 3T (FLO)", + "link": "https://www.youtube.com/watch?v=RR0u-_oooJ8", + "date": "2023-06-28", + "servant": "311", + "turns": "3T", + "runner": "Requiem" + }, + { + "title": "Jalter 3T (NoCE)", + "link": "https://www.youtube.com/watch?v=Vjai9Qg8TyU", + "date": "2023-06-24", + "servant": "106", + "turns": "3T", + "runner": "Ray" + }, + { + "title": "MIXA 3T (NoCE)", + "link": "https://www.youtube.com/watch?v=pV6ktirIuPE", + "date": "2023-06-26", + "servant": "308", + "turns": "3T", + "runner": "Ayumi" + }, + { + "title": "BB (Summer) 3T (NoCE NoNP FLO)", + "link": "https://www.youtube.com/watch?v=lgyteVK7cNA", + "date": "2023-07-06", + "servant": "220", + "turns": "3T", + "runner": "BadLuck" + }, + { + "title": "Cu Alter 3T", + "link": "https://www.youtube.com/watch?v=7QY_9rYmbwA", + "date": "2023-06-30", + "servant": "98", + "turns": "3T", + "runner": "Kusanagi" + }, + { + "title": "Saber Lily 3T", + "link": "https://www.youtube.com/watch?v=v4j8YkJfZJ4", + "date": "2023-06-26", + "servant": "4", + "turns": "3T", + "runner": "Ayumi" + }, + { + "title": "Arjuna Alter 3T (FLO NoCEs)", + "link": "https://www.youtube.com/watch?v=zqGoTDhNfXM", + "date": "2023-07-07", + "servant": "247", + "turns": "3T", + "runner": "Akise" + }, + { + "title": "Arjuna Alter 3T (FLO NoCE)", + "link": "https://www.youtube.com/watch?v=SWK8oevHYmk", + "date": "2023-07-20", + "servant": "247", + "turns": "3T", + "runner": "Sakazuki" + }, + { + "title": "Astrea 3T", + "link": "https://www.youtube.com/watch?v=FsCfhat10yw", + "date": "2023-06-24", + "servant": "242", + "turns": "3T", + "runner": "Duplexubiquitary" + }, + { + "title": "Kijyo Koyo 3T", + "link": "https://www.youtube.com/watch?v=gL4PqwliXr4", + "date": "2023-06-28", + "servant": "282", + "turns": "3T", + "runner": "MCR" + }, + { + "title": "Melt 3T (FLO NoCEs)", + "link": "https://www.youtube.com/watch?v=2eh_Hitk7uQ", + "date": "2023-07-14", + "servant": "163", + "turns": "3T", + "runner": "Zectry" + }, + { + "title": "Taira 3T (FLO)", + "link": "https://www.youtube.com/watch?v=iM7KBuvtUH0", + "date": "2023-07-17", + "servant": "303", + "turns": "3T", + "runner": "Felt" + } + ] + } + ] +} diff --git a/src/content/teslafest/challenge-quest.json b/src/content/teslafest/challenge-quest.json new file mode 100644 index 0000000..25ef7bb --- /dev/null +++ b/src/content/teslafest/challenge-quest.json @@ -0,0 +1,249 @@ +{ + "$schema": "../../../.astro/collections/teslafest.schema.json", + "info": { + "title": "Lightning in Gilgilgamesh", + "releaseDate": "2024-03-23", + "shortdescription": "The actual Challenge Quest of this event - time to make those pompous idiots pay!", + "releaseNumber": 1 + }, + "quests": [ + { + "questTitle": "Lightning in Gilgilgamesh", + "description": "The actual Challenge Quest of this event - time to make those pompous idiots (Gilgamesh, Tesla and another Gilgamesh) pay!", + "data": [ + { + "title": "Scathach 5T (Solo)", + "link": "https://www.youtube.com/watch?v=z00-lmhHSz8", + "date": "2024-04-08", + "servant": "70_bunny", + "turns": "5T", + "runner": "Firq" + }, + { + "title": "Scathach 5T (Solo)", + "link": "https://www.youtube.com/watch?v=OgZo-anT5uQ", + "date": "2024-03-26", + "servant": "70", + "turns": "5T", + "runner": "Requiem" + }, + { + "title": "Summer Sei 5T", + "link": "https://www.youtube.com/watch?v=7fPkwG--6Is", + "date": "2024-03-27", + "servant": "323", + "turns": "5T", + "runner": "Ise(Kai)" + }, + { + "title": "Artoria 3T", + "link": "https://www.youtube.com/watch?v=NbQE0SzQH6M", + "date": "2024-03-28", + "servant": "2", + "turns": "3T", + "runner": "Fu Windsword" + }, + { + "title": "Nero 3T (FLO)", + "link": "https://www.youtube.com/watch?v=9u2JdC2cxYU", + "date": "2024-03-25", + "servant": "5", + "turns": "3T", + "runner": "Lutrec" + }, + { + "title": "Ibuki 3T (NDCE)", + "link": "https://www.youtube.com/watch?v=bUIYd9JI5zE", + "date": "2024-03-24", + "servant": "299", + "turns": "3T", + "runner": "inv4der" + }, + { + "title": "Sei 3T (FLO)", + "link": "https://www.youtube.com/watch?v=_EOrWKda0Mo", + "date": "2024-03-24", + "servant": "276", + "turns": "3T", + "runner": "Ise(Kai)" + }, + { + "title": "Summer Illya 3T (FLO)", + "link": "https://www.youtube.com/watch?v=_EOrWKda0Mo", + "date": "2024-03-30", + "servant": "286", + "turns": "3T", + "runner": "Zoropp" + }, + { + "title": "Gong 3T", + "link": "https://www.youtube.com/watch?v=-hZpsrD-8oA", + "date": "2024-03-24", + "servant": "258", + "turns": "3T", + "runner": "Liz Happy Club" + }, + { + "title": "Summer Kama 3T (NDCE)", + "link": "https://www.youtube.com/watch?v=F5DTWtzSz-w", + "date": "2024-03-24", + "servant": "321", + "turns": "3T", + "runner": "Kamager III" + }, + { + "title": "Voyager 3T (NDCE)", + "link": "https://www.youtube.com/watch?v=cNvJDcKvjzY", + "date": "2024-03-26", + "servant": "281", + "turns": "3T", + "runner": "Kamager III" + }, + { + "title": "Bazett 2T (w. Morgan)", + "link": "https://www.youtube.com/watch?v=nZjTgPkemxM", + "date": "2024-03-24", + "servant": "336", + "turns": "2T", + "runner": "Loki" + }, + { + "title": "Bazett 2T (w. Gong)", + "link": "https://www.youtube.com/watch?v=MxYdAf5L0rQ", + "date": "2024-03-26", + "servant": "336", + "turns": "2T", + "runner": "Paradise" + }, + { + "title": "Da Vinci Rider 3T", + "link": "https://www.youtube.com/watch?v=HnkTrc1HC60", + "date": "2024-03-27", + "servant": "253", + "turns": "3T", + "runner": "Gartendrache" + }, + { + "title": "Ivan 3T", + "link": "https://www.youtube.com/watch?v=fkRfkKwOGg4", + "date": "2024-03-24", + "servant": "205", + "turns": "3T", + "runner": "rotankhero" + }, + { + "title": "Ivan 3T (FLO NDCE)", + "link": "https://www.youtube.com/watch?v=X6JMhUjizvY", + "date": "2024-03-27", + "servant": "205", + "turns": "3T", + "runner": "ProbablyAParrot" + }, + { + "title": "Red Hare 3T", + "link": "https://www.youtube.com/watch?v=QkeY-m2EPVM", + "date": "2024-03-27", + "servant": "231", + "turns": "3T", + "runner": "L11" + }, + { + "title": "Morgan 3T", + "link": "https://www.youtube.com/watch?v=qXqsBAgdjEc", + "date": "2024-03-24", + "servant": "309", + "turns": "3T", + "runner": "Sonicanimefan1" + }, + { + "title": "Morgan 3T", + "link": "https://www.youtube.com/watch?v=mkF973oq5JU", + "date": "2024-03-29", + "servant": "309", + "turns": "3T", + "runner": "SilverChaos" + }, + { + "title": "Arjuna Alter 3T", + "link": "https://www.youtube.com/watch?v=2ALsnvTHErw", + "date": "2024-03-30", + "servant": "247", + "turns": "3T", + "runner": "geens" + }, + { + "title": "Arjuna Alter 3T (FLO NoDupes)", + "link": "https://www.youtube.com/watch?v=M9uMA8zYZ3w", + "date": "2024-03-24", + "servant": "247", + "turns": "3T", + "runner": "Kusanagi" + }, + { + "title": "Arjuna Alter 3T (FLO NoCE)", + "link": "https://www.youtube.com/watch?v=1Eu1qwknSBY", + "date": "2024-04-06", + "servant": "247", + "turns": "3T", + "runner": "Sakazuki" + }, + { + "title": "Romulus 3T", + "link": "https://www.youtube.com/watch?v=QwXakPCGTQY", + "date": "2024-03-24", + "servant": "280", + "turns": "3T", + "runner": "First_TLN" + }, + { + "title": "Romulus 3T (F2P Support)", + "link": "https://www.youtube.com/watch?v=pJIUG1k9AZk", + "date": "2024-03-29", + "servant": "280", + "turns": "3T", + "runner": "Infernia Rosarum" + }, + { + "title": "Melusine 3T (w. Abby)", + "link": "https://www.youtube.com/watch?v=BpVSenM9bHY", + "date": "2024-03-24", + "servant": "312_aoe", + "turns": "3T", + "runner": "TopKirby8305" + }, + { + "title": "Melusine 3T (FLO)", + "link": "https://www.youtube.com/watch?v=H-vQOgCZ6sM", + "date": "2024-03-24", + "servant": "312_aoe", + "turns": "3T", + "runner": "Hentai Daddi" + }, + { + "title": "Melusine 3T (FLO NDCE)", + "link": "https://www.youtube.com/watch?v=13dXuoO9oaE", + "date": "2024-03-24", + "servant": "312_aoe", + "turns": "3T", + "runner": "TokuHer0" + }, + { + "title": "Vritra 3T (FLO)", + "link": "https://www.youtube.com/watch?v=PEqr6jTGEbM", + "date": "2024-03-25", + "servant": "300", + "turns": "3T", + "runner": "Tinesh" + }, + { + "title": "Ereshkigal 3T (FLO)", + "link": "https://twitter.com/yang_766/status/1774051778234839122", + "date": "2024-03-30", + "servant": "196", + "turns": "3T", + "runner": "yang_766" + } + ] + } + ] +} diff --git a/src/content/teslafest/eq-2020/finale-ii.json b/src/content/teslafest/eq-2020/finale-ii.json new file mode 100644 index 0000000..bf4eb2d --- /dev/null +++ b/src/content/teslafest/eq-2020/finale-ii.json @@ -0,0 +1,73 @@ +{ + "$schema": "../../../../.astro/collections/teslafest.schema.json", + "info": { + "title": "Grand Finale - The Golden Metropolis Returns", + "releaseDate": "2024-03-18", + "shortdescription": "The climax to the whole 2020 revival quests - let's have fun for one last round", + "releaseNumber": 7 + }, + "quests": [ + { + "questTitle": "Grand Finale - The Golden Metropolis Returns", + "description": "The climax to the whole 2020 revival quests - let's have fun for one last round", + "data": [ + { + "title": "Melusine 3T", + "link": "https://www.youtube.com/watch?v=jdzfh2L7C30", + "date": "2024-03-18", + "servant": "312_aoe", + "turns": "3T", + "runner": "TokuHer0" + }, + { + "title": "Ereshkigal 3T", + "link": "https://www.youtube.com/watch?v=xXppPoi6z7E", + "date": "2024-03-22", + "servant": "196", + "turns": "3T", + "runner": "Zectry" + }, + { + "title": "Romulus 3T (4man)", + "link": "https://www.youtube.com/watch?v=3H65DgMm2CQ", + "date": "2024-03-26", + "servant": "280", + "turns": "3T", + "runner": "Sakazuki" + }, + { + "title": "Morgan 3T", + "link": "https://www.youtube.com/watch?v=8cVyOWVxkKk", + "date": "2024-03-18", + "servant": "309", + "turns": "3T", + "runner": "Loki" + }, + { + "title": "Morgan 3T (No 5* Support)", + "link": "https://twitter.com/santoryuiai3/status/1770102234711273812", + "date": "2024-03-19", + "servant": "309", + "turns": "3T", + "runner": "Ray" + }, + { + "title": "Arjuna Alter 3T", + "link": "https://www.youtube.com/watch?v=Ts9kNHgVQCc", + "date": "2024-03-18", + "servant": "247", + "turns": "3T", + "runner": "Akise" + }, + { + "title": "Arjuna Alter 3T (5man)", + "link": "https://www.youtube.com/watch?v=fyAEETeNf8Q", + "date": "2024-03-24", + "servant": "247", + "turns": "3T", + "runner": "Sakazuki" + } + ] + } + ] +} diff --git a/src/content/teslafest/eq-2020/flame-gate.json b/src/content/teslafest/eq-2020/flame-gate.json new file mode 100644 index 0000000..5327dd4 --- /dev/null +++ b/src/content/teslafest/eq-2020/flame-gate.json @@ -0,0 +1,153 @@ +{ + "$schema": "../../../../.astro/collections/teslafest.schema.json", + "info": { + "title": "Flame Gate", + "releaseDate": "2024-03-15", + "shortdescription": "Time for Leonidas to show how tough the 300 really are - be advised to bring some kind of defense ignore", + "releaseNumber": 2 + }, + "quests": [ + { + "questTitle": "Flame Gate", + "description": "Time for Leonidas to show how tough the 300 really are - be advised to bring some kind of defense ignore", + "data": [ + { + "title": "Artoria 2T", + "link": "https://www.youtube.com/watch?v=GIk9UhjgO8w", + "date": "2024-03-15", + "servant": "2", + "turns": "2T", + "runner": "First_TLN" + }, + { + "title": "Altera 2T", + "link": "https://www.youtube.com/watch?v=dMOj81oyQi4", + "date": "2024-03-17", + "servant": "8", + "turns": "2T", + "runner": "Requiem" + }, + { + "title": "Okita 2T (w. Helena & Arash)", + "link": "https://www.youtube.com/watch?v=mJq61IjuaR4", + "date": "2024-03-18", + "servant": "68", + "turns": "2T", + "runner": "Nyxi" + }, + { + "title": "Okita 2T (w. Nitocris & Taigong Wang)", + "link": "https://www.youtube.com/watch?v=tuJrX2gxiTE", + "date": "2024-03-17", + "servant": "68", + "turns": "2T", + "runner": "Zectry" + }, + { + "title": "Musashi 2T (w. Morgan)", + "link": "https://twitter.com/santoryuiai3/status/1769165469427118302", + "date": "2024-03-17", + "servant": "153", + "turns": "2T", + "runner": "Ray" + }, + { + "title": "Muramasa 2T", + "link": "https://www.youtube.com/watch?v=R2spWJxXSfY", + "date": "2024-03-16", + "servant": "302", + "turns": "2T", + "runner": "Loki" + }, + { + "title": "Ibuki 2T (NDCE)", + "link": "https://www.youtube.com/watch?v=SRNv98fujUQ", + "date": "2024-03-15", + "servant": "299", + "turns": "2T", + "runner": "inv4der" + }, + { + "title": "Barghest 2T", + "link": "https://www.youtube.com/watch?v=5WMt8kf_loE", + "date": "2024-03-15", + "servant": "310", + "turns": "2T", + "runner": "Kusanagi" + }, + { + "title": "Okita Alter (Summer) 2T", + "link": "https://www.youtube.com/watch?v=CiLA1lHd_E4", + "date": "2024-03-17", + "servant": "317", + "turns": "2T", + "runner": "TokuHer0" + }, + { + "title": "Nero 2T", + "link": "https://www.youtube.com/watch?v=Yfop1b4o1Us", + "date": "2024-03-20", + "servant": "5", + "turns": "2T", + "runner": "Lutrec" + }, + { + "title": "Romulus 2T (NDCE)", + "link": "https://www.youtube.com/watch?v=EhOEeDYidrM", + "date": "2024-03-18", + "servant": "280", + "turns": "2T", + "runner": "Sakazuki" + }, + { + "title": "Melusine 2T", + "link": "https://www.youtube.com/watch?v=bRfdcSstPLE", + "date": "2024-03-17", + "servant": "312_aoe", + "turns": "2T", + "runner": "Hentai Daddi" + }, + { + "title": "Ereshkigal 2T", + "link": "https://www.youtube.com/watch?v=NriopMKja-w", + "date": "2024-03-15", + "servant": "196", + "turns": "2T", + "runner": "Swarmlord2" + }, + { + "title": "Morgan 2T", + "link": "https://www.youtube.com/watch?v=rREch6zsjGI", + "date": "2024-03-16", + "servant": "309", + "turns": "2T", + "runner": "Gorgeous P." + }, + { + "title": "Morgan 2T (NDCE)", + "link": "https://twitter.com/santoryuiai3/status/1768687213921874128", + "date": "2024-03-15", + "servant": "309", + "turns": "2T", + "runner": "Ray" + }, + { + "title": "Arjuna Alter 2T (NDCE 4man)", + "link": "https://www.youtube.com/watch?v=3ev0cmERbtA", + "date": "2024-03-17", + "servant": "247", + "turns": "2T", + "runner": "Sakazuki" + }, + { + "title": "Jalter 2T (w. Morgan & Oberon)", + "link": "https://twitter.com/santoryuiai3/status/1768813813468373494", + "date": "2024-03-16", + "servant": "106", + "turns": "2T", + "runner": "Ray" + } + ] + } + ] +} diff --git a/src/content/teslafest/eq-2020/jaguar-forest.json b/src/content/teslafest/eq-2020/jaguar-forest.json new file mode 100644 index 0000000..c6a2e16 --- /dev/null +++ b/src/content/teslafest/eq-2020/jaguar-forest.json @@ -0,0 +1,225 @@ +{ + "$schema": "../../../../.astro/collections/teslafest.schema.json", + "info": { + "title": "Welcome to Jaguar Country", + "releaseDate": "2024-03-16", + "shortdescription": "When you step foot into Jaguar territory, you either leave alive or you don't at all - which will it be?", + "releaseNumber": 4 + }, + "quests": [ + { + "questTitle": "Welcome to Jaguar Country", + "description": "When you step foot into Jaguar territory, you either leave alive or you don't at all - which will it be?", + "data": [ + { + "title": "Artoria 2T", + "link": "https://www.youtube.com/watch?v=gpX3D4iQcVo", + "date": "2024-03-16", + "servant": "2", + "turns": "2T", + "runner": "Tinesh" + }, + { + "title": "Saber Alter 2T", + "link": "https://www.youtube.com/watch?v=0fco4_aaahw", + "date": "2024-03-18", + "servant": "3", + "turns": "2T", + "runner": "Lyud" + }, + { + "title": "Barghest 2T", + "link": "https://www.youtube.com/watch?v=lkgA_qV9IrA", + "date": "2024-03-16", + "servant": "310", + "turns": "2T", + "runner": "Kusanagi" + }, + { + "title": "Nero 2T", + "link": "https://www.youtube.com/watch?v=Rn25x0ZonVs", + "date": "2024-03-24", + "servant": "5", + "turns": "2T", + "runner": "Lutrec" + }, + { + "title": "Romulus 2T (FLO NDCE)", + "link": "https://www.youtube.com/watch?v=pd-uY8F4iVM", + "date": "2024-03-20", + "servant": "280", + "turns": "2T", + "runner": "Sakazuki" + }, + { + "title": "Ereshkigal 2T", + "link": "https://www.youtube.com/watch?v=_GbNnxxpS0M", + "date": "2024-03-19", + "servant": "196", + "turns": "2T", + "runner": "Anthony J" + }, + { + "title": "Melusine 2T", + "link": "https://www.youtube.com/watch?v=zIo0O92S7Us", + "date": "2024-03-16", + "servant": "312_aoe", + "turns": "2T", + "runner": "Hentai Daddi" + }, + { + "title": "Melusine 2T", + "link": "https://www.youtube.com/watch?v=9nDmoHc-eig", + "date": "2024-03-17", + "servant": "312_aoe", + "turns": "2T", + "runner": "Sesshou01" + }, + { + "title": "Melusine 2T", + "link": "https://www.youtube.com/watch?v=yookE0tGeZA", + "date": "2024-03-17", + "servant": "312_aoe", + "turns": "2T", + "runner": "TokuHer0" + }, + { + "title": "Melt Lambda 2T", + "link": "https://www.youtube.com/watch?v=5ykZzT3qTN4", + "date": "2024-03-16", + "servant": "266", + "turns": "2T", + "runner": "inv4der" + }, + { + "title": "Karna 2T", + "link": "https://www.youtube.com/watch?v=o4gZZtTxszs", + "date": "2024-03-24", + "servant": "85", + "turns": "2T", + "runner": "Blocklv55" + }, + { + "title": "Janta 2T", + "link": "https://www.youtube.com/watch?v=PtiKVcoMRNs", + "date": "2024-03-20", + "servant": "141", + "turns": "2T", + "runner": "Zectry" + }, + { + "title": "Arjuna Alter 2T", + "link": "https://www.youtube.com/watch?v=3CSggM4lARY", + "date": "2024-03-16", + "servant": "247", + "turns": "2T", + "runner": "First_TLN" + }, + { + "title": "Arjuna Alter 2T (FLO)", + "link": "https://www.youtube.com/watch?v=JYM7ZnZNo2U", + "date": "2024-03-16", + "servant": "247", + "turns": "2T", + "runner": "Ray the II" + }, + { + "title": "Arjuna Alter 2T (FLO NDCE)", + "link": "https://www.youtube.com/watch?v=Pyh4X2SQwGo", + "date": "2024-03-16", + "servant": "247", + "turns": "2T", + "runner": "Akise" + }, + { + "title": "Morgan 2T", + "link": "https://www.youtube.com/watch?v=wD34eiRINXg&t=190s", + "date": "2024-03-16", + "servant": "309", + "turns": "2T", + "runner": "Liz Happy Club" + }, + { + "title": "Morgan 2T", + "link": "https://www.youtube.com/watch?v=NlJmc2-6rs8", + "date": "2024-03-21", + "servant": "309", + "turns": "2T", + "runner": "Nyxi" + }, + { + "title": "Morgan 2T", + "link": "https://www.youtube.com/watch?v=sNvNP5N-RUU", + "date": "2024-03-17", + "servant": "309", + "turns": "2T", + "runner": "Duplexubiquitary" + }, + { + "title": "Morgan 2T", + "link": "https://www.youtube.com/watch?v=5bgJZs-ryCQ", + "date": "2024-03-17", + "servant": "309", + "turns": "2T", + "runner": "Gorgeous P." + }, + { + "title": "Morgan 2T (FLO)", + "link": "https://www.youtube.com/watch?v=SB8X13BhLJY", + "date": "2024-03-17", + "servant": "309", + "turns": "2T", + "runner": "Volcanicz" + }, + { + "title": "Morgan 2T (19 Cost)", + "link": "https://www.youtube.com/watch?v=tRGrSlgq2Pc", + "date": "2024-03-17", + "servant": "309", + "turns": "2T", + "runner": "Loki" + }, + { + "title": "Maou Nobu 2T", + "link": "https://www.youtube.com/watch?v=V6wHrLHDQ50", + "date": "2024-03-21", + "servant": "250", + "turns": "2T", + "runner": "SigrdrΓfa" + }, + { + "title": "Summer Kama 2T", + "link": "https://www.youtube.com/watch?v=CfJha9gPuOM", + "date": "2024-03-19", + "servant": "321", + "turns": "2T", + "runner": "Kamager III" + }, + { + "title": "Koyanskaya of Darkness 2T (NDCE)", + "link": "https://www.youtube.com/watch?v=XnLoGdfscT8", + "date": "2024-03-20", + "servant": "334", + "turns": "2T", + "runner": "Alastair Hale" + }, + { + "title": "Summer BB 2T", + "link": "https://www.youtube.com/watch?v=bE75VZ8Mh9w", + "date": "2024-03-19", + "servant": "220", + "turns": "2T", + "runner": "Zoropp" + }, + { + "title": "Scathach 4T", + "link": "https://www.youtube.com/watch?v=9JR-gz5RcpI", + "date": "2024-03-17", + "servant": "70", + "turns": "4T", + "runner": "Requiem" + } + ] + } + ] +} diff --git a/src/content/teslafest/eq-2020/pawn-shop.json b/src/content/teslafest/eq-2020/pawn-shop.json new file mode 100644 index 0000000..2972a78 --- /dev/null +++ b/src/content/teslafest/eq-2020/pawn-shop.json @@ -0,0 +1,33 @@ +{ + "$schema": "../../../../.astro/collections/teslafest.schema.json", + "info": { + "title": "Moolah's Pawn Shop", + "releaseDate": "2024-03-17", + "shortdescription": "Time to first borrow and then return gifts with interests - Sheba won't be pleased", + "releaseNumber": 5 + }, + "quests": [ + { + "questTitle": "Moolah's Pawn Shop", + "description": "Time to first borrow and then return gifts with interests - Sheba won't be pleased", + "data": [ + { + "title": "Ozymandias 5T", + "link": "https://www.youtube.com/watch?v=5FotXqLi8eA", + "date": "2024-03-21", + "servant": "118", + "turns": "5T", + "runner": "Zectry" + }, + { + "title": "Cindereli 5T", + "link": "https://www.youtube.com/watch?v=B8gWE4c8qM0", + "date": "2024-03-21", + "servant": "326", + "turns": "5T", + "runner": "Sakazuki" + } + ] + } + ] +} diff --git a/src/content/teslafest/eq-2020/rice-ball-shop.json b/src/content/teslafest/eq-2020/rice-ball-shop.json new file mode 100644 index 0000000..0a91157 --- /dev/null +++ b/src/content/teslafest/eq-2020/rice-ball-shop.json @@ -0,0 +1,217 @@ +{ + "$schema": "../../../../.astro/collections/teslafest.schema.json", + "info": { + "title": "Rice Ball Franchise Shop No. 1", + "releaseDate": "2024-03-15", + "shortdescription": "Eating and giving out food can be a really nice thing - especially when it buffs your attacks <3", + "releaseNumber": 1 + }, + "quests": [ + { + "questTitle": "Rice Ball Franchise Shop No. 1", + "description": "Eating and giving out food can be a really nice thing - especially when it buffs your attacks <3", + "data": [ + { + "title": "Tamamo (Summer) 2T", + "link": "https://www.youtube.com/watch?v=wbV0VkxkgVo", + "date": "2024-03-15", + "servant": "128", + "turns": "2T", + "runner": "Liz Happy Club" + }, + { + "title": "Brynhild 2T (NDCE)", + "link": "https://www.youtube.com/watch?v=Kme2sdkMvBo", + "date": "2024-03-18", + "servant": "88", + "turns": "2T", + "runner": "SigrdrΓfa" + }, + { + "title": "Melusine 2T", + "link": "https://www.youtube.com/watch?v=YXUwwY0e5Uw", + "date": "2024-03-16", + "servant": "312_st", + "turns": "2T", + "runner": "Sesshou01" + }, + { + "title": "Melusine 2T (FLO)", + "link": "https://www.youtube.com/watch?v=YXUwwY0e5Uw", + "date": "2024-03-15", + "servant": "312_st", + "turns": "2T", + "runner": "Hentai Daddi" + }, + { + "title": "Kagetora 2T", + "link": "https://www.youtube.com/watch?v=aU8Y8lpc12s", + "date": "2024-03-16", + "servant": "252", + "turns": "2T", + "runner": "Tinesh" + }, + { + "title": "Scathach 2T (NDCE)", + "link": "https://www.youtube.com/watch?v=I4dGfI8K2Xo", + "date": "2024-03-17", + "servant": "70", + "turns": "2T", + "runner": "Requiem" + }, + { + "title": "Enkidu 2T (4man)", + "link": "https://www.youtube.com/watch?v=k68VDhh480Y", + "date": "2024-03-16", + "servant": "143", + "turns": "2T", + "runner": "Ise(Kai)" + }, + { + "title": "Enkidu 2T (NDCE)", + "link": "https://www.youtube.com/watch?v=NUBljJdeN4U", + "date": "2024-03-22", + "servant": "143", + "turns": "2T", + "runner": "Alastair Hale" + }, + { + "title": "Kiyohime (Summer) 2T", + "link": "https://www.youtube.com/watch?v=JUTlUlRV2Fs", + "date": "2024-03-16", + "servant": "134", + "turns": "2T", + "runner": "Gorgeous P." + }, + { + "title": "Taiga 2T", + "link": "https://www.youtube.com/watch?v=JOvEqH81VbU", + "date": "2024-03-18", + "servant": "148", + "turns": "2T", + "runner": "Taiga" + }, + { + "title": "Taiga 2T", + "link": "https://www.youtube.com/watch?v=HxLOn7QlRTA", + "date": "2024-03-16", + "servant": "148", + "turns": "2T", + "runner": "Ray the II" + }, + { + "title": "Romulus 2T (FLO)", + "link": "https://www.youtube.com/watch?v=AfggRidr_Uo", + "date": "2024-03-17", + "servant": "280", + "turns": "2T", + "runner": "Sakazuki" + }, + { + "title": "Ereshkigal 2T", + "link": "https://www.youtube.com/watch?v=9FobAzm8ZHY", + "date": "2024-03-17", + "servant": "196", + "turns": "2T", + "runner": "TokuHer0" + }, + { + "title": "Ereshkigal 2T (NoCE)", + "link": "https://www.youtube.com/watch?v=M_tf5DuvvTI", + "date": "2024-03-17", + "servant": "196", + "turns": "2T", + "runner": "Swarmlord2" + }, + { + "title": "Karna 2T (4man)", + "link": "https://www.youtube.com/watch?v=ZZdQE_el_SA", + "date": "2024-04-07", + "servant": "85", + "turns": "2T", + "runner": "Akise" + }, + { + "title": "Summer Yu 2T", + "link": "https://www.youtube.com/watch?v=62vkxTWUBIY", + "date": "2024-03-18", + "servant": "288", + "turns": "2T", + "runner": "Lyud" + }, + { + "title": "Summer Yu 2T", + "link": "https://www.youtube.com/watch?v=59BXpBG84OU", + "date": "2024-03-16", + "servant": "288", + "turns": "2T", + "runner": "Kamager III" + }, + { + "title": "Summer Yu 2T", + "link": "https://www.youtube.com/watch?v=aGQ3RuG_-RM", + "date": "2024-03-23", + "servant": "288", + "turns": "2T", + "runner": "Nyxi" + }, + { + "title": "Melt Lambda 2T", + "link": "https://www.youtube.com/watch?v=uFOcbGj5yzc", + "date": "2024-03-16", + "servant": "266", + "turns": "2T", + "runner": "Zectry" + }, + { + "title": "Ozymandias 2T", + "link": "https://www.youtube.com/watch?v=l9TuRq4WD2o", + "date": "2024-03-15", + "servant": "118", + "turns": "2T", + "runner": "Kusanagi" + }, + { + "title": "Arjuna Alter 2T (FLO)", + "link": "https://www.youtube.com/watch?v=EBtlKA8Zebc", + "date": "2024-03-16", + "servant": "247", + "turns": "2T", + "runner": "Sakazuki" + }, + { + "title": "Morgan 2T (FLO)", + "link": "https://www.youtube.com/watch?v=qHPczHi65Ps", + "date": "2024-03-15", + "servant": "309", + "turns": "2T", + "runner": "Loki" + }, + { + "title": "MHXA 2T", + "link": "https://www.youtube.com/watch?v=HohUbwoU5DE", + "date": "2024-03-18", + "servant": "155", + "turns": "2T", + "runner": "Anthony J" + }, + { + "title": "Cu Alter 2T (4man)", + "link": "https://www.youtube.com/watch?v=IDkaXVUVMm4", + "date": "2024-03-15", + "servant": "98", + "turns": "2T", + "runner": "Volcanicz" + }, + { + "title": "Da Vinci Ruler 2T", + "link": "https://twitter.com/LutrecTA/status/1769450074822574261", + "date": "2024-03-17", + "servant": "320", + "turns": "2T", + "runner": "Lutrec" + } + ] + } + ] +} diff --git a/src/content/teslafest/eq-2020/skyscraper-monster.json b/src/content/teslafest/eq-2020/skyscraper-monster.json new file mode 100644 index 0000000..d16671c --- /dev/null +++ b/src/content/teslafest/eq-2020/skyscraper-monster.json @@ -0,0 +1,233 @@ +{ + "$schema": "../../../../.astro/collections/teslafest.schema.json", + "info": { + "title": "Skyscraper Monster", + "releaseDate": "2024-03-16", + "shortdescription": "A rogue assassin has been spotted that randomly onecrits servants - time to stop him as fast as possible", + "releaseNumber": 3 + }, + "quests": [ + { + "questTitle": "Skyscraper Monster", + "description": "A rogue assassin has been spotted that randomly onecrits servants - time to stop him as fast as possible", + "data": [ + { + "title": "Baobhan Sith 2T", + "link": "https://www.youtube.com/watch?v=KgM20h_Y3d0", + "date": "2024-03-17", + "servant": "311", + "turns": "2T", + "runner": "Requiem" + }, + { + "title": "Sei 2T", + "link": "https://www.youtube.com/watch?v=2XgPUSHqvck", + "date": "2024-03-17", + "servant": "276", + "turns": "2T", + "runner": "inv4der" + }, + { + "title": "Melusine 2T (FLO)", + "link": "https://www.youtube.com/watch?v=RiBu3tNtimU", + "date": "2024-03-17", + "servant": "312_st", + "turns": "2T", + "runner": "TokuHer0" + }, + { + "title": "Romulus 2T (NoCE)", + "link": "https://www.youtube.com/watch?v=0DAcqHq9xdU", + "date": "2024-03-19", + "servant": "280", + "turns": "2T", + "runner": "Sakazuki" + }, + { + "title": "Ereshkigal 2T", + "link": "https://www.youtube.com/watch?v=tmVdPXf7LbU", + "date": "2024-03-17", + "servant": "196", + "turns": "2T", + "runner": "Conry" + }, + { + "title": "Izumo no Okuni 2T", + "link": "https://www.youtube.com/watch?v=YE5SNty6Ci8", + "date": "2024-03-16", + "servant": "327", + "turns": "2T", + "runner": "Kamager III" + }, + { + "title": "Izumo no Okuni 2T (10Cost)", + "link": "https://www.youtube.com/watch?v=of5avLvMihw", + "date": "2024-03-18", + "servant": "327", + "turns": "2T", + "runner": "inv4der" + }, + { + "title": "Illya 2T (FLO)", + "link": "https://www.youtube.com/watch?v=hSzGgc1mP-U", + "date": "2024-03-22", + "servant": "136", + "turns": "2T", + "runner": "Zoropp" + }, + { + "title": "Nero Caster 2T (FLO NoCE)", + "link": "https://twitter.com/LutrecTA/status/1769746018113831158", + "date": "2024-03-18", + "servant": "175", + "turns": "2T", + "runner": "Lutrec" + }, + { + "title": "Shuten Caster 2T", + "link": "https://www.youtube.com/watch?v=y0Cls8YiWeI", + "date": "2024-03-17", + "servant": "225", + "turns": "2T", + "runner": "Tinesh" + }, + { + "title": "Merlin 2T", + "link": "https://www.youtube.com/watch?v=IXx86fVnbSk", + "date": "2024-03-16", + "servant": "150", + "turns": "2T", + "runner": "Volcanicz" + }, + { + "title": "Merlin 2T", + "link": "https://www.youtube.com/watch?v=yHGt8CQ2Rs8", + "date": "2024-03-18", + "servant": "150", + "turns": "2T", + "runner": "Ise(Kai)" + }, + { + "title": "Skadi 2T", + "link": "https://www.youtube.com/watch?v=aSTr2G7IW_M", + "date": "2024-03-17", + "servant": "215", + "turns": "2T", + "runner": "Firq" + }, + { + "title": "Castoria 2T", + "link": "https://www.youtube.com/watch?v=NG7iI5febaQ", + "date": "2024-03-21", + "servant": "284", + "turns": "2T", + "runner": "Loki" + }, + { + "title": "Miss Crane 2T (FLO)", + "link": "https://www.youtube.com/watch?v=ymjOgTgmnPQ", + "date": "2024-03-18", + "servant": "307", + "turns": "2T", + "runner": "QP Dangerous" + }, + { + "title": "Hans 2T", + "link": "https://www.youtube.com/watch?v=nZftQeoFBds", + "date": "2024-03-18", + "servant": "33", + "turns": "2T", + "runner": "Zectry" + }, + { + "title": "Jekyll & Hyde 2T", + "link": "https://www.youtube.com/watch?v=v_s7mKBWNyc", + "date": "2024-03-18", + "servant": "81", + "turns": "2T", + "runner": "Rikohaiji" + }, + { + "title": "Arjuna Alter 2T (FLO)", + "link": "https://www.youtube.com/watch?v=iWYMM6C3vbQ", + "date": "2024-03-19", + "servant": "247", + "turns": "2T", + "runner": "Sakazuki" + }, + { + "title": "Arjuna Alter 2T (FLO NDCE)", + "link": "https://www.youtube.com/watch?v=0A1B2Yc_NVw", + "date": "2024-03-19", + "servant": "247", + "turns": "2T", + "runner": "Sakazuki" + }, + { + "title": "Morgan 2T (FLO NDCE)", + "link": "https://www.youtube.com/watch?v=susehGkuxfQ", + "date": "2024-03-16", + "servant": "309", + "turns": "2T", + "runner": "Volcanicz" + }, + { + "title": "Morgan 2T (FLO NoCE NoNP)", + "link": "https://www.youtube.com/watch?v=lA_t9fNV6Nk", + "date": "2024-03-16", + "servant": "309", + "turns": "2T", + "runner": "Loki" + }, + { + "title": "Summer Jalter 2T (FLO)", + "link": "https://www.youtube.com/watch?v=PKrPJNndlW0", + "date": "2024-03-16", + "servant": "219", + "turns": "2T", + "runner": "Kusanagi" + }, + { + "title": "Summer Sei 2T", + "link": "https://www.youtube.com/watch?v=QZpVNKGouyg", + "date": "2024-03-16", + "servant": "323", + "turns": "2T", + "runner": "Ise(Kai)" + }, + { + "title": "Tamamo Cat 2T (FLO)", + "link": "https://www.youtube.com/watch?v=_VhJwYMiUB4", + "date": "2024-03-19", + "servant": "58", + "turns": "2T", + "runner": "Rikohaiji" + }, + { + "title": "Cu Alter 2T (FLO)", + "link": "https://www.youtube.com/watch?v=EcoE7REerfg", + "date": "2024-03-16", + "servant": "98", + "turns": "2T", + "runner": "Ryougi Bobby" + }, + { + "title": "Taira 2T", + "link": "https://www.youtube.com/watch?v=XuM9Eq2CZJY", + "date": "2024-03-16", + "servant": "303", + "turns": "2T", + "runner": "Anthony J" + }, + { + "title": "Okita Alter 2T", + "link": "https://www.youtube.com/watch?v=7j03DlcgHIE", + "date": "2024-03-16", + "servant": "209", + "turns": "2T", + "runner": "Blocklv55" + } + ] + } + ] +} diff --git a/src/content/teslafest/eq-2020/sweet-universe.json b/src/content/teslafest/eq-2020/sweet-universe.json new file mode 100644 index 0000000..b22bca9 --- /dev/null +++ b/src/content/teslafest/eq-2020/sweet-universe.json @@ -0,0 +1,257 @@ +{ + "$schema": "../../../../.astro/collections/teslafest.schema.json", + "info": { + "title": "Sweets Universe", + "releaseDate": "2024-03-17", + "shortdescription": "Ah, a berserker enemy with .... 10 MILLION HP?????? Welp, time to burst this in a single turn", + "releaseNumber": 6 + }, + "quests": [ + { + "questTitle": "Sweets Universe", + "description": "Ah, a berserker enemy with .... 10 MILLION HP?????? Welp, time to burst this in a single turn", + "data": [ + { + "title": "Maou Nobu 3T", + "link": "https://www.youtube.com/watch?v=bdimFAP0cXc", + "date": "2024-03-17", + "servant": "250", + "turns": "3T", + "runner": "Ray the II" + }, + { + "title": "Musashi 2T", + "link": "https://www.youtube.com/watch?v=S3omeS0AYgo", + "date": "2024-03-24", + "servant": "153", + "turns": "2T", + "runner": "Sunder" + }, + { + "title": "Musashi 2T (NDCE)", + "link": "https://www.youtube.com/watch?v=ybK4XV7v7e0", + "date": "2024-03-27", + "servant": "153", + "turns": "2T", + "runner": "Zectry" + }, + { + "title": "Ibuki 2T", + "link": "https://www.youtube.com/watch?v=VLgnnmx4D7g", + "date": "2024-03-17", + "servant": "299", + "turns": "2T", + "runner": "inv4der" + }, + { + "title": "Saber Alter 2T", + "link": "https://www.youtube.com/watch?v=KNEK2fL-ptw", + "date": "2024-03-24", + "servant": "3", + "turns": "2T", + "runner": "Shawn Sun" + }, + { + "title": "Nero Bride 2T (w. Casgil & Medb)", + "link": "https://www.youtube.com/watch?v=1Blot2gjslw", + "date": "2024-04-11", + "servant": "90", + "turns": "2T", + "runner": "Zectry" + }, + { + "title": "Romulus 2T (NDCE)", + "link": "https://www.youtube.com/watch?v=ltv8Cr0GPPg", + "date": "2024-03-22", + "servant": "280", + "turns": "2T", + "runner": "Sakazuki" + }, + { + "title": "Melusine 2T", + "link": "https://www.youtube.com/watch?v=QtofiRzGGXw", + "date": "2024-03-17", + "servant": "312_aoe", + "turns": "2T", + "runner": "Hentai Daddi" + }, + { + "title": "Melusine 2T", + "link": "https://www.youtube.com/watch?v=v9TIfEXx_HU", + "date": "2024-03-17", + "servant": "312_aoe", + "turns": "2T", + "runner": "Felt" + }, + { + "title": "Melusine 2T", + "link": "https://www.youtube.com/watch?v=LKX3jLg57q4", + "date": "2024-03-17", + "servant": "312_aoe", + "turns": "2T", + "runner": "TokuHer0" + }, + { + "title": "Melusine 2T", + "link": "https://www.youtube.com/watch?v=TRwF6JU4BEQ", + "date": "2024-03-17", + "servant": "312_aoe", + "turns": "2T", + "runner": "Zectry" + }, + { + "title": "Karna 2T", + "link": "https://www.youtube.com/watch?v=CqQcZFWZwCk", + "date": "2024-03-17", + "servant": "85", + "turns": "2T", + "runner": "Akise" + }, + { + "title": "Scathach 2T", + "link": "https://www.youtube.com/watch?v=_mKuvVL7KtU", + "date": "2024-03-17", + "servant": "70", + "turns": "2T", + "runner": "Requiem" + }, + { + "title": "Ozymandias 2T", + "link": "https://www.youtube.com/watch?v=3n-OPY99Qcw", + "date": "2024-03-17", + "servant": "118", + "turns": "2T", + "runner": "Kusanagi" + }, + { + "title": "Illya 2T", + "link": "https://www.youtube.com/watch?v=S7VWJyJWRd8", + "date": "2024-03-22", + "servant": "136", + "turns": "2T", + "runner": "MCR" + }, + { + "title": "Charlotte Summer 2T", + "link": "https://www.youtube.com/watch?v=_Bok9VXgRmA", + "date": "2024-03-17", + "servant": "319", + "turns": "2T", + "runner": "Dante" + }, + { + "title": "MHX 2T", + "link": "https://www.youtube.com/watch?v=GGnzoHtHGbs", + "date": "2024-03-17", + "servant": "86", + "turns": "2T", + "runner": "Ayumi" + }, + { + "title": "Koyanskaya of Light 2T", + "link": "https://www.youtube.com/watch?v=HfQte4l549A", + "date": "2024-03-27", + "servant": "314", + "turns": "2T", + "runner": "Zectry" + }, + { + "title": "Arjuna Alter 2T", + "link": "https://www.youtube.com/watch?v=8xsxfCBv4FE", + "date": "2024-03-22", + "servant": "247", + "turns": "2T", + "runner": "Sakazuki" + }, + { + "title": "Morgan 2T", + "link": "https://www.youtube.com/watch?v=eDZr8a2BrZs", + "date": "2024-03-22", + "servant": "309", + "turns": "2T", + "runner": "Ray" + }, + { + "title": "Cu Alter 2T", + "link": "https://www.youtube.com/watch?v=6cMEXtmgBTM", + "date": "2024-03-22", + "servant": "98", + "turns": "2T", + "runner": "Volcanicz" + }, + { + "title": "Astrea 2T (NDCE)", + "link": "https://www.youtube.com/watch?v=PAsyKNWPsfg", + "date": "2024-03-28", + "servant": "242", + "turns": "2T", + "runner": "Alastair Hale" + }, + { + "title": "Da Vinci Ruler 2T", + "link": "https://twitter.com/LutrecTA/status/1770049305702813787", + "date": "2024-03-19", + "servant": "320", + "turns": "2T", + "runner": "Lutrec" + }, + { + "title": "Jalter 2T (w. Elizabeth)", + "link": "https://www.youtube.com/watch?v=iwVJRGk-tO4", + "date": "2024-03-18", + "servant": "106", + "turns": "2T", + "runner": "Ray the II" + }, + { + "title": "Jalter 2T", + "link": "https://www.youtube.com/watch?v=m7OBOU7DBk4", + "date": "2024-03-17", + "servant": "106", + "turns": "2T", + "runner": "Ray" + }, + { + "title": "Jalter 2T (NoCE)", + "link": "https://twitter.com/santoryuiai3/status/1770250552619814933", + "date": "2024-03-20", + "servant": "106", + "turns": "2T", + "runner": "Ray" + }, + { + "title": "Taira 2T", + "link": "https://www.youtube.com/watch?v=EgfPk-cSXus", + "date": "2024-03-17", + "servant": "303", + "turns": "2T", + "runner": "Felt" + }, + { + "title": "Space Ishtar 2T", + "link": "https://www.youtube.com/watch?v=lWlcu4W_4Go", + "date": "2024-03-21", + "servant": "268", + "turns": "2T", + "runner": "Nirrin" + }, + { + "title": "Koyanskaya of Darkness 2T", + "link": "https://www.youtube.com/watch?v=3zydh0QEmu0", + "date": "2024-03-19", + "servant": "334", + "turns": "2T", + "runner": "Alastair Hale" + }, + { + "title": "Abby 2T", + "link": "https://www.youtube.com/watch?v=FftWUVnah2I", + "date": "2024-03-19", + "servant": "195", + "turns": "2T", + "runner": "Sol Sovereign" + } + ] + } + ] +} diff --git a/src/content/teslafest/eq-2021/bewitched.json b/src/content/teslafest/eq-2021/bewitched.json new file mode 100644 index 0000000..c9ddf6b --- /dev/null +++ b/src/content/teslafest/eq-2021/bewitched.json @@ -0,0 +1,241 @@ +{ + "$schema": "../../../../.astro/collections/teslafest.schema.json", + "info": { + "title": "BE-Witched (Curse)", + "releaseDate": "2024-03-19", + "shortdescription": "Now now, how to deal with a Eric charmed and cheered on by the love of his life?", + "releaseNumber": 2 + }, + "quests": [ + { + "questTitle": "BE-Witched (Curse)", + "description": "Now now, how to deal with a Eric charmed and cheered on by the love of his life?", + "data": [ + { + "title": "Sigurd 3T (NoCE)", + "link": "https://www.youtube.com/watch?v=rpeRrBzZ8y4", + "date": "2024-03-22", + "servant": "213", + "turns": "3T", + "runner": "ProbablyAParrot" + }, + { + "title": "Nero Bride 3T (F2P Support)", + "link": "https://www.youtube.com/watch?v=DpUiSyzOyXQ", + "date": "2024-03-25", + "servant": "90", + "turns": "3T", + "runner": "Infernia Rosarum" + }, + { + "title": "Nero Bride 3T (Lvl. 2)", + "link": "https://twitter.com/LutrecTA/status/1771177568747635118", + "date": "2024-03-22", + "servant": "90", + "turns": "3T", + "runner": "Lutrec" + }, + { + "title": "Gilgamesh 3T", + "link": "https://www.youtube.com/watch?v=q6yMWO2LFUM", + "date": "2024-03-20", + "servant": "12", + "turns": "3T", + "runner": "Gorgeous P." + }, + { + "title": "Fujino 3T", + "link": "https://www.youtube.com/watch?v=CFlUil7cXqE", + "date": "2024-03-25", + "servant": "200", + "turns": "3T", + "runner": "Blocklv55" + }, + { + "title": "Baobhan Sith 3T", + "link": "https://www.youtube.com/watch?v=6whjNuNHnnI", + "date": "2024-03-24", + "servant": "311", + "turns": "3T", + "runner": "Nyxi" + }, + { + "title": "Summer Illya 3T", + "link": "https://www.youtube.com/watch?v=wVloyS4HwSo", + "date": "2024-03-21", + "servant": "286", + "turns": "3T", + "runner": "zoropp" + }, + { + "title": "Brynhild 3T (NoCE)", + "link": "https://www.youtube.com/watch?v=gVusXCtt0g8", + "date": "2024-03-21", + "servant": "88", + "turns": "3T", + "runner": "SigrdrΓfa" + }, + { + "title": "Romulus 3T (3 Cost)", + "link": "https://www.youtube.com/watch?v=O9COj4g60-M", + "date": "2024-03-28", + "servant": "280", + "turns": "3T", + "runner": "Sakazuki" + }, + { + "title": "Melusine 3T (Lvl. 1)", + "link": "https://www.youtube.com/watch?v=WH7G1uBtEHk", + "date": "2024-03-22", + "servant": "312_st", + "turns": "3T", + "runner": "Zectry" + }, + { + "title": "Taiga 3T", + "link": "https://www.youtube.com/watch?v=V95BpzpFWoI", + "date": "2024-03-25", + "servant": "148", + "turns": "3T", + "runner": "Taiga" + }, + { + "title": "Ozymandias 3T (FLO NoCE)", + "link": "https://www.youtube.com/watch?v=H7zBBN7RUXo", + "date": "2024-03-19", + "servant": "118", + "turns": "3T", + "runner": "Kusanagi" + }, + { + "title": "Summer Caenis 3T (FLO)", + "link": "https://www.youtube.com/watch?v=dfOFE-vF-vI", + "date": "2024-03-20", + "servant": "322", + "turns": "3T", + "runner": "Kamager III" + }, + { + "title": "Rider Ishtar 3T", + "link": "https://www.youtube.com/watch?v=_IpVYgtMOqI", + "date": "2024-03-22", + "servant": "182", + "turns": "3T", + "runner": "Volcanicz" + }, + { + "title": "Sanzang 3T", + "link": "https://www.youtube.com/watch?v=BdpfqnGsCyA&t=224s", + "date": "2024-03-19", + "servant": "113", + "turns": "3T", + "runner": "Liz Happy Club" + }, + { + "title": "Castoria 3T", + "link": "https://www.youtube.com/watch?v=kYn5Ubz4g9o", + "date": "2024-03-22", + "servant": "284", + "turns": "3T", + "runner": "Loki" + }, + { + "title": "Miss Crane 3T", + "link": "https://www.youtube.com/watch?v=iikUbWWA-Xc", + "date": "2024-03-22", + "servant": "307", + "turns": "3T", + "runner": "QP Dangerous" + }, + { + "title": "Kojirou 3T", + "link": "https://www.youtube.com/watch?v=cITjpOzF7vg", + "date": "2024-03-22", + "servant": "39", + "turns": "3T", + "runner": "Conry" + }, + { + "title": "Jekyll & Hyde 3T (4man)", + "link": "https://www.youtube.com/watch?v=m6ZJIfeTtWU", + "date": "2024-03-19", + "servant": "81", + "turns": "3T", + "runner": "Rikohaiji" + }, + { + "title": "Stheno 3T", + "link": "https://www.youtube.com/watch?v=eUWnXU7Xgjs", + "date": "2024-03-25", + "servant": "41", + "turns": "3T", + "runner": "Volcanicz" + }, + { + "title": "Morgan 3T (FLO NoCE)", + "link": "https://www.youtube.com/watch?v=Ok4ylQvEjwA", + "date": "2024-03-23", + "servant": "309", + "turns": "3T", + "runner": "Loki" + }, + { + "title": "Morgan 3T (6 Cost)", + "link": "https://www.youtube.com/watch?v=zrMN7DeyHIw", + "date": "2024-03-19", + "servant": "309", + "turns": "3T", + "runner": "Loki" + }, + { + "title": "Arjuna Alter 3T (6 Cost)", + "link": "https://www.youtube.com/watch?v=upGvLuoe2L4", + "date": "2024-03-28", + "servant": "247", + "turns": "3T", + "runner": "Sakazuki" + }, + { + "title": "Da Vinci Ruler 3T (FLO)", + "link": "https://www.youtube.com/watch?v=m7hsS5ppPaI", + "date": "2024-03-20", + "servant": "320", + "turns": "3T", + "runner": "Tinesh" + }, + { + "title": "Taira 3T (FLO)", + "link": "https://www.youtube.com/watch?v=JOaUhugHI6U", + "date": "2024-03-20", + "servant": "303", + "turns": "3T", + "runner": "Anthony J" + }, + { + "title": "Summer Kama 3T", + "link": "https://www.youtube.com/watch?v=-v0-vGpG-gI", + "date": "2024-03-19", + "servant": "321", + "turns": "3T", + "runner": "Kamager III" + }, + { + "title": "Bazett 2T", + "link": "https://www.youtube.com/watch?v=kMQzJlKvMrs", + "date": "2024-03-19", + "servant": "336", + "turns": "2T", + "runner": "First_TLN" + }, + { + "title": "Bazett 2T (3 Cost)", + "link": "https://www.youtube.com/watch?v=nx50uGiCYNw", + "date": "2024-03-24", + "servant": "336", + "turns": "2T", + "runner": "TokuHer0" + } + ] + } + ] +} diff --git a/src/content/teslafest/eq-2021/bride-main-event.json b/src/content/teslafest/eq-2021/bride-main-event.json new file mode 100644 index 0000000..979508b --- /dev/null +++ b/src/content/teslafest/eq-2021/bride-main-event.json @@ -0,0 +1,161 @@ +{ + "$schema": "../../../../.astro/collections/teslafest.schema.json", + "info": { + "title": "Main Event - Final Match", + "releaseDate": "2024-03-19", + "shortdescription": "The old guard from Nerofest - let's see how their fighting powers aged over the downtime", + "releaseNumber": 1 + }, + "quests": [ + { + "questTitle": "Main Event - Final Match", + "description": "The old guard from Nerofest - let's see how their fighting powers aged over the downtime", + "data": [ + { + "title": "Artoria 2T", + "link": "https://www.youtube.com/watch?v=xomwwyFIJAY", + "date": "2024-03-22", + "servant": "2", + "turns": "2T", + "runner": "Tinesh" + }, + { + "title": "Ibuki 2T", + "link": "https://www.youtube.com/watch?v=rKV3hiVP_jg", + "date": "2024-03-19", + "servant": "299", + "turns": "2T", + "runner": "inv4der" + }, + { + "title": "Melusine 2T", + "link": "https://www.youtube.com/watch?v=N1nQev7Vxag", + "date": "2024-03-19", + "servant": "312_aoe", + "turns": "2T", + "runner": "Hentai Daddi" + }, + { + "title": "Melusine 2T", + "link": "https://www.youtube.com/watch?v=TgeO9w_xkXI", + "date": "2024-03-20", + "servant": "312_aoe", + "turns": "2T", + "runner": "TokuHer0" + }, + { + "title": "Romulus 2T", + "link": "https://www.youtube.com/watch?v=oaJCHQgFWGc", + "date": "2024-03-27", + "servant": "280", + "turns": "2T", + "runner": "Sakazuki" + }, + { + "title": "Ivan 2T", + "link": "https://www.youtube.com/watch?v=7VVT3ibdx3w", + "date": "2024-03-24", + "servant": "205", + "turns": "2T", + "runner": "ProbablyAParrot" + }, + { + "title": "Nero Caster 2T", + "link": "https://www.youtube.com/watch?v=PrR2elnsCD8", + "date": "2024-03-22", + "servant": "175", + "turns": "2T", + "runner": "Lutrec" + }, + { + "title": "Morgan 2T", + "link": "https://www.youtube.com/watch?v=eG1SIfC8FCU", + "date": "2024-03-19", + "servant": "309", + "turns": "2T", + "runner": "Gorgeous P." + }, + { + "title": "Morgan 2T", + "link": "https://www.youtube.com/watch?v=xqXIW6V-Xj0", + "date": "2024-03-26", + "servant": "309", + "turns": "2T", + "runner": "Nyxi" + }, + { + "title": "Morgan 2T (FLO)", + "link": "https://www.youtube.com/watch?v=vtzwVCVX1DY", + "date": "2024-03-19", + "servant": "309", + "turns": "2T", + "runner": "Loki" + }, + { + "title": "Arjuna Alter 2T", + "link": "https://www.youtube.com/watch?v=BdpfqnGsCyA", + "date": "2024-03-19", + "servant": "247", + "turns": "2T", + "runner": "Liz Happy Club" + }, + { + "title": "Arjuna Alter 2T (FLO)", + "link": "https://www.youtube.com/watch?v=WhLmfJrZyTA", + "date": "2024-03-19", + "servant": "247", + "turns": "2T", + "runner": "Akise" + }, + { + "title": "Arjuna Alter 2T (FLO)", + "link": "https://www.youtube.com/watch?v=AIVvSa8fOdk", + "date": "2024-03-27", + "servant": "247", + "turns": "2T", + "runner": "Sakazuki" + }, + { + "title": "Summer Musashi 2T", + "link": "https://www.youtube.com/watch?v=4MSIbjrEA7M", + "date": "2024-03-19", + "servant": "261", + "turns": "2T", + "runner": "Kusanagi" + }, + { + "title": "Darius 2T", + "link": "https://www.youtube.com/watch?v=kNYP36Pcfe8", + "date": "2024-03-24", + "servant": "55", + "turns": "2T", + "runner": "TR" + }, + { + "title": "Darius 2T", + "link": "https://www.youtube.com/watch?v=0gUC07HUbKk", + "date": "2024-03-22", + "servant": "55", + "turns": "2T", + "runner": "Zectry" + }, + { + "title": "Space Ishtar 2T", + "link": "https://www.youtube.com/watch?v=uKEdeu6DJTs", + "date": "2024-03-25", + "servant": "268", + "turns": "2T", + "runner": "Requiem" + }, + { + "title": "Koyanskaya of Darkness 2T", + "link": "https://www.youtube.com/watch?v=HlF9zmw5XbE", + "date": "2024-03-23", + "servant": "334", + "turns": "2T", + "runner": "Alastair Hale" + } + ] + } + ] +} diff --git a/src/content/teslafest/eq-2021/catch-the-clown.json b/src/content/teslafest/eq-2021/catch-the-clown.json new file mode 100644 index 0000000..ac5421c --- /dev/null +++ b/src/content/teslafest/eq-2021/catch-the-clown.json @@ -0,0 +1,145 @@ +{ + "$schema": "../../../../.astro/collections/teslafest.schema.json", + "info": { + "title": "Capture the Clown!", + "releaseDate": "2024-03-20", + "shortdescription": "Why are you running? Why are you running? Mephisto, why are you running???", + "releaseNumber": 4 + }, + "quests": [ + { + "questTitle": "Capture the Clown!", + "description": "Why are you running? Why are you running? Mephisto, why are you running???", + "data": [ + { + "title": "Altera 3T", + "link": "https://www.youtube.com/watch?v=foNiMNDPAuI", + "date": "2024-03-25", + "servant": "8", + "turns": "3T", + "runner": "Requiem" + }, + { + "title": "Nero 3T", + "link": "https://twitter.com/LutrecTA/status/1772959434513293518", + "date": "2024-03-27", + "servant": "5", + "turns": "3T", + "runner": "Lutrec" + }, + { + "title": "Gilgamesh 3T (4man)", + "link": "https://www.youtube.com/watch?v=fnO6buimUqg", + "date": "2024-03-20", + "servant": "12", + "turns": "3T", + "runner": "Kusanagi" + }, + { + "title": "Melusine 3T", + "link": "https://www.youtube.com/watch?v=YhLV3ARYBSw", + "date": "2024-03-25", + "servant": "312_aoe", + "turns": "3T", + "runner": "TokuHer0" + }, + { + "title": "Summer Caenis 3T", + "link": "https://www.youtube.com/watch?v=3VPZnvqvev4", + "date": "2024-03-20", + "servant": "322", + "turns": "3T", + "runner": "Kamager III" + }, + { + "title": "Drake 3T", + "link": "https://www.youtube.com/watch?v=JPS48CxAXIY", + "date": "2024-03-28", + "servant": "65", + "turns": "3T", + "runner": "Tinesh" + }, + { + "title": "Drake 3T (4man)", + "link": "https://www.youtube.com/watch?v=J2t-WEV6hJk", + "date": "2024-03-24", + "servant": "65", + "turns": "3T", + "runner": "Zectry" + }, + { + "title": "Arjuna Alter 3T (NoCE)", + "link": "https://www.youtube.com/watch?v=2N-JXjXBBU0", + "date": "2024-03-27", + "servant": "247", + "turns": "3T", + "runner": "Volcanicz" + }, + { + "title": "Arjuna Alter 3T (NDCE 5man)", + "link": "https://www.youtube.com/watch?v=ItA5mW3SwGk", + "date": "2024-03-23", + "servant": "247", + "turns": "3T", + "runner": "Akise" + }, + { + "title": "Arjuna Alter 3T (NoCE 4man)", + "link": "https://www.youtube.com/watch?v=NIiZsn-TBdg", + "date": "2024-03-31", + "servant": "247", + "turns": "3T", + "runner": "Sakazuki" + }, + { + "title": "Morgan 3T", + "link": "https://www.youtube.com/watch?v=BKiMQwQPRjM", + "date": "2024-03-20", + "servant": "309", + "turns": "3T", + "runner": "im poketar" + }, + { + "title": "Morgan 3T", + "link": "https://www.youtube.com/watch?v=aVgm6kfjNNA", + "date": "2024-03-22", + "servant": "309", + "turns": "3T", + "runner": "Gorgeous P." + }, + { + "title": "Morgan 3T (NDCE)", + "link": "https://www.youtube.com/watch?v=E8aWa7GdTqE", + "date": "2024-03-20", + "servant": "309", + "turns": "3T", + "runner": "Loki" + }, + { + "title": "Bazett 2T", + "link": "https://www.youtube.com/watch?v=pAeBIcdtAgg", + "date": "2024-03-20", + "servant": "336", + "turns": "2T", + "runner": "First_TLN" + }, + { + "title": "Bazett 2T", + "link": "https://www.youtube.com/watch?v=1xaPz3sVxqA", + "date": "2024-03-21", + "servant": "336", + "turns": "2T", + "runner": "GregoryZero" + }, + { + "title": "Koyanskaya of Darkness 3T", + "link": "https://www.youtube.com/watch?v=0Yx9jxEU0eU", + "date": "2024-03-29", + "servant": "334", + "turns": "3T", + "runner": "Alastair Hale" + } + ] + } + ] +} diff --git a/src/content/teslafest/eq-2021/crimson-hero.json b/src/content/teslafest/eq-2021/crimson-hero.json new file mode 100644 index 0000000..d83c3b8 --- /dev/null +++ b/src/content/teslafest/eq-2021/crimson-hero.json @@ -0,0 +1,16 @@ +{ + "$schema": "../../../../.astro/collections/teslafest.schema.json", + "info": { + "title": "Legend of the Crimson Hero - HD Remastered", + "releaseDate": "2024-03-21", + "shortdescription": "Let's go onto an adventure with Brave Liz, the Hero that will save us all", + "releaseNumber": 5 + }, + "quests": [ + { + "questTitle": "Legend of the Crimson Hero - HD Remastered", + "description": "Sadly, nobody did any runs on this - now Liz is sad :(", + "data": [] + } + ] +} diff --git a/src/content/teslafest/eq-2021/finale-ii.json b/src/content/teslafest/eq-2021/finale-ii.json new file mode 100644 index 0000000..e551b3a --- /dev/null +++ b/src/content/teslafest/eq-2021/finale-ii.json @@ -0,0 +1,185 @@ +{ + "$schema": "../../../../.astro/collections/teslafest.schema.json", + "info": { + "title": "Finale - The Eternal City Triumphus", + "releaseDate": "2024-03-22", + "shortdescription": "You are Rome, you are Rome - We all are Rome", + "releaseNumber": 7 + }, + "quests": [ + { + "questTitle": "Finale - The Eternal City Triumphus", + "description": "You are Rome, you are Rome - We all are Rome ... well, time to demolisch Rome, then", + "data": [ + { + "title": "Musashi 3T", + "link": "https://www.youtube.com/watch?v=N1_fKU3N6eM", + "date": "2024-03-22", + "servant": "153", + "turns": "3T", + "runner": "Ryougi Bobby" + }, + { + "title": "Musashi 3T", + "link": "https://www.youtube.com/watch?v=-YiKOerg-JQ", + "date": "2024-03-26", + "servant": "153", + "turns": "3T", + "runner": "SigrdrΓfa" + }, + { + "title": "Musashi 3T", + "link": "https://www.youtube.com/watch?v=ivlzuhjRmQs", + "date": "2024-03-22", + "servant": "153", + "turns": "3T", + "runner": "First_TLN" + }, + { + "title": "Musashi 3T", + "link": "https://twitter.com/LutrecTA/status/1771597714309927260", + "date": "2024-03-23", + "servant": "153", + "turns": "3T", + "runner": "Lutrec" + }, + { + "title": "Musashi 3T", + "link": "https://www.youtube.com/watch?v=Uh3qycGalF4", + "date": "2024-03-23", + "servant": "153", + "turns": "3T", + "runner": "Kusanagi" + }, + { + "title": "Musashi 3T (NoCE)", + "link": "https://www.youtube.com/watch?v=dj8yoMdEwkY", + "date": "2024-03-26", + "servant": "153", + "turns": "3T", + "runner": "Zectry" + }, + { + "title": "Sigurd 3T (NCDE)", + "link": "https://www.youtube.com/watch?v=FDFcW8usavE", + "date": "2024-03-23", + "servant": "213", + "turns": "3T", + "runner": "ProbablyAParrot" + }, + { + "title": "Beni-Enma 3T", + "link": "https://www.youtube.com/watch?v=8GRvuL3BLEk", + "date": "2024-03-22", + "servant": "234", + "turns": "3T", + "runner": "Kamager III" + }, + { + "title": "Beni-Enma 3T (NDCE)", + "link": "https://www.youtube.com/watch?v=IvTK0Q0JfsY", + "date": "2024-03-27", + "servant": "234", + "turns": "3T", + "runner": "Alastair Hale" + }, + { + "title": "Bedivere 3T", + "link": "https://www.youtube.com/watch?v=6WKnji9jctc", + "date": "2024-03-22", + "servant": "126", + "turns": "3T", + "runner": "Ray the II" + }, + { + "title": "Summer Hokusai 3T", + "link": "https://www.youtube.com/watch?v=Ly3K6wUapSE", + "date": "2024-03-22", + "servant": "264", + "turns": "3T", + "runner": "Tinesh" + }, + { + "title": "Summer Hokusai 3T (NDCE)", + "link": "https://www.youtube.com/watch?v=4NuCMMovksg", + "date": "2024-03-25", + "servant": "264", + "turns": "3T", + "runner": "inv4der" + }, + { + "title": "Muramasa 3T", + "link": "https://www.youtube.com/watch?v=MsiloyQxDfs", + "date": "2024-03-23", + "servant": "302", + "turns": "3T", + "runner": "Loki" + }, + { + "title": "Muramasa 3T (NDCE)", + "link": "https://www.youtube.com/watch?v=ge_PU19eMWM", + "date": "2024-03-25", + "servant": "302", + "turns": "3T", + "runner": "Alastair Hale" + }, + { + "title": "Saber Alter 3T", + "link": "https://www.youtube.com/watch?v=Moe1-i-NVX8", + "date": "2024-03-29", + "servant": "3", + "turns": "3T", + "runner": "Shawn Sun" + }, + { + "title": "Melusine 3T", + "link": "https://www.youtube.com/watch?v=ahGiqivoUqA", + "date": "2024-03-22", + "servant": "312_st", + "turns": "3T", + "runner": "TokuHer0" + }, + { + "title": "Li Shuwen 3T", + "link": "https://www.youtube.com/watch?v=R5XkPmaImWE", + "date": "2024-03-25", + "servant": "235", + "turns": "3T", + "runner": "Alastair Hale" + }, + { + "title": "MHXA 3T", + "link": "https://www.youtube.com/watch?v=01WPieF-EAQ", + "date": "2024-03-22", + "servant": "155", + "turns": "3T", + "runner": "Ayumi" + }, + { + "title": "Morgan 3T", + "link": "https://twitter.com/santoryuiai3/status/1771260206090965013", + "date": "2024-03-22", + "servant": "309", + "turns": "3T", + "runner": "Ray" + }, + { + "title": "Arjuna Alter 3T", + "link": "https://www.youtube.com/watch?v=VElGV2WdQQQ", + "date": "2024-03-22", + "servant": "247", + "turns": "3T", + "runner": "Akise" + }, + { + "title": "Yang Guifei 3T", + "link": "https://www.youtube.com/watch?v=F0mVvLtx9uE", + "date": "2024-03-24", + "servant": "275", + "turns": "3T", + "runner": "Requiem" + } + ] + } + ] +} diff --git a/src/content/teslafest/eq-2021/gorgon-sisters.json b/src/content/teslafest/eq-2021/gorgon-sisters.json new file mode 100644 index 0000000..ad50ac0 --- /dev/null +++ b/src/content/teslafest/eq-2021/gorgon-sisters.json @@ -0,0 +1,185 @@ +{ + "$schema": "../../../../.astro/collections/teslafest.schema.json", + "info": { + "title": "The Lovely Gorgon Sisters", + "releaseDate": "2024-03-20", + "shortdescription": "Bullying the two sisters that in turn bully her Nee-san - what could go wrong (or right)?", + "releaseNumber": 3 + }, + "quests": [ + { + "questTitle": "The Lovely Gorgon Sisters", + "description": "Bullying the two sisters that in turn bully her Nee-san - what could go wrong (or right)?", + "data": [ + { + "title": "Ibuki 2T", + "link": "https://www.youtube.com/watch?v=nXqrqBPpMik", + "date": "2024-03-20", + "servant": "299", + "turns": "2T", + "runner": "inv4der" + }, + { + "title": "Summer Illya 2T", + "link": "https://www.youtube.com/watch?v=n9r7K8762ck", + "date": "2024-03-28", + "servant": "286", + "turns": "2T", + "runner": "zoropp" + }, + { + "title": "Romulus 2T", + "link": "https://www.youtube.com/watch?v=gOID1sTtcVI", + "date": "2024-03-28", + "servant": "280", + "turns": "2T", + "runner": "Sakazuki" + }, + { + "title": "Melusine 2T (FLO)", + "link": "https://www.youtube.com/watch?v=_UThC-CN6do", + "date": "2024-03-20", + "servant": "312_aoe", + "turns": "2T", + "runner": "Hentai Daddi" + }, + { + "title": "Melusine 2T (FLO)", + "link": "https://www.youtube.com/watch?v=sDuE9IZQ7Ok", + "date": "2024-03-20", + "servant": "312_aoe", + "turns": "2T", + "runner": "TokuHer0" + }, + { + "title": "Nero Caster 2T", + "link": "https://twitter.com/LutrecTA/status/1772372664838963480", + "date": "2024-03-25", + "servant": "175", + "turns": "2T", + "runner": "Lutrec" + }, + { + "title": "Arjuna Alter 2T (FLO NoCE)", + "link": "https://www.youtube.com/watch?v=2GczluPBHcc", + "date": "2024-03-20", + "servant": "247", + "turns": "2T", + "runner": "Akise" + }, + { + "title": "Arjuna Alter 2T (16 Cost)", + "link": "https://www.youtube.com/watch?v=ly6DVlDfcXY", + "date": "2024-03-28", + "servant": "247", + "turns": "2T", + "runner": "Sakazuki" + }, + { + "title": "Morgan 2T", + "link": "https://www.youtube.com/watch?v=z7AzI8SGTv8", + "date": "2024-03-20", + "servant": "309", + "turns": "2T", + "runner": "First_TLN" + }, + { + "title": "Morgan 2T", + "link": "https://www.youtube.com/watch?v=Dm2oe-QbK04", + "date": "2024-03-20", + "servant": "309", + "turns": "2T", + "runner": "Liz Happy Club" + }, + { + "title": "Morgan 2T", + "link": "https://www.youtube.com/watch?v=nBwl3M77GF8", + "date": "2024-03-21", + "servant": "309", + "turns": "2T", + "runner": "Gorgeous P." + }, + { + "title": "Morgan 2T (20 Cost)", + "link": "https://www.youtube.com/watch?v=rwGo5R9DP3A", + "date": "2024-03-21", + "servant": "309", + "turns": "2T", + "runner": "Loki" + }, + { + "title": "Morgan 2T (16 Cost)", + "link": "https://www.youtube.com/watch?v=fQiE5xc2Dv8", + "date": "2024-03-23", + "servant": "309", + "turns": "2T", + "runner": "Volcanicz" + }, + { + "title": "Tamamo Cat 2T", + "link": "https://www.youtube.com/watch?v=nE3mNXVQC04", + "date": "2024-03-29", + "servant": "58", + "turns": "2T", + "runner": "Requiem" + }, + { + "title": "Maou Nobu 2T (NoCE)", + "link": "https://www.youtube.com/watch?v=hzmKa2vrgAk", + "date": "2024-03-25", + "servant": "250", + "turns": "2T", + "runner": "SigrdrΓfa" + }, + { + "title": "Summer Kama 2T", + "link": "https://www.youtube.com/watch?v=axPQJS41hos", + "date": "2024-03-20", + "servant": "321", + "turns": "2T", + "runner": "Kamager III" + }, + { + "title": "Kingprotea 2T", + "link": "https://www.youtube.com/watch?v=wH6ItkkT5wM", + "date": "2024-03-20", + "servant": "238", + "turns": "2T", + "runner": "Kusanagi" + }, + { + "title": "Summer BB 2T", + "link": "https://www.youtube.com/watch?v=1xNZTeC-lzY", + "date": "2024-03-29", + "servant": "220", + "turns": "2T", + "runner": "zoropp" + }, + { + "title": "Koyanskaya of Darkness 2T (FLO)", + "link": "https://www.youtube.com/watch?v=02utpNgpwTI", + "date": "2024-03-23", + "servant": "334", + "turns": "2T", + "runner": "Zectry" + }, + { + "title": "Voyager 2T", + "link": "https://www.youtube.com/watch?v=JHTWwb8L0J0", + "date": "2024-03-21", + "servant": "281", + "turns": "2T", + "runner": "Kamager III" + }, + { + "title": "Sigurd 3T", + "link": "https://www.youtube.com/watch?v=2WV4nB45Mx0", + "date": "2024-03-22", + "servant": "213", + "turns": "3T", + "runner": "ProbablyAParrot" + } + ] + } + ] +} diff --git a/src/content/teslafest/eq-2021/green-comet.json b/src/content/teslafest/eq-2021/green-comet.json new file mode 100644 index 0000000..c53e14c --- /dev/null +++ b/src/content/teslafest/eq-2021/green-comet.json @@ -0,0 +1,121 @@ +{ + "$schema": "../../../../.astro/collections/teslafest.schema.json", + "info": { + "title": "The Green Comet", + "releaseDate": "2024-03-21", + "shortdescription": "When Achillis decends, he brings with him destruction ...", + "releaseNumber": 6 + }, + "quests": [ + { + "questTitle": "The Green Comet", + "description": "When Achillis decends, he brings with him destruction - time to teach him that this is a bad thing!", + "data": [ + { + "title": "Kama 2T", + "link": "https://www.youtube.com/watch?v=re1Po7O_kxM", + "date": "2024-03-23", + "servant": "239", + "turns": "2T", + "runner": "Requiem" + }, + { + "title": "Arjuna Alter 2T", + "link": "https://www.youtube.com/watch?v=6IabkracLbs", + "date": "2024-03-31", + "servant": "247", + "turns": "2T", + "runner": "Sakazuki" + }, + { + "title": "Arjuna Alter 2T", + "link": "https://www.youtube.com/watch?v=55bFPChv1bw", + "date": "2024-03-21", + "servant": "247", + "turns": "2T", + "runner": "Akise" + }, + { + "title": "Kintoki 2T", + "link": "https://www.youtube.com/watch?v=l4xOU8GRATc", + "date": "2024-03-24", + "servant": "51", + "turns": "2T", + "runner": "Zectry" + }, + { + "title": "Bazett 2T", + "link": "https://www.youtube.com/watch?v=F-ueNp9AP8M", + "date": "2024-03-25", + "servant": "336", + "turns": "2T", + "runner": "TokuHer0" + }, + { + "title": "Summer Tamamo 3T", + "link": "https://twitter.com/Certain_Bastard/status/1772404717722689709", + "date": "2024-03-26", + "servant": "128", + "turns": "3T", + "runner": "Certain Bastard" + }, + { + "title": "Ozymandias 3T", + "link": "https://www.youtube.com/watch?v=3LY4IzdN3rQ", + "date": "2024-03-21", + "servant": "118", + "turns": "3T", + "runner": "Kusanagi" + }, + { + "title": "Jekyll & Hyde 3T", + "link": "https://www.youtube.com/watch?v=odX-pAx4csU", + "date": "2024-03-21", + "servant": "81", + "turns": "3T", + "runner": "Rikohaiji" + }, + { + "title": "Arjuna Alter 3T", + "link": "https://www.youtube.com/watch?v=2JWVOe7zu-Y&t=25s", + "date": "2024-03-21", + "servant": "247", + "turns": "3T", + "runner": "Liz Happy Club" + }, + { + "title": "Kintoki 3T", + "link": "https://www.youtube.com/watch?v=D8ClWvbnEdM", + "date": "2024-03-21", + "servant": "51", + "turns": "3T", + "runner": "Loki" + }, + { + "title": "Kintoki 3T", + "link": "https://www.youtube.com/watch?v=1D0dzlNDOfc", + "date": "2024-03-24", + "servant": "51", + "turns": "3T", + "runner": "Conry" + }, + { + "title": "Cu Alter 3T", + "link": "https://www.youtube.com/watch?v=VoTat-fDwlE", + "date": "2024-03-23", + "servant": "98", + "turns": "3T", + "runner": "Gorgeous P." + }, + { + "title": "Sitonai 3T", + "link": "https://www.youtube.com/watch?v=-WPUn_z8aq4", + "date": "2024-03-26", + "servant": "224", + "turns": "3T", + "runner": "zoropp" + } + ] + } + ] +} diff --git a/src/content/teslafest/giga-coil/akihabara-explosion.json b/src/content/teslafest/giga-coil/akihabara-explosion.json new file mode 100644 index 0000000..b94c2e0 --- /dev/null +++ b/src/content/teslafest/giga-coil/akihabara-explosion.json @@ -0,0 +1,49 @@ +{ + "$schema": "../../../../.astro/collections/teslafest.schema.json", + "info": { + "title": "Singularity Gets Restored until You Reach Home", + "releaseDate": "2024-03-15", + "shortdescription": "An interesting, multi-stage quest with plenty of interesting twists", + "releaseNumber": 2 + }, + "quests": [ + { + "questTitle": "Singularity Gets Restored until You Reach Home", + "description": "An interesting, multi-stage quest with plenty of interesting twists ... What do you mean 12 Guts stacks is bad quest design????", + "data": [ + { + "title": "Juano 7T (Multicore FLO NoCE)", + "link": "https://www.youtube.com/watch?v=AznMkbg6UMM", + "date": "2024-03-24", + "servant": "247", + "turns": "7T", + "runner": "Akise" + }, + { + "title": "Morgan 7T (Multicore)", + "link": "https://www.youtube.com/watch?v=RFa_RlhksBs&t=166s", + "date": "2024-04-11", + "servant": "309", + "turns": "7T", + "runner": "Zectry" + }, + { + "title": "Kintoki 8T (Multicore)", + "link": "https://www.youtube.com/watch?v=QqZsNJwsdns", + "date": "2024-04-05", + "servant": "51", + "turns": "8T", + "runner": "Roz" + }, + { + "title": "Bazett 4T (Multicore)", + "link": "https://www.youtube.com/watch?v=pITWIii6JjM&t=110s", + "date": "2024-03-29", + "servant": "336", + "turns": "4T", + "runner": "TokuHer0" + } + ] + } + ] +} diff --git a/src/content/teslafest/giga-coil/fate-requiem.json b/src/content/teslafest/giga-coil/fate-requiem.json new file mode 100644 index 0000000..3c4ef09 --- /dev/null +++ b/src/content/teslafest/giga-coil/fate-requiem.json @@ -0,0 +1,73 @@ +{ + "$schema": "../../../../.astro/collections/teslafest.schema.json", + "info": { + "title": "Child from the Netherworld", + "releaseDate": "2024-03-15", + "shortdescription": "Can Erice stop the racers this time?", + "releaseNumber": 5 + }, + "quests": [ + { + "questTitle": "Child from the Netherworld", + "description": "Can Erice stop the racers this time? Well, she might just if she has more and more ghosts in stock. A real throwback to the Fate/Requiem Collab Event.", + "data": [ + { + "title": "Muramasa 3T", + "link": "https://www.youtube.com/watch?v=gb249dDmfl0", + "date": "2024-03-28", + "servant": "302", + "turns": "3T", + "runner": "Alastair Hale" + }, + { + "title": "Summer Okitan 3T", + "link": "https://www.youtube.com/watch?v=pITWIii6JjM&t=566s", + "date": "2024-03-29", + "servant": "317", + "turns": "3T", + "runner": "Tokuher0" + }, + { + "title": "Saito Hajime 3T", + "link": "https://www.youtube.com/watch?v=QmAmBxJKXWk&t=757s", + "date": "2024-03-27", + "servant": "293", + "turns": "3T", + "runner": "Conry" + }, + { + "title": "Morgan 3T (FLO NoCE)", + "link": "https://www.youtube.com/watch?v=ZLGXjXCW-bE", + "date": "2024-03-27", + "servant": "309", + "turns": "3T", + "runner": "Loki" + }, + { + "title": "Arjuna Alter 3T", + "link": "https://www.youtube.com/watch?v=RFa_RlhksBs&t=829s", + "date": "2024-04-11", + "servant": "247", + "turns": "3T", + "runner": "Zectry" + }, + { + "title": "Summer Musashi 3T", + "link": "https://www.youtube.com/watch?v=yE6Mv6VTnCc&t=876s", + "date": "2024-03-28", + "servant": "261", + "turns": "3T", + "runner": "Patrick Bandeira" + }, + { + "title": "Cu Alter 3T (NoNP)", + "link": "https://www.youtube.com/watch?v=2xMvkmtp-gk", + "date": "2024-04-04", + "servant": "98", + "turns": "3T", + "runner": "Volcanicz" + } + ] + } + ] +} diff --git a/src/content/teslafest/giga-coil/gudaguda-2021.json b/src/content/teslafest/giga-coil/gudaguda-2021.json new file mode 100644 index 0000000..05f3507 --- /dev/null +++ b/src/content/teslafest/giga-coil/gudaguda-2021.json @@ -0,0 +1,97 @@ +{ + "$schema": "../../../../.astro/collections/teslafest.schema.json", + "info": { + "title": "Raging Billows! Kakare Shibata!", + "releaseDate": "2024-03-15", + "shortdescription": "Stacking defences and damage cut - what an interesting strategy", + "releaseNumber": 6 + }, + "quests": [ + { + "questTitle": "Raging Billows! Kakare Shibata!", + "description": "Stacking defences and damage cut - what an interesting strategy ... Let's see how it works out against the racers", + "data": [ + { + "title": "Sigurd 3T (NDCE)", + "link": "https://www.youtube.com/watch?v=ow5KRkoFWYs", + "date": "2024-03-29", + "servant": "213", + "turns": "3T", + "runner": "ProbablyAParrot" + }, + { + "title": "Barghest 3T", + "link": "https://www.youtube.com/watch?v=tkSdcRKT-bg", + "date": "2024-03-25", + "servant": "310", + "turns": "3T", + "runner": "Kusanagi" + }, + { + "title": "Melusine 3T (Asc1/2)", + "link": "https://www.youtube.com/watch?v=yE6Mv6VTnCc&t=1030s", + "date": "2024-03-28", + "servant": "312_st", + "turns": "3T", + "runner": "Patrick Bandeira" + }, + { + "title": "Melusine 3T (Asc1/2)", + "link": "https://www.youtube.com/watch?v=RFa_RlhksBs&t=1014s", + "date": "2024-04-11", + "servant": "312_st", + "turns": "3T", + "runner": "zectry" + }, + { + "title": "Morgan 3T (NDCE)", + "link": "https://www.youtube.com/watch?v=tnq0ACSoBZE", + "date": "2024-03-28", + "servant": "309", + "turns": "3T", + "runner": "Loki" + }, + { + "title": "Morgan 3T (NDCE 5Man)", + "link": "https://www.youtube.com/watch?v=PNLeiRqC9wM", + "date": "2024-03-31", + "servant": "309", + "turns": "3T", + "runner": "Volcanicz" + }, + { + "title": "Arjuna Alter 3T (NDCE)", + "link": "https://www.youtube.com/watch?v=8d0ZBjI6Pd8", + "date": "2024-03-28", + "servant": "247", + "turns": "3T", + "runner": "Akise" + }, + { + "title": "Cu Alter 3T (NDCE)", + "link": "https://www.youtube.com/watch?v=FjNoeuMgf2w", + "date": "2024-03-29", + "servant": "98", + "turns": "3T", + "runner": "Volcanicz" + }, + { + "title": "Bazett 3T", + "link": "https://www.youtube.com/watch?v=SvQYbPxPGwc&t=1949s", + "date": "2024-03-25", + "servant": "336", + "turns": "3T", + "runner": "Paradise" + }, + { + "title": "Van Gogh 3T", + "link": "https://www.youtube.com/watch?v=pITWIii6JjM&t=691s", + "date": "2024-03-29", + "servant": "295", + "turns": "3T", + "runner": "TokuHer0" + } + ] + } + ] +} diff --git a/src/content/teslafest/giga-coil/saber-wars-2.json b/src/content/teslafest/giga-coil/saber-wars-2.json new file mode 100644 index 0000000..6610167 --- /dev/null +++ b/src/content/teslafest/giga-coil/saber-wars-2.json @@ -0,0 +1,57 @@ +{ + "$schema": "../../../../.astro/collections/teslafest.schema.json", + "info": { + "title": "Galaxy Guardian", + "releaseDate": "2024-03-15", + "shortdescription": "The one to keep the Galaxy in order - will her two forms be enough against the racers?", + "releaseNumber": 3 + }, + "quests": [ + { + "questTitle": "Galaxy Guardian", + "description": "The one to keep the Galaxy in order - will her two forms be enough against the racers?", + "data": [ + { + "title": "Sitonai 2T", + "link": "https://www.youtube.com/watch?v=pITWIii6JjM&t=297s", + "date": "2024-03-29", + "servant": "224", + "turns": "2T", + "runner": "TokuHer0" + }, + { + "title": "Bazett 1T (FLO)", + "link": "https://www.youtube.com/watch?v=RFa_RlhksBs&t=491s", + "date": "2024-04-11", + "servant": "336", + "turns": "1T", + "runner": "Zectry" + }, + { + "title": "Yang Guifei 2T", + "link": "https://www.youtube.com/watch?v=yE6Mv6VTnCc&t=492s", + "date": "2024-03-28", + "servant": "275", + "turns": "2T", + "runner": "Patrick Bandeira" + }, + { + "title": "Koyanskaya of Darkness 2T", + "link": "https://www.youtube.com/watch?v=uZDNzw9tTWo", + "date": "2024-03-24", + "servant": "334", + "turns": "2T", + "runner": "Loki" + }, + { + "title": "MIXA 2T (NoNP)", + "link": "https://www.youtube.com/watch?v=6AbWuaLxfzM", + "date": "2024-03-26", + "servant": "308", + "turns": "2T", + "runner": "Rikohaiji" + } + ] + } + ] +} diff --git a/src/content/teslafest/giga-coil/summer-2021.json b/src/content/teslafest/giga-coil/summer-2021.json new file mode 100644 index 0000000..69eb1d8 --- /dev/null +++ b/src/content/teslafest/giga-coil/summer-2021.json @@ -0,0 +1,97 @@ +{ + "$schema": "../../../../.astro/collections/teslafest.schema.json", + "info": { + "title": "Western Ninja Arts Book", + "releaseDate": "2024-03-15", + "shortdescription": "Can Fuuma, his clones and his arsenal of debuffs stop the racers?", + "releaseNumber": 1 + }, + "quests": [ + { + "questTitle": "Western Ninja Arts Book", + "description": "Can Fuuma, his clones and his arsenal of debuffs stop the racers? One of the most obnoxious quests in the history of Challenge Quests - and this time, with a harder cap on party cost.", + "data": [ + { + "title": "Skadi 3T", + "link": "https://www.youtube.com/watch?v=VMVus__ZYXE", + "date": "2024-03-30", + "servant": "215", + "turns": "3T", + "runner": "Firq" + }, + { + "title": "Melusine 3T", + "link": "https://www.youtube.com/watch?v=yE6Mv6VTnCc", + "date": "2024-03-28", + "servant": "312_st", + "turns": "3T", + "runner": "Patrick Bandeira" + }, + { + "title": "Ozymandias 3T", + "link": "https://www.youtube.com/watch?v=gv9YuMvfTYM", + "date": "2024-03-24", + "servant": "118", + "turns": "3T", + "runner": "Kusanagi" + }, + { + "title": "Sanzang 3T", + "link": "https://www.youtube.com/watch?v=OJrs2Gbh_KI", + "date": "2024-03-24", + "servant": "113", + "turns": "3T", + "runner": "Liz Happy Club" + }, + { + "title": "Okuni 3T", + "link": "https://www.youtube.com/watch?v=RFa_RlhksBs", + "date": "2024-04-11", + "servant": "327", + "turns": "3T", + "runner": "Zectry" + }, + { + "title": "Kojirou 3T", + "link": "https://www.youtube.com/watch?v=QmAmBxJKXWk", + "date": "2024-03-27", + "servant": "39", + "turns": "3T", + "runner": "Conry" + }, + { + "title": "MHXA 3T (NDCE)", + "link": "https://youtu.be/7-fPdCtGaks", + "date": "2024-03-29", + "servant": "155", + "turns": "3T", + "runner": "Requiem" + }, + { + "title": "Morgan 3T (FLO NDCE NoBG)", + "link": "https://youtu.be/ls0p-tsH_10", + "date": "2024-03-24", + "servant": "309", + "turns": "3T", + "runner": "Loki" + }, + { + "title": "Junao 3T (FLO NDCE)", + "link": "https://youtu.be/GX9gqQ0YfW0", + "date": "2024-03-27", + "servant": "247", + "turns": "3T", + "runner": "Akise" + }, + { + "title": "Kintoki 3T", + "link": "https://youtu.be/pITWIii6JjM", + "date": "2024-03-29", + "servant": "51", + "turns": "3T", + "runner": "TokuHer0" + } + ] + } + ] +} diff --git a/src/content/teslafest/giga-coil/valentines-2023.json b/src/content/teslafest/giga-coil/valentines-2023.json new file mode 100644 index 0000000..b0cdaef --- /dev/null +++ b/src/content/teslafest/giga-coil/valentines-2023.json @@ -0,0 +1,41 @@ +{ + "$schema": "../../../../.astro/collections/teslafest.schema.json", + "info": { + "title": "True Love", + "releaseDate": "2024-03-15", + "shortdescription": "Somehow, Orion can now transform - is he a Transformer then?", + "releaseNumber": 4 + }, + "quests": [ + { + "questTitle": "True Love", + "description": "Somehow, Orion can now transform - is he a Transformer then? But to be fair, he really fits in with all the other pigs.", + "data": [ + { + "title": "Percival 4T", + "link": "https://www.youtube.com/watch?v=MGcyhZMkMrs&t=1292s", + "date": "2024-03-28", + "servant": "313", + "turns": "4T", + "runner": "Nyxi" + }, + { + "title": "Ryoma 4T (FLO)", + "link": "https://www.youtube.com/watch?v=RFa_RlhksBs&t=581s", + "date": "2024-04-11", + "servant": "329", + "turns": "4T", + "runner": "Zectry" + }, + { + "title": "Space Ishtar 4T", + "link": "https://www.youtube.com/watch?v=pITWIii6JjM&t=398s", + "date": "2024-03-24", + "servant": "268", + "turns": "4T", + "runner": "TokuHer0" + } + ] + } + ] +} diff --git a/src/content/teslafest/giga-coil/white-day-2023.json b/src/content/teslafest/giga-coil/white-day-2023.json new file mode 100644 index 0000000..5f86a49 --- /dev/null +++ b/src/content/teslafest/giga-coil/white-day-2023.json @@ -0,0 +1,97 @@ +{ + "$schema": "../../../../.astro/collections/teslafest.schema.json", + "info": { + "title": "Five Star Idol", + "releaseDate": "2024-03-15", + "shortdescription": "A total of 10 HP Bars and some interesting field effects - what will happen on this stage?", + "releaseNumber": 7 + }, + "quests": [ + { + "questTitle": "Five Star Idol", + "description": "A total of 10 HP Bars and some interesting field effects - what will happen on this stage? Will the racers idol prevail? Let's enjoy the show and see ...", + "data": [ + { + "title": "Baobhan Sith 6T", + "link": "https://www.youtube.com/watch?v=ZBfamgici20", + "date": "2024-03-29", + "servant": "311", + "turns": "6T", + "runner": "Requiem" + }, + { + "title": "Nero 4T", + "link": "https://twitter.com/LutrecTA/status/1773370060603629855", + "date": "2024-03-28", + "servant": "5", + "turns": "4T", + "runner": "Lutrec" + }, + { + "title": "Melusine 4T (2CS)", + "link": "https://www.youtube.com/watch?v=8SLr2KAULIc", + "date": "2024-03-31", + "servant": "312_aoe", + "turns": "4T", + "runner": "TokuHer0" + }, + { + "title": "Zenobia 4T", + "link": "https://www.youtube.com/watch?v=RFa_RlhksBs&t=1192s", + "date": "2024-04-11", + "servant": "325", + "turns": "4T", + "runner": "Zectry" + }, + { + "title": "Morgan 4T (BCE)", + "link": "https://www.youtube.com/watch?v=81N4DhCQ7Io", + "date": "2024-03-27", + "servant": "309", + "turns": "4T", + "runner": "im poketar" + }, + { + "title": "Summer Musashi 4T", + "link": "https://www.youtube.com/watch?v=yE6Mv6VTnCc&t=1175s", + "date": "2024-03-28", + "servant": "261", + "turns": "4T", + "runner": "Patrick Bandeira" + }, + { + "title": "Summer Kama 4T", + "link": "https://www.youtube.com/watch?v=pITWIii6JjM&t=802s", + "date": "2024-03-29", + "servant": "321", + "turns": "4T", + "runner": "TokuHer0" + }, + { + "title": "Summer Kama 4T", + "link": "https://www.youtube.com/watch?v=3MYS_V5Rqhw&t=2985s", + "date": "2024-03-25", + "servant": "321", + "turns": "4T", + "runner": "Kamager III" + }, + { + "title": "Summer Kiara 4T", + "link": "https://www.youtube.com/watch?v=SvQYbPxPGwc&t=2113s", + "date": "2024-03-25", + "servant": "285", + "turns": "4T", + "runner": "Paradise" + }, + { + "title": "Ishtar 4T (NDCE)", + "link": "https://www.youtube.com/watch?v=QmAmBxJKXWk&t=1042s", + "date": "2024-03-27", + "servant": "142", + "turns": "4T", + "runner": "Conry" + } + ] + } + ] +} diff --git a/src/content/teslafest/mega-coil/amazoness-crisis.json b/src/content/teslafest/mega-coil/amazoness-crisis.json new file mode 100644 index 0000000..d22b3fa --- /dev/null +++ b/src/content/teslafest/mega-coil/amazoness-crisis.json @@ -0,0 +1,113 @@ +{ + "$schema": "../../../../.astro/collections/teslafest.schema.json", + "info": { + "title": "Until That Person's Defeated", + "releaseDate": "2024-03-15", + "shortdescription": "Penth fulfilling her role as a CEO without fail - but what about a hostile takeover by racers?", + "releaseNumber": 2 + }, + "quests": [ + { + "questTitle": "Until That Person's Defeated", + "description": "Penth fulfilling her role as a CEO without fail - but what about a hostile takeover by racers?", + "data": [ + { + "title": "Brynhild 3T (FLO NDCE)", + "link": "https://www.youtube.com/watch?v=dkmrzD1X6CQ", + "date": "2024-03-19", + "servant": "88", + "turns": "3T", + "runner": "SigrdrΓfa" + }, + { + "title": "Jekyll & Hyde 3T (4Man)", + "link": "https://www.youtube.com/watch?v=vxAn6PZf2bA", + "date": "2024-04-05", + "servant": "81", + "turns": "3T", + "runner": "Rikohaiji" + }, + { + "title": "Muramasa 2T (FLO NDCE)", + "link": "https://www.youtube.com/watch?v=DeQw_tUWTgo", + "date": "2024-03-24", + "servant": "302", + "turns": "2T", + "runner": "Alastair Hale" + }, + { + "title": "Artoria 2T (FLO NDCE)", + "link": "https://www.youtube.com/watch?v=EJAhp9Vs_ls", + "date": "2024-03-16", + "servant": "2", + "turns": "2T", + "runner": "Sesshou01" + }, + { + "title": "Gilgamesh 2T", + "link": "https://www.youtube.com/watch?v=p8QkHOC-CgE&t=234s", + "date": "2024-03-25", + "servant": "12", + "turns": "2T", + "runner": "Nyxi" + }, + { + "title": "Arash 2T (FLO NDCE)", + "link": "https://www.youtube.com/watch?v=6QkpSKA2YNM", + "date": "2024-03-18", + "servant": "16", + "turns": "2T", + "runner": "Kusanagi" + }, + { + "title": "Bradamante 2T (NDCE)", + "link": "https://www.youtube.com/watch?v=k5hIGF3FW3o", + "date": "2024-03-20", + "servant": "232", + "turns": "2T", + "runner": "Alastair Hale" + }, + { + "title": "Drake 2T", + "link": "https://www.youtube.com/watch?v=k5vbEdc_BA4&t=299s", + "date": "2024-03-27", + "servant": "65", + "turns": "2T", + "runner": "Patrick Bandeira" + }, + { + "title": "Taigong Wang 2T (NoCE FLO)", + "link": "https://www.youtube.com/watch?v=HROrOxcVnKQ", + "date": "2024-03-16", + "servant": "331", + "turns": "2T", + "runner": "Ryougi Bobby" + }, + { + "title": "Anastasia 2T (NoCE FLO)", + "link": "https://www.youtube.com/watch?v=3NebOHW5IC0&t=182s", + "date": "2024-04-09", + "servant": "201", + "turns": "2T", + "runner": "Zectry" + }, + { + "title": "Arjuna Alter 2T (4Man)", + "link": "https://www.youtube.com/watch?v=pLX_4PDIai8", + "date": "2024-03-19", + "servant": "247", + "turns": "2T", + "runner": "Kusanagi" + }, + { + "title": "Caren 2T", + "link": "https://www.youtube.com/watch?v=JdlpwZKanJA&t=161s", + "date": "2024-03-26", + "servant": "305", + "turns": "2T", + "runner": "TokuHer0" + } + ] + } + ] +} diff --git a/src/content/teslafest/mega-coil/christmas-2018.json b/src/content/teslafest/mega-coil/christmas-2018.json new file mode 100644 index 0000000..2059d86 --- /dev/null +++ b/src/content/teslafest/mega-coil/christmas-2018.json @@ -0,0 +1,57 @@ +{ + "$schema": "../../../../.astro/collections/teslafest.schema.json", + "info": { + "title": "March of the Holy Reindeer", + "releaseDate": "2024-03-15", + "shortdescription": "Is this technically ruining Christmas ... naaaah, it's fine", + "releaseNumber": 4 + }, + "quests": [ + { + "questTitle": "March of the Holy Reindeer", + "description": "Is this technically ruining Christmas ... naaaah, it's fine", + "data": [ + { + "title": "Summer Okita Alter 4T", + "link": "https://www.youtube.com/watch?v=JdlpwZKanJA&t=409s", + "date": "2024-03-26", + "servant": "317", + "turns": "4T", + "runner": "TokuHer0" + }, + { + "title": "Morgan 4T (Multicore)", + "link": "https://www.youtube.com/watch?v=QYe-8ijdfnI&t=698s", + "date": "2024-03-15", + "servant": "309", + "turns": "4T", + "runner": "Liz Happy Club" + }, + { + "title": "Cleopatra 4T (FLO)", + "link": "https://www.youtube.com/watch?v=3NebOHW5IC0&t=490s", + "date": "2024-04-09", + "servant": "139", + "turns": "4T", + "runner": "Zectry" + }, + { + "title": "Morgan 4T (w. Jack)", + "link": "https://www.youtube.com/watch?v=EJAhp9Vs_ls&t=338s", + "date": "2024-03-16", + "servant": "309", + "turns": "4T", + "runner": "Sesshou01" + }, + { + "title": "Arjuna Alter 4T (FLO)", + "link": "https://www.youtube.com/watch?v=pLX_4PDIai8&t=281s", + "date": "2024-03-19", + "servant": "247", + "turns": "4T", + "runner": "Kusanagi" + } + ] + } + ] +} diff --git a/src/content/teslafest/mega-coil/halloween-2019.json b/src/content/teslafest/mega-coil/halloween-2019.json new file mode 100644 index 0000000..b27459a --- /dev/null +++ b/src/content/teslafest/mega-coil/halloween-2019.json @@ -0,0 +1,89 @@ +{ + "$schema": "../../../../.astro/collections/teslafest.schema.json", + "info": { + "title": "Crime and Punishment - Gray Mustache Must Die", + "releaseDate": "2024-03-15", + "shortdescription": "Confronting an evil mastermind in his lair with his army of mechas - what could be more on point for Moriaty?", + "releaseNumber": 3 + }, + "quests": [ + { + "questTitle": "Crime and Punishment - Gray Mustache Must Die", + "description": "Confronting an evil mastermind in his lair with his army of mechas - what could be more on point for Moriaty?", + "data": [ + { + "title": "Melt Lambda 3T (FLO)", + "link": "https://www.youtube.com/watch?v=3NebOHW5IC0&t=323s", + "date": "2024-04-09", + "servant": "266", + "turns": "3T", + "runner": "Zectry" + }, + { + "title": "Scathach 3T", + "link": "https://www.youtube.com/watch?v=EJAhp9Vs_ls&t=158s", + "date": "2024-03-16", + "servant": "70", + "turns": "3T", + "runner": "Sesshou01" + }, + { + "title": "Bryn 3T (Solo NDCE)", + "link": "https://www.youtube.com/watch?v=2csi-flWJCU", + "date": "2024-03-20", + "servant": "88", + "turns": "3T", + "runner": "SigrdrΓfa" + }, + { + "title": "Percival 3T (NDCE)", + "link": "https://www.youtube.com/watch?v=QYe-8ijdfnI&t=483s", + "date": "2024-03-20", + "servant": "313", + "turns": "3T", + "runner": "Liz Happy Club" + }, + { + "title": "Melusine 3T", + "link": "https://www.youtube.com/watch?v=HPNIxDrSFxc", + "date": "2024-03-19", + "servant": "312_aoe", + "turns": "3T", + "runner": "Yamada II" + }, + { + "title": "Melusine 3T (Lvl. 1)", + "link": "https://www.youtube.com/watch?v=JdlpwZKanJA&t=284s", + "date": "2024-03-26", + "servant": "312_st", + "turns": "3T", + "runner": "TokuHer0" + }, + { + "title": "Jekyll & Hyde 3T (FLO NDCE)", + "link": "https://www.youtube.com/watch?v=v_WlwqTJYTc", + "date": "2024-04-04", + "servant": "81", + "turns": "3T", + "runner": "Rikohaiji" + }, + { + "title": "Arjuna Alter 3T (FLO NoCE)", + "link": "https://www.youtube.com/watch?v=pLX_4PDIai8&t=133s", + "date": "2024-03-19", + "servant": "247", + "turns": "3T", + "runner": "Kusanagi" + }, + { + "title": "Astrea 3T (Lvl. 2 FLO NDCE)", + "link": "https://www.youtube.com/watch?v=9D6L_47msCw", + "date": "2024-03-21", + "servant": "242", + "turns": "3T", + "runner": "Alastair Hale" + } + ] + } + ] +} diff --git a/src/content/teslafest/mega-coil/summer-2018.json b/src/content/teslafest/mega-coil/summer-2018.json new file mode 100644 index 0000000..8f15d88 --- /dev/null +++ b/src/content/teslafest/mega-coil/summer-2018.json @@ -0,0 +1,33 @@ +{ + "$schema": "../../../../.astro/collections/teslafest.schema.json", + "info": { + "title": "Super My Home Daddy", + "releaseDate": "2024-03-15", + "shortdescription": "An quest where DOT damage is actually the key to success", + "releaseNumber": 1 + }, + "quests": [ + { + "questTitle": "Super My Home Daddy", + "description": "An quest where DOT damage is actually the key to success - what an achievement (Note: Not all participating servants are listed)", + "data": [ + { + "title": "Multicore - Douman 3T", + "link": "https://www.youtube.com/watch?v=JdlpwZKanJA", + "date": "2024-03-26", + "servant": "297", + "turns": "3T", + "runner": "TokuHer0" + }, + { + "title": "Multicore - Koyanskaya of Dark 3T", + "link": "https://www.youtube.com/watch?v=3NebOHW5IC0", + "date": "2024-04-09", + "servant": "334", + "turns": "3T", + "runner": "Zectry" + } + ] + } + ] +} diff --git a/src/content/teslafest/mega-coil/summer-2019.json b/src/content/teslafest/mega-coil/summer-2019.json new file mode 100644 index 0000000..d105213 --- /dev/null +++ b/src/content/teslafest/mega-coil/summer-2019.json @@ -0,0 +1,97 @@ +{ + "$schema": "../../../../.astro/collections/teslafest.schema.json", + "info": { + "title": "Heart Pounding! The Grand Decisive Swimsuit Battle!", + "releaseDate": "2024-03-15", + "shortdescription": "Such a collection of swimsuit beauties ... no, must ... beat ... the quest", + "releaseNumber": 7 + }, + "quests": [ + { + "questTitle": "Heart Pounding! The Grand Decisive Swimsuit Battle!", + "description": "Such a collection of swimsuit beauties ... no, must ... beat ... the quest", + "data": [ + { + "title": "Nero 3T (FLO)", + "link": "https://twitter.com/LutrecTA/status/1772766697864249523", + "date": "2024-03-27", + "servant": "5", + "turns": "3T", + "runner": "Lutrec" + }, + { + "title": "Musashi (Summer) 3T (NDCE)", + "link": "https://www.youtube.com/watch?v=agZb8zyHsfY&t=1373s", + "date": "2024-03-16", + "servant": "261", + "turns": "3T", + "runner": "Paradise" + }, + { + "title": "Musashi (Summer) 3T", + "link": "https://www.youtube.com/watch?v=QYe-8ijdfnI&t=1312s", + "date": "2024-03-15", + "servant": "261", + "turns": "3T", + "runner": "Liz Happy Club" + }, + { + "title": "Arjuna Alter 3T (FLO)", + "link": "https://www.youtube.com/watch?v=pLX_4PDIai8&t=676s", + "date": "2024-03-19", + "servant": "247", + "turns": "3T", + "runner": "Kusanagi" + }, + { + "title": "Space Ishtar 3T", + "link": "https://www.youtube.com/watch?v=EJAhp9Vs_ls&t=821s", + "date": "2024-03-16", + "servant": "268", + "turns": "3T", + "runner": "Sesshou01" + }, + { + "title": "Space Ishtar 3T", + "link": "https://www.youtube.com/watch?v=p8QkHOC-CgE&t=1231s", + "date": "2024-03-25", + "servant": "268", + "turns": "3T", + "runner": "Nyxi" + }, + { + "title": "Space Ishtar 3T (NDCE)", + "link": "https://www.youtube.com/watch?v=JdlpwZKanJA&t=740s", + "date": "2024-03-26", + "servant": "268", + "turns": "3T", + "runner": "TokuHer0" + }, + { + "title": "Summer Kama 3T", + "link": "https://www.youtube.com/watch?v=B2Buu8F2PMI&t=1736s", + "date": "2024-03-17", + "servant": "321", + "turns": "3T", + "runner": "Kamager III" + }, + { + "title": "Summer Kama 3T (FLO)", + "link": "https://www.youtube.com/watch?v=3NebOHW5IC0&t=989s", + "date": "2024-04-09", + "servant": "321", + "turns": "3T", + "runner": "Zectry" + }, + { + "title": "BB (Summer) 3T", + "link": "https://www.youtube.com/watch?v=qgaWv5dvMe0", + "date": "2024-03-25", + "servant": "220", + "turns": "3T", + "runner": "Rikohaiji" + } + ] + } + ] +} diff --git a/src/content/teslafest/mega-coil/valentines-2021.json b/src/content/teslafest/mega-coil/valentines-2021.json new file mode 100644 index 0000000..7574ab0 --- /dev/null +++ b/src/content/teslafest/mega-coil/valentines-2021.json @@ -0,0 +1,105 @@ +{ + "$schema": "../../../../.astro/collections/teslafest.schema.json", + "info": { + "title": "The Librarian's Job", + "releaseDate": "2024-03-15", + "shortdescription": "The Librarians job seems kinda interesting if she always has to deal with books like that", + "releaseNumber": 5 + }, + "quests": [ + { + "questTitle": "The Librarian's Job", + "description": "The Librarians job seems kinda interesting if she always has to deal with books like that - let's see if defeating them also is as much fun", + "data": [ + { + "title": "Sei 2T", + "link": "https://www.youtube.com/watch?v=-Id8YIoJpN0", + "date": "2024-03-17", + "servant": "276", + "turns": "2T", + "runner": "Ise(Kai)" + }, + { + "title": "Kintoki (Rider) 2T (w. Arash)", + "link": "https://www.youtube.com/watch?v=EJAhp9Vs_ls&t=560s", + "date": "2024-03-16", + "servant": "115", + "turns": "2T", + "runner": "Sesshou01" + }, + { + "title": "Odysseus 2T (FLO)", + "link": "https://www.youtube.com/watch?v=3NebOHW5IC0&t=707s", + "date": "2024-04-09", + "servant": "277", + "turns": "2T", + "runner": "Zectry" + }, + { + "title": "Taigong Wang 2T (FLO NoCE)", + "link": "https://www.youtube.com/watch?v=-3srNDj0opg", + "date": "2024-03-16", + "servant": "331", + "turns": "2T", + "runner": "Ryougi Bobby" + }, + { + "title": "Arjuna Alter 2T (FLO NoCEs)", + "link": "https://www.youtube.com/watch?v=pLX_4PDIai8&t=413s", + "date": "2024-03-19", + "servant": "247", + "turns": "2T", + "runner": "Kusanagi" + }, + { + "title": "Maou Nobu 2T (FLO NoCEs)", + "link": "https://www.youtube.com/watch?v=_Sb7j2XAT5U", + "date": "2024-03-19", + "servant": "250", + "turns": "2T", + "runner": "SigrdrΓfa" + }, + { + "title": "Bazett 1T (w. Ozy)", + "link": "https://www.youtube.com/watch?v=agZb8zyHsfY&t=1014s", + "date": "2024-03-16", + "servant": "336", + "turns": "1T", + "runner": "Paradise" + }, + { + "title": "Bazett 1T (w. Cindereli)", + "link": "https://www.youtube.com/watch?v=tJLGb9xye6Y", + "date": "2024-03-24", + "servant": "336", + "turns": "1T", + "runner": "Alastair Hale" + }, + { + "title": "Bazett 1T (w. Maid Alter)", + "link": "https://www.youtube.com/watch?v=JdlpwZKanJA&t=558s", + "date": "2024-03-26", + "servant": "336", + "turns": "1T", + "runner": "TokuHer0" + }, + { + "title": "Bazett 1T (w. Ozy)", + "link": "https://www.youtube.com/watch?v=QYe-8ijdfnI&t=958s", + "date": "2024-03-15", + "servant": "336", + "turns": "1T", + "runner": "Liz Happy Club" + }, + { + "title": "Bazett 1T (w. Arash)", + "link": "https://www.youtube.com/watch?v=p8QkHOC-CgE&t=797s", + "date": "2024-03-25", + "servant": "336", + "turns": "1T", + "runner": "Nyxi" + } + ] + } + ] +} diff --git a/src/content/teslafest/mega-coil/white-day-2021.json b/src/content/teslafest/mega-coil/white-day-2021.json new file mode 100644 index 0000000..495bd66 --- /dev/null +++ b/src/content/teslafest/mega-coil/white-day-2021.json @@ -0,0 +1,57 @@ +{ + "$schema": "../../../../.astro/collections/teslafest.schema.json", + "info": { + "title": "Rematch at Reichenbach Falls", + "releaseDate": "2024-03-15", + "shortdescription": "A showdown of epic proportions - make sure to bring some defense ignore", + "releaseNumber": 6 + }, + "quests": [ + { + "questTitle": "Rematch at Reichenbach Falls", + "description": "A showdown of epic proportions - make sure to bring some defense ignore", + "data": [ + { + "title": "Jekyll & Hyde 3T", + "link": "https://www.youtube.com/watch?v=v_WlwqTJYTc&t=155s", + "date": "2024-04-04", + "servant": "81", + "turns": "3T", + "runner": "Rikohaiji" + }, + { + "title": "Arjuna Alter 3T (FLO NDCE)", + "link": "https://www.youtube.com/watch?v=pLX_4PDIai8&t=526s", + "date": "2024-03-19", + "servant": "247", + "turns": "3T", + "runner": "Kusanagi" + }, + { + "title": "Xiang Yu 3T (FLO)", + "link": "https://www.youtube.com/watch?v=JdlpwZKanJA&t=641s", + "date": "2024-04-04", + "servant": "226", + "turns": "3T", + "runner": "TokuHer0" + }, + { + "title": "Maou Nobu 3T (FLO NDCE)", + "link": "https://www.youtube.com/watch?v=CvvXasgp-iY", + "date": "2024-03-20", + "servant": "250", + "turns": "3T", + "runner": "SigrdrΓfa" + }, + { + "title": "Taira 3T (FLO)", + "link": "https://www.youtube.com/watch?v=3NebOHW5IC0&t=839s", + "date": "2024-04-04", + "servant": "303", + "turns": "3T", + "runner": "Zectry" + } + ] + } + ] +} diff --git a/src/content/teslafestgroups/eq-2020.json b/src/content/teslafestgroups/eq-2020.json new file mode 100644 index 0000000..73fb69f --- /dev/null +++ b/src/content/teslafestgroups/eq-2020.json @@ -0,0 +1,10 @@ +{ + "$schema": "../../../.astro/collections/teslafestgroups.schema.json", + "info": { + "title": "Exhibition Quests 2020", + "releaseDate": "2024-03-15", + "shortdescription": "The return of the 2020 Nerofest Exhibition Quests - time to go for round 2", + "releaseNumber": 1, + "type": "group" + } +} diff --git a/src/content/teslafestgroups/eq-2021.json b/src/content/teslafestgroups/eq-2021.json new file mode 100644 index 0000000..2c33206 --- /dev/null +++ b/src/content/teslafestgroups/eq-2021.json @@ -0,0 +1,10 @@ +{ + "$schema": "../../../.astro/collections/teslafestgroups.schema.json", + "info": { + "title": "Exhibition Quests 2021", + "releaseDate": "2024-03-15", + "shortdescription": "The return of the 2021 Ishtarfest Exhibition Quests - time to run those again", + "releaseNumber": 2, + "type": "group" + } +} diff --git a/src/content/teslafestgroups/giga-coil.json b/src/content/teslafestgroups/giga-coil.json new file mode 100644 index 0000000..f0c774a --- /dev/null +++ b/src/content/teslafestgroups/giga-coil.json @@ -0,0 +1,10 @@ +{ + "$schema": "../../../.astro/collections/teslafestgroups.schema.json", + "info": { + "title": "Giga Coil", + "releaseDate": "2024-03-15", + "shortdescription": "The second collection of old Challenge Quests that requires strategic of servants - let's go again", + "releaseNumber": 4, + "type": "group" + } +} diff --git a/src/content/teslafestgroups/mega-coil.json b/src/content/teslafestgroups/mega-coil.json new file mode 100644 index 0000000..9b65bc7 --- /dev/null +++ b/src/content/teslafestgroups/mega-coil.json @@ -0,0 +1,10 @@ +{ + "$schema": "../../../.astro/collections/teslafestgroups.schema.json", + "info": { + "title": "Mega Coil", + "releaseDate": "2024-03-15", + "shortdescription": "A collection of old Challenge Quests that requires strategic use of a full servant roster - be prepared", + "releaseNumber": 3, + "type": "group" + } +} \ No newline at end of file diff --git a/src/data/_navdata.json b/src/data/_navdata.json new file mode 100644 index 0000000..68082cd --- /dev/null +++ b/src/data/_navdata.json @@ -0,0 +1,17 @@ +[ + { + "link": "/", + "text": "Home", + "icon": "home" + }, + { + "link": "/database", + "text": "TA Database", + "icon": "database" + }, + { + "link": "/teslafest", + "text": "Teslafest", + "icon": "databasestar" + } +] diff --git a/src/env.d.ts b/src/env.d.ts index f964fe0..acef35f 100644 --- a/src/env.d.ts +++ b/src/env.d.ts @@ -1 +1,2 @@ +/// <reference path="../.astro/types.d.ts" /> /// <reference types="astro/client" /> diff --git a/src/layouts/Layout.astro b/src/layouts/Layout.astro index 772dc5e..39e99c5 100644 --- a/src/layouts/Layout.astro +++ b/src/layouts/Layout.astro @@ -1,7 +1,16 @@ --- import Navbar from '../components/navbar.astro' import NavbarEntry from '../components/navbarEntry.astro' -import navdata from '../../static/assets/data/_navdata.json' +import navdata from '../data/_navdata.json' +import embed from '../assets/embed.png' +import home from 'iconoir/icons/home.svg' +import database from 'iconoir/icons/database.svg' +import databasestar from 'iconoir/icons/database-star.svg' +import mail from 'iconoir/icons/mail.svg' +import type { IconsLookup } from '../types/generic' + +import workSans800 from '@fontsource/work-sans/files/work-sans-latin-800-normal.woff2?url'; +import workSans600 from '@fontsource/work-sans/files/work-sans-latin-600-normal.woff2?url'; export interface Props { title: string @@ -9,6 +18,13 @@ export interface Props { descriptionOverride?: string } +const icons: IconsLookup = { + home: home, + database: database, + databasestar: databasestar, + about: mail +} + const { descriptionOverride, currentpage, title } = Astro.props let description @@ -22,9 +38,14 @@ let currPage = 'https://fgo-ta.com/' if (currentpage !== 'home') { currPage += currentpage } + +const mapped_navdata = navdata.map((item) => ({ + ...item, + ...{ icon: icons[item.icon] }, +})) --- -<!DOCTYPE html> +<!doctype html> <html lang="en"> <head> <title>{title}</title> @@ -36,24 +57,39 @@ if (currentpage !== 'home') { <meta property="og:title" content={title} /> <meta property="og:url" content={currPage} /> <meta property="og:description" content={description} /> - <meta property="og:image" content="/assets/embed.png" /> + <meta property="og:image" content={embed.src} /> <meta property="og:type" content="website" /> <meta property="og:locale" content="en_US" /> <meta name="theme-color" content="#b86cff" /> + <!-- Disable DarkReader, as site is already in dark mode --> + <meta name="darkreader-lock" content="this site only has darkmode"> <!-- Links --> - <link rel="icon" type="image/ico" href="/assets/favicon.ico" /> + <link rel="preload" as="font" type="font/woff2" href={workSans600} crossorigin="anonymous" /> + <link rel="preload" as="font" type="font/woff2" href={workSans800} crossorigin="anonymous" /> + <link rel="icon" type="image/ico" href="/favicon.ico" /> <link rel="sitemap" href="/sitemap-index.xml" /> <link href="https://mastodon.neshweb.net/@Firq" rel="me" /> - <link - rel="stylesheet" - href="https://cdn.jsdelivr.net/gh/iconoir-icons/iconoir@main/css/iconoir.css" - /> </head> <body> <Navbar> { - navdata.map((item) => ( - <NavbarEntry currentPage={currentpage} {...item} /> + mapped_navdata.map((item) => ( + <NavbarEntry + currentPage={currentpage} + navtype="desktop" + {...item} + slot="desktop" + /> + )) + } + { + mapped_navdata.map((item) => ( + <NavbarEntry + currentPage={currentpage} + navtype="mobile" + {...item} + slot="mobile" + /> )) } </Navbar> @@ -63,7 +99,7 @@ if (currentpage !== 'home') { <style is:global> :root { --hover-scale: 1.05; - --speed: 50%; + --speed: 0.5; --ease: 50%; font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif; --c-darkgray: #1e1e1e; @@ -71,11 +107,25 @@ if (currentpage !== 'home') { --c-gray: #2e2e2e; --c-lightgray: #3e3e3e; --c-darkpurple: #b86cff; + --c-lighterpurple: #c98fff; --c-purplepink: #c105ff; --c-darkergray: #1b1b1b; + --c-reddish: #ff0077; + --c-lighter: #eee; } body { background: var(--c-lightgray); margin: 0px; } + + .visually-hidden { + border: 0; + clip: rect(0 0 0 0); + height: 1px; + margin: -1px; + overflow: hidden; + padding: 0; + position: absolute; + width: 1px; + } </style> diff --git a/src/layouts/baseSection.astro b/src/layouts/baseSection.astro index 05961a9..eea3647 100644 --- a/src/layouts/baseSection.astro +++ b/src/layouts/baseSection.astro @@ -1,13 +1,17 @@ --- export interface Props { title: string + hidetitle?: boolean + description: string } -const { title } = Astro.props +const { title, hidetitle, description } = Astro.props +const override = hidetitle ? "display: None" : "" --- <div class="base"> - <h1>{title}</h1> + <h1 style={override}>{title}</h1> + <h2 style={override}>{description}</h2> <div> <slot /> </div> @@ -19,36 +23,41 @@ const { title } = Astro.props flex-direction: column; justify-content: center; text-align: center; - } - div > div { - row-gap: 1em; - column-gap: 1em; - justify-content: center; - align-self: center; - display: flex; - flex-flow: row wrap; - padding: 1em; - position: relative; - } - div h1 { - font-size: 40px; - line-height: 48px; - letter-spacing: -1px; - color: white; - margin-top: 2rem; - margin-bottom: 0px; - margin-left: auto; - margin-right: auto; - padding: 0.25rem 1.5rem; - border-radius: 0.5rem; - max-width: max-content; - background-color: var(--c-darkgray); - padding-bottom: 0.5rem; - } - @media (min-width: 512px) { + div { - row-gap: 1.5em; - column-gap: 1.5em; + gap: 1em; + align-self: center; + flex-flow: row wrap; + padding-top: 1em; + position: relative; + } + + h1 { + font-size: 40px; + line-height: 48px; + letter-spacing: -1px; + color: white; + margin: 2rem auto 0px auto; + padding: 0.25rem 1.5rem; + border-radius: 0.5rem; + max-width: max-content; + background-color: var(--c-darkgray); + padding-bottom: 0.5rem; + } + + h2 { + color: white; + font-size: 16px; + font-weight: 600; + max-width: 75; + margin: 1rem; + line-height: 20px; + text-align: center; + + @supports (text-align-last: center) { + text-align: justify; + text-align-last: center; + } } } @@ -56,6 +65,12 @@ const { title } = Astro.props margin-left: 1rem; margin-right: 1rem; } + @media (min-width: 512px) { + div { + row-gap: 1.5em; + column-gap: 1.5em; + } + } @media (min-width: 1000px) { .base { @@ -64,10 +79,23 @@ const { title } = Astro.props } } - @media (min-width: 1500px) { + @media (min-width: 1140px) { .base { margin-left: 10%; margin-right: 10%; } + + div { + h1 { + margin-left: unset; + margin-right: unset; + } + h2 { + text-align: left; + @supports (text-align-last: center) { + text-align-last: unset; + } + } + } } </style> diff --git a/src/layouts/databaseSection.astro b/src/layouts/databaseSection.astro new file mode 100644 index 0000000..9fdf39a --- /dev/null +++ b/src/layouts/databaseSection.astro @@ -0,0 +1,144 @@ +--- +export interface Props { + title: string + titlehidden?: boolean + displayLine?: boolean +} +const { title, titlehidden, displayLine } = Astro.props +const display = titlehidden ? "display: none" : "" +const line = displayLine ? "flex" : "none" +--- + +<section> + <h1 style={display}>{title}</h1> + <div class="wrapper"> + <div class="start hightlighter"></div> + <div class="line"></div> + <slot /> + <div class="drop hightlighter"></div> + </div> +</section> + +<style define:vars={{ line }}> + section { + padding-left: 0.25em; + padding-right: 0.25em; + padding-bottom: 5rem; + } + + .hightlighter { + left: 0; + right: 0; + display: flex; + position: absolute; + visibility: visible; + margin-left: auto; + margin-right: auto; + height: 1.5rem; + width: 1.5rem; + } + + .drop { + bottom: -5rem; + border-radius: 0% 50% 50% 50%; + transform: rotate(45deg); + background-color: var(--c-darkpurple); + } + + .start { + top: -2rem; + border-radius: 40%; + border-style: solid; + border-width: 0.25rem; + border-color: var(--c-lightgray); + background-color: var(--c-darkpurple); + } + + .line { + display: flex; + position: absolute; + visibility: visible; + left: 0; + right: 0; + margin-left: auto; + margin-right: auto; + background-color: var(--c-darkpurple); + height: calc(100% + 5rem); + translate: 0% 2rem; + width: 0.25rem; + z-index: -1; + } + h1 { + line-height: 48px; + letter-spacing: -1px; + color: white; + font-size: 1.6rem; + margin-top: 1rem; + margin-bottom: 0; + margin-left: auto; + margin-right: auto; + max-width: max-content; + background-color: var(--c-darkgray); + padding: 0.25rem 1.5rem; + border-radius: 0.5rem; + padding-bottom: 0.5rem; + justify-self: center; + text-align: center; + } + .wrapper { + margin: 2rem 2rem 0.5rem 2rem; + display: flex; + flex-flow: column wrap; + row-gap: 1em; + column-gap: 1em; + align-self: center; + align-items: stretch; + align-content: center; + justify-content: space-around; + padding: 1em; + color: white; + font-size: 1em; + position: relative; + } + @media (min-width: 900px) { + .drop { + margin-left: 1.5rem; + } + .start { + margin-left: 1.25rem; + } + .line { + margin-left: 2.1rem; + } + h1 { + margin-left: 3rem; + font-size: 1.85rem; + } + } + @media (min-width: 1500px) { + .wrapper { + margin-left: 15rem; + margin-right: 15rem; + flex-direction: row; + } + section { + padding-bottom: unset; + } + .drop, .start, .line { + display: var(--line); + margin-left: 2rem; + } + .start { + margin-left: 1.75rem; + } + .line { + margin-left: 2.6rem; + height: calc(100% + 6rem); + translate: 0px -2rem; + } + h1 { + margin-left: 15rem; + margin-right: 15rem; + } + } +</style> diff --git a/src/layouts/taShowcaseLayout.astro b/src/layouts/taShowcaseLayout.astro new file mode 100644 index 0000000..a9eb502 --- /dev/null +++ b/src/layouts/taShowcaseLayout.astro @@ -0,0 +1,94 @@ +--- +import Layout from '../layouts/Layout.astro' +import BaseSection from '../layouts/baseSection.astro' +import TACard from '../components/taCard.astro' +import { plsLoadTAEntry } from '../utils/tools' +import { Image } from 'astro:assets' +import lizsad from '../assets/lizsad.png' +import SmallTitle from '../components/smallTitle.astro' + +export interface Props { + collection: 'teslafest' | 'taInfoData' + collectionKey: string + baseurl: string +} + +const { collection, collectionKey, baseurl } = Astro.props +const taEntry = await plsLoadTAEntry(collectionKey, collection) +const pagetitle = `${taEntry.info.title} - FGO TA` +const displaystate = taEntry.quests[0].data.length > 0 ? 'none' : 'flex' +const hidetitle = taEntry.quests.length <= 1 +--- + +<Layout + title={pagetitle} + currentpage="database-entry" + descriptionOverride={taEntry.info.shortdescription} +> + <SmallTitle + maintext={taEntry.info.title} + subtext={taEntry.info.shortdescription} + fadeout={true} + baseurl={baseurl} + returnbutton={true} + /> + { + taEntry.quests.map((item) => ( + <BaseSection title={item.questTitle} description={item.description} hidetitle={hidetitle}> + {item.data + .sort((a, b) => b.date.valueOf() - a.date.valueOf()) + .map((item) => ( + <TACard {...item} /> + ))} + </BaseSection> + )) + } + <div style=`display: ${displaystate}` class="overridewrapper"> + <Image + class="overrideimage" + src={lizsad} + alt="Sad override if there are no runs" + loading="eager" + /> + </div> + <div class="placeholder"></div> +</Layout> + +<style> + .overridewrapper { + justify-content: center; + margin-left: auto; + margin-right: auto; + height: 100%; + width: 100%; + } + .overrideimage { + overflow: auto; + height: auto; + width: auto; + max-width: max-content; + max-height: 16rem; + padding: 0px 1rem; + border-radius: 4rem; + } + .placeholder { + visibility: hidden; + width: 100%; + height: 2.5rem; + } + + a { + position: sticky; + top: 4rem; + z-index: 1; + display: flex; + align-items: center; + justify-content: center; + width: 100%; + text-align: center; + color: white; + background-color: var(--c-gray); + padding: 0.5rem 0px; + text-decoration: none; + } +</style> diff --git a/src/pages/404.astro b/src/pages/404.astro new file mode 100644 index 0000000..6feeda7 --- /dev/null +++ b/src/pages/404.astro @@ -0,0 +1,63 @@ +--- +import { Image } from 'astro:assets' +import Layout from '../layouts/Layout.astro' +import BaseSection from '../layouts/baseSection.astro' +import sadshishou from '../assets/shishousad.webp' + +const description = "Error. This shouldn't happen :/" +--- + +<Layout + title="404 - FGO TA" + currentpage="404" + descriptionOverride={description} +> + <BaseSection title="Firqhundred­andFirq - Not Found" description=""> + <div> + <Image src={sadshishou} alt="Sad Shishou" /> + <h2>Well ... you were not supposed to end up here.</h2> + <a href="/" aria-label="Home" rel="noopener noreferrer"> + << Go back home + </a> + </div> + </BaseSection> +</Layout> + +<style> + div { + display: flex; + flex-wrap: wrap; + flex-direction: column; + align-items: center; + } + h2 { + color: white; + font-size: 2rem; + font-weight: bold; + margin-top: 1rem; + max-width: max-content; + } + a { + display: flex; + align-items: center; + justify-content: center; + width: 75%; + text-align: center; + color: white; + background-color: var(--c-gray); + padding: 0.5rem 0px; + margin-bottom: 2rem; + text-decoration: none; + font-size: 1.5rem; + font-weight: bold; + } + + a:hover { + color: var(--c-darkpurple); + } + + img { + width: 256px; + height: 256px; + } +</style> diff --git a/src/pages/database/[...slug].astro b/src/pages/database/[...slug].astro new file mode 100644 index 0000000..e425539 --- /dev/null +++ b/src/pages/database/[...slug].astro @@ -0,0 +1,122 @@ +--- +import { getCollection } from 'astro:content' +import TaShowcaseLayout from '../../layouts/taShowcaseLayout.astro' +import Layout from '../../layouts/Layout.astro' +import DatabaseSection from '../../layouts/databaseSection.astro' +import QuestListing from '../../components/listings/questListingCard.astro' +import SmallTitle from '../../components/smallTitle.astro' + +interface store { + slug: string + group: boolean + questinfo: + | undefined + | { + slug: string + info: { + title: string + releaseDate: Date + shortdescription: string + releaseNumber: number + } + }[] + pageinfo: + | undefined + | { + title: string + shortdescription: string + } +} + +export async function getStaticPaths() { + const fulldata = await getCollection('taInfoData') + const slugdata: store[] = fulldata.map((data) => { + return { + slug: data.id, + group: false, + questinfo: undefined, + pageinfo: undefined, + } + }) + + const groupdata = await getCollection('groups') + const groups: store[] = groupdata.map((data) => { + return { + slug: data.id, + group: true, + questinfo: undefined, + pageinfo: undefined, + } + }) + + const full = slugdata.concat(groups as any) + full.map((data) => { + if (data.group) { + const coll = fulldata.filter((d) => d.id.split("/", 1)[0] == data.slug) + data.questinfo = coll.map((d) => { + return { slug: d.id, info: d.data.info } + }) + data.questinfo.sort( + (a, b) => + b.info.releaseDate.valueOf() - a.info.releaseDate.valueOf() || + b.info.releaseNumber - a.info.releaseNumber + ) + const page = groupdata.find((d) => d.id === data.slug) + data.pageinfo = page?.data.info + } + }) + + return full.map((data) => ({ + params: { slug: data.slug }, + props: { + key: data.slug, + group: data.group, + questinfo: data.questinfo, + pageinfo: data.pageinfo, + }, + })) +} + +const { key, group, questinfo, pageinfo } = Astro.props + +let baseurl_return = "database" +if (key.includes("/")) { + baseurl_return = baseurl_return + "/" + key.split("/", 1)[0] +} + +--- + +{ + !group && ( + <TaShowcaseLayout + collection="taInfoData" + collectionKey={key} + baseurl={baseurl_return} + /> + ) +} +{ + group && ( + <Layout + title={`${pageinfo!.title} - TA Database - FGO TA`} + currentpage="database" + descriptionOverride={pageinfo!.shortdescription} + > + <SmallTitle + maintext={pageinfo!.title} + subtext={pageinfo!.shortdescription} + fadeout={true} + baseurl="database" + returnbutton={true} + /> + <DatabaseSection title="" titlehidden={true}> + {questinfo!.map((quest) => ( + <QuestListing + {...{ ...quest.info, slug: quest.slug }} + baseurl="database" + /> + ))} + </DatabaseSection> + </Layout> + ) +} diff --git a/src/pages/database/index.astro b/src/pages/database/index.astro new file mode 100644 index 0000000..1208bf9 --- /dev/null +++ b/src/pages/database/index.astro @@ -0,0 +1,61 @@ +--- +import { getCollection } from 'astro:content' +import Layout from '../../layouts/Layout.astro' +import QuestListing from '../../components/listings/questListingLine.astro' +import EventListing from '../../components/listings/eventListingLine.astro' +import DatabaseSection from '../../layouts/databaseSection.astro' +import SmallTitle from '../../components/smallTitle.astro' + +const description = 'A mostly up-to-date list of NA TA runs' +const fulldata = await getCollection('taInfoData') +const groups = await getCollection('groups') +const changes = await getCollection('changes') +let combined = fulldata + +for (const group of groups) { + combined = combined.filter((data) => !data.id.startsWith(group.id)) +} +combined = combined.concat(groups as any).concat(changes as any) + +combined.sort( + (a, b) => + b.data.info.releaseDate.valueOf() - a.data.info.releaseDate.valueOf() || + b.data.info.releaseNumber - a.data.info.releaseNumber +) +--- + +<Layout + title="TA Database - FGO TA" + currentpage="database" + descriptionOverride={description} +> + <SmallTitle + maintext="TA DATA­BASE" + subtext="A mostly up-to-date list of NA TA runs" + fadeout={true} + /> + <DatabaseSection title="NA Runs" titlehidden={true} displayLine={true}> + { + combined.map((quest) => { + if (['quest', 'group'].includes(quest.data.info.type)) { + return ( + <QuestListing + {...{ ...quest.data.info, slug: quest.id }} + baseurl="database" + /> + ) + } else { + return ( + <EventListing + {...{ ...quest.data.info, slug: quest.id }} + link={(quest.data as any).link} + hlcolor={(quest.data as any).color} + /> + ) + } + }) + } + </DatabaseSection> +</Layout> + +<style></style> diff --git a/src/pages/index.astro b/src/pages/index.astro index b97ddf9..a5dec7f 100644 --- a/src/pages/index.astro +++ b/src/pages/index.astro @@ -1,6 +1,7 @@ --- import Layout from '../layouts/Layout.astro' import Hero from '../components/hero.astro' +import Title from '../components/title.astro' const description = 'This site is a WIP project by Firq. In the future, it will be used to catalogue information around FGO TA and the game in general.' @@ -11,7 +12,8 @@ const description = currentpage="home" descriptionOverride={description} > -<Hero /> + <Title maintext='FGO NA TA DATA­BASE' subtext='The all-in-one lookup for all your TA needs'/> + <Hero fadeout={true}/> </Layout> <style></style> diff --git a/src/pages/teslafest/[...slug].astro b/src/pages/teslafest/[...slug].astro new file mode 100644 index 0000000..2527418 --- /dev/null +++ b/src/pages/teslafest/[...slug].astro @@ -0,0 +1,122 @@ +--- +import { getCollection } from 'astro:content' +import TaShowcaseLayout from '../../layouts/taShowcaseLayout.astro' +import Layout from '../../layouts/Layout.astro' +import DatabaseSection from '../../layouts/databaseSection.astro' +import QuestListing from '../../components/listings/questListingCard.astro' +import SmallTitle from '../../components/smallTitle.astro' + +interface store { + slug: string + group: boolean + questinfo: + | undefined + | { + slug: string + info: { + title: string + releaseDate: Date + shortdescription: string + releaseNumber: number + } + }[] + pageinfo: + | undefined + | { + title: string + shortdescription: string + } +} + +export async function getStaticPaths() { + const fulldata = await getCollection('teslafest') + const slugdata: store[] = fulldata.map((data) => { + return { + slug: data.id, + group: false, + questinfo: undefined, + pageinfo: undefined, + } + }) + + const groupdata = await getCollection('teslafestgroups') + const groups: store[] = groupdata.map((data) => { + return { + slug: data.id, + group: true, + questinfo: undefined, + pageinfo: undefined, + } + }) + + const full = slugdata.concat(groups as any) + full.map((data) => { + if (data.group) { + const coll = fulldata.filter((d) => d.id.split("/", 1)[0] == data.slug) + data.questinfo = coll.map((d) => { + return { slug: d.id, info: d.data.info } + }) + data.questinfo.sort( + (a, b) => + b.info.releaseDate.valueOf() - a.info.releaseDate.valueOf() || + b.info.releaseNumber - a.info.releaseNumber + ) + const page = groupdata.find((d) => d.id === data.slug) + data.pageinfo = page?.data.info + } + }) + + return full.map((data) => ({ + params: { slug: data.slug }, + props: { + key: data.slug, + group: data.group, + questinfo: data.questinfo, + pageinfo: data.pageinfo, + }, + })) +} + +const { key, group, questinfo, pageinfo } = Astro.props + +let baseurl_return = "teslafest" +if (key.includes("/")) { + baseurl_return = baseurl_return + "/" + key.split("/", 1)[0] +} + +--- + +{ + !group && ( + <TaShowcaseLayout + collection="teslafest" + collectionKey={key} + baseurl={baseurl_return} + /> + ) +} +{ + group && ( + <Layout + title={`${pageinfo!.title} - Teslafest - FGO TA`} + currentpage="teslafest" + descriptionOverride={pageinfo!.shortdescription} + > + <SmallTitle + maintext={pageinfo!.title} + subtext={pageinfo!.shortdescription} + fadeout={true} + baseurl="teslafest" + returnbutton={true} + /> + <DatabaseSection title="" titlehidden={true}> + {questinfo!.map((quest) => ( + <QuestListing + {...{ ...quest.info, slug: quest.slug }} + baseurl="teslafest" + /> + ))} + </DatabaseSection> + </Layout> + ) +} diff --git a/src/pages/teslafest/index.astro b/src/pages/teslafest/index.astro new file mode 100644 index 0000000..f307056 --- /dev/null +++ b/src/pages/teslafest/index.astro @@ -0,0 +1,39 @@ +--- +import { getCollection } from 'astro:content' +import Layout from '../../layouts/Layout.astro' +import QuestListing from '../../components/listings/questListingLine.astro' +import DatabaseSection from '../../layouts/databaseSection.astro' +import SmallTitle from '../../components/smallTitle.astro' + +const description = + 'One of the most anticipated events of 2024 - Teslafest. Were the two weeks of time enough for all those quests, even with a parallel lottery?' +const fulldata = await getCollection('teslafest') +const groups = await getCollection('teslafestgroups') + +let combined = fulldata +for (const group of groups) { + combined = combined.filter((data) => !data.id.startsWith(group.id)) +} +combined = combined.concat(groups as any) + +combined.sort( + (a, b) => + b.data.info.releaseDate.valueOf() - a.data.info.releaseDate.valueOf() || + b.data.info.releaseNumber - a.data.info.releaseNumber +) +--- + +<Layout + title="Teslafest - FGO TA" + currentpage="teslafest" + descriptionOverride={description} +> + <SmallTitle maintext="TESLAΒFEST" subtext={description} fadeout={true} /> + <DatabaseSection title="NA Runs" titlehidden={true} displayLine={true}> + { + combined.map((quest) => { return (<QuestListing {...{ ...quest.data.info, slug: quest.id }} baseurl="teslafest" />)}) + } + </DatabaseSection> +</Layout> + +<style></style> diff --git a/src/types/generic.ts b/src/types/generic.ts new file mode 100644 index 0000000..d1a9693 --- /dev/null +++ b/src/types/generic.ts @@ -0,0 +1,10 @@ +export interface IconsLookup { + [key: string]: ImageMetadata +} + +interface GlobGeneric<T> { + default: T +} +export type GlobImage = GlobGeneric<ImageMetadata> + +export type ImportRecord<T> = Record<string, () => Promise<T>> \ No newline at end of file diff --git a/src/utils/tools.ts b/src/utils/tools.ts new file mode 100644 index 0000000..6d497ed --- /dev/null +++ b/src/utils/tools.ts @@ -0,0 +1,14 @@ +import { getEntry } from 'astro:content' +import type { GlobImage, ImportRecord } from '../types/generic' + +export function plsLoadImage(record: ImportRecord<GlobImage>, path: string) { + const loadedImage = record[path]?.() + if (!loadedImage) throw new Error(`Asset was not found for path ${path}`) + return loadedImage +} + +export async function plsLoadTAEntry(key: string, file: "taInfoData" | "teslafest" = 'taInfoData') { + const filecontent = (await getEntry(file, key))?.data + if (!filecontent) throw new Error(`Datafile was not found for key ${key}`) + return filecontent +} diff --git a/static/assets/data/_navdata.json b/static/assets/data/_navdata.json deleted file mode 100644 index 4c5dbc6..0000000 --- a/static/assets/data/_navdata.json +++ /dev/null @@ -1,7 +0,0 @@ -[ - { - "link": "/", - "text": "Home", - "icon": "iconoir-home-alt" - } -] \ No newline at end of file diff --git a/tsconfig.json b/tsconfig.json index 77da9dd..bcbf8b5 100644 --- a/tsconfig.json +++ b/tsconfig.json @@ -1,3 +1,3 @@ { "extends": "astro/tsconfigs/strict" -} \ No newline at end of file +} diff --git a/unlighthouse.config.ts b/unlighthouse.config.ts new file mode 100644 index 0000000..6f7d007 --- /dev/null +++ b/unlighthouse.config.ts @@ -0,0 +1,32 @@ +export default { + lighthouseOptions: { + throttlingMethod: "devtools", + throttling: { + cpuSlowdownMultiplier: 4, + requestLatencyMs: 150, + downloadThroughputKbps: 1638.4, + uploadThroughputKbps: 1638.4, + }, + screenEmulation: { + width: 412, + height: 823, + deviceScaleFactor: 1.75, + } + }, + puppeteerOptions: { + args: [ + "--no-sandbox", + "--disable-setuid-sandbox" + ], + }, + ci: { + budget: 50, + buildStatic: true, + }, + scanner: { + sitemap: true, + dynamicSampling: false, + samples: 3, + }, + outputPath: "unlighthouse-reports", +}