From 326a769f5a1a07ce057b59b2fad26ea1cc5c5108 Mon Sep 17 00:00:00 2001 From: sockmaster27 <61235930+sockmaster27@users.noreply.github.com> Date: Wed, 23 Oct 2024 14:29:13 +0200 Subject: [PATCH] Split workspace into seperate packages --- .github/workflows/ci.yml | 2 +- .github/workflows/npm-publish.yml | 3 +- .gitignore | 6 +- .npmrc | 1 - LICENSE.md | 22 +- README.md | 295 +-- package-lock.json | 2216 +++++++++++++++++ package.json | 68 +- packages/svader/LICENSE.md | 21 + packages/svader/README.md | 294 +++ packages/svader/package.json | 55 + .../svader/src}/lib/BaseShader.svelte | 0 .../svader/src}/lib/WebGlShader.svelte | 0 .../svader/src}/lib/WebGpuShader.svelte | 0 {src => packages/svader/src}/lib/index.js | 0 .../svader/src}/lib/intersectionObserver.js | 0 {src => packages/svader/src}/lib/utils.js | 0 packages/svader/svelte.config.js | 4 + .../svader/tsconfig.json | 0 packages/tests-svelte4/package.json | 23 + .../tests-svelte4/resources}/banner.png | Bin .../tests-svelte4/resources}/bubbles.png | Bin .../tests-svelte4/resources}/collage.png | Bin .../resources}/debugShaderWebGl.png | Bin .../resources}/debugShaderWebGpu.png | Bin .../tests-svelte4/resources}/halo.png | Bin .../tests-svelte4/resources}/logoDark.png | Bin .../tests-svelte4/resources}/logoLight.png | Bin .../tests-svelte4/resources}/slider.png | Bin {src => packages/tests-svelte4/src}/app.d.ts | 0 {src => packages/tests-svelte4/src}/app.html | 1 + .../src}/routes/+layout.server.js | 0 .../tests-svelte4/src}/routes/+page.svelte | 0 .../src}/routes/hello-world/+page.svelte | 0 .../routes/hello-world/webgl/+page.svelte | 2 +- .../src}/routes/hello-world/webgl/shader.frag | 0 .../routes/hello-world/webgpu/+page.svelte | 2 +- .../routes/hello-world/webgpu/shader.wgsl | 0 .../routes/landing-page-bubbles/+page.svelte | 0 .../landing-page-bubbles/webgl/+page.svelte | 2 +- .../landing-page-bubbles/webgl/shader.frag | 0 .../landing-page-bubbles/webgpu/+page.svelte | 2 +- .../landing-page-bubbles/webgpu/shader.wgsl | 0 .../routes/landing-page-halo/+page.svelte | 0 .../landing-page-halo/webgl/+page.svelte | 2 +- .../landing-page-halo/webgl/shader.frag | 0 .../landing-page-halo/webgpu/+page.svelte | 2 +- .../landing-page-halo/webgpu/shader.wgsl | 0 .../src}/routes/logo/+page.svelte | 0 .../src}/routes/logo/logoDark.png | Bin .../src}/routes/logo/webgl/+page.svelte | 2 +- .../src}/routes/logo/webgl/shader.frag | 0 .../src}/routes/logo/webgpu/+page.svelte | 2 +- .../src}/routes/logo/webgpu/shader.wgsl | 0 .../src}/routes/oversized-canvas/+page.svelte | 0 .../oversized-canvas/webgl/+page.svelte | 2 +- .../routes/oversized-canvas/webgl/shader.frag | 0 .../oversized-canvas/webgpu/+page.svelte | 2 +- .../oversized-canvas/webgpu/shader.wgsl | 0 .../src}/routes/remount/+page.svelte | 0 .../src}/routes/remount/webgl/+page.svelte | 2 +- .../src}/routes/remount/webgl/shader.frag | 0 .../src}/routes/remount/webgpu/+page.svelte | 2 +- .../src}/routes/remount/webgpu/shader.wgsl | 0 .../src}/routes/slider/+page.svelte | 0 .../src}/routes/slider/webgl/+page.svelte | 2 +- .../src}/routes/slider/webgl/shader.frag | 0 .../src}/routes/slider/webgpu/+page.svelte | 2 +- .../src}/routes/slider/webgpu/shader.wgsl | 0 packages/tests-svelte4/static/favicon.png | Bin 0 -> 1571 bytes .../tests-svelte4/svelte.config.js | 0 packages/tests-svelte4/tsconfig.json | 13 + .../tests-svelte4/vite.config.js | 0 73 files changed, 2662 insertions(+), 390 deletions(-) delete mode 100644 .npmrc mode change 100644 => 120000 LICENSE.md mode change 100644 => 120000 README.md create mode 100644 package-lock.json create mode 100644 packages/svader/LICENSE.md create mode 100644 packages/svader/README.md create mode 100644 packages/svader/package.json rename {src => packages/svader/src}/lib/BaseShader.svelte (100%) rename {src => packages/svader/src}/lib/WebGlShader.svelte (100%) rename {src => packages/svader/src}/lib/WebGpuShader.svelte (100%) rename {src => packages/svader/src}/lib/index.js (100%) rename {src => packages/svader/src}/lib/intersectionObserver.js (100%) rename {src => packages/svader/src}/lib/utils.js (100%) create mode 100644 packages/svader/svelte.config.js rename tsconfig.json => packages/svader/tsconfig.json (100%) create mode 100644 packages/tests-svelte4/package.json rename {resources => packages/tests-svelte4/resources}/banner.png (100%) rename {resources => packages/tests-svelte4/resources}/bubbles.png (100%) rename {resources => packages/tests-svelte4/resources}/collage.png (100%) rename {resources => packages/tests-svelte4/resources}/debugShaderWebGl.png (100%) rename {resources => packages/tests-svelte4/resources}/debugShaderWebGpu.png (100%) rename {resources => packages/tests-svelte4/resources}/halo.png (100%) rename {resources => packages/tests-svelte4/resources}/logoDark.png (100%) rename {resources => packages/tests-svelte4/resources}/logoLight.png (100%) rename {resources => packages/tests-svelte4/resources}/slider.png (100%) rename {src => packages/tests-svelte4/src}/app.d.ts (100%) rename {src => packages/tests-svelte4/src}/app.html (82%) rename {src => packages/tests-svelte4/src}/routes/+layout.server.js (100%) rename {src => packages/tests-svelte4/src}/routes/+page.svelte (100%) rename {src => packages/tests-svelte4/src}/routes/hello-world/+page.svelte (100%) rename {src => packages/tests-svelte4/src}/routes/hello-world/webgl/+page.svelte (89%) rename {src => packages/tests-svelte4/src}/routes/hello-world/webgl/shader.frag (100%) rename {src => packages/tests-svelte4/src}/routes/hello-world/webgpu/+page.svelte (90%) rename {src => packages/tests-svelte4/src}/routes/hello-world/webgpu/shader.wgsl (100%) rename {src => packages/tests-svelte4/src}/routes/landing-page-bubbles/+page.svelte (100%) rename {src => packages/tests-svelte4/src}/routes/landing-page-bubbles/webgl/+page.svelte (97%) rename {src => packages/tests-svelte4/src}/routes/landing-page-bubbles/webgl/shader.frag (100%) rename {src => packages/tests-svelte4/src}/routes/landing-page-bubbles/webgpu/+page.svelte (97%) rename {src => packages/tests-svelte4/src}/routes/landing-page-bubbles/webgpu/shader.wgsl (100%) rename {src => packages/tests-svelte4/src}/routes/landing-page-halo/+page.svelte (100%) rename {src => packages/tests-svelte4/src}/routes/landing-page-halo/webgl/+page.svelte (96%) rename {src => packages/tests-svelte4/src}/routes/landing-page-halo/webgl/shader.frag (100%) rename {src => packages/tests-svelte4/src}/routes/landing-page-halo/webgpu/+page.svelte (96%) rename {src => packages/tests-svelte4/src}/routes/landing-page-halo/webgpu/shader.wgsl (100%) rename {src => packages/tests-svelte4/src}/routes/logo/+page.svelte (100%) rename {src => packages/tests-svelte4/src}/routes/logo/logoDark.png (100%) rename {src => packages/tests-svelte4/src}/routes/logo/webgl/+page.svelte (97%) rename {src => packages/tests-svelte4/src}/routes/logo/webgl/shader.frag (100%) rename {src => packages/tests-svelte4/src}/routes/logo/webgpu/+page.svelte (97%) rename {src => packages/tests-svelte4/src}/routes/logo/webgpu/shader.wgsl (100%) rename {src => packages/tests-svelte4/src}/routes/oversized-canvas/+page.svelte (100%) rename {src => packages/tests-svelte4/src}/routes/oversized-canvas/webgl/+page.svelte (89%) rename {src => packages/tests-svelte4/src}/routes/oversized-canvas/webgl/shader.frag (100%) rename {src => packages/tests-svelte4/src}/routes/oversized-canvas/webgpu/+page.svelte (90%) rename {src => packages/tests-svelte4/src}/routes/oversized-canvas/webgpu/shader.wgsl (100%) rename {src => packages/tests-svelte4/src}/routes/remount/+page.svelte (100%) rename {src => packages/tests-svelte4/src}/routes/remount/webgl/+page.svelte (93%) rename {src => packages/tests-svelte4/src}/routes/remount/webgl/shader.frag (100%) rename {src => packages/tests-svelte4/src}/routes/remount/webgpu/+page.svelte (93%) rename {src => packages/tests-svelte4/src}/routes/remount/webgpu/shader.wgsl (100%) rename {src => packages/tests-svelte4/src}/routes/slider/+page.svelte (100%) rename {src => packages/tests-svelte4/src}/routes/slider/webgl/+page.svelte (97%) rename {src => packages/tests-svelte4/src}/routes/slider/webgl/shader.frag (100%) rename {src => packages/tests-svelte4/src}/routes/slider/webgpu/+page.svelte (97%) rename {src => packages/tests-svelte4/src}/routes/slider/webgpu/shader.wgsl (100%) create mode 100644 packages/tests-svelte4/static/favicon.png rename svelte.config.js => packages/tests-svelte4/svelte.config.js (100%) create mode 100644 packages/tests-svelte4/tsconfig.json rename vite.config.js => packages/tests-svelte4/vite.config.js (100%) diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index 92732f7..8965629 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -15,7 +15,7 @@ jobs: with: node-version: 20 - name: Install Dependencies - run: npm install + run: npm ci - name: Check run: npm run check - name: Package diff --git a/.github/workflows/npm-publish.yml b/.github/workflows/npm-publish.yml index d9890c4..8b5a890 100644 --- a/.github/workflows/npm-publish.yml +++ b/.github/workflows/npm-publish.yml @@ -16,8 +16,9 @@ jobs: with: node-version: 20 registry-url: https://registry.npmjs.org/ + - run: cd packages/svader - name: Install Dependencies - run: npm install + run: npm ci - name: Package run: npm run package - name: Publish diff --git a/.gitignore b/.gitignore index 715b548..2fe4f44 100644 --- a/.gitignore +++ b/.gitignore @@ -3,9 +3,9 @@ node_modules # Output .output .vercel -/.svelte-kit -/build -/dist +.svelte-kit +build +dist # OS .DS_Store diff --git a/.npmrc b/.npmrc deleted file mode 100644 index b6f27f1..0000000 --- a/.npmrc +++ /dev/null @@ -1 +0,0 @@ -engine-strict=true diff --git a/LICENSE.md b/LICENSE.md deleted file mode 100644 index 029c148..0000000 --- a/LICENSE.md +++ /dev/null @@ -1,21 +0,0 @@ -MIT License - -Copyright (c) 2024 Holger Dal Mogensen - -Permission is hereby granted, free of charge, to any person obtaining a copy -of this software and associated documentation files (the "Software"), to deal -in the Software without restriction, including without limitation the rights -to use, copy, modify, merge, publish, distribute, sublicense, and/or sell -copies of the Software, and to permit persons to whom the Software is -furnished to do so, subject to the following conditions: - -The above copyright notice and this permission notice shall be included in all -copies or substantial portions of the Software. - -THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR -IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, -FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE -AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER -LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, -OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE -SOFTWARE. diff --git a/LICENSE.md b/LICENSE.md new file mode 120000 index 0000000..e6c6c60 --- /dev/null +++ b/LICENSE.md @@ -0,0 +1 @@ +C:/Users/Holger/OneDrive/DAW/voil/svader/packages/svader/LICENSE.md \ No newline at end of file diff --git a/README.md b/README.md deleted file mode 100644 index 1b15580..0000000 --- a/README.md +++ /dev/null @@ -1,294 +0,0 @@ -

- - - Svader Logo - -

