├── .github
└── workflows
│ ├── publish.yml
│ └── test.yml
├── .gitignore
├── .npmignore
├── README.md
├── lib
├── index.ts
├── joiValidator.ts
├── utils.ts
├── vestValidator.ts
└── zodValidator.ts
├── package-lock.json
├── package.json
├── test
├── joiValidator.test.ts
├── utils.test.ts
├── vestValidator.test.ts
└── zodValidator.test.ts
├── tsconfig.json
└── vitest.config.ts
/.github/workflows/publish.yml:
--------------------------------------------------------------------------------
1 | name: Publish to npm
2 |
3 | on:
4 | push:
5 | branches:
6 | - main
7 | paths:
8 | - "package.json"
9 |
10 | jobs:
11 | publish:
12 | runs-on: ubuntu-latest
13 | permissions:
14 | contents: write
15 |
16 | steps:
17 | - name: Checkout Repository
18 | uses: actions/checkout@v3
19 | with:
20 | fetch-depth: 0 # Ensure full history is fetched
21 |
22 | - name: Setup Node.js
23 | uses: actions/setup-node@v3
24 | with:
25 | node-version: 18
26 | registry-url: "https://registry.npmjs.org/"
27 |
28 | - name: Install Dependencies
29 | run: npm install
30 |
31 | - name: Check if Version Changed
32 | id: version-check
33 | run: |
34 | git fetch --tags --force
35 |
36 | # Fetch the latest version tag and remove "v" prefix if it exists
37 | LATEST_VERSION=$(git tag --sort=-v:refname | grep -E '^v?[0-9]+\.[0-9]+\.[0-9]+$' | head -n 1 | sed 's/^v//')
38 |
39 | # Get the version from package.json
40 | CURRENT_VERSION=$(node -p "require('./package.json').version")
41 |
42 | echo "Latest Git Tag: v$LATEST_VERSION"
43 | echo "Current package.json Version: v$CURRENT_VERSION"
44 |
45 | # Compare versions
46 | if [ "$LATEST_VERSION" != "$CURRENT_VERSION" ]; then
47 | echo "Version has changed. Proceeding with build and publish."
48 | echo "publish=true" >> $GITHUB_ENV
49 | else
50 | echo "No version change. Skipping build and publish."
51 | echo "publish=false" >> $GITHUB_ENV
52 | fi
53 |
54 | - name: Build Package
55 | if: env.publish == 'true'
56 | run: npm run build
57 |
58 | - name: Publish to npm
59 | if: env.publish == 'true'
60 | run: npm publish --access public
61 | env:
62 | NODE_AUTH_TOKEN: ${{ secrets.NPM_TOKEN }}
63 |
64 | - name: Create Git Tag
65 | if: env.publish == 'true'
66 | run: |
67 | CURRENT_VERSION=$(node -p "require('./package.json').version")
68 | git tag v$CURRENT_VERSION
69 | git push origin v$CURRENT_VERSION
70 | env:
71 | GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
72 |
--------------------------------------------------------------------------------
/.github/workflows/test.yml:
--------------------------------------------------------------------------------
1 | name: Run Test Cases
2 |
3 | on:
4 | push:
5 | branches:
6 | - main
7 | # This will trigger the workflow only if the following files are changed
8 | paths:
9 | - "lib/**"
10 | - "test/**"
11 | - "package.json"
12 | pull_request:
13 | branches:
14 | - main
15 | paths:
16 | - "lib/**"
17 | - "test/**"
18 | - "package.json"
19 |
20 | jobs:
21 | test:
22 | runs-on: ubuntu-latest
23 |
24 | steps:
25 | - name: Checkout Repository
26 | uses: actions/checkout@v3
27 |
28 | - name: Setup Node.js
29 | uses: actions/setup-node@v3
30 | with:
31 | node-version: 18
32 | cache: "npm"
33 |
34 | - name: Install Dependencies
35 | run: npm install
36 |
37 | - name: Run Tests
38 | run: npm run test:coverage
39 |
--------------------------------------------------------------------------------
/.gitignore:
--------------------------------------------------------------------------------
1 | node_modules
2 | dist
3 | package-lock.json
--------------------------------------------------------------------------------
/.npmignore:
--------------------------------------------------------------------------------
1 | src/
2 | node_modules/
3 | tsconfig.json
--------------------------------------------------------------------------------
/README.md:
--------------------------------------------------------------------------------
1 | # Formik Validation Adaptors
2 |
3 | A lightweight utility package that provides validation adaptors for Formik using popular validation libraries like **Zod** and **Joi**. Easily integrate robust validation into your Formik forms with minimal setup.
4 |
5 | ## Installation
6 |
7 | ```bash
8 | npm i formik-validation-adaptors
9 | ```
10 |
11 | ## Live Demo
12 |
13 | [](https://stackblitz.com/edit/vitejs-vite-vvbccumy?file=src%2FFormikValidationWithZod.tsx)
14 |
15 | ## Features
16 |
17 | - Zod Adaptor: Validate Formik forms using Zod, a TypeScript-first schema validation library.
18 | - Joi Adaptor: Validate Formik forms using Joi, a powerful schema description language and validator.
19 | - Lightweight: Only includes the validation logic you need.
20 | - TypeScript Support: Fully typed for better developer experience.
21 |
22 | ## Usage
23 |
24 | #### Zod Adaptor
25 |
26 | Validate Formik forms using Zod schemas.
27 |
28 | ```js
29 | import { formikZodValidator } from "formik-validation-adaptors";
30 | import { z } from "zod";
31 | import { Formik, Form, Field } from "formik";
32 |
33 | const schema = z.object({
34 | name: z.string().min(1, "Name is required"),
35 | email: z.string().email("Invalid email"),
36 | });
37 |
38 | const initialValues = {
39 | name: "",
40 | email: "",
41 | };
42 |
43 | const FormikValidationWithZod = () => (
44 | console.log(values)}
48 | >
49 | {({ errors }) => (
50 |
58 | )}
59 |
60 | );
61 |
62 | export default FormikValidationWithZod;
63 | ```
64 |
65 | #### Joi Adaptor
66 |
67 | Validate Formik forms using Joi schemas.
68 |
69 | ```js
70 | import { formikJoiValidator } from "formik-validation-adaptors";
71 | import Joi from "joi";
72 | import { Formik, Form, Field } from "formik";
73 |
74 | const schema = Joi.object({
75 | name: Joi.string().required().messages({
76 | "string.empty": "Name is required",
77 | }),
78 | email: Joi.string()
79 | .email({ tlds: { allow: false } })
80 | .required()
81 | .messages({
82 | "string.email": "Invalid email",
83 | "string.empty": "Email is required",
84 | }),
85 | });
86 |
87 | const initialValues = {
88 | name: "",
89 | email: "",
90 | };
91 |
92 | const FormikValidationWithJoi = () => (
93 | console.log(values)}
97 | >
98 | {({ errors }) => (
99 |
106 | )}
107 |
108 | );
109 |
110 | export default FormikValidationWithJoi;
111 | ```
112 |
113 | #### Vest Adaptor
114 |
115 | Validate Formik forms using Vest, a unit-testing-style validation framework.
116 |
117 | ```js
118 | import { formikVestValidator } from "formik-validation-adaptors";
119 | import { create, test, enforce } from "vest";
120 | import { Formik, Form, Field } from "formik";
121 |
122 | // Define a Vest validation suite
123 | const suite = create((data) => {
124 | test("name", "Name is required", () => {
125 | enforce(data.name).isNotEmpty();
126 | });
127 |
128 | test("email", "Invalid email format", () => {
129 | enforce(data.email).matches(/^[\w-.]+@([\w-]+\.)+[\w-]{2,4}$/);
130 | });
131 |
132 | test("password", "Password must be at least 6 characters", () => {
133 | enforce(data.password).longerThanOrEquals(6);
134 | });
135 | });
136 |
137 | const initialValues = {
138 | name: "",
139 | email: "",
140 | password: "",
141 | };
142 |
143 | const FormikValidationWithVest = () => (
144 | console.log(values)}
148 | >
149 | {({ errors }) => (
150 |
162 | )}
163 |
164 | );
165 |
166 | export default FormikValidationWithVest;
167 | ```
168 |
169 | ## Why Use This Package?
170 |
171 | - **Seamless Integration**: Easily integrate Zod or Joi validation with Formik.
172 | - **Type Safety**: Built with TypeScript for better type inference and error handling.
173 | - **Flexibility**: Supports both Zod and Joi validation libraries.
174 | - **Customizable**: Use your preferred validation library without additional boilerplate.
175 | - **Lightweight**: Only includes the validation logic you need, keeping your bundle size small.
176 |
177 | ## Author
178 |
179 | Maintained by [@kom50](https://github.com/kom50).
180 |
--------------------------------------------------------------------------------
/lib/index.ts:
--------------------------------------------------------------------------------
1 | import formikZodValidator from "./zodValidator.js";
2 | import formikJoiValidator from "./joiValidator.js";
3 | import formikVestValidator from "./vestValidator.js";
4 |
5 | export { formikZodValidator, formikJoiValidator, formikVestValidator };
6 |
--------------------------------------------------------------------------------
/lib/joiValidator.ts:
--------------------------------------------------------------------------------
1 | import { formatValidationErrors } from "./utils.js";
2 | import { Schema } from "joi";
3 |
4 | /**
5 | * A Formik-compatible validation function using Joi schema.
6 | *
7 | * @param {Schema} schema - The Joi schema used for validation.
8 | * @returns A validation function that Formik can use, returning validation errors.
9 | *
10 | * @example
11 | * ```ts
12 | * const schema = Joi.object({
13 | * name: Joi.string().min(3).required(),
14 | * email: Joi.string().email().required(),
15 | * });
16 | *
17 | * const formik = useFormik({
18 | * initialValues: { name: "", email: "" },
19 | * validate: formikJoiValidator(schema),
20 | * onSubmit: (values) => console.log(values),
21 | * });
22 | * ```
23 | */
24 | const formikJoiValidator = (schema: Schema) => {
25 | return async (values: Record) => {
26 | try {
27 | const { error } = schema.validate(values, {
28 | abortEarly: false,
29 | allowUnknown: true,
30 | });
31 |
32 | return error ? formatValidationErrors(error.details) : {};
33 | } catch (err) {
34 | return {};
35 | }
36 | };
37 | };
38 |
39 | export default formikJoiValidator;
40 |
--------------------------------------------------------------------------------
/lib/utils.ts:
--------------------------------------------------------------------------------
1 | export type ValidationErrors = Record;
2 |
3 | /**
4 | * Converts Joi or Zod errors into a Formik-compatible error object.
5 | *
6 | * @param errors - Array of error details from Joi or Zod
7 | * @returns A structured error object.
8 | */
9 | export const formatValidationErrors = (
10 | errors: { path: (string | number)[]; message: string }[]
11 | ): ValidationErrors => {
12 | return errors.reduce((acc: ValidationErrors, err) => {
13 | if (err.path.length > 0) acc[err.path.join(".")] = err.message;
14 | return acc;
15 | }, {});
16 | };
17 |
--------------------------------------------------------------------------------
/lib/vestValidator.ts:
--------------------------------------------------------------------------------
1 | import { Suite } from "vest";
2 |
3 | /**
4 | * A Formik-compatible validation function using Vest.
5 | *
6 | * @param {Suite void>} suite - The Vest test suite used for validation.
7 | * @returns A validation function for Formik, returning validation errors as an object.
8 | *
9 | * @example
10 | * ```ts
11 | * import vest, { test, create } from "vest";
12 | * import formikVestValidator from "./formikVestValidator";
13 | *
14 | * // Define a Vest validation suite
15 | * const suite = create((data) => {
16 | * test("name", "Name is required", () => {
17 | * enforce(data.name).isNotEmpty();
18 | * });
19 | *
20 | * test("email", "Invalid email format", () => {
21 | * enforce(data.email).matches(/^[\w-.]+@([\w-]+\.)+[\w-]{2,4}$/);
22 | * });
23 | * });
24 | *
25 | * // Use in Formik
26 | * const formik = useFormik({
27 | * initialValues: { name: "", email: "" },
28 | * validate: formikVestValidator(suite),
29 | * onSubmit: (values) => console.log(values),
30 | * });
31 | * ```
32 | */
33 | const formikVestValidator = (suite: Suite void>) => {
34 | return async (values: any): Promise> => {
35 | const result = suite(values);
36 |
37 | if (result.isValid()) return {};
38 |
39 | const errors = result.getErrors();
40 |
41 | const formattedErrors: Record = {};
42 | for (const key in errors) {
43 | if (errors[key]?.length > 0) {
44 | formattedErrors[key] = errors[key][0]; // Take the first error message
45 | }
46 | }
47 | return formattedErrors;
48 | };
49 | };
50 |
51 | export default formikVestValidator;
52 |
--------------------------------------------------------------------------------
/lib/zodValidator.ts:
--------------------------------------------------------------------------------
1 | import { ZodError, ZodTypeAny } from "zod";
2 | import { formatValidationErrors } from "./utils.js";
3 |
4 | /**
5 | * A Formik-compatible validation function using Zod schema.
6 | *
7 | * @param {ZodTypeAny} schema - The Zod schema used for validation
8 | * @returns A validation function that Formik can use, returning validation errors.
9 | *
10 | * @example
11 | * ```ts
12 | * const schema = z.object({
13 | * name: z.string().min(3, "Name must be at least 3 characters 1"),
14 | * email: z.string().email("Invalid email address"),
15 | * email1: z.string().email("Invalid email address"),
16 | * });
17 | *
18 | * const formik = useFormik({
19 | * initialValues: { name: "", email: "" },
20 | * validate: formikZodValidator(schema),
21 | * onSubmit: (values) => console.log(values),
22 | * });
23 | * ```
24 | */
25 | const formikZodValidator = (schema: ZodTypeAny) => {
26 | return async (values: Record) => {
27 | try {
28 | await schema.parseAsync(values);
29 | return {};
30 | } catch (error) {
31 | if (error instanceof ZodError) return formatValidationErrors(error.errors);
32 | return {};
33 | }
34 | };
35 | };
36 |
37 | export default formikZodValidator;
38 |
--------------------------------------------------------------------------------
/package-lock.json:
--------------------------------------------------------------------------------
1 | {
2 | "name": "formik-validation-adaptors",
3 | "version": "1.1.0",
4 | "lockfileVersion": 3,
5 | "requires": true,
6 | "packages": {
7 | "": {
8 | "name": "formik-validation-adaptors",
9 | "version": "1.1.0",
10 | "license": "ISC",
11 | "dependencies": {
12 | "joi": "^17.13.3",
13 | "vest": "^5.4.6",
14 | "zod": "^3.24.1"
15 | },
16 | "devDependencies": {
17 | "@vitest/coverage-istanbul": "^3.0.7",
18 | "typescript": "^5.7.3",
19 | "vitest": "^3.0.7"
20 | }
21 | },
22 | "node_modules/@ampproject/remapping": {
23 | "version": "2.3.0",
24 | "resolved": "https://registry.npmjs.org/@ampproject/remapping/-/remapping-2.3.0.tgz",
25 | "integrity": "sha512-30iZtAPgz+LTIYoeivqYo853f02jBYSd5uGnGpkFV0M3xOt9aN73erkgYAmZU43x4VfqcnLxW9Kpg3R5LC4YYw==",
26 | "dev": true,
27 | "license": "Apache-2.0",
28 | "dependencies": {
29 | "@jridgewell/gen-mapping": "^0.3.5",
30 | "@jridgewell/trace-mapping": "^0.3.24"
31 | },
32 | "engines": {
33 | "node": ">=6.0.0"
34 | }
35 | },
36 | "node_modules/@babel/code-frame": {
37 | "version": "7.26.2",
38 | "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.26.2.tgz",
39 | "integrity": "sha512-RJlIHRueQgwWitWgF8OdFYGZX328Ax5BCemNGlqHfplnRT9ESi8JkFlvaVYbS+UubVY6dpv87Fs2u5M29iNFVQ==",
40 | "dev": true,
41 | "license": "MIT",
42 | "dependencies": {
43 | "@babel/helper-validator-identifier": "^7.25.9",
44 | "js-tokens": "^4.0.0",
45 | "picocolors": "^1.0.0"
46 | },
47 | "engines": {
48 | "node": ">=6.9.0"
49 | }
50 | },
51 | "node_modules/@babel/compat-data": {
52 | "version": "7.26.8",
53 | "resolved": "https://registry.npmjs.org/@babel/compat-data/-/compat-data-7.26.8.tgz",
54 | "integrity": "sha512-oH5UPLMWR3L2wEFLnFJ1TZXqHufiTKAiLfqw5zkhS4dKXLJ10yVztfil/twG8EDTA4F/tvVNw9nOl4ZMslB8rQ==",
55 | "dev": true,
56 | "license": "MIT",
57 | "engines": {
58 | "node": ">=6.9.0"
59 | }
60 | },
61 | "node_modules/@babel/core": {
62 | "version": "7.26.9",
63 | "resolved": "https://registry.npmjs.org/@babel/core/-/core-7.26.9.tgz",
64 | "integrity": "sha512-lWBYIrF7qK5+GjY5Uy+/hEgp8OJWOD/rpy74GplYRhEauvbHDeFB8t5hPOZxCZ0Oxf4Cc36tK51/l3ymJysrKw==",
65 | "dev": true,
66 | "license": "MIT",
67 | "dependencies": {
68 | "@ampproject/remapping": "^2.2.0",
69 | "@babel/code-frame": "^7.26.2",
70 | "@babel/generator": "^7.26.9",
71 | "@babel/helper-compilation-targets": "^7.26.5",
72 | "@babel/helper-module-transforms": "^7.26.0",
73 | "@babel/helpers": "^7.26.9",
74 | "@babel/parser": "^7.26.9",
75 | "@babel/template": "^7.26.9",
76 | "@babel/traverse": "^7.26.9",
77 | "@babel/types": "^7.26.9",
78 | "convert-source-map": "^2.0.0",
79 | "debug": "^4.1.0",
80 | "gensync": "^1.0.0-beta.2",
81 | "json5": "^2.2.3",
82 | "semver": "^6.3.1"
83 | },
84 | "engines": {
85 | "node": ">=6.9.0"
86 | },
87 | "funding": {
88 | "type": "opencollective",
89 | "url": "https://opencollective.com/babel"
90 | }
91 | },
92 | "node_modules/@babel/core/node_modules/semver": {
93 | "version": "6.3.1",
94 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.1.tgz",
95 | "integrity": "sha512-BR7VvDCVHO+q2xBEWskxS6DJE1qRnb7DxzUrogb71CWoSficBxYsiAGd+Kl0mmq/MprG9yArRkyrQxTO6XjMzA==",
96 | "dev": true,
97 | "license": "ISC",
98 | "bin": {
99 | "semver": "bin/semver.js"
100 | }
101 | },
102 | "node_modules/@babel/generator": {
103 | "version": "7.26.9",
104 | "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.26.9.tgz",
105 | "integrity": "sha512-kEWdzjOAUMW4hAyrzJ0ZaTOu9OmpyDIQicIh0zg0EEcEkYXZb2TjtBhnHi2ViX7PKwZqF4xwqfAm299/QMP3lg==",
106 | "dev": true,
107 | "license": "MIT",
108 | "dependencies": {
109 | "@babel/parser": "^7.26.9",
110 | "@babel/types": "^7.26.9",
111 | "@jridgewell/gen-mapping": "^0.3.5",
112 | "@jridgewell/trace-mapping": "^0.3.25",
113 | "jsesc": "^3.0.2"
114 | },
115 | "engines": {
116 | "node": ">=6.9.0"
117 | }
118 | },
119 | "node_modules/@babel/helper-compilation-targets": {
120 | "version": "7.26.5",
121 | "resolved": "https://registry.npmjs.org/@babel/helper-compilation-targets/-/helper-compilation-targets-7.26.5.tgz",
122 | "integrity": "sha512-IXuyn5EkouFJscIDuFF5EsiSolseme1s0CZB+QxVugqJLYmKdxI1VfIBOst0SUu4rnk2Z7kqTwmoO1lp3HIfnA==",
123 | "dev": true,
124 | "license": "MIT",
125 | "dependencies": {
126 | "@babel/compat-data": "^7.26.5",
127 | "@babel/helper-validator-option": "^7.25.9",
128 | "browserslist": "^4.24.0",
129 | "lru-cache": "^5.1.1",
130 | "semver": "^6.3.1"
131 | },
132 | "engines": {
133 | "node": ">=6.9.0"
134 | }
135 | },
136 | "node_modules/@babel/helper-compilation-targets/node_modules/semver": {
137 | "version": "6.3.1",
138 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.1.tgz",
139 | "integrity": "sha512-BR7VvDCVHO+q2xBEWskxS6DJE1qRnb7DxzUrogb71CWoSficBxYsiAGd+Kl0mmq/MprG9yArRkyrQxTO6XjMzA==",
140 | "dev": true,
141 | "license": "ISC",
142 | "bin": {
143 | "semver": "bin/semver.js"
144 | }
145 | },
146 | "node_modules/@babel/helper-module-imports": {
147 | "version": "7.25.9",
148 | "resolved": "https://registry.npmjs.org/@babel/helper-module-imports/-/helper-module-imports-7.25.9.tgz",
149 | "integrity": "sha512-tnUA4RsrmflIM6W6RFTLFSXITtl0wKjgpnLgXyowocVPrbYrLUXSBXDgTs8BlbmIzIdlBySRQjINYs2BAkiLtw==",
150 | "dev": true,
151 | "license": "MIT",
152 | "dependencies": {
153 | "@babel/traverse": "^7.25.9",
154 | "@babel/types": "^7.25.9"
155 | },
156 | "engines": {
157 | "node": ">=6.9.0"
158 | }
159 | },
160 | "node_modules/@babel/helper-module-transforms": {
161 | "version": "7.26.0",
162 | "resolved": "https://registry.npmjs.org/@babel/helper-module-transforms/-/helper-module-transforms-7.26.0.tgz",
163 | "integrity": "sha512-xO+xu6B5K2czEnQye6BHA7DolFFmS3LB7stHZFaOLb1pAwO1HWLS8fXA+eh0A2yIvltPVmx3eNNDBJA2SLHXFw==",
164 | "dev": true,
165 | "license": "MIT",
166 | "dependencies": {
167 | "@babel/helper-module-imports": "^7.25.9",
168 | "@babel/helper-validator-identifier": "^7.25.9",
169 | "@babel/traverse": "^7.25.9"
170 | },
171 | "engines": {
172 | "node": ">=6.9.0"
173 | },
174 | "peerDependencies": {
175 | "@babel/core": "^7.0.0"
176 | }
177 | },
178 | "node_modules/@babel/helper-string-parser": {
179 | "version": "7.25.9",
180 | "resolved": "https://registry.npmjs.org/@babel/helper-string-parser/-/helper-string-parser-7.25.9.tgz",
181 | "integrity": "sha512-4A/SCr/2KLd5jrtOMFzaKjVtAei3+2r/NChoBNoZ3EyP/+GlhoaEGoWOZUmFmoITP7zOJyHIMm+DYRd8o3PvHA==",
182 | "dev": true,
183 | "license": "MIT",
184 | "engines": {
185 | "node": ">=6.9.0"
186 | }
187 | },
188 | "node_modules/@babel/helper-validator-identifier": {
189 | "version": "7.25.9",
190 | "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.25.9.tgz",
191 | "integrity": "sha512-Ed61U6XJc3CVRfkERJWDz4dJwKe7iLmmJsbOGu9wSloNSFttHV0I8g6UAgb7qnK5ly5bGLPd4oXZlxCdANBOWQ==",
192 | "dev": true,
193 | "license": "MIT",
194 | "engines": {
195 | "node": ">=6.9.0"
196 | }
197 | },
198 | "node_modules/@babel/helper-validator-option": {
199 | "version": "7.25.9",
200 | "resolved": "https://registry.npmjs.org/@babel/helper-validator-option/-/helper-validator-option-7.25.9.tgz",
201 | "integrity": "sha512-e/zv1co8pp55dNdEcCynfj9X7nyUKUXoUEwfXqaZt0omVOmDe9oOTdKStH4GmAw6zxMFs50ZayuMfHDKlO7Tfw==",
202 | "dev": true,
203 | "license": "MIT",
204 | "engines": {
205 | "node": ">=6.9.0"
206 | }
207 | },
208 | "node_modules/@babel/helpers": {
209 | "version": "7.26.9",
210 | "resolved": "https://registry.npmjs.org/@babel/helpers/-/helpers-7.26.9.tgz",
211 | "integrity": "sha512-Mz/4+y8udxBKdmzt/UjPACs4G3j5SshJJEFFKxlCGPydG4JAHXxjWjAwjd09tf6oINvl1VfMJo+nB7H2YKQ0dA==",
212 | "dev": true,
213 | "license": "MIT",
214 | "dependencies": {
215 | "@babel/template": "^7.26.9",
216 | "@babel/types": "^7.26.9"
217 | },
218 | "engines": {
219 | "node": ">=6.9.0"
220 | }
221 | },
222 | "node_modules/@babel/parser": {
223 | "version": "7.26.9",
224 | "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.26.9.tgz",
225 | "integrity": "sha512-81NWa1njQblgZbQHxWHpxxCzNsa3ZwvFqpUg7P+NNUU6f3UU2jBEg4OlF/J6rl8+PQGh1q6/zWScd001YwcA5A==",
226 | "dev": true,
227 | "license": "MIT",
228 | "dependencies": {
229 | "@babel/types": "^7.26.9"
230 | },
231 | "bin": {
232 | "parser": "bin/babel-parser.js"
233 | },
234 | "engines": {
235 | "node": ">=6.0.0"
236 | }
237 | },
238 | "node_modules/@babel/template": {
239 | "version": "7.26.9",
240 | "resolved": "https://registry.npmjs.org/@babel/template/-/template-7.26.9.tgz",
241 | "integrity": "sha512-qyRplbeIpNZhmzOysF/wFMuP9sctmh2cFzRAZOn1YapxBsE1i9bJIY586R/WBLfLcmcBlM8ROBiQURnnNy+zfA==",
242 | "dev": true,
243 | "license": "MIT",
244 | "dependencies": {
245 | "@babel/code-frame": "^7.26.2",
246 | "@babel/parser": "^7.26.9",
247 | "@babel/types": "^7.26.9"
248 | },
249 | "engines": {
250 | "node": ">=6.9.0"
251 | }
252 | },
253 | "node_modules/@babel/traverse": {
254 | "version": "7.26.9",
255 | "resolved": "https://registry.npmjs.org/@babel/traverse/-/traverse-7.26.9.tgz",
256 | "integrity": "sha512-ZYW7L+pL8ahU5fXmNbPF+iZFHCv5scFak7MZ9bwaRPLUhHh7QQEMjZUg0HevihoqCM5iSYHN61EyCoZvqC+bxg==",
257 | "dev": true,
258 | "license": "MIT",
259 | "dependencies": {
260 | "@babel/code-frame": "^7.26.2",
261 | "@babel/generator": "^7.26.9",
262 | "@babel/parser": "^7.26.9",
263 | "@babel/template": "^7.26.9",
264 | "@babel/types": "^7.26.9",
265 | "debug": "^4.3.1",
266 | "globals": "^11.1.0"
267 | },
268 | "engines": {
269 | "node": ">=6.9.0"
270 | }
271 | },
272 | "node_modules/@babel/types": {
273 | "version": "7.26.9",
274 | "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.26.9.tgz",
275 | "integrity": "sha512-Y3IR1cRnOxOCDvMmNiym7XpXQ93iGDDPHx+Zj+NM+rg0fBaShfQLkg+hKPaZCEvg5N/LeCo4+Rj/i3FuJsIQaw==",
276 | "dev": true,
277 | "license": "MIT",
278 | "dependencies": {
279 | "@babel/helper-string-parser": "^7.25.9",
280 | "@babel/helper-validator-identifier": "^7.25.9"
281 | },
282 | "engines": {
283 | "node": ">=6.9.0"
284 | }
285 | },
286 | "node_modules/@esbuild/aix-ppc64": {
287 | "version": "0.25.0",
288 | "resolved": "https://registry.npmjs.org/@esbuild/aix-ppc64/-/aix-ppc64-0.25.0.tgz",
289 | "integrity": "sha512-O7vun9Sf8DFjH2UtqK8Ku3LkquL9SZL8OLY1T5NZkA34+wG3OQF7cl4Ql8vdNzM6fzBbYfLaiRLIOZ+2FOCgBQ==",
290 | "cpu": [
291 | "ppc64"
292 | ],
293 | "dev": true,
294 | "license": "MIT",
295 | "optional": true,
296 | "os": [
297 | "aix"
298 | ],
299 | "engines": {
300 | "node": ">=18"
301 | }
302 | },
303 | "node_modules/@esbuild/android-arm": {
304 | "version": "0.25.0",
305 | "resolved": "https://registry.npmjs.org/@esbuild/android-arm/-/android-arm-0.25.0.tgz",
306 | "integrity": "sha512-PTyWCYYiU0+1eJKmw21lWtC+d08JDZPQ5g+kFyxP0V+es6VPPSUhM6zk8iImp2jbV6GwjX4pap0JFbUQN65X1g==",
307 | "cpu": [
308 | "arm"
309 | ],
310 | "dev": true,
311 | "license": "MIT",
312 | "optional": true,
313 | "os": [
314 | "android"
315 | ],
316 | "engines": {
317 | "node": ">=18"
318 | }
319 | },
320 | "node_modules/@esbuild/android-arm64": {
321 | "version": "0.25.0",
322 | "resolved": "https://registry.npmjs.org/@esbuild/android-arm64/-/android-arm64-0.25.0.tgz",
323 | "integrity": "sha512-grvv8WncGjDSyUBjN9yHXNt+cq0snxXbDxy5pJtzMKGmmpPxeAmAhWxXI+01lU5rwZomDgD3kJwulEnhTRUd6g==",
324 | "cpu": [
325 | "arm64"
326 | ],
327 | "dev": true,
328 | "license": "MIT",
329 | "optional": true,
330 | "os": [
331 | "android"
332 | ],
333 | "engines": {
334 | "node": ">=18"
335 | }
336 | },
337 | "node_modules/@esbuild/android-x64": {
338 | "version": "0.25.0",
339 | "resolved": "https://registry.npmjs.org/@esbuild/android-x64/-/android-x64-0.25.0.tgz",
340 | "integrity": "sha512-m/ix7SfKG5buCnxasr52+LI78SQ+wgdENi9CqyCXwjVR2X4Jkz+BpC3le3AoBPYTC9NHklwngVXvbJ9/Akhrfg==",
341 | "cpu": [
342 | "x64"
343 | ],
344 | "dev": true,
345 | "license": "MIT",
346 | "optional": true,
347 | "os": [
348 | "android"
349 | ],
350 | "engines": {
351 | "node": ">=18"
352 | }
353 | },
354 | "node_modules/@esbuild/darwin-arm64": {
355 | "version": "0.25.0",
356 | "resolved": "https://registry.npmjs.org/@esbuild/darwin-arm64/-/darwin-arm64-0.25.0.tgz",
357 | "integrity": "sha512-mVwdUb5SRkPayVadIOI78K7aAnPamoeFR2bT5nszFUZ9P8UpK4ratOdYbZZXYSqPKMHfS1wdHCJk1P1EZpRdvw==",
358 | "cpu": [
359 | "arm64"
360 | ],
361 | "dev": true,
362 | "license": "MIT",
363 | "optional": true,
364 | "os": [
365 | "darwin"
366 | ],
367 | "engines": {
368 | "node": ">=18"
369 | }
370 | },
371 | "node_modules/@esbuild/darwin-x64": {
372 | "version": "0.25.0",
373 | "resolved": "https://registry.npmjs.org/@esbuild/darwin-x64/-/darwin-x64-0.25.0.tgz",
374 | "integrity": "sha512-DgDaYsPWFTS4S3nWpFcMn/33ZZwAAeAFKNHNa1QN0rI4pUjgqf0f7ONmXf6d22tqTY+H9FNdgeaAa+YIFUn2Rg==",
375 | "cpu": [
376 | "x64"
377 | ],
378 | "dev": true,
379 | "license": "MIT",
380 | "optional": true,
381 | "os": [
382 | "darwin"
383 | ],
384 | "engines": {
385 | "node": ">=18"
386 | }
387 | },
388 | "node_modules/@esbuild/freebsd-arm64": {
389 | "version": "0.25.0",
390 | "resolved": "https://registry.npmjs.org/@esbuild/freebsd-arm64/-/freebsd-arm64-0.25.0.tgz",
391 | "integrity": "sha512-VN4ocxy6dxefN1MepBx/iD1dH5K8qNtNe227I0mnTRjry8tj5MRk4zprLEdG8WPyAPb93/e4pSgi1SoHdgOa4w==",
392 | "cpu": [
393 | "arm64"
394 | ],
395 | "dev": true,
396 | "license": "MIT",
397 | "optional": true,
398 | "os": [
399 | "freebsd"
400 | ],
401 | "engines": {
402 | "node": ">=18"
403 | }
404 | },
405 | "node_modules/@esbuild/freebsd-x64": {
406 | "version": "0.25.0",
407 | "resolved": "https://registry.npmjs.org/@esbuild/freebsd-x64/-/freebsd-x64-0.25.0.tgz",
408 | "integrity": "sha512-mrSgt7lCh07FY+hDD1TxiTyIHyttn6vnjesnPoVDNmDfOmggTLXRv8Id5fNZey1gl/V2dyVK1VXXqVsQIiAk+A==",
409 | "cpu": [
410 | "x64"
411 | ],
412 | "dev": true,
413 | "license": "MIT",
414 | "optional": true,
415 | "os": [
416 | "freebsd"
417 | ],
418 | "engines": {
419 | "node": ">=18"
420 | }
421 | },
422 | "node_modules/@esbuild/linux-arm": {
423 | "version": "0.25.0",
424 | "resolved": "https://registry.npmjs.org/@esbuild/linux-arm/-/linux-arm-0.25.0.tgz",
425 | "integrity": "sha512-vkB3IYj2IDo3g9xX7HqhPYxVkNQe8qTK55fraQyTzTX/fxaDtXiEnavv9geOsonh2Fd2RMB+i5cbhu2zMNWJwg==",
426 | "cpu": [
427 | "arm"
428 | ],
429 | "dev": true,
430 | "license": "MIT",
431 | "optional": true,
432 | "os": [
433 | "linux"
434 | ],
435 | "engines": {
436 | "node": ">=18"
437 | }
438 | },
439 | "node_modules/@esbuild/linux-arm64": {
440 | "version": "0.25.0",
441 | "resolved": "https://registry.npmjs.org/@esbuild/linux-arm64/-/linux-arm64-0.25.0.tgz",
442 | "integrity": "sha512-9QAQjTWNDM/Vk2bgBl17yWuZxZNQIF0OUUuPZRKoDtqF2k4EtYbpyiG5/Dk7nqeK6kIJWPYldkOcBqjXjrUlmg==",
443 | "cpu": [
444 | "arm64"
445 | ],
446 | "dev": true,
447 | "license": "MIT",
448 | "optional": true,
449 | "os": [
450 | "linux"
451 | ],
452 | "engines": {
453 | "node": ">=18"
454 | }
455 | },
456 | "node_modules/@esbuild/linux-ia32": {
457 | "version": "0.25.0",
458 | "resolved": "https://registry.npmjs.org/@esbuild/linux-ia32/-/linux-ia32-0.25.0.tgz",
459 | "integrity": "sha512-43ET5bHbphBegyeqLb7I1eYn2P/JYGNmzzdidq/w0T8E2SsYL1U6un2NFROFRg1JZLTzdCoRomg8Rvf9M6W6Gg==",
460 | "cpu": [
461 | "ia32"
462 | ],
463 | "dev": true,
464 | "license": "MIT",
465 | "optional": true,
466 | "os": [
467 | "linux"
468 | ],
469 | "engines": {
470 | "node": ">=18"
471 | }
472 | },
473 | "node_modules/@esbuild/linux-loong64": {
474 | "version": "0.25.0",
475 | "resolved": "https://registry.npmjs.org/@esbuild/linux-loong64/-/linux-loong64-0.25.0.tgz",
476 | "integrity": "sha512-fC95c/xyNFueMhClxJmeRIj2yrSMdDfmqJnyOY4ZqsALkDrrKJfIg5NTMSzVBr5YW1jf+l7/cndBfP3MSDpoHw==",
477 | "cpu": [
478 | "loong64"
479 | ],
480 | "dev": true,
481 | "license": "MIT",
482 | "optional": true,
483 | "os": [
484 | "linux"
485 | ],
486 | "engines": {
487 | "node": ">=18"
488 | }
489 | },
490 | "node_modules/@esbuild/linux-mips64el": {
491 | "version": "0.25.0",
492 | "resolved": "https://registry.npmjs.org/@esbuild/linux-mips64el/-/linux-mips64el-0.25.0.tgz",
493 | "integrity": "sha512-nkAMFju7KDW73T1DdH7glcyIptm95a7Le8irTQNO/qtkoyypZAnjchQgooFUDQhNAy4iu08N79W4T4pMBwhPwQ==",
494 | "cpu": [
495 | "mips64el"
496 | ],
497 | "dev": true,
498 | "license": "MIT",
499 | "optional": true,
500 | "os": [
501 | "linux"
502 | ],
503 | "engines": {
504 | "node": ">=18"
505 | }
506 | },
507 | "node_modules/@esbuild/linux-ppc64": {
508 | "version": "0.25.0",
509 | "resolved": "https://registry.npmjs.org/@esbuild/linux-ppc64/-/linux-ppc64-0.25.0.tgz",
510 | "integrity": "sha512-NhyOejdhRGS8Iwv+KKR2zTq2PpysF9XqY+Zk77vQHqNbo/PwZCzB5/h7VGuREZm1fixhs4Q/qWRSi5zmAiO4Fw==",
511 | "cpu": [
512 | "ppc64"
513 | ],
514 | "dev": true,
515 | "license": "MIT",
516 | "optional": true,
517 | "os": [
518 | "linux"
519 | ],
520 | "engines": {
521 | "node": ">=18"
522 | }
523 | },
524 | "node_modules/@esbuild/linux-riscv64": {
525 | "version": "0.25.0",
526 | "resolved": "https://registry.npmjs.org/@esbuild/linux-riscv64/-/linux-riscv64-0.25.0.tgz",
527 | "integrity": "sha512-5S/rbP5OY+GHLC5qXp1y/Mx//e92L1YDqkiBbO9TQOvuFXM+iDqUNG5XopAnXoRH3FjIUDkeGcY1cgNvnXp/kA==",
528 | "cpu": [
529 | "riscv64"
530 | ],
531 | "dev": true,
532 | "license": "MIT",
533 | "optional": true,
534 | "os": [
535 | "linux"
536 | ],
537 | "engines": {
538 | "node": ">=18"
539 | }
540 | },
541 | "node_modules/@esbuild/linux-s390x": {
542 | "version": "0.25.0",
543 | "resolved": "https://registry.npmjs.org/@esbuild/linux-s390x/-/linux-s390x-0.25.0.tgz",
544 | "integrity": "sha512-XM2BFsEBz0Fw37V0zU4CXfcfuACMrppsMFKdYY2WuTS3yi8O1nFOhil/xhKTmE1nPmVyvQJjJivgDT+xh8pXJA==",
545 | "cpu": [
546 | "s390x"
547 | ],
548 | "dev": true,
549 | "license": "MIT",
550 | "optional": true,
551 | "os": [
552 | "linux"
553 | ],
554 | "engines": {
555 | "node": ">=18"
556 | }
557 | },
558 | "node_modules/@esbuild/linux-x64": {
559 | "version": "0.25.0",
560 | "resolved": "https://registry.npmjs.org/@esbuild/linux-x64/-/linux-x64-0.25.0.tgz",
561 | "integrity": "sha512-9yl91rHw/cpwMCNytUDxwj2XjFpxML0y9HAOH9pNVQDpQrBxHy01Dx+vaMu0N1CKa/RzBD2hB4u//nfc+Sd3Cw==",
562 | "cpu": [
563 | "x64"
564 | ],
565 | "dev": true,
566 | "license": "MIT",
567 | "optional": true,
568 | "os": [
569 | "linux"
570 | ],
571 | "engines": {
572 | "node": ">=18"
573 | }
574 | },
575 | "node_modules/@esbuild/netbsd-arm64": {
576 | "version": "0.25.0",
577 | "resolved": "https://registry.npmjs.org/@esbuild/netbsd-arm64/-/netbsd-arm64-0.25.0.tgz",
578 | "integrity": "sha512-RuG4PSMPFfrkH6UwCAqBzauBWTygTvb1nxWasEJooGSJ/NwRw7b2HOwyRTQIU97Hq37l3npXoZGYMy3b3xYvPw==",
579 | "cpu": [
580 | "arm64"
581 | ],
582 | "dev": true,
583 | "license": "MIT",
584 | "optional": true,
585 | "os": [
586 | "netbsd"
587 | ],
588 | "engines": {
589 | "node": ">=18"
590 | }
591 | },
592 | "node_modules/@esbuild/netbsd-x64": {
593 | "version": "0.25.0",
594 | "resolved": "https://registry.npmjs.org/@esbuild/netbsd-x64/-/netbsd-x64-0.25.0.tgz",
595 | "integrity": "sha512-jl+qisSB5jk01N5f7sPCsBENCOlPiS/xptD5yxOx2oqQfyourJwIKLRA2yqWdifj3owQZCL2sn6o08dBzZGQzA==",
596 | "cpu": [
597 | "x64"
598 | ],
599 | "dev": true,
600 | "license": "MIT",
601 | "optional": true,
602 | "os": [
603 | "netbsd"
604 | ],
605 | "engines": {
606 | "node": ">=18"
607 | }
608 | },
609 | "node_modules/@esbuild/openbsd-arm64": {
610 | "version": "0.25.0",
611 | "resolved": "https://registry.npmjs.org/@esbuild/openbsd-arm64/-/openbsd-arm64-0.25.0.tgz",
612 | "integrity": "sha512-21sUNbq2r84YE+SJDfaQRvdgznTD8Xc0oc3p3iW/a1EVWeNj/SdUCbm5U0itZPQYRuRTW20fPMWMpcrciH2EJw==",
613 | "cpu": [
614 | "arm64"
615 | ],
616 | "dev": true,
617 | "license": "MIT",
618 | "optional": true,
619 | "os": [
620 | "openbsd"
621 | ],
622 | "engines": {
623 | "node": ">=18"
624 | }
625 | },
626 | "node_modules/@esbuild/openbsd-x64": {
627 | "version": "0.25.0",
628 | "resolved": "https://registry.npmjs.org/@esbuild/openbsd-x64/-/openbsd-x64-0.25.0.tgz",
629 | "integrity": "sha512-2gwwriSMPcCFRlPlKx3zLQhfN/2WjJ2NSlg5TKLQOJdV0mSxIcYNTMhk3H3ulL/cak+Xj0lY1Ym9ysDV1igceg==",
630 | "cpu": [
631 | "x64"
632 | ],
633 | "dev": true,
634 | "license": "MIT",
635 | "optional": true,
636 | "os": [
637 | "openbsd"
638 | ],
639 | "engines": {
640 | "node": ">=18"
641 | }
642 | },
643 | "node_modules/@esbuild/sunos-x64": {
644 | "version": "0.25.0",
645 | "resolved": "https://registry.npmjs.org/@esbuild/sunos-x64/-/sunos-x64-0.25.0.tgz",
646 | "integrity": "sha512-bxI7ThgLzPrPz484/S9jLlvUAHYMzy6I0XiU1ZMeAEOBcS0VePBFxh1JjTQt3Xiat5b6Oh4x7UC7IwKQKIJRIg==",
647 | "cpu": [
648 | "x64"
649 | ],
650 | "dev": true,
651 | "license": "MIT",
652 | "optional": true,
653 | "os": [
654 | "sunos"
655 | ],
656 | "engines": {
657 | "node": ">=18"
658 | }
659 | },
660 | "node_modules/@esbuild/win32-arm64": {
661 | "version": "0.25.0",
662 | "resolved": "https://registry.npmjs.org/@esbuild/win32-arm64/-/win32-arm64-0.25.0.tgz",
663 | "integrity": "sha512-ZUAc2YK6JW89xTbXvftxdnYy3m4iHIkDtK3CLce8wg8M2L+YZhIvO1DKpxrd0Yr59AeNNkTiic9YLf6FTtXWMw==",
664 | "cpu": [
665 | "arm64"
666 | ],
667 | "dev": true,
668 | "license": "MIT",
669 | "optional": true,
670 | "os": [
671 | "win32"
672 | ],
673 | "engines": {
674 | "node": ">=18"
675 | }
676 | },
677 | "node_modules/@esbuild/win32-ia32": {
678 | "version": "0.25.0",
679 | "resolved": "https://registry.npmjs.org/@esbuild/win32-ia32/-/win32-ia32-0.25.0.tgz",
680 | "integrity": "sha512-eSNxISBu8XweVEWG31/JzjkIGbGIJN/TrRoiSVZwZ6pkC6VX4Im/WV2cz559/TXLcYbcrDN8JtKgd9DJVIo8GA==",
681 | "cpu": [
682 | "ia32"
683 | ],
684 | "dev": true,
685 | "license": "MIT",
686 | "optional": true,
687 | "os": [
688 | "win32"
689 | ],
690 | "engines": {
691 | "node": ">=18"
692 | }
693 | },
694 | "node_modules/@esbuild/win32-x64": {
695 | "version": "0.25.0",
696 | "resolved": "https://registry.npmjs.org/@esbuild/win32-x64/-/win32-x64-0.25.0.tgz",
697 | "integrity": "sha512-ZENoHJBxA20C2zFzh6AI4fT6RraMzjYw4xKWemRTRmRVtN9c5DcH9r/f2ihEkMjOW5eGgrwCslG/+Y/3bL+DHQ==",
698 | "cpu": [
699 | "x64"
700 | ],
701 | "dev": true,
702 | "license": "MIT",
703 | "optional": true,
704 | "os": [
705 | "win32"
706 | ],
707 | "engines": {
708 | "node": ">=18"
709 | }
710 | },
711 | "node_modules/@hapi/hoek": {
712 | "version": "9.3.0",
713 | "resolved": "https://registry.npmjs.org/@hapi/hoek/-/hoek-9.3.0.tgz",
714 | "integrity": "sha512-/c6rf4UJlmHlC9b5BaNvzAcFv7HZ2QHaV0D4/HNlBdvFnvQq8RI4kYdhyPCl7Xj+oWvTWQ8ujhqS53LIgAe6KQ==",
715 | "license": "BSD-3-Clause"
716 | },
717 | "node_modules/@hapi/topo": {
718 | "version": "5.1.0",
719 | "resolved": "https://registry.npmjs.org/@hapi/topo/-/topo-5.1.0.tgz",
720 | "integrity": "sha512-foQZKJig7Ob0BMAYBfcJk8d77QtOe7Wo4ox7ff1lQYoNNAb6jwcY1ncdoy2e9wQZzvNy7ODZCYJkK8kzmcAnAg==",
721 | "license": "BSD-3-Clause",
722 | "dependencies": {
723 | "@hapi/hoek": "^9.0.0"
724 | }
725 | },
726 | "node_modules/@isaacs/cliui": {
727 | "version": "8.0.2",
728 | "resolved": "https://registry.npmjs.org/@isaacs/cliui/-/cliui-8.0.2.tgz",
729 | "integrity": "sha512-O8jcjabXaleOG9DQ0+ARXWZBTfnP4WNAqzuiJK7ll44AmxGKv/J2M4TPjxjY3znBCfvBXFzucm1twdyFybFqEA==",
730 | "dev": true,
731 | "license": "ISC",
732 | "dependencies": {
733 | "string-width": "^5.1.2",
734 | "string-width-cjs": "npm:string-width@^4.2.0",
735 | "strip-ansi": "^7.0.1",
736 | "strip-ansi-cjs": "npm:strip-ansi@^6.0.1",
737 | "wrap-ansi": "^8.1.0",
738 | "wrap-ansi-cjs": "npm:wrap-ansi@^7.0.0"
739 | },
740 | "engines": {
741 | "node": ">=12"
742 | }
743 | },
744 | "node_modules/@istanbuljs/schema": {
745 | "version": "0.1.3",
746 | "resolved": "https://registry.npmjs.org/@istanbuljs/schema/-/schema-0.1.3.tgz",
747 | "integrity": "sha512-ZXRY4jNvVgSVQ8DL3LTcakaAtXwTVUxE81hslsyD2AtoXW/wVob10HkOJ1X/pAlcI7D+2YoZKg5do8G/w6RYgA==",
748 | "dev": true,
749 | "license": "MIT",
750 | "engines": {
751 | "node": ">=8"
752 | }
753 | },
754 | "node_modules/@jridgewell/gen-mapping": {
755 | "version": "0.3.8",
756 | "resolved": "https://registry.npmjs.org/@jridgewell/gen-mapping/-/gen-mapping-0.3.8.tgz",
757 | "integrity": "sha512-imAbBGkb+ebQyxKgzv5Hu2nmROxoDOXHh80evxdoXNOrvAnVx7zimzc1Oo5h9RlfV4vPXaE2iM5pOFbvOCClWA==",
758 | "dev": true,
759 | "license": "MIT",
760 | "dependencies": {
761 | "@jridgewell/set-array": "^1.2.1",
762 | "@jridgewell/sourcemap-codec": "^1.4.10",
763 | "@jridgewell/trace-mapping": "^0.3.24"
764 | },
765 | "engines": {
766 | "node": ">=6.0.0"
767 | }
768 | },
769 | "node_modules/@jridgewell/resolve-uri": {
770 | "version": "3.1.2",
771 | "resolved": "https://registry.npmjs.org/@jridgewell/resolve-uri/-/resolve-uri-3.1.2.tgz",
772 | "integrity": "sha512-bRISgCIjP20/tbWSPWMEi54QVPRZExkuD9lJL+UIxUKtwVJA8wW1Trb1jMs1RFXo1CBTNZ/5hpC9QvmKWdopKw==",
773 | "dev": true,
774 | "license": "MIT",
775 | "engines": {
776 | "node": ">=6.0.0"
777 | }
778 | },
779 | "node_modules/@jridgewell/set-array": {
780 | "version": "1.2.1",
781 | "resolved": "https://registry.npmjs.org/@jridgewell/set-array/-/set-array-1.2.1.tgz",
782 | "integrity": "sha512-R8gLRTZeyp03ymzP/6Lil/28tGeGEzhx1q2k703KGWRAI1VdvPIXdG70VJc2pAMw3NA6JKL5hhFu1sJX0Mnn/A==",
783 | "dev": true,
784 | "license": "MIT",
785 | "engines": {
786 | "node": ">=6.0.0"
787 | }
788 | },
789 | "node_modules/@jridgewell/sourcemap-codec": {
790 | "version": "1.5.0",
791 | "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.5.0.tgz",
792 | "integrity": "sha512-gv3ZRaISU3fjPAgNsriBRqGWQL6quFx04YMPW/zD8XMLsU32mhCCbfbO6KZFLjvYpCZ8zyDEgqsgf+PwPaM7GQ==",
793 | "dev": true,
794 | "license": "MIT"
795 | },
796 | "node_modules/@jridgewell/trace-mapping": {
797 | "version": "0.3.25",
798 | "resolved": "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.25.tgz",
799 | "integrity": "sha512-vNk6aEwybGtawWmy/PzwnGDOjCkLWSD2wqvjGGAgOAwCGWySYXfYoxt00IJkTF+8Lb57DwOb3Aa0o9CApepiYQ==",
800 | "dev": true,
801 | "license": "MIT",
802 | "dependencies": {
803 | "@jridgewell/resolve-uri": "^3.1.0",
804 | "@jridgewell/sourcemap-codec": "^1.4.14"
805 | }
806 | },
807 | "node_modules/@pkgjs/parseargs": {
808 | "version": "0.11.0",
809 | "resolved": "https://registry.npmjs.org/@pkgjs/parseargs/-/parseargs-0.11.0.tgz",
810 | "integrity": "sha512-+1VkjdD0QBLPodGrJUeqarH8VAIvQODIbwh9XpP5Syisf7YoQgsJKPNFoqqLQlu+VQ/tVSshMR6loPMn8U+dPg==",
811 | "dev": true,
812 | "license": "MIT",
813 | "optional": true,
814 | "engines": {
815 | "node": ">=14"
816 | }
817 | },
818 | "node_modules/@rollup/rollup-android-arm-eabi": {
819 | "version": "4.34.9",
820 | "resolved": "https://registry.npmjs.org/@rollup/rollup-android-arm-eabi/-/rollup-android-arm-eabi-4.34.9.tgz",
821 | "integrity": "sha512-qZdlImWXur0CFakn2BJ2znJOdqYZKiedEPEVNTBrpfPjc/YuTGcaYZcdmNFTkUj3DU0ZM/AElcM8Ybww3xVLzA==",
822 | "cpu": [
823 | "arm"
824 | ],
825 | "dev": true,
826 | "license": "MIT",
827 | "optional": true,
828 | "os": [
829 | "android"
830 | ]
831 | },
832 | "node_modules/@rollup/rollup-android-arm64": {
833 | "version": "4.34.9",
834 | "resolved": "https://registry.npmjs.org/@rollup/rollup-android-arm64/-/rollup-android-arm64-4.34.9.tgz",
835 | "integrity": "sha512-4KW7P53h6HtJf5Y608T1ISKvNIYLWRKMvfnG0c44M6In4DQVU58HZFEVhWINDZKp7FZps98G3gxwC1sb0wXUUg==",
836 | "cpu": [
837 | "arm64"
838 | ],
839 | "dev": true,
840 | "license": "MIT",
841 | "optional": true,
842 | "os": [
843 | "android"
844 | ]
845 | },
846 | "node_modules/@rollup/rollup-darwin-arm64": {
847 | "version": "4.34.9",
848 | "resolved": "https://registry.npmjs.org/@rollup/rollup-darwin-arm64/-/rollup-darwin-arm64-4.34.9.tgz",
849 | "integrity": "sha512-0CY3/K54slrzLDjOA7TOjN1NuLKERBgk9nY5V34mhmuu673YNb+7ghaDUs6N0ujXR7fz5XaS5Aa6d2TNxZd0OQ==",
850 | "cpu": [
851 | "arm64"
852 | ],
853 | "dev": true,
854 | "license": "MIT",
855 | "optional": true,
856 | "os": [
857 | "darwin"
858 | ]
859 | },
860 | "node_modules/@rollup/rollup-darwin-x64": {
861 | "version": "4.34.9",
862 | "resolved": "https://registry.npmjs.org/@rollup/rollup-darwin-x64/-/rollup-darwin-x64-4.34.9.tgz",
863 | "integrity": "sha512-eOojSEAi/acnsJVYRxnMkPFqcxSMFfrw7r2iD9Q32SGkb/Q9FpUY1UlAu1DH9T7j++gZ0lHjnm4OyH2vCI7l7Q==",
864 | "cpu": [
865 | "x64"
866 | ],
867 | "dev": true,
868 | "license": "MIT",
869 | "optional": true,
870 | "os": [
871 | "darwin"
872 | ]
873 | },
874 | "node_modules/@rollup/rollup-freebsd-arm64": {
875 | "version": "4.34.9",
876 | "resolved": "https://registry.npmjs.org/@rollup/rollup-freebsd-arm64/-/rollup-freebsd-arm64-4.34.9.tgz",
877 | "integrity": "sha512-2lzjQPJbN5UnHm7bHIUKFMulGTQwdvOkouJDpPysJS+QFBGDJqcfh+CxxtG23Ik/9tEvnebQiylYoazFMAgrYw==",
878 | "cpu": [
879 | "arm64"
880 | ],
881 | "dev": true,
882 | "license": "MIT",
883 | "optional": true,
884 | "os": [
885 | "freebsd"
886 | ]
887 | },
888 | "node_modules/@rollup/rollup-freebsd-x64": {
889 | "version": "4.34.9",
890 | "resolved": "https://registry.npmjs.org/@rollup/rollup-freebsd-x64/-/rollup-freebsd-x64-4.34.9.tgz",
891 | "integrity": "sha512-SLl0hi2Ah2H7xQYd6Qaiu01kFPzQ+hqvdYSoOtHYg/zCIFs6t8sV95kaoqjzjFwuYQLtOI0RZre/Ke0nPaQV+g==",
892 | "cpu": [
893 | "x64"
894 | ],
895 | "dev": true,
896 | "license": "MIT",
897 | "optional": true,
898 | "os": [
899 | "freebsd"
900 | ]
901 | },
902 | "node_modules/@rollup/rollup-linux-arm-gnueabihf": {
903 | "version": "4.34.9",
904 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm-gnueabihf/-/rollup-linux-arm-gnueabihf-4.34.9.tgz",
905 | "integrity": "sha512-88I+D3TeKItrw+Y/2ud4Tw0+3CxQ2kLgu3QvrogZ0OfkmX/DEppehus7L3TS2Q4lpB+hYyxhkQiYPJ6Mf5/dPg==",
906 | "cpu": [
907 | "arm"
908 | ],
909 | "dev": true,
910 | "license": "MIT",
911 | "optional": true,
912 | "os": [
913 | "linux"
914 | ]
915 | },
916 | "node_modules/@rollup/rollup-linux-arm-musleabihf": {
917 | "version": "4.34.9",
918 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm-musleabihf/-/rollup-linux-arm-musleabihf-4.34.9.tgz",
919 | "integrity": "sha512-3qyfWljSFHi9zH0KgtEPG4cBXHDFhwD8kwg6xLfHQ0IWuH9crp005GfoUUh/6w9/FWGBwEHg3lxK1iHRN1MFlA==",
920 | "cpu": [
921 | "arm"
922 | ],
923 | "dev": true,
924 | "license": "MIT",
925 | "optional": true,
926 | "os": [
927 | "linux"
928 | ]
929 | },
930 | "node_modules/@rollup/rollup-linux-arm64-gnu": {
931 | "version": "4.34.9",
932 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm64-gnu/-/rollup-linux-arm64-gnu-4.34.9.tgz",
933 | "integrity": "sha512-6TZjPHjKZUQKmVKMUowF3ewHxctrRR09eYyvT5eFv8w/fXarEra83A2mHTVJLA5xU91aCNOUnM+DWFMSbQ0Nxw==",
934 | "cpu": [
935 | "arm64"
936 | ],
937 | "dev": true,
938 | "license": "MIT",
939 | "optional": true,
940 | "os": [
941 | "linux"
942 | ]
943 | },
944 | "node_modules/@rollup/rollup-linux-arm64-musl": {
945 | "version": "4.34.9",
946 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm64-musl/-/rollup-linux-arm64-musl-4.34.9.tgz",
947 | "integrity": "sha512-LD2fytxZJZ6xzOKnMbIpgzFOuIKlxVOpiMAXawsAZ2mHBPEYOnLRK5TTEsID6z4eM23DuO88X0Tq1mErHMVq0A==",
948 | "cpu": [
949 | "arm64"
950 | ],
951 | "dev": true,
952 | "license": "MIT",
953 | "optional": true,
954 | "os": [
955 | "linux"
956 | ]
957 | },
958 | "node_modules/@rollup/rollup-linux-loongarch64-gnu": {
959 | "version": "4.34.9",
960 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-loongarch64-gnu/-/rollup-linux-loongarch64-gnu-4.34.9.tgz",
961 | "integrity": "sha512-dRAgTfDsn0TE0HI6cmo13hemKpVHOEyeciGtvlBTkpx/F65kTvShtY/EVyZEIfxFkV5JJTuQ9tP5HGBS0hfxIg==",
962 | "cpu": [
963 | "loong64"
964 | ],
965 | "dev": true,
966 | "license": "MIT",
967 | "optional": true,
968 | "os": [
969 | "linux"
970 | ]
971 | },
972 | "node_modules/@rollup/rollup-linux-powerpc64le-gnu": {
973 | "version": "4.34.9",
974 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-powerpc64le-gnu/-/rollup-linux-powerpc64le-gnu-4.34.9.tgz",
975 | "integrity": "sha512-PHcNOAEhkoMSQtMf+rJofwisZqaU8iQ8EaSps58f5HYll9EAY5BSErCZ8qBDMVbq88h4UxaNPlbrKqfWP8RfJA==",
976 | "cpu": [
977 | "ppc64"
978 | ],
979 | "dev": true,
980 | "license": "MIT",
981 | "optional": true,
982 | "os": [
983 | "linux"
984 | ]
985 | },
986 | "node_modules/@rollup/rollup-linux-riscv64-gnu": {
987 | "version": "4.34.9",
988 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-riscv64-gnu/-/rollup-linux-riscv64-gnu-4.34.9.tgz",
989 | "integrity": "sha512-Z2i0Uy5G96KBYKjeQFKbbsB54xFOL5/y1P5wNBsbXB8yE+At3oh0DVMjQVzCJRJSfReiB2tX8T6HUFZ2k8iaKg==",
990 | "cpu": [
991 | "riscv64"
992 | ],
993 | "dev": true,
994 | "license": "MIT",
995 | "optional": true,
996 | "os": [
997 | "linux"
998 | ]
999 | },
1000 | "node_modules/@rollup/rollup-linux-s390x-gnu": {
1001 | "version": "4.34.9",
1002 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-s390x-gnu/-/rollup-linux-s390x-gnu-4.34.9.tgz",
1003 | "integrity": "sha512-U+5SwTMoeYXoDzJX5dhDTxRltSrIax8KWwfaaYcynuJw8mT33W7oOgz0a+AaXtGuvhzTr2tVKh5UO8GVANTxyQ==",
1004 | "cpu": [
1005 | "s390x"
1006 | ],
1007 | "dev": true,
1008 | "license": "MIT",
1009 | "optional": true,
1010 | "os": [
1011 | "linux"
1012 | ]
1013 | },
1014 | "node_modules/@rollup/rollup-linux-x64-gnu": {
1015 | "version": "4.34.9",
1016 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-x64-gnu/-/rollup-linux-x64-gnu-4.34.9.tgz",
1017 | "integrity": "sha512-FwBHNSOjUTQLP4MG7y6rR6qbGw4MFeQnIBrMe161QGaQoBQLqSUEKlHIiVgF3g/mb3lxlxzJOpIBhaP+C+KP2A==",
1018 | "cpu": [
1019 | "x64"
1020 | ],
1021 | "dev": true,
1022 | "license": "MIT",
1023 | "optional": true,
1024 | "os": [
1025 | "linux"
1026 | ]
1027 | },
1028 | "node_modules/@rollup/rollup-linux-x64-musl": {
1029 | "version": "4.34.9",
1030 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-x64-musl/-/rollup-linux-x64-musl-4.34.9.tgz",
1031 | "integrity": "sha512-cYRpV4650z2I3/s6+5/LONkjIz8MBeqrk+vPXV10ORBnshpn8S32bPqQ2Utv39jCiDcO2eJTuSlPXpnvmaIgRA==",
1032 | "cpu": [
1033 | "x64"
1034 | ],
1035 | "dev": true,
1036 | "license": "MIT",
1037 | "optional": true,
1038 | "os": [
1039 | "linux"
1040 | ]
1041 | },
1042 | "node_modules/@rollup/rollup-win32-arm64-msvc": {
1043 | "version": "4.34.9",
1044 | "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-arm64-msvc/-/rollup-win32-arm64-msvc-4.34.9.tgz",
1045 | "integrity": "sha512-z4mQK9dAN6byRA/vsSgQiPeuO63wdiDxZ9yg9iyX2QTzKuQM7T4xlBoeUP/J8uiFkqxkcWndWi+W7bXdPbt27Q==",
1046 | "cpu": [
1047 | "arm64"
1048 | ],
1049 | "dev": true,
1050 | "license": "MIT",
1051 | "optional": true,
1052 | "os": [
1053 | "win32"
1054 | ]
1055 | },
1056 | "node_modules/@rollup/rollup-win32-ia32-msvc": {
1057 | "version": "4.34.9",
1058 | "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-ia32-msvc/-/rollup-win32-ia32-msvc-4.34.9.tgz",
1059 | "integrity": "sha512-KB48mPtaoHy1AwDNkAJfHXvHp24H0ryZog28spEs0V48l3H1fr4i37tiyHsgKZJnCmvxsbATdZGBpbmxTE3a9w==",
1060 | "cpu": [
1061 | "ia32"
1062 | ],
1063 | "dev": true,
1064 | "license": "MIT",
1065 | "optional": true,
1066 | "os": [
1067 | "win32"
1068 | ]
1069 | },
1070 | "node_modules/@rollup/rollup-win32-x64-msvc": {
1071 | "version": "4.34.9",
1072 | "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-x64-msvc/-/rollup-win32-x64-msvc-4.34.9.tgz",
1073 | "integrity": "sha512-AyleYRPU7+rgkMWbEh71fQlrzRfeP6SyMnRf9XX4fCdDPAJumdSBqYEcWPMzVQ4ScAl7E4oFfK0GUVn77xSwbw==",
1074 | "cpu": [
1075 | "x64"
1076 | ],
1077 | "dev": true,
1078 | "license": "MIT",
1079 | "optional": true,
1080 | "os": [
1081 | "win32"
1082 | ]
1083 | },
1084 | "node_modules/@sideway/address": {
1085 | "version": "4.1.5",
1086 | "resolved": "https://registry.npmjs.org/@sideway/address/-/address-4.1.5.tgz",
1087 | "integrity": "sha512-IqO/DUQHUkPeixNQ8n0JA6102hT9CmaljNTPmQ1u8MEhBo/R4Q8eKLN/vGZxuebwOroDB4cbpjheD4+/sKFK4Q==",
1088 | "license": "BSD-3-Clause",
1089 | "dependencies": {
1090 | "@hapi/hoek": "^9.0.0"
1091 | }
1092 | },
1093 | "node_modules/@sideway/formula": {
1094 | "version": "3.0.1",
1095 | "resolved": "https://registry.npmjs.org/@sideway/formula/-/formula-3.0.1.tgz",
1096 | "integrity": "sha512-/poHZJJVjx3L+zVD6g9KgHfYnb443oi7wLu/XKojDviHy6HOEOA6z1Trk5aR1dGcmPenJEgb2sK2I80LeS3MIg==",
1097 | "license": "BSD-3-Clause"
1098 | },
1099 | "node_modules/@sideway/pinpoint": {
1100 | "version": "2.0.0",
1101 | "resolved": "https://registry.npmjs.org/@sideway/pinpoint/-/pinpoint-2.0.0.tgz",
1102 | "integrity": "sha512-RNiOoTPkptFtSVzQevY/yWtZwf/RxyVnPy/OcA9HBM3MlGDnBEYL5B41H0MTn0Uec8Hi+2qUtTfG2WWZBmMejQ==",
1103 | "license": "BSD-3-Clause"
1104 | },
1105 | "node_modules/@types/estree": {
1106 | "version": "1.0.6",
1107 | "resolved": "https://registry.npmjs.org/@types/estree/-/estree-1.0.6.tgz",
1108 | "integrity": "sha512-AYnb1nQyY49te+VRAVgmzfcgjYS91mY5P0TKUDCLEM+gNnA+3T6rWITXRLYCpahpqSQbN5cE+gHpnPyXjHWxcw==",
1109 | "dev": true,
1110 | "license": "MIT"
1111 | },
1112 | "node_modules/@vitest/coverage-istanbul": {
1113 | "version": "3.0.7",
1114 | "resolved": "https://registry.npmjs.org/@vitest/coverage-istanbul/-/coverage-istanbul-3.0.7.tgz",
1115 | "integrity": "sha512-hkd7rlfnqQJFlg6IPv9aFNaxJNkWLasdfaMJR3MBsBkxddSYy5ax9sW6Vv1/3tmmyT9m/b0lHDNknybKJ33cXw==",
1116 | "dev": true,
1117 | "license": "MIT",
1118 | "dependencies": {
1119 | "@istanbuljs/schema": "^0.1.3",
1120 | "debug": "^4.4.0",
1121 | "istanbul-lib-coverage": "^3.2.2",
1122 | "istanbul-lib-instrument": "^6.0.3",
1123 | "istanbul-lib-report": "^3.0.1",
1124 | "istanbul-lib-source-maps": "^5.0.6",
1125 | "istanbul-reports": "^3.1.7",
1126 | "magicast": "^0.3.5",
1127 | "test-exclude": "^7.0.1",
1128 | "tinyrainbow": "^2.0.0"
1129 | },
1130 | "funding": {
1131 | "url": "https://opencollective.com/vitest"
1132 | },
1133 | "peerDependencies": {
1134 | "vitest": "3.0.7"
1135 | }
1136 | },
1137 | "node_modules/@vitest/expect": {
1138 | "version": "3.0.7",
1139 | "resolved": "https://registry.npmjs.org/@vitest/expect/-/expect-3.0.7.tgz",
1140 | "integrity": "sha512-QP25f+YJhzPfHrHfYHtvRn+uvkCFCqFtW9CktfBxmB+25QqWsx7VB2As6f4GmwllHLDhXNHvqedwhvMmSnNmjw==",
1141 | "dev": true,
1142 | "license": "MIT",
1143 | "dependencies": {
1144 | "@vitest/spy": "3.0.7",
1145 | "@vitest/utils": "3.0.7",
1146 | "chai": "^5.2.0",
1147 | "tinyrainbow": "^2.0.0"
1148 | },
1149 | "funding": {
1150 | "url": "https://opencollective.com/vitest"
1151 | }
1152 | },
1153 | "node_modules/@vitest/mocker": {
1154 | "version": "3.0.7",
1155 | "resolved": "https://registry.npmjs.org/@vitest/mocker/-/mocker-3.0.7.tgz",
1156 | "integrity": "sha512-qui+3BLz9Eonx4EAuR/i+QlCX6AUZ35taDQgwGkK/Tw6/WgwodSrjN1X2xf69IA/643ZX5zNKIn2svvtZDrs4w==",
1157 | "dev": true,
1158 | "license": "MIT",
1159 | "dependencies": {
1160 | "@vitest/spy": "3.0.7",
1161 | "estree-walker": "^3.0.3",
1162 | "magic-string": "^0.30.17"
1163 | },
1164 | "funding": {
1165 | "url": "https://opencollective.com/vitest"
1166 | },
1167 | "peerDependencies": {
1168 | "msw": "^2.4.9",
1169 | "vite": "^5.0.0 || ^6.0.0"
1170 | },
1171 | "peerDependenciesMeta": {
1172 | "msw": {
1173 | "optional": true
1174 | },
1175 | "vite": {
1176 | "optional": true
1177 | }
1178 | }
1179 | },
1180 | "node_modules/@vitest/pretty-format": {
1181 | "version": "3.0.7",
1182 | "resolved": "https://registry.npmjs.org/@vitest/pretty-format/-/pretty-format-3.0.7.tgz",
1183 | "integrity": "sha512-CiRY0BViD/V8uwuEzz9Yapyao+M9M008/9oMOSQydwbwb+CMokEq3XVaF3XK/VWaOK0Jm9z7ENhybg70Gtxsmg==",
1184 | "dev": true,
1185 | "license": "MIT",
1186 | "dependencies": {
1187 | "tinyrainbow": "^2.0.0"
1188 | },
1189 | "funding": {
1190 | "url": "https://opencollective.com/vitest"
1191 | }
1192 | },
1193 | "node_modules/@vitest/runner": {
1194 | "version": "3.0.7",
1195 | "resolved": "https://registry.npmjs.org/@vitest/runner/-/runner-3.0.7.tgz",
1196 | "integrity": "sha512-WeEl38Z0S2ZcuRTeyYqaZtm4e26tq6ZFqh5y8YD9YxfWuu0OFiGFUbnxNynwLjNRHPsXyee2M9tV7YxOTPZl2g==",
1197 | "dev": true,
1198 | "license": "MIT",
1199 | "dependencies": {
1200 | "@vitest/utils": "3.0.7",
1201 | "pathe": "^2.0.3"
1202 | },
1203 | "funding": {
1204 | "url": "https://opencollective.com/vitest"
1205 | }
1206 | },
1207 | "node_modules/@vitest/snapshot": {
1208 | "version": "3.0.7",
1209 | "resolved": "https://registry.npmjs.org/@vitest/snapshot/-/snapshot-3.0.7.tgz",
1210 | "integrity": "sha512-eqTUryJWQN0Rtf5yqCGTQWsCFOQe4eNz5Twsu21xYEcnFJtMU5XvmG0vgebhdLlrHQTSq5p8vWHJIeJQV8ovsA==",
1211 | "dev": true,
1212 | "license": "MIT",
1213 | "dependencies": {
1214 | "@vitest/pretty-format": "3.0.7",
1215 | "magic-string": "^0.30.17",
1216 | "pathe": "^2.0.3"
1217 | },
1218 | "funding": {
1219 | "url": "https://opencollective.com/vitest"
1220 | }
1221 | },
1222 | "node_modules/@vitest/spy": {
1223 | "version": "3.0.7",
1224 | "resolved": "https://registry.npmjs.org/@vitest/spy/-/spy-3.0.7.tgz",
1225 | "integrity": "sha512-4T4WcsibB0B6hrKdAZTM37ekuyFZt2cGbEGd2+L0P8ov15J1/HUsUaqkXEQPNAWr4BtPPe1gI+FYfMHhEKfR8w==",
1226 | "dev": true,
1227 | "license": "MIT",
1228 | "dependencies": {
1229 | "tinyspy": "^3.0.2"
1230 | },
1231 | "funding": {
1232 | "url": "https://opencollective.com/vitest"
1233 | }
1234 | },
1235 | "node_modules/@vitest/utils": {
1236 | "version": "3.0.7",
1237 | "resolved": "https://registry.npmjs.org/@vitest/utils/-/utils-3.0.7.tgz",
1238 | "integrity": "sha512-xePVpCRfooFX3rANQjwoditoXgWb1MaFbzmGuPP59MK6i13mrnDw/yEIyJudLeW6/38mCNcwCiJIGmpDPibAIg==",
1239 | "dev": true,
1240 | "license": "MIT",
1241 | "dependencies": {
1242 | "@vitest/pretty-format": "3.0.7",
1243 | "loupe": "^3.1.3",
1244 | "tinyrainbow": "^2.0.0"
1245 | },
1246 | "funding": {
1247 | "url": "https://opencollective.com/vitest"
1248 | }
1249 | },
1250 | "node_modules/ansi-regex": {
1251 | "version": "6.1.0",
1252 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-6.1.0.tgz",
1253 | "integrity": "sha512-7HSX4QQb4CspciLpVFwyRe79O3xsIZDDLER21kERQ71oaPodF8jL725AgJMFAYbooIqolJoRLuM81SpeUkpkvA==",
1254 | "dev": true,
1255 | "license": "MIT",
1256 | "engines": {
1257 | "node": ">=12"
1258 | },
1259 | "funding": {
1260 | "url": "https://github.com/chalk/ansi-regex?sponsor=1"
1261 | }
1262 | },
1263 | "node_modules/ansi-styles": {
1264 | "version": "6.2.1",
1265 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-6.2.1.tgz",
1266 | "integrity": "sha512-bN798gFfQX+viw3R7yrGWRqnrN2oRkEkUjjl4JNn4E8GxxbjtG3FbrEIIY3l8/hrwUwIeCZvi4QuOTP4MErVug==",
1267 | "dev": true,
1268 | "license": "MIT",
1269 | "engines": {
1270 | "node": ">=12"
1271 | },
1272 | "funding": {
1273 | "url": "https://github.com/chalk/ansi-styles?sponsor=1"
1274 | }
1275 | },
1276 | "node_modules/assertion-error": {
1277 | "version": "2.0.1",
1278 | "resolved": "https://registry.npmjs.org/assertion-error/-/assertion-error-2.0.1.tgz",
1279 | "integrity": "sha512-Izi8RQcffqCeNVgFigKli1ssklIbpHnCYc6AknXGYoB6grJqyeby7jv12JUQgmTAnIDnbck1uxksT4dzN3PWBA==",
1280 | "dev": true,
1281 | "license": "MIT",
1282 | "engines": {
1283 | "node": ">=12"
1284 | }
1285 | },
1286 | "node_modules/balanced-match": {
1287 | "version": "1.0.2",
1288 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz",
1289 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==",
1290 | "dev": true,
1291 | "license": "MIT"
1292 | },
1293 | "node_modules/brace-expansion": {
1294 | "version": "2.0.1",
1295 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-2.0.1.tgz",
1296 | "integrity": "sha512-XnAIvQ8eM+kC6aULx6wuQiwVsnzsi9d3WxzV3FpWTGA19F621kwdbsAcFKXgKUHZWsy+mY6iL1sHTxWEFCytDA==",
1297 | "dev": true,
1298 | "license": "MIT",
1299 | "dependencies": {
1300 | "balanced-match": "^1.0.0"
1301 | }
1302 | },
1303 | "node_modules/browserslist": {
1304 | "version": "4.24.4",
1305 | "resolved": "https://registry.npmjs.org/browserslist/-/browserslist-4.24.4.tgz",
1306 | "integrity": "sha512-KDi1Ny1gSePi1vm0q4oxSF8b4DR44GF4BbmS2YdhPLOEqd8pDviZOGH/GsmRwoWJ2+5Lr085X7naowMwKHDG1A==",
1307 | "dev": true,
1308 | "funding": [
1309 | {
1310 | "type": "opencollective",
1311 | "url": "https://opencollective.com/browserslist"
1312 | },
1313 | {
1314 | "type": "tidelift",
1315 | "url": "https://tidelift.com/funding/github/npm/browserslist"
1316 | },
1317 | {
1318 | "type": "github",
1319 | "url": "https://github.com/sponsors/ai"
1320 | }
1321 | ],
1322 | "license": "MIT",
1323 | "dependencies": {
1324 | "caniuse-lite": "^1.0.30001688",
1325 | "electron-to-chromium": "^1.5.73",
1326 | "node-releases": "^2.0.19",
1327 | "update-browserslist-db": "^1.1.1"
1328 | },
1329 | "bin": {
1330 | "browserslist": "cli.js"
1331 | },
1332 | "engines": {
1333 | "node": "^6 || ^7 || ^8 || ^9 || ^10 || ^11 || ^12 || >=13.7"
1334 | }
1335 | },
1336 | "node_modules/cac": {
1337 | "version": "6.7.14",
1338 | "resolved": "https://registry.npmjs.org/cac/-/cac-6.7.14.tgz",
1339 | "integrity": "sha512-b6Ilus+c3RrdDk+JhLKUAQfzzgLEPy6wcXqS7f/xe1EETvsDP6GORG7SFuOs6cID5YkqchW/LXZbX5bc8j7ZcQ==",
1340 | "dev": true,
1341 | "license": "MIT",
1342 | "engines": {
1343 | "node": ">=8"
1344 | }
1345 | },
1346 | "node_modules/caniuse-lite": {
1347 | "version": "1.0.30001702",
1348 | "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001702.tgz",
1349 | "integrity": "sha512-LoPe/D7zioC0REI5W73PeR1e1MLCipRGq/VkovJnd6Df+QVqT+vT33OXCp8QUd7kA7RZrHWxb1B36OQKI/0gOA==",
1350 | "dev": true,
1351 | "funding": [
1352 | {
1353 | "type": "opencollective",
1354 | "url": "https://opencollective.com/browserslist"
1355 | },
1356 | {
1357 | "type": "tidelift",
1358 | "url": "https://tidelift.com/funding/github/npm/caniuse-lite"
1359 | },
1360 | {
1361 | "type": "github",
1362 | "url": "https://github.com/sponsors/ai"
1363 | }
1364 | ],
1365 | "license": "CC-BY-4.0"
1366 | },
1367 | "node_modules/chai": {
1368 | "version": "5.2.0",
1369 | "resolved": "https://registry.npmjs.org/chai/-/chai-5.2.0.tgz",
1370 | "integrity": "sha512-mCuXncKXk5iCLhfhwTc0izo0gtEmpz5CtG2y8GiOINBlMVS6v8TMRc5TaLWKS6692m9+dVVfzgeVxR5UxWHTYw==",
1371 | "dev": true,
1372 | "license": "MIT",
1373 | "dependencies": {
1374 | "assertion-error": "^2.0.1",
1375 | "check-error": "^2.1.1",
1376 | "deep-eql": "^5.0.1",
1377 | "loupe": "^3.1.0",
1378 | "pathval": "^2.0.0"
1379 | },
1380 | "engines": {
1381 | "node": ">=12"
1382 | }
1383 | },
1384 | "node_modules/check-error": {
1385 | "version": "2.1.1",
1386 | "resolved": "https://registry.npmjs.org/check-error/-/check-error-2.1.1.tgz",
1387 | "integrity": "sha512-OAlb+T7V4Op9OwdkjmguYRqncdlx5JiofwOAUkmTF+jNdHwzTaTs4sRAGpzLF3oOz5xAyDGrPgeIDFQmDOTiJw==",
1388 | "dev": true,
1389 | "license": "MIT",
1390 | "engines": {
1391 | "node": ">= 16"
1392 | }
1393 | },
1394 | "node_modules/color-convert": {
1395 | "version": "2.0.1",
1396 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz",
1397 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==",
1398 | "dev": true,
1399 | "license": "MIT",
1400 | "dependencies": {
1401 | "color-name": "~1.1.4"
1402 | },
1403 | "engines": {
1404 | "node": ">=7.0.0"
1405 | }
1406 | },
1407 | "node_modules/color-name": {
1408 | "version": "1.1.4",
1409 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz",
1410 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==",
1411 | "dev": true,
1412 | "license": "MIT"
1413 | },
1414 | "node_modules/context": {
1415 | "version": "3.0.33",
1416 | "resolved": "https://registry.npmjs.org/context/-/context-3.0.33.tgz",
1417 | "integrity": "sha512-9nBbXhHVKRFLYKk3oa7W+aHt/eiGm5aIMp4Y4IwQsiAO+deRtlJ72EA8m7Cvs3v7gjjBuqKljvt2eyihVHUJoQ==",
1418 | "license": "MIT",
1419 | "dependencies": {
1420 | "vest-utils": "^1.3.3"
1421 | }
1422 | },
1423 | "node_modules/convert-source-map": {
1424 | "version": "2.0.0",
1425 | "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-2.0.0.tgz",
1426 | "integrity": "sha512-Kvp459HrV2FEJ1CAsi1Ku+MY3kasH19TFykTz2xWmMeq6bk2NU3XXvfJ+Q61m0xktWwt+1HSYf3JZsTms3aRJg==",
1427 | "dev": true,
1428 | "license": "MIT"
1429 | },
1430 | "node_modules/cross-spawn": {
1431 | "version": "7.0.6",
1432 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.6.tgz",
1433 | "integrity": "sha512-uV2QOWP2nWzsy2aMp8aRibhi9dlzF5Hgh5SHaB9OiTGEyDTiJJyx0uy51QXdyWbtAHNua4XJzUKca3OzKUd3vA==",
1434 | "dev": true,
1435 | "license": "MIT",
1436 | "dependencies": {
1437 | "path-key": "^3.1.0",
1438 | "shebang-command": "^2.0.0",
1439 | "which": "^2.0.1"
1440 | },
1441 | "engines": {
1442 | "node": ">= 8"
1443 | }
1444 | },
1445 | "node_modules/debug": {
1446 | "version": "4.4.0",
1447 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.4.0.tgz",
1448 | "integrity": "sha512-6WTZ/IxCY/T6BALoZHaE4ctp9xm+Z5kY/pzYaCHRFeyVhojxlrm+46y68HA6hr0TcwEssoxNiDEUJQjfPZ/RYA==",
1449 | "dev": true,
1450 | "license": "MIT",
1451 | "dependencies": {
1452 | "ms": "^2.1.3"
1453 | },
1454 | "engines": {
1455 | "node": ">=6.0"
1456 | },
1457 | "peerDependenciesMeta": {
1458 | "supports-color": {
1459 | "optional": true
1460 | }
1461 | }
1462 | },
1463 | "node_modules/deep-eql": {
1464 | "version": "5.0.2",
1465 | "resolved": "https://registry.npmjs.org/deep-eql/-/deep-eql-5.0.2.tgz",
1466 | "integrity": "sha512-h5k/5U50IJJFpzfL6nO9jaaumfjO/f2NjK/oYB2Djzm4p9L+3T9qWpZqZ2hAbLPuuYq9wrU08WQyBTL5GbPk5Q==",
1467 | "dev": true,
1468 | "license": "MIT",
1469 | "engines": {
1470 | "node": ">=6"
1471 | }
1472 | },
1473 | "node_modules/eastasianwidth": {
1474 | "version": "0.2.0",
1475 | "resolved": "https://registry.npmjs.org/eastasianwidth/-/eastasianwidth-0.2.0.tgz",
1476 | "integrity": "sha512-I88TYZWc9XiYHRQ4/3c5rjjfgkjhLyW2luGIheGERbNQ6OY7yTybanSpDXZa8y7VUP9YmDcYa+eyq4ca7iLqWA==",
1477 | "dev": true,
1478 | "license": "MIT"
1479 | },
1480 | "node_modules/electron-to-chromium": {
1481 | "version": "1.5.112",
1482 | "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.5.112.tgz",
1483 | "integrity": "sha512-oen93kVyqSb3l+ziUgzIOlWt/oOuy4zRmpwestMn4rhFWAoFJeFuCVte9F2fASjeZZo7l/Cif9TiyrdW4CwEMA==",
1484 | "dev": true,
1485 | "license": "ISC"
1486 | },
1487 | "node_modules/emoji-regex": {
1488 | "version": "9.2.2",
1489 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-9.2.2.tgz",
1490 | "integrity": "sha512-L18DaJsXSUk2+42pv8mLs5jJT2hqFkFE4j21wOmgbUqsZ2hL72NsUU785g9RXgo3s0ZNgVl42TiHp3ZtOv/Vyg==",
1491 | "dev": true,
1492 | "license": "MIT"
1493 | },
1494 | "node_modules/es-module-lexer": {
1495 | "version": "1.6.0",
1496 | "resolved": "https://registry.npmjs.org/es-module-lexer/-/es-module-lexer-1.6.0.tgz",
1497 | "integrity": "sha512-qqnD1yMU6tk/jnaMosogGySTZP8YtUgAffA9nMN+E/rjxcfRQ6IEk7IiozUjgxKoFHBGjTLnrHB/YC45r/59EQ==",
1498 | "dev": true,
1499 | "license": "MIT"
1500 | },
1501 | "node_modules/esbuild": {
1502 | "version": "0.25.0",
1503 | "resolved": "https://registry.npmjs.org/esbuild/-/esbuild-0.25.0.tgz",
1504 | "integrity": "sha512-BXq5mqc8ltbaN34cDqWuYKyNhX8D/Z0J1xdtdQ8UcIIIyJyz+ZMKUt58tF3SrZ85jcfN/PZYhjR5uDQAYNVbuw==",
1505 | "dev": true,
1506 | "hasInstallScript": true,
1507 | "license": "MIT",
1508 | "bin": {
1509 | "esbuild": "bin/esbuild"
1510 | },
1511 | "engines": {
1512 | "node": ">=18"
1513 | },
1514 | "optionalDependencies": {
1515 | "@esbuild/aix-ppc64": "0.25.0",
1516 | "@esbuild/android-arm": "0.25.0",
1517 | "@esbuild/android-arm64": "0.25.0",
1518 | "@esbuild/android-x64": "0.25.0",
1519 | "@esbuild/darwin-arm64": "0.25.0",
1520 | "@esbuild/darwin-x64": "0.25.0",
1521 | "@esbuild/freebsd-arm64": "0.25.0",
1522 | "@esbuild/freebsd-x64": "0.25.0",
1523 | "@esbuild/linux-arm": "0.25.0",
1524 | "@esbuild/linux-arm64": "0.25.0",
1525 | "@esbuild/linux-ia32": "0.25.0",
1526 | "@esbuild/linux-loong64": "0.25.0",
1527 | "@esbuild/linux-mips64el": "0.25.0",
1528 | "@esbuild/linux-ppc64": "0.25.0",
1529 | "@esbuild/linux-riscv64": "0.25.0",
1530 | "@esbuild/linux-s390x": "0.25.0",
1531 | "@esbuild/linux-x64": "0.25.0",
1532 | "@esbuild/netbsd-arm64": "0.25.0",
1533 | "@esbuild/netbsd-x64": "0.25.0",
1534 | "@esbuild/openbsd-arm64": "0.25.0",
1535 | "@esbuild/openbsd-x64": "0.25.0",
1536 | "@esbuild/sunos-x64": "0.25.0",
1537 | "@esbuild/win32-arm64": "0.25.0",
1538 | "@esbuild/win32-ia32": "0.25.0",
1539 | "@esbuild/win32-x64": "0.25.0"
1540 | }
1541 | },
1542 | "node_modules/escalade": {
1543 | "version": "3.2.0",
1544 | "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.2.0.tgz",
1545 | "integrity": "sha512-WUj2qlxaQtO4g6Pq5c29GTcWGDyd8itL8zTlipgECz3JesAiiOKotd8JU6otB3PACgG6xkJUyVhboMS+bje/jA==",
1546 | "dev": true,
1547 | "license": "MIT",
1548 | "engines": {
1549 | "node": ">=6"
1550 | }
1551 | },
1552 | "node_modules/estree-walker": {
1553 | "version": "3.0.3",
1554 | "resolved": "https://registry.npmjs.org/estree-walker/-/estree-walker-3.0.3.tgz",
1555 | "integrity": "sha512-7RUKfXgSMMkzt6ZuXmqapOurLGPPfgj6l9uRZ7lRGolvk0y2yocc35LdcxKC5PQZdn2DMqioAQ2NoWcrTKmm6g==",
1556 | "dev": true,
1557 | "license": "MIT",
1558 | "dependencies": {
1559 | "@types/estree": "^1.0.0"
1560 | }
1561 | },
1562 | "node_modules/expect-type": {
1563 | "version": "1.2.0",
1564 | "resolved": "https://registry.npmjs.org/expect-type/-/expect-type-1.2.0.tgz",
1565 | "integrity": "sha512-80F22aiJ3GLyVnS/B3HzgR6RelZVumzj9jkL0Rhz4h0xYbNW9PjlQz5h3J/SShErbXBc295vseR4/MIbVmUbeA==",
1566 | "dev": true,
1567 | "license": "Apache-2.0",
1568 | "engines": {
1569 | "node": ">=12.0.0"
1570 | }
1571 | },
1572 | "node_modules/foreground-child": {
1573 | "version": "3.3.1",
1574 | "resolved": "https://registry.npmjs.org/foreground-child/-/foreground-child-3.3.1.tgz",
1575 | "integrity": "sha512-gIXjKqtFuWEgzFRJA9WCQeSJLZDjgJUOMCMzxtvFq/37KojM1BFGufqsCy0r4qSQmYLsZYMeyRqzIWOMup03sw==",
1576 | "dev": true,
1577 | "license": "ISC",
1578 | "dependencies": {
1579 | "cross-spawn": "^7.0.6",
1580 | "signal-exit": "^4.0.1"
1581 | },
1582 | "engines": {
1583 | "node": ">=14"
1584 | },
1585 | "funding": {
1586 | "url": "https://github.com/sponsors/isaacs"
1587 | }
1588 | },
1589 | "node_modules/fsevents": {
1590 | "version": "2.3.3",
1591 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.3.tgz",
1592 | "integrity": "sha512-5xoDfX+fL7faATnagmWPpbFtwh/R77WmMMqqHGS65C3vvB0YHrgF+B1YmZ3441tMj5n63k0212XNoJwzlhffQw==",
1593 | "dev": true,
1594 | "hasInstallScript": true,
1595 | "license": "MIT",
1596 | "optional": true,
1597 | "os": [
1598 | "darwin"
1599 | ],
1600 | "engines": {
1601 | "node": "^8.16.0 || ^10.6.0 || >=11.0.0"
1602 | }
1603 | },
1604 | "node_modules/gensync": {
1605 | "version": "1.0.0-beta.2",
1606 | "resolved": "https://registry.npmjs.org/gensync/-/gensync-1.0.0-beta.2.tgz",
1607 | "integrity": "sha512-3hN7NaskYvMDLQY55gnW3NQ+mesEAepTqlg+VEbj7zzqEMBVNhzcGYYeqFo/TlYz6eQiFcp1HcsCZO+nGgS8zg==",
1608 | "dev": true,
1609 | "license": "MIT",
1610 | "engines": {
1611 | "node": ">=6.9.0"
1612 | }
1613 | },
1614 | "node_modules/glob": {
1615 | "version": "10.4.5",
1616 | "resolved": "https://registry.npmjs.org/glob/-/glob-10.4.5.tgz",
1617 | "integrity": "sha512-7Bv8RF0k6xjo7d4A/PxYLbUCfb6c+Vpd2/mB2yRDlew7Jb5hEXiCD9ibfO7wpk8i4sevK6DFny9h7EYbM3/sHg==",
1618 | "dev": true,
1619 | "license": "ISC",
1620 | "dependencies": {
1621 | "foreground-child": "^3.1.0",
1622 | "jackspeak": "^3.1.2",
1623 | "minimatch": "^9.0.4",
1624 | "minipass": "^7.1.2",
1625 | "package-json-from-dist": "^1.0.0",
1626 | "path-scurry": "^1.11.1"
1627 | },
1628 | "bin": {
1629 | "glob": "dist/esm/bin.mjs"
1630 | },
1631 | "funding": {
1632 | "url": "https://github.com/sponsors/isaacs"
1633 | }
1634 | },
1635 | "node_modules/globals": {
1636 | "version": "11.12.0",
1637 | "resolved": "https://registry.npmjs.org/globals/-/globals-11.12.0.tgz",
1638 | "integrity": "sha512-WOBp/EEGUiIsJSp7wcv/y6MO+lV9UoncWqxuFfm8eBwzWNgyfBd6Gz+IeKQ9jCmyhoH99g15M3T+QaVHFjizVA==",
1639 | "dev": true,
1640 | "license": "MIT",
1641 | "engines": {
1642 | "node": ">=4"
1643 | }
1644 | },
1645 | "node_modules/has-flag": {
1646 | "version": "4.0.0",
1647 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz",
1648 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==",
1649 | "dev": true,
1650 | "license": "MIT",
1651 | "engines": {
1652 | "node": ">=8"
1653 | }
1654 | },
1655 | "node_modules/html-escaper": {
1656 | "version": "2.0.2",
1657 | "resolved": "https://registry.npmjs.org/html-escaper/-/html-escaper-2.0.2.tgz",
1658 | "integrity": "sha512-H2iMtd0I4Mt5eYiapRdIDjp+XzelXQ0tFE4JS7YFwFevXXMmOp9myNrUvCg0D6ws8iqkRPBfKHgbwig1SmlLfg==",
1659 | "dev": true,
1660 | "license": "MIT"
1661 | },
1662 | "node_modules/is-fullwidth-code-point": {
1663 | "version": "3.0.0",
1664 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz",
1665 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==",
1666 | "dev": true,
1667 | "license": "MIT",
1668 | "engines": {
1669 | "node": ">=8"
1670 | }
1671 | },
1672 | "node_modules/isexe": {
1673 | "version": "2.0.0",
1674 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz",
1675 | "integrity": "sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw==",
1676 | "dev": true,
1677 | "license": "ISC"
1678 | },
1679 | "node_modules/istanbul-lib-coverage": {
1680 | "version": "3.2.2",
1681 | "resolved": "https://registry.npmjs.org/istanbul-lib-coverage/-/istanbul-lib-coverage-3.2.2.tgz",
1682 | "integrity": "sha512-O8dpsF+r0WV/8MNRKfnmrtCWhuKjxrq2w+jpzBL5UZKTi2LeVWnWOmWRxFlesJONmc+wLAGvKQZEOanko0LFTg==",
1683 | "dev": true,
1684 | "license": "BSD-3-Clause",
1685 | "engines": {
1686 | "node": ">=8"
1687 | }
1688 | },
1689 | "node_modules/istanbul-lib-instrument": {
1690 | "version": "6.0.3",
1691 | "resolved": "https://registry.npmjs.org/istanbul-lib-instrument/-/istanbul-lib-instrument-6.0.3.tgz",
1692 | "integrity": "sha512-Vtgk7L/R2JHyyGW07spoFlB8/lpjiOLTjMdms6AFMraYt3BaJauod/NGrfnVG/y4Ix1JEuMRPDPEj2ua+zz1/Q==",
1693 | "dev": true,
1694 | "license": "BSD-3-Clause",
1695 | "dependencies": {
1696 | "@babel/core": "^7.23.9",
1697 | "@babel/parser": "^7.23.9",
1698 | "@istanbuljs/schema": "^0.1.3",
1699 | "istanbul-lib-coverage": "^3.2.0",
1700 | "semver": "^7.5.4"
1701 | },
1702 | "engines": {
1703 | "node": ">=10"
1704 | }
1705 | },
1706 | "node_modules/istanbul-lib-report": {
1707 | "version": "3.0.1",
1708 | "resolved": "https://registry.npmjs.org/istanbul-lib-report/-/istanbul-lib-report-3.0.1.tgz",
1709 | "integrity": "sha512-GCfE1mtsHGOELCU8e/Z7YWzpmybrx/+dSTfLrvY8qRmaY6zXTKWn6WQIjaAFw069icm6GVMNkgu0NzI4iPZUNw==",
1710 | "dev": true,
1711 | "license": "BSD-3-Clause",
1712 | "dependencies": {
1713 | "istanbul-lib-coverage": "^3.0.0",
1714 | "make-dir": "^4.0.0",
1715 | "supports-color": "^7.1.0"
1716 | },
1717 | "engines": {
1718 | "node": ">=10"
1719 | }
1720 | },
1721 | "node_modules/istanbul-lib-source-maps": {
1722 | "version": "5.0.6",
1723 | "resolved": "https://registry.npmjs.org/istanbul-lib-source-maps/-/istanbul-lib-source-maps-5.0.6.tgz",
1724 | "integrity": "sha512-yg2d+Em4KizZC5niWhQaIomgf5WlL4vOOjZ5xGCmF8SnPE/mDWWXgvRExdcpCgh9lLRRa1/fSYp2ymmbJ1pI+A==",
1725 | "dev": true,
1726 | "license": "BSD-3-Clause",
1727 | "dependencies": {
1728 | "@jridgewell/trace-mapping": "^0.3.23",
1729 | "debug": "^4.1.1",
1730 | "istanbul-lib-coverage": "^3.0.0"
1731 | },
1732 | "engines": {
1733 | "node": ">=10"
1734 | }
1735 | },
1736 | "node_modules/istanbul-reports": {
1737 | "version": "3.1.7",
1738 | "resolved": "https://registry.npmjs.org/istanbul-reports/-/istanbul-reports-3.1.7.tgz",
1739 | "integrity": "sha512-BewmUXImeuRk2YY0PVbxgKAysvhRPUQE0h5QRM++nVWyubKGV0l8qQ5op8+B2DOmwSe63Jivj0BjkPQVf8fP5g==",
1740 | "dev": true,
1741 | "license": "BSD-3-Clause",
1742 | "dependencies": {
1743 | "html-escaper": "^2.0.0",
1744 | "istanbul-lib-report": "^3.0.0"
1745 | },
1746 | "engines": {
1747 | "node": ">=8"
1748 | }
1749 | },
1750 | "node_modules/jackspeak": {
1751 | "version": "3.4.3",
1752 | "resolved": "https://registry.npmjs.org/jackspeak/-/jackspeak-3.4.3.tgz",
1753 | "integrity": "sha512-OGlZQpz2yfahA/Rd1Y8Cd9SIEsqvXkLVoSw/cgwhnhFMDbsQFeZYoJJ7bIZBS9BcamUW96asq/npPWugM+RQBw==",
1754 | "dev": true,
1755 | "license": "BlueOak-1.0.0",
1756 | "dependencies": {
1757 | "@isaacs/cliui": "^8.0.2"
1758 | },
1759 | "funding": {
1760 | "url": "https://github.com/sponsors/isaacs"
1761 | },
1762 | "optionalDependencies": {
1763 | "@pkgjs/parseargs": "^0.11.0"
1764 | }
1765 | },
1766 | "node_modules/joi": {
1767 | "version": "17.13.3",
1768 | "resolved": "https://registry.npmjs.org/joi/-/joi-17.13.3.tgz",
1769 | "integrity": "sha512-otDA4ldcIx+ZXsKHWmp0YizCweVRZG96J10b0FevjfuncLO1oX59THoAmHkNubYJ+9gWsYsp5k8v4ib6oDv1fA==",
1770 | "license": "BSD-3-Clause",
1771 | "dependencies": {
1772 | "@hapi/hoek": "^9.3.0",
1773 | "@hapi/topo": "^5.1.0",
1774 | "@sideway/address": "^4.1.5",
1775 | "@sideway/formula": "^3.0.1",
1776 | "@sideway/pinpoint": "^2.0.0"
1777 | }
1778 | },
1779 | "node_modules/js-tokens": {
1780 | "version": "4.0.0",
1781 | "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz",
1782 | "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==",
1783 | "dev": true,
1784 | "license": "MIT"
1785 | },
1786 | "node_modules/jsesc": {
1787 | "version": "3.1.0",
1788 | "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-3.1.0.tgz",
1789 | "integrity": "sha512-/sM3dO2FOzXjKQhJuo0Q173wf2KOo8t4I8vHy6lF9poUp7bKT0/NHE8fPX23PwfhnykfqnC2xRxOnVw5XuGIaA==",
1790 | "dev": true,
1791 | "license": "MIT",
1792 | "bin": {
1793 | "jsesc": "bin/jsesc"
1794 | },
1795 | "engines": {
1796 | "node": ">=6"
1797 | }
1798 | },
1799 | "node_modules/json5": {
1800 | "version": "2.2.3",
1801 | "resolved": "https://registry.npmjs.org/json5/-/json5-2.2.3.tgz",
1802 | "integrity": "sha512-XmOWe7eyHYH14cLdVPoyg+GOH3rYX++KpzrylJwSW98t3Nk+U8XOl8FWKOgwtzdb8lXGf6zYwDUzeHMWfxasyg==",
1803 | "dev": true,
1804 | "license": "MIT",
1805 | "bin": {
1806 | "json5": "lib/cli.js"
1807 | },
1808 | "engines": {
1809 | "node": ">=6"
1810 | }
1811 | },
1812 | "node_modules/loupe": {
1813 | "version": "3.1.3",
1814 | "resolved": "https://registry.npmjs.org/loupe/-/loupe-3.1.3.tgz",
1815 | "integrity": "sha512-kkIp7XSkP78ZxJEsSxW3712C6teJVoeHHwgo9zJ380de7IYyJ2ISlxojcH2pC5OFLewESmnRi/+XCDIEEVyoug==",
1816 | "dev": true,
1817 | "license": "MIT"
1818 | },
1819 | "node_modules/lru-cache": {
1820 | "version": "5.1.1",
1821 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-5.1.1.tgz",
1822 | "integrity": "sha512-KpNARQA3Iwv+jTA0utUVVbrh+Jlrr1Fv0e56GGzAFOXN7dk/FviaDW8LHmK52DlcH4WP2n6gI8vN1aesBFgo9w==",
1823 | "dev": true,
1824 | "license": "ISC",
1825 | "dependencies": {
1826 | "yallist": "^3.0.2"
1827 | }
1828 | },
1829 | "node_modules/magic-string": {
1830 | "version": "0.30.17",
1831 | "resolved": "https://registry.npmjs.org/magic-string/-/magic-string-0.30.17.tgz",
1832 | "integrity": "sha512-sNPKHvyjVf7gyjwS4xGTaW/mCnF8wnjtifKBEhxfZ7E/S8tQ0rssrwGNn6q8JH/ohItJfSQp9mBtQYuTlH5QnA==",
1833 | "dev": true,
1834 | "license": "MIT",
1835 | "dependencies": {
1836 | "@jridgewell/sourcemap-codec": "^1.5.0"
1837 | }
1838 | },
1839 | "node_modules/magicast": {
1840 | "version": "0.3.5",
1841 | "resolved": "https://registry.npmjs.org/magicast/-/magicast-0.3.5.tgz",
1842 | "integrity": "sha512-L0WhttDl+2BOsybvEOLK7fW3UA0OQ0IQ2d6Zl2x/a6vVRs3bAY0ECOSHHeL5jD+SbOpOCUEi0y1DgHEn9Qn1AQ==",
1843 | "dev": true,
1844 | "license": "MIT",
1845 | "dependencies": {
1846 | "@babel/parser": "^7.25.4",
1847 | "@babel/types": "^7.25.4",
1848 | "source-map-js": "^1.2.0"
1849 | }
1850 | },
1851 | "node_modules/make-dir": {
1852 | "version": "4.0.0",
1853 | "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-4.0.0.tgz",
1854 | "integrity": "sha512-hXdUTZYIVOt1Ex//jAQi+wTZZpUpwBj/0QsOzqegb3rGMMeJiSEu5xLHnYfBrRV4RH2+OCSOO95Is/7x1WJ4bw==",
1855 | "dev": true,
1856 | "license": "MIT",
1857 | "dependencies": {
1858 | "semver": "^7.5.3"
1859 | },
1860 | "engines": {
1861 | "node": ">=10"
1862 | },
1863 | "funding": {
1864 | "url": "https://github.com/sponsors/sindresorhus"
1865 | }
1866 | },
1867 | "node_modules/minimatch": {
1868 | "version": "9.0.5",
1869 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-9.0.5.tgz",
1870 | "integrity": "sha512-G6T0ZX48xgozx7587koeX9Ys2NYy6Gmv//P89sEte9V9whIapMNF4idKxnW2QtCcLiTWlb/wfCabAtAFWhhBow==",
1871 | "dev": true,
1872 | "license": "ISC",
1873 | "dependencies": {
1874 | "brace-expansion": "^2.0.1"
1875 | },
1876 | "engines": {
1877 | "node": ">=16 || 14 >=14.17"
1878 | },
1879 | "funding": {
1880 | "url": "https://github.com/sponsors/isaacs"
1881 | }
1882 | },
1883 | "node_modules/minipass": {
1884 | "version": "7.1.2",
1885 | "resolved": "https://registry.npmjs.org/minipass/-/minipass-7.1.2.tgz",
1886 | "integrity": "sha512-qOOzS1cBTWYF4BH8fVePDBOO9iptMnGUEZwNc/cMWnTV2nVLZ7VoNWEPHkYczZA0pdoA7dl6e7FL659nX9S2aw==",
1887 | "dev": true,
1888 | "license": "ISC",
1889 | "engines": {
1890 | "node": ">=16 || 14 >=14.17"
1891 | }
1892 | },
1893 | "node_modules/ms": {
1894 | "version": "2.1.3",
1895 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz",
1896 | "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==",
1897 | "dev": true,
1898 | "license": "MIT"
1899 | },
1900 | "node_modules/n4s": {
1901 | "version": "5.0.28",
1902 | "resolved": "https://registry.npmjs.org/n4s/-/n4s-5.0.28.tgz",
1903 | "integrity": "sha512-64ap7Qn8Oyua2ImIZH6/pkql89qyiTZ4jJqpS2g863++0tgbM4cuv3KJvZqMpa8kY2ovZ4q3cD0/KU4SImjg5g==",
1904 | "license": "MIT",
1905 | "dependencies": {
1906 | "context": "^3.0.33",
1907 | "vest-utils": "^1.3.3"
1908 | }
1909 | },
1910 | "node_modules/nanoid": {
1911 | "version": "3.3.8",
1912 | "resolved": "https://registry.npmjs.org/nanoid/-/nanoid-3.3.8.tgz",
1913 | "integrity": "sha512-WNLf5Sd8oZxOm+TzppcYk8gVOgP+l58xNy58D0nbUnOxOWRWvlcCV4kUF7ltmI6PsrLl/BgKEyS4mqsGChFN0w==",
1914 | "dev": true,
1915 | "funding": [
1916 | {
1917 | "type": "github",
1918 | "url": "https://github.com/sponsors/ai"
1919 | }
1920 | ],
1921 | "license": "MIT",
1922 | "bin": {
1923 | "nanoid": "bin/nanoid.cjs"
1924 | },
1925 | "engines": {
1926 | "node": "^10 || ^12 || ^13.7 || ^14 || >=15.0.1"
1927 | }
1928 | },
1929 | "node_modules/node-releases": {
1930 | "version": "2.0.19",
1931 | "resolved": "https://registry.npmjs.org/node-releases/-/node-releases-2.0.19.tgz",
1932 | "integrity": "sha512-xxOWJsBKtzAq7DY0J+DTzuz58K8e7sJbdgwkbMWQe8UYB6ekmsQ45q0M/tJDsGaZmbC+l7n57UV8Hl5tHxO9uw==",
1933 | "dev": true,
1934 | "license": "MIT"
1935 | },
1936 | "node_modules/package-json-from-dist": {
1937 | "version": "1.0.1",
1938 | "resolved": "https://registry.npmjs.org/package-json-from-dist/-/package-json-from-dist-1.0.1.tgz",
1939 | "integrity": "sha512-UEZIS3/by4OC8vL3P2dTXRETpebLI2NiI5vIrjaD/5UtrkFX/tNbwjTSRAGC/+7CAo2pIcBaRgWmcBBHcsaCIw==",
1940 | "dev": true,
1941 | "license": "BlueOak-1.0.0"
1942 | },
1943 | "node_modules/path-key": {
1944 | "version": "3.1.1",
1945 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz",
1946 | "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==",
1947 | "dev": true,
1948 | "license": "MIT",
1949 | "engines": {
1950 | "node": ">=8"
1951 | }
1952 | },
1953 | "node_modules/path-scurry": {
1954 | "version": "1.11.1",
1955 | "resolved": "https://registry.npmjs.org/path-scurry/-/path-scurry-1.11.1.tgz",
1956 | "integrity": "sha512-Xa4Nw17FS9ApQFJ9umLiJS4orGjm7ZzwUrwamcGQuHSzDyth9boKDaycYdDcZDuqYATXw4HFXgaqWTctW/v1HA==",
1957 | "dev": true,
1958 | "license": "BlueOak-1.0.0",
1959 | "dependencies": {
1960 | "lru-cache": "^10.2.0",
1961 | "minipass": "^5.0.0 || ^6.0.2 || ^7.0.0"
1962 | },
1963 | "engines": {
1964 | "node": ">=16 || 14 >=14.18"
1965 | },
1966 | "funding": {
1967 | "url": "https://github.com/sponsors/isaacs"
1968 | }
1969 | },
1970 | "node_modules/path-scurry/node_modules/lru-cache": {
1971 | "version": "10.4.3",
1972 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-10.4.3.tgz",
1973 | "integrity": "sha512-JNAzZcXrCt42VGLuYz0zfAzDfAvJWW6AfYlDBQyDV5DClI2m5sAmK+OIO7s59XfsRsWHp02jAJrRadPRGTt6SQ==",
1974 | "dev": true,
1975 | "license": "ISC"
1976 | },
1977 | "node_modules/pathe": {
1978 | "version": "2.0.3",
1979 | "resolved": "https://registry.npmjs.org/pathe/-/pathe-2.0.3.tgz",
1980 | "integrity": "sha512-WUjGcAqP1gQacoQe+OBJsFA7Ld4DyXuUIjZ5cc75cLHvJ7dtNsTugphxIADwspS+AraAUePCKrSVtPLFj/F88w==",
1981 | "dev": true,
1982 | "license": "MIT"
1983 | },
1984 | "node_modules/pathval": {
1985 | "version": "2.0.0",
1986 | "resolved": "https://registry.npmjs.org/pathval/-/pathval-2.0.0.tgz",
1987 | "integrity": "sha512-vE7JKRyES09KiunauX7nd2Q9/L7lhok4smP9RZTDeD4MVs72Dp2qNFVz39Nz5a0FVEW0BJR6C0DYrq6unoziZA==",
1988 | "dev": true,
1989 | "license": "MIT",
1990 | "engines": {
1991 | "node": ">= 14.16"
1992 | }
1993 | },
1994 | "node_modules/picocolors": {
1995 | "version": "1.1.1",
1996 | "resolved": "https://registry.npmjs.org/picocolors/-/picocolors-1.1.1.tgz",
1997 | "integrity": "sha512-xceH2snhtb5M9liqDsmEw56le376mTZkEX/jEb/RxNFyegNul7eNslCXP9FDj/Lcu0X8KEyMceP2ntpaHrDEVA==",
1998 | "dev": true,
1999 | "license": "ISC"
2000 | },
2001 | "node_modules/postcss": {
2002 | "version": "8.5.3",
2003 | "resolved": "https://registry.npmjs.org/postcss/-/postcss-8.5.3.tgz",
2004 | "integrity": "sha512-dle9A3yYxlBSrt8Fu+IpjGT8SY8hN0mlaA6GY8t0P5PjIOZemULz/E2Bnm/2dcUOena75OTNkHI76uZBNUUq3A==",
2005 | "dev": true,
2006 | "funding": [
2007 | {
2008 | "type": "opencollective",
2009 | "url": "https://opencollective.com/postcss/"
2010 | },
2011 | {
2012 | "type": "tidelift",
2013 | "url": "https://tidelift.com/funding/github/npm/postcss"
2014 | },
2015 | {
2016 | "type": "github",
2017 | "url": "https://github.com/sponsors/ai"
2018 | }
2019 | ],
2020 | "license": "MIT",
2021 | "dependencies": {
2022 | "nanoid": "^3.3.8",
2023 | "picocolors": "^1.1.1",
2024 | "source-map-js": "^1.2.1"
2025 | },
2026 | "engines": {
2027 | "node": "^10 || ^12 || >=14"
2028 | }
2029 | },
2030 | "node_modules/rollup": {
2031 | "version": "4.34.9",
2032 | "resolved": "https://registry.npmjs.org/rollup/-/rollup-4.34.9.tgz",
2033 | "integrity": "sha512-nF5XYqWWp9hx/LrpC8sZvvvmq0TeTjQgaZHYmAgwysT9nh8sWnZhBnM8ZyVbbJFIQBLwHDNoMqsBZBbUo4U8sQ==",
2034 | "dev": true,
2035 | "license": "MIT",
2036 | "dependencies": {
2037 | "@types/estree": "1.0.6"
2038 | },
2039 | "bin": {
2040 | "rollup": "dist/bin/rollup"
2041 | },
2042 | "engines": {
2043 | "node": ">=18.0.0",
2044 | "npm": ">=8.0.0"
2045 | },
2046 | "optionalDependencies": {
2047 | "@rollup/rollup-android-arm-eabi": "4.34.9",
2048 | "@rollup/rollup-android-arm64": "4.34.9",
2049 | "@rollup/rollup-darwin-arm64": "4.34.9",
2050 | "@rollup/rollup-darwin-x64": "4.34.9",
2051 | "@rollup/rollup-freebsd-arm64": "4.34.9",
2052 | "@rollup/rollup-freebsd-x64": "4.34.9",
2053 | "@rollup/rollup-linux-arm-gnueabihf": "4.34.9",
2054 | "@rollup/rollup-linux-arm-musleabihf": "4.34.9",
2055 | "@rollup/rollup-linux-arm64-gnu": "4.34.9",
2056 | "@rollup/rollup-linux-arm64-musl": "4.34.9",
2057 | "@rollup/rollup-linux-loongarch64-gnu": "4.34.9",
2058 | "@rollup/rollup-linux-powerpc64le-gnu": "4.34.9",
2059 | "@rollup/rollup-linux-riscv64-gnu": "4.34.9",
2060 | "@rollup/rollup-linux-s390x-gnu": "4.34.9",
2061 | "@rollup/rollup-linux-x64-gnu": "4.34.9",
2062 | "@rollup/rollup-linux-x64-musl": "4.34.9",
2063 | "@rollup/rollup-win32-arm64-msvc": "4.34.9",
2064 | "@rollup/rollup-win32-ia32-msvc": "4.34.9",
2065 | "@rollup/rollup-win32-x64-msvc": "4.34.9",
2066 | "fsevents": "~2.3.2"
2067 | }
2068 | },
2069 | "node_modules/semver": {
2070 | "version": "7.7.1",
2071 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.7.1.tgz",
2072 | "integrity": "sha512-hlq8tAfn0m/61p4BVRcPzIGr6LKiMwo4VM6dGi6pt4qcRkmNzTcWq6eCEjEh+qXjkMDvPlOFFSGwQjoEa6gyMA==",
2073 | "dev": true,
2074 | "license": "ISC",
2075 | "bin": {
2076 | "semver": "bin/semver.js"
2077 | },
2078 | "engines": {
2079 | "node": ">=10"
2080 | }
2081 | },
2082 | "node_modules/shebang-command": {
2083 | "version": "2.0.0",
2084 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz",
2085 | "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==",
2086 | "dev": true,
2087 | "license": "MIT",
2088 | "dependencies": {
2089 | "shebang-regex": "^3.0.0"
2090 | },
2091 | "engines": {
2092 | "node": ">=8"
2093 | }
2094 | },
2095 | "node_modules/shebang-regex": {
2096 | "version": "3.0.0",
2097 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz",
2098 | "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==",
2099 | "dev": true,
2100 | "license": "MIT",
2101 | "engines": {
2102 | "node": ">=8"
2103 | }
2104 | },
2105 | "node_modules/siginfo": {
2106 | "version": "2.0.0",
2107 | "resolved": "https://registry.npmjs.org/siginfo/-/siginfo-2.0.0.tgz",
2108 | "integrity": "sha512-ybx0WO1/8bSBLEWXZvEd7gMW3Sn3JFlW3TvX1nREbDLRNQNaeNN8WK0meBwPdAaOI7TtRRRJn/Es1zhrrCHu7g==",
2109 | "dev": true,
2110 | "license": "ISC"
2111 | },
2112 | "node_modules/signal-exit": {
2113 | "version": "4.1.0",
2114 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-4.1.0.tgz",
2115 | "integrity": "sha512-bzyZ1e88w9O1iNJbKnOlvYTrWPDl46O1bG0D3XInv+9tkPrxrN8jUUTiFlDkkmKWgn1M6CfIA13SuGqOa9Korw==",
2116 | "dev": true,
2117 | "license": "ISC",
2118 | "engines": {
2119 | "node": ">=14"
2120 | },
2121 | "funding": {
2122 | "url": "https://github.com/sponsors/isaacs"
2123 | }
2124 | },
2125 | "node_modules/source-map-js": {
2126 | "version": "1.2.1",
2127 | "resolved": "https://registry.npmjs.org/source-map-js/-/source-map-js-1.2.1.tgz",
2128 | "integrity": "sha512-UXWMKhLOwVKb728IUtQPXxfYU+usdybtUrK/8uGE8CQMvrhOpwvzDBwj0QhSL7MQc7vIsISBG8VQ8+IDQxpfQA==",
2129 | "dev": true,
2130 | "license": "BSD-3-Clause",
2131 | "engines": {
2132 | "node": ">=0.10.0"
2133 | }
2134 | },
2135 | "node_modules/stackback": {
2136 | "version": "0.0.2",
2137 | "resolved": "https://registry.npmjs.org/stackback/-/stackback-0.0.2.tgz",
2138 | "integrity": "sha512-1XMJE5fQo1jGH6Y/7ebnwPOBEkIEnT4QF32d5R1+VXdXveM0IBMJt8zfaxX1P3QhVwrYe+576+jkANtSS2mBbw==",
2139 | "dev": true,
2140 | "license": "MIT"
2141 | },
2142 | "node_modules/std-env": {
2143 | "version": "3.8.1",
2144 | "resolved": "https://registry.npmjs.org/std-env/-/std-env-3.8.1.tgz",
2145 | "integrity": "sha512-vj5lIj3Mwf9D79hBkltk5qmkFI+biIKWS2IBxEyEU3AX1tUf7AoL8nSazCOiiqQsGKIq01SClsKEzweu34uwvA==",
2146 | "dev": true,
2147 | "license": "MIT"
2148 | },
2149 | "node_modules/string-width": {
2150 | "version": "5.1.2",
2151 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-5.1.2.tgz",
2152 | "integrity": "sha512-HnLOCR3vjcY8beoNLtcjZ5/nxn2afmME6lhrDrebokqMap+XbeW8n9TXpPDOqdGK5qcI3oT0GKTW6wC7EMiVqA==",
2153 | "dev": true,
2154 | "license": "MIT",
2155 | "dependencies": {
2156 | "eastasianwidth": "^0.2.0",
2157 | "emoji-regex": "^9.2.2",
2158 | "strip-ansi": "^7.0.1"
2159 | },
2160 | "engines": {
2161 | "node": ">=12"
2162 | },
2163 | "funding": {
2164 | "url": "https://github.com/sponsors/sindresorhus"
2165 | }
2166 | },
2167 | "node_modules/string-width-cjs": {
2168 | "name": "string-width",
2169 | "version": "4.2.3",
2170 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz",
2171 | "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==",
2172 | "dev": true,
2173 | "license": "MIT",
2174 | "dependencies": {
2175 | "emoji-regex": "^8.0.0",
2176 | "is-fullwidth-code-point": "^3.0.0",
2177 | "strip-ansi": "^6.0.1"
2178 | },
2179 | "engines": {
2180 | "node": ">=8"
2181 | }
2182 | },
2183 | "node_modules/string-width-cjs/node_modules/ansi-regex": {
2184 | "version": "5.0.1",
2185 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz",
2186 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==",
2187 | "dev": true,
2188 | "license": "MIT",
2189 | "engines": {
2190 | "node": ">=8"
2191 | }
2192 | },
2193 | "node_modules/string-width-cjs/node_modules/emoji-regex": {
2194 | "version": "8.0.0",
2195 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz",
2196 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==",
2197 | "dev": true,
2198 | "license": "MIT"
2199 | },
2200 | "node_modules/string-width-cjs/node_modules/strip-ansi": {
2201 | "version": "6.0.1",
2202 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz",
2203 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==",
2204 | "dev": true,
2205 | "license": "MIT",
2206 | "dependencies": {
2207 | "ansi-regex": "^5.0.1"
2208 | },
2209 | "engines": {
2210 | "node": ">=8"
2211 | }
2212 | },
2213 | "node_modules/strip-ansi": {
2214 | "version": "7.1.0",
2215 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-7.1.0.tgz",
2216 | "integrity": "sha512-iq6eVVI64nQQTRYq2KtEg2d2uU7LElhTJwsH4YzIHZshxlgZms/wIc4VoDQTlG/IvVIrBKG06CrZnp0qv7hkcQ==",
2217 | "dev": true,
2218 | "license": "MIT",
2219 | "dependencies": {
2220 | "ansi-regex": "^6.0.1"
2221 | },
2222 | "engines": {
2223 | "node": ">=12"
2224 | },
2225 | "funding": {
2226 | "url": "https://github.com/chalk/strip-ansi?sponsor=1"
2227 | }
2228 | },
2229 | "node_modules/strip-ansi-cjs": {
2230 | "name": "strip-ansi",
2231 | "version": "6.0.1",
2232 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz",
2233 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==",
2234 | "dev": true,
2235 | "license": "MIT",
2236 | "dependencies": {
2237 | "ansi-regex": "^5.0.1"
2238 | },
2239 | "engines": {
2240 | "node": ">=8"
2241 | }
2242 | },
2243 | "node_modules/strip-ansi-cjs/node_modules/ansi-regex": {
2244 | "version": "5.0.1",
2245 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz",
2246 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==",
2247 | "dev": true,
2248 | "license": "MIT",
2249 | "engines": {
2250 | "node": ">=8"
2251 | }
2252 | },
2253 | "node_modules/supports-color": {
2254 | "version": "7.2.0",
2255 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz",
2256 | "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==",
2257 | "dev": true,
2258 | "license": "MIT",
2259 | "dependencies": {
2260 | "has-flag": "^4.0.0"
2261 | },
2262 | "engines": {
2263 | "node": ">=8"
2264 | }
2265 | },
2266 | "node_modules/test-exclude": {
2267 | "version": "7.0.1",
2268 | "resolved": "https://registry.npmjs.org/test-exclude/-/test-exclude-7.0.1.tgz",
2269 | "integrity": "sha512-pFYqmTw68LXVjeWJMST4+borgQP2AyMNbg1BpZh9LbyhUeNkeaPF9gzfPGUAnSMV3qPYdWUwDIjjCLiSDOl7vg==",
2270 | "dev": true,
2271 | "license": "ISC",
2272 | "dependencies": {
2273 | "@istanbuljs/schema": "^0.1.2",
2274 | "glob": "^10.4.1",
2275 | "minimatch": "^9.0.4"
2276 | },
2277 | "engines": {
2278 | "node": ">=18"
2279 | }
2280 | },
2281 | "node_modules/tinybench": {
2282 | "version": "2.9.0",
2283 | "resolved": "https://registry.npmjs.org/tinybench/-/tinybench-2.9.0.tgz",
2284 | "integrity": "sha512-0+DUvqWMValLmha6lr4kD8iAMK1HzV0/aKnCtWb9v9641TnP/MFb7Pc2bxoxQjTXAErryXVgUOfv2YqNllqGeg==",
2285 | "dev": true,
2286 | "license": "MIT"
2287 | },
2288 | "node_modules/tinyexec": {
2289 | "version": "0.3.2",
2290 | "resolved": "https://registry.npmjs.org/tinyexec/-/tinyexec-0.3.2.tgz",
2291 | "integrity": "sha512-KQQR9yN7R5+OSwaK0XQoj22pwHoTlgYqmUscPYoknOoWCWfj/5/ABTMRi69FrKU5ffPVh5QcFikpWJI/P1ocHA==",
2292 | "dev": true,
2293 | "license": "MIT"
2294 | },
2295 | "node_modules/tinypool": {
2296 | "version": "1.0.2",
2297 | "resolved": "https://registry.npmjs.org/tinypool/-/tinypool-1.0.2.tgz",
2298 | "integrity": "sha512-al6n+QEANGFOMf/dmUMsuS5/r9B06uwlyNjZZql/zv8J7ybHCgoihBNORZCY2mzUuAnomQa2JdhyHKzZxPCrFA==",
2299 | "dev": true,
2300 | "license": "MIT",
2301 | "engines": {
2302 | "node": "^18.0.0 || >=20.0.0"
2303 | }
2304 | },
2305 | "node_modules/tinyrainbow": {
2306 | "version": "2.0.0",
2307 | "resolved": "https://registry.npmjs.org/tinyrainbow/-/tinyrainbow-2.0.0.tgz",
2308 | "integrity": "sha512-op4nsTR47R6p0vMUUoYl/a+ljLFVtlfaXkLQmqfLR1qHma1h/ysYk4hEXZ880bf2CYgTskvTa/e196Vd5dDQXw==",
2309 | "dev": true,
2310 | "license": "MIT",
2311 | "engines": {
2312 | "node": ">=14.0.0"
2313 | }
2314 | },
2315 | "node_modules/tinyspy": {
2316 | "version": "3.0.2",
2317 | "resolved": "https://registry.npmjs.org/tinyspy/-/tinyspy-3.0.2.tgz",
2318 | "integrity": "sha512-n1cw8k1k0x4pgA2+9XrOkFydTerNcJ1zWCO5Nn9scWHTD+5tp8dghT2x1uduQePZTZgd3Tupf+x9BxJjeJi77Q==",
2319 | "dev": true,
2320 | "license": "MIT",
2321 | "engines": {
2322 | "node": ">=14.0.0"
2323 | }
2324 | },
2325 | "node_modules/typescript": {
2326 | "version": "5.7.3",
2327 | "resolved": "https://registry.npmjs.org/typescript/-/typescript-5.7.3.tgz",
2328 | "integrity": "sha512-84MVSjMEHP+FQRPy3pX9sTVV/INIex71s9TL2Gm5FG/WG1SqXeKyZ0k7/blY/4FdOzI12CBy1vGc4og/eus0fw==",
2329 | "dev": true,
2330 | "license": "Apache-2.0",
2331 | "bin": {
2332 | "tsc": "bin/tsc",
2333 | "tsserver": "bin/tsserver"
2334 | },
2335 | "engines": {
2336 | "node": ">=14.17"
2337 | }
2338 | },
2339 | "node_modules/update-browserslist-db": {
2340 | "version": "1.1.3",
2341 | "resolved": "https://registry.npmjs.org/update-browserslist-db/-/update-browserslist-db-1.1.3.tgz",
2342 | "integrity": "sha512-UxhIZQ+QInVdunkDAaiazvvT/+fXL5Osr0JZlJulepYu6Jd7qJtDZjlur0emRlT71EN3ScPoE7gvsuIKKNavKw==",
2343 | "dev": true,
2344 | "funding": [
2345 | {
2346 | "type": "opencollective",
2347 | "url": "https://opencollective.com/browserslist"
2348 | },
2349 | {
2350 | "type": "tidelift",
2351 | "url": "https://tidelift.com/funding/github/npm/browserslist"
2352 | },
2353 | {
2354 | "type": "github",
2355 | "url": "https://github.com/sponsors/ai"
2356 | }
2357 | ],
2358 | "license": "MIT",
2359 | "dependencies": {
2360 | "escalade": "^3.2.0",
2361 | "picocolors": "^1.1.1"
2362 | },
2363 | "bin": {
2364 | "update-browserslist-db": "cli.js"
2365 | },
2366 | "peerDependencies": {
2367 | "browserslist": ">= 4.21.0"
2368 | }
2369 | },
2370 | "node_modules/vast": {
2371 | "version": "1.0.42",
2372 | "resolved": "https://registry.npmjs.org/vast/-/vast-1.0.42.tgz",
2373 | "integrity": "sha512-YP3zNDRVZZRuHgUJ5xD7HAF0AFius2KWqIYSAuzA6E4ftPkL+gSQrp9agPM1HgsHS9L7XWoegYxsH81kawztuQ==",
2374 | "license": "MIT",
2375 | "dependencies": {
2376 | "vest-utils": "^1.3.3"
2377 | }
2378 | },
2379 | "node_modules/vest": {
2380 | "version": "5.4.6",
2381 | "resolved": "https://registry.npmjs.org/vest/-/vest-5.4.6.tgz",
2382 | "integrity": "sha512-Q3KQYluxdjnz5/HmR8coHNlXbJPLWMfrwz4wlcqMX4SaJ8qcmy5Ix9NTiQt3hTMrETdj+q+513J/kt+ahdJlLg==",
2383 | "license": "MIT",
2384 | "dependencies": {
2385 | "context": "^3.0.33",
2386 | "n4s": "^5.0.28",
2387 | "vast": "^1.0.42",
2388 | "vest-utils": "^1.3.3",
2389 | "vestjs-runtime": "^1.5.1"
2390 | }
2391 | },
2392 | "node_modules/vest-utils": {
2393 | "version": "1.3.3",
2394 | "resolved": "https://registry.npmjs.org/vest-utils/-/vest-utils-1.3.3.tgz",
2395 | "integrity": "sha512-9y+26YXjOpv89QmEXlFrTFLUMwUjAuwpimUVgb8HS3eNuBR3HEY68o4U/sPyGTh3OEvS7N502pX82WDm1zvsaA==",
2396 | "license": "MIT"
2397 | },
2398 | "node_modules/vestjs-runtime": {
2399 | "version": "1.5.1",
2400 | "resolved": "https://registry.npmjs.org/vestjs-runtime/-/vestjs-runtime-1.5.1.tgz",
2401 | "integrity": "sha512-kiXuNJBS/6ZkzMArLuiEBtXe/cMr/8NE4lp6flpLuEzVwXM2nli9UfvQ26lmuvU1/ggPgjJNv/FpSnWofvHYcA==",
2402 | "license": "MIT",
2403 | "dependencies": {
2404 | "context": "^3.0.33",
2405 | "vest-utils": "^1.3.3"
2406 | }
2407 | },
2408 | "node_modules/vite": {
2409 | "version": "6.2.0",
2410 | "resolved": "https://registry.npmjs.org/vite/-/vite-6.2.0.tgz",
2411 | "integrity": "sha512-7dPxoo+WsT/64rDcwoOjk76XHj+TqNTIvHKcuMQ1k4/SeHDaQt5GFAeLYzrimZrMpn/O6DtdI03WUjdxuPM0oQ==",
2412 | "dev": true,
2413 | "license": "MIT",
2414 | "dependencies": {
2415 | "esbuild": "^0.25.0",
2416 | "postcss": "^8.5.3",
2417 | "rollup": "^4.30.1"
2418 | },
2419 | "bin": {
2420 | "vite": "bin/vite.js"
2421 | },
2422 | "engines": {
2423 | "node": "^18.0.0 || ^20.0.0 || >=22.0.0"
2424 | },
2425 | "funding": {
2426 | "url": "https://github.com/vitejs/vite?sponsor=1"
2427 | },
2428 | "optionalDependencies": {
2429 | "fsevents": "~2.3.3"
2430 | },
2431 | "peerDependencies": {
2432 | "@types/node": "^18.0.0 || ^20.0.0 || >=22.0.0",
2433 | "jiti": ">=1.21.0",
2434 | "less": "*",
2435 | "lightningcss": "^1.21.0",
2436 | "sass": "*",
2437 | "sass-embedded": "*",
2438 | "stylus": "*",
2439 | "sugarss": "*",
2440 | "terser": "^5.16.0",
2441 | "tsx": "^4.8.1",
2442 | "yaml": "^2.4.2"
2443 | },
2444 | "peerDependenciesMeta": {
2445 | "@types/node": {
2446 | "optional": true
2447 | },
2448 | "jiti": {
2449 | "optional": true
2450 | },
2451 | "less": {
2452 | "optional": true
2453 | },
2454 | "lightningcss": {
2455 | "optional": true
2456 | },
2457 | "sass": {
2458 | "optional": true
2459 | },
2460 | "sass-embedded": {
2461 | "optional": true
2462 | },
2463 | "stylus": {
2464 | "optional": true
2465 | },
2466 | "sugarss": {
2467 | "optional": true
2468 | },
2469 | "terser": {
2470 | "optional": true
2471 | },
2472 | "tsx": {
2473 | "optional": true
2474 | },
2475 | "yaml": {
2476 | "optional": true
2477 | }
2478 | }
2479 | },
2480 | "node_modules/vite-node": {
2481 | "version": "3.0.7",
2482 | "resolved": "https://registry.npmjs.org/vite-node/-/vite-node-3.0.7.tgz",
2483 | "integrity": "sha512-2fX0QwX4GkkkpULXdT1Pf4q0tC1i1lFOyseKoonavXUNlQ77KpW2XqBGGNIm/J4Ows4KxgGJzDguYVPKwG/n5A==",
2484 | "dev": true,
2485 | "license": "MIT",
2486 | "dependencies": {
2487 | "cac": "^6.7.14",
2488 | "debug": "^4.4.0",
2489 | "es-module-lexer": "^1.6.0",
2490 | "pathe": "^2.0.3",
2491 | "vite": "^5.0.0 || ^6.0.0"
2492 | },
2493 | "bin": {
2494 | "vite-node": "vite-node.mjs"
2495 | },
2496 | "engines": {
2497 | "node": "^18.0.0 || ^20.0.0 || >=22.0.0"
2498 | },
2499 | "funding": {
2500 | "url": "https://opencollective.com/vitest"
2501 | }
2502 | },
2503 | "node_modules/vitest": {
2504 | "version": "3.0.7",
2505 | "resolved": "https://registry.npmjs.org/vitest/-/vitest-3.0.7.tgz",
2506 | "integrity": "sha512-IP7gPK3LS3Fvn44x30X1dM9vtawm0aesAa2yBIZ9vQf+qB69NXC5776+Qmcr7ohUXIQuLhk7xQR0aSUIDPqavg==",
2507 | "dev": true,
2508 | "license": "MIT",
2509 | "dependencies": {
2510 | "@vitest/expect": "3.0.7",
2511 | "@vitest/mocker": "3.0.7",
2512 | "@vitest/pretty-format": "^3.0.7",
2513 | "@vitest/runner": "3.0.7",
2514 | "@vitest/snapshot": "3.0.7",
2515 | "@vitest/spy": "3.0.7",
2516 | "@vitest/utils": "3.0.7",
2517 | "chai": "^5.2.0",
2518 | "debug": "^4.4.0",
2519 | "expect-type": "^1.1.0",
2520 | "magic-string": "^0.30.17",
2521 | "pathe": "^2.0.3",
2522 | "std-env": "^3.8.0",
2523 | "tinybench": "^2.9.0",
2524 | "tinyexec": "^0.3.2",
2525 | "tinypool": "^1.0.2",
2526 | "tinyrainbow": "^2.0.0",
2527 | "vite": "^5.0.0 || ^6.0.0",
2528 | "vite-node": "3.0.7",
2529 | "why-is-node-running": "^2.3.0"
2530 | },
2531 | "bin": {
2532 | "vitest": "vitest.mjs"
2533 | },
2534 | "engines": {
2535 | "node": "^18.0.0 || ^20.0.0 || >=22.0.0"
2536 | },
2537 | "funding": {
2538 | "url": "https://opencollective.com/vitest"
2539 | },
2540 | "peerDependencies": {
2541 | "@edge-runtime/vm": "*",
2542 | "@types/debug": "^4.1.12",
2543 | "@types/node": "^18.0.0 || ^20.0.0 || >=22.0.0",
2544 | "@vitest/browser": "3.0.7",
2545 | "@vitest/ui": "3.0.7",
2546 | "happy-dom": "*",
2547 | "jsdom": "*"
2548 | },
2549 | "peerDependenciesMeta": {
2550 | "@edge-runtime/vm": {
2551 | "optional": true
2552 | },
2553 | "@types/debug": {
2554 | "optional": true
2555 | },
2556 | "@types/node": {
2557 | "optional": true
2558 | },
2559 | "@vitest/browser": {
2560 | "optional": true
2561 | },
2562 | "@vitest/ui": {
2563 | "optional": true
2564 | },
2565 | "happy-dom": {
2566 | "optional": true
2567 | },
2568 | "jsdom": {
2569 | "optional": true
2570 | }
2571 | }
2572 | },
2573 | "node_modules/which": {
2574 | "version": "2.0.2",
2575 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz",
2576 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==",
2577 | "dev": true,
2578 | "license": "ISC",
2579 | "dependencies": {
2580 | "isexe": "^2.0.0"
2581 | },
2582 | "bin": {
2583 | "node-which": "bin/node-which"
2584 | },
2585 | "engines": {
2586 | "node": ">= 8"
2587 | }
2588 | },
2589 | "node_modules/why-is-node-running": {
2590 | "version": "2.3.0",
2591 | "resolved": "https://registry.npmjs.org/why-is-node-running/-/why-is-node-running-2.3.0.tgz",
2592 | "integrity": "sha512-hUrmaWBdVDcxvYqnyh09zunKzROWjbZTiNy8dBEjkS7ehEDQibXJ7XvlmtbwuTclUiIyN+CyXQD4Vmko8fNm8w==",
2593 | "dev": true,
2594 | "license": "MIT",
2595 | "dependencies": {
2596 | "siginfo": "^2.0.0",
2597 | "stackback": "0.0.2"
2598 | },
2599 | "bin": {
2600 | "why-is-node-running": "cli.js"
2601 | },
2602 | "engines": {
2603 | "node": ">=8"
2604 | }
2605 | },
2606 | "node_modules/wrap-ansi": {
2607 | "version": "8.1.0",
2608 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-8.1.0.tgz",
2609 | "integrity": "sha512-si7QWI6zUMq56bESFvagtmzMdGOtoxfR+Sez11Mobfc7tm+VkUckk9bW2UeffTGVUbOksxmSw0AA2gs8g71NCQ==",
2610 | "dev": true,
2611 | "license": "MIT",
2612 | "dependencies": {
2613 | "ansi-styles": "^6.1.0",
2614 | "string-width": "^5.0.1",
2615 | "strip-ansi": "^7.0.1"
2616 | },
2617 | "engines": {
2618 | "node": ">=12"
2619 | },
2620 | "funding": {
2621 | "url": "https://github.com/chalk/wrap-ansi?sponsor=1"
2622 | }
2623 | },
2624 | "node_modules/wrap-ansi-cjs": {
2625 | "name": "wrap-ansi",
2626 | "version": "7.0.0",
2627 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz",
2628 | "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==",
2629 | "dev": true,
2630 | "license": "MIT",
2631 | "dependencies": {
2632 | "ansi-styles": "^4.0.0",
2633 | "string-width": "^4.1.0",
2634 | "strip-ansi": "^6.0.0"
2635 | },
2636 | "engines": {
2637 | "node": ">=10"
2638 | },
2639 | "funding": {
2640 | "url": "https://github.com/chalk/wrap-ansi?sponsor=1"
2641 | }
2642 | },
2643 | "node_modules/wrap-ansi-cjs/node_modules/ansi-regex": {
2644 | "version": "5.0.1",
2645 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz",
2646 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==",
2647 | "dev": true,
2648 | "license": "MIT",
2649 | "engines": {
2650 | "node": ">=8"
2651 | }
2652 | },
2653 | "node_modules/wrap-ansi-cjs/node_modules/ansi-styles": {
2654 | "version": "4.3.0",
2655 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz",
2656 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==",
2657 | "dev": true,
2658 | "license": "MIT",
2659 | "dependencies": {
2660 | "color-convert": "^2.0.1"
2661 | },
2662 | "engines": {
2663 | "node": ">=8"
2664 | },
2665 | "funding": {
2666 | "url": "https://github.com/chalk/ansi-styles?sponsor=1"
2667 | }
2668 | },
2669 | "node_modules/wrap-ansi-cjs/node_modules/emoji-regex": {
2670 | "version": "8.0.0",
2671 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz",
2672 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==",
2673 | "dev": true,
2674 | "license": "MIT"
2675 | },
2676 | "node_modules/wrap-ansi-cjs/node_modules/string-width": {
2677 | "version": "4.2.3",
2678 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz",
2679 | "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==",
2680 | "dev": true,
2681 | "license": "MIT",
2682 | "dependencies": {
2683 | "emoji-regex": "^8.0.0",
2684 | "is-fullwidth-code-point": "^3.0.0",
2685 | "strip-ansi": "^6.0.1"
2686 | },
2687 | "engines": {
2688 | "node": ">=8"
2689 | }
2690 | },
2691 | "node_modules/wrap-ansi-cjs/node_modules/strip-ansi": {
2692 | "version": "6.0.1",
2693 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz",
2694 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==",
2695 | "dev": true,
2696 | "license": "MIT",
2697 | "dependencies": {
2698 | "ansi-regex": "^5.0.1"
2699 | },
2700 | "engines": {
2701 | "node": ">=8"
2702 | }
2703 | },
2704 | "node_modules/yallist": {
2705 | "version": "3.1.1",
2706 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-3.1.1.tgz",
2707 | "integrity": "sha512-a4UGQaWPH59mOXUYnAG2ewncQS4i4F43Tv3JoAM+s2VDAmS9NsK8GpDMLrCHPksFT7h3K6TOoUNn2pb7RoXx4g==",
2708 | "dev": true,
2709 | "license": "ISC"
2710 | },
2711 | "node_modules/zod": {
2712 | "version": "3.24.1",
2713 | "resolved": "https://registry.npmjs.org/zod/-/zod-3.24.1.tgz",
2714 | "integrity": "sha512-muH7gBL9sI1nciMZV67X5fTKKBLtwpZ5VBp1vsOQzj1MhrBZ4wlVCm3gedKZWLp0Oyel8sIGfeiz54Su+OVT+A==",
2715 | "license": "MIT",
2716 | "funding": {
2717 | "url": "https://github.com/sponsors/colinhacks"
2718 | }
2719 | }
2720 | }
2721 | }
2722 |
--------------------------------------------------------------------------------
/package.json:
--------------------------------------------------------------------------------
1 | {
2 | "name": "formik-validation-adaptors",
3 | "version": "1.2.3",
4 | "main": "dist/index.js",
5 | "module": "dist/index.js",
6 | "type": "module",
7 | "files": [
8 | "dist"
9 | ],
10 | "scripts": {
11 | "build": "tsc",
12 | "test": "vitest",
13 | "test:coverage": "vitest --coverage"
14 | },
15 | "repository": {
16 | "type": "git",
17 | "url": "git+https://github.com/kom50/formik-validation-adapters.git"
18 | },
19 | "keywords": [
20 | "formik",
21 | "validation",
22 | "zod",
23 | "joi",
24 | "adaptors"
25 | ],
26 | "author": "kom50",
27 | "license": "ISC",
28 | "description": "A lightweight utility to integrate Zod and Joi validation with Formik.",
29 | "dependencies": {
30 | "joi": "^17.13.3",
31 | "vest": "^5.4.6",
32 | "zod": "^3.24.1"
33 | },
34 | "devDependencies": {
35 | "@vitest/coverage-istanbul": "^3.0.7",
36 | "typescript": "^5.7.3",
37 | "vitest": "^3.0.7"
38 | }
39 | }
40 |
--------------------------------------------------------------------------------
/test/joiValidator.test.ts:
--------------------------------------------------------------------------------
1 | import { describe, it, expect } from "vitest";
2 | import { formikJoiValidator } from "../lib/index";
3 | import Joi from "joi";
4 |
5 | describe("formikJoiValidator", () => {
6 | const schema = Joi.object({
7 | name: Joi.string().min(3).required().messages({
8 | "string.min": "Name must be at least 3 characters",
9 | "any.required": "Name is required",
10 | "string.empty": "Name is required",
11 | }),
12 | email: Joi.string().email().required().messages({
13 | "string.email": "Invalid email address",
14 | "any.required": "Email is required",
15 | }),
16 | age: Joi.number().min(18).messages({
17 | "number.min": "Age must be at least 18",
18 | }),
19 | // tags: Joi.array().items(Joi.string().min(2)).messages({
20 | // "array.includes": "Each tag must be at least 2 characters",
21 | // }),
22 | tags: Joi.array().items(
23 | Joi.string().min(2).messages({
24 | "string.min": "Each tag must be at least 2 characters",
25 | })
26 | ),
27 | });
28 |
29 | it("should return an empty object for valid values", async () => {
30 | const validate = formikJoiValidator(schema);
31 | const values = {
32 | name: "John",
33 | email: "john@example.com",
34 | age: 25,
35 | tags: ["js", "ts"],
36 | };
37 | const errors = await validate(values);
38 | expect(errors).toEqual({});
39 | });
40 |
41 | it("should return errors for invalid values", async () => {
42 | const validate = formikJoiValidator(schema);
43 | const values = { name: "Jo", email: "invalid-email", age: 15, tags: ["a"] };
44 | const errors = await validate(values);
45 |
46 | expect(errors).toEqual({
47 | name: "Name must be at least 3 characters",
48 | email: "Invalid email address",
49 | age: "Age must be at least 18",
50 | "tags.0": "Each tag must be at least 2 characters",
51 | });
52 | });
53 |
54 | it("should handle missing required fields", async () => {
55 | const validate = formikJoiValidator(schema);
56 | const values = {};
57 | const errors = await validate(values);
58 | expect(errors).toEqual({
59 | name: "Name is required",
60 | email: "Email is required",
61 | });
62 | });
63 |
64 | it("should handle additional fields that are not in schema", async () => {
65 | const validate = formikJoiValidator(schema);
66 | const values = {
67 | name: "John",
68 | email: "john@example.com",
69 | extra: "extra field",
70 | };
71 | const errors = await validate(values);
72 | expect(errors).toEqual({});
73 | });
74 |
75 | it("should handle array of valid values", async () => {
76 | const arraySchema = Joi.array().items(schema);
77 | const validate = formikJoiValidator(arraySchema);
78 | const values = [
79 | { name: "Alice", email: "alice@example.com", age: 22, tags: ["dev"] },
80 | {
81 | name: "Bob",
82 | email: "bob@example.com",
83 | age: 30,
84 | tags: ["code", "react"],
85 | },
86 | ];
87 | const errors = await validate(values);
88 | expect(errors).toEqual({});
89 | });
90 |
91 | it("should return errors for array of invalid values", async () => {
92 | const arraySchema = Joi.array().items(schema);
93 | const validate = formikJoiValidator(arraySchema);
94 | const values = [
95 | { name: "Al", email: "invalid", age: 16, tags: ["x"] },
96 | { name: "", email: "bob@invalid", age: 10, tags: ["y"] },
97 | ];
98 | const errors = await validate(values);
99 | expect(errors).toEqual({
100 | "0.name": "Name must be at least 3 characters",
101 | "0.email": "Invalid email address",
102 | "0.age": "Age must be at least 18",
103 | "0.tags.0": "Each tag must be at least 2 characters",
104 | "1.name": "Name is required",
105 | "1.email": "Invalid email address",
106 | "1.age": "Age must be at least 18",
107 | "1.tags.0": "Each tag must be at least 2 characters",
108 | });
109 | });
110 | });
111 |
--------------------------------------------------------------------------------
/test/utils.test.ts:
--------------------------------------------------------------------------------
1 | import { describe, expect, it } from "vitest";
2 | import { formatValidationErrors } from "../lib/utils";
3 |
4 | describe("formatValidationErrors", () => {
5 | it("should correctly format errors", () => {
6 | const errors = [
7 | { path: ["name"], message: "Name is required" },
8 | { path: ["email"], message: "Invalid email format" },
9 | { path: ["address", "city"], message: "City is required" },
10 | ];
11 |
12 | const formatted = formatValidationErrors(errors);
13 |
14 | expect(formatted).toEqual({
15 | name: "Name is required",
16 | email: "Invalid email format",
17 | "address.city": "City is required",
18 | });
19 | });
20 |
21 | it("should return an empty object for empty errors", () => {
22 | expect(formatValidationErrors([])).toEqual({});
23 | });
24 | });
25 |
--------------------------------------------------------------------------------
/test/vestValidator.test.ts:
--------------------------------------------------------------------------------
1 | import { describe, it, expect } from "vitest";
2 | import { create, test } from "vest";
3 | import { formikVestValidator } from "../lib/index";
4 |
5 | // Define a Vest validation suite
6 | const suite = create((data) => {
7 | test("name", "Name is required", () => {
8 | if (!data.name) {
9 | throw new Error("Name is required");
10 | }
11 | });
12 |
13 | test("email", "Invalid email format", () => {
14 | if (!/^[\w-.]+@([\w-]+\.)+[\w-]{2,4}$/.test(data.email)) {
15 | throw new Error("Invalid email format");
16 | }
17 | });
18 |
19 | test("age", "Age must be a number", () => {
20 | if (data.age && isNaN(Number(data.age))) {
21 | throw new Error("Age must be a number");
22 | }
23 | });
24 | });
25 |
26 | describe("formikVestValidator", () => {
27 | it("should return an empty object for valid input", async () => {
28 | const validate = formikVestValidator(suite);
29 | const values = { name: "John", email: "john@example.com", age: "25" };
30 |
31 | const errors = await validate(values);
32 | expect(errors).toEqual({});
33 | });
34 |
35 | it("should return an error for missing required fields", async () => {
36 | const validate = formikVestValidator(suite);
37 | const values = { name: "", email: "" };
38 |
39 | const errors = await validate(values);
40 | expect(errors).toEqual({
41 | name: "Name is required",
42 | email: "Invalid email format",
43 | });
44 | });
45 |
46 | it("should return an error for invalid email format", async () => {
47 | const validate = formikVestValidator(suite);
48 | const values = { name: "Alice", email: "invalid-email" };
49 |
50 | const errors = await validate(values);
51 | expect(errors).toEqual({
52 | email: "Invalid email format",
53 | });
54 | });
55 |
56 | it("should return errors for multiple invalid fields", async () => {
57 | const validate = formikVestValidator(suite);
58 | const values = { name: "", email: "invalid-email", age: "abc" };
59 |
60 | const errors = await validate(values);
61 | expect(errors).toEqual({
62 | name: "Name is required",
63 | email: "Invalid email format",
64 | age: "Age must be a number",
65 | });
66 | });
67 |
68 | it("should ignore unknown fields and return no errors", async () => {
69 | const validate = formikVestValidator(suite);
70 | const values = { name: "John", email: "john@example.com", age: "30", extraField: "SomeValue" };
71 |
72 | const errors = await validate(values);
73 | expect(errors).toEqual({});
74 | });
75 | });
76 |
--------------------------------------------------------------------------------
/test/zodValidator.test.ts:
--------------------------------------------------------------------------------
1 | import { formikZodValidator } from "../lib/index";
2 | import { describe, it, expect } from "vitest";
3 | import { z } from "zod";
4 |
5 | // Sample schemas
6 | const schema = z.object({
7 | name: z.string().min(3, "Name must be at least 3 characters"),
8 | email: z.string().email("Invalid email address"),
9 | });
10 |
11 | describe("formikZodValidator", () => {
12 | it("should return an empty object for valid values", async () => {
13 | const validate = formikZodValidator(schema);
14 | const values = { name: "John", email: "john@example.com" };
15 |
16 | const errors = await validate(values);
17 | expect(errors).toEqual({});
18 | });
19 |
20 | it("should return errors for invalid values", async () => {
21 | const validate = formikZodValidator(schema);
22 | const values = { name: "Jo", email: "invalid-email" };
23 |
24 | const errors = await validate(values);
25 | expect(errors).toEqual({
26 | name: "Name must be at least 3 characters",
27 | email: "Invalid email address",
28 | });
29 | });
30 |
31 | it("should return an empty object if schema passes validation", async () => {
32 | const validate = formikZodValidator(schema);
33 | const values = { name: "Alice", email: "alice@example.com" };
34 |
35 | const errors = await validate(values);
36 | expect(errors).toEqual({});
37 | });
38 |
39 | it("should return multiple errors if multiple fields are invalid", async () => {
40 | const validate = formikZodValidator(schema);
41 | const values = { name: "", email: "" };
42 |
43 | const errors = await validate(values);
44 | expect(errors).toEqual({
45 | name: "Name must be at least 3 characters",
46 | email: "Invalid email address",
47 | });
48 | });
49 |
50 | it("should handle additional fields that are not in schema", async () => {
51 | const validate = formikZodValidator(schema);
52 | const values = { name: "John", email: "john@example.com", age: 30 };
53 |
54 | const errors = await validate(values);
55 | expect(errors).toEqual({});
56 | });
57 |
58 | it("should return an empty object if values are empty but schema has no required fields", async () => {
59 | const optionalSchema = z.object({
60 | name: z.string().optional(),
61 | email: z.string().optional(),
62 | });
63 |
64 | const validate = formikZodValidator(optionalSchema);
65 | const values = {};
66 |
67 | const errors = await validate(values);
68 | expect(errors).toEqual({});
69 | });
70 |
71 | it("should return an empty object if no errors occur", async () => {
72 | const validate = formikZodValidator(schema);
73 | const values = { name: "Valid Name", email: "valid@example.com" };
74 |
75 | const errors = await validate(values);
76 | expect(errors).toEqual({});
77 | });
78 |
79 | it("should handle nested objects properly", async () => {
80 | const nestedSchema = z.object({
81 | user: z.object({
82 | name: z.string().min(3, "Name must be at least 3 characters"),
83 | email: z.string().email("Invalid email address"),
84 | }),
85 | });
86 |
87 | const validate = formikZodValidator(nestedSchema);
88 | const values = { user: { name: "Jo", email: "invalid-email" } };
89 |
90 | const errors = await validate(values);
91 | expect(errors).toEqual({
92 | "user.name": "Name must be at least 3 characters",
93 | "user.email": "Invalid email address",
94 | });
95 | });
96 | });
97 |
98 | // Define schema for an array of objects
99 | const arraySchema = z.array(
100 | z.object({
101 | name: z.string().min(3, "Name must be at least 3 characters"),
102 | email: z.string().email("Invalid email address"),
103 | })
104 | );
105 |
106 | describe("formikZodValidator - Array of Objects", () => {
107 | it("should return an empty object for an array of valid objects", async () => {
108 | const validate = formikZodValidator(arraySchema);
109 | const values = [
110 | { name: "Alice", email: "alice@example.com" },
111 | { name: "Bob", email: "bob@example.com" },
112 | ];
113 |
114 | const errors = await validate(values);
115 | expect(errors).toEqual({});
116 | });
117 |
118 | it("should return errors for an array with invalid objects", async () => {
119 | const validate = formikZodValidator(arraySchema);
120 | const values = [
121 | { name: "Al", email: "invalid-email" }, // Invalid entry
122 | { name: "", email: "bob@invalid" }, // Invalid entry
123 | ];
124 |
125 | const errors = await validate(values);
126 | expect(errors).toEqual({
127 | "0.name": "Name must be at least 3 characters",
128 | "0.email": "Invalid email address",
129 | "1.name": "Name must be at least 3 characters",
130 | "1.email": "Invalid email address",
131 | });
132 | });
133 |
134 | it("should return errors for an array with mixed valid and invalid objects", async () => {
135 | const validate = formikZodValidator(arraySchema);
136 | const values = [
137 | { name: "Valid Name", email: "valid@example.com" }, // Valid
138 | { name: "Jo", email: "invalid-email" }, // Invalid
139 | ];
140 |
141 | const errors = await validate(values);
142 | expect(errors).toEqual({
143 | "1.name": "Name must be at least 3 characters",
144 | "1.email": "Invalid email address",
145 | });
146 | });
147 |
148 | it("should return errors when required fields are missing", async () => {
149 | const validate = formikZodValidator(arraySchema);
150 | const values = [
151 | { name: "", email: "" }, // Missing both fields
152 | { name: "Valid Name", email: "valid@example.com" }, // Valid
153 | ];
154 |
155 | const errors = await validate(values);
156 | expect(errors).toEqual({
157 | "0.name": "Name must be at least 3 characters",
158 | "0.email": "Invalid email address",
159 | });
160 | });
161 |
162 | it("should handle empty array input", async () => {
163 | const validate = formikZodValidator(arraySchema);
164 | const values = [];
165 |
166 | const errors = await validate(values);
167 | expect(errors).toEqual({});
168 | });
169 | });
170 |
--------------------------------------------------------------------------------
/tsconfig.json:
--------------------------------------------------------------------------------
1 | {
2 | "compilerOptions": {
3 | "target": "ES6",
4 | "module": "NodeNext", // Set to NodeNext
5 | "moduleResolution": "NodeNext", // Set to NodeNext
6 | "declaration": true,
7 | "outDir": "./dist",
8 | "strict": true,
9 | "esModuleInterop": true,
10 | "skipLibCheck": true
11 | },
12 | "include": ["lib/index.ts"]
13 | }
--------------------------------------------------------------------------------
/vitest.config.ts:
--------------------------------------------------------------------------------
1 | import { defineConfig } from "vitest/config";
2 |
3 | export default defineConfig({
4 | test: {
5 | coverage: {
6 | provider: "istanbul", // or 'v8'
7 | reporter: ["text"], // Generates coverage report in terminal and as an HTML file
8 | all: true,
9 | exclude: [
10 | "node_modules",
11 | "dist",
12 | "coverage",
13 | ".github",
14 | "examples",
15 | "vitest.config.ts",
16 | ],
17 | },
18 | reporters: ["default", "verbose"], // Show detailed test cases
19 | },
20 | });
21 |
--------------------------------------------------------------------------------