├── .github
└── workflows
│ └── nodejs.yml
├── .gitignore
├── LICENSE
├── README.md
├── eslint.config.mjs
├── package-lock.json
├── package.json
├── rollup.config.js
├── src
└── index.js
├── test
├── index.test.js
└── src
│ ├── button
│ ├── button.css
│ └── button.js
│ ├── index.css
│ └── index.js
└── types
└── plugin.d.ts
/.github/workflows/nodejs.yml:
--------------------------------------------------------------------------------
1 | # This workflow will do a clean install of node dependencies, build the source code and run tests across different versions of node
2 | # For more information see: https://help.github.com/actions/language-and-framework-guides/using-nodejs-with-github-actions
3 |
4 | name: build
5 |
6 | on:
7 | push:
8 | branches: [ master ]
9 | pull_request:
10 | branches: [ master ]
11 |
12 | jobs:
13 | build:
14 |
15 | runs-on: ubuntu-latest
16 |
17 | strategy:
18 | matrix:
19 | node-version: [20.x, 22.x, 24.x]
20 |
21 | steps:
22 | - uses: actions/checkout@v4
23 | - name: Use Node.js ${{ matrix.node-version }}
24 | uses: actions/setup-node@v4
25 | with:
26 | node-version: ${{ matrix.node-version }}
27 | - run: npm ci
28 | - run: npm run build --if-present
29 | - run: npm run lint --if-present
30 | - run: npm run test --if-present
31 |
--------------------------------------------------------------------------------
/.gitignore:
--------------------------------------------------------------------------------
1 | ### Node ###
2 | # Logs
3 | logs
4 | *.log
5 | npm-debug.log*
6 | yarn-debug.log*
7 | yarn-error.log*
8 | lerna-debug.log*
9 |
10 | # Diagnostic reports (https://nodejs.org/api/report.html)
11 | report.[0-9]*.[0-9]*.[0-9]*.[0-9]*.json
12 |
13 | # Runtime data
14 | pids
15 | *.pid
16 | *.seed
17 | *.pid.lock
18 |
19 | # Compiled binary addons (https://nodejs.org/api/addons.html)
20 | build/Release
21 |
22 | # Dependency directories
23 | node_modules/
24 |
25 | # TypeScript v1 declaration files
26 | typings/
27 |
28 | # TypeScript cache
29 | *.tsbuildinfo
30 |
31 | # Optional npm cache directory
32 | .npm
33 |
34 | # Optional eslint cache
35 | .eslintcache
36 |
37 | # Output of 'npm pack'
38 | *.tgz
39 |
40 | # dotenv environment variables file
41 | .env
42 | .env.test
43 |
44 | # rollup.js default build output
45 | dist/
46 |
47 | # Temporary folders
48 | tmp/
49 | temp/
--------------------------------------------------------------------------------
/LICENSE:
--------------------------------------------------------------------------------
1 | MIT License
2 |
3 | Copyright (c) 2020 Jacob Leeson
4 |
5 | Permission is hereby granted, free of charge, to any person obtaining a copy
6 | of this software and associated documentation files (the "Software"), to deal
7 | in the Software without restriction, including without limitation the rights
8 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9 | copies of the Software, and to permit persons to whom the Software is
10 | furnished to do so, subject to the following conditions:
11 |
12 | The above copyright notice and this permission notice shall be included in all
13 | copies or substantial portions of the Software.
14 |
15 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21 | SOFTWARE.
22 |
--------------------------------------------------------------------------------
/README.md:
--------------------------------------------------------------------------------
1 | # rollup-plugin-import-css
2 | A Rollup plugin to import CSS into JavaScript
3 |
4 | 
5 | [](https://github.com/jleeson/rollup-plugin-import-css/blob/master/LICENSE)
6 | [](https://twitter.com/jleesons)
7 |
8 |
9 | ---
10 |
11 | ## Usage
12 |
13 | ```js
14 | import css from "rollup-plugin-import-css";
15 |
16 | export default {
17 | input: "index.js",
18 | output: { file: "dist/index.js", format: "esm" },
19 | plugins: [ css() ]
20 | };
21 | ```
22 |
23 | This plugins supports three forms of importing css.
24 | ```js
25 | import "./styles.css"; /* extract the styles to a external css bundle */
26 | import styles from "./styles.css"; /* import the styles as a string */
27 | import styles from "./styles.css" with { type: "css" }; /* import the styles as a CSSStyleSheet */
28 | ```
29 |
30 | NOTICE: using import attributes requires Rollup v3+
31 |
32 | If your build uses `preserveModules`, this plugin will process and output your css files while maintaining their original file structure.
33 |
34 | This plugin respects the import order of your css files.
35 |
36 | ---
37 |
38 | ## Options
39 |
40 | ### include
41 |
42 | Type: `array` or `string`
43 | Default: `[]`
44 |
45 | A single file, or array of files to include in the plugins processing.
46 |
47 | ### exclude
48 |
49 | Type: `array` or `string`
50 | Default: `[]`
51 |
52 | A single file, or array of files to exclude in the plugins processing.
53 |
54 | ### output
55 |
56 | Type: `string`
57 | Default: `null`
58 |
59 | An output file name for the css bundle. By default `output.assetFileNames` is used.
60 |
61 | ### transform
62 |
63 | Type: `Function`
64 | Default: `null`
65 |
66 | The transform function is used for processing the CSS, it receives a string containing the code to process as an argument. The function should return a string.
67 |
68 | ### minify
69 |
70 | Type: `boolean`
71 | Default: `false`
72 |
73 | Minifies the css being imported.
74 | **NOTE:** this minifier uses regex, for more complex css, you can utilize your own minifier via the `transform` function.
75 |
76 | ### modules
77 |
78 | Type: `boolean`
79 | Default: `false`
80 |
81 | All css files being imported with a variable will use native CSS Modules.
82 |
83 | ### inject
84 |
85 | Type: `boolean`
86 | Default: `false`
87 |
88 | All css files being imported will be injected into the document head at runtime.
89 |
90 | ### alwaysOutput
91 |
92 | Type: `boolean`
93 | Default: `false`
94 |
95 | Always output a css bundle even if the css output is empty.
96 |
97 | ### preserveImports
98 |
99 | Type: `boolean`
100 | Default: `true`
101 |
102 | When enabled, css imports will be retained in the bundle when preserveModules is enabled.
103 |
104 | ---
105 |
106 | ## Why
107 |
108 | With modern web frameworks, its useful to be able to import the css for components in a variety of ways. Other solutions for Rollup either lack features or are large and bloated with extra features that some users may not need such as SASS or LESS support. This plugin is small and by default only supports standard css with the option to process it further. Unlike most other css plugins this plugin maintains the order of your imports in order to avoid overwritting css unexpectedly and respects Rollup's preserveModules option.
109 |
110 | ---
111 |
112 | ## Reporting Issues
113 |
114 | If you are having trouble getting something to work with this plugin or run into any problems, you can create a new [Issue](https://github.com/jleeson/rollup-plugin-import-css/issues).
115 |
116 | If this plugin does not fit your needs or is missing a feature you would like to see, let us know! We would greatly appreciate your feedback on it.
117 |
118 | ---
119 |
120 | ## License
121 |
122 | rollup-plugin-import-css is licensed under the terms of the [**MIT**](https://github.com/jleeson/rollup-plugin-import-css/blob/master/LICENSE) license.
123 |
--------------------------------------------------------------------------------
/eslint.config.mjs:
--------------------------------------------------------------------------------
1 | import globals from "globals";
2 | import js from "@eslint/js";
3 |
4 | export default {
5 | files: ["src/**/*.{js,mjs,cjs}"],
6 | languageOptions: { globals: { ...globals.node } },
7 | rules: {
8 | ...js.configs.recommended.rules,
9 | "indent": ["error", 4, { "SwitchCase": 1 }],
10 | "linebreak-style": ["error", "unix"],
11 | "quotes": ["error", "double", { "allowTemplateLiterals": true }],
12 | "semi": ["error", "always"]
13 | }
14 | };
--------------------------------------------------------------------------------
/package-lock.json:
--------------------------------------------------------------------------------
1 | {
2 | "name": "rollup-plugin-import-css",
3 | "version": "3.5.8",
4 | "lockfileVersion": 2,
5 | "requires": true,
6 | "packages": {
7 | "": {
8 | "name": "rollup-plugin-import-css",
9 | "version": "3.5.8",
10 | "license": "MIT",
11 | "dependencies": {
12 | "@rollup/pluginutils": "^5.1.4"
13 | },
14 | "devDependencies": {
15 | "@eslint/js": "^9.27.0",
16 | "esbuild": "^0.25.5",
17 | "eslint": "^9.27.0",
18 | "globals": "^16.2.0",
19 | "rollup": "^4.41.1",
20 | "rollup-plugin-esbuild": "^6.2.1"
21 | },
22 | "engines": {
23 | "node": ">=16"
24 | },
25 | "peerDependencies": {
26 | "rollup": "^2.x.x || ^3.x.x || ^4.x.x"
27 | }
28 | },
29 | "node_modules/@aashutoshrathi/word-wrap": {
30 | "version": "1.2.6",
31 | "resolved": "https://registry.npmjs.org/@aashutoshrathi/word-wrap/-/word-wrap-1.2.6.tgz",
32 | "integrity": "sha512-1Yjs2SvM8TflER/OD3cOjhWWOZb58A2t7wpE2S9XfBYTiIl+XFhQG2bjy4Pu1I+EAlCNUzRDYDdFwFYUKvXcIA==",
33 | "dev": true,
34 | "engines": {
35 | "node": ">=0.10.0"
36 | }
37 | },
38 | "node_modules/@esbuild/aix-ppc64": {
39 | "version": "0.25.5",
40 | "resolved": "https://registry.npmjs.org/@esbuild/aix-ppc64/-/aix-ppc64-0.25.5.tgz",
41 | "integrity": "sha512-9o3TMmpmftaCMepOdA5k/yDw8SfInyzWWTjYTFCX3kPSDJMROQTb8jg+h9Cnwnmm1vOzvxN7gIfB5V2ewpjtGA==",
42 | "cpu": [
43 | "ppc64"
44 | ],
45 | "dev": true,
46 | "license": "MIT",
47 | "optional": true,
48 | "os": [
49 | "aix"
50 | ],
51 | "engines": {
52 | "node": ">=18"
53 | }
54 | },
55 | "node_modules/@esbuild/android-arm": {
56 | "version": "0.25.5",
57 | "resolved": "https://registry.npmjs.org/@esbuild/android-arm/-/android-arm-0.25.5.tgz",
58 | "integrity": "sha512-AdJKSPeEHgi7/ZhuIPtcQKr5RQdo6OO2IL87JkianiMYMPbCtot9fxPbrMiBADOWWm3T2si9stAiVsGbTQFkbA==",
59 | "cpu": [
60 | "arm"
61 | ],
62 | "dev": true,
63 | "license": "MIT",
64 | "optional": true,
65 | "os": [
66 | "android"
67 | ],
68 | "engines": {
69 | "node": ">=18"
70 | }
71 | },
72 | "node_modules/@esbuild/android-arm64": {
73 | "version": "0.25.5",
74 | "resolved": "https://registry.npmjs.org/@esbuild/android-arm64/-/android-arm64-0.25.5.tgz",
75 | "integrity": "sha512-VGzGhj4lJO+TVGV1v8ntCZWJktV7SGCs3Pn1GRWI1SBFtRALoomm8k5E9Pmwg3HOAal2VDc2F9+PM/rEY6oIDg==",
76 | "cpu": [
77 | "arm64"
78 | ],
79 | "dev": true,
80 | "license": "MIT",
81 | "optional": true,
82 | "os": [
83 | "android"
84 | ],
85 | "engines": {
86 | "node": ">=18"
87 | }
88 | },
89 | "node_modules/@esbuild/android-x64": {
90 | "version": "0.25.5",
91 | "resolved": "https://registry.npmjs.org/@esbuild/android-x64/-/android-x64-0.25.5.tgz",
92 | "integrity": "sha512-D2GyJT1kjvO//drbRT3Hib9XPwQeWd9vZoBJn+bu/lVsOZ13cqNdDeqIF/xQ5/VmWvMduP6AmXvylO/PIc2isw==",
93 | "cpu": [
94 | "x64"
95 | ],
96 | "dev": true,
97 | "license": "MIT",
98 | "optional": true,
99 | "os": [
100 | "android"
101 | ],
102 | "engines": {
103 | "node": ">=18"
104 | }
105 | },
106 | "node_modules/@esbuild/darwin-arm64": {
107 | "version": "0.25.5",
108 | "resolved": "https://registry.npmjs.org/@esbuild/darwin-arm64/-/darwin-arm64-0.25.5.tgz",
109 | "integrity": "sha512-GtaBgammVvdF7aPIgH2jxMDdivezgFu6iKpmT+48+F8Hhg5J/sfnDieg0aeG/jfSvkYQU2/pceFPDKlqZzwnfQ==",
110 | "cpu": [
111 | "arm64"
112 | ],
113 | "dev": true,
114 | "license": "MIT",
115 | "optional": true,
116 | "os": [
117 | "darwin"
118 | ],
119 | "engines": {
120 | "node": ">=18"
121 | }
122 | },
123 | "node_modules/@esbuild/darwin-x64": {
124 | "version": "0.25.5",
125 | "resolved": "https://registry.npmjs.org/@esbuild/darwin-x64/-/darwin-x64-0.25.5.tgz",
126 | "integrity": "sha512-1iT4FVL0dJ76/q1wd7XDsXrSW+oLoquptvh4CLR4kITDtqi2e/xwXwdCVH8hVHU43wgJdsq7Gxuzcs6Iq/7bxQ==",
127 | "cpu": [
128 | "x64"
129 | ],
130 | "dev": true,
131 | "license": "MIT",
132 | "optional": true,
133 | "os": [
134 | "darwin"
135 | ],
136 | "engines": {
137 | "node": ">=18"
138 | }
139 | },
140 | "node_modules/@esbuild/freebsd-arm64": {
141 | "version": "0.25.5",
142 | "resolved": "https://registry.npmjs.org/@esbuild/freebsd-arm64/-/freebsd-arm64-0.25.5.tgz",
143 | "integrity": "sha512-nk4tGP3JThz4La38Uy/gzyXtpkPW8zSAmoUhK9xKKXdBCzKODMc2adkB2+8om9BDYugz+uGV7sLmpTYzvmz6Sw==",
144 | "cpu": [
145 | "arm64"
146 | ],
147 | "dev": true,
148 | "license": "MIT",
149 | "optional": true,
150 | "os": [
151 | "freebsd"
152 | ],
153 | "engines": {
154 | "node": ">=18"
155 | }
156 | },
157 | "node_modules/@esbuild/freebsd-x64": {
158 | "version": "0.25.5",
159 | "resolved": "https://registry.npmjs.org/@esbuild/freebsd-x64/-/freebsd-x64-0.25.5.tgz",
160 | "integrity": "sha512-PrikaNjiXdR2laW6OIjlbeuCPrPaAl0IwPIaRv+SMV8CiM8i2LqVUHFC1+8eORgWyY7yhQY+2U2fA55mBzReaw==",
161 | "cpu": [
162 | "x64"
163 | ],
164 | "dev": true,
165 | "license": "MIT",
166 | "optional": true,
167 | "os": [
168 | "freebsd"
169 | ],
170 | "engines": {
171 | "node": ">=18"
172 | }
173 | },
174 | "node_modules/@esbuild/linux-arm": {
175 | "version": "0.25.5",
176 | "resolved": "https://registry.npmjs.org/@esbuild/linux-arm/-/linux-arm-0.25.5.tgz",
177 | "integrity": "sha512-cPzojwW2okgh7ZlRpcBEtsX7WBuqbLrNXqLU89GxWbNt6uIg78ET82qifUy3W6OVww6ZWobWub5oqZOVtwolfw==",
178 | "cpu": [
179 | "arm"
180 | ],
181 | "dev": true,
182 | "license": "MIT",
183 | "optional": true,
184 | "os": [
185 | "linux"
186 | ],
187 | "engines": {
188 | "node": ">=18"
189 | }
190 | },
191 | "node_modules/@esbuild/linux-arm64": {
192 | "version": "0.25.5",
193 | "resolved": "https://registry.npmjs.org/@esbuild/linux-arm64/-/linux-arm64-0.25.5.tgz",
194 | "integrity": "sha512-Z9kfb1v6ZlGbWj8EJk9T6czVEjjq2ntSYLY2cw6pAZl4oKtfgQuS4HOq41M/BcoLPzrUbNd+R4BXFyH//nHxVg==",
195 | "cpu": [
196 | "arm64"
197 | ],
198 | "dev": true,
199 | "license": "MIT",
200 | "optional": true,
201 | "os": [
202 | "linux"
203 | ],
204 | "engines": {
205 | "node": ">=18"
206 | }
207 | },
208 | "node_modules/@esbuild/linux-ia32": {
209 | "version": "0.25.5",
210 | "resolved": "https://registry.npmjs.org/@esbuild/linux-ia32/-/linux-ia32-0.25.5.tgz",
211 | "integrity": "sha512-sQ7l00M8bSv36GLV95BVAdhJ2QsIbCuCjh/uYrWiMQSUuV+LpXwIqhgJDcvMTj+VsQmqAHL2yYaasENvJ7CDKA==",
212 | "cpu": [
213 | "ia32"
214 | ],
215 | "dev": true,
216 | "license": "MIT",
217 | "optional": true,
218 | "os": [
219 | "linux"
220 | ],
221 | "engines": {
222 | "node": ">=18"
223 | }
224 | },
225 | "node_modules/@esbuild/linux-loong64": {
226 | "version": "0.25.5",
227 | "resolved": "https://registry.npmjs.org/@esbuild/linux-loong64/-/linux-loong64-0.25.5.tgz",
228 | "integrity": "sha512-0ur7ae16hDUC4OL5iEnDb0tZHDxYmuQyhKhsPBV8f99f6Z9KQM02g33f93rNH5A30agMS46u2HP6qTdEt6Q1kg==",
229 | "cpu": [
230 | "loong64"
231 | ],
232 | "dev": true,
233 | "license": "MIT",
234 | "optional": true,
235 | "os": [
236 | "linux"
237 | ],
238 | "engines": {
239 | "node": ">=18"
240 | }
241 | },
242 | "node_modules/@esbuild/linux-mips64el": {
243 | "version": "0.25.5",
244 | "resolved": "https://registry.npmjs.org/@esbuild/linux-mips64el/-/linux-mips64el-0.25.5.tgz",
245 | "integrity": "sha512-kB/66P1OsHO5zLz0i6X0RxlQ+3cu0mkxS3TKFvkb5lin6uwZ/ttOkP3Z8lfR9mJOBk14ZwZ9182SIIWFGNmqmg==",
246 | "cpu": [
247 | "mips64el"
248 | ],
249 | "dev": true,
250 | "license": "MIT",
251 | "optional": true,
252 | "os": [
253 | "linux"
254 | ],
255 | "engines": {
256 | "node": ">=18"
257 | }
258 | },
259 | "node_modules/@esbuild/linux-ppc64": {
260 | "version": "0.25.5",
261 | "resolved": "https://registry.npmjs.org/@esbuild/linux-ppc64/-/linux-ppc64-0.25.5.tgz",
262 | "integrity": "sha512-UZCmJ7r9X2fe2D6jBmkLBMQetXPXIsZjQJCjgwpVDz+YMcS6oFR27alkgGv3Oqkv07bxdvw7fyB71/olceJhkQ==",
263 | "cpu": [
264 | "ppc64"
265 | ],
266 | "dev": true,
267 | "license": "MIT",
268 | "optional": true,
269 | "os": [
270 | "linux"
271 | ],
272 | "engines": {
273 | "node": ">=18"
274 | }
275 | },
276 | "node_modules/@esbuild/linux-riscv64": {
277 | "version": "0.25.5",
278 | "resolved": "https://registry.npmjs.org/@esbuild/linux-riscv64/-/linux-riscv64-0.25.5.tgz",
279 | "integrity": "sha512-kTxwu4mLyeOlsVIFPfQo+fQJAV9mh24xL+y+Bm6ej067sYANjyEw1dNHmvoqxJUCMnkBdKpvOn0Ahql6+4VyeA==",
280 | "cpu": [
281 | "riscv64"
282 | ],
283 | "dev": true,
284 | "license": "MIT",
285 | "optional": true,
286 | "os": [
287 | "linux"
288 | ],
289 | "engines": {
290 | "node": ">=18"
291 | }
292 | },
293 | "node_modules/@esbuild/linux-s390x": {
294 | "version": "0.25.5",
295 | "resolved": "https://registry.npmjs.org/@esbuild/linux-s390x/-/linux-s390x-0.25.5.tgz",
296 | "integrity": "sha512-K2dSKTKfmdh78uJ3NcWFiqyRrimfdinS5ErLSn3vluHNeHVnBAFWC8a4X5N+7FgVE1EjXS1QDZbpqZBjfrqMTQ==",
297 | "cpu": [
298 | "s390x"
299 | ],
300 | "dev": true,
301 | "license": "MIT",
302 | "optional": true,
303 | "os": [
304 | "linux"
305 | ],
306 | "engines": {
307 | "node": ">=18"
308 | }
309 | },
310 | "node_modules/@esbuild/linux-x64": {
311 | "version": "0.25.5",
312 | "resolved": "https://registry.npmjs.org/@esbuild/linux-x64/-/linux-x64-0.25.5.tgz",
313 | "integrity": "sha512-uhj8N2obKTE6pSZ+aMUbqq+1nXxNjZIIjCjGLfsWvVpy7gKCOL6rsY1MhRh9zLtUtAI7vpgLMK6DxjO8Qm9lJw==",
314 | "cpu": [
315 | "x64"
316 | ],
317 | "dev": true,
318 | "license": "MIT",
319 | "optional": true,
320 | "os": [
321 | "linux"
322 | ],
323 | "engines": {
324 | "node": ">=18"
325 | }
326 | },
327 | "node_modules/@esbuild/netbsd-arm64": {
328 | "version": "0.25.5",
329 | "resolved": "https://registry.npmjs.org/@esbuild/netbsd-arm64/-/netbsd-arm64-0.25.5.tgz",
330 | "integrity": "sha512-pwHtMP9viAy1oHPvgxtOv+OkduK5ugofNTVDilIzBLpoWAM16r7b/mxBvfpuQDpRQFMfuVr5aLcn4yveGvBZvw==",
331 | "cpu": [
332 | "arm64"
333 | ],
334 | "dev": true,
335 | "license": "MIT",
336 | "optional": true,
337 | "os": [
338 | "netbsd"
339 | ],
340 | "engines": {
341 | "node": ">=18"
342 | }
343 | },
344 | "node_modules/@esbuild/netbsd-x64": {
345 | "version": "0.25.5",
346 | "resolved": "https://registry.npmjs.org/@esbuild/netbsd-x64/-/netbsd-x64-0.25.5.tgz",
347 | "integrity": "sha512-WOb5fKrvVTRMfWFNCroYWWklbnXH0Q5rZppjq0vQIdlsQKuw6mdSihwSo4RV/YdQ5UCKKvBy7/0ZZYLBZKIbwQ==",
348 | "cpu": [
349 | "x64"
350 | ],
351 | "dev": true,
352 | "license": "MIT",
353 | "optional": true,
354 | "os": [
355 | "netbsd"
356 | ],
357 | "engines": {
358 | "node": ">=18"
359 | }
360 | },
361 | "node_modules/@esbuild/openbsd-arm64": {
362 | "version": "0.25.5",
363 | "resolved": "https://registry.npmjs.org/@esbuild/openbsd-arm64/-/openbsd-arm64-0.25.5.tgz",
364 | "integrity": "sha512-7A208+uQKgTxHd0G0uqZO8UjK2R0DDb4fDmERtARjSHWxqMTye4Erz4zZafx7Di9Cv+lNHYuncAkiGFySoD+Mw==",
365 | "cpu": [
366 | "arm64"
367 | ],
368 | "dev": true,
369 | "license": "MIT",
370 | "optional": true,
371 | "os": [
372 | "openbsd"
373 | ],
374 | "engines": {
375 | "node": ">=18"
376 | }
377 | },
378 | "node_modules/@esbuild/openbsd-x64": {
379 | "version": "0.25.5",
380 | "resolved": "https://registry.npmjs.org/@esbuild/openbsd-x64/-/openbsd-x64-0.25.5.tgz",
381 | "integrity": "sha512-G4hE405ErTWraiZ8UiSoesH8DaCsMm0Cay4fsFWOOUcz8b8rC6uCvnagr+gnioEjWn0wC+o1/TAHt+It+MpIMg==",
382 | "cpu": [
383 | "x64"
384 | ],
385 | "dev": true,
386 | "license": "MIT",
387 | "optional": true,
388 | "os": [
389 | "openbsd"
390 | ],
391 | "engines": {
392 | "node": ">=18"
393 | }
394 | },
395 | "node_modules/@esbuild/sunos-x64": {
396 | "version": "0.25.5",
397 | "resolved": "https://registry.npmjs.org/@esbuild/sunos-x64/-/sunos-x64-0.25.5.tgz",
398 | "integrity": "sha512-l+azKShMy7FxzY0Rj4RCt5VD/q8mG/e+mDivgspo+yL8zW7qEwctQ6YqKX34DTEleFAvCIUviCFX1SDZRSyMQA==",
399 | "cpu": [
400 | "x64"
401 | ],
402 | "dev": true,
403 | "license": "MIT",
404 | "optional": true,
405 | "os": [
406 | "sunos"
407 | ],
408 | "engines": {
409 | "node": ">=18"
410 | }
411 | },
412 | "node_modules/@esbuild/win32-arm64": {
413 | "version": "0.25.5",
414 | "resolved": "https://registry.npmjs.org/@esbuild/win32-arm64/-/win32-arm64-0.25.5.tgz",
415 | "integrity": "sha512-O2S7SNZzdcFG7eFKgvwUEZ2VG9D/sn/eIiz8XRZ1Q/DO5a3s76Xv0mdBzVM5j5R639lXQmPmSo0iRpHqUUrsxw==",
416 | "cpu": [
417 | "arm64"
418 | ],
419 | "dev": true,
420 | "license": "MIT",
421 | "optional": true,
422 | "os": [
423 | "win32"
424 | ],
425 | "engines": {
426 | "node": ">=18"
427 | }
428 | },
429 | "node_modules/@esbuild/win32-ia32": {
430 | "version": "0.25.5",
431 | "resolved": "https://registry.npmjs.org/@esbuild/win32-ia32/-/win32-ia32-0.25.5.tgz",
432 | "integrity": "sha512-onOJ02pqs9h1iMJ1PQphR+VZv8qBMQ77Klcsqv9CNW2w6yLqoURLcgERAIurY6QE63bbLuqgP9ATqajFLK5AMQ==",
433 | "cpu": [
434 | "ia32"
435 | ],
436 | "dev": true,
437 | "license": "MIT",
438 | "optional": true,
439 | "os": [
440 | "win32"
441 | ],
442 | "engines": {
443 | "node": ">=18"
444 | }
445 | },
446 | "node_modules/@esbuild/win32-x64": {
447 | "version": "0.25.5",
448 | "resolved": "https://registry.npmjs.org/@esbuild/win32-x64/-/win32-x64-0.25.5.tgz",
449 | "integrity": "sha512-TXv6YnJ8ZMVdX+SXWVBo/0p8LTcrUYngpWjvm91TMjjBQii7Oz11Lw5lbDV5Y0TzuhSJHwiH4hEtC1I42mMS0g==",
450 | "cpu": [
451 | "x64"
452 | ],
453 | "dev": true,
454 | "license": "MIT",
455 | "optional": true,
456 | "os": [
457 | "win32"
458 | ],
459 | "engines": {
460 | "node": ">=18"
461 | }
462 | },
463 | "node_modules/@eslint-community/eslint-utils": {
464 | "version": "4.4.0",
465 | "resolved": "https://registry.npmjs.org/@eslint-community/eslint-utils/-/eslint-utils-4.4.0.tgz",
466 | "integrity": "sha512-1/sA4dwrzBAyeUoQ6oxahHKmrZvsnLCg4RfxW3ZFGGmQkSNQPFNLV9CUEFQP1x9EYXHTo5p6xdhZM1Ne9p/AfA==",
467 | "dev": true,
468 | "dependencies": {
469 | "eslint-visitor-keys": "^3.3.0"
470 | },
471 | "engines": {
472 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0"
473 | },
474 | "peerDependencies": {
475 | "eslint": "^6.0.0 || ^7.0.0 || >=8.0.0"
476 | }
477 | },
478 | "node_modules/@eslint-community/regexpp": {
479 | "version": "4.12.1",
480 | "resolved": "https://registry.npmjs.org/@eslint-community/regexpp/-/regexpp-4.12.1.tgz",
481 | "integrity": "sha512-CCZCDJuduB9OUkFkY2IgppNZMi2lBQgD2qzwXkEia16cge2pijY/aXi96CJMquDMn3nJdlPV1A5KrJEXwfLNzQ==",
482 | "dev": true,
483 | "license": "MIT",
484 | "engines": {
485 | "node": "^12.0.0 || ^14.0.0 || >=16.0.0"
486 | }
487 | },
488 | "node_modules/@eslint/config-array": {
489 | "version": "0.20.0",
490 | "resolved": "https://registry.npmjs.org/@eslint/config-array/-/config-array-0.20.0.tgz",
491 | "integrity": "sha512-fxlS1kkIjx8+vy2SjuCB94q3htSNrufYTXubwiBFeaQHbH6Ipi43gFJq2zCMt6PHhImH3Xmr0NksKDvchWlpQQ==",
492 | "dev": true,
493 | "license": "Apache-2.0",
494 | "dependencies": {
495 | "@eslint/object-schema": "^2.1.6",
496 | "debug": "^4.3.1",
497 | "minimatch": "^3.1.2"
498 | },
499 | "engines": {
500 | "node": "^18.18.0 || ^20.9.0 || >=21.1.0"
501 | }
502 | },
503 | "node_modules/@eslint/config-helpers": {
504 | "version": "0.2.2",
505 | "resolved": "https://registry.npmjs.org/@eslint/config-helpers/-/config-helpers-0.2.2.tgz",
506 | "integrity": "sha512-+GPzk8PlG0sPpzdU5ZvIRMPidzAnZDl/s9L+y13iodqvb8leL53bTannOrQ/Im7UkpsmFU5Ily5U60LWixnmLg==",
507 | "dev": true,
508 | "license": "Apache-2.0",
509 | "engines": {
510 | "node": "^18.18.0 || ^20.9.0 || >=21.1.0"
511 | }
512 | },
513 | "node_modules/@eslint/core": {
514 | "version": "0.14.0",
515 | "resolved": "https://registry.npmjs.org/@eslint/core/-/core-0.14.0.tgz",
516 | "integrity": "sha512-qIbV0/JZr7iSDjqAc60IqbLdsj9GDt16xQtWD+B78d/HAlvysGdZZ6rpJHGAc2T0FQx1X6thsSPdnoiGKdNtdg==",
517 | "dev": true,
518 | "license": "Apache-2.0",
519 | "dependencies": {
520 | "@types/json-schema": "^7.0.15"
521 | },
522 | "engines": {
523 | "node": "^18.18.0 || ^20.9.0 || >=21.1.0"
524 | }
525 | },
526 | "node_modules/@eslint/eslintrc": {
527 | "version": "3.3.1",
528 | "resolved": "https://registry.npmjs.org/@eslint/eslintrc/-/eslintrc-3.3.1.tgz",
529 | "integrity": "sha512-gtF186CXhIl1p4pJNGZw8Yc6RlshoePRvE0X91oPGb3vZ8pM3qOS9W9NGPat9LziaBV7XrJWGylNQXkGcnM3IQ==",
530 | "dev": true,
531 | "license": "MIT",
532 | "dependencies": {
533 | "ajv": "^6.12.4",
534 | "debug": "^4.3.2",
535 | "espree": "^10.0.1",
536 | "globals": "^14.0.0",
537 | "ignore": "^5.2.0",
538 | "import-fresh": "^3.2.1",
539 | "js-yaml": "^4.1.0",
540 | "minimatch": "^3.1.2",
541 | "strip-json-comments": "^3.1.1"
542 | },
543 | "engines": {
544 | "node": "^18.18.0 || ^20.9.0 || >=21.1.0"
545 | },
546 | "funding": {
547 | "url": "https://opencollective.com/eslint"
548 | }
549 | },
550 | "node_modules/@eslint/eslintrc/node_modules/globals": {
551 | "version": "14.0.0",
552 | "resolved": "https://registry.npmjs.org/globals/-/globals-14.0.0.tgz",
553 | "integrity": "sha512-oahGvuMGQlPw/ivIYBjVSrWAfWLBeku5tpPE2fOPLi+WHffIWbuh2tCjhyQhTBPMf5E9jDEH4FOmTYgYwbKwtQ==",
554 | "dev": true,
555 | "license": "MIT",
556 | "engines": {
557 | "node": ">=18"
558 | },
559 | "funding": {
560 | "url": "https://github.com/sponsors/sindresorhus"
561 | }
562 | },
563 | "node_modules/@eslint/js": {
564 | "version": "9.27.0",
565 | "resolved": "https://registry.npmjs.org/@eslint/js/-/js-9.27.0.tgz",
566 | "integrity": "sha512-G5JD9Tu5HJEu4z2Uo4aHY2sLV64B7CDMXxFzqzjl3NKd6RVzSXNoE80jk7Y0lJkTTkjiIhBAqmlYwjuBY3tvpA==",
567 | "dev": true,
568 | "license": "MIT",
569 | "engines": {
570 | "node": "^18.18.0 || ^20.9.0 || >=21.1.0"
571 | },
572 | "funding": {
573 | "url": "https://eslint.org/donate"
574 | }
575 | },
576 | "node_modules/@eslint/object-schema": {
577 | "version": "2.1.6",
578 | "resolved": "https://registry.npmjs.org/@eslint/object-schema/-/object-schema-2.1.6.tgz",
579 | "integrity": "sha512-RBMg5FRL0I0gs51M/guSAj5/e14VQ4tpZnQNWwuDT66P14I43ItmPfIZRhO9fUVIPOAQXU47atlywZ/czoqFPA==",
580 | "dev": true,
581 | "license": "Apache-2.0",
582 | "engines": {
583 | "node": "^18.18.0 || ^20.9.0 || >=21.1.0"
584 | }
585 | },
586 | "node_modules/@eslint/plugin-kit": {
587 | "version": "0.3.1",
588 | "resolved": "https://registry.npmjs.org/@eslint/plugin-kit/-/plugin-kit-0.3.1.tgz",
589 | "integrity": "sha512-0J+zgWxHN+xXONWIyPWKFMgVuJoZuGiIFu8yxk7RJjxkzpGmyja5wRFqZIVtjDVOQpV+Rw0iOAjYPE2eQyjr0w==",
590 | "dev": true,
591 | "license": "Apache-2.0",
592 | "dependencies": {
593 | "@eslint/core": "^0.14.0",
594 | "levn": "^0.4.1"
595 | },
596 | "engines": {
597 | "node": "^18.18.0 || ^20.9.0 || >=21.1.0"
598 | }
599 | },
600 | "node_modules/@humanfs/core": {
601 | "version": "0.19.1",
602 | "resolved": "https://registry.npmjs.org/@humanfs/core/-/core-0.19.1.tgz",
603 | "integrity": "sha512-5DyQ4+1JEUzejeK1JGICcideyfUbGixgS9jNgex5nqkW+cY7WZhxBigmieN5Qnw9ZosSNVC9KQKyb+GUaGyKUA==",
604 | "dev": true,
605 | "license": "Apache-2.0",
606 | "engines": {
607 | "node": ">=18.18.0"
608 | }
609 | },
610 | "node_modules/@humanfs/node": {
611 | "version": "0.16.6",
612 | "resolved": "https://registry.npmjs.org/@humanfs/node/-/node-0.16.6.tgz",
613 | "integrity": "sha512-YuI2ZHQL78Q5HbhDiBA1X4LmYdXCKCMQIfw0pw7piHJwyREFebJUvrQN4cMssyES6x+vfUbx1CIpaQUKYdQZOw==",
614 | "dev": true,
615 | "license": "Apache-2.0",
616 | "dependencies": {
617 | "@humanfs/core": "^0.19.1",
618 | "@humanwhocodes/retry": "^0.3.0"
619 | },
620 | "engines": {
621 | "node": ">=18.18.0"
622 | }
623 | },
624 | "node_modules/@humanfs/node/node_modules/@humanwhocodes/retry": {
625 | "version": "0.3.1",
626 | "resolved": "https://registry.npmjs.org/@humanwhocodes/retry/-/retry-0.3.1.tgz",
627 | "integrity": "sha512-JBxkERygn7Bv/GbN5Rv8Ul6LVknS+5Bp6RgDC/O8gEBU/yeH5Ui5C/OlWrTb6qct7LjjfT6Re2NxB0ln0yYybA==",
628 | "dev": true,
629 | "license": "Apache-2.0",
630 | "engines": {
631 | "node": ">=18.18"
632 | },
633 | "funding": {
634 | "type": "github",
635 | "url": "https://github.com/sponsors/nzakas"
636 | }
637 | },
638 | "node_modules/@humanwhocodes/module-importer": {
639 | "version": "1.0.1",
640 | "resolved": "https://registry.npmjs.org/@humanwhocodes/module-importer/-/module-importer-1.0.1.tgz",
641 | "integrity": "sha512-bxveV4V8v5Yb4ncFTT3rPSgZBOpCkjfK0y4oVVVJwIuDVBRMDXrPyXRL988i5ap9m9bnyEEjWfm5WkBmtffLfA==",
642 | "dev": true,
643 | "engines": {
644 | "node": ">=12.22"
645 | },
646 | "funding": {
647 | "type": "github",
648 | "url": "https://github.com/sponsors/nzakas"
649 | }
650 | },
651 | "node_modules/@humanwhocodes/retry": {
652 | "version": "0.4.3",
653 | "resolved": "https://registry.npmjs.org/@humanwhocodes/retry/-/retry-0.4.3.tgz",
654 | "integrity": "sha512-bV0Tgo9K4hfPCek+aMAn81RppFKv2ySDQeMoSZuvTASywNTnVJCArCZE2FWqpvIatKu7VMRLWlR1EazvVhDyhQ==",
655 | "dev": true,
656 | "license": "Apache-2.0",
657 | "engines": {
658 | "node": ">=18.18"
659 | },
660 | "funding": {
661 | "type": "github",
662 | "url": "https://github.com/sponsors/nzakas"
663 | }
664 | },
665 | "node_modules/@rollup/pluginutils": {
666 | "version": "5.1.4",
667 | "resolved": "https://registry.npmjs.org/@rollup/pluginutils/-/pluginutils-5.1.4.tgz",
668 | "integrity": "sha512-USm05zrsFxYLPdWWq+K3STlWiT/3ELn3RcV5hJMghpeAIhxfsUIg6mt12CBJBInWMV4VneoV7SfGv8xIwo2qNQ==",
669 | "license": "MIT",
670 | "dependencies": {
671 | "@types/estree": "^1.0.0",
672 | "estree-walker": "^2.0.2",
673 | "picomatch": "^4.0.2"
674 | },
675 | "engines": {
676 | "node": ">=14.0.0"
677 | },
678 | "peerDependencies": {
679 | "rollup": "^1.20.0||^2.0.0||^3.0.0||^4.0.0"
680 | },
681 | "peerDependenciesMeta": {
682 | "rollup": {
683 | "optional": true
684 | }
685 | }
686 | },
687 | "node_modules/@rollup/rollup-android-arm-eabi": {
688 | "version": "4.41.1",
689 | "resolved": "https://registry.npmjs.org/@rollup/rollup-android-arm-eabi/-/rollup-android-arm-eabi-4.41.1.tgz",
690 | "integrity": "sha512-NELNvyEWZ6R9QMkiytB4/L4zSEaBC03KIXEghptLGLZWJ6VPrL63ooZQCOnlx36aQPGhzuOMwDerC1Eb2VmrLw==",
691 | "cpu": [
692 | "arm"
693 | ],
694 | "dev": true,
695 | "license": "MIT",
696 | "optional": true,
697 | "os": [
698 | "android"
699 | ]
700 | },
701 | "node_modules/@rollup/rollup-android-arm64": {
702 | "version": "4.41.1",
703 | "resolved": "https://registry.npmjs.org/@rollup/rollup-android-arm64/-/rollup-android-arm64-4.41.1.tgz",
704 | "integrity": "sha512-DXdQe1BJ6TK47ukAoZLehRHhfKnKg9BjnQYUu9gzhI8Mwa1d2fzxA1aw2JixHVl403bwp1+/o/NhhHtxWJBgEA==",
705 | "cpu": [
706 | "arm64"
707 | ],
708 | "dev": true,
709 | "license": "MIT",
710 | "optional": true,
711 | "os": [
712 | "android"
713 | ]
714 | },
715 | "node_modules/@rollup/rollup-darwin-arm64": {
716 | "version": "4.41.1",
717 | "resolved": "https://registry.npmjs.org/@rollup/rollup-darwin-arm64/-/rollup-darwin-arm64-4.41.1.tgz",
718 | "integrity": "sha512-5afxvwszzdulsU2w8JKWwY8/sJOLPzf0e1bFuvcW5h9zsEg+RQAojdW0ux2zyYAz7R8HvvzKCjLNJhVq965U7w==",
719 | "cpu": [
720 | "arm64"
721 | ],
722 | "dev": true,
723 | "license": "MIT",
724 | "optional": true,
725 | "os": [
726 | "darwin"
727 | ]
728 | },
729 | "node_modules/@rollup/rollup-darwin-x64": {
730 | "version": "4.41.1",
731 | "resolved": "https://registry.npmjs.org/@rollup/rollup-darwin-x64/-/rollup-darwin-x64-4.41.1.tgz",
732 | "integrity": "sha512-egpJACny8QOdHNNMZKf8xY0Is6gIMz+tuqXlusxquWu3F833DcMwmGM7WlvCO9sB3OsPjdC4U0wHw5FabzCGZg==",
733 | "cpu": [
734 | "x64"
735 | ],
736 | "dev": true,
737 | "license": "MIT",
738 | "optional": true,
739 | "os": [
740 | "darwin"
741 | ]
742 | },
743 | "node_modules/@rollup/rollup-freebsd-arm64": {
744 | "version": "4.41.1",
745 | "resolved": "https://registry.npmjs.org/@rollup/rollup-freebsd-arm64/-/rollup-freebsd-arm64-4.41.1.tgz",
746 | "integrity": "sha512-DBVMZH5vbjgRk3r0OzgjS38z+atlupJ7xfKIDJdZZL6sM6wjfDNo64aowcLPKIx7LMQi8vybB56uh1Ftck/Atg==",
747 | "cpu": [
748 | "arm64"
749 | ],
750 | "dev": true,
751 | "license": "MIT",
752 | "optional": true,
753 | "os": [
754 | "freebsd"
755 | ]
756 | },
757 | "node_modules/@rollup/rollup-freebsd-x64": {
758 | "version": "4.41.1",
759 | "resolved": "https://registry.npmjs.org/@rollup/rollup-freebsd-x64/-/rollup-freebsd-x64-4.41.1.tgz",
760 | "integrity": "sha512-3FkydeohozEskBxNWEIbPfOE0aqQgB6ttTkJ159uWOFn42VLyfAiyD9UK5mhu+ItWzft60DycIN1Xdgiy8o/SA==",
761 | "cpu": [
762 | "x64"
763 | ],
764 | "dev": true,
765 | "license": "MIT",
766 | "optional": true,
767 | "os": [
768 | "freebsd"
769 | ]
770 | },
771 | "node_modules/@rollup/rollup-linux-arm-gnueabihf": {
772 | "version": "4.41.1",
773 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm-gnueabihf/-/rollup-linux-arm-gnueabihf-4.41.1.tgz",
774 | "integrity": "sha512-wC53ZNDgt0pqx5xCAgNunkTzFE8GTgdZ9EwYGVcg+jEjJdZGtq9xPjDnFgfFozQI/Xm1mh+D9YlYtl+ueswNEg==",
775 | "cpu": [
776 | "arm"
777 | ],
778 | "dev": true,
779 | "license": "MIT",
780 | "optional": true,
781 | "os": [
782 | "linux"
783 | ]
784 | },
785 | "node_modules/@rollup/rollup-linux-arm-musleabihf": {
786 | "version": "4.41.1",
787 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm-musleabihf/-/rollup-linux-arm-musleabihf-4.41.1.tgz",
788 | "integrity": "sha512-jwKCca1gbZkZLhLRtsrka5N8sFAaxrGz/7wRJ8Wwvq3jug7toO21vWlViihG85ei7uJTpzbXZRcORotE+xyrLA==",
789 | "cpu": [
790 | "arm"
791 | ],
792 | "dev": true,
793 | "license": "MIT",
794 | "optional": true,
795 | "os": [
796 | "linux"
797 | ]
798 | },
799 | "node_modules/@rollup/rollup-linux-arm64-gnu": {
800 | "version": "4.41.1",
801 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm64-gnu/-/rollup-linux-arm64-gnu-4.41.1.tgz",
802 | "integrity": "sha512-g0UBcNknsmmNQ8V2d/zD2P7WWfJKU0F1nu0k5pW4rvdb+BIqMm8ToluW/eeRmxCared5dD76lS04uL4UaNgpNA==",
803 | "cpu": [
804 | "arm64"
805 | ],
806 | "dev": true,
807 | "license": "MIT",
808 | "optional": true,
809 | "os": [
810 | "linux"
811 | ]
812 | },
813 | "node_modules/@rollup/rollup-linux-arm64-musl": {
814 | "version": "4.41.1",
815 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm64-musl/-/rollup-linux-arm64-musl-4.41.1.tgz",
816 | "integrity": "sha512-XZpeGB5TKEZWzIrj7sXr+BEaSgo/ma/kCgrZgL0oo5qdB1JlTzIYQKel/RmhT6vMAvOdM2teYlAaOGJpJ9lahg==",
817 | "cpu": [
818 | "arm64"
819 | ],
820 | "dev": true,
821 | "license": "MIT",
822 | "optional": true,
823 | "os": [
824 | "linux"
825 | ]
826 | },
827 | "node_modules/@rollup/rollup-linux-loongarch64-gnu": {
828 | "version": "4.41.1",
829 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-loongarch64-gnu/-/rollup-linux-loongarch64-gnu-4.41.1.tgz",
830 | "integrity": "sha512-bkCfDJ4qzWfFRCNt5RVV4DOw6KEgFTUZi2r2RuYhGWC8WhCA8lCAJhDeAmrM/fdiAH54m0mA0Vk2FGRPyzI+tw==",
831 | "cpu": [
832 | "loong64"
833 | ],
834 | "dev": true,
835 | "license": "MIT",
836 | "optional": true,
837 | "os": [
838 | "linux"
839 | ]
840 | },
841 | "node_modules/@rollup/rollup-linux-powerpc64le-gnu": {
842 | "version": "4.41.1",
843 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-powerpc64le-gnu/-/rollup-linux-powerpc64le-gnu-4.41.1.tgz",
844 | "integrity": "sha512-3mr3Xm+gvMX+/8EKogIZSIEF0WUu0HL9di+YWlJpO8CQBnoLAEL/roTCxuLncEdgcfJcvA4UMOf+2dnjl4Ut1A==",
845 | "cpu": [
846 | "ppc64"
847 | ],
848 | "dev": true,
849 | "license": "MIT",
850 | "optional": true,
851 | "os": [
852 | "linux"
853 | ]
854 | },
855 | "node_modules/@rollup/rollup-linux-riscv64-gnu": {
856 | "version": "4.41.1",
857 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-riscv64-gnu/-/rollup-linux-riscv64-gnu-4.41.1.tgz",
858 | "integrity": "sha512-3rwCIh6MQ1LGrvKJitQjZFuQnT2wxfU+ivhNBzmxXTXPllewOF7JR1s2vMX/tWtUYFgphygxjqMl76q4aMotGw==",
859 | "cpu": [
860 | "riscv64"
861 | ],
862 | "dev": true,
863 | "license": "MIT",
864 | "optional": true,
865 | "os": [
866 | "linux"
867 | ]
868 | },
869 | "node_modules/@rollup/rollup-linux-riscv64-musl": {
870 | "version": "4.41.1",
871 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-riscv64-musl/-/rollup-linux-riscv64-musl-4.41.1.tgz",
872 | "integrity": "sha512-LdIUOb3gvfmpkgFZuccNa2uYiqtgZAz3PTzjuM5bH3nvuy9ty6RGc/Q0+HDFrHrizJGVpjnTZ1yS5TNNjFlklw==",
873 | "cpu": [
874 | "riscv64"
875 | ],
876 | "dev": true,
877 | "license": "MIT",
878 | "optional": true,
879 | "os": [
880 | "linux"
881 | ]
882 | },
883 | "node_modules/@rollup/rollup-linux-s390x-gnu": {
884 | "version": "4.41.1",
885 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-s390x-gnu/-/rollup-linux-s390x-gnu-4.41.1.tgz",
886 | "integrity": "sha512-oIE6M8WC9ma6xYqjvPhzZYk6NbobIURvP/lEbh7FWplcMO6gn7MM2yHKA1eC/GvYwzNKK/1LYgqzdkZ8YFxR8g==",
887 | "cpu": [
888 | "s390x"
889 | ],
890 | "dev": true,
891 | "license": "MIT",
892 | "optional": true,
893 | "os": [
894 | "linux"
895 | ]
896 | },
897 | "node_modules/@rollup/rollup-linux-x64-gnu": {
898 | "version": "4.41.1",
899 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-x64-gnu/-/rollup-linux-x64-gnu-4.41.1.tgz",
900 | "integrity": "sha512-cWBOvayNvA+SyeQMp79BHPK8ws6sHSsYnK5zDcsC3Hsxr1dgTABKjMnMslPq1DvZIp6uO7kIWhiGwaTdR4Og9A==",
901 | "cpu": [
902 | "x64"
903 | ],
904 | "dev": true,
905 | "license": "MIT",
906 | "optional": true,
907 | "os": [
908 | "linux"
909 | ]
910 | },
911 | "node_modules/@rollup/rollup-linux-x64-musl": {
912 | "version": "4.41.1",
913 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-x64-musl/-/rollup-linux-x64-musl-4.41.1.tgz",
914 | "integrity": "sha512-y5CbN44M+pUCdGDlZFzGGBSKCA4A/J2ZH4edTYSSxFg7ce1Xt3GtydbVKWLlzL+INfFIZAEg1ZV6hh9+QQf9YQ==",
915 | "cpu": [
916 | "x64"
917 | ],
918 | "dev": true,
919 | "license": "MIT",
920 | "optional": true,
921 | "os": [
922 | "linux"
923 | ]
924 | },
925 | "node_modules/@rollup/rollup-win32-arm64-msvc": {
926 | "version": "4.41.1",
927 | "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-arm64-msvc/-/rollup-win32-arm64-msvc-4.41.1.tgz",
928 | "integrity": "sha512-lZkCxIrjlJlMt1dLO/FbpZbzt6J/A8p4DnqzSa4PWqPEUUUnzXLeki/iyPLfV0BmHItlYgHUqJe+3KiyydmiNQ==",
929 | "cpu": [
930 | "arm64"
931 | ],
932 | "dev": true,
933 | "license": "MIT",
934 | "optional": true,
935 | "os": [
936 | "win32"
937 | ]
938 | },
939 | "node_modules/@rollup/rollup-win32-ia32-msvc": {
940 | "version": "4.41.1",
941 | "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-ia32-msvc/-/rollup-win32-ia32-msvc-4.41.1.tgz",
942 | "integrity": "sha512-+psFT9+pIh2iuGsxFYYa/LhS5MFKmuivRsx9iPJWNSGbh2XVEjk90fmpUEjCnILPEPJnikAU6SFDiEUyOv90Pg==",
943 | "cpu": [
944 | "ia32"
945 | ],
946 | "dev": true,
947 | "license": "MIT",
948 | "optional": true,
949 | "os": [
950 | "win32"
951 | ]
952 | },
953 | "node_modules/@rollup/rollup-win32-x64-msvc": {
954 | "version": "4.41.1",
955 | "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-x64-msvc/-/rollup-win32-x64-msvc-4.41.1.tgz",
956 | "integrity": "sha512-Wq2zpapRYLfi4aKxf2Xff0tN+7slj2d4R87WEzqw7ZLsVvO5zwYCIuEGSZYiK41+GlwUo1HiR+GdkLEJnCKTCw==",
957 | "cpu": [
958 | "x64"
959 | ],
960 | "dev": true,
961 | "license": "MIT",
962 | "optional": true,
963 | "os": [
964 | "win32"
965 | ]
966 | },
967 | "node_modules/@types/estree": {
968 | "version": "1.0.7",
969 | "resolved": "https://registry.npmjs.org/@types/estree/-/estree-1.0.7.tgz",
970 | "integrity": "sha512-w28IoSUCJpidD/TGviZwwMJckNESJZXFu7NBZ5YJ4mEUnNraUn9Pm8HSZm/jDF1pDWYKspWE7oVphigUPRakIQ==",
971 | "license": "MIT"
972 | },
973 | "node_modules/@types/json-schema": {
974 | "version": "7.0.15",
975 | "resolved": "https://registry.npmjs.org/@types/json-schema/-/json-schema-7.0.15.tgz",
976 | "integrity": "sha512-5+fP8P8MFNC+AyZCDxrB2pkZFPGzqQWUzpSeuuVLvm8VMcorNYavBqoFcxK8bQz4Qsbn4oUEEem4wDLfcysGHA==",
977 | "dev": true,
978 | "license": "MIT"
979 | },
980 | "node_modules/acorn": {
981 | "version": "8.14.1",
982 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.14.1.tgz",
983 | "integrity": "sha512-OvQ/2pUDKmgfCg++xsTX1wGxfTaszcHVcTctW4UJB4hibJx2HXxxO5UmVgyjMa+ZDsiaf5wWLXYpRWMmBI0QHg==",
984 | "dev": true,
985 | "license": "MIT",
986 | "bin": {
987 | "acorn": "bin/acorn"
988 | },
989 | "engines": {
990 | "node": ">=0.4.0"
991 | }
992 | },
993 | "node_modules/acorn-jsx": {
994 | "version": "5.3.2",
995 | "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.3.2.tgz",
996 | "integrity": "sha512-rq9s+JNhf0IChjtDXxllJ7g41oZk5SlXtp0LHwyA5cejwn7vKmKp4pPri6YEePv2PU65sAsegbXtIinmDFDXgQ==",
997 | "dev": true,
998 | "license": "MIT",
999 | "peerDependencies": {
1000 | "acorn": "^6.0.0 || ^7.0.0 || ^8.0.0"
1001 | }
1002 | },
1003 | "node_modules/ajv": {
1004 | "version": "6.12.6",
1005 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.6.tgz",
1006 | "integrity": "sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g==",
1007 | "dev": true,
1008 | "license": "MIT",
1009 | "dependencies": {
1010 | "fast-deep-equal": "^3.1.1",
1011 | "fast-json-stable-stringify": "^2.0.0",
1012 | "json-schema-traverse": "^0.4.1",
1013 | "uri-js": "^4.2.2"
1014 | },
1015 | "funding": {
1016 | "type": "github",
1017 | "url": "https://github.com/sponsors/epoberezkin"
1018 | }
1019 | },
1020 | "node_modules/argparse": {
1021 | "version": "2.0.1",
1022 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz",
1023 | "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==",
1024 | "dev": true,
1025 | "license": "Python-2.0"
1026 | },
1027 | "node_modules/balanced-match": {
1028 | "version": "1.0.2",
1029 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz",
1030 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==",
1031 | "dev": true,
1032 | "license": "MIT"
1033 | },
1034 | "node_modules/brace-expansion": {
1035 | "version": "1.1.11",
1036 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz",
1037 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==",
1038 | "dev": true,
1039 | "license": "MIT",
1040 | "dependencies": {
1041 | "balanced-match": "^1.0.0",
1042 | "concat-map": "0.0.1"
1043 | }
1044 | },
1045 | "node_modules/callsites": {
1046 | "version": "3.1.0",
1047 | "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz",
1048 | "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==",
1049 | "dev": true,
1050 | "license": "MIT",
1051 | "engines": {
1052 | "node": ">=6"
1053 | }
1054 | },
1055 | "node_modules/chalk": {
1056 | "version": "4.1.2",
1057 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz",
1058 | "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==",
1059 | "dev": true,
1060 | "dependencies": {
1061 | "ansi-styles": "^4.1.0",
1062 | "supports-color": "^7.1.0"
1063 | },
1064 | "engines": {
1065 | "node": ">=10"
1066 | },
1067 | "funding": {
1068 | "url": "https://github.com/chalk/chalk?sponsor=1"
1069 | }
1070 | },
1071 | "node_modules/chalk/node_modules/ansi-styles": {
1072 | "version": "4.3.0",
1073 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz",
1074 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==",
1075 | "dev": true,
1076 | "dependencies": {
1077 | "color-convert": "^2.0.1"
1078 | },
1079 | "engines": {
1080 | "node": ">=8"
1081 | },
1082 | "funding": {
1083 | "url": "https://github.com/chalk/ansi-styles?sponsor=1"
1084 | }
1085 | },
1086 | "node_modules/chalk/node_modules/color-convert": {
1087 | "version": "2.0.1",
1088 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz",
1089 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==",
1090 | "dev": true,
1091 | "dependencies": {
1092 | "color-name": "~1.1.4"
1093 | },
1094 | "engines": {
1095 | "node": ">=7.0.0"
1096 | }
1097 | },
1098 | "node_modules/chalk/node_modules/color-name": {
1099 | "version": "1.1.4",
1100 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz",
1101 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==",
1102 | "dev": true
1103 | },
1104 | "node_modules/chalk/node_modules/has-flag": {
1105 | "version": "4.0.0",
1106 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz",
1107 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==",
1108 | "dev": true,
1109 | "engines": {
1110 | "node": ">=8"
1111 | }
1112 | },
1113 | "node_modules/chalk/node_modules/supports-color": {
1114 | "version": "7.2.0",
1115 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz",
1116 | "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==",
1117 | "dev": true,
1118 | "dependencies": {
1119 | "has-flag": "^4.0.0"
1120 | },
1121 | "engines": {
1122 | "node": ">=8"
1123 | }
1124 | },
1125 | "node_modules/concat-map": {
1126 | "version": "0.0.1",
1127 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz",
1128 | "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==",
1129 | "dev": true,
1130 | "license": "MIT"
1131 | },
1132 | "node_modules/cross-spawn": {
1133 | "version": "7.0.6",
1134 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.6.tgz",
1135 | "integrity": "sha512-uV2QOWP2nWzsy2aMp8aRibhi9dlzF5Hgh5SHaB9OiTGEyDTiJJyx0uy51QXdyWbtAHNua4XJzUKca3OzKUd3vA==",
1136 | "dev": true,
1137 | "license": "MIT",
1138 | "dependencies": {
1139 | "path-key": "^3.1.0",
1140 | "shebang-command": "^2.0.0",
1141 | "which": "^2.0.1"
1142 | },
1143 | "engines": {
1144 | "node": ">= 8"
1145 | }
1146 | },
1147 | "node_modules/debug": {
1148 | "version": "4.4.1",
1149 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.4.1.tgz",
1150 | "integrity": "sha512-KcKCqiftBJcZr++7ykoDIEwSa3XWowTfNPo92BYxjXiyYEVrUQh2aLyhxBCwww+heortUFxEJYcRzosstTEBYQ==",
1151 | "dev": true,
1152 | "license": "MIT",
1153 | "dependencies": {
1154 | "ms": "^2.1.3"
1155 | },
1156 | "engines": {
1157 | "node": ">=6.0"
1158 | },
1159 | "peerDependenciesMeta": {
1160 | "supports-color": {
1161 | "optional": true
1162 | }
1163 | }
1164 | },
1165 | "node_modules/deep-is": {
1166 | "version": "0.1.4",
1167 | "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.4.tgz",
1168 | "integrity": "sha512-oIPzksmTg4/MriiaYGO+okXDT7ztn/w3Eptv/+gSIdMdKsJo0u4CfYNFJPy+4SKMuCqGw2wxnA+URMg3t8a/bQ==",
1169 | "dev": true
1170 | },
1171 | "node_modules/es-module-lexer": {
1172 | "version": "1.7.0",
1173 | "resolved": "https://registry.npmjs.org/es-module-lexer/-/es-module-lexer-1.7.0.tgz",
1174 | "integrity": "sha512-jEQoCwk8hyb2AZziIOLhDqpm5+2ww5uIE6lkO/6jcOCusfk6LhMHpXXfBLXTZ7Ydyt0j4VoUQv6uGNYbdW+kBA==",
1175 | "dev": true,
1176 | "license": "MIT"
1177 | },
1178 | "node_modules/esbuild": {
1179 | "version": "0.25.5",
1180 | "resolved": "https://registry.npmjs.org/esbuild/-/esbuild-0.25.5.tgz",
1181 | "integrity": "sha512-P8OtKZRv/5J5hhz0cUAdu/cLuPIKXpQl1R9pZtvmHWQvrAUVd0UNIPT4IB4W3rNOqVO0rlqHmCIbSwxh/c9yUQ==",
1182 | "dev": true,
1183 | "hasInstallScript": true,
1184 | "license": "MIT",
1185 | "bin": {
1186 | "esbuild": "bin/esbuild"
1187 | },
1188 | "engines": {
1189 | "node": ">=18"
1190 | },
1191 | "optionalDependencies": {
1192 | "@esbuild/aix-ppc64": "0.25.5",
1193 | "@esbuild/android-arm": "0.25.5",
1194 | "@esbuild/android-arm64": "0.25.5",
1195 | "@esbuild/android-x64": "0.25.5",
1196 | "@esbuild/darwin-arm64": "0.25.5",
1197 | "@esbuild/darwin-x64": "0.25.5",
1198 | "@esbuild/freebsd-arm64": "0.25.5",
1199 | "@esbuild/freebsd-x64": "0.25.5",
1200 | "@esbuild/linux-arm": "0.25.5",
1201 | "@esbuild/linux-arm64": "0.25.5",
1202 | "@esbuild/linux-ia32": "0.25.5",
1203 | "@esbuild/linux-loong64": "0.25.5",
1204 | "@esbuild/linux-mips64el": "0.25.5",
1205 | "@esbuild/linux-ppc64": "0.25.5",
1206 | "@esbuild/linux-riscv64": "0.25.5",
1207 | "@esbuild/linux-s390x": "0.25.5",
1208 | "@esbuild/linux-x64": "0.25.5",
1209 | "@esbuild/netbsd-arm64": "0.25.5",
1210 | "@esbuild/netbsd-x64": "0.25.5",
1211 | "@esbuild/openbsd-arm64": "0.25.5",
1212 | "@esbuild/openbsd-x64": "0.25.5",
1213 | "@esbuild/sunos-x64": "0.25.5",
1214 | "@esbuild/win32-arm64": "0.25.5",
1215 | "@esbuild/win32-ia32": "0.25.5",
1216 | "@esbuild/win32-x64": "0.25.5"
1217 | }
1218 | },
1219 | "node_modules/escape-string-regexp": {
1220 | "version": "4.0.0",
1221 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz",
1222 | "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==",
1223 | "dev": true,
1224 | "engines": {
1225 | "node": ">=10"
1226 | },
1227 | "funding": {
1228 | "url": "https://github.com/sponsors/sindresorhus"
1229 | }
1230 | },
1231 | "node_modules/eslint": {
1232 | "version": "9.27.0",
1233 | "resolved": "https://registry.npmjs.org/eslint/-/eslint-9.27.0.tgz",
1234 | "integrity": "sha512-ixRawFQuMB9DZ7fjU3iGGganFDp3+45bPOdaRurcFHSXO1e/sYwUX/FtQZpLZJR6SjMoJH8hR2pPEAfDyCoU2Q==",
1235 | "dev": true,
1236 | "license": "MIT",
1237 | "dependencies": {
1238 | "@eslint-community/eslint-utils": "^4.2.0",
1239 | "@eslint-community/regexpp": "^4.12.1",
1240 | "@eslint/config-array": "^0.20.0",
1241 | "@eslint/config-helpers": "^0.2.1",
1242 | "@eslint/core": "^0.14.0",
1243 | "@eslint/eslintrc": "^3.3.1",
1244 | "@eslint/js": "9.27.0",
1245 | "@eslint/plugin-kit": "^0.3.1",
1246 | "@humanfs/node": "^0.16.6",
1247 | "@humanwhocodes/module-importer": "^1.0.1",
1248 | "@humanwhocodes/retry": "^0.4.2",
1249 | "@types/estree": "^1.0.6",
1250 | "@types/json-schema": "^7.0.15",
1251 | "ajv": "^6.12.4",
1252 | "chalk": "^4.0.0",
1253 | "cross-spawn": "^7.0.6",
1254 | "debug": "^4.3.2",
1255 | "escape-string-regexp": "^4.0.0",
1256 | "eslint-scope": "^8.3.0",
1257 | "eslint-visitor-keys": "^4.2.0",
1258 | "espree": "^10.3.0",
1259 | "esquery": "^1.5.0",
1260 | "esutils": "^2.0.2",
1261 | "fast-deep-equal": "^3.1.3",
1262 | "file-entry-cache": "^8.0.0",
1263 | "find-up": "^5.0.0",
1264 | "glob-parent": "^6.0.2",
1265 | "ignore": "^5.2.0",
1266 | "imurmurhash": "^0.1.4",
1267 | "is-glob": "^4.0.0",
1268 | "json-stable-stringify-without-jsonify": "^1.0.1",
1269 | "lodash.merge": "^4.6.2",
1270 | "minimatch": "^3.1.2",
1271 | "natural-compare": "^1.4.0",
1272 | "optionator": "^0.9.3"
1273 | },
1274 | "bin": {
1275 | "eslint": "bin/eslint.js"
1276 | },
1277 | "engines": {
1278 | "node": "^18.18.0 || ^20.9.0 || >=21.1.0"
1279 | },
1280 | "funding": {
1281 | "url": "https://eslint.org/donate"
1282 | },
1283 | "peerDependencies": {
1284 | "jiti": "*"
1285 | },
1286 | "peerDependenciesMeta": {
1287 | "jiti": {
1288 | "optional": true
1289 | }
1290 | }
1291 | },
1292 | "node_modules/eslint-scope": {
1293 | "version": "8.3.0",
1294 | "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-8.3.0.tgz",
1295 | "integrity": "sha512-pUNxi75F8MJ/GdeKtVLSbYg4ZI34J6C0C7sbL4YOp2exGwen7ZsuBqKzUhXd0qMQ362yET3z+uPwKeg/0C2XCQ==",
1296 | "dev": true,
1297 | "license": "BSD-2-Clause",
1298 | "dependencies": {
1299 | "esrecurse": "^4.3.0",
1300 | "estraverse": "^5.2.0"
1301 | },
1302 | "engines": {
1303 | "node": "^18.18.0 || ^20.9.0 || >=21.1.0"
1304 | },
1305 | "funding": {
1306 | "url": "https://opencollective.com/eslint"
1307 | }
1308 | },
1309 | "node_modules/eslint-visitor-keys": {
1310 | "version": "3.4.3",
1311 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-3.4.3.tgz",
1312 | "integrity": "sha512-wpc+LXeiyiisxPlEkUzU6svyS1frIO3Mgxj1fdy7Pm8Ygzguax2N3Fa/D/ag1WqbOprdI+uY6wMUl8/a2G+iag==",
1313 | "dev": true,
1314 | "engines": {
1315 | "node": "^12.22.0 || ^14.17.0 || >=16.0.0"
1316 | },
1317 | "funding": {
1318 | "url": "https://opencollective.com/eslint"
1319 | }
1320 | },
1321 | "node_modules/eslint/node_modules/eslint-visitor-keys": {
1322 | "version": "4.2.0",
1323 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-4.2.0.tgz",
1324 | "integrity": "sha512-UyLnSehNt62FFhSwjZlHmeokpRK59rcz29j+F1/aDgbkbRTk7wIc9XzdoasMUbRNKDM0qQt/+BJ4BrpFeABemw==",
1325 | "dev": true,
1326 | "license": "Apache-2.0",
1327 | "engines": {
1328 | "node": "^18.18.0 || ^20.9.0 || >=21.1.0"
1329 | },
1330 | "funding": {
1331 | "url": "https://opencollective.com/eslint"
1332 | }
1333 | },
1334 | "node_modules/espree": {
1335 | "version": "10.3.0",
1336 | "resolved": "https://registry.npmjs.org/espree/-/espree-10.3.0.tgz",
1337 | "integrity": "sha512-0QYC8b24HWY8zjRnDTL6RiHfDbAWn63qb4LMj1Z4b076A4une81+z03Kg7l7mn/48PUTqoLptSXez8oknU8Clg==",
1338 | "dev": true,
1339 | "license": "BSD-2-Clause",
1340 | "dependencies": {
1341 | "acorn": "^8.14.0",
1342 | "acorn-jsx": "^5.3.2",
1343 | "eslint-visitor-keys": "^4.2.0"
1344 | },
1345 | "engines": {
1346 | "node": "^18.18.0 || ^20.9.0 || >=21.1.0"
1347 | },
1348 | "funding": {
1349 | "url": "https://opencollective.com/eslint"
1350 | }
1351 | },
1352 | "node_modules/espree/node_modules/eslint-visitor-keys": {
1353 | "version": "4.2.0",
1354 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-4.2.0.tgz",
1355 | "integrity": "sha512-UyLnSehNt62FFhSwjZlHmeokpRK59rcz29j+F1/aDgbkbRTk7wIc9XzdoasMUbRNKDM0qQt/+BJ4BrpFeABemw==",
1356 | "dev": true,
1357 | "license": "Apache-2.0",
1358 | "engines": {
1359 | "node": "^18.18.0 || ^20.9.0 || >=21.1.0"
1360 | },
1361 | "funding": {
1362 | "url": "https://opencollective.com/eslint"
1363 | }
1364 | },
1365 | "node_modules/esquery": {
1366 | "version": "1.5.0",
1367 | "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.5.0.tgz",
1368 | "integrity": "sha512-YQLXUplAwJgCydQ78IMJywZCceoqk1oH01OERdSAJc/7U2AylwjhSCLDEtqwg811idIS/9fIU5GjG73IgjKMVg==",
1369 | "dev": true,
1370 | "dependencies": {
1371 | "estraverse": "^5.1.0"
1372 | },
1373 | "engines": {
1374 | "node": ">=0.10"
1375 | }
1376 | },
1377 | "node_modules/esrecurse": {
1378 | "version": "4.3.0",
1379 | "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.3.0.tgz",
1380 | "integrity": "sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag==",
1381 | "dev": true,
1382 | "license": "BSD-2-Clause",
1383 | "dependencies": {
1384 | "estraverse": "^5.2.0"
1385 | },
1386 | "engines": {
1387 | "node": ">=4.0"
1388 | }
1389 | },
1390 | "node_modules/estraverse": {
1391 | "version": "5.3.0",
1392 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.3.0.tgz",
1393 | "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==",
1394 | "dev": true,
1395 | "engines": {
1396 | "node": ">=4.0"
1397 | }
1398 | },
1399 | "node_modules/estree-walker": {
1400 | "version": "2.0.2",
1401 | "resolved": "https://registry.npmjs.org/estree-walker/-/estree-walker-2.0.2.tgz",
1402 | "integrity": "sha512-Rfkk/Mp/DL7JVje3u18FxFujQlTNR2q6QfMSMB7AvCBx91NGj/ba3kCfza0f6dVDbw7YlRf/nDrn7pQrCCyQ/w=="
1403 | },
1404 | "node_modules/esutils": {
1405 | "version": "2.0.3",
1406 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz",
1407 | "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==",
1408 | "dev": true,
1409 | "license": "BSD-2-Clause",
1410 | "engines": {
1411 | "node": ">=0.10.0"
1412 | }
1413 | },
1414 | "node_modules/fast-deep-equal": {
1415 | "version": "3.1.3",
1416 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz",
1417 | "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==",
1418 | "dev": true,
1419 | "license": "MIT"
1420 | },
1421 | "node_modules/fast-json-stable-stringify": {
1422 | "version": "2.1.0",
1423 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz",
1424 | "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==",
1425 | "dev": true,
1426 | "license": "MIT"
1427 | },
1428 | "node_modules/fast-levenshtein": {
1429 | "version": "2.0.6",
1430 | "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz",
1431 | "integrity": "sha512-DCXu6Ifhqcks7TZKY3Hxp3y6qphY5SJZmrWMDrKcERSOXWQdMhU9Ig/PYrzyw/ul9jOIyh0N4M0tbC5hodg8dw==",
1432 | "dev": true
1433 | },
1434 | "node_modules/file-entry-cache": {
1435 | "version": "8.0.0",
1436 | "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-8.0.0.tgz",
1437 | "integrity": "sha512-XXTUwCvisa5oacNGRP9SfNtYBNAMi+RPwBFmblZEF7N7swHYQS6/Zfk7SRwx4D5j3CH211YNRco1DEMNVfZCnQ==",
1438 | "dev": true,
1439 | "license": "MIT",
1440 | "dependencies": {
1441 | "flat-cache": "^4.0.0"
1442 | },
1443 | "engines": {
1444 | "node": ">=16.0.0"
1445 | }
1446 | },
1447 | "node_modules/find-up": {
1448 | "version": "5.0.0",
1449 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-5.0.0.tgz",
1450 | "integrity": "sha512-78/PXT1wlLLDgTzDs7sjq9hzz0vXD+zn+7wypEe4fXQxCmdmqfGsEPQxmiCSQI3ajFV91bVSsvNtrJRiW6nGng==",
1451 | "dev": true,
1452 | "dependencies": {
1453 | "locate-path": "^6.0.0",
1454 | "path-exists": "^4.0.0"
1455 | },
1456 | "engines": {
1457 | "node": ">=10"
1458 | },
1459 | "funding": {
1460 | "url": "https://github.com/sponsors/sindresorhus"
1461 | }
1462 | },
1463 | "node_modules/flat-cache": {
1464 | "version": "4.0.1",
1465 | "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-4.0.1.tgz",
1466 | "integrity": "sha512-f7ccFPK3SXFHpx15UIGyRJ/FJQctuKZ0zVuN3frBo4HnK3cay9VEW0R6yPYFHC0AgqhukPzKjq22t5DmAyqGyw==",
1467 | "dev": true,
1468 | "license": "MIT",
1469 | "dependencies": {
1470 | "flatted": "^3.2.9",
1471 | "keyv": "^4.5.4"
1472 | },
1473 | "engines": {
1474 | "node": ">=16"
1475 | }
1476 | },
1477 | "node_modules/flatted": {
1478 | "version": "3.3.2",
1479 | "resolved": "https://registry.npmjs.org/flatted/-/flatted-3.3.2.tgz",
1480 | "integrity": "sha512-AiwGJM8YcNOaobumgtng+6NHuOqC3A7MixFeDafM3X9cIUM+xUXoS5Vfgf+OihAYe20fxqNM9yPBXJzRtZ/4eA==",
1481 | "dev": true,
1482 | "license": "ISC"
1483 | },
1484 | "node_modules/fsevents": {
1485 | "version": "2.3.2",
1486 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.2.tgz",
1487 | "integrity": "sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==",
1488 | "dev": true,
1489 | "hasInstallScript": true,
1490 | "optional": true,
1491 | "os": [
1492 | "darwin"
1493 | ],
1494 | "engines": {
1495 | "node": "^8.16.0 || ^10.6.0 || >=11.0.0"
1496 | }
1497 | },
1498 | "node_modules/get-tsconfig": {
1499 | "version": "4.10.1",
1500 | "resolved": "https://registry.npmjs.org/get-tsconfig/-/get-tsconfig-4.10.1.tgz",
1501 | "integrity": "sha512-auHyJ4AgMz7vgS8Hp3N6HXSmlMdUyhSUrfBF16w153rxtLIEOE+HGqaBppczZvnHLqQJfiHotCYpNhl0lUROFQ==",
1502 | "dev": true,
1503 | "license": "MIT",
1504 | "dependencies": {
1505 | "resolve-pkg-maps": "^1.0.0"
1506 | },
1507 | "funding": {
1508 | "url": "https://github.com/privatenumber/get-tsconfig?sponsor=1"
1509 | }
1510 | },
1511 | "node_modules/glob-parent": {
1512 | "version": "6.0.2",
1513 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-6.0.2.tgz",
1514 | "integrity": "sha512-XxwI8EOhVQgWp6iDL+3b0r86f4d6AX6zSU55HfB4ydCEuXLXc5FcYeOu+nnGftS4TEju/11rt4KJPTMgbfmv4A==",
1515 | "dev": true,
1516 | "dependencies": {
1517 | "is-glob": "^4.0.3"
1518 | },
1519 | "engines": {
1520 | "node": ">=10.13.0"
1521 | }
1522 | },
1523 | "node_modules/globals": {
1524 | "version": "16.2.0",
1525 | "resolved": "https://registry.npmjs.org/globals/-/globals-16.2.0.tgz",
1526 | "integrity": "sha512-O+7l9tPdHCU320IigZZPj5zmRCFG9xHmx9cU8FqU2Rp+JN714seHV+2S9+JslCpY4gJwU2vOGox0wzgae/MCEg==",
1527 | "dev": true,
1528 | "license": "MIT",
1529 | "engines": {
1530 | "node": ">=18"
1531 | },
1532 | "funding": {
1533 | "url": "https://github.com/sponsors/sindresorhus"
1534 | }
1535 | },
1536 | "node_modules/ignore": {
1537 | "version": "5.3.2",
1538 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-5.3.2.tgz",
1539 | "integrity": "sha512-hsBTNUqQTDwkWtcdYI2i06Y/nUBEsNEDJKjWdigLvegy8kDuJAS8uRlpkkcQpyEXL0Z/pjDy5HBmMjRCJ2gq+g==",
1540 | "dev": true,
1541 | "license": "MIT",
1542 | "engines": {
1543 | "node": ">= 4"
1544 | }
1545 | },
1546 | "node_modules/import-fresh": {
1547 | "version": "3.3.1",
1548 | "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.3.1.tgz",
1549 | "integrity": "sha512-TR3KfrTZTYLPB6jUjfx6MF9WcWrHL9su5TObK4ZkYgBdWKPOFoSoQIdEuTuR82pmtxH2spWG9h6etwfr1pLBqQ==",
1550 | "dev": true,
1551 | "license": "MIT",
1552 | "dependencies": {
1553 | "parent-module": "^1.0.0",
1554 | "resolve-from": "^4.0.0"
1555 | },
1556 | "engines": {
1557 | "node": ">=6"
1558 | },
1559 | "funding": {
1560 | "url": "https://github.com/sponsors/sindresorhus"
1561 | }
1562 | },
1563 | "node_modules/imurmurhash": {
1564 | "version": "0.1.4",
1565 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz",
1566 | "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=",
1567 | "dev": true,
1568 | "engines": {
1569 | "node": ">=0.8.19"
1570 | }
1571 | },
1572 | "node_modules/is-extglob": {
1573 | "version": "2.1.1",
1574 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz",
1575 | "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=",
1576 | "dev": true,
1577 | "engines": {
1578 | "node": ">=0.10.0"
1579 | }
1580 | },
1581 | "node_modules/is-glob": {
1582 | "version": "4.0.3",
1583 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz",
1584 | "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==",
1585 | "dev": true,
1586 | "dependencies": {
1587 | "is-extglob": "^2.1.1"
1588 | },
1589 | "engines": {
1590 | "node": ">=0.10.0"
1591 | }
1592 | },
1593 | "node_modules/isexe": {
1594 | "version": "2.0.0",
1595 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz",
1596 | "integrity": "sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw==",
1597 | "dev": true,
1598 | "license": "ISC"
1599 | },
1600 | "node_modules/js-yaml": {
1601 | "version": "4.1.0",
1602 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-4.1.0.tgz",
1603 | "integrity": "sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA==",
1604 | "dev": true,
1605 | "license": "MIT",
1606 | "dependencies": {
1607 | "argparse": "^2.0.1"
1608 | },
1609 | "bin": {
1610 | "js-yaml": "bin/js-yaml.js"
1611 | }
1612 | },
1613 | "node_modules/json-buffer": {
1614 | "version": "3.0.1",
1615 | "resolved": "https://registry.npmjs.org/json-buffer/-/json-buffer-3.0.1.tgz",
1616 | "integrity": "sha512-4bV5BfR2mqfQTJm+V5tPPdf+ZpuhiIvTuAB5g8kcrXOZpTT/QwwVRWBywX1ozr6lEuPdbHxwaJlm9G6mI2sfSQ==",
1617 | "dev": true,
1618 | "license": "MIT"
1619 | },
1620 | "node_modules/json-schema-traverse": {
1621 | "version": "0.4.1",
1622 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz",
1623 | "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==",
1624 | "dev": true,
1625 | "license": "MIT"
1626 | },
1627 | "node_modules/json-stable-stringify-without-jsonify": {
1628 | "version": "1.0.1",
1629 | "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz",
1630 | "integrity": "sha1-nbe1lJatPzz+8wp1FC0tkwrXJlE=",
1631 | "dev": true
1632 | },
1633 | "node_modules/keyv": {
1634 | "version": "4.5.4",
1635 | "resolved": "https://registry.npmjs.org/keyv/-/keyv-4.5.4.tgz",
1636 | "integrity": "sha512-oxVHkHR/EJf2CNXnWxRLW6mg7JyCCUcG0DtEGmL2ctUo1PNTin1PUil+r/+4r5MpVgC/fn1kjsx7mjSujKqIpw==",
1637 | "dev": true,
1638 | "license": "MIT",
1639 | "dependencies": {
1640 | "json-buffer": "3.0.1"
1641 | }
1642 | },
1643 | "node_modules/levn": {
1644 | "version": "0.4.1",
1645 | "resolved": "https://registry.npmjs.org/levn/-/levn-0.4.1.tgz",
1646 | "integrity": "sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ==",
1647 | "dev": true,
1648 | "dependencies": {
1649 | "prelude-ls": "^1.2.1",
1650 | "type-check": "~0.4.0"
1651 | },
1652 | "engines": {
1653 | "node": ">= 0.8.0"
1654 | }
1655 | },
1656 | "node_modules/locate-path": {
1657 | "version": "6.0.0",
1658 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-6.0.0.tgz",
1659 | "integrity": "sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw==",
1660 | "dev": true,
1661 | "dependencies": {
1662 | "p-locate": "^5.0.0"
1663 | },
1664 | "engines": {
1665 | "node": ">=10"
1666 | },
1667 | "funding": {
1668 | "url": "https://github.com/sponsors/sindresorhus"
1669 | }
1670 | },
1671 | "node_modules/lodash.merge": {
1672 | "version": "4.6.2",
1673 | "resolved": "https://registry.npmjs.org/lodash.merge/-/lodash.merge-4.6.2.tgz",
1674 | "integrity": "sha512-0KpjqXRVvrYyCsX1swR/XTK0va6VQkQM6MNo7PqW77ByjAhoARA8EfrP1N4+KlKj8YS0ZUCtRT/YUuhyYDujIQ==",
1675 | "dev": true
1676 | },
1677 | "node_modules/minimatch": {
1678 | "version": "3.1.2",
1679 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz",
1680 | "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==",
1681 | "dev": true,
1682 | "license": "ISC",
1683 | "dependencies": {
1684 | "brace-expansion": "^1.1.7"
1685 | },
1686 | "engines": {
1687 | "node": "*"
1688 | }
1689 | },
1690 | "node_modules/ms": {
1691 | "version": "2.1.3",
1692 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz",
1693 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==",
1694 | "dev": true,
1695 | "license": "MIT"
1696 | },
1697 | "node_modules/natural-compare": {
1698 | "version": "1.4.0",
1699 | "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz",
1700 | "integrity": "sha1-Sr6/7tdUHywnrPspvbvRXI1bpPc=",
1701 | "dev": true
1702 | },
1703 | "node_modules/optionator": {
1704 | "version": "0.9.3",
1705 | "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.9.3.tgz",
1706 | "integrity": "sha512-JjCoypp+jKn1ttEFExxhetCKeJt9zhAgAve5FXHixTvFDW/5aEktX9bufBKLRRMdU7bNtpLfcGu94B3cdEJgjg==",
1707 | "dev": true,
1708 | "dependencies": {
1709 | "@aashutoshrathi/word-wrap": "^1.2.3",
1710 | "deep-is": "^0.1.3",
1711 | "fast-levenshtein": "^2.0.6",
1712 | "levn": "^0.4.1",
1713 | "prelude-ls": "^1.2.1",
1714 | "type-check": "^0.4.0"
1715 | },
1716 | "engines": {
1717 | "node": ">= 0.8.0"
1718 | }
1719 | },
1720 | "node_modules/p-limit": {
1721 | "version": "3.1.0",
1722 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-3.1.0.tgz",
1723 | "integrity": "sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ==",
1724 | "dev": true,
1725 | "dependencies": {
1726 | "yocto-queue": "^0.1.0"
1727 | },
1728 | "engines": {
1729 | "node": ">=10"
1730 | },
1731 | "funding": {
1732 | "url": "https://github.com/sponsors/sindresorhus"
1733 | }
1734 | },
1735 | "node_modules/p-locate": {
1736 | "version": "5.0.0",
1737 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-5.0.0.tgz",
1738 | "integrity": "sha512-LaNjtRWUBY++zB5nE/NwcaoMylSPk+S+ZHNB1TzdbMJMny6dynpAGt7X/tl/QYq3TIeE6nxHppbo2LGymrG5Pw==",
1739 | "dev": true,
1740 | "dependencies": {
1741 | "p-limit": "^3.0.2"
1742 | },
1743 | "engines": {
1744 | "node": ">=10"
1745 | },
1746 | "funding": {
1747 | "url": "https://github.com/sponsors/sindresorhus"
1748 | }
1749 | },
1750 | "node_modules/parent-module": {
1751 | "version": "1.0.1",
1752 | "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz",
1753 | "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==",
1754 | "dev": true,
1755 | "license": "MIT",
1756 | "dependencies": {
1757 | "callsites": "^3.0.0"
1758 | },
1759 | "engines": {
1760 | "node": ">=6"
1761 | }
1762 | },
1763 | "node_modules/path-exists": {
1764 | "version": "4.0.0",
1765 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz",
1766 | "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==",
1767 | "dev": true,
1768 | "engines": {
1769 | "node": ">=8"
1770 | }
1771 | },
1772 | "node_modules/path-key": {
1773 | "version": "3.1.1",
1774 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz",
1775 | "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==",
1776 | "dev": true,
1777 | "license": "MIT",
1778 | "engines": {
1779 | "node": ">=8"
1780 | }
1781 | },
1782 | "node_modules/pathe": {
1783 | "version": "2.0.3",
1784 | "resolved": "https://registry.npmjs.org/pathe/-/pathe-2.0.3.tgz",
1785 | "integrity": "sha512-WUjGcAqP1gQacoQe+OBJsFA7Ld4DyXuUIjZ5cc75cLHvJ7dtNsTugphxIADwspS+AraAUePCKrSVtPLFj/F88w==",
1786 | "dev": true,
1787 | "license": "MIT"
1788 | },
1789 | "node_modules/picomatch": {
1790 | "version": "4.0.2",
1791 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-4.0.2.tgz",
1792 | "integrity": "sha512-M7BAV6Rlcy5u+m6oPhAPFgJTzAioX/6B0DxyvDlo9l8+T3nLKbrczg2WLUyzd45L8RqfUMyGPzekbMvX2Ldkwg==",
1793 | "license": "MIT",
1794 | "engines": {
1795 | "node": ">=12"
1796 | },
1797 | "funding": {
1798 | "url": "https://github.com/sponsors/jonschlinkert"
1799 | }
1800 | },
1801 | "node_modules/prelude-ls": {
1802 | "version": "1.2.1",
1803 | "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.2.1.tgz",
1804 | "integrity": "sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g==",
1805 | "dev": true,
1806 | "engines": {
1807 | "node": ">= 0.8.0"
1808 | }
1809 | },
1810 | "node_modules/punycode": {
1811 | "version": "2.3.1",
1812 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.3.1.tgz",
1813 | "integrity": "sha512-vYt7UD1U9Wg6138shLtLOvdAu+8DsC/ilFtEVHcH+wydcSpNE20AfSOduf6MkRFahL5FY7X1oU7nKVZFtfq8Fg==",
1814 | "dev": true,
1815 | "license": "MIT",
1816 | "engines": {
1817 | "node": ">=6"
1818 | }
1819 | },
1820 | "node_modules/resolve-from": {
1821 | "version": "4.0.0",
1822 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz",
1823 | "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==",
1824 | "dev": true,
1825 | "license": "MIT",
1826 | "engines": {
1827 | "node": ">=4"
1828 | }
1829 | },
1830 | "node_modules/resolve-pkg-maps": {
1831 | "version": "1.0.0",
1832 | "resolved": "https://registry.npmjs.org/resolve-pkg-maps/-/resolve-pkg-maps-1.0.0.tgz",
1833 | "integrity": "sha512-seS2Tj26TBVOC2NIc2rOe2y2ZO7efxITtLZcGSOnHHNOQ7CkiUBfw0Iw2ck6xkIhPwLhKNLS8BO+hEpngQlqzw==",
1834 | "dev": true,
1835 | "license": "MIT",
1836 | "funding": {
1837 | "url": "https://github.com/privatenumber/resolve-pkg-maps?sponsor=1"
1838 | }
1839 | },
1840 | "node_modules/rollup": {
1841 | "version": "4.41.1",
1842 | "resolved": "https://registry.npmjs.org/rollup/-/rollup-4.41.1.tgz",
1843 | "integrity": "sha512-cPmwD3FnFv8rKMBc1MxWCwVQFxwf1JEmSX3iQXrRVVG15zerAIXRjMFVWnd5Q5QvgKF7Aj+5ykXFhUl+QGnyOw==",
1844 | "devOptional": true,
1845 | "license": "MIT",
1846 | "dependencies": {
1847 | "@types/estree": "1.0.7"
1848 | },
1849 | "bin": {
1850 | "rollup": "dist/bin/rollup"
1851 | },
1852 | "engines": {
1853 | "node": ">=18.0.0",
1854 | "npm": ">=8.0.0"
1855 | },
1856 | "optionalDependencies": {
1857 | "@rollup/rollup-android-arm-eabi": "4.41.1",
1858 | "@rollup/rollup-android-arm64": "4.41.1",
1859 | "@rollup/rollup-darwin-arm64": "4.41.1",
1860 | "@rollup/rollup-darwin-x64": "4.41.1",
1861 | "@rollup/rollup-freebsd-arm64": "4.41.1",
1862 | "@rollup/rollup-freebsd-x64": "4.41.1",
1863 | "@rollup/rollup-linux-arm-gnueabihf": "4.41.1",
1864 | "@rollup/rollup-linux-arm-musleabihf": "4.41.1",
1865 | "@rollup/rollup-linux-arm64-gnu": "4.41.1",
1866 | "@rollup/rollup-linux-arm64-musl": "4.41.1",
1867 | "@rollup/rollup-linux-loongarch64-gnu": "4.41.1",
1868 | "@rollup/rollup-linux-powerpc64le-gnu": "4.41.1",
1869 | "@rollup/rollup-linux-riscv64-gnu": "4.41.1",
1870 | "@rollup/rollup-linux-riscv64-musl": "4.41.1",
1871 | "@rollup/rollup-linux-s390x-gnu": "4.41.1",
1872 | "@rollup/rollup-linux-x64-gnu": "4.41.1",
1873 | "@rollup/rollup-linux-x64-musl": "4.41.1",
1874 | "@rollup/rollup-win32-arm64-msvc": "4.41.1",
1875 | "@rollup/rollup-win32-ia32-msvc": "4.41.1",
1876 | "@rollup/rollup-win32-x64-msvc": "4.41.1",
1877 | "fsevents": "~2.3.2"
1878 | }
1879 | },
1880 | "node_modules/rollup-plugin-esbuild": {
1881 | "version": "6.2.1",
1882 | "resolved": "https://registry.npmjs.org/rollup-plugin-esbuild/-/rollup-plugin-esbuild-6.2.1.tgz",
1883 | "integrity": "sha512-jTNOMGoMRhs0JuueJrJqbW8tOwxumaWYq+V5i+PD+8ecSCVkuX27tGW7BXqDgoULQ55rO7IdNxPcnsWtshz3AA==",
1884 | "dev": true,
1885 | "license": "MIT",
1886 | "dependencies": {
1887 | "debug": "^4.4.0",
1888 | "es-module-lexer": "^1.6.0",
1889 | "get-tsconfig": "^4.10.0",
1890 | "unplugin-utils": "^0.2.4"
1891 | },
1892 | "engines": {
1893 | "node": ">=14.18.0"
1894 | },
1895 | "peerDependencies": {
1896 | "esbuild": ">=0.18.0",
1897 | "rollup": "^1.20.0 || ^2.0.0 || ^3.0.0 || ^4.0.0"
1898 | }
1899 | },
1900 | "node_modules/shebang-command": {
1901 | "version": "2.0.0",
1902 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz",
1903 | "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==",
1904 | "dev": true,
1905 | "license": "MIT",
1906 | "dependencies": {
1907 | "shebang-regex": "^3.0.0"
1908 | },
1909 | "engines": {
1910 | "node": ">=8"
1911 | }
1912 | },
1913 | "node_modules/shebang-regex": {
1914 | "version": "3.0.0",
1915 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz",
1916 | "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==",
1917 | "dev": true,
1918 | "license": "MIT",
1919 | "engines": {
1920 | "node": ">=8"
1921 | }
1922 | },
1923 | "node_modules/strip-json-comments": {
1924 | "version": "3.1.1",
1925 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz",
1926 | "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==",
1927 | "dev": true,
1928 | "license": "MIT",
1929 | "engines": {
1930 | "node": ">=8"
1931 | },
1932 | "funding": {
1933 | "url": "https://github.com/sponsors/sindresorhus"
1934 | }
1935 | },
1936 | "node_modules/type-check": {
1937 | "version": "0.4.0",
1938 | "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.4.0.tgz",
1939 | "integrity": "sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew==",
1940 | "dev": true,
1941 | "dependencies": {
1942 | "prelude-ls": "^1.2.1"
1943 | },
1944 | "engines": {
1945 | "node": ">= 0.8.0"
1946 | }
1947 | },
1948 | "node_modules/unplugin-utils": {
1949 | "version": "0.2.4",
1950 | "resolved": "https://registry.npmjs.org/unplugin-utils/-/unplugin-utils-0.2.4.tgz",
1951 | "integrity": "sha512-8U/MtpkPkkk3Atewj1+RcKIjb5WBimZ/WSLhhR3w6SsIj8XJuKTacSP8g+2JhfSGw0Cb125Y+2zA/IzJZDVbhA==",
1952 | "dev": true,
1953 | "license": "MIT",
1954 | "dependencies": {
1955 | "pathe": "^2.0.2",
1956 | "picomatch": "^4.0.2"
1957 | },
1958 | "engines": {
1959 | "node": ">=18.12.0"
1960 | },
1961 | "funding": {
1962 | "url": "https://github.com/sponsors/sxzz"
1963 | }
1964 | },
1965 | "node_modules/uri-js": {
1966 | "version": "4.4.1",
1967 | "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.4.1.tgz",
1968 | "integrity": "sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg==",
1969 | "dev": true,
1970 | "license": "BSD-2-Clause",
1971 | "dependencies": {
1972 | "punycode": "^2.1.0"
1973 | }
1974 | },
1975 | "node_modules/which": {
1976 | "version": "2.0.2",
1977 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz",
1978 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==",
1979 | "dev": true,
1980 | "license": "ISC",
1981 | "dependencies": {
1982 | "isexe": "^2.0.0"
1983 | },
1984 | "bin": {
1985 | "node-which": "bin/node-which"
1986 | },
1987 | "engines": {
1988 | "node": ">= 8"
1989 | }
1990 | },
1991 | "node_modules/yocto-queue": {
1992 | "version": "0.1.0",
1993 | "resolved": "https://registry.npmjs.org/yocto-queue/-/yocto-queue-0.1.0.tgz",
1994 | "integrity": "sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q==",
1995 | "dev": true,
1996 | "engines": {
1997 | "node": ">=10"
1998 | },
1999 | "funding": {
2000 | "url": "https://github.com/sponsors/sindresorhus"
2001 | }
2002 | }
2003 | },
2004 | "dependencies": {
2005 | "@aashutoshrathi/word-wrap": {
2006 | "version": "1.2.6",
2007 | "resolved": "https://registry.npmjs.org/@aashutoshrathi/word-wrap/-/word-wrap-1.2.6.tgz",
2008 | "integrity": "sha512-1Yjs2SvM8TflER/OD3cOjhWWOZb58A2t7wpE2S9XfBYTiIl+XFhQG2bjy4Pu1I+EAlCNUzRDYDdFwFYUKvXcIA==",
2009 | "dev": true
2010 | },
2011 | "@esbuild/aix-ppc64": {
2012 | "version": "0.25.5",
2013 | "resolved": "https://registry.npmjs.org/@esbuild/aix-ppc64/-/aix-ppc64-0.25.5.tgz",
2014 | "integrity": "sha512-9o3TMmpmftaCMepOdA5k/yDw8SfInyzWWTjYTFCX3kPSDJMROQTb8jg+h9Cnwnmm1vOzvxN7gIfB5V2ewpjtGA==",
2015 | "dev": true,
2016 | "optional": true
2017 | },
2018 | "@esbuild/android-arm": {
2019 | "version": "0.25.5",
2020 | "resolved": "https://registry.npmjs.org/@esbuild/android-arm/-/android-arm-0.25.5.tgz",
2021 | "integrity": "sha512-AdJKSPeEHgi7/ZhuIPtcQKr5RQdo6OO2IL87JkianiMYMPbCtot9fxPbrMiBADOWWm3T2si9stAiVsGbTQFkbA==",
2022 | "dev": true,
2023 | "optional": true
2024 | },
2025 | "@esbuild/android-arm64": {
2026 | "version": "0.25.5",
2027 | "resolved": "https://registry.npmjs.org/@esbuild/android-arm64/-/android-arm64-0.25.5.tgz",
2028 | "integrity": "sha512-VGzGhj4lJO+TVGV1v8ntCZWJktV7SGCs3Pn1GRWI1SBFtRALoomm8k5E9Pmwg3HOAal2VDc2F9+PM/rEY6oIDg==",
2029 | "dev": true,
2030 | "optional": true
2031 | },
2032 | "@esbuild/android-x64": {
2033 | "version": "0.25.5",
2034 | "resolved": "https://registry.npmjs.org/@esbuild/android-x64/-/android-x64-0.25.5.tgz",
2035 | "integrity": "sha512-D2GyJT1kjvO//drbRT3Hib9XPwQeWd9vZoBJn+bu/lVsOZ13cqNdDeqIF/xQ5/VmWvMduP6AmXvylO/PIc2isw==",
2036 | "dev": true,
2037 | "optional": true
2038 | },
2039 | "@esbuild/darwin-arm64": {
2040 | "version": "0.25.5",
2041 | "resolved": "https://registry.npmjs.org/@esbuild/darwin-arm64/-/darwin-arm64-0.25.5.tgz",
2042 | "integrity": "sha512-GtaBgammVvdF7aPIgH2jxMDdivezgFu6iKpmT+48+F8Hhg5J/sfnDieg0aeG/jfSvkYQU2/pceFPDKlqZzwnfQ==",
2043 | "dev": true,
2044 | "optional": true
2045 | },
2046 | "@esbuild/darwin-x64": {
2047 | "version": "0.25.5",
2048 | "resolved": "https://registry.npmjs.org/@esbuild/darwin-x64/-/darwin-x64-0.25.5.tgz",
2049 | "integrity": "sha512-1iT4FVL0dJ76/q1wd7XDsXrSW+oLoquptvh4CLR4kITDtqi2e/xwXwdCVH8hVHU43wgJdsq7Gxuzcs6Iq/7bxQ==",
2050 | "dev": true,
2051 | "optional": true
2052 | },
2053 | "@esbuild/freebsd-arm64": {
2054 | "version": "0.25.5",
2055 | "resolved": "https://registry.npmjs.org/@esbuild/freebsd-arm64/-/freebsd-arm64-0.25.5.tgz",
2056 | "integrity": "sha512-nk4tGP3JThz4La38Uy/gzyXtpkPW8zSAmoUhK9xKKXdBCzKODMc2adkB2+8om9BDYugz+uGV7sLmpTYzvmz6Sw==",
2057 | "dev": true,
2058 | "optional": true
2059 | },
2060 | "@esbuild/freebsd-x64": {
2061 | "version": "0.25.5",
2062 | "resolved": "https://registry.npmjs.org/@esbuild/freebsd-x64/-/freebsd-x64-0.25.5.tgz",
2063 | "integrity": "sha512-PrikaNjiXdR2laW6OIjlbeuCPrPaAl0IwPIaRv+SMV8CiM8i2LqVUHFC1+8eORgWyY7yhQY+2U2fA55mBzReaw==",
2064 | "dev": true,
2065 | "optional": true
2066 | },
2067 | "@esbuild/linux-arm": {
2068 | "version": "0.25.5",
2069 | "resolved": "https://registry.npmjs.org/@esbuild/linux-arm/-/linux-arm-0.25.5.tgz",
2070 | "integrity": "sha512-cPzojwW2okgh7ZlRpcBEtsX7WBuqbLrNXqLU89GxWbNt6uIg78ET82qifUy3W6OVww6ZWobWub5oqZOVtwolfw==",
2071 | "dev": true,
2072 | "optional": true
2073 | },
2074 | "@esbuild/linux-arm64": {
2075 | "version": "0.25.5",
2076 | "resolved": "https://registry.npmjs.org/@esbuild/linux-arm64/-/linux-arm64-0.25.5.tgz",
2077 | "integrity": "sha512-Z9kfb1v6ZlGbWj8EJk9T6czVEjjq2ntSYLY2cw6pAZl4oKtfgQuS4HOq41M/BcoLPzrUbNd+R4BXFyH//nHxVg==",
2078 | "dev": true,
2079 | "optional": true
2080 | },
2081 | "@esbuild/linux-ia32": {
2082 | "version": "0.25.5",
2083 | "resolved": "https://registry.npmjs.org/@esbuild/linux-ia32/-/linux-ia32-0.25.5.tgz",
2084 | "integrity": "sha512-sQ7l00M8bSv36GLV95BVAdhJ2QsIbCuCjh/uYrWiMQSUuV+LpXwIqhgJDcvMTj+VsQmqAHL2yYaasENvJ7CDKA==",
2085 | "dev": true,
2086 | "optional": true
2087 | },
2088 | "@esbuild/linux-loong64": {
2089 | "version": "0.25.5",
2090 | "resolved": "https://registry.npmjs.org/@esbuild/linux-loong64/-/linux-loong64-0.25.5.tgz",
2091 | "integrity": "sha512-0ur7ae16hDUC4OL5iEnDb0tZHDxYmuQyhKhsPBV8f99f6Z9KQM02g33f93rNH5A30agMS46u2HP6qTdEt6Q1kg==",
2092 | "dev": true,
2093 | "optional": true
2094 | },
2095 | "@esbuild/linux-mips64el": {
2096 | "version": "0.25.5",
2097 | "resolved": "https://registry.npmjs.org/@esbuild/linux-mips64el/-/linux-mips64el-0.25.5.tgz",
2098 | "integrity": "sha512-kB/66P1OsHO5zLz0i6X0RxlQ+3cu0mkxS3TKFvkb5lin6uwZ/ttOkP3Z8lfR9mJOBk14ZwZ9182SIIWFGNmqmg==",
2099 | "dev": true,
2100 | "optional": true
2101 | },
2102 | "@esbuild/linux-ppc64": {
2103 | "version": "0.25.5",
2104 | "resolved": "https://registry.npmjs.org/@esbuild/linux-ppc64/-/linux-ppc64-0.25.5.tgz",
2105 | "integrity": "sha512-UZCmJ7r9X2fe2D6jBmkLBMQetXPXIsZjQJCjgwpVDz+YMcS6oFR27alkgGv3Oqkv07bxdvw7fyB71/olceJhkQ==",
2106 | "dev": true,
2107 | "optional": true
2108 | },
2109 | "@esbuild/linux-riscv64": {
2110 | "version": "0.25.5",
2111 | "resolved": "https://registry.npmjs.org/@esbuild/linux-riscv64/-/linux-riscv64-0.25.5.tgz",
2112 | "integrity": "sha512-kTxwu4mLyeOlsVIFPfQo+fQJAV9mh24xL+y+Bm6ej067sYANjyEw1dNHmvoqxJUCMnkBdKpvOn0Ahql6+4VyeA==",
2113 | "dev": true,
2114 | "optional": true
2115 | },
2116 | "@esbuild/linux-s390x": {
2117 | "version": "0.25.5",
2118 | "resolved": "https://registry.npmjs.org/@esbuild/linux-s390x/-/linux-s390x-0.25.5.tgz",
2119 | "integrity": "sha512-K2dSKTKfmdh78uJ3NcWFiqyRrimfdinS5ErLSn3vluHNeHVnBAFWC8a4X5N+7FgVE1EjXS1QDZbpqZBjfrqMTQ==",
2120 | "dev": true,
2121 | "optional": true
2122 | },
2123 | "@esbuild/linux-x64": {
2124 | "version": "0.25.5",
2125 | "resolved": "https://registry.npmjs.org/@esbuild/linux-x64/-/linux-x64-0.25.5.tgz",
2126 | "integrity": "sha512-uhj8N2obKTE6pSZ+aMUbqq+1nXxNjZIIjCjGLfsWvVpy7gKCOL6rsY1MhRh9zLtUtAI7vpgLMK6DxjO8Qm9lJw==",
2127 | "dev": true,
2128 | "optional": true
2129 | },
2130 | "@esbuild/netbsd-arm64": {
2131 | "version": "0.25.5",
2132 | "resolved": "https://registry.npmjs.org/@esbuild/netbsd-arm64/-/netbsd-arm64-0.25.5.tgz",
2133 | "integrity": "sha512-pwHtMP9viAy1oHPvgxtOv+OkduK5ugofNTVDilIzBLpoWAM16r7b/mxBvfpuQDpRQFMfuVr5aLcn4yveGvBZvw==",
2134 | "dev": true,
2135 | "optional": true
2136 | },
2137 | "@esbuild/netbsd-x64": {
2138 | "version": "0.25.5",
2139 | "resolved": "https://registry.npmjs.org/@esbuild/netbsd-x64/-/netbsd-x64-0.25.5.tgz",
2140 | "integrity": "sha512-WOb5fKrvVTRMfWFNCroYWWklbnXH0Q5rZppjq0vQIdlsQKuw6mdSihwSo4RV/YdQ5UCKKvBy7/0ZZYLBZKIbwQ==",
2141 | "dev": true,
2142 | "optional": true
2143 | },
2144 | "@esbuild/openbsd-arm64": {
2145 | "version": "0.25.5",
2146 | "resolved": "https://registry.npmjs.org/@esbuild/openbsd-arm64/-/openbsd-arm64-0.25.5.tgz",
2147 | "integrity": "sha512-7A208+uQKgTxHd0G0uqZO8UjK2R0DDb4fDmERtARjSHWxqMTye4Erz4zZafx7Di9Cv+lNHYuncAkiGFySoD+Mw==",
2148 | "dev": true,
2149 | "optional": true
2150 | },
2151 | "@esbuild/openbsd-x64": {
2152 | "version": "0.25.5",
2153 | "resolved": "https://registry.npmjs.org/@esbuild/openbsd-x64/-/openbsd-x64-0.25.5.tgz",
2154 | "integrity": "sha512-G4hE405ErTWraiZ8UiSoesH8DaCsMm0Cay4fsFWOOUcz8b8rC6uCvnagr+gnioEjWn0wC+o1/TAHt+It+MpIMg==",
2155 | "dev": true,
2156 | "optional": true
2157 | },
2158 | "@esbuild/sunos-x64": {
2159 | "version": "0.25.5",
2160 | "resolved": "https://registry.npmjs.org/@esbuild/sunos-x64/-/sunos-x64-0.25.5.tgz",
2161 | "integrity": "sha512-l+azKShMy7FxzY0Rj4RCt5VD/q8mG/e+mDivgspo+yL8zW7qEwctQ6YqKX34DTEleFAvCIUviCFX1SDZRSyMQA==",
2162 | "dev": true,
2163 | "optional": true
2164 | },
2165 | "@esbuild/win32-arm64": {
2166 | "version": "0.25.5",
2167 | "resolved": "https://registry.npmjs.org/@esbuild/win32-arm64/-/win32-arm64-0.25.5.tgz",
2168 | "integrity": "sha512-O2S7SNZzdcFG7eFKgvwUEZ2VG9D/sn/eIiz8XRZ1Q/DO5a3s76Xv0mdBzVM5j5R639lXQmPmSo0iRpHqUUrsxw==",
2169 | "dev": true,
2170 | "optional": true
2171 | },
2172 | "@esbuild/win32-ia32": {
2173 | "version": "0.25.5",
2174 | "resolved": "https://registry.npmjs.org/@esbuild/win32-ia32/-/win32-ia32-0.25.5.tgz",
2175 | "integrity": "sha512-onOJ02pqs9h1iMJ1PQphR+VZv8qBMQ77Klcsqv9CNW2w6yLqoURLcgERAIurY6QE63bbLuqgP9ATqajFLK5AMQ==",
2176 | "dev": true,
2177 | "optional": true
2178 | },
2179 | "@esbuild/win32-x64": {
2180 | "version": "0.25.5",
2181 | "resolved": "https://registry.npmjs.org/@esbuild/win32-x64/-/win32-x64-0.25.5.tgz",
2182 | "integrity": "sha512-TXv6YnJ8ZMVdX+SXWVBo/0p8LTcrUYngpWjvm91TMjjBQii7Oz11Lw5lbDV5Y0TzuhSJHwiH4hEtC1I42mMS0g==",
2183 | "dev": true,
2184 | "optional": true
2185 | },
2186 | "@eslint-community/eslint-utils": {
2187 | "version": "4.4.0",
2188 | "resolved": "https://registry.npmjs.org/@eslint-community/eslint-utils/-/eslint-utils-4.4.0.tgz",
2189 | "integrity": "sha512-1/sA4dwrzBAyeUoQ6oxahHKmrZvsnLCg4RfxW3ZFGGmQkSNQPFNLV9CUEFQP1x9EYXHTo5p6xdhZM1Ne9p/AfA==",
2190 | "dev": true,
2191 | "requires": {
2192 | "eslint-visitor-keys": "^3.3.0"
2193 | }
2194 | },
2195 | "@eslint-community/regexpp": {
2196 | "version": "4.12.1",
2197 | "resolved": "https://registry.npmjs.org/@eslint-community/regexpp/-/regexpp-4.12.1.tgz",
2198 | "integrity": "sha512-CCZCDJuduB9OUkFkY2IgppNZMi2lBQgD2qzwXkEia16cge2pijY/aXi96CJMquDMn3nJdlPV1A5KrJEXwfLNzQ==",
2199 | "dev": true
2200 | },
2201 | "@eslint/config-array": {
2202 | "version": "0.20.0",
2203 | "resolved": "https://registry.npmjs.org/@eslint/config-array/-/config-array-0.20.0.tgz",
2204 | "integrity": "sha512-fxlS1kkIjx8+vy2SjuCB94q3htSNrufYTXubwiBFeaQHbH6Ipi43gFJq2zCMt6PHhImH3Xmr0NksKDvchWlpQQ==",
2205 | "dev": true,
2206 | "requires": {
2207 | "@eslint/object-schema": "^2.1.6",
2208 | "debug": "^4.3.1",
2209 | "minimatch": "^3.1.2"
2210 | }
2211 | },
2212 | "@eslint/config-helpers": {
2213 | "version": "0.2.2",
2214 | "resolved": "https://registry.npmjs.org/@eslint/config-helpers/-/config-helpers-0.2.2.tgz",
2215 | "integrity": "sha512-+GPzk8PlG0sPpzdU5ZvIRMPidzAnZDl/s9L+y13iodqvb8leL53bTannOrQ/Im7UkpsmFU5Ily5U60LWixnmLg==",
2216 | "dev": true
2217 | },
2218 | "@eslint/core": {
2219 | "version": "0.14.0",
2220 | "resolved": "https://registry.npmjs.org/@eslint/core/-/core-0.14.0.tgz",
2221 | "integrity": "sha512-qIbV0/JZr7iSDjqAc60IqbLdsj9GDt16xQtWD+B78d/HAlvysGdZZ6rpJHGAc2T0FQx1X6thsSPdnoiGKdNtdg==",
2222 | "dev": true,
2223 | "requires": {
2224 | "@types/json-schema": "^7.0.15"
2225 | }
2226 | },
2227 | "@eslint/eslintrc": {
2228 | "version": "3.3.1",
2229 | "resolved": "https://registry.npmjs.org/@eslint/eslintrc/-/eslintrc-3.3.1.tgz",
2230 | "integrity": "sha512-gtF186CXhIl1p4pJNGZw8Yc6RlshoePRvE0X91oPGb3vZ8pM3qOS9W9NGPat9LziaBV7XrJWGylNQXkGcnM3IQ==",
2231 | "dev": true,
2232 | "requires": {
2233 | "ajv": "^6.12.4",
2234 | "debug": "^4.3.2",
2235 | "espree": "^10.0.1",
2236 | "globals": "^14.0.0",
2237 | "ignore": "^5.2.0",
2238 | "import-fresh": "^3.2.1",
2239 | "js-yaml": "^4.1.0",
2240 | "minimatch": "^3.1.2",
2241 | "strip-json-comments": "^3.1.1"
2242 | },
2243 | "dependencies": {
2244 | "globals": {
2245 | "version": "14.0.0",
2246 | "resolved": "https://registry.npmjs.org/globals/-/globals-14.0.0.tgz",
2247 | "integrity": "sha512-oahGvuMGQlPw/ivIYBjVSrWAfWLBeku5tpPE2fOPLi+WHffIWbuh2tCjhyQhTBPMf5E9jDEH4FOmTYgYwbKwtQ==",
2248 | "dev": true
2249 | }
2250 | }
2251 | },
2252 | "@eslint/js": {
2253 | "version": "9.27.0",
2254 | "resolved": "https://registry.npmjs.org/@eslint/js/-/js-9.27.0.tgz",
2255 | "integrity": "sha512-G5JD9Tu5HJEu4z2Uo4aHY2sLV64B7CDMXxFzqzjl3NKd6RVzSXNoE80jk7Y0lJkTTkjiIhBAqmlYwjuBY3tvpA==",
2256 | "dev": true
2257 | },
2258 | "@eslint/object-schema": {
2259 | "version": "2.1.6",
2260 | "resolved": "https://registry.npmjs.org/@eslint/object-schema/-/object-schema-2.1.6.tgz",
2261 | "integrity": "sha512-RBMg5FRL0I0gs51M/guSAj5/e14VQ4tpZnQNWwuDT66P14I43ItmPfIZRhO9fUVIPOAQXU47atlywZ/czoqFPA==",
2262 | "dev": true
2263 | },
2264 | "@eslint/plugin-kit": {
2265 | "version": "0.3.1",
2266 | "resolved": "https://registry.npmjs.org/@eslint/plugin-kit/-/plugin-kit-0.3.1.tgz",
2267 | "integrity": "sha512-0J+zgWxHN+xXONWIyPWKFMgVuJoZuGiIFu8yxk7RJjxkzpGmyja5wRFqZIVtjDVOQpV+Rw0iOAjYPE2eQyjr0w==",
2268 | "dev": true,
2269 | "requires": {
2270 | "@eslint/core": "^0.14.0",
2271 | "levn": "^0.4.1"
2272 | }
2273 | },
2274 | "@humanfs/core": {
2275 | "version": "0.19.1",
2276 | "resolved": "https://registry.npmjs.org/@humanfs/core/-/core-0.19.1.tgz",
2277 | "integrity": "sha512-5DyQ4+1JEUzejeK1JGICcideyfUbGixgS9jNgex5nqkW+cY7WZhxBigmieN5Qnw9ZosSNVC9KQKyb+GUaGyKUA==",
2278 | "dev": true
2279 | },
2280 | "@humanfs/node": {
2281 | "version": "0.16.6",
2282 | "resolved": "https://registry.npmjs.org/@humanfs/node/-/node-0.16.6.tgz",
2283 | "integrity": "sha512-YuI2ZHQL78Q5HbhDiBA1X4LmYdXCKCMQIfw0pw7piHJwyREFebJUvrQN4cMssyES6x+vfUbx1CIpaQUKYdQZOw==",
2284 | "dev": true,
2285 | "requires": {
2286 | "@humanfs/core": "^0.19.1",
2287 | "@humanwhocodes/retry": "^0.3.0"
2288 | },
2289 | "dependencies": {
2290 | "@humanwhocodes/retry": {
2291 | "version": "0.3.1",
2292 | "resolved": "https://registry.npmjs.org/@humanwhocodes/retry/-/retry-0.3.1.tgz",
2293 | "integrity": "sha512-JBxkERygn7Bv/GbN5Rv8Ul6LVknS+5Bp6RgDC/O8gEBU/yeH5Ui5C/OlWrTb6qct7LjjfT6Re2NxB0ln0yYybA==",
2294 | "dev": true
2295 | }
2296 | }
2297 | },
2298 | "@humanwhocodes/module-importer": {
2299 | "version": "1.0.1",
2300 | "resolved": "https://registry.npmjs.org/@humanwhocodes/module-importer/-/module-importer-1.0.1.tgz",
2301 | "integrity": "sha512-bxveV4V8v5Yb4ncFTT3rPSgZBOpCkjfK0y4oVVVJwIuDVBRMDXrPyXRL988i5ap9m9bnyEEjWfm5WkBmtffLfA==",
2302 | "dev": true
2303 | },
2304 | "@humanwhocodes/retry": {
2305 | "version": "0.4.3",
2306 | "resolved": "https://registry.npmjs.org/@humanwhocodes/retry/-/retry-0.4.3.tgz",
2307 | "integrity": "sha512-bV0Tgo9K4hfPCek+aMAn81RppFKv2ySDQeMoSZuvTASywNTnVJCArCZE2FWqpvIatKu7VMRLWlR1EazvVhDyhQ==",
2308 | "dev": true
2309 | },
2310 | "@rollup/pluginutils": {
2311 | "version": "5.1.4",
2312 | "resolved": "https://registry.npmjs.org/@rollup/pluginutils/-/pluginutils-5.1.4.tgz",
2313 | "integrity": "sha512-USm05zrsFxYLPdWWq+K3STlWiT/3ELn3RcV5hJMghpeAIhxfsUIg6mt12CBJBInWMV4VneoV7SfGv8xIwo2qNQ==",
2314 | "requires": {
2315 | "@types/estree": "^1.0.0",
2316 | "estree-walker": "^2.0.2",
2317 | "picomatch": "^4.0.2"
2318 | }
2319 | },
2320 | "@rollup/rollup-android-arm-eabi": {
2321 | "version": "4.41.1",
2322 | "resolved": "https://registry.npmjs.org/@rollup/rollup-android-arm-eabi/-/rollup-android-arm-eabi-4.41.1.tgz",
2323 | "integrity": "sha512-NELNvyEWZ6R9QMkiytB4/L4zSEaBC03KIXEghptLGLZWJ6VPrL63ooZQCOnlx36aQPGhzuOMwDerC1Eb2VmrLw==",
2324 | "dev": true,
2325 | "optional": true
2326 | },
2327 | "@rollup/rollup-android-arm64": {
2328 | "version": "4.41.1",
2329 | "resolved": "https://registry.npmjs.org/@rollup/rollup-android-arm64/-/rollup-android-arm64-4.41.1.tgz",
2330 | "integrity": "sha512-DXdQe1BJ6TK47ukAoZLehRHhfKnKg9BjnQYUu9gzhI8Mwa1d2fzxA1aw2JixHVl403bwp1+/o/NhhHtxWJBgEA==",
2331 | "dev": true,
2332 | "optional": true
2333 | },
2334 | "@rollup/rollup-darwin-arm64": {
2335 | "version": "4.41.1",
2336 | "resolved": "https://registry.npmjs.org/@rollup/rollup-darwin-arm64/-/rollup-darwin-arm64-4.41.1.tgz",
2337 | "integrity": "sha512-5afxvwszzdulsU2w8JKWwY8/sJOLPzf0e1bFuvcW5h9zsEg+RQAojdW0ux2zyYAz7R8HvvzKCjLNJhVq965U7w==",
2338 | "dev": true,
2339 | "optional": true
2340 | },
2341 | "@rollup/rollup-darwin-x64": {
2342 | "version": "4.41.1",
2343 | "resolved": "https://registry.npmjs.org/@rollup/rollup-darwin-x64/-/rollup-darwin-x64-4.41.1.tgz",
2344 | "integrity": "sha512-egpJACny8QOdHNNMZKf8xY0Is6gIMz+tuqXlusxquWu3F833DcMwmGM7WlvCO9sB3OsPjdC4U0wHw5FabzCGZg==",
2345 | "dev": true,
2346 | "optional": true
2347 | },
2348 | "@rollup/rollup-freebsd-arm64": {
2349 | "version": "4.41.1",
2350 | "resolved": "https://registry.npmjs.org/@rollup/rollup-freebsd-arm64/-/rollup-freebsd-arm64-4.41.1.tgz",
2351 | "integrity": "sha512-DBVMZH5vbjgRk3r0OzgjS38z+atlupJ7xfKIDJdZZL6sM6wjfDNo64aowcLPKIx7LMQi8vybB56uh1Ftck/Atg==",
2352 | "dev": true,
2353 | "optional": true
2354 | },
2355 | "@rollup/rollup-freebsd-x64": {
2356 | "version": "4.41.1",
2357 | "resolved": "https://registry.npmjs.org/@rollup/rollup-freebsd-x64/-/rollup-freebsd-x64-4.41.1.tgz",
2358 | "integrity": "sha512-3FkydeohozEskBxNWEIbPfOE0aqQgB6ttTkJ159uWOFn42VLyfAiyD9UK5mhu+ItWzft60DycIN1Xdgiy8o/SA==",
2359 | "dev": true,
2360 | "optional": true
2361 | },
2362 | "@rollup/rollup-linux-arm-gnueabihf": {
2363 | "version": "4.41.1",
2364 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm-gnueabihf/-/rollup-linux-arm-gnueabihf-4.41.1.tgz",
2365 | "integrity": "sha512-wC53ZNDgt0pqx5xCAgNunkTzFE8GTgdZ9EwYGVcg+jEjJdZGtq9xPjDnFgfFozQI/Xm1mh+D9YlYtl+ueswNEg==",
2366 | "dev": true,
2367 | "optional": true
2368 | },
2369 | "@rollup/rollup-linux-arm-musleabihf": {
2370 | "version": "4.41.1",
2371 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm-musleabihf/-/rollup-linux-arm-musleabihf-4.41.1.tgz",
2372 | "integrity": "sha512-jwKCca1gbZkZLhLRtsrka5N8sFAaxrGz/7wRJ8Wwvq3jug7toO21vWlViihG85ei7uJTpzbXZRcORotE+xyrLA==",
2373 | "dev": true,
2374 | "optional": true
2375 | },
2376 | "@rollup/rollup-linux-arm64-gnu": {
2377 | "version": "4.41.1",
2378 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm64-gnu/-/rollup-linux-arm64-gnu-4.41.1.tgz",
2379 | "integrity": "sha512-g0UBcNknsmmNQ8V2d/zD2P7WWfJKU0F1nu0k5pW4rvdb+BIqMm8ToluW/eeRmxCared5dD76lS04uL4UaNgpNA==",
2380 | "dev": true,
2381 | "optional": true
2382 | },
2383 | "@rollup/rollup-linux-arm64-musl": {
2384 | "version": "4.41.1",
2385 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm64-musl/-/rollup-linux-arm64-musl-4.41.1.tgz",
2386 | "integrity": "sha512-XZpeGB5TKEZWzIrj7sXr+BEaSgo/ma/kCgrZgL0oo5qdB1JlTzIYQKel/RmhT6vMAvOdM2teYlAaOGJpJ9lahg==",
2387 | "dev": true,
2388 | "optional": true
2389 | },
2390 | "@rollup/rollup-linux-loongarch64-gnu": {
2391 | "version": "4.41.1",
2392 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-loongarch64-gnu/-/rollup-linux-loongarch64-gnu-4.41.1.tgz",
2393 | "integrity": "sha512-bkCfDJ4qzWfFRCNt5RVV4DOw6KEgFTUZi2r2RuYhGWC8WhCA8lCAJhDeAmrM/fdiAH54m0mA0Vk2FGRPyzI+tw==",
2394 | "dev": true,
2395 | "optional": true
2396 | },
2397 | "@rollup/rollup-linux-powerpc64le-gnu": {
2398 | "version": "4.41.1",
2399 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-powerpc64le-gnu/-/rollup-linux-powerpc64le-gnu-4.41.1.tgz",
2400 | "integrity": "sha512-3mr3Xm+gvMX+/8EKogIZSIEF0WUu0HL9di+YWlJpO8CQBnoLAEL/roTCxuLncEdgcfJcvA4UMOf+2dnjl4Ut1A==",
2401 | "dev": true,
2402 | "optional": true
2403 | },
2404 | "@rollup/rollup-linux-riscv64-gnu": {
2405 | "version": "4.41.1",
2406 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-riscv64-gnu/-/rollup-linux-riscv64-gnu-4.41.1.tgz",
2407 | "integrity": "sha512-3rwCIh6MQ1LGrvKJitQjZFuQnT2wxfU+ivhNBzmxXTXPllewOF7JR1s2vMX/tWtUYFgphygxjqMl76q4aMotGw==",
2408 | "dev": true,
2409 | "optional": true
2410 | },
2411 | "@rollup/rollup-linux-riscv64-musl": {
2412 | "version": "4.41.1",
2413 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-riscv64-musl/-/rollup-linux-riscv64-musl-4.41.1.tgz",
2414 | "integrity": "sha512-LdIUOb3gvfmpkgFZuccNa2uYiqtgZAz3PTzjuM5bH3nvuy9ty6RGc/Q0+HDFrHrizJGVpjnTZ1yS5TNNjFlklw==",
2415 | "dev": true,
2416 | "optional": true
2417 | },
2418 | "@rollup/rollup-linux-s390x-gnu": {
2419 | "version": "4.41.1",
2420 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-s390x-gnu/-/rollup-linux-s390x-gnu-4.41.1.tgz",
2421 | "integrity": "sha512-oIE6M8WC9ma6xYqjvPhzZYk6NbobIURvP/lEbh7FWplcMO6gn7MM2yHKA1eC/GvYwzNKK/1LYgqzdkZ8YFxR8g==",
2422 | "dev": true,
2423 | "optional": true
2424 | },
2425 | "@rollup/rollup-linux-x64-gnu": {
2426 | "version": "4.41.1",
2427 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-x64-gnu/-/rollup-linux-x64-gnu-4.41.1.tgz",
2428 | "integrity": "sha512-cWBOvayNvA+SyeQMp79BHPK8ws6sHSsYnK5zDcsC3Hsxr1dgTABKjMnMslPq1DvZIp6uO7kIWhiGwaTdR4Og9A==",
2429 | "dev": true,
2430 | "optional": true
2431 | },
2432 | "@rollup/rollup-linux-x64-musl": {
2433 | "version": "4.41.1",
2434 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-x64-musl/-/rollup-linux-x64-musl-4.41.1.tgz",
2435 | "integrity": "sha512-y5CbN44M+pUCdGDlZFzGGBSKCA4A/J2ZH4edTYSSxFg7ce1Xt3GtydbVKWLlzL+INfFIZAEg1ZV6hh9+QQf9YQ==",
2436 | "dev": true,
2437 | "optional": true
2438 | },
2439 | "@rollup/rollup-win32-arm64-msvc": {
2440 | "version": "4.41.1",
2441 | "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-arm64-msvc/-/rollup-win32-arm64-msvc-4.41.1.tgz",
2442 | "integrity": "sha512-lZkCxIrjlJlMt1dLO/FbpZbzt6J/A8p4DnqzSa4PWqPEUUUnzXLeki/iyPLfV0BmHItlYgHUqJe+3KiyydmiNQ==",
2443 | "dev": true,
2444 | "optional": true
2445 | },
2446 | "@rollup/rollup-win32-ia32-msvc": {
2447 | "version": "4.41.1",
2448 | "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-ia32-msvc/-/rollup-win32-ia32-msvc-4.41.1.tgz",
2449 | "integrity": "sha512-+psFT9+pIh2iuGsxFYYa/LhS5MFKmuivRsx9iPJWNSGbh2XVEjk90fmpUEjCnILPEPJnikAU6SFDiEUyOv90Pg==",
2450 | "dev": true,
2451 | "optional": true
2452 | },
2453 | "@rollup/rollup-win32-x64-msvc": {
2454 | "version": "4.41.1",
2455 | "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-x64-msvc/-/rollup-win32-x64-msvc-4.41.1.tgz",
2456 | "integrity": "sha512-Wq2zpapRYLfi4aKxf2Xff0tN+7slj2d4R87WEzqw7ZLsVvO5zwYCIuEGSZYiK41+GlwUo1HiR+GdkLEJnCKTCw==",
2457 | "dev": true,
2458 | "optional": true
2459 | },
2460 | "@types/estree": {
2461 | "version": "1.0.7",
2462 | "resolved": "https://registry.npmjs.org/@types/estree/-/estree-1.0.7.tgz",
2463 | "integrity": "sha512-w28IoSUCJpidD/TGviZwwMJckNESJZXFu7NBZ5YJ4mEUnNraUn9Pm8HSZm/jDF1pDWYKspWE7oVphigUPRakIQ=="
2464 | },
2465 | "@types/json-schema": {
2466 | "version": "7.0.15",
2467 | "resolved": "https://registry.npmjs.org/@types/json-schema/-/json-schema-7.0.15.tgz",
2468 | "integrity": "sha512-5+fP8P8MFNC+AyZCDxrB2pkZFPGzqQWUzpSeuuVLvm8VMcorNYavBqoFcxK8bQz4Qsbn4oUEEem4wDLfcysGHA==",
2469 | "dev": true
2470 | },
2471 | "acorn": {
2472 | "version": "8.14.1",
2473 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.14.1.tgz",
2474 | "integrity": "sha512-OvQ/2pUDKmgfCg++xsTX1wGxfTaszcHVcTctW4UJB4hibJx2HXxxO5UmVgyjMa+ZDsiaf5wWLXYpRWMmBI0QHg==",
2475 | "dev": true
2476 | },
2477 | "acorn-jsx": {
2478 | "version": "5.3.2",
2479 | "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.3.2.tgz",
2480 | "integrity": "sha512-rq9s+JNhf0IChjtDXxllJ7g41oZk5SlXtp0LHwyA5cejwn7vKmKp4pPri6YEePv2PU65sAsegbXtIinmDFDXgQ==",
2481 | "dev": true,
2482 | "requires": {}
2483 | },
2484 | "ajv": {
2485 | "version": "6.12.6",
2486 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.6.tgz",
2487 | "integrity": "sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g==",
2488 | "dev": true,
2489 | "requires": {
2490 | "fast-deep-equal": "^3.1.1",
2491 | "fast-json-stable-stringify": "^2.0.0",
2492 | "json-schema-traverse": "^0.4.1",
2493 | "uri-js": "^4.2.2"
2494 | }
2495 | },
2496 | "argparse": {
2497 | "version": "2.0.1",
2498 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz",
2499 | "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==",
2500 | "dev": true
2501 | },
2502 | "balanced-match": {
2503 | "version": "1.0.2",
2504 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz",
2505 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==",
2506 | "dev": true
2507 | },
2508 | "brace-expansion": {
2509 | "version": "1.1.11",
2510 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz",
2511 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==",
2512 | "dev": true,
2513 | "requires": {
2514 | "balanced-match": "^1.0.0",
2515 | "concat-map": "0.0.1"
2516 | }
2517 | },
2518 | "callsites": {
2519 | "version": "3.1.0",
2520 | "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz",
2521 | "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==",
2522 | "dev": true
2523 | },
2524 | "chalk": {
2525 | "version": "4.1.2",
2526 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz",
2527 | "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==",
2528 | "dev": true,
2529 | "requires": {
2530 | "ansi-styles": "^4.1.0",
2531 | "supports-color": "^7.1.0"
2532 | },
2533 | "dependencies": {
2534 | "ansi-styles": {
2535 | "version": "4.3.0",
2536 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz",
2537 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==",
2538 | "dev": true,
2539 | "requires": {
2540 | "color-convert": "^2.0.1"
2541 | }
2542 | },
2543 | "color-convert": {
2544 | "version": "2.0.1",
2545 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz",
2546 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==",
2547 | "dev": true,
2548 | "requires": {
2549 | "color-name": "~1.1.4"
2550 | }
2551 | },
2552 | "color-name": {
2553 | "version": "1.1.4",
2554 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz",
2555 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==",
2556 | "dev": true
2557 | },
2558 | "has-flag": {
2559 | "version": "4.0.0",
2560 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz",
2561 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==",
2562 | "dev": true
2563 | },
2564 | "supports-color": {
2565 | "version": "7.2.0",
2566 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz",
2567 | "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==",
2568 | "dev": true,
2569 | "requires": {
2570 | "has-flag": "^4.0.0"
2571 | }
2572 | }
2573 | }
2574 | },
2575 | "concat-map": {
2576 | "version": "0.0.1",
2577 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz",
2578 | "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==",
2579 | "dev": true
2580 | },
2581 | "cross-spawn": {
2582 | "version": "7.0.6",
2583 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.6.tgz",
2584 | "integrity": "sha512-uV2QOWP2nWzsy2aMp8aRibhi9dlzF5Hgh5SHaB9OiTGEyDTiJJyx0uy51QXdyWbtAHNua4XJzUKca3OzKUd3vA==",
2585 | "dev": true,
2586 | "requires": {
2587 | "path-key": "^3.1.0",
2588 | "shebang-command": "^2.0.0",
2589 | "which": "^2.0.1"
2590 | }
2591 | },
2592 | "debug": {
2593 | "version": "4.4.1",
2594 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.4.1.tgz",
2595 | "integrity": "sha512-KcKCqiftBJcZr++7ykoDIEwSa3XWowTfNPo92BYxjXiyYEVrUQh2aLyhxBCwww+heortUFxEJYcRzosstTEBYQ==",
2596 | "dev": true,
2597 | "requires": {
2598 | "ms": "^2.1.3"
2599 | }
2600 | },
2601 | "deep-is": {
2602 | "version": "0.1.4",
2603 | "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.4.tgz",
2604 | "integrity": "sha512-oIPzksmTg4/MriiaYGO+okXDT7ztn/w3Eptv/+gSIdMdKsJo0u4CfYNFJPy+4SKMuCqGw2wxnA+URMg3t8a/bQ==",
2605 | "dev": true
2606 | },
2607 | "es-module-lexer": {
2608 | "version": "1.7.0",
2609 | "resolved": "https://registry.npmjs.org/es-module-lexer/-/es-module-lexer-1.7.0.tgz",
2610 | "integrity": "sha512-jEQoCwk8hyb2AZziIOLhDqpm5+2ww5uIE6lkO/6jcOCusfk6LhMHpXXfBLXTZ7Ydyt0j4VoUQv6uGNYbdW+kBA==",
2611 | "dev": true
2612 | },
2613 | "esbuild": {
2614 | "version": "0.25.5",
2615 | "resolved": "https://registry.npmjs.org/esbuild/-/esbuild-0.25.5.tgz",
2616 | "integrity": "sha512-P8OtKZRv/5J5hhz0cUAdu/cLuPIKXpQl1R9pZtvmHWQvrAUVd0UNIPT4IB4W3rNOqVO0rlqHmCIbSwxh/c9yUQ==",
2617 | "dev": true,
2618 | "requires": {
2619 | "@esbuild/aix-ppc64": "0.25.5",
2620 | "@esbuild/android-arm": "0.25.5",
2621 | "@esbuild/android-arm64": "0.25.5",
2622 | "@esbuild/android-x64": "0.25.5",
2623 | "@esbuild/darwin-arm64": "0.25.5",
2624 | "@esbuild/darwin-x64": "0.25.5",
2625 | "@esbuild/freebsd-arm64": "0.25.5",
2626 | "@esbuild/freebsd-x64": "0.25.5",
2627 | "@esbuild/linux-arm": "0.25.5",
2628 | "@esbuild/linux-arm64": "0.25.5",
2629 | "@esbuild/linux-ia32": "0.25.5",
2630 | "@esbuild/linux-loong64": "0.25.5",
2631 | "@esbuild/linux-mips64el": "0.25.5",
2632 | "@esbuild/linux-ppc64": "0.25.5",
2633 | "@esbuild/linux-riscv64": "0.25.5",
2634 | "@esbuild/linux-s390x": "0.25.5",
2635 | "@esbuild/linux-x64": "0.25.5",
2636 | "@esbuild/netbsd-arm64": "0.25.5",
2637 | "@esbuild/netbsd-x64": "0.25.5",
2638 | "@esbuild/openbsd-arm64": "0.25.5",
2639 | "@esbuild/openbsd-x64": "0.25.5",
2640 | "@esbuild/sunos-x64": "0.25.5",
2641 | "@esbuild/win32-arm64": "0.25.5",
2642 | "@esbuild/win32-ia32": "0.25.5",
2643 | "@esbuild/win32-x64": "0.25.5"
2644 | }
2645 | },
2646 | "escape-string-regexp": {
2647 | "version": "4.0.0",
2648 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz",
2649 | "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==",
2650 | "dev": true
2651 | },
2652 | "eslint": {
2653 | "version": "9.27.0",
2654 | "resolved": "https://registry.npmjs.org/eslint/-/eslint-9.27.0.tgz",
2655 | "integrity": "sha512-ixRawFQuMB9DZ7fjU3iGGganFDp3+45bPOdaRurcFHSXO1e/sYwUX/FtQZpLZJR6SjMoJH8hR2pPEAfDyCoU2Q==",
2656 | "dev": true,
2657 | "requires": {
2658 | "@eslint-community/eslint-utils": "^4.2.0",
2659 | "@eslint-community/regexpp": "^4.12.1",
2660 | "@eslint/config-array": "^0.20.0",
2661 | "@eslint/config-helpers": "^0.2.1",
2662 | "@eslint/core": "^0.14.0",
2663 | "@eslint/eslintrc": "^3.3.1",
2664 | "@eslint/js": "9.27.0",
2665 | "@eslint/plugin-kit": "^0.3.1",
2666 | "@humanfs/node": "^0.16.6",
2667 | "@humanwhocodes/module-importer": "^1.0.1",
2668 | "@humanwhocodes/retry": "^0.4.2",
2669 | "@types/estree": "^1.0.6",
2670 | "@types/json-schema": "^7.0.15",
2671 | "ajv": "^6.12.4",
2672 | "chalk": "^4.0.0",
2673 | "cross-spawn": "^7.0.6",
2674 | "debug": "^4.3.2",
2675 | "escape-string-regexp": "^4.0.0",
2676 | "eslint-scope": "^8.3.0",
2677 | "eslint-visitor-keys": "^4.2.0",
2678 | "espree": "^10.3.0",
2679 | "esquery": "^1.5.0",
2680 | "esutils": "^2.0.2",
2681 | "fast-deep-equal": "^3.1.3",
2682 | "file-entry-cache": "^8.0.0",
2683 | "find-up": "^5.0.0",
2684 | "glob-parent": "^6.0.2",
2685 | "ignore": "^5.2.0",
2686 | "imurmurhash": "^0.1.4",
2687 | "is-glob": "^4.0.0",
2688 | "json-stable-stringify-without-jsonify": "^1.0.1",
2689 | "lodash.merge": "^4.6.2",
2690 | "minimatch": "^3.1.2",
2691 | "natural-compare": "^1.4.0",
2692 | "optionator": "^0.9.3"
2693 | },
2694 | "dependencies": {
2695 | "eslint-visitor-keys": {
2696 | "version": "4.2.0",
2697 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-4.2.0.tgz",
2698 | "integrity": "sha512-UyLnSehNt62FFhSwjZlHmeokpRK59rcz29j+F1/aDgbkbRTk7wIc9XzdoasMUbRNKDM0qQt/+BJ4BrpFeABemw==",
2699 | "dev": true
2700 | }
2701 | }
2702 | },
2703 | "eslint-scope": {
2704 | "version": "8.3.0",
2705 | "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-8.3.0.tgz",
2706 | "integrity": "sha512-pUNxi75F8MJ/GdeKtVLSbYg4ZI34J6C0C7sbL4YOp2exGwen7ZsuBqKzUhXd0qMQ362yET3z+uPwKeg/0C2XCQ==",
2707 | "dev": true,
2708 | "requires": {
2709 | "esrecurse": "^4.3.0",
2710 | "estraverse": "^5.2.0"
2711 | }
2712 | },
2713 | "eslint-visitor-keys": {
2714 | "version": "3.4.3",
2715 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-3.4.3.tgz",
2716 | "integrity": "sha512-wpc+LXeiyiisxPlEkUzU6svyS1frIO3Mgxj1fdy7Pm8Ygzguax2N3Fa/D/ag1WqbOprdI+uY6wMUl8/a2G+iag==",
2717 | "dev": true
2718 | },
2719 | "espree": {
2720 | "version": "10.3.0",
2721 | "resolved": "https://registry.npmjs.org/espree/-/espree-10.3.0.tgz",
2722 | "integrity": "sha512-0QYC8b24HWY8zjRnDTL6RiHfDbAWn63qb4LMj1Z4b076A4une81+z03Kg7l7mn/48PUTqoLptSXez8oknU8Clg==",
2723 | "dev": true,
2724 | "requires": {
2725 | "acorn": "^8.14.0",
2726 | "acorn-jsx": "^5.3.2",
2727 | "eslint-visitor-keys": "^4.2.0"
2728 | },
2729 | "dependencies": {
2730 | "eslint-visitor-keys": {
2731 | "version": "4.2.0",
2732 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-4.2.0.tgz",
2733 | "integrity": "sha512-UyLnSehNt62FFhSwjZlHmeokpRK59rcz29j+F1/aDgbkbRTk7wIc9XzdoasMUbRNKDM0qQt/+BJ4BrpFeABemw==",
2734 | "dev": true
2735 | }
2736 | }
2737 | },
2738 | "esquery": {
2739 | "version": "1.5.0",
2740 | "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.5.0.tgz",
2741 | "integrity": "sha512-YQLXUplAwJgCydQ78IMJywZCceoqk1oH01OERdSAJc/7U2AylwjhSCLDEtqwg811idIS/9fIU5GjG73IgjKMVg==",
2742 | "dev": true,
2743 | "requires": {
2744 | "estraverse": "^5.1.0"
2745 | }
2746 | },
2747 | "esrecurse": {
2748 | "version": "4.3.0",
2749 | "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.3.0.tgz",
2750 | "integrity": "sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag==",
2751 | "dev": true,
2752 | "requires": {
2753 | "estraverse": "^5.2.0"
2754 | }
2755 | },
2756 | "estraverse": {
2757 | "version": "5.3.0",
2758 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.3.0.tgz",
2759 | "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==",
2760 | "dev": true
2761 | },
2762 | "estree-walker": {
2763 | "version": "2.0.2",
2764 | "resolved": "https://registry.npmjs.org/estree-walker/-/estree-walker-2.0.2.tgz",
2765 | "integrity": "sha512-Rfkk/Mp/DL7JVje3u18FxFujQlTNR2q6QfMSMB7AvCBx91NGj/ba3kCfza0f6dVDbw7YlRf/nDrn7pQrCCyQ/w=="
2766 | },
2767 | "esutils": {
2768 | "version": "2.0.3",
2769 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz",
2770 | "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==",
2771 | "dev": true
2772 | },
2773 | "fast-deep-equal": {
2774 | "version": "3.1.3",
2775 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz",
2776 | "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==",
2777 | "dev": true
2778 | },
2779 | "fast-json-stable-stringify": {
2780 | "version": "2.1.0",
2781 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz",
2782 | "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==",
2783 | "dev": true
2784 | },
2785 | "fast-levenshtein": {
2786 | "version": "2.0.6",
2787 | "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz",
2788 | "integrity": "sha512-DCXu6Ifhqcks7TZKY3Hxp3y6qphY5SJZmrWMDrKcERSOXWQdMhU9Ig/PYrzyw/ul9jOIyh0N4M0tbC5hodg8dw==",
2789 | "dev": true
2790 | },
2791 | "file-entry-cache": {
2792 | "version": "8.0.0",
2793 | "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-8.0.0.tgz",
2794 | "integrity": "sha512-XXTUwCvisa5oacNGRP9SfNtYBNAMi+RPwBFmblZEF7N7swHYQS6/Zfk7SRwx4D5j3CH211YNRco1DEMNVfZCnQ==",
2795 | "dev": true,
2796 | "requires": {
2797 | "flat-cache": "^4.0.0"
2798 | }
2799 | },
2800 | "find-up": {
2801 | "version": "5.0.0",
2802 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-5.0.0.tgz",
2803 | "integrity": "sha512-78/PXT1wlLLDgTzDs7sjq9hzz0vXD+zn+7wypEe4fXQxCmdmqfGsEPQxmiCSQI3ajFV91bVSsvNtrJRiW6nGng==",
2804 | "dev": true,
2805 | "requires": {
2806 | "locate-path": "^6.0.0",
2807 | "path-exists": "^4.0.0"
2808 | }
2809 | },
2810 | "flat-cache": {
2811 | "version": "4.0.1",
2812 | "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-4.0.1.tgz",
2813 | "integrity": "sha512-f7ccFPK3SXFHpx15UIGyRJ/FJQctuKZ0zVuN3frBo4HnK3cay9VEW0R6yPYFHC0AgqhukPzKjq22t5DmAyqGyw==",
2814 | "dev": true,
2815 | "requires": {
2816 | "flatted": "^3.2.9",
2817 | "keyv": "^4.5.4"
2818 | }
2819 | },
2820 | "flatted": {
2821 | "version": "3.3.2",
2822 | "resolved": "https://registry.npmjs.org/flatted/-/flatted-3.3.2.tgz",
2823 | "integrity": "sha512-AiwGJM8YcNOaobumgtng+6NHuOqC3A7MixFeDafM3X9cIUM+xUXoS5Vfgf+OihAYe20fxqNM9yPBXJzRtZ/4eA==",
2824 | "dev": true
2825 | },
2826 | "fsevents": {
2827 | "version": "2.3.2",
2828 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.2.tgz",
2829 | "integrity": "sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==",
2830 | "dev": true,
2831 | "optional": true
2832 | },
2833 | "get-tsconfig": {
2834 | "version": "4.10.1",
2835 | "resolved": "https://registry.npmjs.org/get-tsconfig/-/get-tsconfig-4.10.1.tgz",
2836 | "integrity": "sha512-auHyJ4AgMz7vgS8Hp3N6HXSmlMdUyhSUrfBF16w153rxtLIEOE+HGqaBppczZvnHLqQJfiHotCYpNhl0lUROFQ==",
2837 | "dev": true,
2838 | "requires": {
2839 | "resolve-pkg-maps": "^1.0.0"
2840 | }
2841 | },
2842 | "glob-parent": {
2843 | "version": "6.0.2",
2844 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-6.0.2.tgz",
2845 | "integrity": "sha512-XxwI8EOhVQgWp6iDL+3b0r86f4d6AX6zSU55HfB4ydCEuXLXc5FcYeOu+nnGftS4TEju/11rt4KJPTMgbfmv4A==",
2846 | "dev": true,
2847 | "requires": {
2848 | "is-glob": "^4.0.3"
2849 | }
2850 | },
2851 | "globals": {
2852 | "version": "16.2.0",
2853 | "resolved": "https://registry.npmjs.org/globals/-/globals-16.2.0.tgz",
2854 | "integrity": "sha512-O+7l9tPdHCU320IigZZPj5zmRCFG9xHmx9cU8FqU2Rp+JN714seHV+2S9+JslCpY4gJwU2vOGox0wzgae/MCEg==",
2855 | "dev": true
2856 | },
2857 | "ignore": {
2858 | "version": "5.3.2",
2859 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-5.3.2.tgz",
2860 | "integrity": "sha512-hsBTNUqQTDwkWtcdYI2i06Y/nUBEsNEDJKjWdigLvegy8kDuJAS8uRlpkkcQpyEXL0Z/pjDy5HBmMjRCJ2gq+g==",
2861 | "dev": true
2862 | },
2863 | "import-fresh": {
2864 | "version": "3.3.1",
2865 | "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.3.1.tgz",
2866 | "integrity": "sha512-TR3KfrTZTYLPB6jUjfx6MF9WcWrHL9su5TObK4ZkYgBdWKPOFoSoQIdEuTuR82pmtxH2spWG9h6etwfr1pLBqQ==",
2867 | "dev": true,
2868 | "requires": {
2869 | "parent-module": "^1.0.0",
2870 | "resolve-from": "^4.0.0"
2871 | }
2872 | },
2873 | "imurmurhash": {
2874 | "version": "0.1.4",
2875 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz",
2876 | "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=",
2877 | "dev": true
2878 | },
2879 | "is-extglob": {
2880 | "version": "2.1.1",
2881 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz",
2882 | "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=",
2883 | "dev": true
2884 | },
2885 | "is-glob": {
2886 | "version": "4.0.3",
2887 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz",
2888 | "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==",
2889 | "dev": true,
2890 | "requires": {
2891 | "is-extglob": "^2.1.1"
2892 | }
2893 | },
2894 | "isexe": {
2895 | "version": "2.0.0",
2896 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz",
2897 | "integrity": "sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw==",
2898 | "dev": true
2899 | },
2900 | "js-yaml": {
2901 | "version": "4.1.0",
2902 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-4.1.0.tgz",
2903 | "integrity": "sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA==",
2904 | "dev": true,
2905 | "requires": {
2906 | "argparse": "^2.0.1"
2907 | }
2908 | },
2909 | "json-buffer": {
2910 | "version": "3.0.1",
2911 | "resolved": "https://registry.npmjs.org/json-buffer/-/json-buffer-3.0.1.tgz",
2912 | "integrity": "sha512-4bV5BfR2mqfQTJm+V5tPPdf+ZpuhiIvTuAB5g8kcrXOZpTT/QwwVRWBywX1ozr6lEuPdbHxwaJlm9G6mI2sfSQ==",
2913 | "dev": true
2914 | },
2915 | "json-schema-traverse": {
2916 | "version": "0.4.1",
2917 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz",
2918 | "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==",
2919 | "dev": true
2920 | },
2921 | "json-stable-stringify-without-jsonify": {
2922 | "version": "1.0.1",
2923 | "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz",
2924 | "integrity": "sha1-nbe1lJatPzz+8wp1FC0tkwrXJlE=",
2925 | "dev": true
2926 | },
2927 | "keyv": {
2928 | "version": "4.5.4",
2929 | "resolved": "https://registry.npmjs.org/keyv/-/keyv-4.5.4.tgz",
2930 | "integrity": "sha512-oxVHkHR/EJf2CNXnWxRLW6mg7JyCCUcG0DtEGmL2ctUo1PNTin1PUil+r/+4r5MpVgC/fn1kjsx7mjSujKqIpw==",
2931 | "dev": true,
2932 | "requires": {
2933 | "json-buffer": "3.0.1"
2934 | }
2935 | },
2936 | "levn": {
2937 | "version": "0.4.1",
2938 | "resolved": "https://registry.npmjs.org/levn/-/levn-0.4.1.tgz",
2939 | "integrity": "sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ==",
2940 | "dev": true,
2941 | "requires": {
2942 | "prelude-ls": "^1.2.1",
2943 | "type-check": "~0.4.0"
2944 | }
2945 | },
2946 | "locate-path": {
2947 | "version": "6.0.0",
2948 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-6.0.0.tgz",
2949 | "integrity": "sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw==",
2950 | "dev": true,
2951 | "requires": {
2952 | "p-locate": "^5.0.0"
2953 | }
2954 | },
2955 | "lodash.merge": {
2956 | "version": "4.6.2",
2957 | "resolved": "https://registry.npmjs.org/lodash.merge/-/lodash.merge-4.6.2.tgz",
2958 | "integrity": "sha512-0KpjqXRVvrYyCsX1swR/XTK0va6VQkQM6MNo7PqW77ByjAhoARA8EfrP1N4+KlKj8YS0ZUCtRT/YUuhyYDujIQ==",
2959 | "dev": true
2960 | },
2961 | "minimatch": {
2962 | "version": "3.1.2",
2963 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz",
2964 | "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==",
2965 | "dev": true,
2966 | "requires": {
2967 | "brace-expansion": "^1.1.7"
2968 | }
2969 | },
2970 | "ms": {
2971 | "version": "2.1.3",
2972 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz",
2973 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==",
2974 | "dev": true
2975 | },
2976 | "natural-compare": {
2977 | "version": "1.4.0",
2978 | "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz",
2979 | "integrity": "sha1-Sr6/7tdUHywnrPspvbvRXI1bpPc=",
2980 | "dev": true
2981 | },
2982 | "optionator": {
2983 | "version": "0.9.3",
2984 | "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.9.3.tgz",
2985 | "integrity": "sha512-JjCoypp+jKn1ttEFExxhetCKeJt9zhAgAve5FXHixTvFDW/5aEktX9bufBKLRRMdU7bNtpLfcGu94B3cdEJgjg==",
2986 | "dev": true,
2987 | "requires": {
2988 | "@aashutoshrathi/word-wrap": "^1.2.3",
2989 | "deep-is": "^0.1.3",
2990 | "fast-levenshtein": "^2.0.6",
2991 | "levn": "^0.4.1",
2992 | "prelude-ls": "^1.2.1",
2993 | "type-check": "^0.4.0"
2994 | }
2995 | },
2996 | "p-limit": {
2997 | "version": "3.1.0",
2998 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-3.1.0.tgz",
2999 | "integrity": "sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ==",
3000 | "dev": true,
3001 | "requires": {
3002 | "yocto-queue": "^0.1.0"
3003 | }
3004 | },
3005 | "p-locate": {
3006 | "version": "5.0.0",
3007 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-5.0.0.tgz",
3008 | "integrity": "sha512-LaNjtRWUBY++zB5nE/NwcaoMylSPk+S+ZHNB1TzdbMJMny6dynpAGt7X/tl/QYq3TIeE6nxHppbo2LGymrG5Pw==",
3009 | "dev": true,
3010 | "requires": {
3011 | "p-limit": "^3.0.2"
3012 | }
3013 | },
3014 | "parent-module": {
3015 | "version": "1.0.1",
3016 | "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz",
3017 | "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==",
3018 | "dev": true,
3019 | "requires": {
3020 | "callsites": "^3.0.0"
3021 | }
3022 | },
3023 | "path-exists": {
3024 | "version": "4.0.0",
3025 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz",
3026 | "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==",
3027 | "dev": true
3028 | },
3029 | "path-key": {
3030 | "version": "3.1.1",
3031 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz",
3032 | "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==",
3033 | "dev": true
3034 | },
3035 | "pathe": {
3036 | "version": "2.0.3",
3037 | "resolved": "https://registry.npmjs.org/pathe/-/pathe-2.0.3.tgz",
3038 | "integrity": "sha512-WUjGcAqP1gQacoQe+OBJsFA7Ld4DyXuUIjZ5cc75cLHvJ7dtNsTugphxIADwspS+AraAUePCKrSVtPLFj/F88w==",
3039 | "dev": true
3040 | },
3041 | "picomatch": {
3042 | "version": "4.0.2",
3043 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-4.0.2.tgz",
3044 | "integrity": "sha512-M7BAV6Rlcy5u+m6oPhAPFgJTzAioX/6B0DxyvDlo9l8+T3nLKbrczg2WLUyzd45L8RqfUMyGPzekbMvX2Ldkwg=="
3045 | },
3046 | "prelude-ls": {
3047 | "version": "1.2.1",
3048 | "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.2.1.tgz",
3049 | "integrity": "sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g==",
3050 | "dev": true
3051 | },
3052 | "punycode": {
3053 | "version": "2.3.1",
3054 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.3.1.tgz",
3055 | "integrity": "sha512-vYt7UD1U9Wg6138shLtLOvdAu+8DsC/ilFtEVHcH+wydcSpNE20AfSOduf6MkRFahL5FY7X1oU7nKVZFtfq8Fg==",
3056 | "dev": true
3057 | },
3058 | "resolve-from": {
3059 | "version": "4.0.0",
3060 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz",
3061 | "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==",
3062 | "dev": true
3063 | },
3064 | "resolve-pkg-maps": {
3065 | "version": "1.0.0",
3066 | "resolved": "https://registry.npmjs.org/resolve-pkg-maps/-/resolve-pkg-maps-1.0.0.tgz",
3067 | "integrity": "sha512-seS2Tj26TBVOC2NIc2rOe2y2ZO7efxITtLZcGSOnHHNOQ7CkiUBfw0Iw2ck6xkIhPwLhKNLS8BO+hEpngQlqzw==",
3068 | "dev": true
3069 | },
3070 | "rollup": {
3071 | "version": "4.41.1",
3072 | "resolved": "https://registry.npmjs.org/rollup/-/rollup-4.41.1.tgz",
3073 | "integrity": "sha512-cPmwD3FnFv8rKMBc1MxWCwVQFxwf1JEmSX3iQXrRVVG15zerAIXRjMFVWnd5Q5QvgKF7Aj+5ykXFhUl+QGnyOw==",
3074 | "devOptional": true,
3075 | "requires": {
3076 | "@rollup/rollup-android-arm-eabi": "4.41.1",
3077 | "@rollup/rollup-android-arm64": "4.41.1",
3078 | "@rollup/rollup-darwin-arm64": "4.41.1",
3079 | "@rollup/rollup-darwin-x64": "4.41.1",
3080 | "@rollup/rollup-freebsd-arm64": "4.41.1",
3081 | "@rollup/rollup-freebsd-x64": "4.41.1",
3082 | "@rollup/rollup-linux-arm-gnueabihf": "4.41.1",
3083 | "@rollup/rollup-linux-arm-musleabihf": "4.41.1",
3084 | "@rollup/rollup-linux-arm64-gnu": "4.41.1",
3085 | "@rollup/rollup-linux-arm64-musl": "4.41.1",
3086 | "@rollup/rollup-linux-loongarch64-gnu": "4.41.1",
3087 | "@rollup/rollup-linux-powerpc64le-gnu": "4.41.1",
3088 | "@rollup/rollup-linux-riscv64-gnu": "4.41.1",
3089 | "@rollup/rollup-linux-riscv64-musl": "4.41.1",
3090 | "@rollup/rollup-linux-s390x-gnu": "4.41.1",
3091 | "@rollup/rollup-linux-x64-gnu": "4.41.1",
3092 | "@rollup/rollup-linux-x64-musl": "4.41.1",
3093 | "@rollup/rollup-win32-arm64-msvc": "4.41.1",
3094 | "@rollup/rollup-win32-ia32-msvc": "4.41.1",
3095 | "@rollup/rollup-win32-x64-msvc": "4.41.1",
3096 | "@types/estree": "1.0.7",
3097 | "fsevents": "~2.3.2"
3098 | }
3099 | },
3100 | "rollup-plugin-esbuild": {
3101 | "version": "6.2.1",
3102 | "resolved": "https://registry.npmjs.org/rollup-plugin-esbuild/-/rollup-plugin-esbuild-6.2.1.tgz",
3103 | "integrity": "sha512-jTNOMGoMRhs0JuueJrJqbW8tOwxumaWYq+V5i+PD+8ecSCVkuX27tGW7BXqDgoULQ55rO7IdNxPcnsWtshz3AA==",
3104 | "dev": true,
3105 | "requires": {
3106 | "debug": "^4.4.0",
3107 | "es-module-lexer": "^1.6.0",
3108 | "get-tsconfig": "^4.10.0",
3109 | "unplugin-utils": "^0.2.4"
3110 | }
3111 | },
3112 | "shebang-command": {
3113 | "version": "2.0.0",
3114 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz",
3115 | "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==",
3116 | "dev": true,
3117 | "requires": {
3118 | "shebang-regex": "^3.0.0"
3119 | }
3120 | },
3121 | "shebang-regex": {
3122 | "version": "3.0.0",
3123 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz",
3124 | "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==",
3125 | "dev": true
3126 | },
3127 | "strip-json-comments": {
3128 | "version": "3.1.1",
3129 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz",
3130 | "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==",
3131 | "dev": true
3132 | },
3133 | "type-check": {
3134 | "version": "0.4.0",
3135 | "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.4.0.tgz",
3136 | "integrity": "sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew==",
3137 | "dev": true,
3138 | "requires": {
3139 | "prelude-ls": "^1.2.1"
3140 | }
3141 | },
3142 | "unplugin-utils": {
3143 | "version": "0.2.4",
3144 | "resolved": "https://registry.npmjs.org/unplugin-utils/-/unplugin-utils-0.2.4.tgz",
3145 | "integrity": "sha512-8U/MtpkPkkk3Atewj1+RcKIjb5WBimZ/WSLhhR3w6SsIj8XJuKTacSP8g+2JhfSGw0Cb125Y+2zA/IzJZDVbhA==",
3146 | "dev": true,
3147 | "requires": {
3148 | "pathe": "^2.0.2",
3149 | "picomatch": "^4.0.2"
3150 | }
3151 | },
3152 | "uri-js": {
3153 | "version": "4.4.1",
3154 | "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.4.1.tgz",
3155 | "integrity": "sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg==",
3156 | "dev": true,
3157 | "requires": {
3158 | "punycode": "^2.1.0"
3159 | }
3160 | },
3161 | "which": {
3162 | "version": "2.0.2",
3163 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz",
3164 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==",
3165 | "dev": true,
3166 | "requires": {
3167 | "isexe": "^2.0.0"
3168 | }
3169 | },
3170 | "yocto-queue": {
3171 | "version": "0.1.0",
3172 | "resolved": "https://registry.npmjs.org/yocto-queue/-/yocto-queue-0.1.0.tgz",
3173 | "integrity": "sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q==",
3174 | "dev": true
3175 | }
3176 | }
3177 | }
3178 |
--------------------------------------------------------------------------------
/package.json:
--------------------------------------------------------------------------------
1 | {
2 | "name": "rollup-plugin-import-css",
3 | "type": "module",
4 | "version": "4.0.1",
5 | "description": "A Rollup plugin to import CSS into JavaScript",
6 | "main": "dist/plugin.cjs",
7 | "module": "dist/plugin.js",
8 | "types": "types/plugin.d.ts",
9 | "engines": {
10 | "node": ">=16"
11 | },
12 | "scripts": {
13 | "build": "rollup -c",
14 | "lint": "eslint src",
15 | "test": "node --test test/index.test.js",
16 | "prepublishOnly": "npm run lint && npm run build && npm run test"
17 | },
18 | "keywords": [
19 | "rollup",
20 | "rollup-plugin",
21 | "css",
22 | "import",
23 | "modules"
24 | ],
25 | "files": [
26 | "dist",
27 | "types"
28 | ],
29 | "exports": {
30 | ".": {
31 | "types": "./types/plugin.d.ts",
32 | "import": "./dist/plugin.js",
33 | "require": "./dist/plugin.cjs"
34 | }
35 | },
36 | "repository": {
37 | "type": "git",
38 | "url": "git+https://github.com/jleeson/rollup-plugin-import-css.git"
39 | },
40 | "bugs": {
41 | "url": "https://github.com/jleeson/rollup-plugin-import-css/issues"
42 | },
43 | "homepage": "https://github.com/jleeson/rollup-plugin-import-css#readme",
44 | "author": "Jacob Leeson (https://twitter.com/jleesons)",
45 | "license": "MIT",
46 | "devDependencies": {
47 | "@eslint/js": "^9.27.0",
48 | "esbuild": "^0.25.5",
49 | "eslint": "^9.27.0",
50 | "globals": "^16.2.0",
51 | "rollup": "^4.41.1",
52 | "rollup-plugin-esbuild": "^6.2.1"
53 | },
54 | "dependencies": {
55 | "@rollup/pluginutils": "^5.1.4"
56 | },
57 | "peerDependencies": {
58 | "rollup": "^2.x.x || ^3.x.x || ^4.x.x"
59 | }
60 | }
61 |
--------------------------------------------------------------------------------
/rollup.config.js:
--------------------------------------------------------------------------------
1 | import esbuild from "rollup-plugin-esbuild";
2 | import { builtinModules } from "module";
3 | import fs from "fs";
4 |
5 | const { dependencies } = JSON.parse(fs.readFileSync(new URL("./package.json", import.meta.url)));
6 |
7 | export default {
8 | input: "src/index.js",
9 | output: [
10 | { file: "dist/plugin.js", format: "esm" },
11 | { file: "dist/plugin.cjs", format: "cjs", exports: "default" },
12 | ],
13 | plugins: [
14 | esbuild({ target: "node16" })
15 | ],
16 | external: builtinModules.concat(Object.keys(dependencies))
17 | };
--------------------------------------------------------------------------------
/src/index.js:
--------------------------------------------------------------------------------
1 | import { createFilter } from "@rollup/pluginutils";
2 | import path from "path";
3 |
4 | export default (options = {}) => {
5 | if (!options.transform) options.transform = (code) => code;
6 |
7 | const styles = {};
8 | const imports = {};
9 | const alwaysOutput = options.alwaysOutput ?? false;
10 | const preserveImports = options.preserveImports ?? true;
11 | const filter = createFilter(options.include ?? ["**/*.css"], options.exclude ?? []);
12 |
13 | /* function to sort the css imports in order - credit to rollup-plugin-postcss */
14 | const getRecursiveImportOrder = (id, getModuleInfo, seen = new Set()) => {
15 | if (seen.has(id)) return [];
16 |
17 | seen.add(id);
18 |
19 | const result = [id];
20 | const moduleInfo = getModuleInfo(id);
21 |
22 | if (moduleInfo) {
23 | getModuleInfo(id).importedIds.forEach((importFile) => {
24 | result.push(...getRecursiveImportOrder(importFile, getModuleInfo, seen));
25 | });
26 | }
27 |
28 | return result;
29 | };
30 |
31 | /* minify css */
32 | const minifyCSS = (css) => {
33 | /* Step 1: Remove comments but preserve quoted strings */
34 | return css.replace(/("([^"\\]|\\.)*"|'([^'\\]|\\.)*')|\/\*[^]*?\*\//g, (_, quoted) => quoted || "")
35 | /* Step 2: Remove spaces around ; and } — keep the closing brace */
36 | .replace(/\s*;\s*(})/g, ";$1")
37 | /* Step 3: Remove spaces around meta characters and operators */
38 | .replace(/\s*([*$~^|]?=|[{};,>~]|!important)\s*/g, "$1")
39 | /* Step 4: Remove spaces around + and - in selectors before { */
40 | .replace(/\s*([+-])\s*(?=[^}]*\{)/g, "$1")
41 | /* Step 5: Remove space after [, ( */
42 | .replace(/([[(])\s+/g, "$1")
43 | /* Step 6: Remove space before ], ) */
44 | .replace(/\s+([\])])/g, "$1")
45 | /* Step 7: Remove space around colon, only outside selectors */
46 | .replace(/({[^}]*?)\s*:\s*/g, "$1:")
47 | /* Step 8: Trim leading and trailing whitespace */
48 | .replace(/^\s+|\s+$/g, "")
49 | /* Step 9: Collapse multiple spaces into one */
50 | .replace(/(\s)\s+/g, "$1")
51 | /* Step 10: Replace newlines characters with a space. */
52 | .replace(/\n+/g, " ");
53 | };
54 |
55 | return {
56 | name: "import-css",
57 |
58 | resolveId(source, importer) {
59 | if (source.endsWith(".css") && (source.startsWith(".") || source.startsWith("/"))) {
60 | (imports[importer] = imports[importer] ?? []).push(source);
61 | return { id: path.resolve(path.dirname(importer), source) };
62 | }
63 |
64 | return null;
65 | },
66 |
67 | /* convert the css file to a module and save the code for a file output */
68 | async transform(code, id) {
69 | if (!filter(id)) return;
70 |
71 | const transformedCode = (options.minify) ? minifyCSS(await options.transform(code)) : await options.transform(code);
72 |
73 | /* cache the result */
74 | if (!styles[id] || styles[id] != transformedCode) {
75 | styles[id] = transformedCode;
76 | }
77 |
78 | /* if modules are enabled or an import uses native css module syntax, export it as a CSSStyleSheet */
79 | const moduleInfo = this.getModuleInfo(id);
80 | const attributes = moduleInfo.assertions != undefined ? moduleInfo.assertions : moduleInfo.attributes;
81 | if (options.modules || attributes?.type == "css") {
82 | return {
83 | code: `const sheet = new CSSStyleSheet();sheet.replaceSync(${JSON.stringify(transformedCode)});export default sheet;`,
84 | map: null
85 | };
86 | }
87 |
88 | /* if inject is enabled, we want to simply inject the stylesheet into the document head */
89 | if (options.inject) {
90 | return {
91 | code: `document.head.appendChild(document.createElement("style")).textContent=${JSON.stringify(transformedCode)};`,
92 | map: null
93 | };
94 | }
95 |
96 | return {
97 | code: `export default ${JSON.stringify(transformedCode)};`,
98 | map: null
99 | };
100 | },
101 |
102 | /* output a css file with all css that was imported without being assigned a variable */
103 | generateBundle(opts, bundle) {
104 |
105 | /* collect all the imported modules for each entry file */
106 | const modules = Object.keys(bundle).reduce((modules, file) => Object.assign(modules, bundle[file].modules), {});
107 | const entryChunk = Object.values(bundle).find((chunk) => chunk.facadeModuleId).facadeModuleId;
108 |
109 | /* remove css that was imported as a string, if there are no remaining stylesheets, we can return early */
110 | const stylesheets = Object.keys(styles).filter((id) => !modules[id]);
111 | if (!stylesheets.length) return;
112 |
113 | /* get the import order of the stylesheets and sort the array in place */
114 | const moduleIds = getRecursiveImportOrder(entryChunk, this.getModuleInfo);
115 | stylesheets.sort((a, b) => moduleIds.indexOf(a) - moduleIds.indexOf(b));
116 |
117 | /* if perserveModules is true, output the css files without bundling */
118 | if (opts.preserveModules && !options.output) {
119 | for (let id of stylesheets) {
120 | const relativeToEntry = path.dirname(path.relative(entryChunk, id));
121 | const outputPath = opts.dir ? opts.dir : path.dirname(opts.file);
122 | const relativePath = path.join(path.join(outputPath, relativeToEntry), path.basename(id));
123 | const fileName = relativePath.includes("node_modules") ? relativePath.split("/").at(-1) : relativePath;
124 |
125 | if (styles[id].trim().length <= 0 && !alwaysOutput) continue;
126 |
127 | this.emitFile({ type: "asset", fileName: fileName, source: styles[id] });
128 | }
129 |
130 | /* reinject the css import into the bundle based on the imports we have tracked */
131 | if (preserveImports) {
132 | for (let chunk of Object.values(bundle)) {
133 | if (chunk.type != "chunk" || !imports[chunk.facadeModuleId]) continue;
134 |
135 | for (let file of imports[chunk.facadeModuleId].reverse()) {
136 | const importPath = file.includes("node_modules") ? `./${file.split("/").at(-1)}` : file;
137 | if (chunk.code.includes(importPath)) continue;
138 |
139 | chunk.code = `import "${importPath}";\n${chunk.code}`;
140 | }
141 | }
142 | }
143 |
144 | return;
145 | }
146 |
147 | /* merge all css files into a single stylesheet */
148 | const css = stylesheets.map((id) => styles[id]).join("\n");
149 |
150 | if (css.trim().length <= 0 && !alwaysOutput) return;
151 |
152 | /* return the asset name by going through a set of possible options */
153 | const getAssetName = () => {
154 | const fileName = options.output ?? (opts.file ?? "bundle.js");
155 | return `${path.basename(fileName, path.extname(fileName))}.css`;
156 | };
157 |
158 | /* return the asset fileName by going through a set of possible options */
159 | const getAssetFileName = () => {
160 | if (options.output) return options.output;
161 | if (opts.assetFileNames) return undefined;
162 |
163 | return getAssetName();
164 | };
165 |
166 | this.emitFile({
167 | type: "asset",
168 | name: getAssetName(),
169 | fileName: getAssetFileName(),
170 | source: css
171 | });
172 | }
173 | };
174 | };
175 |
--------------------------------------------------------------------------------
/test/index.test.js:
--------------------------------------------------------------------------------
1 | import css from "../dist/plugin.js";
2 | import { rollup } from "rollup";
3 | import { builtinModules } from "module";
4 | import assert from "assert";
5 | import path from "path";
6 | import fs from "fs";
7 |
8 | const { dependencies } = JSON.parse(fs.readFileSync(new URL("../package.json", import.meta.url)));
9 |
10 | (async () => {
11 | const bundle = await rollup({
12 | input: "test/src/index.js",
13 | plugins: [css({ minify: true, output: "index.css" })],
14 | external: builtinModules.concat(Object.keys(dependencies))
15 | });
16 |
17 | await bundle.write({
18 | file: "test/dist/index.js",
19 | format: "esm",
20 | preserveModulesRoot: "test/src"
21 | });
22 |
23 | const source = fs.readFileSync(path.resolve("test/dist/index.js"), "utf8");
24 | const style = fs.readFileSync(path.resolve("test/dist/index.css"), "utf8");
25 |
26 | assert.strictEqual(source.includes(`import "./index.css"`), false, "the css import should be removed.");
27 | assert.strictEqual(style.includes(`.element{box-shadow:0px 16px 32px -10px rgba(17,24,38,0.1);}`), true, "negative values should be minified correctly.");
28 | assert.strictEqual(style.includes(`.test{top:calc(var(--variable-name));top: calc(var(--variable-name) + 10px);top: calc((10px + var(--variable-name)) * 2);}`), true, "nested parentheses should be minfied correctly.");
29 | assert.strictEqual(style.includes(`:is(.a-very-long-class-name,.b-very-long-class-name,.c-very-long-class-name) textarea{margin:0;}`), true, "new lines should be minified correctly.");
30 | assert.strictEqual(style.includes(`html[style*="--color-scheme: dark"]{color:blue;}`), true, "spaces should be preserved in css selectors.");
31 |
32 | fs.rmSync(path.resolve("test/dist/index.js"));
33 | fs.rmSync(path.resolve("test/dist/index.css"));
34 | fs.rmdirSync(path.resolve("test/dist"));
35 | })();
--------------------------------------------------------------------------------
/test/src/button/button.css:
--------------------------------------------------------------------------------
1 | .btn-primary {
2 | color: blue;
3 | }
--------------------------------------------------------------------------------
/test/src/button/button.js:
--------------------------------------------------------------------------------
1 | import "./button.css";
2 |
3 | export function button() {
4 | console.log("button");
5 | }
--------------------------------------------------------------------------------
/test/src/index.css:
--------------------------------------------------------------------------------
1 | .element {
2 | box-shadow: 0px 16px 32px -10px rgba(17, 24, 38, 0.1);
3 | }
4 |
5 | .another-element {
6 | background: red;
7 | }
8 |
9 | .test {
10 | top: calc(var(--variable-name));
11 | top: calc(var(--variable-name) + 10px);
12 | top: calc((10px + var(--variable-name)) * 2);
13 | }
14 |
15 | :is(.a-very-long-class-name, .b-very-long-class-name, .c-very-long-class-name)
16 | textarea {
17 | margin: 0;
18 | }
19 |
20 | html[style*="--color-scheme: dark"] {
21 | color: blue;
22 | }
--------------------------------------------------------------------------------
/test/src/index.js:
--------------------------------------------------------------------------------
1 | import { button } from "./button/button";
2 | import "./index.css";
3 |
4 | button();
--------------------------------------------------------------------------------
/types/plugin.d.ts:
--------------------------------------------------------------------------------
1 | import { Plugin, ResolveIdHook, TransformHook } from "rollup";
2 |
3 | declare interface Options {
4 | include?: string | string[];
5 | exclude?: string | string[];
6 | output?: string;
7 | transform?: Function;
8 | minify?: boolean;
9 | modules?: boolean;
10 | inject?: boolean;
11 | alwaysOutput?: boolean;
12 | preserveImports?: boolean;
13 | }
14 |
15 | export default function (options?: Options) : Plugin & {
16 | resolveId: ResolveIdHook;
17 | transform: TransformHook;
18 | }
--------------------------------------------------------------------------------