├── .editorconfig ├── .github ├── dependabot.yml └── workflows │ ├── build.yml │ ├── publish.yml │ ├── release.yml │ └── test.yml ├── .gitignore ├── .npmignore ├── CHANGELOG.md ├── LICENSE ├── README.md ├── biome.json ├── example ├── index.html └── index.js ├── package-lock.json ├── package.json ├── src ├── index.test.ts └── index.ts ├── tsconfig.json ├── vite.config.ts └── vitest.config.ts /.editorconfig: -------------------------------------------------------------------------------- 1 | # EditorConfig helps developers define and maintain consistent 2 | # coding styles between different editors and IDEs 3 | # editorconfig.org 4 | 5 | root = true 6 | 7 | [*] 8 | 9 | # Change these settings to your own preference 10 | indent_style = space 11 | indent_size = 2 12 | 13 | # We recommend you to keep these unchanged 14 | end_of_line = lf 15 | charset = utf-8 16 | trim_trailing_whitespace = true 17 | insert_final_newline = true 18 | 19 | [*.md] 20 | trim_trailing_whitespace = false 21 | -------------------------------------------------------------------------------- /.github/dependabot.yml: -------------------------------------------------------------------------------- 1 | version: 2 2 | updates: 3 | - package-ecosystem: "github-actions" 4 | directory: "/" 5 | schedule: 6 | interval: "monthly" 7 | -------------------------------------------------------------------------------- /.github/workflows/build.yml: -------------------------------------------------------------------------------- 1 | name: build 2 | 3 | on: 4 | push: 5 | branches: [master] 6 | pull_request: 7 | branches: [master] 8 | 9 | jobs: 10 | build: 11 | runs-on: macos-latest 12 | 13 | strategy: 14 | matrix: 15 | node-version: [20.x] 16 | 17 | steps: 18 | - name: Checkout 19 | uses: actions/checkout@v4 20 | - name: Use Node.js ${{ matrix.node-version }} 21 | uses: actions/setup-node@v4 22 | with: 23 | node-version: ${{ matrix.node-version }} 24 | - name: Install pub-sub-es 25 | run: npm ci 26 | - name: Build pub-sub-es 27 | run: npm run build --if-present 28 | - name: Test pub-sub-es 29 | run: npm test 30 | -------------------------------------------------------------------------------- /.github/workflows/publish.yml: -------------------------------------------------------------------------------- 1 | name: publish 2 | 3 | on: 4 | push: 5 | tags: 6 | - 'v*' 7 | 8 | jobs: 9 | build: 10 | runs-on: macos-latest 11 | steps: 12 | - uses: actions/checkout@v4 13 | - uses: actions/setup-node@v4 14 | with: 15 | node-version: 20 16 | - run: npm ci 17 | - run: npm run build --if-present 18 | env: 19 | CI: true 20 | 21 | publish-npm: 22 | needs: build 23 | runs-on: macos-latest 24 | steps: 25 | - uses: actions/checkout@v4 26 | - uses: actions/setup-node@v4 27 | with: 28 | node-version: 20 29 | registry-url: https://registry.npmjs.org/ 30 | - run: npm ci 31 | - run: npm run prerelease 32 | - run: npm publish --ignore-scripts 33 | env: 34 | NODE_AUTH_TOKEN: ${{secrets.NPM_TOKEN}} 35 | -------------------------------------------------------------------------------- /.github/workflows/release.yml: -------------------------------------------------------------------------------- 1 | name: release 2 | 3 | on: 4 | push: 5 | tags: 6 | - 'v*' 7 | 8 | jobs: 9 | build: 10 | name: Create Release 11 | runs-on: macos-latest 12 | steps: 13 | - name: Checkout code 14 | uses: actions/checkout@v4 15 | - name: Create Release 16 | id: create_release 17 | uses: actions/create-release@v1 18 | env: 19 | GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} # This token is provided by Actions, you do not need to create your own token 20 | with: 21 | tag_name: ${{ github.ref }} 22 | release_name: ${{ github.ref }} 23 | draft: false 24 | prerelease: false 25 | -------------------------------------------------------------------------------- /.github/workflows/test.yml: -------------------------------------------------------------------------------- 1 | name: 'Test' 2 | on: 3 | pull_request: 4 | 5 | jobs: 6 | test: 7 | runs-on: ubuntu-latest 8 | 9 | permissions: 10 | contents: read 11 | pull-requests: write 12 | 13 | steps: 14 | - uses: actions/checkout@v4 15 | - name: 'Install Node' 16 | uses: actions/setup-node@v4 17 | with: 18 | node-version: '20.x' 19 | - name: 'Install Deps' 20 | run: npm ci 21 | - name: 'Test' 22 | run: npx vitest --environment=happy-dom --coverage.enabled true 23 | - name: 'Report Coverage' 24 | uses: davelosert/vitest-coverage-report-action@v2 25 | -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | coverage/* 2 | docs/* 3 | dist/* 4 | dist.zip 5 | npm-debug.log 6 | node_modules/* 7 | *.DS_cache 8 | -------------------------------------------------------------------------------- /.npmignore: -------------------------------------------------------------------------------- 1 | coverage 2 | node_modules 3 | *.zip 4 | *.log 5 | *.DS_cache 6 | -------------------------------------------------------------------------------- /CHANGELOG.md: -------------------------------------------------------------------------------- 1 | ### v3.0.0 2 | 3 | - Rewrote the whole library in TypeScript to finally fix all the type issues. 4 | 5 | **Breaking Changes** 6 | 7 | - Stop publishing UMD modules 8 | 9 | ### v2.1.2 10 | 11 | - Fix behavior of `publish`'s `async` option. The option will now override the globally specified behavior. 12 | - Fix a typo in `types` of `package.json` to point to the correct type definitions 13 | - Further improve some type descriptions 14 | 15 | ### v2.1.1 16 | 17 | - Fix several type definitions 18 | 19 | ### v2.1.0 20 | 21 | - Add and publish types 22 | - Add missing `clear()` function to the global pub sub instance 23 | 24 | ### v2.0.2 25 | 26 | - Fix an issue with the Broadcast Channel's `publish` call 27 | 28 | ### v2.0.1 29 | 30 | - Fix an edge case in async `publish` 31 | 32 | ### v2.0.0 33 | 34 | - Add option to make the event stack case-insensitive via `createPubSub({ caseInsensitive: true })` 35 | - Add option to make `publish` asynchronous via `createPubSub({ async: true })` (or `pubSub.publish(event, news, { async: true })`) 36 | 37 | **Breaking Changes** 38 | 39 | - The API of `createPubSub` changed from `createPubSub(customStackObject = {})` to `createPubSub({ async = false, caseInsensitive = false, stack = {} } = {})` 40 | 41 | ### v1.2.2 42 | 43 | - Fix a bug when using pub-sub-es in an iframe. 44 | - Updated third-party packages 45 | 46 | ### v1.2.1 47 | 48 | - Fixed a bad bug when subscribing with the shorthand. Expanded the tests to cover the shorthand unsubscription. 49 | 50 | ### v1.2.0 51 | 52 | - Add `clear()` for removing all currently active event listeners and unsetting all event times 53 | 54 | ### v1.1.2 55 | 56 | - Check if `BroadcastChannel` is available and log a warning otherwise 57 | 58 | ### v1.1.1 59 | 60 | - Catch exceptions on broadcasting with `BroadcastChannel` 61 | 62 | ### v1.1.0 63 | 64 | - Expand global communication across windows 65 | - Add a demo page 66 | 67 | ### v1.0.2 68 | 69 | - Prettify code and fix doc typos 70 | 71 | ### v1.0.1 72 | 73 | - Make sure that custom stacks have the `__times__` property 74 | 75 | ### v1.0.0 76 | 77 | - Fully tested working version 78 | -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | MIT License 2 | 3 | Copyright (c) 2018 Fritz Lekschas 4 | 5 | Permission is hereby granted, free of charge, to any person obtaining a copy 6 | of this software and associated documentation files (the "Software"), to deal 7 | in the Software without restriction, including without limitation the rights 8 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 9 | copies of the Software, and to permit persons to whom the Software is 10 | furnished to do so, subject to the following conditions: 11 | 12 | The above copyright notice and this permission notice shall be included in all 13 | copies or substantial portions of the Software. 14 | 15 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 16 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 17 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 18 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 19 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 20 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE 21 | SOFTWARE. 22 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # PubSubES: A tiny ES6-based pub-sub library 2 | 3 | [![npm version](https://img.shields.io/npm/v/pub-sub-es.svg)](https://www.npmjs.com/package/pub-sub-es) 4 | [![stability experimental](https://img.shields.io/badge/stability-stable-green.svg)](https://nodejs.org/api/documentation.html#documentation_stability_index) 5 | [![build status](https://img.shields.io/github/actions/workflow/status/flekschas/pub-sub/build.yml?branch=master&color=a17fff)](https://github.com/flekschas/pub-sub/actions?query=workflow%3Abuild) 6 | [![gzipped size](https://img.shields.io/bundlephobia/minzip/pub-sub-es?color=6ae3c7&label=gzipped%20size)](https://unpkg.com/pub-sub-es) 7 | [![code style prettier](https://img.shields.io/badge/code_style-prettier-ff69b4.svg)](https://github.com/prettier/prettier) 8 | [![demo](https://img.shields.io/badge/demo-online-c15de2.svg)](http://pub-sub.lekschas.de) 9 | 10 | > A [tiny <1KB](https://bundlephobia.com/result?p=pub-sub-es) [pub-sub](https://en.wikipedia.org/wiki/Publish%E2%80%93subscribe_pattern)-based event library that lets you send custom message within and cross the window! It's written in ES6 and makes use of the awesome [Broadcast Channel API](https://developer.mozilla.org/en-US/docs/Web/API/Broadcast_Channel_API). 11 | 12 | **Demo:** [pub-sub.lekschas.de](http://pub-sub.lekschas.de) 13 | 14 | ## Install 15 | 16 | ``` 17 | npm -i -D pub-sub-es 18 | ``` 19 | 20 | ## Get Started 21 | 22 | ```javascript 23 | import createPubSub from 'pub-sub-es'; 24 | 25 | // Creates a new pub-sub event listener stack. 26 | const pubSub = createPubSub(); 27 | 28 | // Subscribe to an event 29 | const myEmojiEventHandler = (msg) => console.log(`🎉 ${msg} 😍`); 30 | pubSub.subscribe('my-emoji-event', myEmojiEventHandler); 31 | 32 | // Publish an event 33 | pubSub.publish('my-emoji-event', 'Yuuhuu'); // >> 🎉 Yuuhuu 😍 34 | 35 | // Unsubscribe 36 | pubSub.unsubscribe('my-emoji-event', myEmojiEventHandler); 37 | ``` 38 | 39 | ### Type Events 40 | 41 | By default, `pub-sub` assumes you are publishing any kind of events with an 42 | unknown payload. With TypeScript you can specify which events (name and payload) 43 | you are publishing as follows. 44 | 45 | ```typescript 46 | import createPubSub, { Event } from 'pub-sub-es'; 47 | 48 | type Events = Event<'init' | 'destroy', undefined> & 49 | Event<'solution', number> & 50 | Event<'selection', number[]>; 51 | 52 | const pubSub = createPubSub(); 53 | ``` 54 | 55 | With this, we established that `pubSub` will handle four events: 56 | 57 | - `init` and `destroy` feature no payload (i.e., the payload is `undefined`) 58 | - `solution` features a single `number` as payload 59 | - `selection` features an array of numbers as payload 60 | 61 | When you listen to or publish an event, the payload will now be typed based of the event. I.e.: 62 | 63 | ```typescript 64 | pubSub.subscribe('destroy', (payload) => payload === undefined); // => ✅ 65 | pubSub.subscribe('destroy', (payload) => payload * 2); // => ❌ 66 | pubSub.subscribe('solution', (payload) => console.log(payload + 2)); // => ✅ 67 | pubSub.subscribe('solution', (payload) => console.log(payload.length)); // => ❌ 68 | pubSub.subscribe('selection', (payload) => console.log(payload.length)); // => ✅ 69 | pubSub.subscribe('selection', (payload) => console.log(payload * 2)); // => ❌ 70 | 71 | pubSub.publish('init'); // => ✅ 72 | pubSub.publish('init', 'w00t'); // => ❌ 73 | pubSub.publish('solution', 42); // => ✅ 74 | pubSub.publish('solution', '42'); // => ❌ 75 | pubSub.publish('selection', [1,3,3,7]); // => ✅ 76 | pubSub.publish('selection', 1337); // => ❌ 77 | ``` 78 | 79 | ## API 80 | 81 | `pub-sub-es` exports the factory function (`createPubSub`) for creating a new pub-sub service by default and a global pub-sub service (`globalPubSub`). The API is the same for both. 82 | 83 | #### `createPubSub(options = { async: false, caseInsensitive: false, stack: {})` 84 | 85 | > Creates a new pub-sub instances 86 | 87 | **Arguments:** 88 | 89 | - `options` is an object for customizing pubSub. The following properties are understood: 90 | - `async`: when `true`, events are published asynchronously to decouple the process of the originator and consumer. 91 | - `caseInsensitive`: when `true`, event names are case insensitive 92 | - `stack`: is an object holding the event listeners and defaults to a new stack when being omitted. 93 | 94 | **Returns:** a new pub-sub service 95 | 96 | #### `pubSub.publish(event, news, options = { async: false, isNoGlobalBroadcast: false})` 97 | 98 | > Publishes or broadcasts an event with some news or payload 99 | 100 | **Arguments:** 101 | 102 | - `event` is the name of the event to be published. 103 | - `news` is an arbitrary value that is being broadcasted. 104 | - `options` is an object for customizing the behavior. The following properties are understood: 105 | - `async`: overrides the global `async` flag for a single call. 106 | - `isNoGlobalBroadcast`: overrides the global `isGlobal` flag for a single call. 107 | 108 | #### `pubSub.subscribe(event, handler, times)` 109 | 110 | > Subscribes a handler to a specific event 111 | 112 | - `event` is the name of the event to be published. 113 | - `handler` is the handler function that is being called together with the broadcasted value. 114 | - `times` is the number of times the handler is invoked before it's automatically unsubscribed. 115 | 116 | **Returns:** an object of form `{ event, handler }`. This object can be used to automatically unsubscribe, e.g., `pubSub.unsubscribe(pubSub.subscribe('my-event', myHandler))`. 117 | 118 | #### `pubSub.unsubscribe(eventOrSubscription, handler?)` 119 | 120 | > Unsubscribes a handler from listening to an event 121 | 122 | - `eventOrSubscription` is the name of the event to be published. Optionally, `unsubscribe` accepts an object of form `{ event, handler}` coming from `subscribe`. 123 | - `handler` is the event handler function to be unsubscribed from the event 124 | 125 | #### `pubSub.clear()` 126 | 127 | > Removes all currently active event listeners and unsets the event times. 128 | 129 | _Note: this endpoint is not available on the global pub-sub because it could have undesired side effects. You need to unsubscribe global event listeners manually instead._ 130 | 131 | ### Between-context messaging 132 | 133 | The global pub-sub instance is created when `pub-sub-es.js` is loaded and provides a way for 134 | global messaging within and between contexts. It utilizes the [Broadcast Channel API](https://developer.mozilla.org/en-US/docs/Web/API/BroadcastChannel). Note, when sending sending objects from one context to another you have to make sure that they are cloneable. For example, trying to broadcast a reference to a DOM element will fail. 135 | 136 | ## Difference to other pub-sub libraries 137 | 138 | You might have come across the awesome [PubSubJS](https://github.com/mroderick/PubSubJS) library and wonder which one to choose. First of all, both are tiny, have no dependencies, and offer async event broadcasting. The two main features that PubSubES offers are: 139 | 140 | 1. Auto-unsubscribable event listening: via `pubSub.subscribe(eventName, eventHandler, times)` you can make the `eventHandler` unsubscribed from `eventName` automatically after `eventName` was broadcasted `times` times. 141 | 142 | 2. Between-context messaging: PubSubES supports the new Broadcast Channel API so you can send events between different browser contexts, e.g., tabs. 143 | -------------------------------------------------------------------------------- /biome.json: -------------------------------------------------------------------------------- 1 | { 2 | "$schema": "https://biomejs.dev/schemas/1.7.3/schema.json", 3 | "organizeImports": { 4 | "enabled": true 5 | }, 6 | "linter": { 7 | "enabled": true, 8 | "rules": { 9 | "all": true, 10 | "complexity": { 11 | "noExcessiveCognitiveComplexity": "off" 12 | }, 13 | "style": { 14 | "noDefaultExport": "off" 15 | } 16 | } 17 | }, 18 | "files": { 19 | "include": ["src"] 20 | } 21 | } 22 | -------------------------------------------------------------------------------- /example/index.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 7 | PubSubES 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 | 32 | 33 | 34 | 35 | 36 | 37 | 209 | 210 | 211 | 212 |

PubSubES – a tiny JavaScript library for broadcasting events within and cross windows.

213 | 214 |

PubSubES is a 0.6KB heavy library for managing custom events within and cross windows. It is written in ES6 and makes use of the new awesome Broadcast Channel API. Test it below by either sending out a message. To see the effect of global events open this page in a new window. Your browser doesn't support the Broadcast Channel API: use Firefox or Chrome to play with this demo! Check out the getting started guide and the API docs for details on how to use PubSubES.

215 | 216 |

Send an event

217 |
218 | 219 | 220 | 221 |
222 | 223 |

Messages

224 |
    225 |
