├── .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 | [![Live Demo](https://img.shields.io/badge/demo-live-green)](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 |
51 | 52 | {errors.name &&
{errors.name}
} 53 | 54 | {errors.email &&
{errors.email}
} 55 |
56 | 57 | 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 |
100 | 101 | {errors.name &&
{errors.name}
} 102 | 103 | {errors.email &&
{errors.email}
} 104 | 105 | 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 |
151 | 152 | {errors.name &&
{errors.name}
} 153 | 154 | 155 | {errors.email &&
{errors.email}
} 156 | 157 | 158 | {errors.password &&
{errors.password}
} 159 | 160 | 161 | 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 | --------------------------------------------------------------------------------