- -# Svader - -Create GPU-rendered Svelte components with WebGL and WebGPU fragment shaders. - -## What is a fragment shader? - -In short, a _fragment shader_ can be written as a program that takes the coordinates of a pixel on the screen and returns the color that this pixel should have. -This program can be executed on the GPU, ensuring massive parallelism and speed. - -To learn more about how to write fragment shaders, check out [The Book of Shaders](https://thebookofshaders.com/). - -The following is a collection of examples all made using Svader. The live version of all of these can be previewed on [svader.vercel.app](https://svader.vercel.app/), -and the source code can be found in the [`src/routes/`](https://github.com/sockmaster27/svader/tree/master/src/routes) directory. - -![Shader example collage](https://raw.githubusercontent.com/sockmaster27/svader/master/resources/collage.png) - -## Installation - -```bash -# npm -npm i -D svader - -# pnpm -pnpm i -D svader - -# Bun -bun i -D svader - -# Yarn -yarn add -D svader -``` - -## Usage - -To use a fragment shader component, you first need to decide whether to use WebGL or WebGPU. -If you're unsure about what to use, see the [WebGL vs. WebGPU](#webgl-vs-webgpu) section. - -### Sections - -- [WebGL](#webgl) - - [WebGL parameters](#webgl-parameters) - - [WebGL built-in values](#webgl-built-in-values) -- [WebGPU](#webgpu) - - [WebGPU parameters](#webgpu-parameters) - - [WebGPU built-in values](#webgpu-built-in-values) - -### WebGL - -The following is a minimal example of a WebGL fragment shader component. - -[**View in REPL**](https://svelte.dev/repl/3e4a38bca5ca49fa94e1106a841063d5?version=4.2.19) - -```svelte - - - -
WebGL not supported in this environment.
-
-``` - -This produces the following output: - -![Output of the WebGL shader](https://raw.githubusercontent.com/sockmaster27/svader/master/resources/debugShaderWebGl.png) - -Here, the `shaderCode` variable is a string containing the [GLES](https://en.wikipedia.org/wiki/OpenGL_ES) shader code. -For simplicity, this is stored as a string, but it would typically be stored in a separate `myShader.frag` file. -When loading the shader from a file, it might be useful to know that the `code` property accepts both a `string` and a `Promise`. - -What this code does is: - -1. Add the given `u_offset` uniform to the 2D coordinates of the pixel given by `gl_FragCoord.xy`. -2. Divide the resulting coordinates entrywise by the `u_resolution` uniform to normalize the coordinates between 0 and 1. -3. Return the normalized coordinates as the color of the pixel, such that the `x` coordinate becomes the red channel and the `y` coordinate becomes the green channel. The blue channel is always set to 0, and the alpha (opacity) channel is always set to 1 (fully opaque). - -In GLES, _uniforms_ are inputs to the function, that are the same for every pixel on the screen. -These need to be passed in via the `parameters` property of the `` component. -In this case, we need to pass in two uniforms: `u_resolution` and `u_offset`. -Since these specific parameters are very commonly used, they are specially implemented in Svader -such that the `value` property of each parameter can simply be set to `"resolution"` and `"offset"` respectively. - -Lastly, the `` component accepts a fallback slot, which is rendered when the browser cannot render the shader. - -#### WebGL parameters - -The `parameters` property is an array of objects with the following properties: - -- **`name`**: The name of the uniform parameter, e.g. `"my_uniform"`. - This must match the name of the parameter in the shader code. - -- **`type`**: The type of the uniform parameter as it is written in the shader code, e.g. `"float"`. - If the `value` property is a [built-in value](#webgl-built-in-values), such as `"resolution"`, - the `type` will be determined automatically and should not be set. - -- **`value`**: The value of the uniform parameter, or a string specifying a [built-in value](#webgl-built-in-values). - If not a built-in value, the type of this property must correspond to the `type` property, such that: - - **`float`, `int`, `uint`** is a `number`, - - **`vecN`, `ivecN`, `uvecN`** is a `number[]` with a length of `N`, e.g. `vec2` -> `[1.2, 3.4]`. - - **`matN`** is a `number[]` with a length of `N * N`, e.g. `mat2` -> `[1, 2, 3, 4]`. - -##### WebGL built-in values - -Some types of uniforms are used very often. These are implemented in Svader itself, and referred to as _built-in values_. -To use these, the `value` property of the parameter object must be set to a string matching one of the following: - -- **`"resolution"`**: A `vec2` of the canvas width and height in physical device pixels. - -- **`"scale"`**: A `float` of the ratio between CSS pixels and physical device pixels, i.e. zoom level. - For example, if the browser has been zoomed to 150%, the `scale` parameter will be `1.5`. - -- **`"time"`**: A `float` of the current time in seconds. - NOTE: Passing this parameter to the shader will cause it to rerender every frame. - -- **`"offset"`**: A `vec2` to be added to the `gl_FragCoord.xy` of the fragment shader. - Sometimes the size of the canvas is limited by hardware. - To compensate for this, Svader creates a virtual canvas with a smaller cutout shifting around to cover the screen. - The `"resolution"` parameter is automatically adjusted to match the size of this virtual canvas, but for technical reasons, - the `gl_FragCoord.xy` cannot be adjusted from the outside. - Therefore, the `"offset"` parameter is provided to be manually added to these coordinates. - -### WebGPU - -The following is a minimal example of a WebGPU fragment shader component. - -[**View in REPL**](https://svelte.dev/repl/498446d091964bb199e6a88bce90feae?version=4.2.19) - -```svelte - - - -
WebGPU not supported in this environment.
-
-``` - -This produces the following output: - -![Output of the WebGPU shader](https://raw.githubusercontent.com/sockmaster27/svader/master/resources/debugShaderWebGpu.png) - -Here, the `shaderCode` variable is a string containing the [WGSL](https://google.github.io/tour-of-wgsl/) shader code. -For simplicity, this is stored as a string, but it would typically be stored in a separate `myShader.wgsl` file. -When loading the shader from a file, it might be useful to know that the `code` property accepts both a `string` and a `Promise`. - -What this code does is: - -1. Add the given `offset` uniform variable to the 2D coordinates of the pixel given by `raw_pos.xy`. -2. Divide the resulting coordinates entrywise by the `resolution` uniform to normalize the coordinates between 0 and 1. -3. Return the normalized coordinates as the color of the pixel, such that the `x` coordinate becomes the red channel and the `y` coordinate becomes the green channel. The blue channel is always set to 0, and the alpha (opacity) channel is always set to 1 (fully opaque). - -In WGSL, these `var`s are the primary way to pass in parameters to the shader. -These need to be passed in via the `parameters` property of the `` component. -In this case, we need to pass in two uniforms: `resolution` and `offset`. -Since these specific parameters are very commonly used, they are specially implemented in Svader -such that the `value` property of each parameter can simply be set to `"resolution"` and `"offset"` respectively. - -Lastly, the `` component accepts a fallback slot, which is rendered when the browser cannot render the shader. - -#### WebGPU parameters - -The `parameters` property is an array of objects with the following properties: - -- **`label`**: The name of the parameter to be used for debugging. - This does not have to correspond to the name of the parameter in the shader code. - -- **`binding`**: An integer used to match the parameter to the variable in the shader code. - This has to match the `binding` property of the parameter in the shader code, e.g. for the variable declaration - - ```WGSL - @group(0) @binding(42) var my_variable: f32; - ``` - - the `binding` property should be `42`. - -- **`value`**: The value of the parameter, or a string specifying a [built-in value](#webgpu-built-in-values). - If not a built-in value, this parameter should be an `ArrayBuffer`/`ArrayBufferView`. - For example, to pass in a number to an `f32` parameter, it can be constructed like `new Float32Array([myNumberValue])`. - -- **`storage`**: [Optional - defaults to `false`] Whether the parameter is a storage variable rather than a uniform variable. - This has to match the declaration in the shader code, e.g. for the variable declaration - - ```WGSL - @group(0) @binding(0) var my_variable: f32; - ``` - - the `storage` property should be `false` or omitted, and for - - ```WGSL - @group(0) @binding(0) var my_variable: f32; - ``` - - it should be `true`. - Note that Svader currently only supports `var` and not `var`. - -##### WebGPU built-in values - -Some types of inputs are used very often. These are implemented in Svader itself, and referred to as _built-in values_. -To use these, the `value` property of the parameter object must be set to a string matching one of the following: - -- **`"resolution"`**: A `vec2f` of the canvas width and height in physical device pixels. - -- **`"scale"`**: An `f32` of the ratio between CSS pixels and physical device pixels, i.e. zoom level. - For example, if the browser has been zoomed to 150%, the `scale` parameter will be `1.5`. - -- **`"time"`**: An `f32` of the current time in seconds. - NOTE: Passing this parameter to the shader will cause it to rerender every frame. - -- **`"offset"`**: A `vec2f` to be added to the `@builtin(position)` of the fragment shader. - Sometimes the size of the canvas is limited by hardware. - To compensate for this, Svader creates a virtual canvas with a smaller cutout shifting around to cover the screen. - The `"resolution"` parameter is automatically adjusted to match the size of this virtual canvas, but for technical reasons, - the `@builtin(position)` cannot be adjusted from the outside. - Therefore, the `"offset"` parameter is provided to be manually added to these coordinates. - -## WebGL vs. WebGPU - -**For practical applications, default to using WebGL.** - -WebGL and WebGPU are both rendering APIs that allow web applications to render GPU-accelerated graphics. - -WebGL is the older of the two and is supported by [all modern browsers](https://caniuse.com/webgl). - -WebGPU is still in the experimental stage and is only supported in a [few browsers](https://caniuse.com/webgpu). -However, it supports certain features that WebGL does not. For example, as of writing, WebGL in Google Chrome only supports having 8 canvases active in the document at once, while WebGPU supports a practically unlimited number. - -## License - -Svader is licensed under the [MIT License](https://github.com/sockmaster27/svader/blob/master/LICENSE.md). diff --git a/README.md b/README.md new file mode 120000 index 0000000..05ef881 --- /dev/null +++ b/README.md @@ -0,0 +1 @@ +C:/Users/Holger/OneDrive/DAW/voil/svader/packages/svader/README.md \ No newline at end of file diff --git a/package-lock.json b/package-lock.json new file mode 100644 index 0000000..84463c0 --- /dev/null +++ b/package-lock.json @@ -0,0 +1,2216 @@ +{ + "name": "svader-monorepo", + "lockfileVersion": 3, + "requires": true, + "packages": { + "": { + "name": "svader-monorepo", + "workspaces": [ + "packages/*" + ] + }, + "node_modules/@ampproject/remapping": { + "version": "2.3.0", + "resolved": "https://registry.npmjs.org/@ampproject/remapping/-/remapping-2.3.0.tgz", + "integrity": "sha512-30iZtAPgz+LTIYoeivqYo853f02jBYSd5uGnGpkFV0M3xOt9aN73erkgYAmZU43x4VfqcnLxW9Kpg3R5LC4YYw==", + "dev": true, + "license": "Apache-2.0", + "dependencies": { + "@jridgewell/gen-mapping": "^0.3.5", + "@jridgewell/trace-mapping": "^0.3.24" + }, + "engines": { + "node": ">=6.0.0" + } + }, + "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" + ], + "dev": true, + "license": "MIT", + "optional": true, + "os": [ + "aix" + ], + "engines": { + "node": ">=12" + } + }, + "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" + ], + "dev": true, + "license": "MIT", + "optional": true, + "os": [ + "android" + ], + "engines": { + "node": ">=12" + } + }, + "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" + ], + "dev": true, + "license": "MIT", + "optional": true, + "os": [ + "android" + ], + "engines": { + "node": ">=12" + } + }, + "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" + ], + "dev": true, + "license": "MIT", + "optional": true, + "os": [ + "android" + ], + "engines": { + "node": ">=12" + } + }, + "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" + ], + "dev": true, + "license": "MIT", + "optional": true, + "os": [ + "darwin" + ], + "engines": { + "node": ">=12" + } + }, + "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" + ], + "dev": true, + "license": "MIT", + "optional": true, + "os": [ + "darwin" + ], + "engines": { + "node": ">=12" + } + }, + "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" + ], + "dev": true, + "license": "MIT", + "optional": true, + "os": [ + "freebsd" + ], + "engines": { + "node": ">=12" + } + }, + "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" + ], + "dev": true, + "license": "MIT", + "optional": true, + "os": [ + "freebsd" + ], + "engines": { + "node": ">=12" + } + }, + "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" + ], + "dev": true, + "license": "MIT", + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">=12" + } + }, + "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" + ], + "dev": true, + "license": "MIT", + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">=12" + } + }, + "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" + ], + "dev": true, + "license": "MIT", + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">=12" + } + }, + "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" + ], + "dev": true, + "license": "MIT", + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">=12" + } + }, + "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" + ], + "dev": true, + "license": "MIT", + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">=12" + } + }, + "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" + ], + "dev": true, + "license": "MIT", + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">=12" + } + }, + "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" + ], + "dev": true, + "license": "MIT", + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">=12" + } + }, + "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" + ], + "dev": true, + "license": "MIT", + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">=12" + } + }, + "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" + ], + "dev": true, + "license": "MIT", + "optional": true, + "os": [ + "linux" + ], + "engines": { + "node": ">=12" + } + }, + "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" + ], + "dev": true, + "license": "MIT", + "optional": true, + "os": [ + "netbsd" + ], + "engines": { + "node": ">=12" + } + }, + "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" + ], + "dev": true, + "license": "MIT", + "optional": true, + "os": [ + "openbsd" + ], + "engines": { + "node": ">=12" + } + }, + "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" + ], + "dev": true, + "license": "MIT", + "optional": true, + "os": [ + "sunos" + ], + "engines": { + "node": ">=12" + } + }, + "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" + ], + "dev": true, + "license": "MIT", + "optional": true, + "os": [ + "win32" + ], + "engines": { + "node": ">=12" + } + }, + "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" + ], + "dev": true, + "license": "MIT", + "optional": true, + "os": [ + "win32" + ], + "engines": { + "node": ">=12" + } + }, + "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" + ], + "dev": true, + "license": "MIT", + "optional": true, + "os": [ + "win32" + ], + "engines": { + "node": ">=12" + } + }, + "node_modules/@jridgewell/gen-mapping": { + "version": "0.3.5", + "resolved": "https://registry.npmjs.org/@jridgewell/gen-mapping/-/gen-mapping-0.3.5.tgz", + "integrity": "sha512-IzL8ZoEDIBRWEzlCcRhOaCupYyN5gdIK+Q6fbFdPDg6HqX6jpkItn7DFIpW9LQzXG6Df9sA7+OKnq0qlz/GaQg==", + "dev": true, + "license": "MIT", + "dependencies": { + "@jridgewell/set-array": "^1.2.1", + "@jridgewell/sourcemap-codec": "^1.4.10", + "@jridgewell/trace-mapping": "^0.3.24" + }, + "engines": { + "node": ">=6.0.0" + } + }, + "node_modules/@jridgewell/resolve-uri": { + "version": "3.1.2", + "resolved": "https://registry.npmjs.org/@jridgewell/resolve-uri/-/resolve-uri-3.1.2.tgz", + "integrity": "sha512-bRISgCIjP20/tbWSPWMEi54QVPRZExkuD9lJL+UIxUKtwVJA8wW1Trb1jMs1RFXo1CBTNZ/5hpC9QvmKWdopKw==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=6.0.0" + } + }, + "node_modules/@jridgewell/set-array": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/@jridgewell/set-array/-/set-array-1.2.1.tgz", + "integrity": "sha512-R8gLRTZeyp03ymzP/6Lil/28tGeGEzhx1q2k703KGWRAI1VdvPIXdG70VJc2pAMw3NA6JKL5hhFu1sJX0Mnn/A==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=6.0.0" + } + }, + "node_modules/@jridgewell/sourcemap-codec": { + "version": "1.5.0", + "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.5.0.tgz", + "integrity": "sha512-gv3ZRaISU3fjPAgNsriBRqGWQL6quFx04YMPW/zD8XMLsU32mhCCbfbO6KZFLjvYpCZ8zyDEgqsgf+PwPaM7GQ==", + "dev": true, + "license": "MIT" + }, + "node_modules/@jridgewell/trace-mapping": { + "version": "0.3.25", + "resolved": "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.25.tgz", + "integrity": "sha512-vNk6aEwybGtawWmy/PzwnGDOjCkLWSD2wqvjGGAgOAwCGWySYXfYoxt00IJkTF+8Lb57DwOb3Aa0o9CApepiYQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "@jridgewell/resolve-uri": "^3.1.0", + "@jridgewell/sourcemap-codec": "^1.4.14" + } + }, + "node_modules/@polka/url": { + "version": "1.0.0-next.28", + "resolved": "https://registry.npmjs.org/@polka/url/-/url-1.0.0-next.28.tgz", + "integrity": "sha512-8LduaNlMZGwdZ6qWrKlfa+2M4gahzFkprZiAt2TF8uS0qQgBizKXpXURqvTJ4WtmupWxaLqjRb2UCTe72mu+Aw==", + "dev": true, + "license": "MIT" + }, + "node_modules/@rollup/rollup-android-arm-eabi": { + "version": "4.24.0", + "resolved": "https://registry.npmjs.org/@rollup/rollup-android-arm-eabi/-/rollup-android-arm-eabi-4.24.0.tgz", + "integrity": "sha512-Q6HJd7Y6xdB48x8ZNVDOqsbh2uByBhgK8PiQgPhwkIw/HC/YX5Ghq2mQY5sRMZWHb3VsFkWooUVOZHKr7DmDIA==", + "cpu": [ + "arm" + ], + "dev": true, + "license": "MIT", + "optional": true, + "os": [ + "android" + ] + }, + "node_modules/@rollup/rollup-android-arm64": { + "version": "4.24.0", + "resolved": "https://registry.npmjs.org/@rollup/rollup-android-arm64/-/rollup-android-arm64-4.24.0.tgz", + "integrity": "sha512-ijLnS1qFId8xhKjT81uBHuuJp2lU4x2yxa4ctFPtG+MqEE6+C5f/+X/bStmxapgmwLwiL3ih122xv8kVARNAZA==", + "cpu": [ + "arm64" + ], + "dev": true, + "license": "MIT", + "optional": true, + "os": [ + "android" + ] + }, + "node_modules/@rollup/rollup-darwin-arm64": { + "version": "4.24.0", + "resolved": "https://registry.npmjs.org/@rollup/rollup-darwin-arm64/-/rollup-darwin-arm64-4.24.0.tgz", + "integrity": "sha512-bIv+X9xeSs1XCk6DVvkO+S/z8/2AMt/2lMqdQbMrmVpgFvXlmde9mLcbQpztXm1tajC3raFDqegsH18HQPMYtA==", + "cpu": [ + "arm64" + ], + "dev": true, + "license": "MIT", + "optional": true, + "os": [ + "darwin" + ] + }, + "node_modules/@rollup/rollup-darwin-x64": { + "version": "4.24.0", + "resolved": "https://registry.npmjs.org/@rollup/rollup-darwin-x64/-/rollup-darwin-x64-4.24.0.tgz", + "integrity": "sha512-X6/nOwoFN7RT2svEQWUsW/5C/fYMBe4fnLK9DQk4SX4mgVBiTA9h64kjUYPvGQ0F/9xwJ5U5UfTbl6BEjaQdBQ==", + "cpu": [ + "x64" + ], + "dev": true, + "license": "MIT", + "optional": true, + "os": [ + "darwin" + ] + }, + "node_modules/@rollup/rollup-linux-arm-gnueabihf": { + "version": "4.24.0", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm-gnueabihf/-/rollup-linux-arm-gnueabihf-4.24.0.tgz", + "integrity": "sha512-0KXvIJQMOImLCVCz9uvvdPgfyWo93aHHp8ui3FrtOP57svqrF/roSSR5pjqL2hcMp0ljeGlU4q9o/rQaAQ3AYA==", + "cpu": [ + "arm" + ], + "dev": true, + "license": "MIT", + "optional": true, + "os": [ + "linux" + ] + }, + "node_modules/@rollup/rollup-linux-arm-musleabihf": { + "version": "4.24.0", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm-musleabihf/-/rollup-linux-arm-musleabihf-4.24.0.tgz", + "integrity": "sha512-it2BW6kKFVh8xk/BnHfakEeoLPv8STIISekpoF+nBgWM4d55CZKc7T4Dx1pEbTnYm/xEKMgy1MNtYuoA8RFIWw==", + "cpu": [ + "arm" + ], + "dev": true, + "license": "MIT", + "optional": true, + "os": [ + "linux" + ] + }, + "node_modules/@rollup/rollup-linux-arm64-gnu": { + "version": "4.24.0", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm64-gnu/-/rollup-linux-arm64-gnu-4.24.0.tgz", + "integrity": "sha512-i0xTLXjqap2eRfulFVlSnM5dEbTVque/3Pi4g2y7cxrs7+a9De42z4XxKLYJ7+OhE3IgxvfQM7vQc43bwTgPwA==", + "cpu": [ + "arm64" + ], + "dev": true, + "license": "MIT", + "optional": true, + "os": [ + "linux" + ] + }, + "node_modules/@rollup/rollup-linux-arm64-musl": { + "version": "4.24.0", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm64-musl/-/rollup-linux-arm64-musl-4.24.0.tgz", + "integrity": "sha512-9E6MKUJhDuDh604Qco5yP/3qn3y7SLXYuiC0Rpr89aMScS2UAmK1wHP2b7KAa1nSjWJc/f/Lc0Wl1L47qjiyQw==", + "cpu": [ + "arm64" + ], + "dev": true, + "license": "MIT", + "optional": true, + "os": [ + "linux" + ] + }, + "node_modules/@rollup/rollup-linux-powerpc64le-gnu": { + "version": "4.24.0", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-powerpc64le-gnu/-/rollup-linux-powerpc64le-gnu-4.24.0.tgz", + "integrity": "sha512-2XFFPJ2XMEiF5Zi2EBf4h73oR1V/lycirxZxHZNc93SqDN/IWhYYSYj8I9381ikUFXZrz2v7r2tOVk2NBwxrWw==", + "cpu": [ + "ppc64" + ], + "dev": true, + "license": "MIT", + "optional": true, + "os": [ + "linux" + ] + }, + "node_modules/@rollup/rollup-linux-riscv64-gnu": { + "version": "4.24.0", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-riscv64-gnu/-/rollup-linux-riscv64-gnu-4.24.0.tgz", + "integrity": "sha512-M3Dg4hlwuntUCdzU7KjYqbbd+BLq3JMAOhCKdBE3TcMGMZbKkDdJ5ivNdehOssMCIokNHFOsv7DO4rlEOfyKpg==", + "cpu": [ + "riscv64" + ], + "dev": true, + "license": "MIT", + "optional": true, + "os": [ + "linux" + ] + }, + "node_modules/@rollup/rollup-linux-s390x-gnu": { + "version": "4.24.0", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-s390x-gnu/-/rollup-linux-s390x-gnu-4.24.0.tgz", + "integrity": "sha512-mjBaoo4ocxJppTorZVKWFpy1bfFj9FeCMJqzlMQGjpNPY9JwQi7OuS1axzNIk0nMX6jSgy6ZURDZ2w0QW6D56g==", + "cpu": [ + "s390x" + ], + "dev": true, + "license": "MIT", + "optional": true, + "os": [ + "linux" + ] + }, + "node_modules/@rollup/rollup-linux-x64-gnu": { + "version": "4.24.0", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-x64-gnu/-/rollup-linux-x64-gnu-4.24.0.tgz", + "integrity": "sha512-ZXFk7M72R0YYFN5q13niV0B7G8/5dcQ9JDp8keJSfr3GoZeXEoMHP/HlvqROA3OMbMdfr19IjCeNAnPUG93b6A==", + "cpu": [ + "x64" + ], + "dev": true, + "license": "MIT", + "optional": true, + "os": [ + "linux" + ] + }, + "node_modules/@rollup/rollup-linux-x64-musl": { + "version": "4.24.0", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-x64-musl/-/rollup-linux-x64-musl-4.24.0.tgz", + "integrity": "sha512-w1i+L7kAXZNdYl+vFvzSZy8Y1arS7vMgIy8wusXJzRrPyof5LAb02KGr1PD2EkRcl73kHulIID0M501lN+vobQ==", + "cpu": [ + "x64" + ], + "dev": true, + "license": "MIT", + "optional": true, + "os": [ + "linux" + ] + }, + "node_modules/@rollup/rollup-win32-arm64-msvc": { + "version": "4.24.0", + "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-arm64-msvc/-/rollup-win32-arm64-msvc-4.24.0.tgz", + "integrity": "sha512-VXBrnPWgBpVDCVY6XF3LEW0pOU51KbaHhccHw6AS6vBWIC60eqsH19DAeeObl+g8nKAz04QFdl/Cefta0xQtUQ==", + "cpu": [ + "arm64" + ], + "dev": true, + "license": "MIT", + "optional": true, + "os": [ + "win32" + ] + }, + "node_modules/@rollup/rollup-win32-ia32-msvc": { + "version": "4.24.0", + "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-ia32-msvc/-/rollup-win32-ia32-msvc-4.24.0.tgz", + "integrity": "sha512-xrNcGDU0OxVcPTH/8n/ShH4UevZxKIO6HJFK0e15XItZP2UcaiLFd5kiX7hJnqCbSztUF8Qot+JWBC/QXRPYWQ==", + "cpu": [ + "ia32" + ], + "dev": true, + "license": "MIT", + "optional": true, + "os": [ + "win32" + ] + }, + "node_modules/@rollup/rollup-win32-x64-msvc": { + "version": "4.24.0", + "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-x64-msvc/-/rollup-win32-x64-msvc-4.24.0.tgz", + "integrity": "sha512-fbMkAF7fufku0N2dE5TBXcNlg0pt0cJue4xBRE2Qc5Vqikxr4VCgKj/ht6SMdFcOacVA9rqF70APJ8RN/4vMJw==", + "cpu": [ + "x64" + ], + "dev": true, + "license": "MIT", + "optional": true, + "os": [ + "win32" + ] + }, + "node_modules/@sveltejs/adapter-auto": { + "version": "3.3.0", + "resolved": "https://registry.npmjs.org/@sveltejs/adapter-auto/-/adapter-auto-3.3.0.tgz", + "integrity": "sha512-EJZqY7eMM+bdbR898Xt9ufawUHLPJu7w3wPr4Cc+T1iIDf3fufVLWg4C71OluIqsdJqv85E4biKuHo3XXIY0PQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "import-meta-resolve": "^4.1.0" + }, + "peerDependencies": { + "@sveltejs/kit": "^2.0.0" + } + }, + "node_modules/@sveltejs/kit": { + "version": "2.7.2", + "resolved": "https://registry.npmjs.org/@sveltejs/kit/-/kit-2.7.2.tgz", + "integrity": "sha512-bFwrl+0bNr0/DHQZM0INwwSPNYqDjfsKRhUoa6rj9d8tDZzszBrJ3La6/HVFxWGONEigtG+SzHXa1BEa1BLdwA==", + "dev": true, + "hasInstallScript": true, + "license": "MIT", + "dependencies": { + "@types/cookie": "^0.6.0", + "cookie": "^0.6.0", + "devalue": "^5.1.0", + "esm-env": "^1.0.0", + "import-meta-resolve": "^4.1.0", + "kleur": "^4.1.5", + "magic-string": "^0.30.5", + "mrmime": "^2.0.0", + "sade": "^1.8.1", + "set-cookie-parser": "^2.6.0", + "sirv": "^3.0.0", + "tiny-glob": "^0.2.9" + }, + "bin": { + "svelte-kit": "svelte-kit.js" + }, + "engines": { + "node": ">=18.13" + }, + "peerDependencies": { + "@sveltejs/vite-plugin-svelte": "^3.0.0 || ^4.0.0-next.1", + "svelte": "^4.0.0 || ^5.0.0-next.0", + "vite": "^5.0.3" + } + }, + "node_modules/@sveltejs/package": { + "version": "2.3.6", + "resolved": "https://registry.npmjs.org/@sveltejs/package/-/package-2.3.6.tgz", + "integrity": "sha512-XzbXWXrdeGbiPj3xICtmh66XrLXApoB/s17LIf0X25bEowAWjEnmukzHVJXaMeSuaFukggdFYoxqcfy4SxucbA==", + "dev": true, + "license": "MIT", + "dependencies": { + "chokidar": "^4.0.0", + "kleur": "^4.1.5", + "sade": "^1.8.1", + "semver": "^7.5.4", + "svelte2tsx": "~0.7.16" + }, + "bin": { + "svelte-package": "svelte-package.js" + }, + "engines": { + "node": "^16.14 || >=18" + }, + "peerDependencies": { + "svelte": "^3.44.0 || ^4.0.0 || ^5.0.0-next.1" + } + }, + "node_modules/@sveltejs/vite-plugin-svelte": { + "version": "3.1.2", + "resolved": "https://registry.npmjs.org/@sveltejs/vite-plugin-svelte/-/vite-plugin-svelte-3.1.2.tgz", + "integrity": "sha512-Txsm1tJvtiYeLUVRNqxZGKR/mI+CzuIQuc2gn+YCs9rMTowpNZ2Nqt53JdL8KF9bLhAf2ruR/dr9eZCwdTriRA==", + "dev": true, + "license": "MIT", + "dependencies": { + "@sveltejs/vite-plugin-svelte-inspector": "^2.1.0", + "debug": "^4.3.4", + "deepmerge": "^4.3.1", + "kleur": "^4.1.5", + "magic-string": "^0.30.10", + "svelte-hmr": "^0.16.0", + "vitefu": "^0.2.5" + }, + "engines": { + "node": "^18.0.0 || >=20" + }, + "peerDependencies": { + "svelte": "^4.0.0 || ^5.0.0-next.0", + "vite": "^5.0.0" + } + }, + "node_modules/@sveltejs/vite-plugin-svelte-inspector": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/@sveltejs/vite-plugin-svelte-inspector/-/vite-plugin-svelte-inspector-2.1.0.tgz", + "integrity": "sha512-9QX28IymvBlSCqsCll5t0kQVxipsfhFFL+L2t3nTWfXnddYwxBuAEtTtlaVQpRz9c37BhJjltSeY4AJSC03SSg==", + "dev": true, + "license": "MIT", + "dependencies": { + "debug": "^4.3.4" + }, + "engines": { + "node": "^18.0.0 || >=20" + }, + "peerDependencies": { + "@sveltejs/vite-plugin-svelte": "^3.0.0", + "svelte": "^4.0.0 || ^5.0.0-next.0", + "vite": "^5.0.0" + } + }, + "node_modules/@types/cookie": { + "version": "0.6.0", + "resolved": "https://registry.npmjs.org/@types/cookie/-/cookie-0.6.0.tgz", + "integrity": "sha512-4Kh9a6B2bQciAhf7FSuMRRkUWecJgJu9nPnx3yzpsfXX/c50REIqpHY4C82bXP90qrLtXtkDxTZosYO3UpOwlA==", + "dev": true, + "license": "MIT" + }, + "node_modules/@types/estree": { + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/@types/estree/-/estree-1.0.6.tgz", + "integrity": "sha512-AYnb1nQyY49te+VRAVgmzfcgjYS91mY5P0TKUDCLEM+gNnA+3T6rWITXRLYCpahpqSQbN5cE+gHpnPyXjHWxcw==", + "dev": true, + "license": "MIT" + }, + "node_modules/@types/pug": { + "version": "2.0.10", + "resolved": "https://registry.npmjs.org/@types/pug/-/pug-2.0.10.tgz", + "integrity": "sha512-Sk/uYFOBAB7mb74XcpizmH0KOR2Pv3D2Hmrh1Dmy5BmK3MpdSa5kqZcg6EKBdklU0bFXX9gCfzvpnyUehrPIuA==", + "dev": true, + "license": "MIT" + }, + "node_modules/@webgpu/types": { + "version": "0.1.49", + "resolved": "https://registry.npmjs.org/@webgpu/types/-/types-0.1.49.tgz", + "integrity": "sha512-NMmS8/DofhH/IFeW+876XrHVWel+J/vdcFCHLDqeJgkH9x0DeiwjVd8LcBdaxdG/T7Rf8VUAYsA8X1efMzLjRQ==", + "dev": true, + "license": "BSD-3-Clause" + }, + "node_modules/acorn": { + "version": "8.13.0", + "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.13.0.tgz", + "integrity": "sha512-8zSiw54Oxrdym50NlZ9sUusyO1Z1ZchgRLWRaK6c86XJFClyCgFKetdowBg5bKxyp/u+CDBJG4Mpp0m3HLZl9w==", + "dev": true, + "license": "MIT", + "bin": { + "acorn": "bin/acorn" + }, + "engines": { + "node": ">=0.4.0" + } + }, + "node_modules/anymatch": { + "version": "3.1.3", + "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.3.tgz", + "integrity": "sha512-KMReFUr0B4t+D+OBkjR3KYqvocp2XaSzO55UcB6mgQMd3KbcE+mWTyvVV7D/zsdEbNnV6acZUutkiHQXvTr1Rw==", + "dev": true, + "license": "ISC", + "dependencies": { + "normalize-path": "^3.0.0", + "picomatch": "^2.0.4" + }, + "engines": { + "node": ">= 8" + } + }, + "node_modules/aria-query": { + "version": "5.3.2", + "resolved": "https://registry.npmjs.org/aria-query/-/aria-query-5.3.2.tgz", + "integrity": "sha512-COROpnaoap1E2F000S62r6A60uHZnmlvomhfyT2DlTcrY1OrBKn2UhH7qn5wTC9zMvD0AY7csdPSNwKP+7WiQw==", + "dev": true, + "license": "Apache-2.0", + "engines": { + "node": ">= 0.4" + } + }, + "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==", + "dev": true, + "license": "Apache-2.0", + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/balanced-match": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", + "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", + "dev": true, + "license": "MIT" + }, + "node_modules/binary-extensions": { + "version": "2.3.0", + "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.3.0.tgz", + "integrity": "sha512-Ceh+7ox5qe7LJuLHoY0feh3pHuUDHAcRUeyL2VYghZwfpkNIy/+8Ocg0a3UuSoYzavmylwuLWQOf3hl0jjMMIw==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=8" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/brace-expansion": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-2.0.1.tgz", + "integrity": "sha512-XnAIvQ8eM+kC6aULx6wuQiwVsnzsi9d3WxzV3FpWTGA19F621kwdbsAcFKXgKUHZWsy+mY6iL1sHTxWEFCytDA==", + "dev": true, + "license": "MIT", + "dependencies": { + "balanced-match": "^1.0.0" + } + }, + "node_modules/braces": { + "version": "3.0.3", + "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.3.tgz", + "integrity": "sha512-yQbXgO/OSZVD2IsiLlro+7Hf6Q18EJrKSEsdoMzKePKXct3gvD8oLcOQdIzGupr5Fj+EDe8gO/lxc1BzfMpxvA==", + "dev": true, + "license": "MIT", + "dependencies": { + "fill-range": "^7.1.1" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/buffer-crc32": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/buffer-crc32/-/buffer-crc32-1.0.0.tgz", + "integrity": "sha512-Db1SbgBS/fg/392AblrMJk97KggmvYhr4pB5ZIMTWtaivCPMWLkmb7m21cJvpvgK+J3nsU2CmmixNBZx4vFj/w==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=8.0.0" + } + }, + "node_modules/chokidar": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-4.0.1.tgz", + "integrity": "sha512-n8enUVCED/KVRQlab1hr3MVpcVMvxtZjmEa956u+4YijlmQED223XMSYj2tLuKvr4jcCTzNNMpQDUer72MMmzA==", + "dev": true, + "license": "MIT", + "dependencies": { + "readdirp": "^4.0.1" + }, + "engines": { + "node": ">= 14.16.0" + }, + "funding": { + "url": "https://paulmillr.com/funding/" + } + }, + "node_modules/code-red": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/code-red/-/code-red-1.0.4.tgz", + "integrity": "sha512-7qJWqItLA8/VPVlKJlFXU+NBlo/qyfs39aJcuMT/2ere32ZqvF5OSxgdM5xOfJJ7O429gg2HM47y8v9P+9wrNw==", + "dev": true, + "license": "MIT", + "dependencies": { + "@jridgewell/sourcemap-codec": "^1.4.15", + "@types/estree": "^1.0.1", + "acorn": "^8.10.0", + "estree-walker": "^3.0.3", + "periscopic": "^3.1.0" + } + }, + "node_modules/concat-map": { + "version": "0.0.1", + "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", + "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==", + "dev": true, + "license": "MIT" + }, + "node_modules/cookie": { + "version": "0.6.0", + "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.6.0.tgz", + "integrity": "sha512-U71cyTamuh1CRNCfpGY6to28lxvNwPG4Guz/EVjgf3Jmzv0vlDp1atT9eS5dDjMYHucpHbWns6Lwf3BKz6svdw==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/css-tree": { + "version": "2.3.1", + "resolved": "https://registry.npmjs.org/css-tree/-/css-tree-2.3.1.tgz", + "integrity": "sha512-6Fv1DV/TYw//QF5IzQdqsNDjx/wc8TrMBZsqjL9eW01tWb7R7k/mq+/VXfJCl7SoD5emsJop9cOByJZfs8hYIw==", + "dev": true, + "license": "MIT", + "dependencies": { + "mdn-data": "2.0.30", + "source-map-js": "^1.0.1" + }, + "engines": { + "node": "^10 || ^12.20.0 || ^14.13.0 || >=15.0.0" + } + }, + "node_modules/debug": { + "version": "4.3.7", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.7.tgz", + "integrity": "sha512-Er2nc/H7RrMXZBFCEim6TCmMk02Z8vLC2Rbi1KEBggpo0fS6l0S1nnapwmIi3yW/+GOJap1Krg4w0Hg80oCqgQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "ms": "^2.1.3" + }, + "engines": { + "node": ">=6.0" + }, + "peerDependenciesMeta": { + "supports-color": { + "optional": true + } + } + }, + "node_modules/dedent-js": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/dedent-js/-/dedent-js-1.0.1.tgz", + "integrity": "sha512-OUepMozQULMLUmhxS95Vudo0jb0UchLimi3+pQ2plj61Fcy8axbP9hbiD4Sz6DPqn6XG3kfmziVfQ1rSys5AJQ==", + "dev": true, + "license": "MIT" + }, + "node_modules/deepmerge": { + "version": "4.3.1", + "resolved": "https://registry.npmjs.org/deepmerge/-/deepmerge-4.3.1.tgz", + "integrity": "sha512-3sUqbMEc77XqpdNO7FRyRog+eW3ph+GYCbj+rK+uYyRMuwsVy0rMiVtPn+QJlKFvWP/1PYpapqYn0Me2knFn+A==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/detect-indent": { + "version": "6.1.0", + "resolved": "https://registry.npmjs.org/detect-indent/-/detect-indent-6.1.0.tgz", + "integrity": "sha512-reYkTUJAZb9gUuZ2RvVCNhVHdg62RHnJ7WJl8ftMi4diZ6NWlciOzQN88pUhSELEwflJht4oQDv0F0BMlwaYtA==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=8" + } + }, + "node_modules/devalue": { + "version": "5.1.1", + "resolved": "https://registry.npmjs.org/devalue/-/devalue-5.1.1.tgz", + "integrity": "sha512-maua5KUiapvEwiEAe+XnlZ3Rh0GD+qI1J/nb9vrJc3muPXvcF/8gXYTWF76+5DAqHyDUtOIImEuo0YKE9mshVw==", + "dev": true, + "license": "MIT" + }, + "node_modules/es6-promise": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/es6-promise/-/es6-promise-3.3.1.tgz", + "integrity": "sha512-SOp9Phqvqn7jtEUxPWdWfWoLmyt2VaJ6MpvP9Comy1MceMXqE6bxvaTu4iaxpYYPzhny28Lc+M87/c2cPK6lDg==", + "dev": true, + "license": "MIT" + }, + "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==", + "dev": true, + "hasInstallScript": true, + "license": "MIT", + "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/esm-env": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/esm-env/-/esm-env-1.0.0.tgz", + "integrity": "sha512-Cf6VksWPsTuW01vU9Mk/3vRue91Zevka5SjyNf3nEpokFRuqt/KjUQoGAwq9qMmhpLTHmXzSIrFRw8zxWzmFBA==", + "dev": true, + "license": "MIT" + }, + "node_modules/estree-walker": { + "version": "3.0.3", + "resolved": "https://registry.npmjs.org/estree-walker/-/estree-walker-3.0.3.tgz", + "integrity": "sha512-7RUKfXgSMMkzt6ZuXmqapOurLGPPfgj6l9uRZ7lRGolvk0y2yocc35LdcxKC5PQZdn2DMqioAQ2NoWcrTKmm6g==", + "dev": true, + "license": "MIT", + "dependencies": { + "@types/estree": "^1.0.0" + } + }, + "node_modules/fdir": { + "version": "6.4.2", + "resolved": "https://registry.npmjs.org/fdir/-/fdir-6.4.2.tgz", + "integrity": "sha512-KnhMXsKSPZlAhp7+IjUkRZKPb4fUyccpDrdFXbi4QL1qkmFh9kVY09Yox+n4MaOb3lHZ1Tv829C3oaaXoMYPDQ==", + "dev": true, + "license": "MIT", + "peerDependencies": { + "picomatch": "^3 || ^4" + }, + "peerDependenciesMeta": { + "picomatch": { + "optional": true + } + } + }, + "node_modules/fill-range": { + "version": "7.1.1", + "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.1.1.tgz", + "integrity": "sha512-YsGpe3WHLK8ZYi4tWDg2Jy3ebRz2rXowDxnld4bkQB00cc/1Zw9AWnC0i9ztDJitivtQvaI9KaLyKrc+hBW0yg==", + "dev": true, + "license": "MIT", + "dependencies": { + "to-regex-range": "^5.0.1" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/fs.realpath": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", + "integrity": "sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw==", + "dev": true, + "license": "ISC" + }, + "node_modules/fsevents": { + "version": "2.3.3", + "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.3.tgz", + "integrity": "sha512-5xoDfX+fL7faATnagmWPpbFtwh/R77WmMMqqHGS65C3vvB0YHrgF+B1YmZ3441tMj5n63k0212XNoJwzlhffQw==", + "dev": true, + "hasInstallScript": true, + "license": "MIT", + "optional": true, + "os": [ + "darwin" + ], + "engines": { + "node": "^8.16.0 || ^10.6.0 || >=11.0.0" + } + }, + "node_modules/glob": { + "version": "8.1.0", + "resolved": "https://registry.npmjs.org/glob/-/glob-8.1.0.tgz", + "integrity": "sha512-r8hpEjiQEYlF2QU0df3dS+nxxSIreXQS1qRhMJM0Q5NDdR386C7jb7Hwwod8Fgiuex+k0GFjgft18yvxm5XoCQ==", + "deprecated": "Glob versions prior to v9 are no longer supported", + "dev": true, + "license": "ISC", + "dependencies": { + "fs.realpath": "^1.0.0", + "inflight": "^1.0.4", + "inherits": "2", + "minimatch": "^5.0.1", + "once": "^1.3.0" + }, + "engines": { + "node": ">=12" + }, + "funding": { + "url": "https://github.com/sponsors/isaacs" + } + }, + "node_modules/glob-parent": { + "version": "5.1.2", + "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", + "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", + "dev": true, + "license": "ISC", + "dependencies": { + "is-glob": "^4.0.1" + }, + "engines": { + "node": ">= 6" + } + }, + "node_modules/globalyzer": { + "version": "0.1.0", + "resolved": "https://registry.npmjs.org/globalyzer/-/globalyzer-0.1.0.tgz", + "integrity": "sha512-40oNTM9UfG6aBmuKxk/giHn5nQ8RVz/SS4Ir6zgzOv9/qC3kKZ9v4etGTcJbEl/NyVQH7FGU7d+X1egr57Md2Q==", + "dev": true, + "license": "MIT" + }, + "node_modules/globrex": { + "version": "0.1.2", + "resolved": "https://registry.npmjs.org/globrex/-/globrex-0.1.2.tgz", + "integrity": "sha512-uHJgbwAMwNFf5mLst7IWLNg14x1CkeqglJb/K3doi4dw6q2IvAAmM/Y81kevy83wP+Sst+nutFTYOGg3d1lsxg==", + "dev": true, + "license": "MIT" + }, + "node_modules/graceful-fs": { + "version": "4.2.11", + "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.11.tgz", + "integrity": "sha512-RbJ5/jmFcNNCcDV5o9eTnBLJ/HszWV0P73bc+Ff4nS/rJj+YaS6IGyiOL0VoBYX+l1Wrl3k63h/KrH+nhJ0XvQ==", + "dev": true, + "license": "ISC" + }, + "node_modules/ignore-walk": { + "version": "5.0.1", + "resolved": "https://registry.npmjs.org/ignore-walk/-/ignore-walk-5.0.1.tgz", + "integrity": "sha512-yemi4pMf51WKT7khInJqAvsIGzoqYXblnsz0ql8tM+yi1EKYTY1evX4NAbJrLL/Aanr2HyZeluqU+Oi7MGHokw==", + "dev": true, + "license": "ISC", + "dependencies": { + "minimatch": "^5.0.1" + }, + "engines": { + "node": "^12.13.0 || ^14.15.0 || >=16.0.0" + } + }, + "node_modules/import-meta-resolve": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/import-meta-resolve/-/import-meta-resolve-4.1.0.tgz", + "integrity": "sha512-I6fiaX09Xivtk+THaMfAwnA3MVA5Big1WHF1Dfx9hFuvNIWpXnorlkzhcQf6ehrqQiiZECRt1poOAkPmer3ruw==", + "dev": true, + "license": "MIT", + "funding": { + "type": "github", + "url": "https://github.com/sponsors/wooorm" + } + }, + "node_modules/inflight": { + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", + "integrity": "sha512-k92I/b08q4wvFscXCLvqfsHCrjrF7yiXsQuIVvVE7N82W3+aqpzuUdBbfhWcy/FZR3/4IgflMgKLOsvPDrGCJA==", + "deprecated": "This module is not supported, and leaks memory. Do not use it. Check out lru-cache if you want a good and tested way to coalesce async requests by a key value, which is much more comprehensive and powerful.", + "dev": true, + "license": "ISC", + "dependencies": { + "once": "^1.3.0", + "wrappy": "1" + } + }, + "node_modules/inherits": { + "version": "2.0.4", + "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", + "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", + "dev": true, + "license": "ISC" + }, + "node_modules/is-binary-path": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", + "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", + "dev": true, + "license": "MIT", + "dependencies": { + "binary-extensions": "^2.0.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/is-extglob": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", + "integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/is-glob": { + "version": "4.0.3", + "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", + "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", + "dev": true, + "license": "MIT", + "dependencies": { + "is-extglob": "^2.1.1" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/is-number": { + "version": "7.0.0", + "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", + "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=0.12.0" + } + }, + "node_modules/is-reference": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/is-reference/-/is-reference-3.0.2.tgz", + "integrity": "sha512-v3rht/LgVcsdZa3O2Nqs+NMowLOxeOm7Ay9+/ARQ2F+qEoANRcqrjAZKGN0v8ymUetZGgkp26LTnGT7H0Qo9Pg==", + "dev": true, + "license": "MIT", + "dependencies": { + "@types/estree": "*" + } + }, + "node_modules/kleur": { + "version": "4.1.5", + "resolved": "https://registry.npmjs.org/kleur/-/kleur-4.1.5.tgz", + "integrity": "sha512-o+NO+8WrRiQEE4/7nwRJhN1HWpVmJm511pBHUxPLtp0BUISzlBplORYSmTclCnJvQq2tKu/sgl3xVpkc7ZWuQQ==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=6" + } + }, + "node_modules/locate-character": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/locate-character/-/locate-character-3.0.0.tgz", + "integrity": "sha512-SW13ws7BjaeJ6p7Q6CO2nchbYEc3X3J6WrmTTDto7yMPqVSZTUyY5Tjbid+Ab8gLnATtygYtiDIJGQRRn2ZOiA==", + "dev": true, + "license": "MIT" + }, + "node_modules/lower-case": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/lower-case/-/lower-case-2.0.2.tgz", + "integrity": "sha512-7fm3l3NAF9WfN6W3JOmf5drwpVqX78JtoGJ3A6W0a6ZnldM41w2fV5D490psKFTpMds8TJse/eHLFFsNHHjHgg==", + "dev": true, + "license": "MIT", + "dependencies": { + "tslib": "^2.0.3" + } + }, + "node_modules/magic-string": { + "version": "0.30.12", + "resolved": "https://registry.npmjs.org/magic-string/-/magic-string-0.30.12.tgz", + "integrity": "sha512-Ea8I3sQMVXr8JhN4z+H/d8zwo+tYDgHE9+5G4Wnrwhs0gaK9fXTKx0Tw5Xwsd/bCPTTZNRAdpyzvoeORe9LYpw==", + "dev": true, + "license": "MIT", + "dependencies": { + "@jridgewell/sourcemap-codec": "^1.5.0" + } + }, + "node_modules/mdn-data": { + "version": "2.0.30", + "resolved": "https://registry.npmjs.org/mdn-data/-/mdn-data-2.0.30.tgz", + "integrity": "sha512-GaqWWShW4kv/G9IEucWScBx9G1/vsFZZJUO+tD26M8J8z3Kw5RDQjaoZe03YAClgeS/SWPOcb4nkFBTEi5DUEA==", + "dev": true, + "license": "CC0-1.0" + }, + "node_modules/min-indent": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/min-indent/-/min-indent-1.0.1.tgz", + "integrity": "sha512-I9jwMn07Sy/IwOj3zVkVik2JTvgpaykDZEigL6Rx6N9LbMywwUSMtxET+7lVoDLLd3O3IXwJwvuuns8UB/HeAg==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=4" + } + }, + "node_modules/minimatch": { + "version": "5.1.6", + "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-5.1.6.tgz", + "integrity": "sha512-lKwV/1brpG6mBUFHtb7NUmtABCb2WZZmm2wNiOA5hAb8VdCS4B3dtMWyvcoViccwAW/COERjXLt0zP1zXUN26g==", + "dev": true, + "license": "ISC", + "dependencies": { + "brace-expansion": "^2.0.1" + }, + "engines": { + "node": ">=10" + } + }, + "node_modules/minimist": { + "version": "1.2.8", + "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.8.tgz", + "integrity": "sha512-2yyAR8qBkN3YuheJanUpWC5U3bb5osDywNB8RzDVlDwDHbocAJveqqj1u8+SVD7jkWT4yvsHCpWqqWqAxb0zCA==", + "dev": true, + "license": "MIT", + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/mkdirp": { + "version": "0.5.6", + "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.6.tgz", + "integrity": "sha512-FP+p8RB8OWpF3YZBCrP5gtADmtXApB5AMLn+vdyA+PyxCjrCs00mjyUozssO33cwDeT3wNGdLxJ5M//YqtHAJw==", + "dev": true, + "license": "MIT", + "dependencies": { + "minimist": "^1.2.6" + }, + "bin": { + "mkdirp": "bin/cmd.js" + } + }, + "node_modules/mri": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/mri/-/mri-1.2.0.tgz", + "integrity": "sha512-tzzskb3bG8LvYGFF/mDTpq3jpI6Q9wc3LEmBaghu+DdCssd1FakN7Bc0hVNmEyGq1bq3RgfkCb3cmQLpNPOroA==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=4" + } + }, + "node_modules/mrmime": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/mrmime/-/mrmime-2.0.0.tgz", + "integrity": "sha512-eu38+hdgojoyq63s+yTpN4XMBdt5l8HhMhc4VKLO9KM5caLIBvUm4thi7fFaxyTmCKeNnXZ5pAlBwCUnhA09uw==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=10" + } + }, + "node_modules/ms": { + "version": "2.1.3", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", + "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==", + "dev": true, + "license": "MIT" + }, + "node_modules/nanoid": { + "version": "3.3.7", + "resolved": "https://registry.npmjs.org/nanoid/-/nanoid-3.3.7.tgz", + "integrity": "sha512-eSRppjcPIatRIMC1U6UngP8XFcz8MQWGQdt1MTBQ7NaAmvXDfvNxbvWV3x2y6CdEUciCSsDHDQZbhYaB8QEo2g==", + "dev": true, + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/ai" + } + ], + "license": "MIT", + "bin": { + "nanoid": "bin/nanoid.cjs" + }, + "engines": { + "node": "^10 || ^12 || ^13.7 || ^14 || >=15.0.1" + } + }, + "node_modules/no-case": { + "version": "3.0.4", + "resolved": "https://registry.npmjs.org/no-case/-/no-case-3.0.4.tgz", + "integrity": "sha512-fgAN3jGAh+RoxUGZHTSOLJIqUc2wmoBwGR4tbpNAKmmovFoWq0OdRkb0VkldReO2a2iBT/OEulG9XSUc10r3zg==", + "dev": true, + "license": "MIT", + "dependencies": { + "lower-case": "^2.0.2", + "tslib": "^2.0.3" + } + }, + "node_modules/normalize-path": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", + "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/npm-bundled": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/npm-bundled/-/npm-bundled-2.0.1.tgz", + "integrity": "sha512-gZLxXdjEzE/+mOstGDqR6b0EkhJ+kM6fxM6vUuckuctuVPh80Q6pw/rSZj9s4Gex9GxWtIicO1pc8DB9KZWudw==", + "dev": true, + "license": "ISC", + "dependencies": { + "npm-normalize-package-bin": "^2.0.0" + }, + "engines": { + "node": "^12.13.0 || ^14.15.0 || >=16.0.0" + } + }, + "node_modules/npm-normalize-package-bin": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/npm-normalize-package-bin/-/npm-normalize-package-bin-2.0.0.tgz", + "integrity": "sha512-awzfKUO7v0FscrSpRoogyNm0sajikhBWpU0QMrW09AMi9n1PoKU6WaIqUzuJSQnpciZZmJ/jMZ2Egfmb/9LiWQ==", + "dev": true, + "license": "ISC", + "engines": { + "node": "^12.13.0 || ^14.15.0 || >=16.0.0" + } + }, + "node_modules/npm-packlist": { + "version": "5.1.3", + "resolved": "https://registry.npmjs.org/npm-packlist/-/npm-packlist-5.1.3.tgz", + "integrity": "sha512-263/0NGrn32YFYi4J533qzrQ/krmmrWwhKkzwTuM4f/07ug51odoaNjUexxO4vxlzURHcmYMH1QjvHjsNDKLVg==", + "dev": true, + "license": "ISC", + "dependencies": { + "glob": "^8.0.1", + "ignore-walk": "^5.0.1", + "npm-bundled": "^2.0.0", + "npm-normalize-package-bin": "^2.0.0" + }, + "bin": { + "npm-packlist": "bin/index.js" + }, + "engines": { + "node": "^12.13.0 || ^14.15.0 || >=16.0.0" + } + }, + "node_modules/once": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", + "integrity": "sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w==", + "dev": true, + "license": "ISC", + "dependencies": { + "wrappy": "1" + } + }, + "node_modules/pascal-case": { + "version": "3.1.2", + "resolved": "https://registry.npmjs.org/pascal-case/-/pascal-case-3.1.2.tgz", + "integrity": "sha512-uWlGT3YSnK9x3BQJaOdcZwrnV6hPpd8jFH1/ucpiLRPh/2zCVJKS19E4GvYHvaCcACn3foXZ0cLB9Wrx1KGe5g==", + "dev": true, + "license": "MIT", + "dependencies": { + "no-case": "^3.0.4", + "tslib": "^2.0.3" + } + }, + "node_modules/path-is-absolute": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", + "integrity": "sha512-AVbw3UJ2e9bq64vSaS9Am0fje1Pa8pbGqTTsmXfaIiMpnr5DlDhfJOuLj9Sf95ZPVDAUerDfEk88MPmPe7UCQg==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/periscopic": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/periscopic/-/periscopic-3.1.0.tgz", + "integrity": "sha512-vKiQ8RRtkl9P+r/+oefh25C3fhybptkHKCZSPlcXiJux2tJF55GnEj3BVn4A5gKfq9NWWXXrxkHBwVPUfH0opw==", + "dev": true, + "license": "MIT", + "dependencies": { + "@types/estree": "^1.0.0", + "estree-walker": "^3.0.0", + "is-reference": "^3.0.0" + } + }, + "node_modules/picocolors": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/picocolors/-/picocolors-1.1.1.tgz", + "integrity": "sha512-xceH2snhtb5M9liqDsmEw56le376mTZkEX/jEb/RxNFyegNul7eNslCXP9FDj/Lcu0X8KEyMceP2ntpaHrDEVA==", + "dev": true, + "license": "ISC" + }, + "node_modules/picomatch": { + "version": "2.3.1", + "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz", + "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=8.6" + }, + "funding": { + "url": "https://github.com/sponsors/jonschlinkert" + } + }, + "node_modules/postcss": { + "version": "8.4.47", + "resolved": "https://registry.npmjs.org/postcss/-/postcss-8.4.47.tgz", + "integrity": "sha512-56rxCq7G/XfB4EkXq9Egn5GCqugWvDFjafDOThIdMBsI15iqPqR5r15TfSr1YPYeEI19YeaXMCbY6u88Y76GLQ==", + "dev": true, + "funding": [ + { + "type": "opencollective", + "url": "https://opencollective.com/postcss/" + }, + { + "type": "tidelift", + "url": "https://tidelift.com/funding/github/npm/postcss" + }, + { + "type": "github", + "url": "https://github.com/sponsors/ai" + } + ], + "license": "MIT", + "dependencies": { + "nanoid": "^3.3.7", + "picocolors": "^1.1.0", + "source-map-js": "^1.2.1" + }, + "engines": { + "node": "^10 || ^12 || >=14" + } + }, + "node_modules/publint": { + "version": "0.2.11", + "resolved": "https://registry.npmjs.org/publint/-/publint-0.2.11.tgz", + "integrity": "sha512-/kxbd+sD/uEG515N/ZYpC6gYs8h89cQ4UIsAq1y6VT4qlNh8xmiSwcP2xU2MbzXFl8J0l2IdONKFweLfYoqhcA==", + "dev": true, + "license": "MIT", + "dependencies": { + "npm-packlist": "^5.1.3", + "picocolors": "^1.1.0", + "sade": "^1.8.1" + }, + "bin": { + "publint": "lib/cli.js" + }, + "engines": { + "node": ">=16" + }, + "funding": { + "url": "https://bjornlu.com/sponsor" + } + }, + "node_modules/readdirp": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-4.0.2.tgz", + "integrity": "sha512-yDMz9g+VaZkqBYS/ozoBJwaBhTbZo3UNYQHNRw1D3UFQB8oHB4uS/tAODO+ZLjGWmUbKnIlOWO+aaIiAxrUWHA==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">= 14.16.0" + }, + "funding": { + "type": "individual", + "url": "https://paulmillr.com/funding/" + } + }, + "node_modules/rimraf": { + "version": "2.7.1", + "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.7.1.tgz", + "integrity": "sha512-uWjbaKIK3T1OSVptzX7Nl6PvQ3qAGtKEtVRjRuazjfL3Bx5eI409VZSqgND+4UNnmzLVdPj9FqFJNPqBZFve4w==", + "deprecated": "Rimraf versions prior to v4 are no longer supported", + "dev": true, + "license": "ISC", + "dependencies": { + "glob": "^7.1.3" + }, + "bin": { + "rimraf": "bin.js" + } + }, + "node_modules/rimraf/node_modules/brace-expansion": { + "version": "1.1.11", + "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", + "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", + "dev": true, + "license": "MIT", + "dependencies": { + "balanced-match": "^1.0.0", + "concat-map": "0.0.1" + } + }, + "node_modules/rimraf/node_modules/glob": { + "version": "7.2.3", + "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.3.tgz", + "integrity": "sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q==", + "deprecated": "Glob versions prior to v9 are no longer supported", + "dev": true, + "license": "ISC", + "dependencies": { + "fs.realpath": "^1.0.0", + "inflight": "^1.0.4", + "inherits": "2", + "minimatch": "^3.1.1", + "once": "^1.3.0", + "path-is-absolute": "^1.0.0" + }, + "engines": { + "node": "*" + }, + "funding": { + "url": "https://github.com/sponsors/isaacs" + } + }, + "node_modules/rimraf/node_modules/minimatch": { + "version": "3.1.2", + "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", + "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", + "dev": true, + "license": "ISC", + "dependencies": { + "brace-expansion": "^1.1.7" + }, + "engines": { + "node": "*" + } + }, + "node_modules/rollup": { + "version": "4.24.0", + "resolved": "https://registry.npmjs.org/rollup/-/rollup-4.24.0.tgz", + "integrity": "sha512-DOmrlGSXNk1DM0ljiQA+i+o0rSLhtii1je5wgk60j49d1jHT5YYttBv1iWOnYSTG+fZZESUOSNiAl89SIet+Cg==", + "dev": true, + "license": "MIT", + "dependencies": { + "@types/estree": "1.0.6" + }, + "bin": { + "rollup": "dist/bin/rollup" + }, + "engines": { + "node": ">=18.0.0", + "npm": ">=8.0.0" + }, + "optionalDependencies": { + "@rollup/rollup-android-arm-eabi": "4.24.0", + "@rollup/rollup-android-arm64": "4.24.0", + "@rollup/rollup-darwin-arm64": "4.24.0", + "@rollup/rollup-darwin-x64": "4.24.0", + "@rollup/rollup-linux-arm-gnueabihf": "4.24.0", + "@rollup/rollup-linux-arm-musleabihf": "4.24.0", + "@rollup/rollup-linux-arm64-gnu": "4.24.0", + "@rollup/rollup-linux-arm64-musl": "4.24.0", + "@rollup/rollup-linux-powerpc64le-gnu": "4.24.0", + "@rollup/rollup-linux-riscv64-gnu": "4.24.0", + "@rollup/rollup-linux-s390x-gnu": "4.24.0", + "@rollup/rollup-linux-x64-gnu": "4.24.0", + "@rollup/rollup-linux-x64-musl": "4.24.0", + "@rollup/rollup-win32-arm64-msvc": "4.24.0", + "@rollup/rollup-win32-ia32-msvc": "4.24.0", + "@rollup/rollup-win32-x64-msvc": "4.24.0", + "fsevents": "~2.3.2" + } + }, + "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==", + "dev": true, + "license": "MIT", + "dependencies": { + "mri": "^1.1.0" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/sander": { + "version": "0.5.1", + "resolved": "https://registry.npmjs.org/sander/-/sander-0.5.1.tgz", + "integrity": "sha512-3lVqBir7WuKDHGrKRDn/1Ye3kwpXaDOMsiRP1wd6wpZW56gJhsbp5RqQpA6JG/P+pkXizygnr1dKR8vzWaVsfA==", + "dev": true, + "license": "MIT", + "dependencies": { + "es6-promise": "^3.1.2", + "graceful-fs": "^4.1.3", + "mkdirp": "^0.5.1", + "rimraf": "^2.5.2" + } + }, + "node_modules/semver": { + "version": "7.6.3", + "resolved": "https://registry.npmjs.org/semver/-/semver-7.6.3.tgz", + "integrity": "sha512-oVekP1cKtI+CTDvHWYFUcMtsK/00wmAEfyqKfNdARm8u1wNVhSgaX7A8d4UuIlUI5e84iEwOhs7ZPYRmzU9U6A==", + "dev": true, + "license": "ISC", + "bin": { + "semver": "bin/semver.js" + }, + "engines": { + "node": ">=10" + } + }, + "node_modules/set-cookie-parser": { + "version": "2.7.1", + "resolved": "https://registry.npmjs.org/set-cookie-parser/-/set-cookie-parser-2.7.1.tgz", + "integrity": "sha512-IOc8uWeOZgnb3ptbCURJWNjWUPcO3ZnTTdzsurqERrP6nPyv+paC55vJM0LpOlT2ne+Ix+9+CRG1MNLlyZ4GjQ==", + "dev": true, + "license": "MIT" + }, + "node_modules/sirv": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/sirv/-/sirv-3.0.0.tgz", + "integrity": "sha512-BPwJGUeDaDCHihkORDchNyyTvWFhcusy1XMmhEVTQTwGeybFbp8YEmB+njbPnth1FibULBSBVwCQni25XlCUDg==", + "dev": true, + "license": "MIT", + "dependencies": { + "@polka/url": "^1.0.0-next.24", + "mrmime": "^2.0.0", + "totalist": "^3.0.0" + }, + "engines": { + "node": ">=18" + } + }, + "node_modules/sorcery": { + "version": "0.11.1", + "resolved": "https://registry.npmjs.org/sorcery/-/sorcery-0.11.1.tgz", + "integrity": "sha512-o7npfeJE6wi6J9l0/5LKshFzZ2rMatRiCDwYeDQaOzqdzRJwALhX7mk/A/ecg6wjMu7wdZbmXfD2S/vpOg0bdQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "@jridgewell/sourcemap-codec": "^1.4.14", + "buffer-crc32": "^1.0.0", + "minimist": "^1.2.0", + "sander": "^0.5.0" + }, + "bin": { + "sorcery": "bin/sorcery" + } + }, + "node_modules/source-map-js": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/source-map-js/-/source-map-js-1.2.1.tgz", + "integrity": "sha512-UXWMKhLOwVKb728IUtQPXxfYU+usdybtUrK/8uGE8CQMvrhOpwvzDBwj0QhSL7MQc7vIsISBG8VQ8+IDQxpfQA==", + "dev": true, + "license": "BSD-3-Clause", + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/strip-indent": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/strip-indent/-/strip-indent-3.0.0.tgz", + "integrity": "sha512-laJTa3Jb+VQpaC6DseHhF7dXVqHTfJPCRDaEbid/drOhgitgYku/letMUqOXFoWV0zIIUbjpdH2t+tYj4bQMRQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "min-indent": "^1.0.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/svader": { + "resolved": "packages/svader", + "link": true + }, + "node_modules/svelte": { + "version": "4.2.19", + "resolved": "https://registry.npmjs.org/svelte/-/svelte-4.2.19.tgz", + "integrity": "sha512-IY1rnGr6izd10B0A8LqsBfmlT5OILVuZ7XsI0vdGPEvuonFV7NYEUK4dAkm9Zg2q0Um92kYjTpS1CAP3Nh/KWw==", + "dev": true, + "license": "MIT", + "dependencies": { + "@ampproject/remapping": "^2.2.1", + "@jridgewell/sourcemap-codec": "^1.4.15", + "@jridgewell/trace-mapping": "^0.3.18", + "@types/estree": "^1.0.1", + "acorn": "^8.9.0", + "aria-query": "^5.3.0", + "axobject-query": "^4.0.0", + "code-red": "^1.0.3", + "css-tree": "^2.3.1", + "estree-walker": "^3.0.3", + "is-reference": "^3.0.1", + "locate-character": "^3.0.0", + "magic-string": "^0.30.4", + "periscopic": "^3.1.0" + }, + "engines": { + "node": ">=16" + } + }, + "node_modules/svelte-check": { + "version": "3.8.6", + "resolved": "https://registry.npmjs.org/svelte-check/-/svelte-check-3.8.6.tgz", + "integrity": "sha512-ij0u4Lw/sOTREP13BdWZjiXD/BlHE6/e2e34XzmVmsp5IN4kVa3PWP65NM32JAgwjZlwBg/+JtiNV1MM8khu0Q==", + "dev": true, + "license": "MIT", + "dependencies": { + "@jridgewell/trace-mapping": "^0.3.17", + "chokidar": "^3.4.1", + "picocolors": "^1.0.0", + "sade": "^1.7.4", + "svelte-preprocess": "^5.1.3", + "typescript": "^5.0.3" + }, + "bin": { + "svelte-check": "bin/svelte-check" + }, + "peerDependencies": { + "svelte": "^3.55.0 || ^4.0.0-next.0 || ^4.0.0 || ^5.0.0-next.0" + } + }, + "node_modules/svelte-check/node_modules/chokidar": { + "version": "3.6.0", + "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.6.0.tgz", + "integrity": "sha512-7VT13fmjotKpGipCW9JEQAusEPE+Ei8nl6/g4FBAmIm0GOOLMua9NDDo/DWp0ZAxCr3cPq5ZpBqmPAQgDda2Pw==", + "dev": true, + "license": "MIT", + "dependencies": { + "anymatch": "~3.1.2", + "braces": "~3.0.2", + "glob-parent": "~5.1.2", + "is-binary-path": "~2.1.0", + "is-glob": "~4.0.1", + "normalize-path": "~3.0.0", + "readdirp": "~3.6.0" + }, + "engines": { + "node": ">= 8.10.0" + }, + "funding": { + "url": "https://paulmillr.com/funding/" + }, + "optionalDependencies": { + "fsevents": "~2.3.2" + } + }, + "node_modules/svelte-check/node_modules/readdirp": { + "version": "3.6.0", + "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz", + "integrity": "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==", + "dev": true, + "license": "MIT", + "dependencies": { + "picomatch": "^2.2.1" + }, + "engines": { + "node": ">=8.10.0" + } + }, + "node_modules/svelte-hmr": { + "version": "0.16.0", + "resolved": "https://registry.npmjs.org/svelte-hmr/-/svelte-hmr-0.16.0.tgz", + "integrity": "sha512-Gyc7cOS3VJzLlfj7wKS0ZnzDVdv3Pn2IuVeJPk9m2skfhcu5bq3wtIZyQGggr7/Iim5rH5cncyQft/kRLupcnA==", + "dev": true, + "license": "ISC", + "engines": { + "node": "^12.20 || ^14.13.1 || >= 16" + }, + "peerDependencies": { + "svelte": "^3.19.0 || ^4.0.0" + } + }, + "node_modules/svelte-preprocess": { + "version": "5.1.4", + "resolved": "https://registry.npmjs.org/svelte-preprocess/-/svelte-preprocess-5.1.4.tgz", + "integrity": "sha512-IvnbQ6D6Ao3Gg6ftiM5tdbR6aAETwjhHV+UKGf5bHGYR69RQvF1ho0JKPcbUON4vy4R7zom13jPjgdOWCQ5hDA==", + "dev": true, + "hasInstallScript": true, + "license": "MIT", + "dependencies": { + "@types/pug": "^2.0.6", + "detect-indent": "^6.1.0", + "magic-string": "^0.30.5", + "sorcery": "^0.11.0", + "strip-indent": "^3.0.0" + }, + "engines": { + "node": ">= 16.0.0" + }, + "peerDependencies": { + "@babel/core": "^7.10.2", + "coffeescript": "^2.5.1", + "less": "^3.11.3 || ^4.0.0", + "postcss": "^7 || ^8", + "postcss-load-config": "^2.1.0 || ^3.0.0 || ^4.0.0 || ^5.0.0", + "pug": "^3.0.0", + "sass": "^1.26.8", + "stylus": "^0.55.0", + "sugarss": "^2.0.0 || ^3.0.0 || ^4.0.0", + "svelte": "^3.23.0 || ^4.0.0-next.0 || ^4.0.0 || ^5.0.0-next.0", + "typescript": ">=3.9.5 || ^4.0.0 || ^5.0.0" + }, + "peerDependenciesMeta": { + "@babel/core": { + "optional": true + }, + "coffeescript": { + "optional": true + }, + "less": { + "optional": true + }, + "postcss": { + "optional": true + }, + "postcss-load-config": { + "optional": true + }, + "pug": { + "optional": true + }, + "sass": { + "optional": true + }, + "stylus": { + "optional": true + }, + "sugarss": { + "optional": true + }, + "typescript": { + "optional": true + } + } + }, + "node_modules/svelte2tsx": { + "version": "0.7.22", + "resolved": "https://registry.npmjs.org/svelte2tsx/-/svelte2tsx-0.7.22.tgz", + "integrity": "sha512-hf55ujq17ufVpDQlJzaQfRr9EjlLIwGmFlpKq4uYrQAQFw/99q1OcVYyBT6568iJySgBUY9PdccURrORmfetmQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "dedent-js": "^1.0.1", + "pascal-case": "^3.1.1" + }, + "peerDependencies": { + "svelte": "^3.55 || ^4.0.0-next.0 || ^4.0 || ^5.0.0-next.0", + "typescript": "^4.9.4 || ^5.0.0" + } + }, + "node_modules/tests-svelte4": { + "resolved": "packages/tests-svelte4", + "link": true + }, + "node_modules/tiny-glob": { + "version": "0.2.9", + "resolved": "https://registry.npmjs.org/tiny-glob/-/tiny-glob-0.2.9.tgz", + "integrity": "sha512-g/55ssRPUjShh+xkfx9UPDXqhckHEsHr4Vd9zX55oSdGZc/MD0m3sferOkwWtp98bv+kcVfEHtRJgBVJzelrzg==", + "dev": true, + "license": "MIT", + "dependencies": { + "globalyzer": "0.1.0", + "globrex": "^0.1.2" + } + }, + "node_modules/to-regex-range": { + "version": "5.0.1", + "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", + "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "is-number": "^7.0.0" + }, + "engines": { + "node": ">=8.0" + } + }, + "node_modules/totalist": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/totalist/-/totalist-3.0.1.tgz", + "integrity": "sha512-sf4i37nQ2LBx4m3wB74y+ubopq6W/dIzXg0FDGjsYnZHVa1Da8FH853wlL2gtUhg+xJXjfk3kUZS3BRoQeoQBQ==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=6" + } + }, + "node_modules/tslib": { + "version": "2.8.0", + "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.8.0.tgz", + "integrity": "sha512-jWVzBLplnCmoaTr13V9dYbiQ99wvZRd0vNWaDRg+aVYRcjDF3nDksxFDE/+fkXnKhpnUUkmx5pK/v8mCtLVqZA==", + "dev": true, + "license": "0BSD" + }, + "node_modules/typescript": { + "version": "5.6.3", + "resolved": "https://registry.npmjs.org/typescript/-/typescript-5.6.3.tgz", + "integrity": "sha512-hjcS1mhfuyi4WW8IWtjP7brDrG2cuDZukyrYrSauoXGNgx0S7zceP07adYkJycEr56BOUTNPzbInooiN3fn1qw==", + "dev": true, + "license": "Apache-2.0", + "bin": { + "tsc": "bin/tsc", + "tsserver": "bin/tsserver" + }, + "engines": { + "node": ">=14.17" + } + }, + "node_modules/vite": { + "version": "5.4.10", + "resolved": "https://registry.npmjs.org/vite/-/vite-5.4.10.tgz", + "integrity": "sha512-1hvaPshuPUtxeQ0hsVH3Mud0ZanOLwVTneA1EgbAM5LhaZEqyPWGRQ7BtaMvUrTDeEaC8pxtj6a6jku3x4z6SQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "esbuild": "^0.21.3", + "postcss": "^8.4.43", + "rollup": "^4.20.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": { + "@types/node": "^18.0.0 || >=20.0.0", + "less": "*", + "lightningcss": "^1.21.0", + "sass": "*", + "sass-embedded": "*", + "stylus": "*", + "sugarss": "*", + "terser": "^5.4.0" + }, + "peerDependenciesMeta": { + "@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/vitefu": { + "version": "0.2.5", + "resolved": "https://registry.npmjs.org/vitefu/-/vitefu-0.2.5.tgz", + "integrity": "sha512-SgHtMLoqaeeGnd2evZ849ZbACbnwQCIwRH57t18FxcXoZop0uQu0uzlIhJBlF/eWVzuce0sHeqPcDo+evVcg8Q==", + "dev": true, + "license": "MIT", + "peerDependencies": { + "vite": "^3.0.0 || ^4.0.0 || ^5.0.0" + }, + "peerDependenciesMeta": { + "vite": { + "optional": true + } + } + }, + "node_modules/wrappy": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", + "integrity": "sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ==", + "dev": true, + "license": "ISC" + }, + "packages/svader": { + "version": "0.4.1", + "license": "MIT", + "devDependencies": { + "@sveltejs/kit": "^2.0.0", + "@sveltejs/package": "^2.3.4", + "@sveltejs/vite-plugin-svelte": "^3.0.0", + "@webgpu/types": "^0.1.44", + "publint": "^0.2.9", + "svelte": "^4.0.0", + "svelte-check": "^3.8.5", + "typescript": "^5.5.4", + "vite": "^5.4.0" + }, + "peerDependencies": { + "svelte": "^4.0.0" + } + }, + "packages/tests-svelte4": { + "devDependencies": { + "@sveltejs/adapter-auto": "^3.0.0", + "@sveltejs/kit": "^2.0.0", + "@sveltejs/vite-plugin-svelte": "^3.1.1", + "svelte": "^4.0.0", + "svelte-check": "^4.0.0", + "typescript": "^5.0.0", + "vite": "^5.0.11" + } + }, + "packages/tests-svelte4/node_modules/svelte-check": { + "version": "4.0.5", + "resolved": "https://registry.npmjs.org/svelte-check/-/svelte-check-4.0.5.tgz", + "integrity": "sha512-icBTBZ3ibBaywbXUat3cK6hB5Du+Kq9Z8CRuyLmm64XIe2/r+lQcbuBx/IQgsbrC+kT2jQ0weVpZSSRIPwB6jQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "@jridgewell/trace-mapping": "^0.3.25", + "chokidar": "^4.0.1", + "fdir": "^6.2.0", + "picocolors": "^1.0.0", + "sade": "^1.7.4" + }, + "bin": { + "svelte-check": "bin/svelte-check" + }, + "engines": { + "node": ">= 18.0.0" + }, + "peerDependencies": { + "svelte": "^4.0.0 || ^5.0.0-next.0", + "typescript": ">=5.0.0" + } + } + } +} diff --git a/package.json b/package.json index 6d4294f..4c72a03 100644 --- a/package.json +++ b/package.json @@ -1,59 +1,17 @@ { - "name": "svader", - "version": "0.4.1", - "description": "Create GPU-rendered Svelte components", - "author": "Holger Dal Mogensen", - "license": "MIT", - "repository": "github:sockmaster27/svader", - "keywords": [ - "svader", - "svelte", - "svelte-components", - "webgpu", - "webgl", - "gpu", - "accelerated", - "graphics", - "fragment", - "shader", - "shaders" + "name": "svader-monorepo", + "private": true, + "workspaces": [ + "packages/*" ], "scripts": { - "dev": "vite dev", - "build": "vite build && npm run package", - "preview": "vite build && vite preview", - "package": "svelte-kit sync && svelte-package && publint", - "prepublishOnly": "npm run package", - "check": "svelte-kit sync && svelte-check --tsconfig ./tsconfig.json", - "check:watch": "svelte-kit sync && svelte-check --tsconfig ./tsconfig.json --watch" - }, - "exports": { - ".": { - "types": "./dist/index.d.ts", - "svelte": "./dist/index.js" - } - }, - "files": [ - "dist", - "!dist/**/*.test.*", - "!dist/**/*.spec.*" - ], - "peerDependencies": { - "svelte": "^4.0.0" - }, - "devDependencies": { - "@sveltejs/adapter-auto": "^3.2.4", - "@sveltejs/kit": "^2.5.22", - "@sveltejs/package": "^2.3.4", - "@sveltejs/vite-plugin-svelte": "^3.1.1", - "@webgpu/types": "^0.1.44", - "publint": "^0.2.9", - "svelte": "^4.2.18", - "svelte-check": "^3.8.5", - "typescript": "^5.5.4", - "vite": "^5.4.0" - }, - "svelte": "./dist/index.js", - "types": "./dist/index.d.ts", - "type": "module" + "package": "cd packages/svader && npm run package", + "dev:v4": "npm run package && cd packages/tests-svelte4 && npm run dev", + "preview:v4": "npm run package && cd packages/tests-svelte4 && npm run preview", + "check": "npm run package && npm run check:svader && npm run check:tests-svelte4", + "check:svader": "cd packages/svader && npm run check", + "check:tests-svelte4": "cd packages/tests-svelte4 && npm run check", + "build": "npm run package && npm run build:tests-svelte4", + "build:tests-svelte4": "cd packages/tests-svelte4 && npm run build" + } } diff --git a/packages/svader/LICENSE.md b/packages/svader/LICENSE.md new file mode 100644 index 0000000..029c148 --- /dev/null +++ b/packages/svader/LICENSE.md @@ -0,0 +1,21 @@ +MIT License + +Copyright (c) 2024 Holger Dal Mogensen + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +SOFTWARE. diff --git a/packages/svader/README.md b/packages/svader/README.md new file mode 100644 index 0000000..1b15580 --- /dev/null +++ b/packages/svader/README.md @@ -0,0 +1,294 @@ +

+ + + Svader Logo + +

+ +# Svader + +Create GPU-rendered Svelte components with WebGL and WebGPU fragment shaders. + +## What is a fragment shader? + +In short, a _fragment shader_ can be written as a program that takes the coordinates of a pixel on the screen and returns the color that this pixel should have. +This program can be executed on the GPU, ensuring massive parallelism and speed. + +To learn more about how to write fragment shaders, check out [The Book of Shaders](https://thebookofshaders.com/). + +The following is a collection of examples all made using Svader. The live version of all of these can be previewed on [svader.vercel.app](https://svader.vercel.app/), +and the source code can be found in the [`src/routes/`](https://github.com/sockmaster27/svader/tree/master/src/routes) directory. + +![Shader example collage](https://raw.githubusercontent.com/sockmaster27/svader/master/resources/collage.png) + +## Installation + +```bash +# npm +npm i -D svader + +# pnpm +pnpm i -D svader + +# Bun +bun i -D svader + +# Yarn +yarn add -D svader +``` + +## Usage + +To use a fragment shader component, you first need to decide whether to use WebGL or WebGPU. +If you're unsure about what to use, see the [WebGL vs. WebGPU](#webgl-vs-webgpu) section. + +### Sections + +- [WebGL](#webgl) + - [WebGL parameters](#webgl-parameters) + - [WebGL built-in values](#webgl-built-in-values) +- [WebGPU](#webgpu) + - [WebGPU parameters](#webgpu-parameters) + - [WebGPU built-in values](#webgpu-built-in-values) + +### WebGL + +The following is a minimal example of a WebGL fragment shader component. + +[**View in REPL**](https://svelte.dev/repl/3e4a38bca5ca49fa94e1106a841063d5?version=4.2.19) + +```svelte + + + +
WebGL not supported in this environment.
+
+``` + +This produces the following output: + +![Output of the WebGL shader](https://raw.githubusercontent.com/sockmaster27/svader/master/resources/debugShaderWebGl.png) + +Here, the `shaderCode` variable is a string containing the [GLES](https://en.wikipedia.org/wiki/OpenGL_ES) shader code. +For simplicity, this is stored as a string, but it would typically be stored in a separate `myShader.frag` file. +When loading the shader from a file, it might be useful to know that the `code` property accepts both a `string` and a `Promise`. + +What this code does is: + +1. Add the given `u_offset` uniform to the 2D coordinates of the pixel given by `gl_FragCoord.xy`. +2. Divide the resulting coordinates entrywise by the `u_resolution` uniform to normalize the coordinates between 0 and 1. +3. Return the normalized coordinates as the color of the pixel, such that the `x` coordinate becomes the red channel and the `y` coordinate becomes the green channel. The blue channel is always set to 0, and the alpha (opacity) channel is always set to 1 (fully opaque). + +In GLES, _uniforms_ are inputs to the function, that are the same for every pixel on the screen. +These need to be passed in via the `parameters` property of the `` component. +In this case, we need to pass in two uniforms: `u_resolution` and `u_offset`. +Since these specific parameters are very commonly used, they are specially implemented in Svader +such that the `value` property of each parameter can simply be set to `"resolution"` and `"offset"` respectively. + +Lastly, the `` component accepts a fallback slot, which is rendered when the browser cannot render the shader. + +#### WebGL parameters + +The `parameters` property is an array of objects with the following properties: + +- **`name`**: The name of the uniform parameter, e.g. `"my_uniform"`. + This must match the name of the parameter in the shader code. + +- **`type`**: The type of the uniform parameter as it is written in the shader code, e.g. `"float"`. + If the `value` property is a [built-in value](#webgl-built-in-values), such as `"resolution"`, + the `type` will be determined automatically and should not be set. + +- **`value`**: The value of the uniform parameter, or a string specifying a [built-in value](#webgl-built-in-values). + If not a built-in value, the type of this property must correspond to the `type` property, such that: + - **`float`, `int`, `uint`** is a `number`, + - **`vecN`, `ivecN`, `uvecN`** is a `number[]` with a length of `N`, e.g. `vec2` -> `[1.2, 3.4]`. + - **`matN`** is a `number[]` with a length of `N * N`, e.g. `mat2` -> `[1, 2, 3, 4]`. + +##### WebGL built-in values + +Some types of uniforms are used very often. These are implemented in Svader itself, and referred to as _built-in values_. +To use these, the `value` property of the parameter object must be set to a string matching one of the following: + +- **`"resolution"`**: A `vec2` of the canvas width and height in physical device pixels. + +- **`"scale"`**: A `float` of the ratio between CSS pixels and physical device pixels, i.e. zoom level. + For example, if the browser has been zoomed to 150%, the `scale` parameter will be `1.5`. + +- **`"time"`**: A `float` of the current time in seconds. + NOTE: Passing this parameter to the shader will cause it to rerender every frame. + +- **`"offset"`**: A `vec2` to be added to the `gl_FragCoord.xy` of the fragment shader. + Sometimes the size of the canvas is limited by hardware. + To compensate for this, Svader creates a virtual canvas with a smaller cutout shifting around to cover the screen. + The `"resolution"` parameter is automatically adjusted to match the size of this virtual canvas, but for technical reasons, + the `gl_FragCoord.xy` cannot be adjusted from the outside. + Therefore, the `"offset"` parameter is provided to be manually added to these coordinates. + +### WebGPU + +The following is a minimal example of a WebGPU fragment shader component. + +[**View in REPL**](https://svelte.dev/repl/498446d091964bb199e6a88bce90feae?version=4.2.19) + +```svelte + + + +
WebGPU not supported in this environment.
+
+``` + +This produces the following output: + +![Output of the WebGPU shader](https://raw.githubusercontent.com/sockmaster27/svader/master/resources/debugShaderWebGpu.png) + +Here, the `shaderCode` variable is a string containing the [WGSL](https://google.github.io/tour-of-wgsl/) shader code. +For simplicity, this is stored as a string, but it would typically be stored in a separate `myShader.wgsl` file. +When loading the shader from a file, it might be useful to know that the `code` property accepts both a `string` and a `Promise`. + +What this code does is: + +1. Add the given `offset` uniform variable to the 2D coordinates of the pixel given by `raw_pos.xy`. +2. Divide the resulting coordinates entrywise by the `resolution` uniform to normalize the coordinates between 0 and 1. +3. Return the normalized coordinates as the color of the pixel, such that the `x` coordinate becomes the red channel and the `y` coordinate becomes the green channel. The blue channel is always set to 0, and the alpha (opacity) channel is always set to 1 (fully opaque). + +In WGSL, these `var`s are the primary way to pass in parameters to the shader. +These need to be passed in via the `parameters` property of the `` component. +In this case, we need to pass in two uniforms: `resolution` and `offset`. +Since these specific parameters are very commonly used, they are specially implemented in Svader +such that the `value` property of each parameter can simply be set to `"resolution"` and `"offset"` respectively. + +Lastly, the `` component accepts a fallback slot, which is rendered when the browser cannot render the shader. + +#### WebGPU parameters + +The `parameters` property is an array of objects with the following properties: + +- **`label`**: The name of the parameter to be used for debugging. + This does not have to correspond to the name of the parameter in the shader code. + +- **`binding`**: An integer used to match the parameter to the variable in the shader code. + This has to match the `binding` property of the parameter in the shader code, e.g. for the variable declaration + + ```WGSL + @group(0) @binding(42) var my_variable: f32; + ``` + + the `binding` property should be `42`. + +- **`value`**: The value of the parameter, or a string specifying a [built-in value](#webgpu-built-in-values). + If not a built-in value, this parameter should be an `ArrayBuffer`/`ArrayBufferView`. + For example, to pass in a number to an `f32` parameter, it can be constructed like `new Float32Array([myNumberValue])`. + +- **`storage`**: [Optional - defaults to `false`] Whether the parameter is a storage variable rather than a uniform variable. + This has to match the declaration in the shader code, e.g. for the variable declaration + + ```WGSL + @group(0) @binding(0) var my_variable: f32; + ``` + + the `storage` property should be `false` or omitted, and for + + ```WGSL + @group(0) @binding(0) var my_variable: f32; + ``` + + it should be `true`. + Note that Svader currently only supports `var` and not `var`. + +##### WebGPU built-in values + +Some types of inputs are used very often. These are implemented in Svader itself, and referred to as _built-in values_. +To use these, the `value` property of the parameter object must be set to a string matching one of the following: + +- **`"resolution"`**: A `vec2f` of the canvas width and height in physical device pixels. + +- **`"scale"`**: An `f32` of the ratio between CSS pixels and physical device pixels, i.e. zoom level. + For example, if the browser has been zoomed to 150%, the `scale` parameter will be `1.5`. + +- **`"time"`**: An `f32` of the current time in seconds. + NOTE: Passing this parameter to the shader will cause it to rerender every frame. + +- **`"offset"`**: A `vec2f` to be added to the `@builtin(position)` of the fragment shader. + Sometimes the size of the canvas is limited by hardware. + To compensate for this, Svader creates a virtual canvas with a smaller cutout shifting around to cover the screen. + The `"resolution"` parameter is automatically adjusted to match the size of this virtual canvas, but for technical reasons, + the `@builtin(position)` cannot be adjusted from the outside. + Therefore, the `"offset"` parameter is provided to be manually added to these coordinates. + +## WebGL vs. WebGPU + +**For practical applications, default to using WebGL.** + +WebGL and WebGPU are both rendering APIs that allow web applications to render GPU-accelerated graphics. + +WebGL is the older of the two and is supported by [all modern browsers](https://caniuse.com/webgl). + +WebGPU is still in the experimental stage and is only supported in a [few browsers](https://caniuse.com/webgpu). +However, it supports certain features that WebGL does not. For example, as of writing, WebGL in Google Chrome only supports having 8 canvases active in the document at once, while WebGPU supports a practically unlimited number. + +## License + +Svader is licensed under the [MIT License](https://github.com/sockmaster27/svader/blob/master/LICENSE.md). diff --git a/packages/svader/package.json b/packages/svader/package.json new file mode 100644 index 0000000..219edec --- /dev/null +++ b/packages/svader/package.json @@ -0,0 +1,55 @@ +{ + "name": "svader", + "version": "0.4.1", + "description": "Create GPU-rendered Svelte components", + "author": "Holger Dal Mogensen", + "license": "MIT", + "repository": "github:sockmaster27/svader", + "keywords": [ + "svader", + "svelte", + "svelte-components", + "webgpu", + "webgl", + "gpu", + "accelerated", + "graphics", + "fragment", + "shader", + "shaders" + ], + "scripts": { + "package": "svelte-kit sync && svelte-package && publint", + "prepublishOnly": "npm run package", + "check": "svelte-kit sync && svelte-check --tsconfig ./tsconfig.json", + "check:watch": "svelte-kit sync && svelte-check --tsconfig ./tsconfig.json --watch" + }, + "exports": { + ".": { + "types": "./dist/index.d.ts", + "svelte": "./dist/index.js" + } + }, + "files": [ + "dist", + "!dist/**/*.test.*", + "!dist/**/*.spec.*" + ], + "peerDependencies": { + "svelte": "^4.0.0" + }, + "devDependencies": { + "@sveltejs/kit": "^2.0.0", + "@sveltejs/package": "^2.3.4", + "@sveltejs/vite-plugin-svelte": "^3.0.0", + "@webgpu/types": "^0.1.44", + "publint": "^0.2.9", + "svelte": "^4.0.0", + "svelte-check": "^3.8.5", + "typescript": "^5.5.4", + "vite": "^5.4.0" + }, + "svelte": "./dist/index.js", + "types": "./dist/index.d.ts", + "type": "module" +} diff --git a/src/lib/BaseShader.svelte b/packages/svader/src/lib/BaseShader.svelte similarity index 100% rename from src/lib/BaseShader.svelte rename to packages/svader/src/lib/BaseShader.svelte diff --git a/src/lib/WebGlShader.svelte b/packages/svader/src/lib/WebGlShader.svelte similarity index 100% rename from src/lib/WebGlShader.svelte rename to packages/svader/src/lib/WebGlShader.svelte diff --git a/src/lib/WebGpuShader.svelte b/packages/svader/src/lib/WebGpuShader.svelte similarity index 100% rename from src/lib/WebGpuShader.svelte rename to packages/svader/src/lib/WebGpuShader.svelte diff --git a/src/lib/index.js b/packages/svader/src/lib/index.js similarity index 100% rename from src/lib/index.js rename to packages/svader/src/lib/index.js diff --git a/src/lib/intersectionObserver.js b/packages/svader/src/lib/intersectionObserver.js similarity index 100% rename from src/lib/intersectionObserver.js rename to packages/svader/src/lib/intersectionObserver.js diff --git a/src/lib/utils.js b/packages/svader/src/lib/utils.js similarity index 100% rename from src/lib/utils.js rename to packages/svader/src/lib/utils.js diff --git a/packages/svader/svelte.config.js b/packages/svader/svelte.config.js new file mode 100644 index 0000000..bded485 --- /dev/null +++ b/packages/svader/svelte.config.js @@ -0,0 +1,4 @@ +/** @type {import('@sveltejs/kit').Config} */ +const config = {}; + +export default config; diff --git a/tsconfig.json b/packages/svader/tsconfig.json similarity index 100% rename from tsconfig.json rename to packages/svader/tsconfig.json diff --git a/packages/tests-svelte4/package.json b/packages/tests-svelte4/package.json new file mode 100644 index 0000000..fbf1481 --- /dev/null +++ b/packages/tests-svelte4/package.json @@ -0,0 +1,23 @@ +{ + "name": "tests-svelte4", + "private": true, + "scripts": { + "dev": "vite dev", + "build": "vite build", + "preview": "vite build && vite preview", + "check": "svelte-kit sync && svelte-check --tsconfig ./tsconfig.json", + "check:watch": "svelte-kit sync && svelte-check --tsconfig ./tsconfig.json --watch" + }, + "devDependencies": { + "@sveltejs/adapter-auto": "^3.0.0", + "@sveltejs/kit": "^2.0.0", + "@sveltejs/vite-plugin-svelte": "^3.1.1", + "svelte": "^4.0.0", + "svelte-check": "^4.0.0", + "typescript": "^5.0.0", + "vite": "^5.0.11" + }, + "svelte": "./dist/index.js", + "types": "./dist/index.d.ts", + "type": "module" +} diff --git a/resources/banner.png b/packages/tests-svelte4/resources/banner.png similarity index 100% rename from resources/banner.png rename to packages/tests-svelte4/resources/banner.png diff --git a/resources/bubbles.png b/packages/tests-svelte4/resources/bubbles.png similarity index 100% rename from resources/bubbles.png rename to packages/tests-svelte4/resources/bubbles.png diff --git a/resources/collage.png b/packages/tests-svelte4/resources/collage.png similarity index 100% rename from resources/collage.png rename to packages/tests-svelte4/resources/collage.png diff --git a/resources/debugShaderWebGl.png b/packages/tests-svelte4/resources/debugShaderWebGl.png similarity index 100% rename from resources/debugShaderWebGl.png rename to packages/tests-svelte4/resources/debugShaderWebGl.png diff --git a/resources/debugShaderWebGpu.png b/packages/tests-svelte4/resources/debugShaderWebGpu.png similarity index 100% rename from resources/debugShaderWebGpu.png rename to packages/tests-svelte4/resources/debugShaderWebGpu.png diff --git a/resources/halo.png b/packages/tests-svelte4/resources/halo.png similarity index 100% rename from resources/halo.png rename to packages/tests-svelte4/resources/halo.png diff --git a/resources/logoDark.png b/packages/tests-svelte4/resources/logoDark.png similarity index 100% rename from resources/logoDark.png rename to packages/tests-svelte4/resources/logoDark.png diff --git a/resources/logoLight.png b/packages/tests-svelte4/resources/logoLight.png similarity index 100% rename from resources/logoLight.png rename to packages/tests-svelte4/resources/logoLight.png diff --git a/resources/slider.png b/packages/tests-svelte4/resources/slider.png similarity index 100% rename from resources/slider.png rename to packages/tests-svelte4/resources/slider.png diff --git a/src/app.d.ts b/packages/tests-svelte4/src/app.d.ts similarity index 100% rename from src/app.d.ts rename to packages/tests-svelte4/src/app.d.ts diff --git a/src/app.html b/packages/tests-svelte4/src/app.html similarity index 82% rename from src/app.html rename to packages/tests-svelte4/src/app.html index 2f12f93..faf2db7 100644 --- a/src/app.html +++ b/packages/tests-svelte4/src/app.html @@ -3,6 +3,7 @@ + %sveltekit.head% diff --git a/src/routes/+layout.server.js b/packages/tests-svelte4/src/routes/+layout.server.js similarity index 100% rename from src/routes/+layout.server.js rename to packages/tests-svelte4/src/routes/+layout.server.js diff --git a/src/routes/+page.svelte b/packages/tests-svelte4/src/routes/+page.svelte similarity index 100% rename from src/routes/+page.svelte rename to packages/tests-svelte4/src/routes/+page.svelte diff --git a/src/routes/hello-world/+page.svelte b/packages/tests-svelte4/src/routes/hello-world/+page.svelte similarity index 100% rename from src/routes/hello-world/+page.svelte rename to packages/tests-svelte4/src/routes/hello-world/+page.svelte diff --git a/src/routes/hello-world/webgl/+page.svelte b/packages/tests-svelte4/src/routes/hello-world/webgl/+page.svelte similarity index 89% rename from src/routes/hello-world/webgl/+page.svelte rename to packages/tests-svelte4/src/routes/hello-world/webgl/+page.svelte index 3a6b533..09cf622 100644 --- a/src/routes/hello-world/webgl/+page.svelte +++ b/packages/tests-svelte4/src/routes/hello-world/webgl/+page.svelte @@ -1,5 +1,5 @@ diff --git a/src/routes/hello-world/webgl/shader.frag b/packages/tests-svelte4/src/routes/hello-world/webgl/shader.frag similarity index 100% rename from src/routes/hello-world/webgl/shader.frag rename to packages/tests-svelte4/src/routes/hello-world/webgl/shader.frag diff --git a/src/routes/hello-world/webgpu/+page.svelte b/packages/tests-svelte4/src/routes/hello-world/webgpu/+page.svelte similarity index 90% rename from src/routes/hello-world/webgpu/+page.svelte rename to packages/tests-svelte4/src/routes/hello-world/webgpu/+page.svelte index 75a3e92..9335e26 100644 --- a/src/routes/hello-world/webgpu/+page.svelte +++ b/packages/tests-svelte4/src/routes/hello-world/webgpu/+page.svelte @@ -1,5 +1,5 @@ diff --git a/src/routes/hello-world/webgpu/shader.wgsl b/packages/tests-svelte4/src/routes/hello-world/webgpu/shader.wgsl similarity index 100% rename from src/routes/hello-world/webgpu/shader.wgsl rename to packages/tests-svelte4/src/routes/hello-world/webgpu/shader.wgsl diff --git a/src/routes/landing-page-bubbles/+page.svelte b/packages/tests-svelte4/src/routes/landing-page-bubbles/+page.svelte similarity index 100% rename from src/routes/landing-page-bubbles/+page.svelte rename to packages/tests-svelte4/src/routes/landing-page-bubbles/+page.svelte diff --git a/src/routes/landing-page-bubbles/webgl/+page.svelte b/packages/tests-svelte4/src/routes/landing-page-bubbles/webgl/+page.svelte similarity index 97% rename from src/routes/landing-page-bubbles/webgl/+page.svelte rename to packages/tests-svelte4/src/routes/landing-page-bubbles/webgl/+page.svelte index d4c2dcb..e3f0794 100644 --- a/src/routes/landing-page-bubbles/webgl/+page.svelte +++ b/packages/tests-svelte4/src/routes/landing-page-bubbles/webgl/+page.svelte @@ -1,5 +1,5 @@ diff --git a/src/routes/landing-page-halo/webgl/shader.frag b/packages/tests-svelte4/src/routes/landing-page-halo/webgl/shader.frag similarity index 100% rename from src/routes/landing-page-halo/webgl/shader.frag rename to packages/tests-svelte4/src/routes/landing-page-halo/webgl/shader.frag diff --git a/src/routes/landing-page-halo/webgpu/+page.svelte b/packages/tests-svelte4/src/routes/landing-page-halo/webgpu/+page.svelte similarity index 96% rename from src/routes/landing-page-halo/webgpu/+page.svelte rename to packages/tests-svelte4/src/routes/landing-page-halo/webgpu/+page.svelte index 0e71e94..2622c48 100644 --- a/src/routes/landing-page-halo/webgpu/+page.svelte +++ b/packages/tests-svelte4/src/routes/landing-page-halo/webgpu/+page.svelte @@ -1,5 +1,5 @@ diff --git a/src/routes/landing-page-halo/webgpu/shader.wgsl b/packages/tests-svelte4/src/routes/landing-page-halo/webgpu/shader.wgsl similarity index 100% rename from src/routes/landing-page-halo/webgpu/shader.wgsl rename to packages/tests-svelte4/src/routes/landing-page-halo/webgpu/shader.wgsl diff --git a/src/routes/logo/+page.svelte b/packages/tests-svelte4/src/routes/logo/+page.svelte similarity index 100% rename from src/routes/logo/+page.svelte rename to packages/tests-svelte4/src/routes/logo/+page.svelte diff --git a/src/routes/logo/logoDark.png b/packages/tests-svelte4/src/routes/logo/logoDark.png similarity index 100% rename from src/routes/logo/logoDark.png rename to packages/tests-svelte4/src/routes/logo/logoDark.png diff --git a/src/routes/logo/webgl/+page.svelte b/packages/tests-svelte4/src/routes/logo/webgl/+page.svelte similarity index 97% rename from src/routes/logo/webgl/+page.svelte rename to packages/tests-svelte4/src/routes/logo/webgl/+page.svelte index 29059ba..9203423 100644 --- a/src/routes/logo/webgl/+page.svelte +++ b/packages/tests-svelte4/src/routes/logo/webgl/+page.svelte @@ -1,5 +1,5 @@ diff --git a/src/routes/logo/webgl/shader.frag b/packages/tests-svelte4/src/routes/logo/webgl/shader.frag similarity index 100% rename from src/routes/logo/webgl/shader.frag rename to packages/tests-svelte4/src/routes/logo/webgl/shader.frag diff --git a/src/routes/logo/webgpu/+page.svelte b/packages/tests-svelte4/src/routes/logo/webgpu/+page.svelte similarity index 97% rename from src/routes/logo/webgpu/+page.svelte rename to packages/tests-svelte4/src/routes/logo/webgpu/+page.svelte index 505e5f1..9cd727d 100644 --- a/src/routes/logo/webgpu/+page.svelte +++ b/packages/tests-svelte4/src/routes/logo/webgpu/+page.svelte @@ -1,5 +1,5 @@ diff --git a/src/routes/logo/webgpu/shader.wgsl b/packages/tests-svelte4/src/routes/logo/webgpu/shader.wgsl similarity index 100% rename from src/routes/logo/webgpu/shader.wgsl rename to packages/tests-svelte4/src/routes/logo/webgpu/shader.wgsl diff --git a/src/routes/oversized-canvas/+page.svelte b/packages/tests-svelte4/src/routes/oversized-canvas/+page.svelte similarity index 100% rename from src/routes/oversized-canvas/+page.svelte rename to packages/tests-svelte4/src/routes/oversized-canvas/+page.svelte diff --git a/src/routes/oversized-canvas/webgl/+page.svelte b/packages/tests-svelte4/src/routes/oversized-canvas/webgl/+page.svelte similarity index 89% rename from src/routes/oversized-canvas/webgl/+page.svelte rename to packages/tests-svelte4/src/routes/oversized-canvas/webgl/+page.svelte index c608442..7f87c49 100644 --- a/src/routes/oversized-canvas/webgl/+page.svelte +++ b/packages/tests-svelte4/src/routes/oversized-canvas/webgl/+page.svelte @@ -1,5 +1,5 @@ diff --git a/src/routes/oversized-canvas/webgl/shader.frag b/packages/tests-svelte4/src/routes/oversized-canvas/webgl/shader.frag similarity index 100% rename from src/routes/oversized-canvas/webgl/shader.frag rename to packages/tests-svelte4/src/routes/oversized-canvas/webgl/shader.frag diff --git a/src/routes/oversized-canvas/webgpu/+page.svelte b/packages/tests-svelte4/src/routes/oversized-canvas/webgpu/+page.svelte similarity index 90% rename from src/routes/oversized-canvas/webgpu/+page.svelte rename to packages/tests-svelte4/src/routes/oversized-canvas/webgpu/+page.svelte index 1a48094..09f9d17 100644 --- a/src/routes/oversized-canvas/webgpu/+page.svelte +++ b/packages/tests-svelte4/src/routes/oversized-canvas/webgpu/+page.svelte @@ -1,5 +1,5 @@ diff --git a/src/routes/oversized-canvas/webgpu/shader.wgsl b/packages/tests-svelte4/src/routes/oversized-canvas/webgpu/shader.wgsl similarity index 100% rename from src/routes/oversized-canvas/webgpu/shader.wgsl rename to packages/tests-svelte4/src/routes/oversized-canvas/webgpu/shader.wgsl diff --git a/src/routes/remount/+page.svelte b/packages/tests-svelte4/src/routes/remount/+page.svelte similarity index 100% rename from src/routes/remount/+page.svelte rename to packages/tests-svelte4/src/routes/remount/+page.svelte diff --git a/src/routes/remount/webgl/+page.svelte b/packages/tests-svelte4/src/routes/remount/webgl/+page.svelte similarity index 93% rename from src/routes/remount/webgl/+page.svelte rename to packages/tests-svelte4/src/routes/remount/webgl/+page.svelte index b6290bd..03f2a08 100644 --- a/src/routes/remount/webgl/+page.svelte +++ b/packages/tests-svelte4/src/routes/remount/webgl/+page.svelte @@ -1,5 +1,5 @@