226 | 227 | 228 | -------------------------------------------------------------------------------- /example/index.js: -------------------------------------------------------------------------------- 1 | import { createPubSub, globalPubSub } from "../src"; 2 | 3 | if (!window.BroadcastChannel) { 4 | document.querySelector(".between-contexts").className = 5 | "between-contexts active"; 6 | document.querySelector(".between-contexts-warning").style.display = "inline"; 7 | } 8 | 9 | const pubSub = createPubSub(); 10 | const messages = document.querySelector("#messages"); 11 | 12 | const eventHandler = (isGlobal) => (event) => { 13 | const newElement = document.createElement("li"); 14 | newElement.innerText = event; 15 | newElement.className = isGlobal ? "is-global" : "is-local"; 16 | 17 | messages.appendChild(newElement); 18 | }; 19 | 20 | const localEventHandler = eventHandler(); 21 | const globalEventHandler = eventHandler(true); 22 | 23 | pubSub.subscribe("event", localEventHandler); 24 | 25 | globalPubSub.subscribe("event", globalEventHandler); 26 | 27 | const message = document.querySelector("#message"); 28 | 29 | const buttonSendLocally = document.querySelector("#send-locally"); 30 | const buttonSendGlobally = document.querySelector("#send-globally"); 31 | 32 | const clickHandler = (isGlobal) => (event) => { 33 | event.preventDefault(); 34 | if (isGlobal) globalPubSub.publish("event", message.value); 35 | else pubSub.publish("event", message.value); 36 | }; 37 | 38 | const localClickHandler = clickHandler(); 39 | const globalClickHandler = clickHandler(true); 40 | 41 | buttonSendLocally.addEventListener("click", localClickHandler); 42 | buttonSendGlobally.addEventListener("click", globalClickHandler); 43 | -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "pub-sub-es", 3 | "version": "3.0.0", 4 | "lockfileVersion": 3, 5 | "requires": true, 6 | "packages": { 7 | "": { 8 | "name": "pub-sub-es", 9 | "version": "3.0.0", 10 | "license": "MIT", 11 | "devDependencies": { 12 | "@biomejs/biome": "1.7.3", 13 | "@vitest/coverage-v8": "^1.6.0", 14 | "happy-dom": "^15.10.2", 15 | "typescript": "^5.4.5", 16 | "vite": "^5.2.12", 17 | "vite-plugin-html": "^3.2.2", 18 | "vitest": "^1.6.0" 19 | } 20 | }, 21 | "node_modules/@ampproject/remapping": { 22 | "version": "2.3.0", 23 | "resolved": "https://registry.npmjs.org/@ampproject/remapping/-/remapping-2.3.0.tgz", 24 | "integrity": "sha512-30iZtAPgz+LTIYoeivqYo853f02jBYSd5uGnGpkFV0M3xOt9aN73erkgYAmZU43x4VfqcnLxW9Kpg3R5LC4YYw==", 25 | "dev": true, 26 | "dependencies": { 27 | "@jridgewell/gen-mapping": "^0.3.5", 28 | "@jridgewell/trace-mapping": "^0.3.24" 29 | }, 30 | "engines": { 31 | "node": ">=6.0.0" 32 | } 33 | }, 34 | "node_modules/@babel/helper-string-parser": { 35 | "version": "7.24.6", 36 | "resolved": "https://registry.npmjs.org/@babel/helper-string-parser/-/helper-string-parser-7.24.6.tgz", 37 | "integrity": "sha512-WdJjwMEkmBicq5T9fm/cHND3+UlFa2Yj8ALLgmoSQAJZysYbBjw+azChSGPN4DSPLXOcooGRvDwZWMcF/mLO2Q==", 38 | "dev": true, 39 | "engines": { 40 | "node": ">=6.9.0" 41 | } 42 | }, 43 | "node_modules/@babel/helper-validator-identifier": { 44 | "version": "7.24.6", 45 | "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.24.6.tgz", 46 | "integrity": "sha512-4yA7s865JHaqUdRbnaxarZREuPTHrjpDT+pXoAZ1yhyo6uFnIEpS8VMu16siFOHDpZNKYv5BObhsB//ycbICyw==", 47 | "dev": true, 48 | "engines": { 49 | "node": ">=6.9.0" 50 | } 51 | }, 52 | "node_modules/@babel/parser": { 53 | "version": "7.24.6", 54 | "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.24.6.tgz", 55 | "integrity": "sha512-eNZXdfU35nJC2h24RznROuOpO94h6x8sg9ju0tT9biNtLZ2vuP8SduLqqV+/8+cebSLV9SJEAN5Z3zQbJG/M+Q==", 56 | "dev": true, 57 | "bin": { 58 | "parser": "bin/babel-parser.js" 59 | }, 60 | "engines": { 61 | "node": ">=6.0.0" 62 | } 63 | }, 64 | "node_modules/@babel/types": { 65 | "version": "7.24.6", 66 | "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.24.6.tgz", 67 | "integrity": "sha512-WaMsgi6Q8zMgMth93GvWPXkhAIEobfsIkLTacoVZoK1J0CevIPGYY2Vo5YvJGqyHqXM6P4ppOYGsIRU8MM9pFQ==", 68 | "dev": true, 69 | "dependencies": { 70 | "@babel/helper-string-parser": "^7.24.6", 71 | "@babel/helper-validator-identifier": "^7.24.6", 72 | "to-fast-properties": "^2.0.0" 73 | }, 74 | "engines": { 75 | "node": ">=6.9.0" 76 | } 77 | }, 78 | "node_modules/@bcoe/v8-coverage": { 79 | "version": "0.2.3", 80 | "resolved": "https://registry.npmjs.org/@bcoe/v8-coverage/-/v8-coverage-0.2.3.tgz", 81 | "integrity": "sha512-0hYQ8SB4Db5zvZB4axdMHGwEaQjkZzFjQiN9LVYvIFB2nSUHW9tYpxWriPrWDASIxiaXax83REcLxuSdnGPZtw==", 82 | "dev": true 83 | }, 84 | "node_modules/@biomejs/biome": { 85 | "version": "1.7.3", 86 | "resolved": "https://registry.npmjs.org/@biomejs/biome/-/biome-1.7.3.tgz", 87 | "integrity": "sha512-ogFQI+fpXftr+tiahA6bIXwZ7CSikygASdqMtH07J2cUzrpjyTMVc9Y97v23c7/tL1xCZhM+W9k4hYIBm7Q6cQ==", 88 | "dev": true, 89 | "hasInstallScript": true, 90 | "bin": { 91 | "biome": "bin/biome" 92 | }, 93 | "engines": { 94 | "node": ">=14.21.3" 95 | }, 96 | "funding": { 97 | "type": "opencollective", 98 | "url": "https://opencollective.com/biome" 99 | }, 100 | "optionalDependencies": { 101 | "@biomejs/cli-darwin-arm64": "1.7.3", 102 | "@biomejs/cli-darwin-x64": "1.7.3", 103 | "@biomejs/cli-linux-arm64": "1.7.3", 104 | "@biomejs/cli-linux-arm64-musl": "1.7.3", 105 | "@biomejs/cli-linux-x64": "1.7.3", 106 | "@biomejs/cli-linux-x64-musl": "1.7.3", 107 | "@biomejs/cli-win32-arm64": "1.7.3", 108 | "@biomejs/cli-win32-x64": "1.7.3" 109 | } 110 | }, 111 | "node_modules/@biomejs/cli-darwin-arm64": { 112 | "version": "1.7.3", 113 | "resolved": "https://registry.npmjs.org/@biomejs/cli-darwin-arm64/-/cli-darwin-arm64-1.7.3.tgz", 114 | "integrity": "sha512-eDvLQWmGRqrPIRY7AIrkPHkQ3visEItJKkPYSHCscSDdGvKzYjmBJwG1Gu8+QC5ed6R7eiU63LEC0APFBobmfQ==", 115 | "cpu": [ 116 | "arm64" 117 | ], 118 | "dev": true, 119 | "optional": true, 120 | "os": [ 121 | "darwin" 122 | ], 123 | "engines": { 124 | "node": ">=14.21.3" 125 | } 126 | }, 127 | "node_modules/@biomejs/cli-darwin-x64": { 128 | "version": "1.7.3", 129 | "resolved": "https://registry.npmjs.org/@biomejs/cli-darwin-x64/-/cli-darwin-x64-1.7.3.tgz", 130 | "integrity": "sha512-JXCaIseKRER7dIURsVlAJacnm8SG5I0RpxZ4ya3dudASYUc68WGl4+FEN03ABY3KMIq7hcK1tzsJiWlmXyosZg==", 131 | "cpu": [ 132 | "x64" 133 | ], 134 | "dev": true, 135 | "optional": true, 136 | "os": [ 137 | "darwin" 138 | ], 139 | "engines": { 140 | "node": ">=14.21.3" 141 | } 142 | }, 143 | "node_modules/@biomejs/cli-linux-arm64": { 144 | "version": "1.7.3", 145 | "resolved": "https://registry.npmjs.org/@biomejs/cli-linux-arm64/-/cli-linux-arm64-1.7.3.tgz", 146 | "integrity": "sha512-phNTBpo7joDFastnmZsFjYcDYobLTx4qR4oPvc9tJ486Bd1SfEVPHEvJdNJrMwUQK56T+TRClOQd/8X1nnjA9w==", 147 | "cpu": [ 148 | "arm64" 149 | ], 150 | "dev": true, 151 | "optional": true, 152 | "os": [ 153 | "linux" 154 | ], 155 | "engines": { 156 | "node": ">=14.21.3" 157 | } 158 | }, 159 | "node_modules/@biomejs/cli-linux-arm64-musl": { 160 | "version": "1.7.3", 161 | "resolved": "https://registry.npmjs.org/@biomejs/cli-linux-arm64-musl/-/cli-linux-arm64-musl-1.7.3.tgz", 162 | "integrity": "sha512-c8AlO45PNFZ1BYcwaKzdt46kYbuP6xPGuGQ6h4j3XiEDpyseRRUy/h+6gxj07XovmyxKnSX9GSZ6nVbZvcVUAw==", 163 | "cpu": [ 164 | "arm64" 165 | ], 166 | "dev": true, 167 | "optional": true, 168 | "os": [ 169 | "linux" 170 | ], 171 | "engines": { 172 | "node": ">=14.21.3" 173 | } 174 | }, 175 | "node_modules/@biomejs/cli-linux-x64": { 176 | "version": "1.7.3", 177 | "resolved": "https://registry.npmjs.org/@biomejs/cli-linux-x64/-/cli-linux-x64-1.7.3.tgz", 178 | "integrity": "sha512-vnedYcd5p4keT3iD48oSKjOIRPYcjSNNbd8MO1bKo9ajg3GwQXZLAH+0Cvlr+eMsO67/HddWmscSQwTFrC/uPA==", 179 | "cpu": [ 180 | "x64" 181 | ], 182 | "dev": true, 183 | "optional": true, 184 | "os": [ 185 | "linux" 186 | ], 187 | "engines": { 188 | "node": ">=14.21.3" 189 | } 190 | }, 191 | "node_modules/@biomejs/cli-linux-x64-musl": { 192 | "version": "1.7.3", 193 | "resolved": "https://registry.npmjs.org/@biomejs/cli-linux-x64-musl/-/cli-linux-x64-musl-1.7.3.tgz", 194 | "integrity": "sha512-UdEHKtYGWEX3eDmVWvQeT+z05T9/Sdt2+F/7zmMOFQ7boANeX8pcO6EkJPK3wxMudrApsNEKT26rzqK6sZRTRA==", 195 | "cpu": [ 196 | "x64" 197 | ], 198 | "dev": true, 199 | "optional": true, 200 | "os": [ 201 | "linux" 202 | ], 203 | "engines": { 204 | "node": ">=14.21.3" 205 | } 206 | }, 207 | "node_modules/@biomejs/cli-win32-arm64": { 208 | "version": "1.7.3", 209 | "resolved": "https://registry.npmjs.org/@biomejs/cli-win32-arm64/-/cli-win32-arm64-1.7.3.tgz", 210 | "integrity": "sha512-unNCDqUKjujYkkSxs7gFIfdasttbDC4+z0kYmcqzRk6yWVoQBL4dNLcCbdnJS+qvVDNdI9rHp2NwpQ0WAdla4Q==", 211 | "cpu": [ 212 | "arm64" 213 | ], 214 | "dev": true, 215 | "optional": true, 216 | "os": [ 217 | "win32" 218 | ], 219 | "engines": { 220 | "node": ">=14.21.3" 221 | } 222 | }, 223 | "node_modules/@biomejs/cli-win32-x64": { 224 | "version": "1.7.3", 225 | "resolved": "https://registry.npmjs.org/@biomejs/cli-win32-x64/-/cli-win32-x64-1.7.3.tgz", 226 | "integrity": "sha512-ZmByhbrnmz/UUFYB622CECwhKIPjJLLPr5zr3edhu04LzbfcOrz16VYeNq5dpO1ADG70FORhAJkaIGdaVBG00w==", 227 | "cpu": [ 228 | "x64" 229 | ], 230 | "dev": true, 231 | "optional": true, 232 | "os": [ 233 | "win32" 234 | ], 235 | "engines": { 236 | "node": ">=14.21.3" 237 | } 238 | }, 239 | "node_modules/@esbuild/aix-ppc64": { 240 | "version": "0.21.5", 241 | "resolved": "https://registry.npmjs.org/@esbuild/aix-ppc64/-/aix-ppc64-0.21.5.tgz", 242 | "integrity": "sha512-1SDgH6ZSPTlggy1yI6+Dbkiz8xzpHJEVAlF/AM1tHPLsf5STom9rwtjE4hKAF20FfXXNTFqEYXyJNWh1GiZedQ==", 243 | "cpu": [ 244 | "ppc64" 245 | ], 246 | "dev": true, 247 | "optional": true, 248 | "os": [ 249 | "aix" 250 | ], 251 | "engines": { 252 | "node": ">=12" 253 | } 254 | }, 255 | "node_modules/@esbuild/android-arm": { 256 | "version": "0.21.5", 257 | "resolved": "https://registry.npmjs.org/@esbuild/android-arm/-/android-arm-0.21.5.tgz", 258 | "integrity": "sha512-vCPvzSjpPHEi1siZdlvAlsPxXl7WbOVUBBAowWug4rJHb68Ox8KualB+1ocNvT5fjv6wpkX6o/iEpbDrf68zcg==", 259 | "cpu": [ 260 | "arm" 261 | ], 262 | "dev": true, 263 | "optional": true, 264 | "os": [ 265 | "android" 266 | ], 267 | "engines": { 268 | "node": ">=12" 269 | } 270 | }, 271 | "node_modules/@esbuild/android-arm64": { 272 | "version": "0.21.5", 273 | "resolved": "https://registry.npmjs.org/@esbuild/android-arm64/-/android-arm64-0.21.5.tgz", 274 | "integrity": "sha512-c0uX9VAUBQ7dTDCjq+wdyGLowMdtR/GoC2U5IYk/7D1H1JYC0qseD7+11iMP2mRLN9RcCMRcjC4YMclCzGwS/A==", 275 | "cpu": [ 276 | "arm64" 277 | ], 278 | "dev": true, 279 | "optional": true, 280 | "os": [ 281 | "android" 282 | ], 283 | "engines": { 284 | "node": ">=12" 285 | } 286 | }, 287 | "node_modules/@esbuild/android-x64": { 288 | "version": "0.21.5", 289 | "resolved": "https://registry.npmjs.org/@esbuild/android-x64/-/android-x64-0.21.5.tgz", 290 | "integrity": "sha512-D7aPRUUNHRBwHxzxRvp856rjUHRFW1SdQATKXH2hqA0kAZb1hKmi02OpYRacl0TxIGz/ZmXWlbZgjwWYaCakTA==", 291 | "cpu": [ 292 | "x64" 293 | ], 294 | "dev": true, 295 | "optional": true, 296 | "os": [ 297 | "android" 298 | ], 299 | "engines": { 300 | "node": ">=12" 301 | } 302 | }, 303 | "node_modules/@esbuild/darwin-arm64": { 304 | "version": "0.21.5", 305 | "resolved": "https://registry.npmjs.org/@esbuild/darwin-arm64/-/darwin-arm64-0.21.5.tgz", 306 | "integrity": "sha512-DwqXqZyuk5AiWWf3UfLiRDJ5EDd49zg6O9wclZ7kUMv2WRFr4HKjXp/5t8JZ11QbQfUS6/cRCKGwYhtNAY88kQ==", 307 | "cpu": [ 308 | "arm64" 309 | ], 310 | "dev": true, 311 | "optional": true, 312 | "os": [ 313 | "darwin" 314 | ], 315 | "engines": { 316 | "node": ">=12" 317 | } 318 | }, 319 | "node_modules/@esbuild/darwin-x64": { 320 | "version": "0.21.5", 321 | "resolved": "https://registry.npmjs.org/@esbuild/darwin-x64/-/darwin-x64-0.21.5.tgz", 322 | "integrity": "sha512-se/JjF8NlmKVG4kNIuyWMV/22ZaerB+qaSi5MdrXtd6R08kvs2qCN4C09miupktDitvh8jRFflwGFBQcxZRjbw==", 323 | "cpu": [ 324 | "x64" 325 | ], 326 | "dev": true, 327 | "optional": true, 328 | "os": [ 329 | "darwin" 330 | ], 331 | "engines": { 332 | "node": ">=12" 333 | } 334 | }, 335 | "node_modules/@esbuild/freebsd-arm64": { 336 | "version": "0.21.5", 337 | "resolved": "https://registry.npmjs.org/@esbuild/freebsd-arm64/-/freebsd-arm64-0.21.5.tgz", 338 | "integrity": "sha512-5JcRxxRDUJLX8JXp/wcBCy3pENnCgBR9bN6JsY4OmhfUtIHe3ZW0mawA7+RDAcMLrMIZaf03NlQiX9DGyB8h4g==", 339 | "cpu": [ 340 | "arm64" 341 | ], 342 | "dev": true, 343 | "optional": true, 344 | "os": [ 345 | "freebsd" 346 | ], 347 | "engines": { 348 | "node": ">=12" 349 | } 350 | }, 351 | "node_modules/@esbuild/freebsd-x64": { 352 | "version": "0.21.5", 353 | "resolved": "https://registry.npmjs.org/@esbuild/freebsd-x64/-/freebsd-x64-0.21.5.tgz", 354 | "integrity": "sha512-J95kNBj1zkbMXtHVH29bBriQygMXqoVQOQYA+ISs0/2l3T9/kj42ow2mpqerRBxDJnmkUDCaQT/dfNXWX/ZZCQ==", 355 | "cpu": [ 356 | "x64" 357 | ], 358 | "dev": true, 359 | "optional": true, 360 | "os": [ 361 | "freebsd" 362 | ], 363 | "engines": { 364 | "node": ">=12" 365 | } 366 | }, 367 | "node_modules/@esbuild/linux-arm": { 368 | "version": "0.21.5", 369 | "resolved": "https://registry.npmjs.org/@esbuild/linux-arm/-/linux-arm-0.21.5.tgz", 370 | "integrity": "sha512-bPb5AHZtbeNGjCKVZ9UGqGwo8EUu4cLq68E95A53KlxAPRmUyYv2D6F0uUI65XisGOL1hBP5mTronbgo+0bFcA==", 371 | "cpu": [ 372 | "arm" 373 | ], 374 | "dev": true, 375 | "optional": true, 376 | "os": [ 377 | "linux" 378 | ], 379 | "engines": { 380 | "node": ">=12" 381 | } 382 | }, 383 | "node_modules/@esbuild/linux-arm64": { 384 | "version": "0.21.5", 385 | "resolved": "https://registry.npmjs.org/@esbuild/linux-arm64/-/linux-arm64-0.21.5.tgz", 386 | "integrity": "sha512-ibKvmyYzKsBeX8d8I7MH/TMfWDXBF3db4qM6sy+7re0YXya+K1cem3on9XgdT2EQGMu4hQyZhan7TeQ8XkGp4Q==", 387 | "cpu": [ 388 | "arm64" 389 | ], 390 | "dev": true, 391 | "optional": true, 392 | "os": [ 393 | "linux" 394 | ], 395 | "engines": { 396 | "node": ">=12" 397 | } 398 | }, 399 | "node_modules/@esbuild/linux-ia32": { 400 | "version": "0.21.5", 401 | "resolved": "https://registry.npmjs.org/@esbuild/linux-ia32/-/linux-ia32-0.21.5.tgz", 402 | "integrity": "sha512-YvjXDqLRqPDl2dvRODYmmhz4rPeVKYvppfGYKSNGdyZkA01046pLWyRKKI3ax8fbJoK5QbxblURkwK/MWY18Tg==", 403 | "cpu": [ 404 | "ia32" 405 | ], 406 | "dev": true, 407 | "optional": true, 408 | "os": [ 409 | "linux" 410 | ], 411 | "engines": { 412 | "node": ">=12" 413 | } 414 | }, 415 | "node_modules/@esbuild/linux-loong64": { 416 | "version": "0.21.5", 417 | "resolved": "https://registry.npmjs.org/@esbuild/linux-loong64/-/linux-loong64-0.21.5.tgz", 418 | "integrity": "sha512-uHf1BmMG8qEvzdrzAqg2SIG/02+4/DHB6a9Kbya0XDvwDEKCoC8ZRWI5JJvNdUjtciBGFQ5PuBlpEOXQj+JQSg==", 419 | "cpu": [ 420 | "loong64" 421 | ], 422 | "dev": true, 423 | "optional": true, 424 | "os": [ 425 | "linux" 426 | ], 427 | "engines": { 428 | "node": ">=12" 429 | } 430 | }, 431 | "node_modules/@esbuild/linux-mips64el": { 432 | "version": "0.21.5", 433 | "resolved": "https://registry.npmjs.org/@esbuild/linux-mips64el/-/linux-mips64el-0.21.5.tgz", 434 | "integrity": "sha512-IajOmO+KJK23bj52dFSNCMsz1QP1DqM6cwLUv3W1QwyxkyIWecfafnI555fvSGqEKwjMXVLokcV5ygHW5b3Jbg==", 435 | "cpu": [ 436 | "mips64el" 437 | ], 438 | "dev": true, 439 | "optional": true, 440 | "os": [ 441 | "linux" 442 | ], 443 | "engines": { 444 | "node": ">=12" 445 | } 446 | }, 447 | "node_modules/@esbuild/linux-ppc64": { 448 | "version": "0.21.5", 449 | "resolved": "https://registry.npmjs.org/@esbuild/linux-ppc64/-/linux-ppc64-0.21.5.tgz", 450 | "integrity": "sha512-1hHV/Z4OEfMwpLO8rp7CvlhBDnjsC3CttJXIhBi+5Aj5r+MBvy4egg7wCbe//hSsT+RvDAG7s81tAvpL2XAE4w==", 451 | "cpu": [ 452 | "ppc64" 453 | ], 454 | "dev": true, 455 | "optional": true, 456 | "os": [ 457 | "linux" 458 | ], 459 | "engines": { 460 | "node": ">=12" 461 | } 462 | }, 463 | "node_modules/@esbuild/linux-riscv64": { 464 | "version": "0.21.5", 465 | "resolved": "https://registry.npmjs.org/@esbuild/linux-riscv64/-/linux-riscv64-0.21.5.tgz", 466 | "integrity": "sha512-2HdXDMd9GMgTGrPWnJzP2ALSokE/0O5HhTUvWIbD3YdjME8JwvSCnNGBnTThKGEB91OZhzrJ4qIIxk/SBmyDDA==", 467 | "cpu": [ 468 | "riscv64" 469 | ], 470 | "dev": true, 471 | "optional": true, 472 | "os": [ 473 | "linux" 474 | ], 475 | "engines": { 476 | "node": ">=12" 477 | } 478 | }, 479 | "node_modules/@esbuild/linux-s390x": { 480 | "version": "0.21.5", 481 | "resolved": "https://registry.npmjs.org/@esbuild/linux-s390x/-/linux-s390x-0.21.5.tgz", 482 | "integrity": "sha512-zus5sxzqBJD3eXxwvjN1yQkRepANgxE9lgOW2qLnmr8ikMTphkjgXu1HR01K4FJg8h1kEEDAqDcZQtbrRnB41A==", 483 | "cpu": [ 484 | "s390x" 485 | ], 486 | "dev": true, 487 | "optional": true, 488 | "os": [ 489 | "linux" 490 | ], 491 | "engines": { 492 | "node": ">=12" 493 | } 494 | }, 495 | "node_modules/@esbuild/linux-x64": { 496 | "version": "0.21.5", 497 | "resolved": "https://registry.npmjs.org/@esbuild/linux-x64/-/linux-x64-0.21.5.tgz", 498 | "integrity": "sha512-1rYdTpyv03iycF1+BhzrzQJCdOuAOtaqHTWJZCWvijKD2N5Xu0TtVC8/+1faWqcP9iBCWOmjmhoH94dH82BxPQ==", 499 | "cpu": [ 500 | "x64" 501 | ], 502 | "dev": true, 503 | "optional": true, 504 | "os": [ 505 | "linux" 506 | ], 507 | "engines": { 508 | "node": ">=12" 509 | } 510 | }, 511 | "node_modules/@esbuild/netbsd-x64": { 512 | "version": "0.21.5", 513 | "resolved": "https://registry.npmjs.org/@esbuild/netbsd-x64/-/netbsd-x64-0.21.5.tgz", 514 | "integrity": "sha512-Woi2MXzXjMULccIwMnLciyZH4nCIMpWQAs049KEeMvOcNADVxo0UBIQPfSmxB3CWKedngg7sWZdLvLczpe0tLg==", 515 | "cpu": [ 516 | "x64" 517 | ], 518 | "dev": true, 519 | "optional": true, 520 | "os": [ 521 | "netbsd" 522 | ], 523 | "engines": { 524 | "node": ">=12" 525 | } 526 | }, 527 | "node_modules/@esbuild/openbsd-x64": { 528 | "version": "0.21.5", 529 | "resolved": "https://registry.npmjs.org/@esbuild/openbsd-x64/-/openbsd-x64-0.21.5.tgz", 530 | "integrity": "sha512-HLNNw99xsvx12lFBUwoT8EVCsSvRNDVxNpjZ7bPn947b8gJPzeHWyNVhFsaerc0n3TsbOINvRP2byTZ5LKezow==", 531 | "cpu": [ 532 | "x64" 533 | ], 534 | "dev": true, 535 | "optional": true, 536 | "os": [ 537 | "openbsd" 538 | ], 539 | "engines": { 540 | "node": ">=12" 541 | } 542 | }, 543 | "node_modules/@esbuild/sunos-x64": { 544 | "version": "0.21.5", 545 | "resolved": "https://registry.npmjs.org/@esbuild/sunos-x64/-/sunos-x64-0.21.5.tgz", 546 | "integrity": "sha512-6+gjmFpfy0BHU5Tpptkuh8+uw3mnrvgs+dSPQXQOv3ekbordwnzTVEb4qnIvQcYXq6gzkyTnoZ9dZG+D4garKg==", 547 | "cpu": [ 548 | "x64" 549 | ], 550 | "dev": true, 551 | "optional": true, 552 | "os": [ 553 | "sunos" 554 | ], 555 | "engines": { 556 | "node": ">=12" 557 | } 558 | }, 559 | "node_modules/@esbuild/win32-arm64": { 560 | "version": "0.21.5", 561 | "resolved": "https://registry.npmjs.org/@esbuild/win32-arm64/-/win32-arm64-0.21.5.tgz", 562 | "integrity": "sha512-Z0gOTd75VvXqyq7nsl93zwahcTROgqvuAcYDUr+vOv8uHhNSKROyU961kgtCD1e95IqPKSQKH7tBTslnS3tA8A==", 563 | "cpu": [ 564 | "arm64" 565 | ], 566 | "dev": true, 567 | "optional": true, 568 | "os": [ 569 | "win32" 570 | ], 571 | "engines": { 572 | "node": ">=12" 573 | } 574 | }, 575 | "node_modules/@esbuild/win32-ia32": { 576 | "version": "0.21.5", 577 | "resolved": "https://registry.npmjs.org/@esbuild/win32-ia32/-/win32-ia32-0.21.5.tgz", 578 | "integrity": "sha512-SWXFF1CL2RVNMaVs+BBClwtfZSvDgtL//G/smwAc5oVK/UPu2Gu9tIaRgFmYFFKrmg3SyAjSrElf0TiJ1v8fYA==", 579 | "cpu": [ 580 | "ia32" 581 | ], 582 | "dev": true, 583 | "optional": true, 584 | "os": [ 585 | "win32" 586 | ], 587 | "engines": { 588 | "node": ">=12" 589 | } 590 | }, 591 | "node_modules/@esbuild/win32-x64": { 592 | "version": "0.21.5", 593 | "resolved": "https://registry.npmjs.org/@esbuild/win32-x64/-/win32-x64-0.21.5.tgz", 594 | "integrity": "sha512-tQd/1efJuzPC6rCFwEvLtci/xNFcTZknmXs98FYDfGE4wP9ClFV98nyKrzJKVPMhdDnjzLhdUyMX4PsQAPjwIw==", 595 | "cpu": [ 596 | "x64" 597 | ], 598 | "dev": true, 599 | "optional": true, 600 | "os": [ 601 | "win32" 602 | ], 603 | "engines": { 604 | "node": ">=12" 605 | } 606 | }, 607 | "node_modules/@istanbuljs/schema": { 608 | "version": "0.1.3", 609 | "resolved": "https://registry.npmjs.org/@istanbuljs/schema/-/schema-0.1.3.tgz", 610 | "integrity": "sha512-ZXRY4jNvVgSVQ8DL3LTcakaAtXwTVUxE81hslsyD2AtoXW/wVob10HkOJ1X/pAlcI7D+2YoZKg5do8G/w6RYgA==", 611 | "dev": true, 612 | "engines": { 613 | "node": ">=8" 614 | } 615 | }, 616 | "node_modules/@jest/schemas": { 617 | "version": "29.6.3", 618 | "resolved": "https://registry.npmjs.org/@jest/schemas/-/schemas-29.6.3.tgz", 619 | "integrity": "sha512-mo5j5X+jIZmJQveBKeS/clAueipV7KgiX1vMgCxam1RNYiqE1w62n0/tJJnHtjW8ZHcQco5gY85jA3mi0L+nSA==", 620 | "dev": true, 621 | "dependencies": { 622 | "@sinclair/typebox": "^0.27.8" 623 | }, 624 | "engines": { 625 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 626 | } 627 | }, 628 | "node_modules/@jridgewell/gen-mapping": { 629 | "version": "0.3.5", 630 | "resolved": "https://registry.npmjs.org/@jridgewell/gen-mapping/-/gen-mapping-0.3.5.tgz", 631 | "integrity": "sha512-IzL8ZoEDIBRWEzlCcRhOaCupYyN5gdIK+Q6fbFdPDg6HqX6jpkItn7DFIpW9LQzXG6Df9sA7+OKnq0qlz/GaQg==", 632 | "dev": true, 633 | "dependencies": { 634 | "@jridgewell/set-array": "^1.2.1", 635 | "@jridgewell/sourcemap-codec": "^1.4.10", 636 | "@jridgewell/trace-mapping": "^0.3.24" 637 | }, 638 | "engines": { 639 | "node": ">=6.0.0" 640 | } 641 | }, 642 | "node_modules/@jridgewell/resolve-uri": { 643 | "version": "3.1.2", 644 | "resolved": "https://registry.npmjs.org/@jridgewell/resolve-uri/-/resolve-uri-3.1.2.tgz", 645 | "integrity": "sha512-bRISgCIjP20/tbWSPWMEi54QVPRZExkuD9lJL+UIxUKtwVJA8wW1Trb1jMs1RFXo1CBTNZ/5hpC9QvmKWdopKw==", 646 | "dev": true, 647 | "engines": { 648 | "node": ">=6.0.0" 649 | } 650 | }, 651 | "node_modules/@jridgewell/set-array": { 652 | "version": "1.2.1", 653 | "resolved": "https://registry.npmjs.org/@jridgewell/set-array/-/set-array-1.2.1.tgz", 654 | "integrity": "sha512-R8gLRTZeyp03ymzP/6Lil/28tGeGEzhx1q2k703KGWRAI1VdvPIXdG70VJc2pAMw3NA6JKL5hhFu1sJX0Mnn/A==", 655 | "dev": true, 656 | "engines": { 657 | "node": ">=6.0.0" 658 | } 659 | }, 660 | "node_modules/@jridgewell/source-map": { 661 | "version": "0.3.6", 662 | "resolved": "https://registry.npmjs.org/@jridgewell/source-map/-/source-map-0.3.6.tgz", 663 | "integrity": "sha512-1ZJTZebgqllO79ue2bm3rIGud/bOe0pP5BjSRCRxxYkEZS8STV7zN84UBbiYu7jy+eCKSnVIUgoWWE/tt+shMQ==", 664 | "dev": true, 665 | "dependencies": { 666 | "@jridgewell/gen-mapping": "^0.3.5", 667 | "@jridgewell/trace-mapping": "^0.3.25" 668 | } 669 | }, 670 | "node_modules/@jridgewell/sourcemap-codec": { 671 | "version": "1.4.15", 672 | "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.4.15.tgz", 673 | "integrity": "sha512-eF2rxCRulEKXHTRiDrDy6erMYWqNw4LPdQ8UQA4huuxaQsVeRPFl2oM8oDGxMFhJUWZf9McpLtJasDDZb/Bpeg==", 674 | "dev": true 675 | }, 676 | "node_modules/@jridgewell/trace-mapping": { 677 | "version": "0.3.25", 678 | "resolved": "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.25.tgz", 679 | "integrity": "sha512-vNk6aEwybGtawWmy/PzwnGDOjCkLWSD2wqvjGGAgOAwCGWySYXfYoxt00IJkTF+8Lb57DwOb3Aa0o9CApepiYQ==", 680 | "dev": true, 681 | "dependencies": { 682 | "@jridgewell/resolve-uri": "^3.1.0", 683 | "@jridgewell/sourcemap-codec": "^1.4.14" 684 | } 685 | }, 686 | "node_modules/@nodelib/fs.scandir": { 687 | "version": "2.1.5", 688 | "resolved": "https://registry.npmjs.org/@nodelib/fs.scandir/-/fs.scandir-2.1.5.tgz", 689 | "integrity": "sha512-vq24Bq3ym5HEQm2NKCr3yXDwjc7vTsEThRDnkp2DK9p1uqLR+DHurm/NOTo0KG7HYHU7eppKZj3MyqYuMBf62g==", 690 | "dev": true, 691 | "dependencies": { 692 | "@nodelib/fs.stat": "2.0.5", 693 | "run-parallel": "^1.1.9" 694 | }, 695 | "engines": { 696 | "node": ">= 8" 697 | } 698 | }, 699 | "node_modules/@nodelib/fs.stat": { 700 | "version": "2.0.5", 701 | "resolved": "https://registry.npmjs.org/@nodelib/fs.stat/-/fs.stat-2.0.5.tgz", 702 | "integrity": "sha512-RkhPPp2zrqDAQA/2jNhnztcPAlv64XdhIp7a7454A5ovI7Bukxgt7MX7udwAu3zg1DcpPU0rz3VV1SeaqvY4+A==", 703 | "dev": true, 704 | "engines": { 705 | "node": ">= 8" 706 | } 707 | }, 708 | "node_modules/@nodelib/fs.walk": { 709 | "version": "1.2.8", 710 | "resolved": "https://registry.npmjs.org/@nodelib/fs.walk/-/fs.walk-1.2.8.tgz", 711 | "integrity": "sha512-oGB+UxlgWcgQkgwo8GcEGwemoTFt3FIO9ababBmaGwXIoBKZ+GTy0pP185beGg7Llih/NSHSV2XAs1lnznocSg==", 712 | "dev": true, 713 | "dependencies": { 714 | "@nodelib/fs.scandir": "2.1.5", 715 | "fastq": "^1.6.0" 716 | }, 717 | "engines": { 718 | "node": ">= 8" 719 | } 720 | }, 721 | "node_modules/@rollup/pluginutils": { 722 | "version": "4.2.1", 723 | "resolved": "https://registry.npmjs.org/@rollup/pluginutils/-/pluginutils-4.2.1.tgz", 724 | "integrity": "sha512-iKnFXr7NkdZAIHiIWE+BX5ULi/ucVFYWD6TbAV+rZctiRTY2PL6tsIKhoIOaoskiWAkgu+VsbXgUVDNLHf+InQ==", 725 | "dev": true, 726 | "dependencies": { 727 | "estree-walker": "^2.0.1", 728 | "picomatch": "^2.2.2" 729 | }, 730 | "engines": { 731 | "node": ">= 8.0.0" 732 | } 733 | }, 734 | "node_modules/@rollup/rollup-android-arm-eabi": { 735 | "version": "4.24.4", 736 | "resolved": "https://registry.npmjs.org/@rollup/rollup-android-arm-eabi/-/rollup-android-arm-eabi-4.24.4.tgz", 737 | "integrity": "sha512-jfUJrFct/hTA0XDM5p/htWKoNNTbDLY0KRwEt6pyOA6k2fmk0WVwl65PdUdJZgzGEHWx+49LilkcSaumQRyNQw==", 738 | "cpu": [ 739 | "arm" 740 | ], 741 | "dev": true, 742 | "optional": true, 743 | "os": [ 744 | "android" 745 | ] 746 | }, 747 | "node_modules/@rollup/rollup-android-arm64": { 748 | "version": "4.24.4", 749 | "resolved": "https://registry.npmjs.org/@rollup/rollup-android-arm64/-/rollup-android-arm64-4.24.4.tgz", 750 | "integrity": "sha512-j4nrEO6nHU1nZUuCfRKoCcvh7PIywQPUCBa2UsootTHvTHIoIu2BzueInGJhhvQO/2FTRdNYpf63xsgEqH9IhA==", 751 | "cpu": [ 752 | "arm64" 753 | ], 754 | "dev": true, 755 | "optional": true, 756 | "os": [ 757 | "android" 758 | ] 759 | }, 760 | "node_modules/@rollup/rollup-darwin-arm64": { 761 | "version": "4.24.4", 762 | "resolved": "https://registry.npmjs.org/@rollup/rollup-darwin-arm64/-/rollup-darwin-arm64-4.24.4.tgz", 763 | "integrity": "sha512-GmU/QgGtBTeraKyldC7cDVVvAJEOr3dFLKneez/n7BvX57UdhOqDsVwzU7UOnYA7AAOt+Xb26lk79PldDHgMIQ==", 764 | "cpu": [ 765 | "arm64" 766 | ], 767 | "dev": true, 768 | "optional": true, 769 | "os": [ 770 | "darwin" 771 | ] 772 | }, 773 | "node_modules/@rollup/rollup-darwin-x64": { 774 | "version": "4.24.4", 775 | "resolved": "https://registry.npmjs.org/@rollup/rollup-darwin-x64/-/rollup-darwin-x64-4.24.4.tgz", 776 | "integrity": "sha512-N6oDBiZCBKlwYcsEPXGDE4g9RoxZLK6vT98M8111cW7VsVJFpNEqvJeIPfsCzbf0XEakPslh72X0gnlMi4Ddgg==", 777 | "cpu": [ 778 | "x64" 779 | ], 780 | "dev": true, 781 | "optional": true, 782 | "os": [ 783 | "darwin" 784 | ] 785 | }, 786 | "node_modules/@rollup/rollup-freebsd-arm64": { 787 | "version": "4.24.4", 788 | "resolved": "https://registry.npmjs.org/@rollup/rollup-freebsd-arm64/-/rollup-freebsd-arm64-4.24.4.tgz", 789 | "integrity": "sha512-py5oNShCCjCyjWXCZNrRGRpjWsF0ic8f4ieBNra5buQz0O/U6mMXCpC1LvrHuhJsNPgRt36tSYMidGzZiJF6mw==", 790 | "cpu": [ 791 | "arm64" 792 | ], 793 | "dev": true, 794 | "optional": true, 795 | "os": [ 796 | "freebsd" 797 | ] 798 | }, 799 | "node_modules/@rollup/rollup-freebsd-x64": { 800 | "version": "4.24.4", 801 | "resolved": "https://registry.npmjs.org/@rollup/rollup-freebsd-x64/-/rollup-freebsd-x64-4.24.4.tgz", 802 | "integrity": "sha512-L7VVVW9FCnTTp4i7KrmHeDsDvjB4++KOBENYtNYAiYl96jeBThFfhP6HVxL74v4SiZEVDH/1ILscR5U9S4ms4g==", 803 | "cpu": [ 804 | "x64" 805 | ], 806 | "dev": true, 807 | "optional": true, 808 | "os": [ 809 | "freebsd" 810 | ] 811 | }, 812 | "node_modules/@rollup/rollup-linux-arm-gnueabihf": { 813 | "version": "4.24.4", 814 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm-gnueabihf/-/rollup-linux-arm-gnueabihf-4.24.4.tgz", 815 | "integrity": "sha512-10ICosOwYChROdQoQo589N5idQIisxjaFE/PAnX2i0Zr84mY0k9zul1ArH0rnJ/fpgiqfu13TFZR5A5YJLOYZA==", 816 | "cpu": [ 817 | "arm" 818 | ], 819 | "dev": true, 820 | "optional": true, 821 | "os": [ 822 | "linux" 823 | ] 824 | }, 825 | "node_modules/@rollup/rollup-linux-arm-musleabihf": { 826 | "version": "4.24.4", 827 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm-musleabihf/-/rollup-linux-arm-musleabihf-4.24.4.tgz", 828 | "integrity": "sha512-ySAfWs69LYC7QhRDZNKqNhz2UKN8LDfbKSMAEtoEI0jitwfAG2iZwVqGACJT+kfYvvz3/JgsLlcBP+WWoKCLcw==", 829 | "cpu": [ 830 | "arm" 831 | ], 832 | "dev": true, 833 | "optional": true, 834 | "os": [ 835 | "linux" 836 | ] 837 | }, 838 | "node_modules/@rollup/rollup-linux-arm64-gnu": { 839 | "version": "4.24.4", 840 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm64-gnu/-/rollup-linux-arm64-gnu-4.24.4.tgz", 841 | "integrity": "sha512-uHYJ0HNOI6pGEeZ/5mgm5arNVTI0nLlmrbdph+pGXpC9tFHFDQmDMOEqkmUObRfosJqpU8RliYoGz06qSdtcjg==", 842 | "cpu": [ 843 | "arm64" 844 | ], 845 | "dev": true, 846 | "optional": true, 847 | "os": [ 848 | "linux" 849 | ] 850 | }, 851 | "node_modules/@rollup/rollup-linux-arm64-musl": { 852 | "version": "4.24.4", 853 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm64-musl/-/rollup-linux-arm64-musl-4.24.4.tgz", 854 | "integrity": "sha512-38yiWLemQf7aLHDgTg85fh3hW9stJ0Muk7+s6tIkSUOMmi4Xbv5pH/5Bofnsb6spIwD5FJiR+jg71f0CH5OzoA==", 855 | "cpu": [ 856 | "arm64" 857 | ], 858 | "dev": true, 859 | "optional": true, 860 | "os": [ 861 | "linux" 862 | ] 863 | }, 864 | "node_modules/@rollup/rollup-linux-powerpc64le-gnu": { 865 | "version": "4.24.4", 866 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-powerpc64le-gnu/-/rollup-linux-powerpc64le-gnu-4.24.4.tgz", 867 | "integrity": "sha512-q73XUPnkwt9ZNF2xRS4fvneSuaHw2BXuV5rI4cw0fWYVIWIBeDZX7c7FWhFQPNTnE24172K30I+dViWRVD9TwA==", 868 | "cpu": [ 869 | "ppc64" 870 | ], 871 | "dev": true, 872 | "optional": true, 873 | "os": [ 874 | "linux" 875 | ] 876 | }, 877 | "node_modules/@rollup/rollup-linux-riscv64-gnu": { 878 | "version": "4.24.4", 879 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-riscv64-gnu/-/rollup-linux-riscv64-gnu-4.24.4.tgz", 880 | "integrity": "sha512-Aie/TbmQi6UXokJqDZdmTJuZBCU3QBDA8oTKRGtd4ABi/nHgXICulfg1KI6n9/koDsiDbvHAiQO3YAUNa/7BCw==", 881 | "cpu": [ 882 | "riscv64" 883 | ], 884 | "dev": true, 885 | "optional": true, 886 | "os": [ 887 | "linux" 888 | ] 889 | }, 890 | "node_modules/@rollup/rollup-linux-s390x-gnu": { 891 | "version": "4.24.4", 892 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-s390x-gnu/-/rollup-linux-s390x-gnu-4.24.4.tgz", 893 | "integrity": "sha512-P8MPErVO/y8ohWSP9JY7lLQ8+YMHfTI4bAdtCi3pC2hTeqFJco2jYspzOzTUB8hwUWIIu1xwOrJE11nP+0JFAQ==", 894 | "cpu": [ 895 | "s390x" 896 | ], 897 | "dev": true, 898 | "optional": true, 899 | "os": [ 900 | "linux" 901 | ] 902 | }, 903 | "node_modules/@rollup/rollup-linux-x64-gnu": { 904 | "version": "4.24.4", 905 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-x64-gnu/-/rollup-linux-x64-gnu-4.24.4.tgz", 906 | "integrity": "sha512-K03TljaaoPK5FOyNMZAAEmhlyO49LaE4qCsr0lYHUKyb6QacTNF9pnfPpXnFlFD3TXuFbFbz7tJ51FujUXkXYA==", 907 | "cpu": [ 908 | "x64" 909 | ], 910 | "dev": true, 911 | "optional": true, 912 | "os": [ 913 | "linux" 914 | ] 915 | }, 916 | "node_modules/@rollup/rollup-linux-x64-musl": { 917 | "version": "4.24.4", 918 | "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-x64-musl/-/rollup-linux-x64-musl-4.24.4.tgz", 919 | "integrity": "sha512-VJYl4xSl/wqG2D5xTYncVWW+26ICV4wubwN9Gs5NrqhJtayikwCXzPL8GDsLnaLU3WwhQ8W02IinYSFJfyo34Q==", 920 | "cpu": [ 921 | "x64" 922 | ], 923 | "dev": true, 924 | "optional": true, 925 | "os": [ 926 | "linux" 927 | ] 928 | }, 929 | "node_modules/@rollup/rollup-win32-arm64-msvc": { 930 | "version": "4.24.4", 931 | "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-arm64-msvc/-/rollup-win32-arm64-msvc-4.24.4.tgz", 932 | "integrity": "sha512-ku2GvtPwQfCqoPFIJCqZ8o7bJcj+Y54cZSr43hHca6jLwAiCbZdBUOrqE6y29QFajNAzzpIOwsckaTFmN6/8TA==", 933 | "cpu": [ 934 | "arm64" 935 | ], 936 | "dev": true, 937 | "optional": true, 938 | "os": [ 939 | "win32" 940 | ] 941 | }, 942 | "node_modules/@rollup/rollup-win32-ia32-msvc": { 943 | "version": "4.24.4", 944 | "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-ia32-msvc/-/rollup-win32-ia32-msvc-4.24.4.tgz", 945 | "integrity": "sha512-V3nCe+eTt/W6UYNr/wGvO1fLpHUrnlirlypZfKCT1fG6hWfqhPgQV/K/mRBXBpxc0eKLIF18pIOFVPh0mqHjlg==", 946 | "cpu": [ 947 | "ia32" 948 | ], 949 | "dev": true, 950 | "optional": true, 951 | "os": [ 952 | "win32" 953 | ] 954 | }, 955 | "node_modules/@rollup/rollup-win32-x64-msvc": { 956 | "version": "4.24.4", 957 | "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-x64-msvc/-/rollup-win32-x64-msvc-4.24.4.tgz", 958 | "integrity": "sha512-LTw1Dfd0mBIEqUVCxbvTE/LLo+9ZxVC9k99v1v4ahg9Aak6FpqOfNu5kRkeTAn0wphoC4JU7No1/rL+bBCEwhg==", 959 | "cpu": [ 960 | "x64" 961 | ], 962 | "dev": true, 963 | "optional": true, 964 | "os": [ 965 | "win32" 966 | ] 967 | }, 968 | "node_modules/@sinclair/typebox": { 969 | "version": "0.27.8", 970 | "resolved": "https://registry.npmjs.org/@sinclair/typebox/-/typebox-0.27.8.tgz", 971 | "integrity": "sha512-+Fj43pSMwJs4KRrH/938Uf+uAELIgVBmQzg/q1YG10djyfA3TnrU8N8XzqCh/okZdszqBQTZf96idMfE5lnwTA==", 972 | "dev": true 973 | }, 974 | "node_modules/@types/estree": { 975 | "version": "1.0.6", 976 | "resolved": "https://registry.npmjs.org/@types/estree/-/estree-1.0.6.tgz", 977 | "integrity": "sha512-AYnb1nQyY49te+VRAVgmzfcgjYS91mY5P0TKUDCLEM+gNnA+3T6rWITXRLYCpahpqSQbN5cE+gHpnPyXjHWxcw==", 978 | "dev": true 979 | }, 980 | "node_modules/@vitest/coverage-v8": { 981 | "version": "1.6.0", 982 | "resolved": "https://registry.npmjs.org/@vitest/coverage-v8/-/coverage-v8-1.6.0.tgz", 983 | "integrity": "sha512-KvapcbMY/8GYIG0rlwwOKCVNRc0OL20rrhFkg/CHNzncV03TE2XWvO5w9uZYoxNiMEBacAJt3unSOiZ7svePew==", 984 | "dev": true, 985 | "dependencies": { 986 | "@ampproject/remapping": "^2.2.1", 987 | "@bcoe/v8-coverage": "^0.2.3", 988 | "debug": "^4.3.4", 989 | "istanbul-lib-coverage": "^3.2.2", 990 | "istanbul-lib-report": "^3.0.1", 991 | "istanbul-lib-source-maps": "^5.0.4", 992 | "istanbul-reports": "^3.1.6", 993 | "magic-string": "^0.30.5", 994 | "magicast": "^0.3.3", 995 | "picocolors": "^1.0.0", 996 | "std-env": "^3.5.0", 997 | "strip-literal": "^2.0.0", 998 | "test-exclude": "^6.0.0" 999 | }, 1000 | "funding": { 1001 | "url": "https://opencollective.com/vitest" 1002 | }, 1003 | "peerDependencies": { 1004 | "vitest": "1.6.0" 1005 | } 1006 | }, 1007 | "node_modules/@vitest/expect": { 1008 | "version": "1.6.0", 1009 | "resolved": "https://registry.npmjs.org/@vitest/expect/-/expect-1.6.0.tgz", 1010 | "integrity": "sha512-ixEvFVQjycy/oNgHjqsL6AZCDduC+tflRluaHIzKIsdbzkLn2U/iBnVeJwB6HsIjQBdfMR8Z0tRxKUsvFJEeWQ==", 1011 | "dev": true, 1012 | "dependencies": { 1013 | "@vitest/spy": "1.6.0", 1014 | "@vitest/utils": "1.6.0", 1015 | "chai": "^4.3.10" 1016 | }, 1017 | "funding": { 1018 | "url": "https://opencollective.com/vitest" 1019 | } 1020 | }, 1021 | "node_modules/@vitest/runner": { 1022 | "version": "1.6.0", 1023 | "resolved": "https://registry.npmjs.org/@vitest/runner/-/runner-1.6.0.tgz", 1024 | "integrity": "sha512-P4xgwPjwesuBiHisAVz/LSSZtDjOTPYZVmNAnpHHSR6ONrf8eCJOFRvUwdHn30F5M1fxhqtl7QZQUk2dprIXAg==", 1025 | "dev": true, 1026 | "dependencies": { 1027 | "@vitest/utils": "1.6.0", 1028 | "p-limit": "^5.0.0", 1029 | "pathe": "^1.1.1" 1030 | }, 1031 | "funding": { 1032 | "url": "https://opencollective.com/vitest" 1033 | } 1034 | }, 1035 | "node_modules/@vitest/runner/node_modules/pathe": { 1036 | "version": "1.1.2", 1037 | "resolved": "https://registry.npmjs.org/pathe/-/pathe-1.1.2.tgz", 1038 | "integrity": "sha512-whLdWMYL2TwI08hn8/ZqAbrVemu0LNaNNJZX73O6qaIdCTfXutsLhMkjdENX0qhsQ9uIimo4/aQOmXkoon2nDQ==", 1039 | "dev": true 1040 | }, 1041 | "node_modules/@vitest/snapshot": { 1042 | "version": "1.6.0", 1043 | "resolved": "https://registry.npmjs.org/@vitest/snapshot/-/snapshot-1.6.0.tgz", 1044 | "integrity": "sha512-+Hx43f8Chus+DCmygqqfetcAZrDJwvTj0ymqjQq4CvmpKFSTVteEOBzCusu1x2tt4OJcvBflyHUE0DZSLgEMtQ==", 1045 | "dev": true, 1046 | "dependencies": { 1047 | "magic-string": "^0.30.5", 1048 | "pathe": "^1.1.1", 1049 | "pretty-format": "^29.7.0" 1050 | }, 1051 | "funding": { 1052 | "url": "https://opencollective.com/vitest" 1053 | } 1054 | }, 1055 | "node_modules/@vitest/snapshot/node_modules/pathe": { 1056 | "version": "1.1.2", 1057 | "resolved": "https://registry.npmjs.org/pathe/-/pathe-1.1.2.tgz", 1058 | "integrity": "sha512-whLdWMYL2TwI08hn8/ZqAbrVemu0LNaNNJZX73O6qaIdCTfXutsLhMkjdENX0qhsQ9uIimo4/aQOmXkoon2nDQ==", 1059 | "dev": true 1060 | }, 1061 | "node_modules/@vitest/spy": { 1062 | "version": "1.6.0", 1063 | "resolved": "https://registry.npmjs.org/@vitest/spy/-/spy-1.6.0.tgz", 1064 | "integrity": "sha512-leUTap6B/cqi/bQkXUu6bQV5TZPx7pmMBKBQiI0rJA8c3pB56ZsaTbREnF7CJfmvAS4V2cXIBAh/3rVwrrCYgw==", 1065 | "dev": true, 1066 | "dependencies": { 1067 | "tinyspy": "^2.2.0" 1068 | }, 1069 | "funding": { 1070 | "url": "https://opencollective.com/vitest" 1071 | } 1072 | }, 1073 | "node_modules/@vitest/utils": { 1074 | "version": "1.6.0", 1075 | "resolved": "https://registry.npmjs.org/@vitest/utils/-/utils-1.6.0.tgz", 1076 | "integrity": "sha512-21cPiuGMoMZwiOHa2i4LXkMkMkCGzA+MVFV70jRwHo95dL4x/ts5GZhML1QWuy7yfp3WzK3lRvZi3JnXTYqrBw==", 1077 | "dev": true, 1078 | "dependencies": { 1079 | "diff-sequences": "^29.6.3", 1080 | "estree-walker": "^3.0.3", 1081 | "loupe": "^2.3.7", 1082 | "pretty-format": "^29.7.0" 1083 | }, 1084 | "funding": { 1085 | "url": "https://opencollective.com/vitest" 1086 | } 1087 | }, 1088 | "node_modules/@vitest/utils/node_modules/estree-walker": { 1089 | "version": "3.0.3", 1090 | "resolved": "https://registry.npmjs.org/estree-walker/-/estree-walker-3.0.3.tgz", 1091 | "integrity": "sha512-7RUKfXgSMMkzt6ZuXmqapOurLGPPfgj6l9uRZ7lRGolvk0y2yocc35LdcxKC5PQZdn2DMqioAQ2NoWcrTKmm6g==", 1092 | "dev": true, 1093 | "dependencies": { 1094 | "@types/estree": "^1.0.0" 1095 | } 1096 | }, 1097 | "node_modules/acorn": { 1098 | "version": "8.11.3", 1099 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.11.3.tgz", 1100 | "integrity": "sha512-Y9rRfJG5jcKOE0CLisYbojUjIrIEE7AGMzA/Sm4BslANhbS+cDMpgBdcPT91oJ7OuJ9hYJBx59RjbhxVnrF8Xg==", 1101 | "dev": true, 1102 | "bin": { 1103 | "acorn": "bin/acorn" 1104 | }, 1105 | "engines": { 1106 | "node": ">=0.4.0" 1107 | } 1108 | }, 1109 | "node_modules/acorn-walk": { 1110 | "version": "8.3.2", 1111 | "resolved": "https://registry.npmjs.org/acorn-walk/-/acorn-walk-8.3.2.tgz", 1112 | "integrity": "sha512-cjkyv4OtNCIeqhHrfS81QWXoCBPExR/J62oyEqepVw8WaQeSqpW2uhuLPh1m9eWhDuOo/jUXVTlifvesOWp/4A==", 1113 | "dev": true, 1114 | "engines": { 1115 | "node": ">=0.4.0" 1116 | } 1117 | }, 1118 | "node_modules/ansi-styles": { 1119 | "version": "4.3.0", 1120 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 1121 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 1122 | "dev": true, 1123 | "dependencies": { 1124 | "color-convert": "^2.0.1" 1125 | }, 1126 | "engines": { 1127 | "node": ">=8" 1128 | }, 1129 | "funding": { 1130 | "url": "https://github.com/chalk/ansi-styles?sponsor=1" 1131 | } 1132 | }, 1133 | "node_modules/assertion-error": { 1134 | "version": "1.1.0", 1135 | "resolved": "https://registry.npmjs.org/assertion-error/-/assertion-error-1.1.0.tgz", 1136 | "integrity": "sha512-jgsaNduz+ndvGyFt3uSuWqvy4lCnIJiovtouQN5JZHOKCS2QuhEdbcQHFhVksz2N2U9hXJo8odG7ETyWlEeuDw==", 1137 | "dev": true, 1138 | "engines": { 1139 | "node": "*" 1140 | } 1141 | }, 1142 | "node_modules/async": { 1143 | "version": "3.2.5", 1144 | "resolved": "https://registry.npmjs.org/async/-/async-3.2.5.tgz", 1145 | "integrity": "sha512-baNZyqaaLhyLVKm/DlvdW051MSgO6b8eVfIezl9E5PqWxFgzLm/wQntEW4zOytVburDEr0JlALEpdOFwvErLsg==", 1146 | "dev": true 1147 | }, 1148 | "node_modules/balanced-match": { 1149 | "version": "1.0.2", 1150 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", 1151 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", 1152 | "dev": true 1153 | }, 1154 | "node_modules/boolbase": { 1155 | "version": "1.0.0", 1156 | "resolved": "https://registry.npmjs.org/boolbase/-/boolbase-1.0.0.tgz", 1157 | "integrity": "sha512-JZOSA7Mo9sNGB8+UjSgzdLtokWAky1zbztM3WRLCbZ70/3cTANmQmOdR7y2g+J0e2WXywy1yS468tY+IruqEww==", 1158 | "dev": true 1159 | }, 1160 | "node_modules/brace-expansion": { 1161 | "version": "1.1.11", 1162 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 1163 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 1164 | "dev": true, 1165 | "dependencies": { 1166 | "balanced-match": "^1.0.0", 1167 | "concat-map": "0.0.1" 1168 | } 1169 | }, 1170 | "node_modules/braces": { 1171 | "version": "3.0.3", 1172 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.3.tgz", 1173 | "integrity": "sha512-yQbXgO/OSZVD2IsiLlro+7Hf6Q18EJrKSEsdoMzKePKXct3gvD8oLcOQdIzGupr5Fj+EDe8gO/lxc1BzfMpxvA==", 1174 | "dev": true, 1175 | "dependencies": { 1176 | "fill-range": "^7.1.1" 1177 | }, 1178 | "engines": { 1179 | "node": ">=8" 1180 | } 1181 | }, 1182 | "node_modules/buffer-from": { 1183 | "version": "1.1.2", 1184 | "resolved": "https://registry.npmjs.org/buffer-from/-/buffer-from-1.1.2.tgz", 1185 | "integrity": "sha512-E+XQCRwSbaaiChtv6k6Dwgc+bx+Bs6vuKJHHl5kox/BaKbhiXzqQOwK4cO22yElGp2OCmjwVhT3HmxgyPGnJfQ==", 1186 | "dev": true 1187 | }, 1188 | "node_modules/cac": { 1189 | "version": "6.7.14", 1190 | "resolved": "https://registry.npmjs.org/cac/-/cac-6.7.14.tgz", 1191 | "integrity": "sha512-b6Ilus+c3RrdDk+JhLKUAQfzzgLEPy6wcXqS7f/xe1EETvsDP6GORG7SFuOs6cID5YkqchW/LXZbX5bc8j7ZcQ==", 1192 | "dev": true, 1193 | "engines": { 1194 | "node": ">=8" 1195 | } 1196 | }, 1197 | "node_modules/camel-case": { 1198 | "version": "4.1.2", 1199 | "resolved": "https://registry.npmjs.org/camel-case/-/camel-case-4.1.2.tgz", 1200 | "integrity": "sha512-gxGWBrTT1JuMx6R+o5PTXMmUnhnVzLQ9SNutD4YqKtI6ap897t3tKECYla6gCWEkplXnlNybEkZg9GEGxKFCgw==", 1201 | "dev": true, 1202 | "dependencies": { 1203 | "pascal-case": "^3.1.2", 1204 | "tslib": "^2.0.3" 1205 | } 1206 | }, 1207 | "node_modules/chai": { 1208 | "version": "4.4.1", 1209 | "resolved": "https://registry.npmjs.org/chai/-/chai-4.4.1.tgz", 1210 | "integrity": "sha512-13sOfMv2+DWduEU+/xbun3LScLoqN17nBeTLUsmDfKdoiC1fr0n9PU4guu4AhRcOVFk/sW8LyZWHuhWtQZiF+g==", 1211 | "dev": true, 1212 | "dependencies": { 1213 | "assertion-error": "^1.1.0", 1214 | "check-error": "^1.0.3", 1215 | "deep-eql": "^4.1.3", 1216 | "get-func-name": "^2.0.2", 1217 | "loupe": "^2.3.6", 1218 | "pathval": "^1.1.1", 1219 | "type-detect": "^4.0.8" 1220 | }, 1221 | "engines": { 1222 | "node": ">=4" 1223 | } 1224 | }, 1225 | "node_modules/chalk": { 1226 | "version": "4.1.2", 1227 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", 1228 | "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", 1229 | "dev": true, 1230 | "dependencies": { 1231 | "ansi-styles": "^4.1.0", 1232 | "supports-color": "^7.1.0" 1233 | }, 1234 | "engines": { 1235 | "node": ">=10" 1236 | }, 1237 | "funding": { 1238 | "url": "https://github.com/chalk/chalk?sponsor=1" 1239 | } 1240 | }, 1241 | "node_modules/check-error": { 1242 | "version": "1.0.3", 1243 | "resolved": "https://registry.npmjs.org/check-error/-/check-error-1.0.3.tgz", 1244 | "integrity": "sha512-iKEoDYaRmd1mxM90a2OEfWhjsjPpYPuQ+lMYsoxB126+t8fw7ySEO48nmDg5COTjxDI65/Y2OWpeEHk3ZOe8zg==", 1245 | "dev": true, 1246 | "dependencies": { 1247 | "get-func-name": "^2.0.2" 1248 | }, 1249 | "engines": { 1250 | "node": "*" 1251 | } 1252 | }, 1253 | "node_modules/clean-css": { 1254 | "version": "5.3.3", 1255 | "resolved": "https://registry.npmjs.org/clean-css/-/clean-css-5.3.3.tgz", 1256 | "integrity": "sha512-D5J+kHaVb/wKSFcyyV75uCn8fiY4sV38XJoe4CUyGQ+mOU/fMVYUdH1hJC+CJQ5uY3EnW27SbJYS4X8BiLrAFg==", 1257 | "dev": true, 1258 | "dependencies": { 1259 | "source-map": "~0.6.0" 1260 | }, 1261 | "engines": { 1262 | "node": ">= 10.0" 1263 | } 1264 | }, 1265 | "node_modules/color-convert": { 1266 | "version": "2.0.1", 1267 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 1268 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 1269 | "dev": true, 1270 | "dependencies": { 1271 | "color-name": "~1.1.4" 1272 | }, 1273 | "engines": { 1274 | "node": ">=7.0.0" 1275 | } 1276 | }, 1277 | "node_modules/color-name": { 1278 | "version": "1.1.4", 1279 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 1280 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 1281 | "dev": true 1282 | }, 1283 | "node_modules/colorette": { 1284 | "version": "2.0.20", 1285 | "resolved": "https://registry.npmjs.org/colorette/-/colorette-2.0.20.tgz", 1286 | "integrity": "sha512-IfEDxwoWIjkeXL1eXcDiow4UbKjhLdq6/EuSVR9GMN7KVH3r9gQ83e73hsz1Nd1T3ijd5xv1wcWRYO+D6kCI2w==", 1287 | "dev": true 1288 | }, 1289 | "node_modules/commander": { 1290 | "version": "8.3.0", 1291 | "resolved": "https://registry.npmjs.org/commander/-/commander-8.3.0.tgz", 1292 | "integrity": "sha512-OkTL9umf+He2DZkUq8f8J9of7yL6RJKI24dVITBmNfZBmri9zYZQrKkuXiKhyfPSu8tUhnVBB1iKXevvnlR4Ww==", 1293 | "dev": true, 1294 | "engines": { 1295 | "node": ">= 12" 1296 | } 1297 | }, 1298 | "node_modules/concat-map": { 1299 | "version": "0.0.1", 1300 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 1301 | "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==", 1302 | "dev": true 1303 | }, 1304 | "node_modules/confbox": { 1305 | "version": "0.1.7", 1306 | "resolved": "https://registry.npmjs.org/confbox/-/confbox-0.1.7.tgz", 1307 | "integrity": "sha512-uJcB/FKZtBMCJpK8MQji6bJHgu1tixKPxRLeGkNzBoOZzpnZUJm0jm2/sBDWcuBx1dYgxV4JU+g5hmNxCyAmdA==", 1308 | "dev": true 1309 | }, 1310 | "node_modules/connect-history-api-fallback": { 1311 | "version": "1.6.0", 1312 | "resolved": "https://registry.npmjs.org/connect-history-api-fallback/-/connect-history-api-fallback-1.6.0.tgz", 1313 | "integrity": "sha512-e54B99q/OUoH64zYYRf3HBP5z24G38h5D3qXu23JGRoigpX5Ss4r9ZnDk3g0Z8uQC2x2lPaJ+UlWBc1ZWBWdLg==", 1314 | "dev": true, 1315 | "engines": { 1316 | "node": ">=0.8" 1317 | } 1318 | }, 1319 | "node_modules/consola": { 1320 | "version": "2.15.3", 1321 | "resolved": "https://registry.npmjs.org/consola/-/consola-2.15.3.tgz", 1322 | "integrity": "sha512-9vAdYbHj6x2fLKC4+oPH0kFzY/orMZyG2Aj+kNylHxKGJ/Ed4dpNyAQYwJOdqO4zdM7XpVHmyejQDcQHrnuXbw==", 1323 | "dev": true 1324 | }, 1325 | "node_modules/cross-spawn": { 1326 | "version": "7.0.3", 1327 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz", 1328 | "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==", 1329 | "dev": true, 1330 | "dependencies": { 1331 | "path-key": "^3.1.0", 1332 | "shebang-command": "^2.0.0", 1333 | "which": "^2.0.1" 1334 | }, 1335 | "engines": { 1336 | "node": ">= 8" 1337 | } 1338 | }, 1339 | "node_modules/css-select": { 1340 | "version": "4.3.0", 1341 | "resolved": "https://registry.npmjs.org/css-select/-/css-select-4.3.0.tgz", 1342 | "integrity": "sha512-wPpOYtnsVontu2mODhA19JrqWxNsfdatRKd64kmpRbQgh1KtItko5sTnEpPdpSaJszTOhEMlF/RPz28qj4HqhQ==", 1343 | "dev": true, 1344 | "dependencies": { 1345 | "boolbase": "^1.0.0", 1346 | "css-what": "^6.0.1", 1347 | "domhandler": "^4.3.1", 1348 | "domutils": "^2.8.0", 1349 | "nth-check": "^2.0.1" 1350 | }, 1351 | "funding": { 1352 | "url": "https://github.com/sponsors/fb55" 1353 | } 1354 | }, 1355 | "node_modules/css-what": { 1356 | "version": "6.1.0", 1357 | "resolved": "https://registry.npmjs.org/css-what/-/css-what-6.1.0.tgz", 1358 | "integrity": "sha512-HTUrgRJ7r4dsZKU6GjmpfRK1O76h97Z8MfS1G0FozR+oF2kG6Vfe8JE6zwrkbxigziPHinCJ+gCPjA9EaBDtRw==", 1359 | "dev": true, 1360 | "engines": { 1361 | "node": ">= 6" 1362 | }, 1363 | "funding": { 1364 | "url": "https://github.com/sponsors/fb55" 1365 | } 1366 | }, 1367 | "node_modules/debug": { 1368 | "version": "4.3.4", 1369 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", 1370 | "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", 1371 | "dev": true, 1372 | "dependencies": { 1373 | "ms": "2.1.2" 1374 | }, 1375 | "engines": { 1376 | "node": ">=6.0" 1377 | }, 1378 | "peerDependenciesMeta": { 1379 | "supports-color": { 1380 | "optional": true 1381 | } 1382 | } 1383 | }, 1384 | "node_modules/deep-eql": { 1385 | "version": "4.1.3", 1386 | "resolved": "https://registry.npmjs.org/deep-eql/-/deep-eql-4.1.3.tgz", 1387 | "integrity": "sha512-WaEtAOpRA1MQ0eohqZjpGD8zdI0Ovsm8mmFhaDN8dvDZzyoUMcYDnf5Y6iu7HTXxf8JDS23qWa4a+hKCDyOPzw==", 1388 | "dev": true, 1389 | "dependencies": { 1390 | "type-detect": "^4.0.0" 1391 | }, 1392 | "engines": { 1393 | "node": ">=6" 1394 | } 1395 | }, 1396 | "node_modules/diff-sequences": { 1397 | "version": "29.6.3", 1398 | "resolved": "https://registry.npmjs.org/diff-sequences/-/diff-sequences-29.6.3.tgz", 1399 | "integrity": "sha512-EjePK1srD3P08o2j4f0ExnylqRs5B9tJjcp9t1krH2qRi8CCdsYfwe9JgSLurFBWwq4uOlipzfk5fHNvwFKr8Q==", 1400 | "dev": true, 1401 | "engines": { 1402 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 1403 | } 1404 | }, 1405 | "node_modules/dom-serializer": { 1406 | "version": "1.4.1", 1407 | "resolved": "https://registry.npmjs.org/dom-serializer/-/dom-serializer-1.4.1.tgz", 1408 | "integrity": "sha512-VHwB3KfrcOOkelEG2ZOfxqLZdfkil8PtJi4P8N2MMXucZq2yLp75ClViUlOVwyoHEDjYU433Aq+5zWP61+RGag==", 1409 | "dev": true, 1410 | "dependencies": { 1411 | "domelementtype": "^2.0.1", 1412 | "domhandler": "^4.2.0", 1413 | "entities": "^2.0.0" 1414 | }, 1415 | "funding": { 1416 | "url": "https://github.com/cheeriojs/dom-serializer?sponsor=1" 1417 | } 1418 | }, 1419 | "node_modules/dom-serializer/node_modules/entities": { 1420 | "version": "2.2.0", 1421 | "resolved": "https://registry.npmjs.org/entities/-/entities-2.2.0.tgz", 1422 | "integrity": "sha512-p92if5Nz619I0w+akJrLZH0MX0Pb5DX39XOwQTtXSdQQOaYH03S1uIQp4mhOZtAXrxq4ViO67YTiLBo2638o9A==", 1423 | "dev": true, 1424 | "funding": { 1425 | "url": "https://github.com/fb55/entities?sponsor=1" 1426 | } 1427 | }, 1428 | "node_modules/domelementtype": { 1429 | "version": "2.3.0", 1430 | "resolved": "https://registry.npmjs.org/domelementtype/-/domelementtype-2.3.0.tgz", 1431 | "integrity": "sha512-OLETBj6w0OsagBwdXnPdN0cnMfF9opN69co+7ZrbfPGrdpPVNBUj02spi6B1N7wChLQiPn4CSH/zJvXw56gmHw==", 1432 | "dev": true, 1433 | "funding": [ 1434 | { 1435 | "type": "github", 1436 | "url": "https://github.com/sponsors/fb55" 1437 | } 1438 | ] 1439 | }, 1440 | "node_modules/domhandler": { 1441 | "version": "4.3.1", 1442 | "resolved": "https://registry.npmjs.org/domhandler/-/domhandler-4.3.1.tgz", 1443 | "integrity": "sha512-GrwoxYN+uWlzO8uhUXRl0P+kHE4GtVPfYzVLcUxPL7KNdHKj66vvlhiweIHqYYXWlw+T8iLMp42Lm67ghw4WMQ==", 1444 | "dev": true, 1445 | "dependencies": { 1446 | "domelementtype": "^2.2.0" 1447 | }, 1448 | "engines": { 1449 | "node": ">= 4" 1450 | }, 1451 | "funding": { 1452 | "url": "https://github.com/fb55/domhandler?sponsor=1" 1453 | } 1454 | }, 1455 | "node_modules/domutils": { 1456 | "version": "2.8.0", 1457 | "resolved": "https://registry.npmjs.org/domutils/-/domutils-2.8.0.tgz", 1458 | "integrity": "sha512-w96Cjofp72M5IIhpjgobBimYEfoPjx1Vx0BSX9P30WBdZW2WIKU0T1Bd0kz2eNZ9ikjKgHbEyKx8BB6H1L3h3A==", 1459 | "dev": true, 1460 | "dependencies": { 1461 | "dom-serializer": "^1.0.1", 1462 | "domelementtype": "^2.2.0", 1463 | "domhandler": "^4.2.0" 1464 | }, 1465 | "funding": { 1466 | "url": "https://github.com/fb55/domutils?sponsor=1" 1467 | } 1468 | }, 1469 | "node_modules/dot-case": { 1470 | "version": "3.0.4", 1471 | "resolved": "https://registry.npmjs.org/dot-case/-/dot-case-3.0.4.tgz", 1472 | "integrity": "sha512-Kv5nKlh6yRrdrGvxeJ2e5y2eRUpkUosIW4A2AS38zwSz27zu7ufDwQPi5Jhs3XAlGNetl3bmnGhQsMtkKJnj3w==", 1473 | "dev": true, 1474 | "dependencies": { 1475 | "no-case": "^3.0.4", 1476 | "tslib": "^2.0.3" 1477 | } 1478 | }, 1479 | "node_modules/dotenv": { 1480 | "version": "16.4.5", 1481 | "resolved": "https://registry.npmjs.org/dotenv/-/dotenv-16.4.5.tgz", 1482 | "integrity": "sha512-ZmdL2rui+eB2YwhsWzjInR8LldtZHGDoQ1ugH85ppHKwpUHL7j7rN0Ti9NCnGiQbhaZ11FpR+7ao1dNsmduNUg==", 1483 | "dev": true, 1484 | "engines": { 1485 | "node": ">=12" 1486 | }, 1487 | "funding": { 1488 | "url": "https://dotenvx.com" 1489 | } 1490 | }, 1491 | "node_modules/dotenv-expand": { 1492 | "version": "8.0.3", 1493 | "resolved": "https://registry.npmjs.org/dotenv-expand/-/dotenv-expand-8.0.3.tgz", 1494 | "integrity": "sha512-SErOMvge0ZUyWd5B0NXMQlDkN+8r+HhVUsxgOO7IoPDOdDRD2JjExpN6y3KnFR66jsJMwSn1pqIivhU5rcJiNg==", 1495 | "dev": true, 1496 | "engines": { 1497 | "node": ">=12" 1498 | } 1499 | }, 1500 | "node_modules/ejs": { 1501 | "version": "3.1.10", 1502 | "resolved": "https://registry.npmjs.org/ejs/-/ejs-3.1.10.tgz", 1503 | "integrity": "sha512-UeJmFfOrAQS8OJWPZ4qtgHyWExa088/MtK5UEyoJGFH67cDEXkZSviOiKRCZ4Xij0zxI3JECgYs3oKx+AizQBA==", 1504 | "dev": true, 1505 | "dependencies": { 1506 | "jake": "^10.8.5" 1507 | }, 1508 | "bin": { 1509 | "ejs": "bin/cli.js" 1510 | }, 1511 | "engines": { 1512 | "node": ">=0.10.0" 1513 | } 1514 | }, 1515 | "node_modules/entities": { 1516 | "version": "4.5.0", 1517 | "resolved": "https://registry.npmjs.org/entities/-/entities-4.5.0.tgz", 1518 | "integrity": "sha512-V0hjH4dGPh9Ao5p0MoRY6BVqtwCjhz6vI5LT8AJ55H+4g9/4vbHx1I54fS0XuclLhDHArPQCiMjDxjaL8fPxhw==", 1519 | "dev": true, 1520 | "engines": { 1521 | "node": ">=0.12" 1522 | }, 1523 | "funding": { 1524 | "url": "https://github.com/fb55/entities?sponsor=1" 1525 | } 1526 | }, 1527 | "node_modules/esbuild": { 1528 | "version": "0.21.5", 1529 | "resolved": "https://registry.npmjs.org/esbuild/-/esbuild-0.21.5.tgz", 1530 | "integrity": "sha512-mg3OPMV4hXywwpoDxu3Qda5xCKQi+vCTZq8S9J/EpkhB2HzKXq4SNFZE3+NK93JYxc8VMSep+lOUSC/RVKaBqw==", 1531 | "dev": true, 1532 | "hasInstallScript": true, 1533 | "bin": { 1534 | "esbuild": "bin/esbuild" 1535 | }, 1536 | "engines": { 1537 | "node": ">=12" 1538 | }, 1539 | "optionalDependencies": { 1540 | "@esbuild/aix-ppc64": "0.21.5", 1541 | "@esbuild/android-arm": "0.21.5", 1542 | "@esbuild/android-arm64": "0.21.5", 1543 | "@esbuild/android-x64": "0.21.5", 1544 | "@esbuild/darwin-arm64": "0.21.5", 1545 | "@esbuild/darwin-x64": "0.21.5", 1546 | "@esbuild/freebsd-arm64": "0.21.5", 1547 | "@esbuild/freebsd-x64": "0.21.5", 1548 | "@esbuild/linux-arm": "0.21.5", 1549 | "@esbuild/linux-arm64": "0.21.5", 1550 | "@esbuild/linux-ia32": "0.21.5", 1551 | "@esbuild/linux-loong64": "0.21.5", 1552 | "@esbuild/linux-mips64el": "0.21.5", 1553 | "@esbuild/linux-ppc64": "0.21.5", 1554 | "@esbuild/linux-riscv64": "0.21.5", 1555 | "@esbuild/linux-s390x": "0.21.5", 1556 | "@esbuild/linux-x64": "0.21.5", 1557 | "@esbuild/netbsd-x64": "0.21.5", 1558 | "@esbuild/openbsd-x64": "0.21.5", 1559 | "@esbuild/sunos-x64": "0.21.5", 1560 | "@esbuild/win32-arm64": "0.21.5", 1561 | "@esbuild/win32-ia32": "0.21.5", 1562 | "@esbuild/win32-x64": "0.21.5" 1563 | } 1564 | }, 1565 | "node_modules/estree-walker": { 1566 | "version": "2.0.2", 1567 | "resolved": "https://registry.npmjs.org/estree-walker/-/estree-walker-2.0.2.tgz", 1568 | "integrity": "sha512-Rfkk/Mp/DL7JVje3u18FxFujQlTNR2q6QfMSMB7AvCBx91NGj/ba3kCfza0f6dVDbw7YlRf/nDrn7pQrCCyQ/w==", 1569 | "dev": true 1570 | }, 1571 | "node_modules/execa": { 1572 | "version": "8.0.1", 1573 | "resolved": "https://registry.npmjs.org/execa/-/execa-8.0.1.tgz", 1574 | "integrity": "sha512-VyhnebXciFV2DESc+p6B+y0LjSm0krU4OgJN44qFAhBY0TJ+1V61tYD2+wHusZ6F9n5K+vl8k0sTy7PEfV4qpg==", 1575 | "dev": true, 1576 | "dependencies": { 1577 | "cross-spawn": "^7.0.3", 1578 | "get-stream": "^8.0.1", 1579 | "human-signals": "^5.0.0", 1580 | "is-stream": "^3.0.0", 1581 | "merge-stream": "^2.0.0", 1582 | "npm-run-path": "^5.1.0", 1583 | "onetime": "^6.0.0", 1584 | "signal-exit": "^4.1.0", 1585 | "strip-final-newline": "^3.0.0" 1586 | }, 1587 | "engines": { 1588 | "node": ">=16.17" 1589 | }, 1590 | "funding": { 1591 | "url": "https://github.com/sindresorhus/execa?sponsor=1" 1592 | } 1593 | }, 1594 | "node_modules/fast-glob": { 1595 | "version": "3.3.2", 1596 | "resolved": "https://registry.npmjs.org/fast-glob/-/fast-glob-3.3.2.tgz", 1597 | "integrity": "sha512-oX2ruAFQwf/Orj8m737Y5adxDQO0LAB7/S5MnxCdTNDd4p6BsyIVsv9JQsATbTSq8KHRpLwIHbVlUNatxd+1Ow==", 1598 | "dev": true, 1599 | "dependencies": { 1600 | "@nodelib/fs.stat": "^2.0.2", 1601 | "@nodelib/fs.walk": "^1.2.3", 1602 | "glob-parent": "^5.1.2", 1603 | "merge2": "^1.3.0", 1604 | "micromatch": "^4.0.4" 1605 | }, 1606 | "engines": { 1607 | "node": ">=8.6.0" 1608 | } 1609 | }, 1610 | "node_modules/fastq": { 1611 | "version": "1.17.1", 1612 | "resolved": "https://registry.npmjs.org/fastq/-/fastq-1.17.1.tgz", 1613 | "integrity": "sha512-sRVD3lWVIXWg6By68ZN7vho9a1pQcN/WBFaAAsDDFzlJjvoGx0P8z7V1t72grFJfJhu3YPZBuu25f7Kaw2jN1w==", 1614 | "dev": true, 1615 | "dependencies": { 1616 | "reusify": "^1.0.4" 1617 | } 1618 | }, 1619 | "node_modules/filelist": { 1620 | "version": "1.0.4", 1621 | "resolved": "https://registry.npmjs.org/filelist/-/filelist-1.0.4.tgz", 1622 | "integrity": "sha512-w1cEuf3S+DrLCQL7ET6kz+gmlJdbq9J7yXCSjK/OZCPA+qEN1WyF4ZAf0YYJa4/shHJra2t/d/r8SV4Ji+x+8Q==", 1623 | "dev": true, 1624 | "dependencies": { 1625 | "minimatch": "^5.0.1" 1626 | } 1627 | }, 1628 | "node_modules/filelist/node_modules/brace-expansion": { 1629 | "version": "2.0.1", 1630 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-2.0.1.tgz", 1631 | "integrity": "sha512-XnAIvQ8eM+kC6aULx6wuQiwVsnzsi9d3WxzV3FpWTGA19F621kwdbsAcFKXgKUHZWsy+mY6iL1sHTxWEFCytDA==", 1632 | "dev": true, 1633 | "dependencies": { 1634 | "balanced-match": "^1.0.0" 1635 | } 1636 | }, 1637 | "node_modules/filelist/node_modules/minimatch": { 1638 | "version": "5.1.6", 1639 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-5.1.6.tgz", 1640 | "integrity": "sha512-lKwV/1brpG6mBUFHtb7NUmtABCb2WZZmm2wNiOA5hAb8VdCS4B3dtMWyvcoViccwAW/COERjXLt0zP1zXUN26g==", 1641 | "dev": true, 1642 | "dependencies": { 1643 | "brace-expansion": "^2.0.1" 1644 | }, 1645 | "engines": { 1646 | "node": ">=10" 1647 | } 1648 | }, 1649 | "node_modules/fill-range": { 1650 | "version": "7.1.1", 1651 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.1.1.tgz", 1652 | "integrity": "sha512-YsGpe3WHLK8ZYi4tWDg2Jy3ebRz2rXowDxnld4bkQB00cc/1Zw9AWnC0i9ztDJitivtQvaI9KaLyKrc+hBW0yg==", 1653 | "dev": true, 1654 | "dependencies": { 1655 | "to-regex-range": "^5.0.1" 1656 | }, 1657 | "engines": { 1658 | "node": ">=8" 1659 | } 1660 | }, 1661 | "node_modules/fs-extra": { 1662 | "version": "10.1.0", 1663 | "resolved": "https://registry.npmjs.org/fs-extra/-/fs-extra-10.1.0.tgz", 1664 | "integrity": "sha512-oRXApq54ETRj4eMiFzGnHWGy+zo5raudjuxN0b8H7s/RU2oW0Wvsx9O0ACRN/kRq9E8Vu/ReskGB5o3ji+FzHQ==", 1665 | "dev": true, 1666 | "dependencies": { 1667 | "graceful-fs": "^4.2.0", 1668 | "jsonfile": "^6.0.1", 1669 | "universalify": "^2.0.0" 1670 | }, 1671 | "engines": { 1672 | "node": ">=12" 1673 | } 1674 | }, 1675 | "node_modules/fs.realpath": { 1676 | "version": "1.0.0", 1677 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 1678 | "integrity": "sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw==", 1679 | "dev": true 1680 | }, 1681 | "node_modules/fsevents": { 1682 | "version": "2.3.3", 1683 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.3.tgz", 1684 | "integrity": "sha512-5xoDfX+fL7faATnagmWPpbFtwh/R77WmMMqqHGS65C3vvB0YHrgF+B1YmZ3441tMj5n63k0212XNoJwzlhffQw==", 1685 | "dev": true, 1686 | "hasInstallScript": true, 1687 | "optional": true, 1688 | "os": [ 1689 | "darwin" 1690 | ], 1691 | "engines": { 1692 | "node": "^8.16.0 || ^10.6.0 || >=11.0.0" 1693 | } 1694 | }, 1695 | "node_modules/get-func-name": { 1696 | "version": "2.0.2", 1697 | "resolved": "https://registry.npmjs.org/get-func-name/-/get-func-name-2.0.2.tgz", 1698 | "integrity": "sha512-8vXOvuE167CtIc3OyItco7N/dpRtBbYOsPsXCz7X/PMnlGjYjSGuZJgM1Y7mmew7BKf9BqvLX2tnOVy1BBUsxQ==", 1699 | "dev": true, 1700 | "engines": { 1701 | "node": "*" 1702 | } 1703 | }, 1704 | "node_modules/get-stream": { 1705 | "version": "8.0.1", 1706 | "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-8.0.1.tgz", 1707 | "integrity": "sha512-VaUJspBffn/LMCJVoMvSAdmscJyS1auj5Zulnn5UoYcY531UWmdwhRWkcGKnGU93m5HSXP9LP2usOryrBtQowA==", 1708 | "dev": true, 1709 | "engines": { 1710 | "node": ">=16" 1711 | }, 1712 | "funding": { 1713 | "url": "https://github.com/sponsors/sindresorhus" 1714 | } 1715 | }, 1716 | "node_modules/glob": { 1717 | "version": "7.2.3", 1718 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.3.tgz", 1719 | "integrity": "sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q==", 1720 | "deprecated": "Glob versions prior to v9 are no longer supported", 1721 | "dev": true, 1722 | "dependencies": { 1723 | "fs.realpath": "^1.0.0", 1724 | "inflight": "^1.0.4", 1725 | "inherits": "2", 1726 | "minimatch": "^3.1.1", 1727 | "once": "^1.3.0", 1728 | "path-is-absolute": "^1.0.0" 1729 | }, 1730 | "engines": { 1731 | "node": "*" 1732 | }, 1733 | "funding": { 1734 | "url": "https://github.com/sponsors/isaacs" 1735 | } 1736 | }, 1737 | "node_modules/glob-parent": { 1738 | "version": "5.1.2", 1739 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", 1740 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", 1741 | "dev": true, 1742 | "dependencies": { 1743 | "is-glob": "^4.0.1" 1744 | }, 1745 | "engines": { 1746 | "node": ">= 6" 1747 | } 1748 | }, 1749 | "node_modules/graceful-fs": { 1750 | "version": "4.2.11", 1751 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.11.tgz", 1752 | "integrity": "sha512-RbJ5/jmFcNNCcDV5o9eTnBLJ/HszWV0P73bc+Ff4nS/rJj+YaS6IGyiOL0VoBYX+l1Wrl3k63h/KrH+nhJ0XvQ==", 1753 | "dev": true 1754 | }, 1755 | "node_modules/happy-dom": { 1756 | "version": "15.10.2", 1757 | "resolved": "https://registry.npmjs.org/happy-dom/-/happy-dom-15.10.2.tgz", 1758 | "integrity": "sha512-NbA5XrSovenJIIcfixCREX3ZnV7yHP4phhbfuxxf4CPn+LZpz/jIM9EqJ2DrPwgVDSMoAKH3pZwQvkbsSiCrUw==", 1759 | "dev": true, 1760 | "dependencies": { 1761 | "entities": "^4.5.0", 1762 | "webidl-conversions": "^7.0.0", 1763 | "whatwg-mimetype": "^3.0.0" 1764 | }, 1765 | "engines": { 1766 | "node": ">=18.0.0" 1767 | } 1768 | }, 1769 | "node_modules/has-flag": { 1770 | "version": "4.0.0", 1771 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 1772 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 1773 | "dev": true, 1774 | "engines": { 1775 | "node": ">=8" 1776 | } 1777 | }, 1778 | "node_modules/he": { 1779 | "version": "1.2.0", 1780 | "resolved": "https://registry.npmjs.org/he/-/he-1.2.0.tgz", 1781 | "integrity": "sha512-F/1DnUGPopORZi0ni+CvrCgHQ5FyEAHRLSApuYWMmrbSwoN2Mn/7k+Gl38gJnR7yyDZk6WLXwiGod1JOWNDKGw==", 1782 | "dev": true, 1783 | "bin": { 1784 | "he": "bin/he" 1785 | } 1786 | }, 1787 | "node_modules/html-escaper": { 1788 | "version": "2.0.2", 1789 | "resolved": "https://registry.npmjs.org/html-escaper/-/html-escaper-2.0.2.tgz", 1790 | "integrity": "sha512-H2iMtd0I4Mt5eYiapRdIDjp+XzelXQ0tFE4JS7YFwFevXXMmOp9myNrUvCg0D6ws8iqkRPBfKHgbwig1SmlLfg==", 1791 | "dev": true 1792 | }, 1793 | "node_modules/html-minifier-terser": { 1794 | "version": "6.1.0", 1795 | "resolved": "https://registry.npmjs.org/html-minifier-terser/-/html-minifier-terser-6.1.0.tgz", 1796 | "integrity": "sha512-YXxSlJBZTP7RS3tWnQw74ooKa6L9b9i9QYXY21eUEvhZ3u9XLfv6OnFsQq6RxkhHygsaUMvYsZRV5rU/OVNZxw==", 1797 | "dev": true, 1798 | "dependencies": { 1799 | "camel-case": "^4.1.2", 1800 | "clean-css": "^5.2.2", 1801 | "commander": "^8.3.0", 1802 | "he": "^1.2.0", 1803 | "param-case": "^3.0.4", 1804 | "relateurl": "^0.2.7", 1805 | "terser": "^5.10.0" 1806 | }, 1807 | "bin": { 1808 | "html-minifier-terser": "cli.js" 1809 | }, 1810 | "engines": { 1811 | "node": ">=12" 1812 | } 1813 | }, 1814 | "node_modules/human-signals": { 1815 | "version": "5.0.0", 1816 | "resolved": "https://registry.npmjs.org/human-signals/-/human-signals-5.0.0.tgz", 1817 | "integrity": "sha512-AXcZb6vzzrFAUE61HnN4mpLqd/cSIwNQjtNWR0euPm6y0iqx3G4gOXaIDdtdDwZmhwe82LA6+zinmW4UBWVePQ==", 1818 | "dev": true, 1819 | "engines": { 1820 | "node": ">=16.17.0" 1821 | } 1822 | }, 1823 | "node_modules/inflight": { 1824 | "version": "1.0.6", 1825 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 1826 | "integrity": "sha512-k92I/b08q4wvFscXCLvqfsHCrjrF7yiXsQuIVvVE7N82W3+aqpzuUdBbfhWcy/FZR3/4IgflMgKLOsvPDrGCJA==", 1827 | "deprecated": "This module is not supported, and leaks memory. Do not use it. Check out lru-cache if you want a good and tested way to coalesce async requests by a key value, which is much more comprehensive and powerful.", 1828 | "dev": true, 1829 | "dependencies": { 1830 | "once": "^1.3.0", 1831 | "wrappy": "1" 1832 | } 1833 | }, 1834 | "node_modules/inherits": { 1835 | "version": "2.0.4", 1836 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 1837 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", 1838 | "dev": true 1839 | }, 1840 | "node_modules/is-extglob": { 1841 | "version": "2.1.1", 1842 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 1843 | "integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==", 1844 | "dev": true, 1845 | "engines": { 1846 | "node": ">=0.10.0" 1847 | } 1848 | }, 1849 | "node_modules/is-glob": { 1850 | "version": "4.0.3", 1851 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", 1852 | "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", 1853 | "dev": true, 1854 | "dependencies": { 1855 | "is-extglob": "^2.1.1" 1856 | }, 1857 | "engines": { 1858 | "node": ">=0.10.0" 1859 | } 1860 | }, 1861 | "node_modules/is-number": { 1862 | "version": "7.0.0", 1863 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 1864 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", 1865 | "dev": true, 1866 | "engines": { 1867 | "node": ">=0.12.0" 1868 | } 1869 | }, 1870 | "node_modules/is-stream": { 1871 | "version": "3.0.0", 1872 | "resolved": "https://registry.npmjs.org/is-stream/-/is-stream-3.0.0.tgz", 1873 | "integrity": "sha512-LnQR4bZ9IADDRSkvpqMGvt/tEJWclzklNgSw48V5EAaAeDd6qGvN8ei6k5p0tvxSR171VmGyHuTiAOfxAbr8kA==", 1874 | "dev": true, 1875 | "engines": { 1876 | "node": "^12.20.0 || ^14.13.1 || >=16.0.0" 1877 | }, 1878 | "funding": { 1879 | "url": "https://github.com/sponsors/sindresorhus" 1880 | } 1881 | }, 1882 | "node_modules/isexe": { 1883 | "version": "2.0.0", 1884 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 1885 | "integrity": "sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw==", 1886 | "dev": true 1887 | }, 1888 | "node_modules/istanbul-lib-coverage": { 1889 | "version": "3.2.2", 1890 | "resolved": "https://registry.npmjs.org/istanbul-lib-coverage/-/istanbul-lib-coverage-3.2.2.tgz", 1891 | "integrity": "sha512-O8dpsF+r0WV/8MNRKfnmrtCWhuKjxrq2w+jpzBL5UZKTi2LeVWnWOmWRxFlesJONmc+wLAGvKQZEOanko0LFTg==", 1892 | "dev": true, 1893 | "engines": { 1894 | "node": ">=8" 1895 | } 1896 | }, 1897 | "node_modules/istanbul-lib-report": { 1898 | "version": "3.0.1", 1899 | "resolved": "https://registry.npmjs.org/istanbul-lib-report/-/istanbul-lib-report-3.0.1.tgz", 1900 | "integrity": "sha512-GCfE1mtsHGOELCU8e/Z7YWzpmybrx/+dSTfLrvY8qRmaY6zXTKWn6WQIjaAFw069icm6GVMNkgu0NzI4iPZUNw==", 1901 | "dev": true, 1902 | "dependencies": { 1903 | "istanbul-lib-coverage": "^3.0.0", 1904 | "make-dir": "^4.0.0", 1905 | "supports-color": "^7.1.0" 1906 | }, 1907 | "engines": { 1908 | "node": ">=10" 1909 | } 1910 | }, 1911 | "node_modules/istanbul-lib-source-maps": { 1912 | "version": "5.0.4", 1913 | "resolved": "https://registry.npmjs.org/istanbul-lib-source-maps/-/istanbul-lib-source-maps-5.0.4.tgz", 1914 | "integrity": "sha512-wHOoEsNJTVltaJp8eVkm8w+GVkVNHT2YDYo53YdzQEL2gWm1hBX5cGFR9hQJtuGLebidVX7et3+dmDZrmclduw==", 1915 | "dev": true, 1916 | "dependencies": { 1917 | "@jridgewell/trace-mapping": "^0.3.23", 1918 | "debug": "^4.1.1", 1919 | "istanbul-lib-coverage": "^3.0.0" 1920 | }, 1921 | "engines": { 1922 | "node": ">=10" 1923 | } 1924 | }, 1925 | "node_modules/istanbul-reports": { 1926 | "version": "3.1.7", 1927 | "resolved": "https://registry.npmjs.org/istanbul-reports/-/istanbul-reports-3.1.7.tgz", 1928 | "integrity": "sha512-BewmUXImeuRk2YY0PVbxgKAysvhRPUQE0h5QRM++nVWyubKGV0l8qQ5op8+B2DOmwSe63Jivj0BjkPQVf8fP5g==", 1929 | "dev": true, 1930 | "dependencies": { 1931 | "html-escaper": "^2.0.0", 1932 | "istanbul-lib-report": "^3.0.0" 1933 | }, 1934 | "engines": { 1935 | "node": ">=8" 1936 | } 1937 | }, 1938 | "node_modules/jake": { 1939 | "version": "10.9.1", 1940 | "resolved": "https://registry.npmjs.org/jake/-/jake-10.9.1.tgz", 1941 | "integrity": "sha512-61btcOHNnLnsOdtLgA5efqQWjnSi/vow5HbI7HMdKKWqvrKR1bLK3BPlJn9gcSaP2ewuamUSMB5XEy76KUIS2w==", 1942 | "dev": true, 1943 | "dependencies": { 1944 | "async": "^3.2.3", 1945 | "chalk": "^4.0.2", 1946 | "filelist": "^1.0.4", 1947 | "minimatch": "^3.1.2" 1948 | }, 1949 | "bin": { 1950 | "jake": "bin/cli.js" 1951 | }, 1952 | "engines": { 1953 | "node": ">=10" 1954 | } 1955 | }, 1956 | "node_modules/js-tokens": { 1957 | "version": "9.0.0", 1958 | "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-9.0.0.tgz", 1959 | "integrity": "sha512-WriZw1luRMlmV3LGJaR6QOJjWwgLUTf89OwT2lUOyjX2dJGBwgmIkbcz+7WFZjrZM635JOIR517++e/67CP9dQ==", 1960 | "dev": true 1961 | }, 1962 | "node_modules/jsonfile": { 1963 | "version": "6.1.0", 1964 | "resolved": "https://registry.npmjs.org/jsonfile/-/jsonfile-6.1.0.tgz", 1965 | "integrity": "sha512-5dgndWOriYSm5cnYaJNhalLNDKOqFwyDB/rr1E9ZsGciGvKPs8R2xYGCacuf3z6K1YKDz182fd+fY3cn3pMqXQ==", 1966 | "dev": true, 1967 | "dependencies": { 1968 | "universalify": "^2.0.0" 1969 | }, 1970 | "optionalDependencies": { 1971 | "graceful-fs": "^4.1.6" 1972 | } 1973 | }, 1974 | "node_modules/local-pkg": { 1975 | "version": "0.5.0", 1976 | "resolved": "https://registry.npmjs.org/local-pkg/-/local-pkg-0.5.0.tgz", 1977 | "integrity": "sha512-ok6z3qlYyCDS4ZEU27HaU6x/xZa9Whf8jD4ptH5UZTQYZVYeb9bnZ3ojVhiJNLiXK1Hfc0GNbLXcmZ5plLDDBg==", 1978 | "dev": true, 1979 | "dependencies": { 1980 | "mlly": "^1.4.2", 1981 | "pkg-types": "^1.0.3" 1982 | }, 1983 | "engines": { 1984 | "node": ">=14" 1985 | }, 1986 | "funding": { 1987 | "url": "https://github.com/sponsors/antfu" 1988 | } 1989 | }, 1990 | "node_modules/loupe": { 1991 | "version": "2.3.7", 1992 | "resolved": "https://registry.npmjs.org/loupe/-/loupe-2.3.7.tgz", 1993 | "integrity": "sha512-zSMINGVYkdpYSOBmLi0D1Uo7JU9nVdQKrHxC8eYlV+9YKK9WePqAlL7lSlorG/U2Fw1w0hTBmaa/jrQ3UbPHtA==", 1994 | "dev": true, 1995 | "dependencies": { 1996 | "get-func-name": "^2.0.1" 1997 | } 1998 | }, 1999 | "node_modules/lower-case": { 2000 | "version": "2.0.2", 2001 | "resolved": "https://registry.npmjs.org/lower-case/-/lower-case-2.0.2.tgz", 2002 | "integrity": "sha512-7fm3l3NAF9WfN6W3JOmf5drwpVqX78JtoGJ3A6W0a6ZnldM41w2fV5D490psKFTpMds8TJse/eHLFFsNHHjHgg==", 2003 | "dev": true, 2004 | "dependencies": { 2005 | "tslib": "^2.0.3" 2006 | } 2007 | }, 2008 | "node_modules/magic-string": { 2009 | "version": "0.30.10", 2010 | "resolved": "https://registry.npmjs.org/magic-string/-/magic-string-0.30.10.tgz", 2011 | "integrity": "sha512-iIRwTIf0QKV3UAnYK4PU8uiEc4SRh5jX0mwpIwETPpHdhVM4f53RSwS/vXvN1JhGX+Cs7B8qIq3d6AH49O5fAQ==", 2012 | "dev": true, 2013 | "dependencies": { 2014 | "@jridgewell/sourcemap-codec": "^1.4.15" 2015 | } 2016 | }, 2017 | "node_modules/magicast": { 2018 | "version": "0.3.4", 2019 | "resolved": "https://registry.npmjs.org/magicast/-/magicast-0.3.4.tgz", 2020 | "integrity": "sha512-TyDF/Pn36bBji9rWKHlZe+PZb6Mx5V8IHCSxk7X4aljM4e/vyDvZZYwHewdVaqiA0nb3ghfHU/6AUpDxWoER2Q==", 2021 | "dev": true, 2022 | "dependencies": { 2023 | "@babel/parser": "^7.24.4", 2024 | "@babel/types": "^7.24.0", 2025 | "source-map-js": "^1.2.0" 2026 | } 2027 | }, 2028 | "node_modules/make-dir": { 2029 | "version": "4.0.0", 2030 | "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-4.0.0.tgz", 2031 | "integrity": "sha512-hXdUTZYIVOt1Ex//jAQi+wTZZpUpwBj/0QsOzqegb3rGMMeJiSEu5xLHnYfBrRV4RH2+OCSOO95Is/7x1WJ4bw==", 2032 | "dev": true, 2033 | "dependencies": { 2034 | "semver": "^7.5.3" 2035 | }, 2036 | "engines": { 2037 | "node": ">=10" 2038 | }, 2039 | "funding": { 2040 | "url": "https://github.com/sponsors/sindresorhus" 2041 | } 2042 | }, 2043 | "node_modules/merge-stream": { 2044 | "version": "2.0.0", 2045 | "resolved": "https://registry.npmjs.org/merge-stream/-/merge-stream-2.0.0.tgz", 2046 | "integrity": "sha512-abv/qOcuPfk3URPfDzmZU1LKmuw8kT+0nIHvKrKgFrwifol/doWcdA4ZqsWQ8ENrFKkd67Mfpo/LovbIUsbt3w==", 2047 | "dev": true 2048 | }, 2049 | "node_modules/merge2": { 2050 | "version": "1.4.1", 2051 | "resolved": "https://registry.npmjs.org/merge2/-/merge2-1.4.1.tgz", 2052 | "integrity": "sha512-8q7VEgMJW4J8tcfVPy8g09NcQwZdbwFEqhe/WZkoIzjn/3TGDwtOCYtXGxA3O8tPzpczCCDgv+P2P5y00ZJOOg==", 2053 | "dev": true, 2054 | "engines": { 2055 | "node": ">= 8" 2056 | } 2057 | }, 2058 | "node_modules/micromatch": { 2059 | "version": "4.0.7", 2060 | "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-4.0.7.tgz", 2061 | "integrity": "sha512-LPP/3KorzCwBxfeUuZmaR6bG2kdeHSbe0P2tY3FLRU4vYrjYz5hI4QZwV0njUx3jeuKe67YukQ1LSPZBKDqO/Q==", 2062 | "dev": true, 2063 | "dependencies": { 2064 | "braces": "^3.0.3", 2065 | "picomatch": "^2.3.1" 2066 | }, 2067 | "engines": { 2068 | "node": ">=8.6" 2069 | } 2070 | }, 2071 | "node_modules/mimic-fn": { 2072 | "version": "4.0.0", 2073 | "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-4.0.0.tgz", 2074 | "integrity": "sha512-vqiC06CuhBTUdZH+RYl8sFrL096vA45Ok5ISO6sE/Mr1jRbGH4Csnhi8f3wKVl7x8mO4Au7Ir9D3Oyv1VYMFJw==", 2075 | "dev": true, 2076 | "engines": { 2077 | "node": ">=12" 2078 | }, 2079 | "funding": { 2080 | "url": "https://github.com/sponsors/sindresorhus" 2081 | } 2082 | }, 2083 | "node_modules/minimatch": { 2084 | "version": "3.1.2", 2085 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", 2086 | "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", 2087 | "dev": true, 2088 | "dependencies": { 2089 | "brace-expansion": "^1.1.7" 2090 | }, 2091 | "engines": { 2092 | "node": "*" 2093 | } 2094 | }, 2095 | "node_modules/mlly": { 2096 | "version": "1.7.0", 2097 | "resolved": "https://registry.npmjs.org/mlly/-/mlly-1.7.0.tgz", 2098 | "integrity": "sha512-U9SDaXGEREBYQgfejV97coK0UL1r+qnF2SyO9A3qcI8MzKnsIFKHNVEkrDyNncQTKQQumsasmeq84eNMdBfsNQ==", 2099 | "dev": true, 2100 | "dependencies": { 2101 | "acorn": "^8.11.3", 2102 | "pathe": "^1.1.2", 2103 | "pkg-types": "^1.1.0", 2104 | "ufo": "^1.5.3" 2105 | } 2106 | }, 2107 | "node_modules/mlly/node_modules/pathe": { 2108 | "version": "1.1.2", 2109 | "resolved": "https://registry.npmjs.org/pathe/-/pathe-1.1.2.tgz", 2110 | "integrity": "sha512-whLdWMYL2TwI08hn8/ZqAbrVemu0LNaNNJZX73O6qaIdCTfXutsLhMkjdENX0qhsQ9uIimo4/aQOmXkoon2nDQ==", 2111 | "dev": true 2112 | }, 2113 | "node_modules/ms": { 2114 | "version": "2.1.2", 2115 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 2116 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 2117 | "dev": true 2118 | }, 2119 | "node_modules/nanoid": { 2120 | "version": "3.3.7", 2121 | "resolved": "https://registry.npmjs.org/nanoid/-/nanoid-3.3.7.tgz", 2122 | "integrity": "sha512-eSRppjcPIatRIMC1U6UngP8XFcz8MQWGQdt1MTBQ7NaAmvXDfvNxbvWV3x2y6CdEUciCSsDHDQZbhYaB8QEo2g==", 2123 | "dev": true, 2124 | "funding": [ 2125 | { 2126 | "type": "github", 2127 | "url": "https://github.com/sponsors/ai" 2128 | } 2129 | ], 2130 | "bin": { 2131 | "nanoid": "bin/nanoid.cjs" 2132 | }, 2133 | "engines": { 2134 | "node": "^10 || ^12 || ^13.7 || ^14 || >=15.0.1" 2135 | } 2136 | }, 2137 | "node_modules/no-case": { 2138 | "version": "3.0.4", 2139 | "resolved": "https://registry.npmjs.org/no-case/-/no-case-3.0.4.tgz", 2140 | "integrity": "sha512-fgAN3jGAh+RoxUGZHTSOLJIqUc2wmoBwGR4tbpNAKmmovFoWq0OdRkb0VkldReO2a2iBT/OEulG9XSUc10r3zg==", 2141 | "dev": true, 2142 | "dependencies": { 2143 | "lower-case": "^2.0.2", 2144 | "tslib": "^2.0.3" 2145 | } 2146 | }, 2147 | "node_modules/node-html-parser": { 2148 | "version": "5.4.2", 2149 | "resolved": "https://registry.npmjs.org/node-html-parser/-/node-html-parser-5.4.2.tgz", 2150 | "integrity": "sha512-RaBPP3+51hPne/OolXxcz89iYvQvKOydaqoePpOgXcrOKZhjVIzmpKZz+Hd/RBO2/zN2q6CNJhQzucVz+u3Jyw==", 2151 | "dev": true, 2152 | "dependencies": { 2153 | "css-select": "^4.2.1", 2154 | "he": "1.2.0" 2155 | } 2156 | }, 2157 | "node_modules/npm-run-path": { 2158 | "version": "5.3.0", 2159 | "resolved": "https://registry.npmjs.org/npm-run-path/-/npm-run-path-5.3.0.tgz", 2160 | "integrity": "sha512-ppwTtiJZq0O/ai0z7yfudtBpWIoxM8yE6nHi1X47eFR2EWORqfbu6CnPlNsjeN683eT0qG6H/Pyf9fCcvjnnnQ==", 2161 | "dev": true, 2162 | "dependencies": { 2163 | "path-key": "^4.0.0" 2164 | }, 2165 | "engines": { 2166 | "node": "^12.20.0 || ^14.13.1 || >=16.0.0" 2167 | }, 2168 | "funding": { 2169 | "url": "https://github.com/sponsors/sindresorhus" 2170 | } 2171 | }, 2172 | "node_modules/npm-run-path/node_modules/path-key": { 2173 | "version": "4.0.0", 2174 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-4.0.0.tgz", 2175 | "integrity": "sha512-haREypq7xkM7ErfgIyA0z+Bj4AGKlMSdlQE2jvJo6huWD1EdkKYV+G/T4nq0YEF2vgTT8kqMFKo1uHn950r4SQ==", 2176 | "dev": true, 2177 | "engines": { 2178 | "node": ">=12" 2179 | }, 2180 | "funding": { 2181 | "url": "https://github.com/sponsors/sindresorhus" 2182 | } 2183 | }, 2184 | "node_modules/nth-check": { 2185 | "version": "2.1.1", 2186 | "resolved": "https://registry.npmjs.org/nth-check/-/nth-check-2.1.1.tgz", 2187 | "integrity": "sha512-lqjrjmaOoAnWfMmBPL+XNnynZh2+swxiX3WUE0s4yEHI6m+AwrK2UZOimIRl3X/4QctVqS8AiZjFqyOGrMXb/w==", 2188 | "dev": true, 2189 | "dependencies": { 2190 | "boolbase": "^1.0.0" 2191 | }, 2192 | "funding": { 2193 | "url": "https://github.com/fb55/nth-check?sponsor=1" 2194 | } 2195 | }, 2196 | "node_modules/once": { 2197 | "version": "1.4.0", 2198 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 2199 | "integrity": "sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w==", 2200 | "dev": true, 2201 | "dependencies": { 2202 | "wrappy": "1" 2203 | } 2204 | }, 2205 | "node_modules/onetime": { 2206 | "version": "6.0.0", 2207 | "resolved": "https://registry.npmjs.org/onetime/-/onetime-6.0.0.tgz", 2208 | "integrity": "sha512-1FlR+gjXK7X+AsAHso35MnyN5KqGwJRi/31ft6x0M194ht7S+rWAvd7PHss9xSKMzE0asv1pyIHaJYq+BbacAQ==", 2209 | "dev": true, 2210 | "dependencies": { 2211 | "mimic-fn": "^4.0.0" 2212 | }, 2213 | "engines": { 2214 | "node": ">=12" 2215 | }, 2216 | "funding": { 2217 | "url": "https://github.com/sponsors/sindresorhus" 2218 | } 2219 | }, 2220 | "node_modules/p-limit": { 2221 | "version": "5.0.0", 2222 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-5.0.0.tgz", 2223 | "integrity": "sha512-/Eaoq+QyLSiXQ4lyYV23f14mZRQcXnxfHrN0vCai+ak9G0pp9iEQukIIZq5NccEvwRB8PUnZT0KsOoDCINS1qQ==", 2224 | "dev": true, 2225 | "dependencies": { 2226 | "yocto-queue": "^1.0.0" 2227 | }, 2228 | "engines": { 2229 | "node": ">=18" 2230 | }, 2231 | "funding": { 2232 | "url": "https://github.com/sponsors/sindresorhus" 2233 | } 2234 | }, 2235 | "node_modules/param-case": { 2236 | "version": "3.0.4", 2237 | "resolved": "https://registry.npmjs.org/param-case/-/param-case-3.0.4.tgz", 2238 | "integrity": "sha512-RXlj7zCYokReqWpOPH9oYivUzLYZ5vAPIfEmCTNViosC78F8F0H9y7T7gG2M39ymgutxF5gcFEsyZQSph9Bp3A==", 2239 | "dev": true, 2240 | "dependencies": { 2241 | "dot-case": "^3.0.4", 2242 | "tslib": "^2.0.3" 2243 | } 2244 | }, 2245 | "node_modules/pascal-case": { 2246 | "version": "3.1.2", 2247 | "resolved": "https://registry.npmjs.org/pascal-case/-/pascal-case-3.1.2.tgz", 2248 | "integrity": "sha512-uWlGT3YSnK9x3BQJaOdcZwrnV6hPpd8jFH1/ucpiLRPh/2zCVJKS19E4GvYHvaCcACn3foXZ0cLB9Wrx1KGe5g==", 2249 | "dev": true, 2250 | "dependencies": { 2251 | "no-case": "^3.0.4", 2252 | "tslib": "^2.0.3" 2253 | } 2254 | }, 2255 | "node_modules/path-is-absolute": { 2256 | "version": "1.0.1", 2257 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 2258 | "integrity": "sha512-AVbw3UJ2e9bq64vSaS9Am0fje1Pa8pbGqTTsmXfaIiMpnr5DlDhfJOuLj9Sf95ZPVDAUerDfEk88MPmPe7UCQg==", 2259 | "dev": true, 2260 | "engines": { 2261 | "node": ">=0.10.0" 2262 | } 2263 | }, 2264 | "node_modules/path-key": { 2265 | "version": "3.1.1", 2266 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", 2267 | "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", 2268 | "dev": true, 2269 | "engines": { 2270 | "node": ">=8" 2271 | } 2272 | }, 2273 | "node_modules/pathe": { 2274 | "version": "0.2.0", 2275 | "resolved": "https://registry.npmjs.org/pathe/-/pathe-0.2.0.tgz", 2276 | "integrity": "sha512-sTitTPYnn23esFR3RlqYBWn4c45WGeLcsKzQiUpXJAyfcWkolvlYpV8FLo7JishK946oQwMFUCHXQ9AjGPKExw==", 2277 | "dev": true 2278 | }, 2279 | "node_modules/pathval": { 2280 | "version": "1.1.1", 2281 | "resolved": "https://registry.npmjs.org/pathval/-/pathval-1.1.1.tgz", 2282 | "integrity": "sha512-Dp6zGqpTdETdR63lehJYPeIOqpiNBNtc7BpWSLrOje7UaIsE5aY92r/AunQA7rsXvet3lrJ3JnZX29UPTKXyKQ==", 2283 | "dev": true, 2284 | "engines": { 2285 | "node": "*" 2286 | } 2287 | }, 2288 | "node_modules/picocolors": { 2289 | "version": "1.1.0", 2290 | "resolved": "https://registry.npmjs.org/picocolors/-/picocolors-1.1.0.tgz", 2291 | "integrity": "sha512-TQ92mBOW0l3LeMeyLV6mzy/kWr8lkd/hp3mTg7wYK7zJhuBStmGMBG0BdeDZS/dZx1IukaX6Bk11zcln25o1Aw==", 2292 | "dev": true 2293 | }, 2294 | "node_modules/picomatch": { 2295 | "version": "2.3.1", 2296 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz", 2297 | "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==", 2298 | "dev": true, 2299 | "engines": { 2300 | "node": ">=8.6" 2301 | }, 2302 | "funding": { 2303 | "url": "https://github.com/sponsors/jonschlinkert" 2304 | } 2305 | }, 2306 | "node_modules/pkg-types": { 2307 | "version": "1.1.1", 2308 | "resolved": "https://registry.npmjs.org/pkg-types/-/pkg-types-1.1.1.tgz", 2309 | "integrity": "sha512-ko14TjmDuQJ14zsotODv7dBlwxKhUKQEhuhmbqo1uCi9BB0Z2alo/wAXg6q1dTR5TyuqYyWhjtfe/Tsh+X28jQ==", 2310 | "dev": true, 2311 | "dependencies": { 2312 | "confbox": "^0.1.7", 2313 | "mlly": "^1.7.0", 2314 | "pathe": "^1.1.2" 2315 | } 2316 | }, 2317 | "node_modules/pkg-types/node_modules/pathe": { 2318 | "version": "1.1.2", 2319 | "resolved": "https://registry.npmjs.org/pathe/-/pathe-1.1.2.tgz", 2320 | "integrity": "sha512-whLdWMYL2TwI08hn8/ZqAbrVemu0LNaNNJZX73O6qaIdCTfXutsLhMkjdENX0qhsQ9uIimo4/aQOmXkoon2nDQ==", 2321 | "dev": true 2322 | }, 2323 | "node_modules/postcss": { 2324 | "version": "8.4.47", 2325 | "resolved": "https://registry.npmjs.org/postcss/-/postcss-8.4.47.tgz", 2326 | "integrity": "sha512-56rxCq7G/XfB4EkXq9Egn5GCqugWvDFjafDOThIdMBsI15iqPqR5r15TfSr1YPYeEI19YeaXMCbY6u88Y76GLQ==", 2327 | "dev": true, 2328 | "funding": [ 2329 | { 2330 | "type": "opencollective", 2331 | "url": "https://opencollective.com/postcss/" 2332 | }, 2333 | { 2334 | "type": "tidelift", 2335 | "url": "https://tidelift.com/funding/github/npm/postcss" 2336 | }, 2337 | { 2338 | "type": "github", 2339 | "url": "https://github.com/sponsors/ai" 2340 | } 2341 | ], 2342 | "dependencies": { 2343 | "nanoid": "^3.3.7", 2344 | "picocolors": "^1.1.0", 2345 | "source-map-js": "^1.2.1" 2346 | }, 2347 | "engines": { 2348 | "node": "^10 || ^12 || >=14" 2349 | } 2350 | }, 2351 | "node_modules/pretty-format": { 2352 | "version": "29.7.0", 2353 | "resolved": "https://registry.npmjs.org/pretty-format/-/pretty-format-29.7.0.tgz", 2354 | "integrity": "sha512-Pdlw/oPxN+aXdmM9R00JVC9WVFoCLTKJvDVLgmJ+qAffBMxsV85l/Lu7sNx4zSzPyoL2euImuEwHhOXdEgNFZQ==", 2355 | "dev": true, 2356 | "dependencies": { 2357 | "@jest/schemas": "^29.6.3", 2358 | "ansi-styles": "^5.0.0", 2359 | "react-is": "^18.0.0" 2360 | }, 2361 | "engines": { 2362 | "node": "^14.15.0 || ^16.10.0 || >=18.0.0" 2363 | } 2364 | }, 2365 | "node_modules/pretty-format/node_modules/ansi-styles": { 2366 | "version": "5.2.0", 2367 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-5.2.0.tgz", 2368 | "integrity": "sha512-Cxwpt2SfTzTtXcfOlzGEee8O+c+MmUgGrNiBcXnuWxuFJHe6a5Hz7qwhwe5OgaSYI0IJvkLqWX1ASG+cJOkEiA==", 2369 | "dev": true, 2370 | "engines": { 2371 | "node": ">=10" 2372 | }, 2373 | "funding": { 2374 | "url": "https://github.com/chalk/ansi-styles?sponsor=1" 2375 | } 2376 | }, 2377 | "node_modules/queue-microtask": { 2378 | "version": "1.2.3", 2379 | "resolved": "https://registry.npmjs.org/queue-microtask/-/queue-microtask-1.2.3.tgz", 2380 | "integrity": "sha512-NuaNSa6flKT5JaSYQzJok04JzTL1CA6aGhv5rfLW3PgqA+M2ChpZQnAC8h8i4ZFkBS8X5RqkDBHA7r4hej3K9A==", 2381 | "dev": true, 2382 | "funding": [ 2383 | { 2384 | "type": "github", 2385 | "url": "https://github.com/sponsors/feross" 2386 | }, 2387 | { 2388 | "type": "patreon", 2389 | "url": "https://www.patreon.com/feross" 2390 | }, 2391 | { 2392 | "type": "consulting", 2393 | "url": "https://feross.org/support" 2394 | } 2395 | ] 2396 | }, 2397 | "node_modules/react-is": { 2398 | "version": "18.3.1", 2399 | "resolved": "https://registry.npmjs.org/react-is/-/react-is-18.3.1.tgz", 2400 | "integrity": "sha512-/LLMVyas0ljjAtoYiPqYiL8VWXzUUdThrmU5+n20DZv+a+ClRoevUzw5JxU+Ieh5/c87ytoTBV9G1FiKfNJdmg==", 2401 | "dev": true 2402 | }, 2403 | "node_modules/relateurl": { 2404 | "version": "0.2.7", 2405 | "resolved": "https://registry.npmjs.org/relateurl/-/relateurl-0.2.7.tgz", 2406 | "integrity": "sha512-G08Dxvm4iDN3MLM0EsP62EDV9IuhXPR6blNz6Utcp7zyV3tr4HVNINt6MpaRWbxoOHT3Q7YN2P+jaHX8vUbgog==", 2407 | "dev": true, 2408 | "engines": { 2409 | "node": ">= 0.10" 2410 | } 2411 | }, 2412 | "node_modules/reusify": { 2413 | "version": "1.0.4", 2414 | "resolved": "https://registry.npmjs.org/reusify/-/reusify-1.0.4.tgz", 2415 | "integrity": "sha512-U9nH88a3fc/ekCF1l0/UP1IosiuIjyTh7hBvXVMHYgVcfGvt897Xguj2UOLDeI5BG2m7/uwyaLVT6fbtCwTyzw==", 2416 | "dev": true, 2417 | "engines": { 2418 | "iojs": ">=1.0.0", 2419 | "node": ">=0.10.0" 2420 | } 2421 | }, 2422 | "node_modules/rollup": { 2423 | "version": "4.24.4", 2424 | "resolved": "https://registry.npmjs.org/rollup/-/rollup-4.24.4.tgz", 2425 | "integrity": "sha512-vGorVWIsWfX3xbcyAS+I047kFKapHYivmkaT63Smj77XwvLSJos6M1xGqZnBPFQFBRZDOcG1QnYEIxAvTr/HjA==", 2426 | "dev": true, 2427 | "dependencies": { 2428 | "@types/estree": "1.0.6" 2429 | }, 2430 | "bin": { 2431 | "rollup": "dist/bin/rollup" 2432 | }, 2433 | "engines": { 2434 | "node": ">=18.0.0", 2435 | "npm": ">=8.0.0" 2436 | }, 2437 | "optionalDependencies": { 2438 | "@rollup/rollup-android-arm-eabi": "4.24.4", 2439 | "@rollup/rollup-android-arm64": "4.24.4", 2440 | "@rollup/rollup-darwin-arm64": "4.24.4", 2441 | "@rollup/rollup-darwin-x64": "4.24.4", 2442 | "@rollup/rollup-freebsd-arm64": "4.24.4", 2443 | "@rollup/rollup-freebsd-x64": "4.24.4", 2444 | "@rollup/rollup-linux-arm-gnueabihf": "4.24.4", 2445 | "@rollup/rollup-linux-arm-musleabihf": "4.24.4", 2446 | "@rollup/rollup-linux-arm64-gnu": "4.24.4", 2447 | "@rollup/rollup-linux-arm64-musl": "4.24.4", 2448 | "@rollup/rollup-linux-powerpc64le-gnu": "4.24.4", 2449 | "@rollup/rollup-linux-riscv64-gnu": "4.24.4", 2450 | "@rollup/rollup-linux-s390x-gnu": "4.24.4", 2451 | "@rollup/rollup-linux-x64-gnu": "4.24.4", 2452 | "@rollup/rollup-linux-x64-musl": "4.24.4", 2453 | "@rollup/rollup-win32-arm64-msvc": "4.24.4", 2454 | "@rollup/rollup-win32-ia32-msvc": "4.24.4", 2455 | "@rollup/rollup-win32-x64-msvc": "4.24.4", 2456 | "fsevents": "~2.3.2" 2457 | } 2458 | }, 2459 | "node_modules/run-parallel": { 2460 | "version": "1.2.0", 2461 | "resolved": "https://registry.npmjs.org/run-parallel/-/run-parallel-1.2.0.tgz", 2462 | "integrity": "sha512-5l4VyZR86LZ/lDxZTR6jqL8AFE2S0IFLMP26AbjsLVADxHdhB/c0GUsH+y39UfCi3dzz8OlQuPmnaJOMoDHQBA==", 2463 | "dev": true, 2464 | "funding": [ 2465 | { 2466 | "type": "github", 2467 | "url": "https://github.com/sponsors/feross" 2468 | }, 2469 | { 2470 | "type": "patreon", 2471 | "url": "https://www.patreon.com/feross" 2472 | }, 2473 | { 2474 | "type": "consulting", 2475 | "url": "https://feross.org/support" 2476 | } 2477 | ], 2478 | "dependencies": { 2479 | "queue-microtask": "^1.2.2" 2480 | } 2481 | }, 2482 | "node_modules/semver": { 2483 | "version": "7.6.2", 2484 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.6.2.tgz", 2485 | "integrity": "sha512-FNAIBWCx9qcRhoHcgcJ0gvU7SN1lYU2ZXuSfl04bSC5OpvDHFyJCjdNHomPXxjQlCBU67YW64PzY7/VIEH7F2w==", 2486 | "dev": true, 2487 | "bin": { 2488 | "semver": "bin/semver.js" 2489 | }, 2490 | "engines": { 2491 | "node": ">=10" 2492 | } 2493 | }, 2494 | "node_modules/shebang-command": { 2495 | "version": "2.0.0", 2496 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", 2497 | "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", 2498 | "dev": true, 2499 | "dependencies": { 2500 | "shebang-regex": "^3.0.0" 2501 | }, 2502 | "engines": { 2503 | "node": ">=8" 2504 | } 2505 | }, 2506 | "node_modules/shebang-regex": { 2507 | "version": "3.0.0", 2508 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", 2509 | "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", 2510 | "dev": true, 2511 | "engines": { 2512 | "node": ">=8" 2513 | } 2514 | }, 2515 | "node_modules/siginfo": { 2516 | "version": "2.0.0", 2517 | "resolved": "https://registry.npmjs.org/siginfo/-/siginfo-2.0.0.tgz", 2518 | "integrity": "sha512-ybx0WO1/8bSBLEWXZvEd7gMW3Sn3JFlW3TvX1nREbDLRNQNaeNN8WK0meBwPdAaOI7TtRRRJn/Es1zhrrCHu7g==", 2519 | "dev": true 2520 | }, 2521 | "node_modules/signal-exit": { 2522 | "version": "4.1.0", 2523 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-4.1.0.tgz", 2524 | "integrity": "sha512-bzyZ1e88w9O1iNJbKnOlvYTrWPDl46O1bG0D3XInv+9tkPrxrN8jUUTiFlDkkmKWgn1M6CfIA13SuGqOa9Korw==", 2525 | "dev": true, 2526 | "engines": { 2527 | "node": ">=14" 2528 | }, 2529 | "funding": { 2530 | "url": "https://github.com/sponsors/isaacs" 2531 | } 2532 | }, 2533 | "node_modules/source-map": { 2534 | "version": "0.6.1", 2535 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", 2536 | "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", 2537 | "dev": true, 2538 | "engines": { 2539 | "node": ">=0.10.0" 2540 | } 2541 | }, 2542 | "node_modules/source-map-js": { 2543 | "version": "1.2.1", 2544 | "resolved": "https://registry.npmjs.org/source-map-js/-/source-map-js-1.2.1.tgz", 2545 | "integrity": "sha512-UXWMKhLOwVKb728IUtQPXxfYU+usdybtUrK/8uGE8CQMvrhOpwvzDBwj0QhSL7MQc7vIsISBG8VQ8+IDQxpfQA==", 2546 | "dev": true, 2547 | "engines": { 2548 | "node": ">=0.10.0" 2549 | } 2550 | }, 2551 | "node_modules/source-map-support": { 2552 | "version": "0.5.21", 2553 | "resolved": "https://registry.npmjs.org/source-map-support/-/source-map-support-0.5.21.tgz", 2554 | "integrity": "sha512-uBHU3L3czsIyYXKX88fdrGovxdSCoTGDRZ6SYXtSRxLZUzHg5P/66Ht6uoUlHu9EZod+inXhKo3qQgwXUT/y1w==", 2555 | "dev": true, 2556 | "dependencies": { 2557 | "buffer-from": "^1.0.0", 2558 | "source-map": "^0.6.0" 2559 | } 2560 | }, 2561 | "node_modules/stackback": { 2562 | "version": "0.0.2", 2563 | "resolved": "https://registry.npmjs.org/stackback/-/stackback-0.0.2.tgz", 2564 | "integrity": "sha512-1XMJE5fQo1jGH6Y/7ebnwPOBEkIEnT4QF32d5R1+VXdXveM0IBMJt8zfaxX1P3QhVwrYe+576+jkANtSS2mBbw==", 2565 | "dev": true 2566 | }, 2567 | "node_modules/std-env": { 2568 | "version": "3.7.0", 2569 | "resolved": "https://registry.npmjs.org/std-env/-/std-env-3.7.0.tgz", 2570 | "integrity": "sha512-JPbdCEQLj1w5GilpiHAx3qJvFndqybBysA3qUOnznweH4QbNYUsW/ea8QzSrnh0vNsezMMw5bcVool8lM0gwzg==", 2571 | "dev": true 2572 | }, 2573 | "node_modules/strip-final-newline": { 2574 | "version": "3.0.0", 2575 | "resolved": "https://registry.npmjs.org/strip-final-newline/-/strip-final-newline-3.0.0.tgz", 2576 | "integrity": "sha512-dOESqjYr96iWYylGObzd39EuNTa5VJxyvVAEm5Jnh7KGo75V43Hk1odPQkNDyXNmUR6k+gEiDVXnjB8HJ3crXw==", 2577 | "dev": true, 2578 | "engines": { 2579 | "node": ">=12" 2580 | }, 2581 | "funding": { 2582 | "url": "https://github.com/sponsors/sindresorhus" 2583 | } 2584 | }, 2585 | "node_modules/strip-literal": { 2586 | "version": "2.1.0", 2587 | "resolved": "https://registry.npmjs.org/strip-literal/-/strip-literal-2.1.0.tgz", 2588 | "integrity": "sha512-Op+UycaUt/8FbN/Z2TWPBLge3jWrP3xj10f3fnYxf052bKuS3EKs1ZQcVGjnEMdsNVAM+plXRdmjrZ/KgG3Skw==", 2589 | "dev": true, 2590 | "dependencies": { 2591 | "js-tokens": "^9.0.0" 2592 | }, 2593 | "funding": { 2594 | "url": "https://github.com/sponsors/antfu" 2595 | } 2596 | }, 2597 | "node_modules/supports-color": { 2598 | "version": "7.2.0", 2599 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", 2600 | "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", 2601 | "dev": true, 2602 | "dependencies": { 2603 | "has-flag": "^4.0.0" 2604 | }, 2605 | "engines": { 2606 | "node": ">=8" 2607 | } 2608 | }, 2609 | "node_modules/terser": { 2610 | "version": "5.31.0", 2611 | "resolved": "https://registry.npmjs.org/terser/-/terser-5.31.0.tgz", 2612 | "integrity": "sha512-Q1JFAoUKE5IMfI4Z/lkE/E6+SwgzO+x4tq4v1AyBLRj8VSYvRO6A/rQrPg1yud4g0En9EKI1TvFRF2tQFcoUkg==", 2613 | "dev": true, 2614 | "dependencies": { 2615 | "@jridgewell/source-map": "^0.3.3", 2616 | "acorn": "^8.8.2", 2617 | "commander": "^2.20.0", 2618 | "source-map-support": "~0.5.20" 2619 | }, 2620 | "bin": { 2621 | "terser": "bin/terser" 2622 | }, 2623 | "engines": { 2624 | "node": ">=10" 2625 | } 2626 | }, 2627 | "node_modules/terser/node_modules/commander": { 2628 | "version": "2.20.3", 2629 | "resolved": "https://registry.npmjs.org/commander/-/commander-2.20.3.tgz", 2630 | "integrity": "sha512-GpVkmM8vF2vQUkj2LvZmD35JxeJOLCwJ9cUkugyk2nuhbv3+mJvpLYYt+0+USMxE+oj+ey/lJEnhZw75x/OMcQ==", 2631 | "dev": true 2632 | }, 2633 | "node_modules/test-exclude": { 2634 | "version": "6.0.0", 2635 | "resolved": "https://registry.npmjs.org/test-exclude/-/test-exclude-6.0.0.tgz", 2636 | "integrity": "sha512-cAGWPIyOHU6zlmg88jwm7VRyXnMN7iV68OGAbYDk/Mh/xC/pzVPlQtY6ngoIH/5/tciuhGfvESU8GrHrcxD56w==", 2637 | "dev": true, 2638 | "dependencies": { 2639 | "@istanbuljs/schema": "^0.1.2", 2640 | "glob": "^7.1.4", 2641 | "minimatch": "^3.0.4" 2642 | }, 2643 | "engines": { 2644 | "node": ">=8" 2645 | } 2646 | }, 2647 | "node_modules/tinybench": { 2648 | "version": "2.8.0", 2649 | "resolved": "https://registry.npmjs.org/tinybench/-/tinybench-2.8.0.tgz", 2650 | "integrity": "sha512-1/eK7zUnIklz4JUUlL+658n58XO2hHLQfSk1Zf2LKieUjxidN16eKFEoDEfjHc3ohofSSqK3X5yO6VGb6iW8Lw==", 2651 | "dev": true 2652 | }, 2653 | "node_modules/tinypool": { 2654 | "version": "0.8.4", 2655 | "resolved": "https://registry.npmjs.org/tinypool/-/tinypool-0.8.4.tgz", 2656 | "integrity": "sha512-i11VH5gS6IFeLY3gMBQ00/MmLncVP7JLXOw1vlgkytLmJK7QnEr7NXf0LBdxfmNPAeyetukOk0bOYrJrFGjYJQ==", 2657 | "dev": true, 2658 | "engines": { 2659 | "node": ">=14.0.0" 2660 | } 2661 | }, 2662 | "node_modules/tinyspy": { 2663 | "version": "2.2.1", 2664 | "resolved": "https://registry.npmjs.org/tinyspy/-/tinyspy-2.2.1.tgz", 2665 | "integrity": "sha512-KYad6Vy5VDWV4GH3fjpseMQ/XU2BhIYP7Vzd0LG44qRWm/Yt2WCOTicFdvmgo6gWaqooMQCawTtILVQJupKu7A==", 2666 | "dev": true, 2667 | "engines": { 2668 | "node": ">=14.0.0" 2669 | } 2670 | }, 2671 | "node_modules/to-fast-properties": { 2672 | "version": "2.0.0", 2673 | "resolved": "https://registry.npmjs.org/to-fast-properties/-/to-fast-properties-2.0.0.tgz", 2674 | "integrity": "sha512-/OaKK0xYrs3DmxRYqL/yDc+FxFUVYhDlXMhRmv3z915w2HF1tnN1omB354j8VUGO/hbRzyD6Y3sA7v7GS/ceog==", 2675 | "dev": true, 2676 | "engines": { 2677 | "node": ">=4" 2678 | } 2679 | }, 2680 | "node_modules/to-regex-range": { 2681 | "version": "5.0.1", 2682 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 2683 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 2684 | "dev": true, 2685 | "dependencies": { 2686 | "is-number": "^7.0.0" 2687 | }, 2688 | "engines": { 2689 | "node": ">=8.0" 2690 | } 2691 | }, 2692 | "node_modules/tslib": { 2693 | "version": "2.6.2", 2694 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.6.2.tgz", 2695 | "integrity": "sha512-AEYxH93jGFPn/a2iVAwW87VuUIkR1FVUKB77NwMF7nBTDkDrrT/Hpt/IrCJ0QXhW27jTBDcf5ZY7w6RiqTMw2Q==", 2696 | "dev": true 2697 | }, 2698 | "node_modules/type-detect": { 2699 | "version": "4.0.8", 2700 | "resolved": "https://registry.npmjs.org/type-detect/-/type-detect-4.0.8.tgz", 2701 | "integrity": "sha512-0fr/mIH1dlO+x7TlcMy+bIDqKPsw/70tVyeHW787goQjhmqaZe10uwLujubK9q9Lg6Fiho1KUKDYz0Z7k7g5/g==", 2702 | "dev": true, 2703 | "engines": { 2704 | "node": ">=4" 2705 | } 2706 | }, 2707 | "node_modules/typescript": { 2708 | "version": "5.4.5", 2709 | "resolved": "https://registry.npmjs.org/typescript/-/typescript-5.4.5.tgz", 2710 | "integrity": "sha512-vcI4UpRgg81oIRUFwR0WSIHKt11nJ7SAVlYNIu+QpqeyXP+gpQJy/Z4+F0aGxSE4MqwjyXvW/TzgkLAx2AGHwQ==", 2711 | "dev": true, 2712 | "bin": { 2713 | "tsc": "bin/tsc", 2714 | "tsserver": "bin/tsserver" 2715 | }, 2716 | "engines": { 2717 | "node": ">=14.17" 2718 | } 2719 | }, 2720 | "node_modules/ufo": { 2721 | "version": "1.5.3", 2722 | "resolved": "https://registry.npmjs.org/ufo/-/ufo-1.5.3.tgz", 2723 | "integrity": "sha512-Y7HYmWaFwPUmkoQCUIAYpKqkOf+SbVj/2fJJZ4RJMCfZp0rTGwRbzQD+HghfnhKOjL9E01okqz+ncJskGYfBNw==", 2724 | "dev": true 2725 | }, 2726 | "node_modules/universalify": { 2727 | "version": "2.0.1", 2728 | "resolved": "https://registry.npmjs.org/universalify/-/universalify-2.0.1.tgz", 2729 | "integrity": "sha512-gptHNQghINnc/vTGIk0SOFGFNXw7JVrlRUtConJRlvaw6DuX0wO5Jeko9sWrMBhh+PsYAZ7oXAiOnf/UKogyiw==", 2730 | "dev": true, 2731 | "engines": { 2732 | "node": ">= 10.0.0" 2733 | } 2734 | }, 2735 | "node_modules/vite": { 2736 | "version": "5.4.6", 2737 | "resolved": "https://registry.npmjs.org/vite/-/vite-5.4.6.tgz", 2738 | "integrity": "sha512-IeL5f8OO5nylsgzd9tq4qD2QqI0k2CQLGrWD0rCN0EQJZpBK5vJAx0I+GDkMOXxQX/OfFHMuLIx6ddAxGX/k+Q==", 2739 | "dev": true, 2740 | "dependencies": { 2741 | "esbuild": "^0.21.3", 2742 | "postcss": "^8.4.43", 2743 | "rollup": "^4.20.0" 2744 | }, 2745 | "bin": { 2746 | "vite": "bin/vite.js" 2747 | }, 2748 | "engines": { 2749 | "node": "^18.0.0 || >=20.0.0" 2750 | }, 2751 | "funding": { 2752 | "url": "https://github.com/vitejs/vite?sponsor=1" 2753 | }, 2754 | "optionalDependencies": { 2755 | "fsevents": "~2.3.3" 2756 | }, 2757 | "peerDependencies": { 2758 | "@types/node": "^18.0.0 || >=20.0.0", 2759 | "less": "*", 2760 | "lightningcss": "^1.21.0", 2761 | "sass": "*", 2762 | "sass-embedded": "*", 2763 | "stylus": "*", 2764 | "sugarss": "*", 2765 | "terser": "^5.4.0" 2766 | }, 2767 | "peerDependenciesMeta": { 2768 | "@types/node": { 2769 | "optional": true 2770 | }, 2771 | "less": { 2772 | "optional": true 2773 | }, 2774 | "lightningcss": { 2775 | "optional": true 2776 | }, 2777 | "sass": { 2778 | "optional": true 2779 | }, 2780 | "sass-embedded": { 2781 | "optional": true 2782 | }, 2783 | "stylus": { 2784 | "optional": true 2785 | }, 2786 | "sugarss": { 2787 | "optional": true 2788 | }, 2789 | "terser": { 2790 | "optional": true 2791 | } 2792 | } 2793 | }, 2794 | "node_modules/vite-node": { 2795 | "version": "1.6.0", 2796 | "resolved": "https://registry.npmjs.org/vite-node/-/vite-node-1.6.0.tgz", 2797 | "integrity": "sha512-de6HJgzC+TFzOu0NTC4RAIsyf/DY/ibWDYQUcuEA84EMHhcefTUGkjFHKKEJhQN4A+6I0u++kr3l36ZF2d7XRw==", 2798 | "dev": true, 2799 | "dependencies": { 2800 | "cac": "^6.7.14", 2801 | "debug": "^4.3.4", 2802 | "pathe": "^1.1.1", 2803 | "picocolors": "^1.0.0", 2804 | "vite": "^5.0.0" 2805 | }, 2806 | "bin": { 2807 | "vite-node": "vite-node.mjs" 2808 | }, 2809 | "engines": { 2810 | "node": "^18.0.0 || >=20.0.0" 2811 | }, 2812 | "funding": { 2813 | "url": "https://opencollective.com/vitest" 2814 | } 2815 | }, 2816 | "node_modules/vite-node/node_modules/pathe": { 2817 | "version": "1.1.2", 2818 | "resolved": "https://registry.npmjs.org/pathe/-/pathe-1.1.2.tgz", 2819 | "integrity": "sha512-whLdWMYL2TwI08hn8/ZqAbrVemu0LNaNNJZX73O6qaIdCTfXutsLhMkjdENX0qhsQ9uIimo4/aQOmXkoon2nDQ==", 2820 | "dev": true 2821 | }, 2822 | "node_modules/vite-plugin-html": { 2823 | "version": "3.2.2", 2824 | "resolved": "https://registry.npmjs.org/vite-plugin-html/-/vite-plugin-html-3.2.2.tgz", 2825 | "integrity": "sha512-vb9C9kcdzcIo/Oc3CLZVS03dL5pDlOFuhGlZYDCJ840BhWl/0nGeZWf3Qy7NlOayscY4Cm/QRgULCQkEZige5Q==", 2826 | "dev": true, 2827 | "dependencies": { 2828 | "@rollup/pluginutils": "^4.2.0", 2829 | "colorette": "^2.0.16", 2830 | "connect-history-api-fallback": "^1.6.0", 2831 | "consola": "^2.15.3", 2832 | "dotenv": "^16.0.0", 2833 | "dotenv-expand": "^8.0.2", 2834 | "ejs": "^3.1.6", 2835 | "fast-glob": "^3.2.11", 2836 | "fs-extra": "^10.0.1", 2837 | "html-minifier-terser": "^6.1.0", 2838 | "node-html-parser": "^5.3.3", 2839 | "pathe": "^0.2.0" 2840 | }, 2841 | "peerDependencies": { 2842 | "vite": ">=2.0.0" 2843 | } 2844 | }, 2845 | "node_modules/vitest": { 2846 | "version": "1.6.0", 2847 | "resolved": "https://registry.npmjs.org/vitest/-/vitest-1.6.0.tgz", 2848 | "integrity": "sha512-H5r/dN06swuFnzNFhq/dnz37bPXnq8xB2xB5JOVk8K09rUtoeNN+LHWkoQ0A/i3hvbUKKcCei9KpbxqHMLhLLA==", 2849 | "dev": true, 2850 | "dependencies": { 2851 | "@vitest/expect": "1.6.0", 2852 | "@vitest/runner": "1.6.0", 2853 | "@vitest/snapshot": "1.6.0", 2854 | "@vitest/spy": "1.6.0", 2855 | "@vitest/utils": "1.6.0", 2856 | "acorn-walk": "^8.3.2", 2857 | "chai": "^4.3.10", 2858 | "debug": "^4.3.4", 2859 | "execa": "^8.0.1", 2860 | "local-pkg": "^0.5.0", 2861 | "magic-string": "^0.30.5", 2862 | "pathe": "^1.1.1", 2863 | "picocolors": "^1.0.0", 2864 | "std-env": "^3.5.0", 2865 | "strip-literal": "^2.0.0", 2866 | "tinybench": "^2.5.1", 2867 | "tinypool": "^0.8.3", 2868 | "vite": "^5.0.0", 2869 | "vite-node": "1.6.0", 2870 | "why-is-node-running": "^2.2.2" 2871 | }, 2872 | "bin": { 2873 | "vitest": "vitest.mjs" 2874 | }, 2875 | "engines": { 2876 | "node": "^18.0.0 || >=20.0.0" 2877 | }, 2878 | "funding": { 2879 | "url": "https://opencollective.com/vitest" 2880 | }, 2881 | "peerDependencies": { 2882 | "@edge-runtime/vm": "*", 2883 | "@types/node": "^18.0.0 || >=20.0.0", 2884 | "@vitest/browser": "1.6.0", 2885 | "@vitest/ui": "1.6.0", 2886 | "happy-dom": "*", 2887 | "jsdom": "*" 2888 | }, 2889 | "peerDependenciesMeta": { 2890 | "@edge-runtime/vm": { 2891 | "optional": true 2892 | }, 2893 | "@types/node": { 2894 | "optional": true 2895 | }, 2896 | "@vitest/browser": { 2897 | "optional": true 2898 | }, 2899 | "@vitest/ui": { 2900 | "optional": true 2901 | }, 2902 | "happy-dom": { 2903 | "optional": true 2904 | }, 2905 | "jsdom": { 2906 | "optional": true 2907 | } 2908 | } 2909 | }, 2910 | "node_modules/vitest/node_modules/pathe": { 2911 | "version": "1.1.2", 2912 | "resolved": "https://registry.npmjs.org/pathe/-/pathe-1.1.2.tgz", 2913 | "integrity": "sha512-whLdWMYL2TwI08hn8/ZqAbrVemu0LNaNNJZX73O6qaIdCTfXutsLhMkjdENX0qhsQ9uIimo4/aQOmXkoon2nDQ==", 2914 | "dev": true 2915 | }, 2916 | "node_modules/webidl-conversions": { 2917 | "version": "7.0.0", 2918 | "resolved": "https://registry.npmjs.org/webidl-conversions/-/webidl-conversions-7.0.0.tgz", 2919 | "integrity": "sha512-VwddBukDzu71offAQR975unBIGqfKZpM+8ZX6ySk8nYhVoo5CYaZyzt3YBvYtRtO+aoGlqxPg/B87NGVZ/fu6g==", 2920 | "dev": true, 2921 | "engines": { 2922 | "node": ">=12" 2923 | } 2924 | }, 2925 | "node_modules/whatwg-mimetype": { 2926 | "version": "3.0.0", 2927 | "resolved": "https://registry.npmjs.org/whatwg-mimetype/-/whatwg-mimetype-3.0.0.tgz", 2928 | "integrity": "sha512-nt+N2dzIutVRxARx1nghPKGv1xHikU7HKdfafKkLNLindmPU/ch3U31NOCGGA/dmPcmb1VlofO0vnKAcsm0o/Q==", 2929 | "dev": true, 2930 | "engines": { 2931 | "node": ">=12" 2932 | } 2933 | }, 2934 | "node_modules/which": { 2935 | "version": "2.0.2", 2936 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", 2937 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", 2938 | "dev": true, 2939 | "dependencies": { 2940 | "isexe": "^2.0.0" 2941 | }, 2942 | "bin": { 2943 | "node-which": "bin/node-which" 2944 | }, 2945 | "engines": { 2946 | "node": ">= 8" 2947 | } 2948 | }, 2949 | "node_modules/why-is-node-running": { 2950 | "version": "2.2.2", 2951 | "resolved": "https://registry.npmjs.org/why-is-node-running/-/why-is-node-running-2.2.2.tgz", 2952 | "integrity": "sha512-6tSwToZxTOcotxHeA+qGCq1mVzKR3CwcJGmVcY+QE8SHy6TnpFnh8PAvPNHYr7EcuVeG0QSMxtYCuO1ta/G/oA==", 2953 | "dev": true, 2954 | "dependencies": { 2955 | "siginfo": "^2.0.0", 2956 | "stackback": "0.0.2" 2957 | }, 2958 | "bin": { 2959 | "why-is-node-running": "cli.js" 2960 | }, 2961 | "engines": { 2962 | "node": ">=8" 2963 | } 2964 | }, 2965 | "node_modules/wrappy": { 2966 | "version": "1.0.2", 2967 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 2968 | "integrity": "sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ==", 2969 | "dev": true 2970 | }, 2971 | "node_modules/yocto-queue": { 2972 | "version": "1.0.0", 2973 | "resolved": "https://registry.npmjs.org/yocto-queue/-/yocto-queue-1.0.0.tgz", 2974 | "integrity": "sha512-9bnSc/HEW2uRy67wc+T8UwauLuPJVn28jb+GtJY16iiKWyvmYJRXVT4UamsAEGQfPohgr2q4Tq0sQbQlxTfi1g==", 2975 | "dev": true, 2976 | "engines": { 2977 | "node": ">=12.20" 2978 | }, 2979 | "funding": { 2980 | "url": "https://github.com/sponsors/sindresorhus" 2981 | } 2982 | } 2983 | } 2984 | } 2985 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "pub-sub-es", 3 | "version": "3.0.0", 4 | "description": "A simple pub-sub service", 5 | "author": "Fritz Lekschas", 6 | "type": "module", 7 | "keywords": [ 8 | "pub-sub", 9 | "es6", 10 | "es2015", 11 | "publish", 12 | "subscribe" 13 | ], 14 | "license": "MIT", 15 | "main": "./dist/index.js", 16 | "module": "./dist/index.js", 17 | "types": "./dist/index.d.ts", 18 | "exports": "./dist/index.js", 19 | "files": [ 20 | "dist" 21 | ], 22 | "scripts": { 23 | "start": "vite", 24 | "build": "tsc --build && vite build", 25 | "prepublishOnly": "npm run fix", 26 | "prerelease": "rm -rf dist/*; npm run build; zip -r dist.zip dist", 27 | "pretest": "npm run fix", 28 | "test": "vitest run --environment=happy-dom", 29 | "coverage": "vitest run --coverage --environment=happy-dom", 30 | "fix": "biome check --apply ." 31 | }, 32 | "devDependencies": { 33 | "@biomejs/biome": "1.7.3", 34 | "@vitest/coverage-v8": "^1.6.0", 35 | "happy-dom": "^15.10.2", 36 | "typescript": "^5.4.5", 37 | "vite": "^5.2.12", 38 | "vite-plugin-html": "^3.2.2", 39 | "vitest": "^1.6.0" 40 | }, 41 | "homepage": "https://github.com/flekschas/pub-sub", 42 | "repository": { 43 | "type": "git", 44 | "url": "git://github.com/flekschas/pub-sub.git" 45 | }, 46 | "bugs": { 47 | "url": "https://github.com/flekschas/pub-sub/issues" 48 | } 49 | } 50 | -------------------------------------------------------------------------------- /src/index.test.ts: -------------------------------------------------------------------------------- 1 | import { expect, expectTypeOf, test, vi } from "vitest"; 2 | 3 | import { createPubSub, globalPubSub } from "./index"; 4 | import type { Event } from "./index"; 5 | 6 | const wait = (msec: number) => 7 | new Promise((resolve) => { 8 | setTimeout(resolve, msec); 9 | }); 10 | 11 | let globalCounter = 0; 12 | 13 | const globalEventName = "my-global-event"; 14 | const globalEventHandler = () => ++globalCounter; 15 | 16 | globalPubSub.subscribe(globalEventName, globalEventHandler); 17 | 18 | globalPubSub.publish(globalEventName); 19 | globalPubSub.publish(globalEventName); 20 | 21 | test("publishes and subscribes to event", () => { 22 | const eventName = "my-event"; 23 | const pubSub = createPubSub>(); 24 | 25 | pubSub.subscribe(eventName, (x) => expect(x).toBe(true)); 26 | pubSub.publish(eventName, true); 27 | 28 | expect(pubSub.stack[eventName]?.length).toBe(1); 29 | expect(pubSub.stack[eventName]?.[0].times).toBe(Number.POSITIVE_INFINITY); 30 | }); 31 | 32 | test("creates independent pub-sub stacks", () => { 33 | const pubSubA = createPubSub>(); 34 | const pubSubB = createPubSub>(); 35 | 36 | const eventName = "count"; 37 | 38 | let counterA = 0; 39 | let counterB = 0; 40 | 41 | expect(pubSubA.stack).not.toBe(pubSubB.stack); 42 | 43 | pubSubA.subscribe(eventName, () => ++counterA); 44 | pubSubB.subscribe(eventName, () => ++counterB); 45 | 46 | pubSubA.publish(eventName); 47 | pubSubA.publish(eventName); 48 | 49 | expect(counterA).toBe(2); 50 | expect(counterB).toBe(0); 51 | 52 | pubSubB.publish(eventName); 53 | 54 | expect(counterA).toBe(2); 55 | expect(counterB).toBe(1); 56 | 57 | expect(pubSubA.stack[eventName]?.length).toBe(1); 58 | expect(pubSubB.stack[eventName]?.length).toBe(1); 59 | }); 60 | 61 | test("unsubscribes from event", () => { 62 | const pubSub = createPubSub(); 63 | 64 | let counter = 0; 65 | 66 | const eventName = "my-event"; 67 | const eventHandler = () => ++counter; 68 | 69 | pubSub.subscribe(eventName, eventHandler); 70 | 71 | pubSub.publish(eventName); 72 | pubSub.publish(eventName); 73 | 74 | pubSub.unsubscribe(eventName, eventHandler); 75 | 76 | pubSub.publish(eventName); 77 | 78 | expect(counter).toBe(2); 79 | expect(pubSub.stack[eventName]?.length).toBe(0); 80 | 81 | const eventSubscription = pubSub.subscribe(eventName, eventHandler); 82 | 83 | pubSub.publish(eventName); 84 | pubSub.publish(eventName); 85 | 86 | pubSub.unsubscribe(eventSubscription); 87 | 88 | pubSub.publish(eventName); 89 | 90 | expect(counter).toBe(4); 91 | expect(pubSub.stack[eventName]?.length).toBe(0); 92 | 93 | pubSub.subscribe(eventName, eventHandler); 94 | 95 | // Nothing should happen if one tries to unsubscribe an unknown handler 96 | pubSub.unsubscribe(eventName, () => ++counter); 97 | 98 | pubSub.publish(eventName); 99 | pubSub.publish(eventName); 100 | 101 | pubSub.unsubscribe(eventName, eventHandler); 102 | 103 | pubSub.publish(eventName); 104 | 105 | expect(counter).toBe(6); 106 | expect(pubSub.stack[eventName]?.length).toBe(0); 107 | }); 108 | 109 | test("test case-sensitive", () => { 110 | const pubSub = createPubSub(); 111 | const eventName = "myEvent"; 112 | 113 | let counter = 0; 114 | const eventHandler = () => ++counter; 115 | 116 | pubSub.subscribe(eventName, eventHandler); 117 | pubSub.publish(eventName); 118 | pubSub.publish(eventName.toLowerCase()); 119 | 120 | expect(counter).toBe(1); 121 | 122 | pubSub.unsubscribe(eventName.toLowerCase(), eventHandler); 123 | 124 | pubSub.publish(eventName); 125 | 126 | expect(pubSub.stack[eventName]?.length).toBe(1); 127 | expect(counter === 2, "should have registered 2 events"); 128 | 129 | pubSub.unsubscribe(eventName, eventHandler); 130 | 131 | expect(pubSub.stack[eventName]?.length).toBe(0); 132 | }); 133 | 134 | test("test case-insensitivity", () => { 135 | const eventName = "myEvent"; 136 | const pubSub = createPubSub({ caseInsensitive: true }); 137 | 138 | let counterA = 0; 139 | let counterB = 0; 140 | const eventHandlerA = () => ++counterA; 141 | const eventHandlerB = () => ++counterB; 142 | 143 | pubSub.subscribe(eventName, eventHandlerA); 144 | 145 | pubSub.publish(eventName); 146 | 147 | expect(counterA).toBe(1); 148 | 149 | pubSub.subscribe(eventName.toLowerCase(), eventHandlerB); 150 | pubSub.publish(eventName.toLowerCase()); 151 | 152 | expect(counterA).toBe(2); 153 | expect(counterB).toBe(1); 154 | 155 | pubSub.unsubscribe(eventName.toLowerCase(), eventHandlerA); 156 | pubSub.unsubscribe(eventName, eventHandlerB); 157 | 158 | pubSub.publish(eventName); 159 | 160 | expect(pubSub.stack[eventName]).toBe(undefined); 161 | expect(pubSub.stack[eventName.toLowerCase()]?.length).toBe(0); 162 | }); 163 | 164 | test("automatically unsubscribes after n events", () => { 165 | const eventName = "my-event"; 166 | const pubSub = createPubSub>(); 167 | 168 | let counter = 0; 169 | 170 | const eventHandler = () => ++counter; 171 | 172 | pubSub.subscribe(eventName, eventHandler, 2); 173 | expect(pubSub.stack[eventName]?.[0].times).toBe(2); 174 | 175 | pubSub.publish(eventName); 176 | pubSub.publish(eventName); 177 | pubSub.publish(eventName); 178 | 179 | expect(counter).toBe(2); 180 | expect(pubSub.stack[eventName]?.length).toBe(0); 181 | }); 182 | 183 | test("global pub-sub service", () => { 184 | // Check the beginning of this file. We've already fired a global event twice 185 | expect(globalCounter).toBe(2); 186 | 187 | const eventHandler = () => expect(globalCounter).toBe(3); 188 | 189 | globalPubSub.subscribe(globalEventName, eventHandler, 2); 190 | 191 | expect(globalPubSub.stack[globalEventName]?.length).toBe(2); 192 | 193 | globalPubSub.publish(globalEventName); 194 | 195 | const consoleWarn = vi.spyOn(console, "warn"); 196 | 197 | globalPubSub.subscribe("anotherGlobalEvent", () => { 198 | /* nothing */ 199 | }); 200 | 201 | // Try to publish an event with an unclonable payload 202 | // @see https://developer.mozilla.org/en-US/docs/Web/API/Web_Workers_API/Structured_clone_algorithm#things_that_dont_work_with_structured_clone 203 | globalPubSub.publish("anotherGlobalEvent", () => 42); 204 | 205 | expect(consoleWarn).toHaveBeenCalledOnce(); 206 | expect(consoleWarn).toHaveBeenLastCalledWith( 207 | "Could not broadcast 'anotherGlobalEvent' globally. Payload is not clonable.", 208 | ); 209 | 210 | globalPubSub.subscribe("yetAnotherGlobalEvent", (news) => 211 | expect(news).toBe(42), 212 | ); 213 | 214 | const broadcastChannel = new window.BroadcastChannel("pub-sub-es"); 215 | broadcastChannel.postMessage({ event: "yetAnotherGlobalEvent", news: 42 }); 216 | broadcastChannel.close(); 217 | }); 218 | 219 | test("allows custom event stack and sets __times__ if necessary", () => { 220 | const myStack = {}; 221 | const pubSub = createPubSub({ stack: myStack }); 222 | 223 | expect(pubSub.stack === myStack, "`myStack` should be the event stack"); 224 | expect(pubSub.stack.__times__, "event stack should be the `__times__` prop"); 225 | }); 226 | 227 | test("removes all listeners on clear()", () => { 228 | const eventName = "my-event"; 229 | const pubSub = createPubSub>(); 230 | 231 | let counter = 0; 232 | 233 | const eventHandler = () => ++counter; 234 | 235 | pubSub.subscribe(eventName, eventHandler); 236 | 237 | pubSub.publish(eventName); 238 | 239 | expect(Object.keys(pubSub.stack).length).toBe(1); 240 | expect(counter).toBe(1); 241 | 242 | pubSub.clear(); 243 | pubSub.publish(eventName); 244 | 245 | expect(Object.keys(pubSub.stack).length).toBe(0); 246 | expect(counter).toBe(1); 247 | }); 248 | 249 | test("test async events", async () => { 250 | const eventName = "myEvent"; 251 | 252 | const syncPubSub = createPubSub>(); 253 | const asyncPubSub = createPubSub>({ 254 | async: true, 255 | }); 256 | 257 | let counter = 0; 258 | const eventHandler = () => ++counter; 259 | 260 | syncPubSub.subscribe(eventName, eventHandler); 261 | syncPubSub.publish(eventName); 262 | expect(counter).toBe(1); 263 | 264 | counter = 0; 265 | asyncPubSub.subscribe(eventName, eventHandler); 266 | asyncPubSub.publish(eventName); 267 | expect(counter).toBe(0); 268 | 269 | await wait(0); 270 | 271 | expect(counter).toBe(1); 272 | 273 | counter = 0; 274 | syncPubSub.publish(eventName, undefined, { async: true }); 275 | expect(counter).toBe(0); 276 | 277 | await wait(0); 278 | 279 | expect(counter).toBe(1); 280 | 281 | counter = 0; 282 | asyncPubSub.publish(eventName, undefined, { async: false }); 283 | expect(counter).toBe(1); 284 | 285 | asyncPubSub.clear(); 286 | counter = 0; 287 | asyncPubSub.subscribe(eventName, eventHandler, 1); 288 | asyncPubSub.publish(eventName); 289 | asyncPubSub.publish(eventName); 290 | 291 | await wait(0); 292 | 293 | expect(counter).toBe(1); 294 | }); 295 | 296 | test("publish() types", () => { 297 | const pubSub1 = createPubSub>(); 298 | expectTypeOf(pubSub1.publish).parameter(1).toBeUndefined(); 299 | 300 | const pubSub2 = createPubSub>(); 301 | expectTypeOf(pubSub2.publish).parameter(1).toBeBoolean(); 302 | 303 | const pubSub3 = createPubSub>(); 304 | expectTypeOf(pubSub3.publish).parameter(1).toBeNumber(); 305 | 306 | const pubSub4 = createPubSub>(); 307 | expectTypeOf(pubSub4.publish).parameter(1).toBeNumber(); 308 | 309 | const pubSub5 = createPubSub>(); 310 | expectTypeOf(pubSub5.publish).parameter(1).toBeArray(); 311 | }); 312 | -------------------------------------------------------------------------------- /src/index.ts: -------------------------------------------------------------------------------- 1 | /** 2 | * Event object 3 | */ 4 | export type Event< 5 | EventName extends string = string, 6 | // biome-ignore lint/complexity/noUselessTypeConstraint: 7 | Payload extends unknown = unknown, 8 | > = { [Key in EventName]: Payload }; 9 | 10 | /** 11 | * Event handler function 12 | */ 13 | export type Handler = undefined extends News 14 | ? (news?: News | undefined) => void 15 | : (news: News) => void; 16 | 17 | /** 18 | * Event subscription object 19 | */ 20 | export interface Subscription { 21 | event: Key; 22 | handler: Handler; 23 | } 24 | 25 | /** 26 | * Function to subscribe to an event 27 | */ 28 | export type Subscribe = ReturnType>; 29 | 30 | /** 31 | * Function to unsubscribe to an event 32 | */ 33 | export type Unsubscribe = ReturnType< 34 | typeof createUnsubscribe 35 | >; 36 | 37 | /** 38 | * Options for customizing the subscriber factory 39 | */ 40 | export interface CreateSubscribeOptions { 41 | /** 42 | * If `true` the event names are case insenseitive 43 | */ 44 | caseInsensitive: boolean; 45 | } 46 | 47 | /** 48 | * Options for customizing the unsubscriber factory 49 | */ 50 | export interface CreateUnsubscribeOptions { 51 | /** 52 | * If `true` the event names are case insenseitive 53 | */ 54 | caseInsensitive: boolean; 55 | } 56 | 57 | /** 58 | * Options for how to publish an event 59 | */ 60 | export type PublishOptions = { 61 | /** 62 | * If `true` event will *not* be broadcasted gloablly even if `isGlobal` is `true`. 63 | */ 64 | isNoGlobalBroadcast: boolean; 65 | /** 66 | * If `true` event will *not* be broadcasted synchronously even if `async` is `false` globally. 67 | */ 68 | async: boolean; 69 | }; 70 | 71 | /** 72 | * Function to publish an event 73 | */ 74 | export type Publish = ( 75 | ...args: undefined extends T[Key] 76 | ? [key: Key, news?: T[Key], options?: Partial] 77 | : [key: Key, news: T[Key], options?: Partial] 78 | ) => void; 79 | 80 | /** 81 | * Options for customizing the publisher factory 82 | */ 83 | export interface CreatePublishOptions { 84 | /** 85 | * If `true` event will be published globally. 86 | */ 87 | isGlobal: boolean; 88 | /** 89 | * If `true` the event names are case insenseitive 90 | */ 91 | caseInsensitive: boolean; 92 | /** 93 | * If `true` the pub-sub instance publishes events asynchronously (recommended) 94 | */ 95 | async: boolean; 96 | } 97 | 98 | /** 99 | * Event listener object that stores the event hander and notification times 100 | */ 101 | export interface Listener { 102 | handler: Handler; 103 | times: number; 104 | } 105 | 106 | /** 107 | * Event stack object that stores all event listeners 108 | */ 109 | export type Stack = Partial<{ 110 | [Key in keyof T & string]: Listener[]; 111 | }>; 112 | 113 | /** 114 | * Remove all event listeners 115 | */ 116 | export type Clear = ReturnType; 117 | 118 | /** 119 | * Options for customizing the pub-sub instance 120 | */ 121 | export interface PubSubOptions { 122 | async: boolean; 123 | caseInsensitive: boolean; 124 | stack: Stack; 125 | } 126 | 127 | /** 128 | * The pub-sub instance 129 | */ 130 | export interface PubSub { 131 | publish: Publish; 132 | subscribe: Subscribe; 133 | unsubscribe: Unsubscribe; 134 | clear: Clear; 135 | stack: Stack; 136 | } 137 | 138 | /** 139 | * Broadcast channel for global events 140 | */ 141 | const broadcastChannel = new window.BroadcastChannel("pub-sub-es"); 142 | 143 | const isString = (key: unknown): key is string => typeof key === "string"; 144 | 145 | const getEventName = ( 146 | eventName: Key, 147 | caseInsensitive?: boolean, 148 | ) => { 149 | if (isString(eventName) && caseInsensitive) { 150 | return eventName.toLowerCase() as Key; 151 | } 152 | return eventName; 153 | }; 154 | 155 | /** 156 | * Setup subscriber 157 | */ 158 | const createSubscribe = 159 | ( 160 | stack: Stack, 161 | options?: Partial, 162 | ) => 163 | ( 164 | event: Key, 165 | handler: Handler, 166 | times = Number.POSITIVE_INFINITY, 167 | ) => { 168 | const e = getEventName(event, options?.caseInsensitive); 169 | const listeners = stack[e] || []; 170 | 171 | listeners.push({ 172 | handler, 173 | times: +times || Number.POSITIVE_INFINITY, 174 | }); 175 | 176 | stack[e] = listeners; 177 | 178 | return { event: e, handler }; 179 | }; 180 | 181 | const isSubscription = ( 182 | event: Key | Subscription, 183 | ): event is Subscription => typeof event === "object"; 184 | 185 | /** 186 | * Factory function for creating `unsubscribe` 187 | */ 188 | function createUnsubscribe( 189 | stack: Stack, 190 | options?: Partial, 191 | ) { 192 | /** 193 | * Function to unsubscribe from an event 194 | */ 195 | function unsubscribe( 196 | subscription: Subscription, 197 | ): void; 198 | function unsubscribe( 199 | event: Key, 200 | handler: Handler, 201 | ): void; 202 | function unsubscribe( 203 | eventOrSubscription: Key | Subscription, 204 | handlerOrUndefined?: Handler, 205 | ) { 206 | let event: Key; 207 | let handler: Handler; 208 | 209 | if (isSubscription(eventOrSubscription)) { 210 | handler = eventOrSubscription.handler; 211 | event = eventOrSubscription.event; 212 | } else { 213 | event = eventOrSubscription; 214 | // biome-ignore lint/style/noNonNullAssertion: The function overload defines that if `eventOrSubscription` is not a subscription, `handler` must be defined 215 | handler = handlerOrUndefined!; 216 | } 217 | 218 | const e = getEventName(event, options?.caseInsensitive); 219 | const listeners = stack[e]; 220 | 221 | if (!listeners) { 222 | return; 223 | } 224 | 225 | const idx = listeners.findIndex((listener) => listener.handler === handler); 226 | 227 | if (idx === -1 || idx >= listeners.length) { 228 | return; 229 | } 230 | 231 | listeners.splice(idx, 1); 232 | } 233 | 234 | return unsubscribe; 235 | } 236 | 237 | const hasListeners = ( 238 | listeners?: Partial<{ [Key in keyof T & string]: Listener[] }>[Key], 239 | ): listeners is Listener[] => { 240 | return Boolean(listeners); 241 | }; 242 | 243 | /** 244 | * Factory function for create `publish()` 245 | */ 246 | const createPublish = ( 247 | stack: Stack, 248 | options?: Partial, 249 | ): Publish => { 250 | const unsubscribe = createUnsubscribe(stack); 251 | return ( 252 | ...args: undefined extends T[Key] 253 | ? [event: Key, news?: T[Key], callOptions?: Partial] 254 | : [event: Key, news: T[Key], callOptions?: Partial] 255 | ) => { 256 | const [event, news, callOptions] = args; 257 | const eventName = getEventName(event, options?.caseInsensitive); 258 | const listenersOrUndefined = stack[eventName]; 259 | 260 | if (!hasListeners(listenersOrUndefined)) { 261 | return; 262 | } 263 | 264 | const listeners = [...listenersOrUndefined]; 265 | 266 | for (const listener of listeners) { 267 | if (--listener.times < 1) { 268 | unsubscribe(eventName, listener.handler); 269 | } 270 | } 271 | 272 | const isAsync = 273 | callOptions?.async !== undefined ? callOptions.async : options?.async; 274 | 275 | /** 276 | * Inform listeners about some news 277 | */ 278 | const inform = () => { 279 | for (const listener of listeners) { 280 | listener.handler(news as T[Key]); 281 | } 282 | }; 283 | 284 | if (isAsync) { 285 | setTimeout(inform, 0); 286 | } else { 287 | inform(); 288 | } 289 | 290 | if (options?.isGlobal && !callOptions?.isNoGlobalBroadcast) { 291 | try { 292 | broadcastChannel.postMessage({ event: eventName, news }); 293 | } catch (error) { 294 | if (error instanceof Error && error.name === "DataCloneError") { 295 | console.warn( 296 | `Could not broadcast '${eventName.toString()}' globally. Payload is not clonable.`, 297 | ); 298 | } else { 299 | throw error; 300 | } 301 | } 302 | } 303 | }; 304 | }; 305 | 306 | function keys(obj: T): Array { 307 | // @ts-expect-error - Object.keys returns the string keys of our type and omits number & symbol but TS's doesn't type the object this way because there are edge cases 308 | return Object.keys(obj); 309 | } 310 | 311 | /** 312 | * Factory function for creating `clear()` 313 | */ 314 | const createClear = 315 | (stack: Stack) => 316 | () => { 317 | for (const event of keys(stack)) { 318 | delete stack[event]; 319 | } 320 | }; 321 | 322 | /** 323 | * Create a new empty stack object 324 | */ 325 | const createStack = (): Stack => ({}); 326 | 327 | /** 328 | * Create a new pub-sub instance 329 | */ 330 | const createPubSub = ( 331 | options?: Partial>, 332 | ): PubSub => { 333 | const async = Boolean(options?.async); 334 | const caseInsensitive = Boolean(options?.caseInsensitive); 335 | const stack = options?.stack || createStack(); 336 | 337 | return { 338 | publish: createPublish(stack, { async, caseInsensitive }), 339 | subscribe: createSubscribe(stack, { caseInsensitive }), 340 | unsubscribe: createUnsubscribe(stack, { caseInsensitive }), 341 | clear: createClear(stack), 342 | stack, 343 | }; 344 | }; 345 | 346 | /** 347 | * Global pub-sub stack object 348 | */ 349 | const globalPubSubStack = createStack(); 350 | 351 | /** 352 | * Global pub-sub instance 353 | */ 354 | const globalPubSub: PubSub = { 355 | publish: createPublish(globalPubSubStack, { isGlobal: true }), 356 | subscribe: createSubscribe(globalPubSubStack), 357 | unsubscribe: createUnsubscribe(globalPubSubStack), 358 | clear: createClear(globalPubSubStack), 359 | stack: globalPubSubStack, 360 | }; 361 | 362 | broadcastChannel.onmessage = ({ data: { event, news } }) => 363 | globalPubSub.publish(event, news, { isNoGlobalBroadcast: true }); 364 | 365 | export { globalPubSub, createPubSub }; 366 | 367 | export default createPubSub; 368 | -------------------------------------------------------------------------------- /tsconfig.json: -------------------------------------------------------------------------------- 1 | { 2 | "compilerOptions": { 3 | "declaration": true, 4 | "target": "ESNext", 5 | "module": "NodeNext", 6 | "esModuleInterop": true, 7 | "forceConsistentCasingInFileNames": true, 8 | "outDir": "dist", 9 | "strict": true, 10 | "strictNullChecks": true, 11 | "skipLibCheck": true 12 | }, 13 | "files": [ 14 | "src/index.ts" 15 | ] 16 | } 17 | -------------------------------------------------------------------------------- /vite.config.ts: -------------------------------------------------------------------------------- 1 | import { defineConfig } from 'vite'; 2 | import { createHtmlPlugin } from 'vite-plugin-html'; 3 | 4 | export default defineConfig({ 5 | root: '.', 6 | build: { 7 | outDir: './docs' 8 | }, 9 | plugins: [ 10 | createHtmlPlugin({ 11 | entry: './index.js', 12 | template: './example/index.html', 13 | minify: true, 14 | }), 15 | ], 16 | }); 17 | -------------------------------------------------------------------------------- /vitest.config.ts: -------------------------------------------------------------------------------- 1 | import { defineConfig } from 'vitest/config' 2 | 3 | export default defineConfig({ 4 | test: { 5 | coverage: { 6 | include: ['src'], 7 | reporter: ['text', 'json-summary', 'json'], 8 | }, 9 | }, 10 | }) 11 | --------------------------------------------------------------------------------