├── .gitignore ├── .husky ├── .gitignore └── pre-commit ├── .npmignore ├── README.md ├── example ├── index.html ├── main.jsx └── worker.js ├── package-lock.json ├── package.json ├── src ├── use-workerized-reducer.preact.ts ├── use-workerized-reducer.react.ts └── use-workerized-reducer.ts ├── tests ├── basic │ ├── app.jsx │ ├── index.html │ └── worker.js ├── index.html ├── instant-dispatch │ ├── app.jsx │ ├── index.html │ └── worker.js ├── local-state │ ├── app.jsx │ ├── index.html │ └── worker.js ├── multi-component │ ├── app.jsx │ ├── index.html │ └── worker.js ├── remount │ ├── app.jsx │ ├── index.html │ └── worker.js └── test-utils.js ├── vite.baseconfig.js ├── vite.config.generic.js ├── vite.config.preact.js └── vite.config.react.js /.gitignore: -------------------------------------------------------------------------------- 1 | node_modules 2 | dist -------------------------------------------------------------------------------- /.husky/.gitignore: -------------------------------------------------------------------------------- 1 | _ 2 | -------------------------------------------------------------------------------- /.husky/pre-commit: -------------------------------------------------------------------------------- 1 | #!/bin/sh 2 | . "$(dirname "$0")/_/husky.sh" 3 | 4 | npx lint-staged 5 | -------------------------------------------------------------------------------- /.npmignore: -------------------------------------------------------------------------------- 1 | node_modules -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | ## useWorkerizedReducer 2 | 3 | `useWorkerizedReducer` is like `useReducer`, but the reducer runs in a worker. This makes it possible to place long-running computations in the reducer without affecting the responsiveness of the app. 4 | 5 | - Works with both [React] and [Preact]. 6 | - Weighs in at ~5KiB brotli’d. 7 | - Powered by [ImmerJS]. 8 | 9 | ### Example 10 | 11 | ```jsx 12 | // worker.js 13 | import { initWorkerizedReducer } from "use-workerized-reducer"; 14 | 15 | initWorkerizedReducer( 16 | "counter", // Name of the reducer 17 | async (state, action) => { 18 | // Reducers can be async! 19 | // Manipulate `state` directly. ImmerJS will take 20 | // care of maintaining referential equality. 21 | switch (action.type) { 22 | case "increment": 23 | state.counter += 1; 24 | break; 25 | case "decrement": 26 | state.counter -= 1; 27 | break; 28 | default: 29 | throw new Error(); 30 | } 31 | } 32 | ); 33 | 34 | // main.js 35 | import { render, h, Fragment } from "preact"; 36 | import { useWorkerizedReducer } from "use-workerized-reducer/preact"; 37 | 38 | // Spin up the worker running the reducers. 39 | const worker = new Worker(new URL("./worker.js", import.meta.url), { 40 | type: "module", 41 | }); 42 | 43 | function App() { 44 | // A worker can contain multiple reducers, each with a unique name. 45 | // `busy` is true if any action is still being processed. 46 | const [state, dispatch, busy] = useWorkerizedReducer( 47 | worker, 48 | "counter", // Reducer name 49 | { counter: 0 } // Initial state 50 | ); 51 | 52 | return ( 53 | <> 54 | Count: {state.counter} 55 | 58 | 61 | 62 | ); 63 | } 64 | 65 | render(, document.querySelector("main")); 66 | ``` 67 | 68 | ### Browser Support 69 | 70 | `useWorkerizedReducer` works in all browsers. Firefox requires a polyfill. 71 | 72 | (Currently, `useWorkerizedReducer` relies on `WritableStream`, which is available everywhere except Firefox. If you want to support Firefox, I recommend the [web-streams-polyfill].) 73 | 74 | ### Details 75 | 76 | `useWorkerizedReducer` takes care of bringing the functionality of `useReducer` to a worker. It bridges the gap between worker and main thread by duplicating the reducer’s state to the main thread. The reducer manipulates the state object in the worker, and through [ImmerJS] only patches will be `postMessage()`’d to keep the main thread’s copy of the state up-to-date. 77 | 78 | Due to the communication with a worker, `useWorkerizedReducer` is inherently asynchronous. In fact, part of the motivation was to enable long-running reducers, which means considerable time can pass between a `dispatch()` call and the subsequent state change. `useWorkerizedReducer` will fully finish processing an action before starting the next one, even if the reducer is async. 79 | 80 | If a reducer is still running, the `busy` variable returned by `useWorkerizedReducer` will be set to `true`. 81 | 82 | ### API 83 | 84 | #### Exported methods 85 | 86 | ##### `useWorkerizedReducer(worker, name, initialState): [State, DispatchFunc, isBusy];` 87 | 88 | `isBusy` will be `true` until the `initialState` has been successfully replicated to the worker. Afterwards, `isBusy` is true when there actions still being processed, `false` otherwise. 89 | 90 | ##### `initWorkerizedReducer(name, reducerFunc, localState?);` 91 | 92 | `name` is the name of the reducer, which has to be identical to the `name` passed into `useWorkerizedReducer`. `reducerFunc` is a function of type `(state, action, localState) => void | Promise`. It behaves the same as the reducer function you pass to the vanilla `useReducer` hook. In contrast to the reducer functions from the vanilla `useReducer` hook, it is important to manipulate the `state` object directly. ImmerJS is recording the operations performed on the object to generate a patch set. Creating copies of the object will not yield the desired effect. Since the modifications to `state` have to be transferred back to the main thread, the state object can only hold [structured cloneable values]. 93 | 94 | `localState` is optional, and is a function of type `(initialState) => LocalState`. It will be called when a new reducer is being created and is expected to return a new local state instance. Local state will not be transferred to the main thread and therefore can hold references to values that are _not_ structured cloneable, like functions or errors. 95 | 96 | ### Convenience exports 97 | 98 | For React: 99 | 100 | ```js 101 | import { ... } from "use-workerized-reducer/react"; 102 | ``` 103 | 104 | For Preact: 105 | 106 | ```js 107 | import { ... } from "use-workerized-reducer/preact"; 108 | ``` 109 | 110 | If, for some reason, you don’t want to use either of those, you can use the generic export. Note that `useWorkerizedReducer` takes 3 extra parameters, which have to be the `useState`, `useEffect` and `useMemo` hook in that order. 111 | 112 | ```js 113 | import { ... } from "use-workerized-reducer"; 114 | ``` 115 | 116 | --- 117 | 118 | Apache-2.0 119 | 120 | [immerjs]: https://immerjs.github.io/immer/ 121 | [web-streams-polyfill]: https://www.npmjs.com/package/web-streams-polyfill 122 | [react]: https://reactjs.org/ 123 | [preact]: https://preactjs.com/ 124 | [structured cloneable values]: https://developer.mozilla.org/en-US/docs/Web/API/Web_Workers_API/Structured_clone_algorithm#supported_types 125 | -------------------------------------------------------------------------------- /example/index.html: -------------------------------------------------------------------------------- 1 | 2 |
3 | 4 | -------------------------------------------------------------------------------- /example/main.jsx: -------------------------------------------------------------------------------- 1 | /* @jsx h */ 2 | import { render, h } from "preact"; 3 | import { useRef } from "preact/hooks"; 4 | import { useWorkerizedReducer } from "../src/use-workerized-reducer.preact.ts"; 5 | 6 | const w = new Worker(new URL("./worker.js", import.meta.url), { 7 | type: "module", 8 | }); 9 | 10 | function Counter() { 11 | const [state, dispatch, busy] = useWorkerizedReducer(w, "counter", { 12 | counter: 0, 13 | }); 14 | 15 | return ( 16 |
17 | 20 | {state?.counter} 21 | 24 |
25 | ); 26 | } 27 | 28 | function Name() { 29 | const [state, dispatch, busy] = useWorkerizedReducer(w, "name", { 30 | name: "Test", 31 | }); 32 | const ref = useRef(null); 33 | 34 | return ( 35 |
36 | {state?.name} 37 |
38 | 39 | 45 |
46 | ); 47 | } 48 | 49 | function App() { 50 | return ( 51 |
52 | 53 | 54 |
55 | ); 56 | } 57 | 58 | render(, document.querySelector("main")); 59 | -------------------------------------------------------------------------------- /example/worker.js: -------------------------------------------------------------------------------- 1 | import { initWorkerizedReducer } from "../src/use-workerized-reducer.preact.ts"; 2 | 3 | initWorkerizedReducer("counter", (state, { type }) => { 4 | switch (type) { 5 | case "increment": 6 | state.counter += 1; 7 | break; 8 | case "decrement": 9 | state.counter -= 1; 10 | break; 11 | default: 12 | throw new Error(); 13 | } 14 | }); 15 | 16 | initWorkerizedReducer("name", async (state, { append }) => { 17 | await sleep(1000); 18 | state.name += append; 19 | }); 20 | 21 | function sleep(ms) { 22 | return new Promise((resolve) => setTimeout(resolve, ms)); 23 | } 24 | -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "use-workerized-reducer", 3 | "version": "0.0.7", 4 | "lockfileVersion": 2, 5 | "requires": true, 6 | "packages": { 7 | "": { 8 | "name": "use-workerized-reducer", 9 | "version": "0.0.7", 10 | "license": "Apache-2.0", 11 | "dependencies": { 12 | "immer": "^9.0.12", 13 | "npm-run-all": "^4.1.5", 14 | "vite": "^2.8.0-beta.1" 15 | }, 16 | "devDependencies": { 17 | "husky": "^7.0.4", 18 | "lint-staged": "^12.1.7", 19 | "preact": "^10.6.4", 20 | "prettier": "^2.5.1" 21 | } 22 | }, 23 | "node_modules/aggregate-error": { 24 | "version": "3.1.0", 25 | "resolved": "https://registry.npmjs.org/aggregate-error/-/aggregate-error-3.1.0.tgz", 26 | "integrity": "sha512-4I7Td01quW/RpocfNayFdFVk1qSuoh0E7JrbRJ16nH01HhKFQ88INq9Sd+nd72zqRySlr9BmDA8xlEJ6vJMrYA==", 27 | "dev": true, 28 | "dependencies": { 29 | "clean-stack": "^2.0.0", 30 | "indent-string": "^4.0.0" 31 | }, 32 | "engines": { 33 | "node": ">=8" 34 | } 35 | }, 36 | "node_modules/ansi-escapes": { 37 | "version": "4.3.2", 38 | "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-4.3.2.tgz", 39 | "integrity": "sha512-gKXj5ALrKWQLsYG9jlTRmR/xKluxHV+Z9QEwNIgCfM1/uwPMCuzVVnh5mwTd+OuBZcwSIMbqssNWRm1lE51QaQ==", 40 | "dev": true, 41 | "dependencies": { 42 | "type-fest": "^0.21.3" 43 | }, 44 | "engines": { 45 | "node": ">=8" 46 | }, 47 | "funding": { 48 | "url": "https://github.com/sponsors/sindresorhus" 49 | } 50 | }, 51 | "node_modules/ansi-regex": { 52 | "version": "6.0.1", 53 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-6.0.1.tgz", 54 | "integrity": "sha512-n5M855fKb2SsfMIiFFoVrABHJC8QtHwVx+mHWP3QcEqBHYienj5dHSgjbxtC0WEZXYt4wcD6zrQElDPhFuZgfA==", 55 | "dev": true, 56 | "engines": { 57 | "node": ">=12" 58 | }, 59 | "funding": { 60 | "url": "https://github.com/chalk/ansi-regex?sponsor=1" 61 | } 62 | }, 63 | "node_modules/ansi-styles": { 64 | "version": "6.1.0", 65 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-6.1.0.tgz", 66 | "integrity": "sha512-VbqNsoz55SYGczauuup0MFUyXNQviSpFTj1RQtFzmQLk18qbVSpTFFGMT293rmDaQuKCT6InmbuEyUne4mTuxQ==", 67 | "dev": true, 68 | "engines": { 69 | "node": ">=12" 70 | }, 71 | "funding": { 72 | "url": "https://github.com/chalk/ansi-styles?sponsor=1" 73 | } 74 | }, 75 | "node_modules/astral-regex": { 76 | "version": "2.0.0", 77 | "resolved": "https://registry.npmjs.org/astral-regex/-/astral-regex-2.0.0.tgz", 78 | "integrity": "sha512-Z7tMw1ytTXt5jqMcOP+OQteU1VuNK9Y02uuJtKQ1Sv69jXQKKg5cibLwGJow8yzZP+eAc18EmLGPal0bp36rvQ==", 79 | "dev": true, 80 | "engines": { 81 | "node": ">=8" 82 | } 83 | }, 84 | "node_modules/balanced-match": { 85 | "version": "1.0.2", 86 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", 87 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==" 88 | }, 89 | "node_modules/brace-expansion": { 90 | "version": "1.1.11", 91 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 92 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 93 | "dependencies": { 94 | "balanced-match": "^1.0.0", 95 | "concat-map": "0.0.1" 96 | } 97 | }, 98 | "node_modules/braces": { 99 | "version": "3.0.2", 100 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", 101 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", 102 | "dev": true, 103 | "dependencies": { 104 | "fill-range": "^7.0.1" 105 | }, 106 | "engines": { 107 | "node": ">=8" 108 | } 109 | }, 110 | "node_modules/call-bind": { 111 | "version": "1.0.2", 112 | "resolved": "https://registry.npmjs.org/call-bind/-/call-bind-1.0.2.tgz", 113 | "integrity": "sha512-7O+FbCihrB5WGbFYesctwmTKae6rOiIzmz1icreWJ+0aA7LJfuqhEso2T9ncpcFtzMQtzXf2QGGueWJGTYsqrA==", 114 | "dependencies": { 115 | "function-bind": "^1.1.1", 116 | "get-intrinsic": "^1.0.2" 117 | }, 118 | "funding": { 119 | "url": "https://github.com/sponsors/ljharb" 120 | } 121 | }, 122 | "node_modules/chalk": { 123 | "version": "2.4.2", 124 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", 125 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", 126 | "dependencies": { 127 | "ansi-styles": "^3.2.1", 128 | "escape-string-regexp": "^1.0.5", 129 | "supports-color": "^5.3.0" 130 | }, 131 | "engines": { 132 | "node": ">=4" 133 | } 134 | }, 135 | "node_modules/chalk/node_modules/ansi-styles": { 136 | "version": "3.2.1", 137 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 138 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 139 | "dependencies": { 140 | "color-convert": "^1.9.0" 141 | }, 142 | "engines": { 143 | "node": ">=4" 144 | } 145 | }, 146 | "node_modules/chalk/node_modules/color-convert": { 147 | "version": "1.9.3", 148 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", 149 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", 150 | "dependencies": { 151 | "color-name": "1.1.3" 152 | } 153 | }, 154 | "node_modules/chalk/node_modules/color-name": { 155 | "version": "1.1.3", 156 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 157 | "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=" 158 | }, 159 | "node_modules/chalk/node_modules/supports-color": { 160 | "version": "5.5.0", 161 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 162 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 163 | "dependencies": { 164 | "has-flag": "^3.0.0" 165 | }, 166 | "engines": { 167 | "node": ">=4" 168 | } 169 | }, 170 | "node_modules/clean-stack": { 171 | "version": "2.2.0", 172 | "resolved": "https://registry.npmjs.org/clean-stack/-/clean-stack-2.2.0.tgz", 173 | "integrity": "sha512-4diC9HaTE+KRAMWhDhrGOECgWZxoevMc5TlkObMqNSsVU62PYzXZ/SMTjzyGAFF1YusgxGcSWTEXBhp0CPwQ1A==", 174 | "dev": true, 175 | "engines": { 176 | "node": ">=6" 177 | } 178 | }, 179 | "node_modules/cli-cursor": { 180 | "version": "3.1.0", 181 | "resolved": "https://registry.npmjs.org/cli-cursor/-/cli-cursor-3.1.0.tgz", 182 | "integrity": "sha512-I/zHAwsKf9FqGoXM4WWRACob9+SNukZTd94DWF57E4toouRulbCxcUh6RKUEOQlYTHJnzkPMySvPNaaSLNfLZw==", 183 | "dev": true, 184 | "dependencies": { 185 | "restore-cursor": "^3.1.0" 186 | }, 187 | "engines": { 188 | "node": ">=8" 189 | } 190 | }, 191 | "node_modules/cli-truncate": { 192 | "version": "3.1.0", 193 | "resolved": "https://registry.npmjs.org/cli-truncate/-/cli-truncate-3.1.0.tgz", 194 | "integrity": "sha512-wfOBkjXteqSnI59oPcJkcPl/ZmwvMMOj340qUIY1SKZCv0B9Cf4D4fAucRkIKQmsIuYK3x1rrgU7MeGRruiuiA==", 195 | "dev": true, 196 | "dependencies": { 197 | "slice-ansi": "^5.0.0", 198 | "string-width": "^5.0.0" 199 | }, 200 | "engines": { 201 | "node": "^12.20.0 || ^14.13.1 || >=16.0.0" 202 | }, 203 | "funding": { 204 | "url": "https://github.com/sponsors/sindresorhus" 205 | } 206 | }, 207 | "node_modules/color-convert": { 208 | "version": "2.0.1", 209 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 210 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 211 | "dev": true, 212 | "dependencies": { 213 | "color-name": "~1.1.4" 214 | }, 215 | "engines": { 216 | "node": ">=7.0.0" 217 | } 218 | }, 219 | "node_modules/color-name": { 220 | "version": "1.1.4", 221 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 222 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 223 | "dev": true 224 | }, 225 | "node_modules/colorette": { 226 | "version": "2.0.16", 227 | "resolved": "https://registry.npmjs.org/colorette/-/colorette-2.0.16.tgz", 228 | "integrity": "sha512-hUewv7oMjCp+wkBv5Rm0v87eJhq4woh5rSR+42YSQJKecCqgIqNkZ6lAlQms/BwHPJA5NKMRlpxPRv0n8HQW6g==", 229 | "dev": true 230 | }, 231 | "node_modules/commander": { 232 | "version": "8.3.0", 233 | "resolved": "https://registry.npmjs.org/commander/-/commander-8.3.0.tgz", 234 | "integrity": "sha512-OkTL9umf+He2DZkUq8f8J9of7yL6RJKI24dVITBmNfZBmri9zYZQrKkuXiKhyfPSu8tUhnVBB1iKXevvnlR4Ww==", 235 | "dev": true, 236 | "engines": { 237 | "node": ">= 12" 238 | } 239 | }, 240 | "node_modules/concat-map": { 241 | "version": "0.0.1", 242 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 243 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=" 244 | }, 245 | "node_modules/cross-spawn": { 246 | "version": "7.0.3", 247 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz", 248 | "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==", 249 | "dev": true, 250 | "dependencies": { 251 | "path-key": "^3.1.0", 252 | "shebang-command": "^2.0.0", 253 | "which": "^2.0.1" 254 | }, 255 | "engines": { 256 | "node": ">= 8" 257 | } 258 | }, 259 | "node_modules/debug": { 260 | "version": "4.3.3", 261 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.3.tgz", 262 | "integrity": "sha512-/zxw5+vh1Tfv+4Qn7a5nsbcJKPaSvCDhojn6FEl9vupwK2VCSDtEiEtqr8DFtzYFOdz63LBkxec7DYuc2jon6Q==", 263 | "dev": true, 264 | "dependencies": { 265 | "ms": "2.1.2" 266 | }, 267 | "engines": { 268 | "node": ">=6.0" 269 | }, 270 | "peerDependenciesMeta": { 271 | "supports-color": { 272 | "optional": true 273 | } 274 | } 275 | }, 276 | "node_modules/define-properties": { 277 | "version": "1.1.3", 278 | "resolved": "https://registry.npmjs.org/define-properties/-/define-properties-1.1.3.tgz", 279 | "integrity": "sha512-3MqfYKj2lLzdMSf8ZIZE/V+Zuy+BgD6f164e8K2w7dgnpKArBDerGYpM46IYYcjnkdPNMjPk9A6VFB8+3SKlXQ==", 280 | "dependencies": { 281 | "object-keys": "^1.0.12" 282 | }, 283 | "engines": { 284 | "node": ">= 0.4" 285 | } 286 | }, 287 | "node_modules/eastasianwidth": { 288 | "version": "0.2.0", 289 | "resolved": "https://registry.npmjs.org/eastasianwidth/-/eastasianwidth-0.2.0.tgz", 290 | "integrity": "sha512-I88TYZWc9XiYHRQ4/3c5rjjfgkjhLyW2luGIheGERbNQ6OY7yTybanSpDXZa8y7VUP9YmDcYa+eyq4ca7iLqWA==", 291 | "dev": true 292 | }, 293 | "node_modules/emoji-regex": { 294 | "version": "9.2.2", 295 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-9.2.2.tgz", 296 | "integrity": "sha512-L18DaJsXSUk2+42pv8mLs5jJT2hqFkFE4j21wOmgbUqsZ2hL72NsUU785g9RXgo3s0ZNgVl42TiHp3ZtOv/Vyg==", 297 | "dev": true 298 | }, 299 | "node_modules/error-ex": { 300 | "version": "1.3.2", 301 | "resolved": "https://registry.npmjs.org/error-ex/-/error-ex-1.3.2.tgz", 302 | "integrity": "sha512-7dFHNmqeFSEt2ZBsCriorKnn3Z2pj+fd9kmI6QoWw4//DL+icEBfc0U7qJCisqrTsKTjw4fNFy2pW9OqStD84g==", 303 | "dependencies": { 304 | "is-arrayish": "^0.2.1" 305 | } 306 | }, 307 | "node_modules/es-abstract": { 308 | "version": "1.19.1", 309 | "resolved": "https://registry.npmjs.org/es-abstract/-/es-abstract-1.19.1.tgz", 310 | "integrity": "sha512-2vJ6tjA/UfqLm2MPs7jxVybLoB8i1t1Jd9R3kISld20sIxPcTbLuggQOUxeWeAvIUkduv/CfMjuh4WmiXr2v9w==", 311 | "dependencies": { 312 | "call-bind": "^1.0.2", 313 | "es-to-primitive": "^1.2.1", 314 | "function-bind": "^1.1.1", 315 | "get-intrinsic": "^1.1.1", 316 | "get-symbol-description": "^1.0.0", 317 | "has": "^1.0.3", 318 | "has-symbols": "^1.0.2", 319 | "internal-slot": "^1.0.3", 320 | "is-callable": "^1.2.4", 321 | "is-negative-zero": "^2.0.1", 322 | "is-regex": "^1.1.4", 323 | "is-shared-array-buffer": "^1.0.1", 324 | "is-string": "^1.0.7", 325 | "is-weakref": "^1.0.1", 326 | "object-inspect": "^1.11.0", 327 | "object-keys": "^1.1.1", 328 | "object.assign": "^4.1.2", 329 | "string.prototype.trimend": "^1.0.4", 330 | "string.prototype.trimstart": "^1.0.4", 331 | "unbox-primitive": "^1.0.1" 332 | }, 333 | "engines": { 334 | "node": ">= 0.4" 335 | }, 336 | "funding": { 337 | "url": "https://github.com/sponsors/ljharb" 338 | } 339 | }, 340 | "node_modules/es-to-primitive": { 341 | "version": "1.2.1", 342 | "resolved": "https://registry.npmjs.org/es-to-primitive/-/es-to-primitive-1.2.1.tgz", 343 | "integrity": "sha512-QCOllgZJtaUo9miYBcLChTUaHNjJF3PYs1VidD7AwiEj1kYxKeQTctLAezAOH5ZKRH0g2IgPn6KwB4IT8iRpvA==", 344 | "dependencies": { 345 | "is-callable": "^1.1.4", 346 | "is-date-object": "^1.0.1", 347 | "is-symbol": "^1.0.2" 348 | }, 349 | "engines": { 350 | "node": ">= 0.4" 351 | }, 352 | "funding": { 353 | "url": "https://github.com/sponsors/ljharb" 354 | } 355 | }, 356 | "node_modules/esbuild": { 357 | "version": "0.14.3", 358 | "resolved": "https://registry.npmjs.org/esbuild/-/esbuild-0.14.3.tgz", 359 | "integrity": "sha512-zyEC5hkguW2oieXRXp8VJzQdcO/1FxCS5GjzqOHItRlojXnx/cTavsrkxdWvBH9li2lUq0bN+LeeVEmyCwiR/Q==", 360 | "hasInstallScript": true, 361 | "bin": { 362 | "esbuild": "bin/esbuild" 363 | }, 364 | "optionalDependencies": { 365 | "esbuild-android-arm64": "0.14.3", 366 | "esbuild-darwin-64": "0.14.3", 367 | "esbuild-darwin-arm64": "0.14.3", 368 | "esbuild-freebsd-64": "0.14.3", 369 | "esbuild-freebsd-arm64": "0.14.3", 370 | "esbuild-linux-32": "0.14.3", 371 | "esbuild-linux-64": "0.14.3", 372 | "esbuild-linux-arm": "0.14.3", 373 | "esbuild-linux-arm64": "0.14.3", 374 | "esbuild-linux-mips64le": "0.14.3", 375 | "esbuild-linux-ppc64le": "0.14.3", 376 | "esbuild-netbsd-64": "0.14.3", 377 | "esbuild-openbsd-64": "0.14.3", 378 | "esbuild-sunos-64": "0.14.3", 379 | "esbuild-windows-32": "0.14.3", 380 | "esbuild-windows-64": "0.14.3", 381 | "esbuild-windows-arm64": "0.14.3" 382 | } 383 | }, 384 | "node_modules/esbuild-android-arm64": { 385 | "version": "0.14.3", 386 | "resolved": "https://registry.npmjs.org/esbuild-android-arm64/-/esbuild-android-arm64-0.14.3.tgz", 387 | "integrity": "sha512-v/vdnGJiSGWOAXzg422T9qb4S+P3tOaYtc5n3FDR27Bh3/xQDS7PdYz/yY7HhOlVp0eGwWNbPHEi8FcEhXjsuw==", 388 | "cpu": [ 389 | "arm64" 390 | ], 391 | "optional": true, 392 | "os": [ 393 | "android" 394 | ] 395 | }, 396 | "node_modules/esbuild-darwin-64": { 397 | "version": "0.14.3", 398 | "resolved": "https://registry.npmjs.org/esbuild-darwin-64/-/esbuild-darwin-64-0.14.3.tgz", 399 | "integrity": "sha512-swY5OtEg6cfWdgc/XEjkBP7wXSyXXeZHEsWMdh1bDiN1D6GmRphk9SgKFKTj+P3ZHhOGIcC1+UdIwHk5bUcOig==", 400 | "cpu": [ 401 | "x64" 402 | ], 403 | "optional": true, 404 | "os": [ 405 | "darwin" 406 | ] 407 | }, 408 | "node_modules/esbuild-darwin-arm64": { 409 | "version": "0.14.3", 410 | "resolved": "https://registry.npmjs.org/esbuild-darwin-arm64/-/esbuild-darwin-arm64-0.14.3.tgz", 411 | "integrity": "sha512-6i9dXPk8oT87wF6VHmwzSad76eMRU2Rt+GXrwF3Y4DCJgnPssJbabNQ9gurkuEX8M0YnEyJF0d1cR7rpTzcEiA==", 412 | "cpu": [ 413 | "arm64" 414 | ], 415 | "optional": true, 416 | "os": [ 417 | "darwin" 418 | ] 419 | }, 420 | "node_modules/esbuild-freebsd-64": { 421 | "version": "0.14.3", 422 | "resolved": "https://registry.npmjs.org/esbuild-freebsd-64/-/esbuild-freebsd-64-0.14.3.tgz", 423 | "integrity": "sha512-WDY5ENsmyceeE+95U3eI+FM8yARY5akWkf21M/x/+v2P5OVsYqCYELglSeAI5Y7bhteCVV3g4i2fRqtkmprdSA==", 424 | "cpu": [ 425 | "x64" 426 | ], 427 | "optional": true, 428 | "os": [ 429 | "freebsd" 430 | ] 431 | }, 432 | "node_modules/esbuild-freebsd-arm64": { 433 | "version": "0.14.3", 434 | "resolved": "https://registry.npmjs.org/esbuild-freebsd-arm64/-/esbuild-freebsd-arm64-0.14.3.tgz", 435 | "integrity": "sha512-4BEEGcP0wBzg04pCCWXlgaPuksQHHfwHvYgCIsi+7IsuB17ykt6MHhTkHR5b5pjI/jNtRhPfMsDODUyftQJgvw==", 436 | "cpu": [ 437 | "arm64" 438 | ], 439 | "optional": true, 440 | "os": [ 441 | "freebsd" 442 | ] 443 | }, 444 | "node_modules/esbuild-linux-32": { 445 | "version": "0.14.3", 446 | "resolved": "https://registry.npmjs.org/esbuild-linux-32/-/esbuild-linux-32-0.14.3.tgz", 447 | "integrity": "sha512-8yhsnjLG/GwCA1RAIndjmCHWViRB2Ol0XeOh2fCXS9qF8tlVrJB7qAiHZpm2vXx+yjOA/bFLTxzU+5pMKqkn5A==", 448 | "cpu": [ 449 | "ia32" 450 | ], 451 | "optional": true, 452 | "os": [ 453 | "linux" 454 | ] 455 | }, 456 | "node_modules/esbuild-linux-64": { 457 | "version": "0.14.3", 458 | "resolved": "https://registry.npmjs.org/esbuild-linux-64/-/esbuild-linux-64-0.14.3.tgz", 459 | "integrity": "sha512-eNq4aixfbwXHIJq4bQDe+XaSNV1grxqpZYs/zHbp0HGHf6SBNlTI02uyTbYGpIzlXmCEPS9tpPCi7BTU45kcJQ==", 460 | "cpu": [ 461 | "x64" 462 | ], 463 | "optional": true, 464 | "os": [ 465 | "linux" 466 | ] 467 | }, 468 | "node_modules/esbuild-linux-arm": { 469 | "version": "0.14.3", 470 | "resolved": "https://registry.npmjs.org/esbuild-linux-arm/-/esbuild-linux-arm-0.14.3.tgz", 471 | "integrity": "sha512-YcMvJHAQnWrWKb+eLxN9e/iWUC/3w01UF/RXuMknqOW3prX8UQ63QknWz9/RI8BY/sdrdgPEbSmsTU2jy2cayQ==", 472 | "cpu": [ 473 | "arm" 474 | ], 475 | "optional": true, 476 | "os": [ 477 | "linux" 478 | ] 479 | }, 480 | "node_modules/esbuild-linux-arm64": { 481 | "version": "0.14.3", 482 | "resolved": "https://registry.npmjs.org/esbuild-linux-arm64/-/esbuild-linux-arm64-0.14.3.tgz", 483 | "integrity": "sha512-wPLyRoqoV/tEMQ7M24DpAmCMyKqBmtgZY35w2tXM8X5O5b2Ohi7fkPSmd6ZgLIxZIApWt88toA8RT0S7qoxcOA==", 484 | "cpu": [ 485 | "arm64" 486 | ], 487 | "optional": true, 488 | "os": [ 489 | "linux" 490 | ] 491 | }, 492 | "node_modules/esbuild-linux-mips64le": { 493 | "version": "0.14.3", 494 | "resolved": "https://registry.npmjs.org/esbuild-linux-mips64le/-/esbuild-linux-mips64le-0.14.3.tgz", 495 | "integrity": "sha512-DdmfM5rcuoqjQL3px5MbquAjZWnySB5LdTrg52SSapp0gXMnGcsM6GY2WVta02CMKn5qi7WPVG4WbqTWE++tJw==", 496 | "cpu": [ 497 | "mips64el" 498 | ], 499 | "optional": true, 500 | "os": [ 501 | "linux" 502 | ] 503 | }, 504 | "node_modules/esbuild-linux-ppc64le": { 505 | "version": "0.14.3", 506 | "resolved": "https://registry.npmjs.org/esbuild-linux-ppc64le/-/esbuild-linux-ppc64le-0.14.3.tgz", 507 | "integrity": "sha512-ujdqryj0m135Ms9yaNDVFAcLeRtyftM/v2v7Osji5zElf2TivSMdFxdrYnYICuHfkm8c8gHg1ncwqitL0r+nnA==", 508 | "cpu": [ 509 | "ppc64" 510 | ], 511 | "optional": true, 512 | "os": [ 513 | "linux" 514 | ] 515 | }, 516 | "node_modules/esbuild-netbsd-64": { 517 | "version": "0.14.3", 518 | "resolved": "https://registry.npmjs.org/esbuild-netbsd-64/-/esbuild-netbsd-64-0.14.3.tgz", 519 | "integrity": "sha512-Z/UB9OUdwo1KDJCSGnVueDuKowRZRkduLvRMegHtDBHC3lS5LfZ3RdM1i+4MMN9iafyk8Q9FNcqIXI178ZujvA==", 520 | "cpu": [ 521 | "x64" 522 | ], 523 | "optional": true, 524 | "os": [ 525 | "netbsd" 526 | ] 527 | }, 528 | "node_modules/esbuild-openbsd-64": { 529 | "version": "0.14.3", 530 | "resolved": "https://registry.npmjs.org/esbuild-openbsd-64/-/esbuild-openbsd-64-0.14.3.tgz", 531 | "integrity": "sha512-9I1uoMDeogq3zQuTe3qygmXYjImnvc6rBn51LLbLniQDlfvqHPBMnAZ/5KshwtXXIIMkCwByytDZdiuzRRlTvQ==", 532 | "cpu": [ 533 | "x64" 534 | ], 535 | "optional": true, 536 | "os": [ 537 | "openbsd" 538 | ] 539 | }, 540 | "node_modules/esbuild-sunos-64": { 541 | "version": "0.14.3", 542 | "resolved": "https://registry.npmjs.org/esbuild-sunos-64/-/esbuild-sunos-64-0.14.3.tgz", 543 | "integrity": "sha512-pldqx/Adxl4V4ymiyKxOOyJmHn6nUIo3wqk2xBx07iDgmL2XTcDDQd7N4U4QGu9LnYN4ZF+8IdOYa3oRRpbjtg==", 544 | "cpu": [ 545 | "x64" 546 | ], 547 | "optional": true, 548 | "os": [ 549 | "sunos" 550 | ] 551 | }, 552 | "node_modules/esbuild-windows-32": { 553 | "version": "0.14.3", 554 | "resolved": "https://registry.npmjs.org/esbuild-windows-32/-/esbuild-windows-32-0.14.3.tgz", 555 | "integrity": "sha512-AqzvA/KbkC2m3kTXGpljLin3EttRbtoPTfBn6w6n2m9MWkTEbhQbE1ONoOBxhO5tExmyJdL/6B87TJJD5jEFBQ==", 556 | "cpu": [ 557 | "ia32" 558 | ], 559 | "optional": true, 560 | "os": [ 561 | "win32" 562 | ] 563 | }, 564 | "node_modules/esbuild-windows-64": { 565 | "version": "0.14.3", 566 | "resolved": "https://registry.npmjs.org/esbuild-windows-64/-/esbuild-windows-64-0.14.3.tgz", 567 | "integrity": "sha512-HGg3C6113zLGB5hN41PROTnBuoh/arG2lQdOird6xFl9giff1cAfMQOUJUfODKD57dDqHjQ1YGW8gOkg0/IrWw==", 568 | "cpu": [ 569 | "x64" 570 | ], 571 | "optional": true, 572 | "os": [ 573 | "win32" 574 | ] 575 | }, 576 | "node_modules/esbuild-windows-arm64": { 577 | "version": "0.14.3", 578 | "resolved": "https://registry.npmjs.org/esbuild-windows-arm64/-/esbuild-windows-arm64-0.14.3.tgz", 579 | "integrity": "sha512-qB2izYu4VpigGnOrAN2Yv7ICYLZWY/AojZtwFfteViDnHgW4jXPYkHQIXTISJbRz25H2cYiv+MfRQYK31RNjlw==", 580 | "cpu": [ 581 | "arm64" 582 | ], 583 | "optional": true, 584 | "os": [ 585 | "win32" 586 | ] 587 | }, 588 | "node_modules/escape-string-regexp": { 589 | "version": "1.0.5", 590 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", 591 | "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=", 592 | "engines": { 593 | "node": ">=0.8.0" 594 | } 595 | }, 596 | "node_modules/execa": { 597 | "version": "5.1.1", 598 | "resolved": "https://registry.npmjs.org/execa/-/execa-5.1.1.tgz", 599 | "integrity": "sha512-8uSpZZocAZRBAPIEINJj3Lo9HyGitllczc27Eh5YYojjMFMn8yHMDMaUHE2Jqfq05D/wucwI4JGURyXt1vchyg==", 600 | "dev": true, 601 | "dependencies": { 602 | "cross-spawn": "^7.0.3", 603 | "get-stream": "^6.0.0", 604 | "human-signals": "^2.1.0", 605 | "is-stream": "^2.0.0", 606 | "merge-stream": "^2.0.0", 607 | "npm-run-path": "^4.0.1", 608 | "onetime": "^5.1.2", 609 | "signal-exit": "^3.0.3", 610 | "strip-final-newline": "^2.0.0" 611 | }, 612 | "engines": { 613 | "node": ">=10" 614 | }, 615 | "funding": { 616 | "url": "https://github.com/sindresorhus/execa?sponsor=1" 617 | } 618 | }, 619 | "node_modules/fill-range": { 620 | "version": "7.0.1", 621 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", 622 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", 623 | "dev": true, 624 | "dependencies": { 625 | "to-regex-range": "^5.0.1" 626 | }, 627 | "engines": { 628 | "node": ">=8" 629 | } 630 | }, 631 | "node_modules/fsevents": { 632 | "version": "2.3.2", 633 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.2.tgz", 634 | "integrity": "sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==", 635 | "hasInstallScript": true, 636 | "optional": true, 637 | "os": [ 638 | "darwin" 639 | ], 640 | "engines": { 641 | "node": "^8.16.0 || ^10.6.0 || >=11.0.0" 642 | } 643 | }, 644 | "node_modules/function-bind": { 645 | "version": "1.1.1", 646 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", 647 | "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==" 648 | }, 649 | "node_modules/get-intrinsic": { 650 | "version": "1.1.1", 651 | "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.1.1.tgz", 652 | "integrity": "sha512-kWZrnVM42QCiEA2Ig1bG8zjoIMOgxWwYCEeNdwY6Tv/cOSeGpcoX4pXHfKUxNKVoArnrEr2e9srnAxxGIraS9Q==", 653 | "dependencies": { 654 | "function-bind": "^1.1.1", 655 | "has": "^1.0.3", 656 | "has-symbols": "^1.0.1" 657 | }, 658 | "funding": { 659 | "url": "https://github.com/sponsors/ljharb" 660 | } 661 | }, 662 | "node_modules/get-stream": { 663 | "version": "6.0.1", 664 | "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-6.0.1.tgz", 665 | "integrity": "sha512-ts6Wi+2j3jQjqi70w5AlN8DFnkSwC+MqmxEzdEALB2qXZYV3X/b1CTfgPLGJNMeAWxdPfU8FO1ms3NUfaHCPYg==", 666 | "dev": true, 667 | "engines": { 668 | "node": ">=10" 669 | }, 670 | "funding": { 671 | "url": "https://github.com/sponsors/sindresorhus" 672 | } 673 | }, 674 | "node_modules/get-symbol-description": { 675 | "version": "1.0.0", 676 | "resolved": "https://registry.npmjs.org/get-symbol-description/-/get-symbol-description-1.0.0.tgz", 677 | "integrity": "sha512-2EmdH1YvIQiZpltCNgkuiUnyukzxM/R6NDJX31Ke3BG1Nq5b0S2PhX59UKi9vZpPDQVdqn+1IcaAwnzTT5vCjw==", 678 | "dependencies": { 679 | "call-bind": "^1.0.2", 680 | "get-intrinsic": "^1.1.1" 681 | }, 682 | "engines": { 683 | "node": ">= 0.4" 684 | }, 685 | "funding": { 686 | "url": "https://github.com/sponsors/ljharb" 687 | } 688 | }, 689 | "node_modules/graceful-fs": { 690 | "version": "4.2.9", 691 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.9.tgz", 692 | "integrity": "sha512-NtNxqUcXgpW2iMrfqSfR73Glt39K+BLwWsPs94yR63v45T0Wbej7eRmL5cWfwEgqXnmjQp3zaJTshdRW/qC2ZQ==" 693 | }, 694 | "node_modules/has": { 695 | "version": "1.0.3", 696 | "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", 697 | "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", 698 | "dependencies": { 699 | "function-bind": "^1.1.1" 700 | }, 701 | "engines": { 702 | "node": ">= 0.4.0" 703 | } 704 | }, 705 | "node_modules/has-bigints": { 706 | "version": "1.0.1", 707 | "resolved": "https://registry.npmjs.org/has-bigints/-/has-bigints-1.0.1.tgz", 708 | "integrity": "sha512-LSBS2LjbNBTf6287JEbEzvJgftkF5qFkmCo9hDRpAzKhUOlJ+hx8dd4USs00SgsUNwc4617J9ki5YtEClM2ffA==", 709 | "funding": { 710 | "url": "https://github.com/sponsors/ljharb" 711 | } 712 | }, 713 | "node_modules/has-flag": { 714 | "version": "3.0.0", 715 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 716 | "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=", 717 | "engines": { 718 | "node": ">=4" 719 | } 720 | }, 721 | "node_modules/has-symbols": { 722 | "version": "1.0.2", 723 | "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.2.tgz", 724 | "integrity": "sha512-chXa79rL/UC2KlX17jo3vRGz0azaWEx5tGqZg5pO3NUyEJVB17dMruQlzCCOfUvElghKcm5194+BCRvi2Rv/Gw==", 725 | "engines": { 726 | "node": ">= 0.4" 727 | }, 728 | "funding": { 729 | "url": "https://github.com/sponsors/ljharb" 730 | } 731 | }, 732 | "node_modules/has-tostringtag": { 733 | "version": "1.0.0", 734 | "resolved": "https://registry.npmjs.org/has-tostringtag/-/has-tostringtag-1.0.0.tgz", 735 | "integrity": "sha512-kFjcSNhnlGV1kyoGk7OXKSawH5JOb/LzUc5w9B02hOTO0dfFRjbHQKvg1d6cf3HbeUmtU9VbbV3qzZ2Teh97WQ==", 736 | "dependencies": { 737 | "has-symbols": "^1.0.2" 738 | }, 739 | "engines": { 740 | "node": ">= 0.4" 741 | }, 742 | "funding": { 743 | "url": "https://github.com/sponsors/ljharb" 744 | } 745 | }, 746 | "node_modules/hosted-git-info": { 747 | "version": "2.8.9", 748 | "resolved": "https://registry.npmjs.org/hosted-git-info/-/hosted-git-info-2.8.9.tgz", 749 | "integrity": "sha512-mxIDAb9Lsm6DoOJ7xH+5+X4y1LU/4Hi50L9C5sIswK3JzULS4bwk1FvjdBgvYR4bzT4tuUQiC15FE2f5HbLvYw==" 750 | }, 751 | "node_modules/human-signals": { 752 | "version": "2.1.0", 753 | "resolved": "https://registry.npmjs.org/human-signals/-/human-signals-2.1.0.tgz", 754 | "integrity": "sha512-B4FFZ6q/T2jhhksgkbEW3HBvWIfDW85snkQgawt07S7J5QXTk6BkNV+0yAeZrM5QpMAdYlocGoljn0sJ/WQkFw==", 755 | "dev": true, 756 | "engines": { 757 | "node": ">=10.17.0" 758 | } 759 | }, 760 | "node_modules/husky": { 761 | "version": "7.0.4", 762 | "resolved": "https://registry.npmjs.org/husky/-/husky-7.0.4.tgz", 763 | "integrity": "sha512-vbaCKN2QLtP/vD4yvs6iz6hBEo6wkSzs8HpRah1Z6aGmF2KW5PdYuAd7uX5a+OyBZHBhd+TFLqgjUgytQr4RvQ==", 764 | "dev": true, 765 | "bin": { 766 | "husky": "lib/bin.js" 767 | }, 768 | "engines": { 769 | "node": ">=12" 770 | }, 771 | "funding": { 772 | "url": "https://github.com/sponsors/typicode" 773 | } 774 | }, 775 | "node_modules/immer": { 776 | "version": "9.0.12", 777 | "resolved": "https://registry.npmjs.org/immer/-/immer-9.0.12.tgz", 778 | "integrity": "sha512-lk7UNmSbAukB5B6dh9fnh5D0bJTOFKxVg2cyJWTYrWRfhLrLMBquONcUs3aFq507hNoIZEDDh8lb8UtOizSMhA==", 779 | "funding": { 780 | "type": "opencollective", 781 | "url": "https://opencollective.com/immer" 782 | } 783 | }, 784 | "node_modules/indent-string": { 785 | "version": "4.0.0", 786 | "resolved": "https://registry.npmjs.org/indent-string/-/indent-string-4.0.0.tgz", 787 | "integrity": "sha512-EdDDZu4A2OyIK7Lr/2zG+w5jmbuk1DVBnEwREQvBzspBJkCEbRa8GxU1lghYcaGJCnRWibjDXlq779X1/y5xwg==", 788 | "dev": true, 789 | "engines": { 790 | "node": ">=8" 791 | } 792 | }, 793 | "node_modules/internal-slot": { 794 | "version": "1.0.3", 795 | "resolved": "https://registry.npmjs.org/internal-slot/-/internal-slot-1.0.3.tgz", 796 | "integrity": "sha512-O0DB1JC/sPyZl7cIo78n5dR7eUSwwpYPiXRhTzNxZVAMUuB8vlnRFyLxdrVToks6XPLVnFfbzaVd5WLjhgg+vA==", 797 | "dependencies": { 798 | "get-intrinsic": "^1.1.0", 799 | "has": "^1.0.3", 800 | "side-channel": "^1.0.4" 801 | }, 802 | "engines": { 803 | "node": ">= 0.4" 804 | } 805 | }, 806 | "node_modules/is-arrayish": { 807 | "version": "0.2.1", 808 | "resolved": "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.2.1.tgz", 809 | "integrity": "sha1-d8mYQFJ6qOyxqLppe4BkWnqSap0=" 810 | }, 811 | "node_modules/is-bigint": { 812 | "version": "1.0.4", 813 | "resolved": "https://registry.npmjs.org/is-bigint/-/is-bigint-1.0.4.tgz", 814 | "integrity": "sha512-zB9CruMamjym81i2JZ3UMn54PKGsQzsJeo6xvN3HJJ4CAsQNB6iRutp2To77OfCNuoxspsIhzaPoO1zyCEhFOg==", 815 | "dependencies": { 816 | "has-bigints": "^1.0.1" 817 | }, 818 | "funding": { 819 | "url": "https://github.com/sponsors/ljharb" 820 | } 821 | }, 822 | "node_modules/is-boolean-object": { 823 | "version": "1.1.2", 824 | "resolved": "https://registry.npmjs.org/is-boolean-object/-/is-boolean-object-1.1.2.tgz", 825 | "integrity": "sha512-gDYaKHJmnj4aWxyj6YHyXVpdQawtVLHU5cb+eztPGczf6cjuTdwve5ZIEfgXqH4e57An1D1AKf8CZ3kYrQRqYA==", 826 | "dependencies": { 827 | "call-bind": "^1.0.2", 828 | "has-tostringtag": "^1.0.0" 829 | }, 830 | "engines": { 831 | "node": ">= 0.4" 832 | }, 833 | "funding": { 834 | "url": "https://github.com/sponsors/ljharb" 835 | } 836 | }, 837 | "node_modules/is-callable": { 838 | "version": "1.2.4", 839 | "resolved": "https://registry.npmjs.org/is-callable/-/is-callable-1.2.4.tgz", 840 | "integrity": "sha512-nsuwtxZfMX67Oryl9LCQ+upnC0Z0BgpwntpS89m1H/TLF0zNfzfLMV/9Wa/6MZsj0acpEjAO0KF1xT6ZdLl95w==", 841 | "engines": { 842 | "node": ">= 0.4" 843 | }, 844 | "funding": { 845 | "url": "https://github.com/sponsors/ljharb" 846 | } 847 | }, 848 | "node_modules/is-core-module": { 849 | "version": "2.8.1", 850 | "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.8.1.tgz", 851 | "integrity": "sha512-SdNCUs284hr40hFTFP6l0IfZ/RSrMXF3qgoRHd3/79unUTvrFO/JoXwkGm+5J/Oe3E/b5GsnG330uUNgRpu1PA==", 852 | "dependencies": { 853 | "has": "^1.0.3" 854 | }, 855 | "funding": { 856 | "url": "https://github.com/sponsors/ljharb" 857 | } 858 | }, 859 | "node_modules/is-date-object": { 860 | "version": "1.0.5", 861 | "resolved": "https://registry.npmjs.org/is-date-object/-/is-date-object-1.0.5.tgz", 862 | "integrity": "sha512-9YQaSxsAiSwcvS33MBk3wTCVnWK+HhF8VZR2jRxehM16QcVOdHqPn4VPHmRK4lSr38n9JriurInLcP90xsYNfQ==", 863 | "dependencies": { 864 | "has-tostringtag": "^1.0.0" 865 | }, 866 | "engines": { 867 | "node": ">= 0.4" 868 | }, 869 | "funding": { 870 | "url": "https://github.com/sponsors/ljharb" 871 | } 872 | }, 873 | "node_modules/is-fullwidth-code-point": { 874 | "version": "4.0.0", 875 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-4.0.0.tgz", 876 | "integrity": "sha512-O4L094N2/dZ7xqVdrXhh9r1KODPJpFms8B5sGdJLPy664AgvXsreZUyCQQNItZRDlYug4xStLjNp/sz3HvBowQ==", 877 | "dev": true, 878 | "engines": { 879 | "node": ">=12" 880 | }, 881 | "funding": { 882 | "url": "https://github.com/sponsors/sindresorhus" 883 | } 884 | }, 885 | "node_modules/is-negative-zero": { 886 | "version": "2.0.2", 887 | "resolved": "https://registry.npmjs.org/is-negative-zero/-/is-negative-zero-2.0.2.tgz", 888 | "integrity": "sha512-dqJvarLawXsFbNDeJW7zAz8ItJ9cd28YufuuFzh0G8pNHjJMnY08Dv7sYX2uF5UpQOwieAeOExEYAWWfu7ZZUA==", 889 | "engines": { 890 | "node": ">= 0.4" 891 | }, 892 | "funding": { 893 | "url": "https://github.com/sponsors/ljharb" 894 | } 895 | }, 896 | "node_modules/is-number": { 897 | "version": "7.0.0", 898 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 899 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", 900 | "dev": true, 901 | "engines": { 902 | "node": ">=0.12.0" 903 | } 904 | }, 905 | "node_modules/is-number-object": { 906 | "version": "1.0.6", 907 | "resolved": "https://registry.npmjs.org/is-number-object/-/is-number-object-1.0.6.tgz", 908 | "integrity": "sha512-bEVOqiRcvo3zO1+G2lVMy+gkkEm9Yh7cDMRusKKu5ZJKPUYSJwICTKZrNKHA2EbSP0Tu0+6B/emsYNHZyn6K8g==", 909 | "dependencies": { 910 | "has-tostringtag": "^1.0.0" 911 | }, 912 | "engines": { 913 | "node": ">= 0.4" 914 | }, 915 | "funding": { 916 | "url": "https://github.com/sponsors/ljharb" 917 | } 918 | }, 919 | "node_modules/is-regex": { 920 | "version": "1.1.4", 921 | "resolved": "https://registry.npmjs.org/is-regex/-/is-regex-1.1.4.tgz", 922 | "integrity": "sha512-kvRdxDsxZjhzUX07ZnLydzS1TU/TJlTUHHY4YLL87e37oUA49DfkLqgy+VjFocowy29cKvcSiu+kIv728jTTVg==", 923 | "dependencies": { 924 | "call-bind": "^1.0.2", 925 | "has-tostringtag": "^1.0.0" 926 | }, 927 | "engines": { 928 | "node": ">= 0.4" 929 | }, 930 | "funding": { 931 | "url": "https://github.com/sponsors/ljharb" 932 | } 933 | }, 934 | "node_modules/is-shared-array-buffer": { 935 | "version": "1.0.1", 936 | "resolved": "https://registry.npmjs.org/is-shared-array-buffer/-/is-shared-array-buffer-1.0.1.tgz", 937 | "integrity": "sha512-IU0NmyknYZN0rChcKhRO1X8LYz5Isj/Fsqh8NJOSf+N/hCOTwy29F32Ik7a+QszE63IdvmwdTPDd6cZ5pg4cwA==", 938 | "funding": { 939 | "url": "https://github.com/sponsors/ljharb" 940 | } 941 | }, 942 | "node_modules/is-stream": { 943 | "version": "2.0.1", 944 | "resolved": "https://registry.npmjs.org/is-stream/-/is-stream-2.0.1.tgz", 945 | "integrity": "sha512-hFoiJiTl63nn+kstHGBtewWSKnQLpyb155KHheA1l39uvtO9nWIop1p3udqPcUd/xbF1VLMO4n7OI6p7RbngDg==", 946 | "dev": true, 947 | "engines": { 948 | "node": ">=8" 949 | }, 950 | "funding": { 951 | "url": "https://github.com/sponsors/sindresorhus" 952 | } 953 | }, 954 | "node_modules/is-string": { 955 | "version": "1.0.7", 956 | "resolved": "https://registry.npmjs.org/is-string/-/is-string-1.0.7.tgz", 957 | "integrity": "sha512-tE2UXzivje6ofPW7l23cjDOMa09gb7xlAqG6jG5ej6uPV32TlWP3NKPigtaGeHNu9fohccRYvIiZMfOOnOYUtg==", 958 | "dependencies": { 959 | "has-tostringtag": "^1.0.0" 960 | }, 961 | "engines": { 962 | "node": ">= 0.4" 963 | }, 964 | "funding": { 965 | "url": "https://github.com/sponsors/ljharb" 966 | } 967 | }, 968 | "node_modules/is-symbol": { 969 | "version": "1.0.4", 970 | "resolved": "https://registry.npmjs.org/is-symbol/-/is-symbol-1.0.4.tgz", 971 | "integrity": "sha512-C/CPBqKWnvdcxqIARxyOh4v1UUEOCHpgDa0WYgpKDFMszcrPcffg5uhwSgPCLD2WWxmq6isisz87tzT01tuGhg==", 972 | "dependencies": { 973 | "has-symbols": "^1.0.2" 974 | }, 975 | "engines": { 976 | "node": ">= 0.4" 977 | }, 978 | "funding": { 979 | "url": "https://github.com/sponsors/ljharb" 980 | } 981 | }, 982 | "node_modules/is-weakref": { 983 | "version": "1.0.2", 984 | "resolved": "https://registry.npmjs.org/is-weakref/-/is-weakref-1.0.2.tgz", 985 | "integrity": "sha512-qctsuLZmIQ0+vSSMfoVvyFe2+GSEvnmZ2ezTup1SBse9+twCCeial6EEi3Nc2KFcf6+qz2FBPnjXsk8xhKSaPQ==", 986 | "dependencies": { 987 | "call-bind": "^1.0.2" 988 | }, 989 | "funding": { 990 | "url": "https://github.com/sponsors/ljharb" 991 | } 992 | }, 993 | "node_modules/isexe": { 994 | "version": "2.0.0", 995 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 996 | "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=" 997 | }, 998 | "node_modules/json-parse-better-errors": { 999 | "version": "1.0.2", 1000 | "resolved": "https://registry.npmjs.org/json-parse-better-errors/-/json-parse-better-errors-1.0.2.tgz", 1001 | "integrity": "sha512-mrqyZKfX5EhL7hvqcV6WG1yYjnjeuYDzDhhcAAUrq8Po85NBQBJP+ZDUT75qZQ98IkUoBqdkExkukOU7Ts2wrw==" 1002 | }, 1003 | "node_modules/json5": { 1004 | "version": "2.2.0", 1005 | "resolved": "https://registry.npmjs.org/json5/-/json5-2.2.0.tgz", 1006 | "integrity": "sha512-f+8cldu7X/y7RAJurMEJmdoKXGB/X550w2Nr3tTbezL6RwEE/iMcm+tZnXeoZtKuOq6ft8+CqzEkrIgx1fPoQA==", 1007 | "dependencies": { 1008 | "minimist": "^1.2.5" 1009 | }, 1010 | "bin": { 1011 | "json5": "lib/cli.js" 1012 | }, 1013 | "engines": { 1014 | "node": ">=6" 1015 | } 1016 | }, 1017 | "node_modules/lilconfig": { 1018 | "version": "2.0.4", 1019 | "resolved": "https://registry.npmjs.org/lilconfig/-/lilconfig-2.0.4.tgz", 1020 | "integrity": "sha512-bfTIN7lEsiooCocSISTWXkiWJkRqtL9wYtYy+8EK3Y41qh3mpwPU0ycTOgjdY9ErwXCc8QyrQp82bdL0Xkm9yA==", 1021 | "dev": true, 1022 | "engines": { 1023 | "node": ">=10" 1024 | } 1025 | }, 1026 | "node_modules/lint-staged": { 1027 | "version": "12.1.7", 1028 | "resolved": "https://registry.npmjs.org/lint-staged/-/lint-staged-12.1.7.tgz", 1029 | "integrity": "sha512-bltv/ejiLWtowExpjU+s5z8j1Byjg9AlmaAjMmqNbIicY69u6sYIwXGg0dCn0TlkrrY2CphtHIXAkbZ+1VoWQQ==", 1030 | "dev": true, 1031 | "dependencies": { 1032 | "cli-truncate": "^3.1.0", 1033 | "colorette": "^2.0.16", 1034 | "commander": "^8.3.0", 1035 | "debug": "^4.3.3", 1036 | "execa": "^5.1.1", 1037 | "lilconfig": "2.0.4", 1038 | "listr2": "^3.13.5", 1039 | "micromatch": "^4.0.4", 1040 | "normalize-path": "^3.0.0", 1041 | "object-inspect": "^1.11.1", 1042 | "string-argv": "^0.3.1", 1043 | "supports-color": "^9.2.1", 1044 | "yaml": "^1.10.2" 1045 | }, 1046 | "bin": { 1047 | "lint-staged": "bin/lint-staged.js" 1048 | }, 1049 | "engines": { 1050 | "node": "^12.20.0 || ^14.13.1 || >=16.0.0" 1051 | }, 1052 | "funding": { 1053 | "url": "https://opencollective.com/lint-staged" 1054 | } 1055 | }, 1056 | "node_modules/listr2": { 1057 | "version": "3.14.0", 1058 | "resolved": "https://registry.npmjs.org/listr2/-/listr2-3.14.0.tgz", 1059 | "integrity": "sha512-TyWI8G99GX9GjE54cJ+RrNMcIFBfwMPxc3XTFiAYGN4s10hWROGtOg7+O6u6LE3mNkyld7RSLE6nrKBvTfcs3g==", 1060 | "dev": true, 1061 | "dependencies": { 1062 | "cli-truncate": "^2.1.0", 1063 | "colorette": "^2.0.16", 1064 | "log-update": "^4.0.0", 1065 | "p-map": "^4.0.0", 1066 | "rfdc": "^1.3.0", 1067 | "rxjs": "^7.5.1", 1068 | "through": "^2.3.8", 1069 | "wrap-ansi": "^7.0.0" 1070 | }, 1071 | "engines": { 1072 | "node": ">=10.0.0" 1073 | }, 1074 | "peerDependencies": { 1075 | "enquirer": ">= 2.3.0 < 3" 1076 | }, 1077 | "peerDependenciesMeta": { 1078 | "enquirer": { 1079 | "optional": true 1080 | } 1081 | } 1082 | }, 1083 | "node_modules/listr2/node_modules/ansi-regex": { 1084 | "version": "5.0.1", 1085 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 1086 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 1087 | "dev": true, 1088 | "engines": { 1089 | "node": ">=8" 1090 | } 1091 | }, 1092 | "node_modules/listr2/node_modules/ansi-styles": { 1093 | "version": "4.3.0", 1094 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 1095 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 1096 | "dev": true, 1097 | "dependencies": { 1098 | "color-convert": "^2.0.1" 1099 | }, 1100 | "engines": { 1101 | "node": ">=8" 1102 | }, 1103 | "funding": { 1104 | "url": "https://github.com/chalk/ansi-styles?sponsor=1" 1105 | } 1106 | }, 1107 | "node_modules/listr2/node_modules/cli-truncate": { 1108 | "version": "2.1.0", 1109 | "resolved": "https://registry.npmjs.org/cli-truncate/-/cli-truncate-2.1.0.tgz", 1110 | "integrity": "sha512-n8fOixwDD6b/ObinzTrp1ZKFzbgvKZvuz/TvejnLn1aQfC6r52XEx85FmuC+3HI+JM7coBRXUvNqEU2PHVrHpg==", 1111 | "dev": true, 1112 | "dependencies": { 1113 | "slice-ansi": "^3.0.0", 1114 | "string-width": "^4.2.0" 1115 | }, 1116 | "engines": { 1117 | "node": ">=8" 1118 | }, 1119 | "funding": { 1120 | "url": "https://github.com/sponsors/sindresorhus" 1121 | } 1122 | }, 1123 | "node_modules/listr2/node_modules/emoji-regex": { 1124 | "version": "8.0.0", 1125 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 1126 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 1127 | "dev": true 1128 | }, 1129 | "node_modules/listr2/node_modules/is-fullwidth-code-point": { 1130 | "version": "3.0.0", 1131 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 1132 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 1133 | "dev": true, 1134 | "engines": { 1135 | "node": ">=8" 1136 | } 1137 | }, 1138 | "node_modules/listr2/node_modules/slice-ansi": { 1139 | "version": "3.0.0", 1140 | "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-3.0.0.tgz", 1141 | "integrity": "sha512-pSyv7bSTC7ig9Dcgbw9AuRNUb5k5V6oDudjZoMBSr13qpLBG7tB+zgCkARjq7xIUgdz5P1Qe8u+rSGdouOOIyQ==", 1142 | "dev": true, 1143 | "dependencies": { 1144 | "ansi-styles": "^4.0.0", 1145 | "astral-regex": "^2.0.0", 1146 | "is-fullwidth-code-point": "^3.0.0" 1147 | }, 1148 | "engines": { 1149 | "node": ">=8" 1150 | } 1151 | }, 1152 | "node_modules/listr2/node_modules/string-width": { 1153 | "version": "4.2.3", 1154 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", 1155 | "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", 1156 | "dev": true, 1157 | "dependencies": { 1158 | "emoji-regex": "^8.0.0", 1159 | "is-fullwidth-code-point": "^3.0.0", 1160 | "strip-ansi": "^6.0.1" 1161 | }, 1162 | "engines": { 1163 | "node": ">=8" 1164 | } 1165 | }, 1166 | "node_modules/listr2/node_modules/strip-ansi": { 1167 | "version": "6.0.1", 1168 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 1169 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 1170 | "dev": true, 1171 | "dependencies": { 1172 | "ansi-regex": "^5.0.1" 1173 | }, 1174 | "engines": { 1175 | "node": ">=8" 1176 | } 1177 | }, 1178 | "node_modules/load-json-file": { 1179 | "version": "4.0.0", 1180 | "resolved": "https://registry.npmjs.org/load-json-file/-/load-json-file-4.0.0.tgz", 1181 | "integrity": "sha1-L19Fq5HjMhYjT9U62rZo607AmTs=", 1182 | "dependencies": { 1183 | "graceful-fs": "^4.1.2", 1184 | "parse-json": "^4.0.0", 1185 | "pify": "^3.0.0", 1186 | "strip-bom": "^3.0.0" 1187 | }, 1188 | "engines": { 1189 | "node": ">=4" 1190 | } 1191 | }, 1192 | "node_modules/log-update": { 1193 | "version": "4.0.0", 1194 | "resolved": "https://registry.npmjs.org/log-update/-/log-update-4.0.0.tgz", 1195 | "integrity": "sha512-9fkkDevMefjg0mmzWFBW8YkFP91OrizzkW3diF7CpG+S2EYdy4+TVfGwz1zeF8x7hCx1ovSPTOE9Ngib74qqUg==", 1196 | "dev": true, 1197 | "dependencies": { 1198 | "ansi-escapes": "^4.3.0", 1199 | "cli-cursor": "^3.1.0", 1200 | "slice-ansi": "^4.0.0", 1201 | "wrap-ansi": "^6.2.0" 1202 | }, 1203 | "engines": { 1204 | "node": ">=10" 1205 | }, 1206 | "funding": { 1207 | "url": "https://github.com/sponsors/sindresorhus" 1208 | } 1209 | }, 1210 | "node_modules/log-update/node_modules/ansi-regex": { 1211 | "version": "5.0.1", 1212 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 1213 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 1214 | "dev": true, 1215 | "engines": { 1216 | "node": ">=8" 1217 | } 1218 | }, 1219 | "node_modules/log-update/node_modules/ansi-styles": { 1220 | "version": "4.3.0", 1221 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 1222 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 1223 | "dev": true, 1224 | "dependencies": { 1225 | "color-convert": "^2.0.1" 1226 | }, 1227 | "engines": { 1228 | "node": ">=8" 1229 | }, 1230 | "funding": { 1231 | "url": "https://github.com/chalk/ansi-styles?sponsor=1" 1232 | } 1233 | }, 1234 | "node_modules/log-update/node_modules/emoji-regex": { 1235 | "version": "8.0.0", 1236 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 1237 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 1238 | "dev": true 1239 | }, 1240 | "node_modules/log-update/node_modules/is-fullwidth-code-point": { 1241 | "version": "3.0.0", 1242 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 1243 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 1244 | "dev": true, 1245 | "engines": { 1246 | "node": ">=8" 1247 | } 1248 | }, 1249 | "node_modules/log-update/node_modules/slice-ansi": { 1250 | "version": "4.0.0", 1251 | "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-4.0.0.tgz", 1252 | "integrity": "sha512-qMCMfhY040cVHT43K9BFygqYbUPFZKHOg7K73mtTWJRb8pyP3fzf4Ixd5SzdEJQ6MRUg/WBnOLxghZtKKurENQ==", 1253 | "dev": true, 1254 | "dependencies": { 1255 | "ansi-styles": "^4.0.0", 1256 | "astral-regex": "^2.0.0", 1257 | "is-fullwidth-code-point": "^3.0.0" 1258 | }, 1259 | "engines": { 1260 | "node": ">=10" 1261 | }, 1262 | "funding": { 1263 | "url": "https://github.com/chalk/slice-ansi?sponsor=1" 1264 | } 1265 | }, 1266 | "node_modules/log-update/node_modules/string-width": { 1267 | "version": "4.2.3", 1268 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", 1269 | "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", 1270 | "dev": true, 1271 | "dependencies": { 1272 | "emoji-regex": "^8.0.0", 1273 | "is-fullwidth-code-point": "^3.0.0", 1274 | "strip-ansi": "^6.0.1" 1275 | }, 1276 | "engines": { 1277 | "node": ">=8" 1278 | } 1279 | }, 1280 | "node_modules/log-update/node_modules/strip-ansi": { 1281 | "version": "6.0.1", 1282 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 1283 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 1284 | "dev": true, 1285 | "dependencies": { 1286 | "ansi-regex": "^5.0.1" 1287 | }, 1288 | "engines": { 1289 | "node": ">=8" 1290 | } 1291 | }, 1292 | "node_modules/log-update/node_modules/wrap-ansi": { 1293 | "version": "6.2.0", 1294 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-6.2.0.tgz", 1295 | "integrity": "sha512-r6lPcBGxZXlIcymEu7InxDMhdW0KDxpLgoFLcguasxCaJ/SOIZwINatK9KY/tf+ZrlywOKU0UDj3ATXUBfxJXA==", 1296 | "dev": true, 1297 | "dependencies": { 1298 | "ansi-styles": "^4.0.0", 1299 | "string-width": "^4.1.0", 1300 | "strip-ansi": "^6.0.0" 1301 | }, 1302 | "engines": { 1303 | "node": ">=8" 1304 | } 1305 | }, 1306 | "node_modules/memorystream": { 1307 | "version": "0.3.1", 1308 | "resolved": "https://registry.npmjs.org/memorystream/-/memorystream-0.3.1.tgz", 1309 | "integrity": "sha1-htcJCzDORV1j+64S3aUaR93K+bI=", 1310 | "engines": { 1311 | "node": ">= 0.10.0" 1312 | } 1313 | }, 1314 | "node_modules/merge-stream": { 1315 | "version": "2.0.0", 1316 | "resolved": "https://registry.npmjs.org/merge-stream/-/merge-stream-2.0.0.tgz", 1317 | "integrity": "sha512-abv/qOcuPfk3URPfDzmZU1LKmuw8kT+0nIHvKrKgFrwifol/doWcdA4ZqsWQ8ENrFKkd67Mfpo/LovbIUsbt3w==", 1318 | "dev": true 1319 | }, 1320 | "node_modules/micromatch": { 1321 | "version": "4.0.4", 1322 | "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-4.0.4.tgz", 1323 | "integrity": "sha512-pRmzw/XUcwXGpD9aI9q/0XOwLNygjETJ8y0ao0wdqprrzDa4YnxLcz7fQRZr8voh8V10kGhABbNcHVk5wHgWwg==", 1324 | "dev": true, 1325 | "dependencies": { 1326 | "braces": "^3.0.1", 1327 | "picomatch": "^2.2.3" 1328 | }, 1329 | "engines": { 1330 | "node": ">=8.6" 1331 | } 1332 | }, 1333 | "node_modules/mimic-fn": { 1334 | "version": "2.1.0", 1335 | "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-2.1.0.tgz", 1336 | "integrity": "sha512-OqbOk5oEQeAZ8WXWydlu9HJjz9WVdEIvamMCcXmuqUYjTknH/sqsWvhQ3vgwKFRR1HpjvNBKQ37nbJgYzGqGcg==", 1337 | "dev": true, 1338 | "engines": { 1339 | "node": ">=6" 1340 | } 1341 | }, 1342 | "node_modules/minimatch": { 1343 | "version": "3.0.4", 1344 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", 1345 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 1346 | "dependencies": { 1347 | "brace-expansion": "^1.1.7" 1348 | }, 1349 | "engines": { 1350 | "node": "*" 1351 | } 1352 | }, 1353 | "node_modules/minimist": { 1354 | "version": "1.2.5", 1355 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.5.tgz", 1356 | "integrity": "sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw==" 1357 | }, 1358 | "node_modules/ms": { 1359 | "version": "2.1.2", 1360 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 1361 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 1362 | "dev": true 1363 | }, 1364 | "node_modules/nanoid": { 1365 | "version": "3.1.31", 1366 | "resolved": "https://registry.npmjs.org/nanoid/-/nanoid-3.1.31.tgz", 1367 | "integrity": "sha512-ZivnJm0o9bb13p2Ot5CpgC2rQdzB9Uxm/mFZweqm5eMViqOJe3PV6LU2E30SiLgheesmcPrjquqraoolONSA0A==", 1368 | "bin": { 1369 | "nanoid": "bin/nanoid.cjs" 1370 | }, 1371 | "engines": { 1372 | "node": "^10 || ^12 || ^13.7 || ^14 || >=15.0.1" 1373 | } 1374 | }, 1375 | "node_modules/nice-try": { 1376 | "version": "1.0.5", 1377 | "resolved": "https://registry.npmjs.org/nice-try/-/nice-try-1.0.5.tgz", 1378 | "integrity": "sha512-1nh45deeb5olNY7eX82BkPO7SSxR5SSYJiPTrTdFUVYwAl8CKMA5N9PjTYkHiRjisVcxcQ1HXdLhx2qxxJzLNQ==" 1379 | }, 1380 | "node_modules/normalize-package-data": { 1381 | "version": "2.5.0", 1382 | "resolved": "https://registry.npmjs.org/normalize-package-data/-/normalize-package-data-2.5.0.tgz", 1383 | "integrity": "sha512-/5CMN3T0R4XTj4DcGaexo+roZSdSFW/0AOOTROrjxzCG1wrWXEsGbRKevjlIL+ZDE4sZlJr5ED4YW0yqmkK+eA==", 1384 | "dependencies": { 1385 | "hosted-git-info": "^2.1.4", 1386 | "resolve": "^1.10.0", 1387 | "semver": "2 || 3 || 4 || 5", 1388 | "validate-npm-package-license": "^3.0.1" 1389 | } 1390 | }, 1391 | "node_modules/normalize-path": { 1392 | "version": "3.0.0", 1393 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", 1394 | "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", 1395 | "dev": true, 1396 | "engines": { 1397 | "node": ">=0.10.0" 1398 | } 1399 | }, 1400 | "node_modules/npm-run-all": { 1401 | "version": "4.1.5", 1402 | "resolved": "https://registry.npmjs.org/npm-run-all/-/npm-run-all-4.1.5.tgz", 1403 | "integrity": "sha512-Oo82gJDAVcaMdi3nuoKFavkIHBRVqQ1qvMb+9LHk/cF4P6B2m8aP04hGf7oL6wZ9BuGwX1onlLhpuoofSyoQDQ==", 1404 | "dependencies": { 1405 | "ansi-styles": "^3.2.1", 1406 | "chalk": "^2.4.1", 1407 | "cross-spawn": "^6.0.5", 1408 | "memorystream": "^0.3.1", 1409 | "minimatch": "^3.0.4", 1410 | "pidtree": "^0.3.0", 1411 | "read-pkg": "^3.0.0", 1412 | "shell-quote": "^1.6.1", 1413 | "string.prototype.padend": "^3.0.0" 1414 | }, 1415 | "bin": { 1416 | "npm-run-all": "bin/npm-run-all/index.js", 1417 | "run-p": "bin/run-p/index.js", 1418 | "run-s": "bin/run-s/index.js" 1419 | }, 1420 | "engines": { 1421 | "node": ">= 4" 1422 | } 1423 | }, 1424 | "node_modules/npm-run-all/node_modules/ansi-styles": { 1425 | "version": "3.2.1", 1426 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 1427 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 1428 | "dependencies": { 1429 | "color-convert": "^1.9.0" 1430 | }, 1431 | "engines": { 1432 | "node": ">=4" 1433 | } 1434 | }, 1435 | "node_modules/npm-run-all/node_modules/color-convert": { 1436 | "version": "1.9.3", 1437 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", 1438 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", 1439 | "dependencies": { 1440 | "color-name": "1.1.3" 1441 | } 1442 | }, 1443 | "node_modules/npm-run-all/node_modules/color-name": { 1444 | "version": "1.1.3", 1445 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 1446 | "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=" 1447 | }, 1448 | "node_modules/npm-run-all/node_modules/cross-spawn": { 1449 | "version": "6.0.5", 1450 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-6.0.5.tgz", 1451 | "integrity": "sha512-eTVLrBSt7fjbDygz805pMnstIs2VTBNkRm0qxZd+M7A5XDdxVRWO5MxGBXZhjY4cqLYLdtrGqRf8mBPmzwSpWQ==", 1452 | "dependencies": { 1453 | "nice-try": "^1.0.4", 1454 | "path-key": "^2.0.1", 1455 | "semver": "^5.5.0", 1456 | "shebang-command": "^1.2.0", 1457 | "which": "^1.2.9" 1458 | }, 1459 | "engines": { 1460 | "node": ">=4.8" 1461 | } 1462 | }, 1463 | "node_modules/npm-run-all/node_modules/path-key": { 1464 | "version": "2.0.1", 1465 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-2.0.1.tgz", 1466 | "integrity": "sha1-QRyttXTFoUDTpLGRDUDYDMn0C0A=", 1467 | "engines": { 1468 | "node": ">=4" 1469 | } 1470 | }, 1471 | "node_modules/npm-run-all/node_modules/shebang-command": { 1472 | "version": "1.2.0", 1473 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-1.2.0.tgz", 1474 | "integrity": "sha1-RKrGW2lbAzmJaMOfNj/uXer98eo=", 1475 | "dependencies": { 1476 | "shebang-regex": "^1.0.0" 1477 | }, 1478 | "engines": { 1479 | "node": ">=0.10.0" 1480 | } 1481 | }, 1482 | "node_modules/npm-run-all/node_modules/shebang-regex": { 1483 | "version": "1.0.0", 1484 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-1.0.0.tgz", 1485 | "integrity": "sha1-2kL0l0DAtC2yypcoVxyxkMmO/qM=", 1486 | "engines": { 1487 | "node": ">=0.10.0" 1488 | } 1489 | }, 1490 | "node_modules/npm-run-all/node_modules/which": { 1491 | "version": "1.3.1", 1492 | "resolved": "https://registry.npmjs.org/which/-/which-1.3.1.tgz", 1493 | "integrity": "sha512-HxJdYWq1MTIQbJ3nw0cqssHoTNU267KlrDuGZ1WYlxDStUtKUhOaJmh112/TZmHxxUfuJqPXSOm7tDyas0OSIQ==", 1494 | "dependencies": { 1495 | "isexe": "^2.0.0" 1496 | }, 1497 | "bin": { 1498 | "which": "bin/which" 1499 | } 1500 | }, 1501 | "node_modules/npm-run-path": { 1502 | "version": "4.0.1", 1503 | "resolved": "https://registry.npmjs.org/npm-run-path/-/npm-run-path-4.0.1.tgz", 1504 | "integrity": "sha512-S48WzZW777zhNIrn7gxOlISNAqi9ZC/uQFnRdbeIHhZhCA6UqpkOT8T1G7BvfdgP4Er8gF4sUbaS0i7QvIfCWw==", 1505 | "dev": true, 1506 | "dependencies": { 1507 | "path-key": "^3.0.0" 1508 | }, 1509 | "engines": { 1510 | "node": ">=8" 1511 | } 1512 | }, 1513 | "node_modules/object-inspect": { 1514 | "version": "1.12.0", 1515 | "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.12.0.tgz", 1516 | "integrity": "sha512-Ho2z80bVIvJloH+YzRmpZVQe87+qASmBUKZDWgx9cu+KDrX2ZDH/3tMy+gXbZETVGs2M8YdxObOh7XAtim9Y0g==", 1517 | "funding": { 1518 | "url": "https://github.com/sponsors/ljharb" 1519 | } 1520 | }, 1521 | "node_modules/object-keys": { 1522 | "version": "1.1.1", 1523 | "resolved": "https://registry.npmjs.org/object-keys/-/object-keys-1.1.1.tgz", 1524 | "integrity": "sha512-NuAESUOUMrlIXOfHKzD6bpPu3tYt3xvjNdRIQ+FeT0lNb4K8WR70CaDxhuNguS2XG+GjkyMwOzsN5ZktImfhLA==", 1525 | "engines": { 1526 | "node": ">= 0.4" 1527 | } 1528 | }, 1529 | "node_modules/object.assign": { 1530 | "version": "4.1.2", 1531 | "resolved": "https://registry.npmjs.org/object.assign/-/object.assign-4.1.2.tgz", 1532 | "integrity": "sha512-ixT2L5THXsApyiUPYKmW+2EHpXXe5Ii3M+f4e+aJFAHao5amFRW6J0OO6c/LU8Be47utCx2GL89hxGB6XSmKuQ==", 1533 | "dependencies": { 1534 | "call-bind": "^1.0.0", 1535 | "define-properties": "^1.1.3", 1536 | "has-symbols": "^1.0.1", 1537 | "object-keys": "^1.1.1" 1538 | }, 1539 | "engines": { 1540 | "node": ">= 0.4" 1541 | }, 1542 | "funding": { 1543 | "url": "https://github.com/sponsors/ljharb" 1544 | } 1545 | }, 1546 | "node_modules/onetime": { 1547 | "version": "5.1.2", 1548 | "resolved": "https://registry.npmjs.org/onetime/-/onetime-5.1.2.tgz", 1549 | "integrity": "sha512-kbpaSSGJTWdAY5KPVeMOKXSrPtr8C8C7wodJbcsd51jRnmD+GZu8Y0VoU6Dm5Z4vWr0Ig/1NKuWRKf7j5aaYSg==", 1550 | "dev": true, 1551 | "dependencies": { 1552 | "mimic-fn": "^2.1.0" 1553 | }, 1554 | "engines": { 1555 | "node": ">=6" 1556 | }, 1557 | "funding": { 1558 | "url": "https://github.com/sponsors/sindresorhus" 1559 | } 1560 | }, 1561 | "node_modules/p-map": { 1562 | "version": "4.0.0", 1563 | "resolved": "https://registry.npmjs.org/p-map/-/p-map-4.0.0.tgz", 1564 | "integrity": "sha512-/bjOqmgETBYB5BoEeGVea8dmvHb2m9GLy1E9W43yeyfP6QQCZGFNa+XRceJEuDB6zqr+gKpIAmlLebMpykw/MQ==", 1565 | "dev": true, 1566 | "dependencies": { 1567 | "aggregate-error": "^3.0.0" 1568 | }, 1569 | "engines": { 1570 | "node": ">=10" 1571 | }, 1572 | "funding": { 1573 | "url": "https://github.com/sponsors/sindresorhus" 1574 | } 1575 | }, 1576 | "node_modules/parse-json": { 1577 | "version": "4.0.0", 1578 | "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-4.0.0.tgz", 1579 | "integrity": "sha1-vjX1Qlvh9/bHRxhPmKeIy5lHfuA=", 1580 | "dependencies": { 1581 | "error-ex": "^1.3.1", 1582 | "json-parse-better-errors": "^1.0.1" 1583 | }, 1584 | "engines": { 1585 | "node": ">=4" 1586 | } 1587 | }, 1588 | "node_modules/path-key": { 1589 | "version": "3.1.1", 1590 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", 1591 | "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", 1592 | "dev": true, 1593 | "engines": { 1594 | "node": ">=8" 1595 | } 1596 | }, 1597 | "node_modules/path-parse": { 1598 | "version": "1.0.7", 1599 | "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.7.tgz", 1600 | "integrity": "sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==" 1601 | }, 1602 | "node_modules/path-type": { 1603 | "version": "3.0.0", 1604 | "resolved": "https://registry.npmjs.org/path-type/-/path-type-3.0.0.tgz", 1605 | "integrity": "sha512-T2ZUsdZFHgA3u4e5PfPbjd7HDDpxPnQb5jN0SrDsjNSuVXHJqtwTnWqG0B1jZrgmJ/7lj1EmVIByWt1gxGkWvg==", 1606 | "dependencies": { 1607 | "pify": "^3.0.0" 1608 | }, 1609 | "engines": { 1610 | "node": ">=4" 1611 | } 1612 | }, 1613 | "node_modules/picocolors": { 1614 | "version": "1.0.0", 1615 | "resolved": "https://registry.npmjs.org/picocolors/-/picocolors-1.0.0.tgz", 1616 | "integrity": "sha512-1fygroTLlHu66zi26VoTDv8yRgm0Fccecssto+MhsZ0D/DGW2sm8E8AjW7NU5VVTRt5GxbeZ5qBuJr+HyLYkjQ==" 1617 | }, 1618 | "node_modules/picomatch": { 1619 | "version": "2.3.1", 1620 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz", 1621 | "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==", 1622 | "dev": true, 1623 | "engines": { 1624 | "node": ">=8.6" 1625 | }, 1626 | "funding": { 1627 | "url": "https://github.com/sponsors/jonschlinkert" 1628 | } 1629 | }, 1630 | "node_modules/pidtree": { 1631 | "version": "0.3.1", 1632 | "resolved": "https://registry.npmjs.org/pidtree/-/pidtree-0.3.1.tgz", 1633 | "integrity": "sha512-qQbW94hLHEqCg7nhby4yRC7G2+jYHY4Rguc2bjw7Uug4GIJuu1tvf2uHaZv5Q8zdt+WKJ6qK1FOI6amaWUo5FA==", 1634 | "bin": { 1635 | "pidtree": "bin/pidtree.js" 1636 | }, 1637 | "engines": { 1638 | "node": ">=0.10" 1639 | } 1640 | }, 1641 | "node_modules/pify": { 1642 | "version": "3.0.0", 1643 | "resolved": "https://registry.npmjs.org/pify/-/pify-3.0.0.tgz", 1644 | "integrity": "sha1-5aSs0sEB/fPZpNB/DbxNtJ3SgXY=", 1645 | "engines": { 1646 | "node": ">=4" 1647 | } 1648 | }, 1649 | "node_modules/postcss": { 1650 | "version": "8.4.5", 1651 | "resolved": "https://registry.npmjs.org/postcss/-/postcss-8.4.5.tgz", 1652 | "integrity": "sha512-jBDboWM8qpaqwkMwItqTQTiFikhs/67OYVvblFFTM7MrZjt6yMKd6r2kgXizEbTTljacm4NldIlZnhbjr84QYg==", 1653 | "dependencies": { 1654 | "nanoid": "^3.1.30", 1655 | "picocolors": "^1.0.0", 1656 | "source-map-js": "^1.0.1" 1657 | }, 1658 | "engines": { 1659 | "node": "^10 || ^12 || >=14" 1660 | }, 1661 | "funding": { 1662 | "type": "opencollective", 1663 | "url": "https://opencollective.com/postcss/" 1664 | } 1665 | }, 1666 | "node_modules/preact": { 1667 | "version": "10.6.4", 1668 | "resolved": "https://registry.npmjs.org/preact/-/preact-10.6.4.tgz", 1669 | "integrity": "sha512-WyosM7pxGcndU8hY0OQlLd54tOU+qmG45QXj2dAYrL11HoyU/EzOSTlpJsirbBr1QW7lICxSsVJJmcmUglovHQ==", 1670 | "dev": true, 1671 | "funding": { 1672 | "type": "opencollective", 1673 | "url": "https://opencollective.com/preact" 1674 | } 1675 | }, 1676 | "node_modules/prettier": { 1677 | "version": "2.5.1", 1678 | "resolved": "https://registry.npmjs.org/prettier/-/prettier-2.5.1.tgz", 1679 | "integrity": "sha512-vBZcPRUR5MZJwoyi3ZoyQlc1rXeEck8KgeC9AwwOn+exuxLxq5toTRDTSaVrXHxelDMHy9zlicw8u66yxoSUFg==", 1680 | "dev": true, 1681 | "bin": { 1682 | "prettier": "bin-prettier.js" 1683 | }, 1684 | "engines": { 1685 | "node": ">=10.13.0" 1686 | } 1687 | }, 1688 | "node_modules/read-pkg": { 1689 | "version": "3.0.0", 1690 | "resolved": "https://registry.npmjs.org/read-pkg/-/read-pkg-3.0.0.tgz", 1691 | "integrity": "sha1-nLxoaXj+5l0WwA4rGcI3/Pbjg4k=", 1692 | "dependencies": { 1693 | "load-json-file": "^4.0.0", 1694 | "normalize-package-data": "^2.3.2", 1695 | "path-type": "^3.0.0" 1696 | }, 1697 | "engines": { 1698 | "node": ">=4" 1699 | } 1700 | }, 1701 | "node_modules/resolve": { 1702 | "version": "1.21.0", 1703 | "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.21.0.tgz", 1704 | "integrity": "sha512-3wCbTpk5WJlyE4mSOtDLhqQmGFi0/TD9VPwmiolnk8U0wRgMEktqCXd3vy5buTO3tljvalNvKrjHEfrd2WpEKA==", 1705 | "dependencies": { 1706 | "is-core-module": "^2.8.0", 1707 | "path-parse": "^1.0.7", 1708 | "supports-preserve-symlinks-flag": "^1.0.0" 1709 | }, 1710 | "bin": { 1711 | "resolve": "bin/resolve" 1712 | }, 1713 | "funding": { 1714 | "url": "https://github.com/sponsors/ljharb" 1715 | } 1716 | }, 1717 | "node_modules/restore-cursor": { 1718 | "version": "3.1.0", 1719 | "resolved": "https://registry.npmjs.org/restore-cursor/-/restore-cursor-3.1.0.tgz", 1720 | "integrity": "sha512-l+sSefzHpj5qimhFSE5a8nufZYAM3sBSVMAPtYkmC+4EH2anSGaEMXSD0izRQbu9nfyQ9y5JrVmp7E8oZrUjvA==", 1721 | "dev": true, 1722 | "dependencies": { 1723 | "onetime": "^5.1.0", 1724 | "signal-exit": "^3.0.2" 1725 | }, 1726 | "engines": { 1727 | "node": ">=8" 1728 | } 1729 | }, 1730 | "node_modules/rfdc": { 1731 | "version": "1.3.0", 1732 | "resolved": "https://registry.npmjs.org/rfdc/-/rfdc-1.3.0.tgz", 1733 | "integrity": "sha512-V2hovdzFbOi77/WajaSMXk2OLm+xNIeQdMMuB7icj7bk6zi2F8GGAxigcnDFpJHbNyNcgyJDiP+8nOrY5cZGrA==", 1734 | "dev": true 1735 | }, 1736 | "node_modules/rollup": { 1737 | "version": "2.63.0", 1738 | "resolved": "https://registry.npmjs.org/rollup/-/rollup-2.63.0.tgz", 1739 | "integrity": "sha512-nps0idjmD+NXl6OREfyYXMn/dar3WGcyKn+KBzPdaLecub3x/LrId0wUcthcr8oZUAcZAR8NKcfGGFlNgGL1kQ==", 1740 | "bin": { 1741 | "rollup": "dist/bin/rollup" 1742 | }, 1743 | "engines": { 1744 | "node": ">=10.0.0" 1745 | }, 1746 | "optionalDependencies": { 1747 | "fsevents": "~2.3.2" 1748 | } 1749 | }, 1750 | "node_modules/rxjs": { 1751 | "version": "7.5.2", 1752 | "resolved": "https://registry.npmjs.org/rxjs/-/rxjs-7.5.2.tgz", 1753 | "integrity": "sha512-PwDt186XaL3QN5qXj/H9DGyHhP3/RYYgZZwqBv9Tv8rsAaiwFH1IsJJlcgD37J7UW5a6O67qX0KWKS3/pu0m4w==", 1754 | "dev": true, 1755 | "dependencies": { 1756 | "tslib": "^2.1.0" 1757 | } 1758 | }, 1759 | "node_modules/semver": { 1760 | "version": "5.7.1", 1761 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", 1762 | "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==", 1763 | "bin": { 1764 | "semver": "bin/semver" 1765 | } 1766 | }, 1767 | "node_modules/shebang-command": { 1768 | "version": "2.0.0", 1769 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", 1770 | "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", 1771 | "dev": true, 1772 | "dependencies": { 1773 | "shebang-regex": "^3.0.0" 1774 | }, 1775 | "engines": { 1776 | "node": ">=8" 1777 | } 1778 | }, 1779 | "node_modules/shebang-regex": { 1780 | "version": "3.0.0", 1781 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", 1782 | "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", 1783 | "dev": true, 1784 | "engines": { 1785 | "node": ">=8" 1786 | } 1787 | }, 1788 | "node_modules/shell-quote": { 1789 | "version": "1.7.3", 1790 | "resolved": "https://registry.npmjs.org/shell-quote/-/shell-quote-1.7.3.tgz", 1791 | "integrity": "sha512-Vpfqwm4EnqGdlsBFNmHhxhElJYrdfcxPThu+ryKS5J8L/fhAwLazFZtq+S+TWZ9ANj2piSQLGj6NQg+lKPmxrw==" 1792 | }, 1793 | "node_modules/side-channel": { 1794 | "version": "1.0.4", 1795 | "resolved": "https://registry.npmjs.org/side-channel/-/side-channel-1.0.4.tgz", 1796 | "integrity": "sha512-q5XPytqFEIKHkGdiMIrY10mvLRvnQh42/+GoBlFW3b2LXLE2xxJpZFdm94we0BaoV3RwJyGqg5wS7epxTv0Zvw==", 1797 | "dependencies": { 1798 | "call-bind": "^1.0.0", 1799 | "get-intrinsic": "^1.0.2", 1800 | "object-inspect": "^1.9.0" 1801 | }, 1802 | "funding": { 1803 | "url": "https://github.com/sponsors/ljharb" 1804 | } 1805 | }, 1806 | "node_modules/signal-exit": { 1807 | "version": "3.0.6", 1808 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.6.tgz", 1809 | "integrity": "sha512-sDl4qMFpijcGw22U5w63KmD3cZJfBuFlVNbVMKje2keoKML7X2UzWbc4XrmEbDwg0NXJc3yv4/ox7b+JWb57kQ==", 1810 | "dev": true 1811 | }, 1812 | "node_modules/slice-ansi": { 1813 | "version": "5.0.0", 1814 | "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-5.0.0.tgz", 1815 | "integrity": "sha512-FC+lgizVPfie0kkhqUScwRu1O/lF6NOgJmlCgK+/LYxDCTk8sGelYaHDhFcDN+Sn3Cv+3VSa4Byeo+IMCzpMgQ==", 1816 | "dev": true, 1817 | "dependencies": { 1818 | "ansi-styles": "^6.0.0", 1819 | "is-fullwidth-code-point": "^4.0.0" 1820 | }, 1821 | "engines": { 1822 | "node": ">=12" 1823 | }, 1824 | "funding": { 1825 | "url": "https://github.com/chalk/slice-ansi?sponsor=1" 1826 | } 1827 | }, 1828 | "node_modules/source-map-js": { 1829 | "version": "1.0.1", 1830 | "resolved": "https://registry.npmjs.org/source-map-js/-/source-map-js-1.0.1.tgz", 1831 | "integrity": "sha512-4+TN2b3tqOCd/kaGRJ/sTYA0tR0mdXx26ipdolxcwtJVqEnqNYvlCAt1q3ypy4QMlYus+Zh34RNtYLoq2oQ4IA==", 1832 | "engines": { 1833 | "node": ">=0.10.0" 1834 | } 1835 | }, 1836 | "node_modules/spdx-correct": { 1837 | "version": "3.1.1", 1838 | "resolved": "https://registry.npmjs.org/spdx-correct/-/spdx-correct-3.1.1.tgz", 1839 | "integrity": "sha512-cOYcUWwhCuHCXi49RhFRCyJEK3iPj1Ziz9DpViV3tbZOwXD49QzIN3MpOLJNxh2qwq2lJJZaKMVw9qNi4jTC0w==", 1840 | "dependencies": { 1841 | "spdx-expression-parse": "^3.0.0", 1842 | "spdx-license-ids": "^3.0.0" 1843 | } 1844 | }, 1845 | "node_modules/spdx-exceptions": { 1846 | "version": "2.3.0", 1847 | "resolved": "https://registry.npmjs.org/spdx-exceptions/-/spdx-exceptions-2.3.0.tgz", 1848 | "integrity": "sha512-/tTrYOC7PPI1nUAgx34hUpqXuyJG+DTHJTnIULG4rDygi4xu/tfgmq1e1cIRwRzwZgo4NLySi+ricLkZkw4i5A==" 1849 | }, 1850 | "node_modules/spdx-expression-parse": { 1851 | "version": "3.0.1", 1852 | "resolved": "https://registry.npmjs.org/spdx-expression-parse/-/spdx-expression-parse-3.0.1.tgz", 1853 | "integrity": "sha512-cbqHunsQWnJNE6KhVSMsMeH5H/L9EpymbzqTQ3uLwNCLZ1Q481oWaofqH7nO6V07xlXwY6PhQdQ2IedWx/ZK4Q==", 1854 | "dependencies": { 1855 | "spdx-exceptions": "^2.1.0", 1856 | "spdx-license-ids": "^3.0.0" 1857 | } 1858 | }, 1859 | "node_modules/spdx-license-ids": { 1860 | "version": "3.0.11", 1861 | "resolved": "https://registry.npmjs.org/spdx-license-ids/-/spdx-license-ids-3.0.11.tgz", 1862 | "integrity": "sha512-Ctl2BrFiM0X3MANYgj3CkygxhRmr9mi6xhejbdO960nF6EDJApTYpn0BQnDKlnNBULKiCN1n3w9EBkHK8ZWg+g==" 1863 | }, 1864 | "node_modules/string-argv": { 1865 | "version": "0.3.1", 1866 | "resolved": "https://registry.npmjs.org/string-argv/-/string-argv-0.3.1.tgz", 1867 | "integrity": "sha512-a1uQGz7IyVy9YwhqjZIZu1c8JO8dNIe20xBmSS6qu9kv++k3JGzCVmprbNN5Kn+BgzD5E7YYwg1CcjuJMRNsvg==", 1868 | "dev": true, 1869 | "engines": { 1870 | "node": ">=0.6.19" 1871 | } 1872 | }, 1873 | "node_modules/string-width": { 1874 | "version": "5.1.0", 1875 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-5.1.0.tgz", 1876 | "integrity": "sha512-7x54QnN21P+XL/v8SuNKvfgsUre6PXpN7mc77N3HlZv+f1SBRGmjxtOud2Z6FZ8DmdkD/IdjCaf9XXbnqmTZGQ==", 1877 | "dev": true, 1878 | "dependencies": { 1879 | "eastasianwidth": "^0.2.0", 1880 | "emoji-regex": "^9.2.2", 1881 | "strip-ansi": "^7.0.1" 1882 | }, 1883 | "engines": { 1884 | "node": ">=12" 1885 | }, 1886 | "funding": { 1887 | "url": "https://github.com/sponsors/sindresorhus" 1888 | } 1889 | }, 1890 | "node_modules/string.prototype.padend": { 1891 | "version": "3.1.3", 1892 | "resolved": "https://registry.npmjs.org/string.prototype.padend/-/string.prototype.padend-3.1.3.tgz", 1893 | "integrity": "sha512-jNIIeokznm8SD/TZISQsZKYu7RJyheFNt84DUPrh482GC8RVp2MKqm2O5oBRdGxbDQoXrhhWtPIWQOiy20svUg==", 1894 | "dependencies": { 1895 | "call-bind": "^1.0.2", 1896 | "define-properties": "^1.1.3", 1897 | "es-abstract": "^1.19.1" 1898 | }, 1899 | "engines": { 1900 | "node": ">= 0.4" 1901 | }, 1902 | "funding": { 1903 | "url": "https://github.com/sponsors/ljharb" 1904 | } 1905 | }, 1906 | "node_modules/string.prototype.trimend": { 1907 | "version": "1.0.4", 1908 | "resolved": "https://registry.npmjs.org/string.prototype.trimend/-/string.prototype.trimend-1.0.4.tgz", 1909 | "integrity": "sha512-y9xCjw1P23Awk8EvTpcyL2NIr1j7wJ39f+k6lvRnSMz+mz9CGz9NYPelDk42kOz6+ql8xjfK8oYzy3jAP5QU5A==", 1910 | "dependencies": { 1911 | "call-bind": "^1.0.2", 1912 | "define-properties": "^1.1.3" 1913 | }, 1914 | "funding": { 1915 | "url": "https://github.com/sponsors/ljharb" 1916 | } 1917 | }, 1918 | "node_modules/string.prototype.trimstart": { 1919 | "version": "1.0.4", 1920 | "resolved": "https://registry.npmjs.org/string.prototype.trimstart/-/string.prototype.trimstart-1.0.4.tgz", 1921 | "integrity": "sha512-jh6e984OBfvxS50tdY2nRZnoC5/mLFKOREQfw8t5yytkoUsJRNxvI/E39qu1sD0OtWI3OC0XgKSmcWwziwYuZw==", 1922 | "dependencies": { 1923 | "call-bind": "^1.0.2", 1924 | "define-properties": "^1.1.3" 1925 | }, 1926 | "funding": { 1927 | "url": "https://github.com/sponsors/ljharb" 1928 | } 1929 | }, 1930 | "node_modules/strip-ansi": { 1931 | "version": "7.0.1", 1932 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-7.0.1.tgz", 1933 | "integrity": "sha512-cXNxvT8dFNRVfhVME3JAe98mkXDYN2O1l7jmcwMnOslDeESg1rF/OZMtK0nRAhiari1unG5cD4jG3rapUAkLbw==", 1934 | "dev": true, 1935 | "dependencies": { 1936 | "ansi-regex": "^6.0.1" 1937 | }, 1938 | "engines": { 1939 | "node": ">=12" 1940 | }, 1941 | "funding": { 1942 | "url": "https://github.com/chalk/strip-ansi?sponsor=1" 1943 | } 1944 | }, 1945 | "node_modules/strip-bom": { 1946 | "version": "3.0.0", 1947 | "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-3.0.0.tgz", 1948 | "integrity": "sha1-IzTBjpx1n3vdVv3vfprj1YjmjtM=", 1949 | "engines": { 1950 | "node": ">=4" 1951 | } 1952 | }, 1953 | "node_modules/strip-final-newline": { 1954 | "version": "2.0.0", 1955 | "resolved": "https://registry.npmjs.org/strip-final-newline/-/strip-final-newline-2.0.0.tgz", 1956 | "integrity": "sha512-BrpvfNAE3dcvq7ll3xVumzjKjZQ5tI1sEUIKr3Uoks0XUl45St3FlatVqef9prk4jRDzhW6WZg+3bk93y6pLjA==", 1957 | "dev": true, 1958 | "engines": { 1959 | "node": ">=6" 1960 | } 1961 | }, 1962 | "node_modules/supports-color": { 1963 | "version": "9.2.1", 1964 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-9.2.1.tgz", 1965 | "integrity": "sha512-Obv7ycoCTG51N7y175StI9BlAXrmgZrFhZOb0/PyjHBher/NmsdBgbbQ1Inhq+gIhz6+7Gb+jWF2Vqi7Mf1xnQ==", 1966 | "dev": true, 1967 | "engines": { 1968 | "node": ">=12" 1969 | }, 1970 | "funding": { 1971 | "url": "https://github.com/chalk/supports-color?sponsor=1" 1972 | } 1973 | }, 1974 | "node_modules/supports-preserve-symlinks-flag": { 1975 | "version": "1.0.0", 1976 | "resolved": "https://registry.npmjs.org/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz", 1977 | "integrity": "sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w==", 1978 | "engines": { 1979 | "node": ">= 0.4" 1980 | }, 1981 | "funding": { 1982 | "url": "https://github.com/sponsors/ljharb" 1983 | } 1984 | }, 1985 | "node_modules/through": { 1986 | "version": "2.3.8", 1987 | "resolved": "https://registry.npmjs.org/through/-/through-2.3.8.tgz", 1988 | "integrity": "sha1-DdTJ/6q8NXlgsbckEV1+Doai4fU=", 1989 | "dev": true 1990 | }, 1991 | "node_modules/to-regex-range": { 1992 | "version": "5.0.1", 1993 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 1994 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 1995 | "dev": true, 1996 | "dependencies": { 1997 | "is-number": "^7.0.0" 1998 | }, 1999 | "engines": { 2000 | "node": ">=8.0" 2001 | } 2002 | }, 2003 | "node_modules/tslib": { 2004 | "version": "2.3.1", 2005 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.3.1.tgz", 2006 | "integrity": "sha512-77EbyPPpMz+FRFRuAFlWMtmgUWGe9UOG2Z25NqCwiIjRhOf5iKGuzSe5P2w1laq+FkRy4p+PCuVkJSGkzTEKVw==", 2007 | "dev": true 2008 | }, 2009 | "node_modules/type-fest": { 2010 | "version": "0.21.3", 2011 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.21.3.tgz", 2012 | "integrity": "sha512-t0rzBq87m3fVcduHDUFhKmyyX+9eo6WQjZvf51Ea/M0Q7+T374Jp1aUiyUl0GKxp8M/OETVHSDvmkyPgvX+X2w==", 2013 | "dev": true, 2014 | "engines": { 2015 | "node": ">=10" 2016 | }, 2017 | "funding": { 2018 | "url": "https://github.com/sponsors/sindresorhus" 2019 | } 2020 | }, 2021 | "node_modules/unbox-primitive": { 2022 | "version": "1.0.1", 2023 | "resolved": "https://registry.npmjs.org/unbox-primitive/-/unbox-primitive-1.0.1.tgz", 2024 | "integrity": "sha512-tZU/3NqK3dA5gpE1KtyiJUrEB0lxnGkMFHptJ7q6ewdZ8s12QrODwNbhIJStmJkd1QDXa1NRA8aF2A1zk/Ypyw==", 2025 | "dependencies": { 2026 | "function-bind": "^1.1.1", 2027 | "has-bigints": "^1.0.1", 2028 | "has-symbols": "^1.0.2", 2029 | "which-boxed-primitive": "^1.0.2" 2030 | }, 2031 | "funding": { 2032 | "url": "https://github.com/sponsors/ljharb" 2033 | } 2034 | }, 2035 | "node_modules/validate-npm-package-license": { 2036 | "version": "3.0.4", 2037 | "resolved": "https://registry.npmjs.org/validate-npm-package-license/-/validate-npm-package-license-3.0.4.tgz", 2038 | "integrity": "sha512-DpKm2Ui/xN7/HQKCtpZxoRWBhZ9Z0kqtygG8XCgNQ8ZlDnxuQmWhj566j8fN4Cu3/JmbhsDo7fcAJq4s9h27Ew==", 2039 | "dependencies": { 2040 | "spdx-correct": "^3.0.0", 2041 | "spdx-expression-parse": "^3.0.0" 2042 | } 2043 | }, 2044 | "node_modules/vite": { 2045 | "version": "2.8.0-beta.1", 2046 | "resolved": "https://registry.npmjs.org/vite/-/vite-2.8.0-beta.1.tgz", 2047 | "integrity": "sha512-tAXGZKPGPntD7MXHm+pxSy8+aY8iC7u+qK+8pl3hQfj2mTwvpQq2Tk/oydsNIXIQz9ott76H9C89IvhOmp6BvQ==", 2048 | "dependencies": { 2049 | "esbuild": "0.14.3", 2050 | "json5": "^2.2.0", 2051 | "postcss": "^8.4.5", 2052 | "resolve": "^1.20.0", 2053 | "rollup": "^2.59.0" 2054 | }, 2055 | "bin": { 2056 | "vite": "bin/vite.js" 2057 | }, 2058 | "engines": { 2059 | "node": ">=12.2.0" 2060 | }, 2061 | "optionalDependencies": { 2062 | "fsevents": "~2.3.2" 2063 | }, 2064 | "peerDependencies": { 2065 | "less": "*", 2066 | "sass": "*", 2067 | "stylus": "*" 2068 | }, 2069 | "peerDependenciesMeta": { 2070 | "less": { 2071 | "optional": true 2072 | }, 2073 | "sass": { 2074 | "optional": true 2075 | }, 2076 | "stylus": { 2077 | "optional": true 2078 | } 2079 | } 2080 | }, 2081 | "node_modules/which": { 2082 | "version": "2.0.2", 2083 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", 2084 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", 2085 | "dev": true, 2086 | "dependencies": { 2087 | "isexe": "^2.0.0" 2088 | }, 2089 | "bin": { 2090 | "node-which": "bin/node-which" 2091 | }, 2092 | "engines": { 2093 | "node": ">= 8" 2094 | } 2095 | }, 2096 | "node_modules/which-boxed-primitive": { 2097 | "version": "1.0.2", 2098 | "resolved": "https://registry.npmjs.org/which-boxed-primitive/-/which-boxed-primitive-1.0.2.tgz", 2099 | "integrity": "sha512-bwZdv0AKLpplFY2KZRX6TvyuN7ojjr7lwkg6ml0roIy9YeuSr7JS372qlNW18UQYzgYK9ziGcerWqZOmEn9VNg==", 2100 | "dependencies": { 2101 | "is-bigint": "^1.0.1", 2102 | "is-boolean-object": "^1.1.0", 2103 | "is-number-object": "^1.0.4", 2104 | "is-string": "^1.0.5", 2105 | "is-symbol": "^1.0.3" 2106 | }, 2107 | "funding": { 2108 | "url": "https://github.com/sponsors/ljharb" 2109 | } 2110 | }, 2111 | "node_modules/wrap-ansi": { 2112 | "version": "7.0.0", 2113 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz", 2114 | "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==", 2115 | "dev": true, 2116 | "dependencies": { 2117 | "ansi-styles": "^4.0.0", 2118 | "string-width": "^4.1.0", 2119 | "strip-ansi": "^6.0.0" 2120 | }, 2121 | "engines": { 2122 | "node": ">=10" 2123 | }, 2124 | "funding": { 2125 | "url": "https://github.com/chalk/wrap-ansi?sponsor=1" 2126 | } 2127 | }, 2128 | "node_modules/wrap-ansi/node_modules/ansi-regex": { 2129 | "version": "5.0.1", 2130 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 2131 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 2132 | "dev": true, 2133 | "engines": { 2134 | "node": ">=8" 2135 | } 2136 | }, 2137 | "node_modules/wrap-ansi/node_modules/ansi-styles": { 2138 | "version": "4.3.0", 2139 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 2140 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 2141 | "dev": true, 2142 | "dependencies": { 2143 | "color-convert": "^2.0.1" 2144 | }, 2145 | "engines": { 2146 | "node": ">=8" 2147 | }, 2148 | "funding": { 2149 | "url": "https://github.com/chalk/ansi-styles?sponsor=1" 2150 | } 2151 | }, 2152 | "node_modules/wrap-ansi/node_modules/emoji-regex": { 2153 | "version": "8.0.0", 2154 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 2155 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 2156 | "dev": true 2157 | }, 2158 | "node_modules/wrap-ansi/node_modules/is-fullwidth-code-point": { 2159 | "version": "3.0.0", 2160 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 2161 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 2162 | "dev": true, 2163 | "engines": { 2164 | "node": ">=8" 2165 | } 2166 | }, 2167 | "node_modules/wrap-ansi/node_modules/string-width": { 2168 | "version": "4.2.3", 2169 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", 2170 | "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", 2171 | "dev": true, 2172 | "dependencies": { 2173 | "emoji-regex": "^8.0.0", 2174 | "is-fullwidth-code-point": "^3.0.0", 2175 | "strip-ansi": "^6.0.1" 2176 | }, 2177 | "engines": { 2178 | "node": ">=8" 2179 | } 2180 | }, 2181 | "node_modules/wrap-ansi/node_modules/strip-ansi": { 2182 | "version": "6.0.1", 2183 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 2184 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 2185 | "dev": true, 2186 | "dependencies": { 2187 | "ansi-regex": "^5.0.1" 2188 | }, 2189 | "engines": { 2190 | "node": ">=8" 2191 | } 2192 | }, 2193 | "node_modules/yaml": { 2194 | "version": "1.10.2", 2195 | "resolved": "https://registry.npmjs.org/yaml/-/yaml-1.10.2.tgz", 2196 | "integrity": "sha512-r3vXyErRCYJ7wg28yvBY5VSoAF8ZvlcW9/BwUzEtUsjvX/DKs24dIkuwjtuprwJJHsbyUbLApepYTR1BN4uHrg==", 2197 | "dev": true, 2198 | "engines": { 2199 | "node": ">= 6" 2200 | } 2201 | } 2202 | }, 2203 | "dependencies": { 2204 | "aggregate-error": { 2205 | "version": "3.1.0", 2206 | "resolved": "https://registry.npmjs.org/aggregate-error/-/aggregate-error-3.1.0.tgz", 2207 | "integrity": "sha512-4I7Td01quW/RpocfNayFdFVk1qSuoh0E7JrbRJ16nH01HhKFQ88INq9Sd+nd72zqRySlr9BmDA8xlEJ6vJMrYA==", 2208 | "dev": true, 2209 | "requires": { 2210 | "clean-stack": "^2.0.0", 2211 | "indent-string": "^4.0.0" 2212 | } 2213 | }, 2214 | "ansi-escapes": { 2215 | "version": "4.3.2", 2216 | "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-4.3.2.tgz", 2217 | "integrity": "sha512-gKXj5ALrKWQLsYG9jlTRmR/xKluxHV+Z9QEwNIgCfM1/uwPMCuzVVnh5mwTd+OuBZcwSIMbqssNWRm1lE51QaQ==", 2218 | "dev": true, 2219 | "requires": { 2220 | "type-fest": "^0.21.3" 2221 | } 2222 | }, 2223 | "ansi-regex": { 2224 | "version": "6.0.1", 2225 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-6.0.1.tgz", 2226 | "integrity": "sha512-n5M855fKb2SsfMIiFFoVrABHJC8QtHwVx+mHWP3QcEqBHYienj5dHSgjbxtC0WEZXYt4wcD6zrQElDPhFuZgfA==", 2227 | "dev": true 2228 | }, 2229 | "ansi-styles": { 2230 | "version": "6.1.0", 2231 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-6.1.0.tgz", 2232 | "integrity": "sha512-VbqNsoz55SYGczauuup0MFUyXNQviSpFTj1RQtFzmQLk18qbVSpTFFGMT293rmDaQuKCT6InmbuEyUne4mTuxQ==", 2233 | "dev": true 2234 | }, 2235 | "astral-regex": { 2236 | "version": "2.0.0", 2237 | "resolved": "https://registry.npmjs.org/astral-regex/-/astral-regex-2.0.0.tgz", 2238 | "integrity": "sha512-Z7tMw1ytTXt5jqMcOP+OQteU1VuNK9Y02uuJtKQ1Sv69jXQKKg5cibLwGJow8yzZP+eAc18EmLGPal0bp36rvQ==", 2239 | "dev": true 2240 | }, 2241 | "balanced-match": { 2242 | "version": "1.0.2", 2243 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", 2244 | "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==" 2245 | }, 2246 | "brace-expansion": { 2247 | "version": "1.1.11", 2248 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 2249 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 2250 | "requires": { 2251 | "balanced-match": "^1.0.0", 2252 | "concat-map": "0.0.1" 2253 | } 2254 | }, 2255 | "braces": { 2256 | "version": "3.0.2", 2257 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", 2258 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", 2259 | "dev": true, 2260 | "requires": { 2261 | "fill-range": "^7.0.1" 2262 | } 2263 | }, 2264 | "call-bind": { 2265 | "version": "1.0.2", 2266 | "resolved": "https://registry.npmjs.org/call-bind/-/call-bind-1.0.2.tgz", 2267 | "integrity": "sha512-7O+FbCihrB5WGbFYesctwmTKae6rOiIzmz1icreWJ+0aA7LJfuqhEso2T9ncpcFtzMQtzXf2QGGueWJGTYsqrA==", 2268 | "requires": { 2269 | "function-bind": "^1.1.1", 2270 | "get-intrinsic": "^1.0.2" 2271 | } 2272 | }, 2273 | "chalk": { 2274 | "version": "2.4.2", 2275 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", 2276 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", 2277 | "requires": { 2278 | "ansi-styles": "^3.2.1", 2279 | "escape-string-regexp": "^1.0.5", 2280 | "supports-color": "^5.3.0" 2281 | }, 2282 | "dependencies": { 2283 | "ansi-styles": { 2284 | "version": "3.2.1", 2285 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 2286 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 2287 | "requires": { 2288 | "color-convert": "^1.9.0" 2289 | } 2290 | }, 2291 | "color-convert": { 2292 | "version": "1.9.3", 2293 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", 2294 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", 2295 | "requires": { 2296 | "color-name": "1.1.3" 2297 | } 2298 | }, 2299 | "color-name": { 2300 | "version": "1.1.3", 2301 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 2302 | "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=" 2303 | }, 2304 | "supports-color": { 2305 | "version": "5.5.0", 2306 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 2307 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 2308 | "requires": { 2309 | "has-flag": "^3.0.0" 2310 | } 2311 | } 2312 | } 2313 | }, 2314 | "clean-stack": { 2315 | "version": "2.2.0", 2316 | "resolved": "https://registry.npmjs.org/clean-stack/-/clean-stack-2.2.0.tgz", 2317 | "integrity": "sha512-4diC9HaTE+KRAMWhDhrGOECgWZxoevMc5TlkObMqNSsVU62PYzXZ/SMTjzyGAFF1YusgxGcSWTEXBhp0CPwQ1A==", 2318 | "dev": true 2319 | }, 2320 | "cli-cursor": { 2321 | "version": "3.1.0", 2322 | "resolved": "https://registry.npmjs.org/cli-cursor/-/cli-cursor-3.1.0.tgz", 2323 | "integrity": "sha512-I/zHAwsKf9FqGoXM4WWRACob9+SNukZTd94DWF57E4toouRulbCxcUh6RKUEOQlYTHJnzkPMySvPNaaSLNfLZw==", 2324 | "dev": true, 2325 | "requires": { 2326 | "restore-cursor": "^3.1.0" 2327 | } 2328 | }, 2329 | "cli-truncate": { 2330 | "version": "3.1.0", 2331 | "resolved": "https://registry.npmjs.org/cli-truncate/-/cli-truncate-3.1.0.tgz", 2332 | "integrity": "sha512-wfOBkjXteqSnI59oPcJkcPl/ZmwvMMOj340qUIY1SKZCv0B9Cf4D4fAucRkIKQmsIuYK3x1rrgU7MeGRruiuiA==", 2333 | "dev": true, 2334 | "requires": { 2335 | "slice-ansi": "^5.0.0", 2336 | "string-width": "^5.0.0" 2337 | } 2338 | }, 2339 | "color-convert": { 2340 | "version": "2.0.1", 2341 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 2342 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 2343 | "dev": true, 2344 | "requires": { 2345 | "color-name": "~1.1.4" 2346 | } 2347 | }, 2348 | "color-name": { 2349 | "version": "1.1.4", 2350 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 2351 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 2352 | "dev": true 2353 | }, 2354 | "colorette": { 2355 | "version": "2.0.16", 2356 | "resolved": "https://registry.npmjs.org/colorette/-/colorette-2.0.16.tgz", 2357 | "integrity": "sha512-hUewv7oMjCp+wkBv5Rm0v87eJhq4woh5rSR+42YSQJKecCqgIqNkZ6lAlQms/BwHPJA5NKMRlpxPRv0n8HQW6g==", 2358 | "dev": true 2359 | }, 2360 | "commander": { 2361 | "version": "8.3.0", 2362 | "resolved": "https://registry.npmjs.org/commander/-/commander-8.3.0.tgz", 2363 | "integrity": "sha512-OkTL9umf+He2DZkUq8f8J9of7yL6RJKI24dVITBmNfZBmri9zYZQrKkuXiKhyfPSu8tUhnVBB1iKXevvnlR4Ww==", 2364 | "dev": true 2365 | }, 2366 | "concat-map": { 2367 | "version": "0.0.1", 2368 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 2369 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=" 2370 | }, 2371 | "cross-spawn": { 2372 | "version": "7.0.3", 2373 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz", 2374 | "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==", 2375 | "dev": true, 2376 | "requires": { 2377 | "path-key": "^3.1.0", 2378 | "shebang-command": "^2.0.0", 2379 | "which": "^2.0.1" 2380 | } 2381 | }, 2382 | "debug": { 2383 | "version": "4.3.3", 2384 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.3.tgz", 2385 | "integrity": "sha512-/zxw5+vh1Tfv+4Qn7a5nsbcJKPaSvCDhojn6FEl9vupwK2VCSDtEiEtqr8DFtzYFOdz63LBkxec7DYuc2jon6Q==", 2386 | "dev": true, 2387 | "requires": { 2388 | "ms": "2.1.2" 2389 | } 2390 | }, 2391 | "define-properties": { 2392 | "version": "1.1.3", 2393 | "resolved": "https://registry.npmjs.org/define-properties/-/define-properties-1.1.3.tgz", 2394 | "integrity": "sha512-3MqfYKj2lLzdMSf8ZIZE/V+Zuy+BgD6f164e8K2w7dgnpKArBDerGYpM46IYYcjnkdPNMjPk9A6VFB8+3SKlXQ==", 2395 | "requires": { 2396 | "object-keys": "^1.0.12" 2397 | } 2398 | }, 2399 | "eastasianwidth": { 2400 | "version": "0.2.0", 2401 | "resolved": "https://registry.npmjs.org/eastasianwidth/-/eastasianwidth-0.2.0.tgz", 2402 | "integrity": "sha512-I88TYZWc9XiYHRQ4/3c5rjjfgkjhLyW2luGIheGERbNQ6OY7yTybanSpDXZa8y7VUP9YmDcYa+eyq4ca7iLqWA==", 2403 | "dev": true 2404 | }, 2405 | "emoji-regex": { 2406 | "version": "9.2.2", 2407 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-9.2.2.tgz", 2408 | "integrity": "sha512-L18DaJsXSUk2+42pv8mLs5jJT2hqFkFE4j21wOmgbUqsZ2hL72NsUU785g9RXgo3s0ZNgVl42TiHp3ZtOv/Vyg==", 2409 | "dev": true 2410 | }, 2411 | "error-ex": { 2412 | "version": "1.3.2", 2413 | "resolved": "https://registry.npmjs.org/error-ex/-/error-ex-1.3.2.tgz", 2414 | "integrity": "sha512-7dFHNmqeFSEt2ZBsCriorKnn3Z2pj+fd9kmI6QoWw4//DL+icEBfc0U7qJCisqrTsKTjw4fNFy2pW9OqStD84g==", 2415 | "requires": { 2416 | "is-arrayish": "^0.2.1" 2417 | } 2418 | }, 2419 | "es-abstract": { 2420 | "version": "1.19.1", 2421 | "resolved": "https://registry.npmjs.org/es-abstract/-/es-abstract-1.19.1.tgz", 2422 | "integrity": "sha512-2vJ6tjA/UfqLm2MPs7jxVybLoB8i1t1Jd9R3kISld20sIxPcTbLuggQOUxeWeAvIUkduv/CfMjuh4WmiXr2v9w==", 2423 | "requires": { 2424 | "call-bind": "^1.0.2", 2425 | "es-to-primitive": "^1.2.1", 2426 | "function-bind": "^1.1.1", 2427 | "get-intrinsic": "^1.1.1", 2428 | "get-symbol-description": "^1.0.0", 2429 | "has": "^1.0.3", 2430 | "has-symbols": "^1.0.2", 2431 | "internal-slot": "^1.0.3", 2432 | "is-callable": "^1.2.4", 2433 | "is-negative-zero": "^2.0.1", 2434 | "is-regex": "^1.1.4", 2435 | "is-shared-array-buffer": "^1.0.1", 2436 | "is-string": "^1.0.7", 2437 | "is-weakref": "^1.0.1", 2438 | "object-inspect": "^1.11.0", 2439 | "object-keys": "^1.1.1", 2440 | "object.assign": "^4.1.2", 2441 | "string.prototype.trimend": "^1.0.4", 2442 | "string.prototype.trimstart": "^1.0.4", 2443 | "unbox-primitive": "^1.0.1" 2444 | } 2445 | }, 2446 | "es-to-primitive": { 2447 | "version": "1.2.1", 2448 | "resolved": "https://registry.npmjs.org/es-to-primitive/-/es-to-primitive-1.2.1.tgz", 2449 | "integrity": "sha512-QCOllgZJtaUo9miYBcLChTUaHNjJF3PYs1VidD7AwiEj1kYxKeQTctLAezAOH5ZKRH0g2IgPn6KwB4IT8iRpvA==", 2450 | "requires": { 2451 | "is-callable": "^1.1.4", 2452 | "is-date-object": "^1.0.1", 2453 | "is-symbol": "^1.0.2" 2454 | } 2455 | }, 2456 | "esbuild": { 2457 | "version": "0.14.3", 2458 | "resolved": "https://registry.npmjs.org/esbuild/-/esbuild-0.14.3.tgz", 2459 | "integrity": "sha512-zyEC5hkguW2oieXRXp8VJzQdcO/1FxCS5GjzqOHItRlojXnx/cTavsrkxdWvBH9li2lUq0bN+LeeVEmyCwiR/Q==", 2460 | "requires": { 2461 | "esbuild-android-arm64": "0.14.3", 2462 | "esbuild-darwin-64": "0.14.3", 2463 | "esbuild-darwin-arm64": "0.14.3", 2464 | "esbuild-freebsd-64": "0.14.3", 2465 | "esbuild-freebsd-arm64": "0.14.3", 2466 | "esbuild-linux-32": "0.14.3", 2467 | "esbuild-linux-64": "0.14.3", 2468 | "esbuild-linux-arm": "0.14.3", 2469 | "esbuild-linux-arm64": "0.14.3", 2470 | "esbuild-linux-mips64le": "0.14.3", 2471 | "esbuild-linux-ppc64le": "0.14.3", 2472 | "esbuild-netbsd-64": "0.14.3", 2473 | "esbuild-openbsd-64": "0.14.3", 2474 | "esbuild-sunos-64": "0.14.3", 2475 | "esbuild-windows-32": "0.14.3", 2476 | "esbuild-windows-64": "0.14.3", 2477 | "esbuild-windows-arm64": "0.14.3" 2478 | } 2479 | }, 2480 | "esbuild-android-arm64": { 2481 | "version": "0.14.3", 2482 | "resolved": "https://registry.npmjs.org/esbuild-android-arm64/-/esbuild-android-arm64-0.14.3.tgz", 2483 | "integrity": "sha512-v/vdnGJiSGWOAXzg422T9qb4S+P3tOaYtc5n3FDR27Bh3/xQDS7PdYz/yY7HhOlVp0eGwWNbPHEi8FcEhXjsuw==", 2484 | "optional": true 2485 | }, 2486 | "esbuild-darwin-64": { 2487 | "version": "0.14.3", 2488 | "resolved": "https://registry.npmjs.org/esbuild-darwin-64/-/esbuild-darwin-64-0.14.3.tgz", 2489 | "integrity": "sha512-swY5OtEg6cfWdgc/XEjkBP7wXSyXXeZHEsWMdh1bDiN1D6GmRphk9SgKFKTj+P3ZHhOGIcC1+UdIwHk5bUcOig==", 2490 | "optional": true 2491 | }, 2492 | "esbuild-darwin-arm64": { 2493 | "version": "0.14.3", 2494 | "resolved": "https://registry.npmjs.org/esbuild-darwin-arm64/-/esbuild-darwin-arm64-0.14.3.tgz", 2495 | "integrity": "sha512-6i9dXPk8oT87wF6VHmwzSad76eMRU2Rt+GXrwF3Y4DCJgnPssJbabNQ9gurkuEX8M0YnEyJF0d1cR7rpTzcEiA==", 2496 | "optional": true 2497 | }, 2498 | "esbuild-freebsd-64": { 2499 | "version": "0.14.3", 2500 | "resolved": "https://registry.npmjs.org/esbuild-freebsd-64/-/esbuild-freebsd-64-0.14.3.tgz", 2501 | "integrity": "sha512-WDY5ENsmyceeE+95U3eI+FM8yARY5akWkf21M/x/+v2P5OVsYqCYELglSeAI5Y7bhteCVV3g4i2fRqtkmprdSA==", 2502 | "optional": true 2503 | }, 2504 | "esbuild-freebsd-arm64": { 2505 | "version": "0.14.3", 2506 | "resolved": "https://registry.npmjs.org/esbuild-freebsd-arm64/-/esbuild-freebsd-arm64-0.14.3.tgz", 2507 | "integrity": "sha512-4BEEGcP0wBzg04pCCWXlgaPuksQHHfwHvYgCIsi+7IsuB17ykt6MHhTkHR5b5pjI/jNtRhPfMsDODUyftQJgvw==", 2508 | "optional": true 2509 | }, 2510 | "esbuild-linux-32": { 2511 | "version": "0.14.3", 2512 | "resolved": "https://registry.npmjs.org/esbuild-linux-32/-/esbuild-linux-32-0.14.3.tgz", 2513 | "integrity": "sha512-8yhsnjLG/GwCA1RAIndjmCHWViRB2Ol0XeOh2fCXS9qF8tlVrJB7qAiHZpm2vXx+yjOA/bFLTxzU+5pMKqkn5A==", 2514 | "optional": true 2515 | }, 2516 | "esbuild-linux-64": { 2517 | "version": "0.14.3", 2518 | "resolved": "https://registry.npmjs.org/esbuild-linux-64/-/esbuild-linux-64-0.14.3.tgz", 2519 | "integrity": "sha512-eNq4aixfbwXHIJq4bQDe+XaSNV1grxqpZYs/zHbp0HGHf6SBNlTI02uyTbYGpIzlXmCEPS9tpPCi7BTU45kcJQ==", 2520 | "optional": true 2521 | }, 2522 | "esbuild-linux-arm": { 2523 | "version": "0.14.3", 2524 | "resolved": "https://registry.npmjs.org/esbuild-linux-arm/-/esbuild-linux-arm-0.14.3.tgz", 2525 | "integrity": "sha512-YcMvJHAQnWrWKb+eLxN9e/iWUC/3w01UF/RXuMknqOW3prX8UQ63QknWz9/RI8BY/sdrdgPEbSmsTU2jy2cayQ==", 2526 | "optional": true 2527 | }, 2528 | "esbuild-linux-arm64": { 2529 | "version": "0.14.3", 2530 | "resolved": "https://registry.npmjs.org/esbuild-linux-arm64/-/esbuild-linux-arm64-0.14.3.tgz", 2531 | "integrity": "sha512-wPLyRoqoV/tEMQ7M24DpAmCMyKqBmtgZY35w2tXM8X5O5b2Ohi7fkPSmd6ZgLIxZIApWt88toA8RT0S7qoxcOA==", 2532 | "optional": true 2533 | }, 2534 | "esbuild-linux-mips64le": { 2535 | "version": "0.14.3", 2536 | "resolved": "https://registry.npmjs.org/esbuild-linux-mips64le/-/esbuild-linux-mips64le-0.14.3.tgz", 2537 | "integrity": "sha512-DdmfM5rcuoqjQL3px5MbquAjZWnySB5LdTrg52SSapp0gXMnGcsM6GY2WVta02CMKn5qi7WPVG4WbqTWE++tJw==", 2538 | "optional": true 2539 | }, 2540 | "esbuild-linux-ppc64le": { 2541 | "version": "0.14.3", 2542 | "resolved": "https://registry.npmjs.org/esbuild-linux-ppc64le/-/esbuild-linux-ppc64le-0.14.3.tgz", 2543 | "integrity": "sha512-ujdqryj0m135Ms9yaNDVFAcLeRtyftM/v2v7Osji5zElf2TivSMdFxdrYnYICuHfkm8c8gHg1ncwqitL0r+nnA==", 2544 | "optional": true 2545 | }, 2546 | "esbuild-netbsd-64": { 2547 | "version": "0.14.3", 2548 | "resolved": "https://registry.npmjs.org/esbuild-netbsd-64/-/esbuild-netbsd-64-0.14.3.tgz", 2549 | "integrity": "sha512-Z/UB9OUdwo1KDJCSGnVueDuKowRZRkduLvRMegHtDBHC3lS5LfZ3RdM1i+4MMN9iafyk8Q9FNcqIXI178ZujvA==", 2550 | "optional": true 2551 | }, 2552 | "esbuild-openbsd-64": { 2553 | "version": "0.14.3", 2554 | "resolved": "https://registry.npmjs.org/esbuild-openbsd-64/-/esbuild-openbsd-64-0.14.3.tgz", 2555 | "integrity": "sha512-9I1uoMDeogq3zQuTe3qygmXYjImnvc6rBn51LLbLniQDlfvqHPBMnAZ/5KshwtXXIIMkCwByytDZdiuzRRlTvQ==", 2556 | "optional": true 2557 | }, 2558 | "esbuild-sunos-64": { 2559 | "version": "0.14.3", 2560 | "resolved": "https://registry.npmjs.org/esbuild-sunos-64/-/esbuild-sunos-64-0.14.3.tgz", 2561 | "integrity": "sha512-pldqx/Adxl4V4ymiyKxOOyJmHn6nUIo3wqk2xBx07iDgmL2XTcDDQd7N4U4QGu9LnYN4ZF+8IdOYa3oRRpbjtg==", 2562 | "optional": true 2563 | }, 2564 | "esbuild-windows-32": { 2565 | "version": "0.14.3", 2566 | "resolved": "https://registry.npmjs.org/esbuild-windows-32/-/esbuild-windows-32-0.14.3.tgz", 2567 | "integrity": "sha512-AqzvA/KbkC2m3kTXGpljLin3EttRbtoPTfBn6w6n2m9MWkTEbhQbE1ONoOBxhO5tExmyJdL/6B87TJJD5jEFBQ==", 2568 | "optional": true 2569 | }, 2570 | "esbuild-windows-64": { 2571 | "version": "0.14.3", 2572 | "resolved": "https://registry.npmjs.org/esbuild-windows-64/-/esbuild-windows-64-0.14.3.tgz", 2573 | "integrity": "sha512-HGg3C6113zLGB5hN41PROTnBuoh/arG2lQdOird6xFl9giff1cAfMQOUJUfODKD57dDqHjQ1YGW8gOkg0/IrWw==", 2574 | "optional": true 2575 | }, 2576 | "esbuild-windows-arm64": { 2577 | "version": "0.14.3", 2578 | "resolved": "https://registry.npmjs.org/esbuild-windows-arm64/-/esbuild-windows-arm64-0.14.3.tgz", 2579 | "integrity": "sha512-qB2izYu4VpigGnOrAN2Yv7ICYLZWY/AojZtwFfteViDnHgW4jXPYkHQIXTISJbRz25H2cYiv+MfRQYK31RNjlw==", 2580 | "optional": true 2581 | }, 2582 | "escape-string-regexp": { 2583 | "version": "1.0.5", 2584 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", 2585 | "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=" 2586 | }, 2587 | "execa": { 2588 | "version": "5.1.1", 2589 | "resolved": "https://registry.npmjs.org/execa/-/execa-5.1.1.tgz", 2590 | "integrity": "sha512-8uSpZZocAZRBAPIEINJj3Lo9HyGitllczc27Eh5YYojjMFMn8yHMDMaUHE2Jqfq05D/wucwI4JGURyXt1vchyg==", 2591 | "dev": true, 2592 | "requires": { 2593 | "cross-spawn": "^7.0.3", 2594 | "get-stream": "^6.0.0", 2595 | "human-signals": "^2.1.0", 2596 | "is-stream": "^2.0.0", 2597 | "merge-stream": "^2.0.0", 2598 | "npm-run-path": "^4.0.1", 2599 | "onetime": "^5.1.2", 2600 | "signal-exit": "^3.0.3", 2601 | "strip-final-newline": "^2.0.0" 2602 | } 2603 | }, 2604 | "fill-range": { 2605 | "version": "7.0.1", 2606 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", 2607 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", 2608 | "dev": true, 2609 | "requires": { 2610 | "to-regex-range": "^5.0.1" 2611 | } 2612 | }, 2613 | "fsevents": { 2614 | "version": "2.3.2", 2615 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.2.tgz", 2616 | "integrity": "sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==", 2617 | "optional": true 2618 | }, 2619 | "function-bind": { 2620 | "version": "1.1.1", 2621 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", 2622 | "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==" 2623 | }, 2624 | "get-intrinsic": { 2625 | "version": "1.1.1", 2626 | "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.1.1.tgz", 2627 | "integrity": "sha512-kWZrnVM42QCiEA2Ig1bG8zjoIMOgxWwYCEeNdwY6Tv/cOSeGpcoX4pXHfKUxNKVoArnrEr2e9srnAxxGIraS9Q==", 2628 | "requires": { 2629 | "function-bind": "^1.1.1", 2630 | "has": "^1.0.3", 2631 | "has-symbols": "^1.0.1" 2632 | } 2633 | }, 2634 | "get-stream": { 2635 | "version": "6.0.1", 2636 | "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-6.0.1.tgz", 2637 | "integrity": "sha512-ts6Wi+2j3jQjqi70w5AlN8DFnkSwC+MqmxEzdEALB2qXZYV3X/b1CTfgPLGJNMeAWxdPfU8FO1ms3NUfaHCPYg==", 2638 | "dev": true 2639 | }, 2640 | "get-symbol-description": { 2641 | "version": "1.0.0", 2642 | "resolved": "https://registry.npmjs.org/get-symbol-description/-/get-symbol-description-1.0.0.tgz", 2643 | "integrity": "sha512-2EmdH1YvIQiZpltCNgkuiUnyukzxM/R6NDJX31Ke3BG1Nq5b0S2PhX59UKi9vZpPDQVdqn+1IcaAwnzTT5vCjw==", 2644 | "requires": { 2645 | "call-bind": "^1.0.2", 2646 | "get-intrinsic": "^1.1.1" 2647 | } 2648 | }, 2649 | "graceful-fs": { 2650 | "version": "4.2.9", 2651 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.9.tgz", 2652 | "integrity": "sha512-NtNxqUcXgpW2iMrfqSfR73Glt39K+BLwWsPs94yR63v45T0Wbej7eRmL5cWfwEgqXnmjQp3zaJTshdRW/qC2ZQ==" 2653 | }, 2654 | "has": { 2655 | "version": "1.0.3", 2656 | "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", 2657 | "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", 2658 | "requires": { 2659 | "function-bind": "^1.1.1" 2660 | } 2661 | }, 2662 | "has-bigints": { 2663 | "version": "1.0.1", 2664 | "resolved": "https://registry.npmjs.org/has-bigints/-/has-bigints-1.0.1.tgz", 2665 | "integrity": "sha512-LSBS2LjbNBTf6287JEbEzvJgftkF5qFkmCo9hDRpAzKhUOlJ+hx8dd4USs00SgsUNwc4617J9ki5YtEClM2ffA==" 2666 | }, 2667 | "has-flag": { 2668 | "version": "3.0.0", 2669 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 2670 | "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=" 2671 | }, 2672 | "has-symbols": { 2673 | "version": "1.0.2", 2674 | "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.2.tgz", 2675 | "integrity": "sha512-chXa79rL/UC2KlX17jo3vRGz0azaWEx5tGqZg5pO3NUyEJVB17dMruQlzCCOfUvElghKcm5194+BCRvi2Rv/Gw==" 2676 | }, 2677 | "has-tostringtag": { 2678 | "version": "1.0.0", 2679 | "resolved": "https://registry.npmjs.org/has-tostringtag/-/has-tostringtag-1.0.0.tgz", 2680 | "integrity": "sha512-kFjcSNhnlGV1kyoGk7OXKSawH5JOb/LzUc5w9B02hOTO0dfFRjbHQKvg1d6cf3HbeUmtU9VbbV3qzZ2Teh97WQ==", 2681 | "requires": { 2682 | "has-symbols": "^1.0.2" 2683 | } 2684 | }, 2685 | "hosted-git-info": { 2686 | "version": "2.8.9", 2687 | "resolved": "https://registry.npmjs.org/hosted-git-info/-/hosted-git-info-2.8.9.tgz", 2688 | "integrity": "sha512-mxIDAb9Lsm6DoOJ7xH+5+X4y1LU/4Hi50L9C5sIswK3JzULS4bwk1FvjdBgvYR4bzT4tuUQiC15FE2f5HbLvYw==" 2689 | }, 2690 | "human-signals": { 2691 | "version": "2.1.0", 2692 | "resolved": "https://registry.npmjs.org/human-signals/-/human-signals-2.1.0.tgz", 2693 | "integrity": "sha512-B4FFZ6q/T2jhhksgkbEW3HBvWIfDW85snkQgawt07S7J5QXTk6BkNV+0yAeZrM5QpMAdYlocGoljn0sJ/WQkFw==", 2694 | "dev": true 2695 | }, 2696 | "husky": { 2697 | "version": "7.0.4", 2698 | "resolved": "https://registry.npmjs.org/husky/-/husky-7.0.4.tgz", 2699 | "integrity": "sha512-vbaCKN2QLtP/vD4yvs6iz6hBEo6wkSzs8HpRah1Z6aGmF2KW5PdYuAd7uX5a+OyBZHBhd+TFLqgjUgytQr4RvQ==", 2700 | "dev": true 2701 | }, 2702 | "immer": { 2703 | "version": "9.0.12", 2704 | "resolved": "https://registry.npmjs.org/immer/-/immer-9.0.12.tgz", 2705 | "integrity": "sha512-lk7UNmSbAukB5B6dh9fnh5D0bJTOFKxVg2cyJWTYrWRfhLrLMBquONcUs3aFq507hNoIZEDDh8lb8UtOizSMhA==" 2706 | }, 2707 | "indent-string": { 2708 | "version": "4.0.0", 2709 | "resolved": "https://registry.npmjs.org/indent-string/-/indent-string-4.0.0.tgz", 2710 | "integrity": "sha512-EdDDZu4A2OyIK7Lr/2zG+w5jmbuk1DVBnEwREQvBzspBJkCEbRa8GxU1lghYcaGJCnRWibjDXlq779X1/y5xwg==", 2711 | "dev": true 2712 | }, 2713 | "internal-slot": { 2714 | "version": "1.0.3", 2715 | "resolved": "https://registry.npmjs.org/internal-slot/-/internal-slot-1.0.3.tgz", 2716 | "integrity": "sha512-O0DB1JC/sPyZl7cIo78n5dR7eUSwwpYPiXRhTzNxZVAMUuB8vlnRFyLxdrVToks6XPLVnFfbzaVd5WLjhgg+vA==", 2717 | "requires": { 2718 | "get-intrinsic": "^1.1.0", 2719 | "has": "^1.0.3", 2720 | "side-channel": "^1.0.4" 2721 | } 2722 | }, 2723 | "is-arrayish": { 2724 | "version": "0.2.1", 2725 | "resolved": "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.2.1.tgz", 2726 | "integrity": "sha1-d8mYQFJ6qOyxqLppe4BkWnqSap0=" 2727 | }, 2728 | "is-bigint": { 2729 | "version": "1.0.4", 2730 | "resolved": "https://registry.npmjs.org/is-bigint/-/is-bigint-1.0.4.tgz", 2731 | "integrity": "sha512-zB9CruMamjym81i2JZ3UMn54PKGsQzsJeo6xvN3HJJ4CAsQNB6iRutp2To77OfCNuoxspsIhzaPoO1zyCEhFOg==", 2732 | "requires": { 2733 | "has-bigints": "^1.0.1" 2734 | } 2735 | }, 2736 | "is-boolean-object": { 2737 | "version": "1.1.2", 2738 | "resolved": "https://registry.npmjs.org/is-boolean-object/-/is-boolean-object-1.1.2.tgz", 2739 | "integrity": "sha512-gDYaKHJmnj4aWxyj6YHyXVpdQawtVLHU5cb+eztPGczf6cjuTdwve5ZIEfgXqH4e57An1D1AKf8CZ3kYrQRqYA==", 2740 | "requires": { 2741 | "call-bind": "^1.0.2", 2742 | "has-tostringtag": "^1.0.0" 2743 | } 2744 | }, 2745 | "is-callable": { 2746 | "version": "1.2.4", 2747 | "resolved": "https://registry.npmjs.org/is-callable/-/is-callable-1.2.4.tgz", 2748 | "integrity": "sha512-nsuwtxZfMX67Oryl9LCQ+upnC0Z0BgpwntpS89m1H/TLF0zNfzfLMV/9Wa/6MZsj0acpEjAO0KF1xT6ZdLl95w==" 2749 | }, 2750 | "is-core-module": { 2751 | "version": "2.8.1", 2752 | "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.8.1.tgz", 2753 | "integrity": "sha512-SdNCUs284hr40hFTFP6l0IfZ/RSrMXF3qgoRHd3/79unUTvrFO/JoXwkGm+5J/Oe3E/b5GsnG330uUNgRpu1PA==", 2754 | "requires": { 2755 | "has": "^1.0.3" 2756 | } 2757 | }, 2758 | "is-date-object": { 2759 | "version": "1.0.5", 2760 | "resolved": "https://registry.npmjs.org/is-date-object/-/is-date-object-1.0.5.tgz", 2761 | "integrity": "sha512-9YQaSxsAiSwcvS33MBk3wTCVnWK+HhF8VZR2jRxehM16QcVOdHqPn4VPHmRK4lSr38n9JriurInLcP90xsYNfQ==", 2762 | "requires": { 2763 | "has-tostringtag": "^1.0.0" 2764 | } 2765 | }, 2766 | "is-fullwidth-code-point": { 2767 | "version": "4.0.0", 2768 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-4.0.0.tgz", 2769 | "integrity": "sha512-O4L094N2/dZ7xqVdrXhh9r1KODPJpFms8B5sGdJLPy664AgvXsreZUyCQQNItZRDlYug4xStLjNp/sz3HvBowQ==", 2770 | "dev": true 2771 | }, 2772 | "is-negative-zero": { 2773 | "version": "2.0.2", 2774 | "resolved": "https://registry.npmjs.org/is-negative-zero/-/is-negative-zero-2.0.2.tgz", 2775 | "integrity": "sha512-dqJvarLawXsFbNDeJW7zAz8ItJ9cd28YufuuFzh0G8pNHjJMnY08Dv7sYX2uF5UpQOwieAeOExEYAWWfu7ZZUA==" 2776 | }, 2777 | "is-number": { 2778 | "version": "7.0.0", 2779 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 2780 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", 2781 | "dev": true 2782 | }, 2783 | "is-number-object": { 2784 | "version": "1.0.6", 2785 | "resolved": "https://registry.npmjs.org/is-number-object/-/is-number-object-1.0.6.tgz", 2786 | "integrity": "sha512-bEVOqiRcvo3zO1+G2lVMy+gkkEm9Yh7cDMRusKKu5ZJKPUYSJwICTKZrNKHA2EbSP0Tu0+6B/emsYNHZyn6K8g==", 2787 | "requires": { 2788 | "has-tostringtag": "^1.0.0" 2789 | } 2790 | }, 2791 | "is-regex": { 2792 | "version": "1.1.4", 2793 | "resolved": "https://registry.npmjs.org/is-regex/-/is-regex-1.1.4.tgz", 2794 | "integrity": "sha512-kvRdxDsxZjhzUX07ZnLydzS1TU/TJlTUHHY4YLL87e37oUA49DfkLqgy+VjFocowy29cKvcSiu+kIv728jTTVg==", 2795 | "requires": { 2796 | "call-bind": "^1.0.2", 2797 | "has-tostringtag": "^1.0.0" 2798 | } 2799 | }, 2800 | "is-shared-array-buffer": { 2801 | "version": "1.0.1", 2802 | "resolved": "https://registry.npmjs.org/is-shared-array-buffer/-/is-shared-array-buffer-1.0.1.tgz", 2803 | "integrity": "sha512-IU0NmyknYZN0rChcKhRO1X8LYz5Isj/Fsqh8NJOSf+N/hCOTwy29F32Ik7a+QszE63IdvmwdTPDd6cZ5pg4cwA==" 2804 | }, 2805 | "is-stream": { 2806 | "version": "2.0.1", 2807 | "resolved": "https://registry.npmjs.org/is-stream/-/is-stream-2.0.1.tgz", 2808 | "integrity": "sha512-hFoiJiTl63nn+kstHGBtewWSKnQLpyb155KHheA1l39uvtO9nWIop1p3udqPcUd/xbF1VLMO4n7OI6p7RbngDg==", 2809 | "dev": true 2810 | }, 2811 | "is-string": { 2812 | "version": "1.0.7", 2813 | "resolved": "https://registry.npmjs.org/is-string/-/is-string-1.0.7.tgz", 2814 | "integrity": "sha512-tE2UXzivje6ofPW7l23cjDOMa09gb7xlAqG6jG5ej6uPV32TlWP3NKPigtaGeHNu9fohccRYvIiZMfOOnOYUtg==", 2815 | "requires": { 2816 | "has-tostringtag": "^1.0.0" 2817 | } 2818 | }, 2819 | "is-symbol": { 2820 | "version": "1.0.4", 2821 | "resolved": "https://registry.npmjs.org/is-symbol/-/is-symbol-1.0.4.tgz", 2822 | "integrity": "sha512-C/CPBqKWnvdcxqIARxyOh4v1UUEOCHpgDa0WYgpKDFMszcrPcffg5uhwSgPCLD2WWxmq6isisz87tzT01tuGhg==", 2823 | "requires": { 2824 | "has-symbols": "^1.0.2" 2825 | } 2826 | }, 2827 | "is-weakref": { 2828 | "version": "1.0.2", 2829 | "resolved": "https://registry.npmjs.org/is-weakref/-/is-weakref-1.0.2.tgz", 2830 | "integrity": "sha512-qctsuLZmIQ0+vSSMfoVvyFe2+GSEvnmZ2ezTup1SBse9+twCCeial6EEi3Nc2KFcf6+qz2FBPnjXsk8xhKSaPQ==", 2831 | "requires": { 2832 | "call-bind": "^1.0.2" 2833 | } 2834 | }, 2835 | "isexe": { 2836 | "version": "2.0.0", 2837 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 2838 | "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=" 2839 | }, 2840 | "json-parse-better-errors": { 2841 | "version": "1.0.2", 2842 | "resolved": "https://registry.npmjs.org/json-parse-better-errors/-/json-parse-better-errors-1.0.2.tgz", 2843 | "integrity": "sha512-mrqyZKfX5EhL7hvqcV6WG1yYjnjeuYDzDhhcAAUrq8Po85NBQBJP+ZDUT75qZQ98IkUoBqdkExkukOU7Ts2wrw==" 2844 | }, 2845 | "json5": { 2846 | "version": "2.2.0", 2847 | "resolved": "https://registry.npmjs.org/json5/-/json5-2.2.0.tgz", 2848 | "integrity": "sha512-f+8cldu7X/y7RAJurMEJmdoKXGB/X550w2Nr3tTbezL6RwEE/iMcm+tZnXeoZtKuOq6ft8+CqzEkrIgx1fPoQA==", 2849 | "requires": { 2850 | "minimist": "^1.2.5" 2851 | } 2852 | }, 2853 | "lilconfig": { 2854 | "version": "2.0.4", 2855 | "resolved": "https://registry.npmjs.org/lilconfig/-/lilconfig-2.0.4.tgz", 2856 | "integrity": "sha512-bfTIN7lEsiooCocSISTWXkiWJkRqtL9wYtYy+8EK3Y41qh3mpwPU0ycTOgjdY9ErwXCc8QyrQp82bdL0Xkm9yA==", 2857 | "dev": true 2858 | }, 2859 | "lint-staged": { 2860 | "version": "12.1.7", 2861 | "resolved": "https://registry.npmjs.org/lint-staged/-/lint-staged-12.1.7.tgz", 2862 | "integrity": "sha512-bltv/ejiLWtowExpjU+s5z8j1Byjg9AlmaAjMmqNbIicY69u6sYIwXGg0dCn0TlkrrY2CphtHIXAkbZ+1VoWQQ==", 2863 | "dev": true, 2864 | "requires": { 2865 | "cli-truncate": "^3.1.0", 2866 | "colorette": "^2.0.16", 2867 | "commander": "^8.3.0", 2868 | "debug": "^4.3.3", 2869 | "execa": "^5.1.1", 2870 | "lilconfig": "2.0.4", 2871 | "listr2": "^3.13.5", 2872 | "micromatch": "^4.0.4", 2873 | "normalize-path": "^3.0.0", 2874 | "object-inspect": "^1.11.1", 2875 | "string-argv": "^0.3.1", 2876 | "supports-color": "^9.2.1", 2877 | "yaml": "^1.10.2" 2878 | } 2879 | }, 2880 | "listr2": { 2881 | "version": "3.14.0", 2882 | "resolved": "https://registry.npmjs.org/listr2/-/listr2-3.14.0.tgz", 2883 | "integrity": "sha512-TyWI8G99GX9GjE54cJ+RrNMcIFBfwMPxc3XTFiAYGN4s10hWROGtOg7+O6u6LE3mNkyld7RSLE6nrKBvTfcs3g==", 2884 | "dev": true, 2885 | "requires": { 2886 | "cli-truncate": "^2.1.0", 2887 | "colorette": "^2.0.16", 2888 | "log-update": "^4.0.0", 2889 | "p-map": "^4.0.0", 2890 | "rfdc": "^1.3.0", 2891 | "rxjs": "^7.5.1", 2892 | "through": "^2.3.8", 2893 | "wrap-ansi": "^7.0.0" 2894 | }, 2895 | "dependencies": { 2896 | "ansi-regex": { 2897 | "version": "5.0.1", 2898 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 2899 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 2900 | "dev": true 2901 | }, 2902 | "ansi-styles": { 2903 | "version": "4.3.0", 2904 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 2905 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 2906 | "dev": true, 2907 | "requires": { 2908 | "color-convert": "^2.0.1" 2909 | } 2910 | }, 2911 | "cli-truncate": { 2912 | "version": "2.1.0", 2913 | "resolved": "https://registry.npmjs.org/cli-truncate/-/cli-truncate-2.1.0.tgz", 2914 | "integrity": "sha512-n8fOixwDD6b/ObinzTrp1ZKFzbgvKZvuz/TvejnLn1aQfC6r52XEx85FmuC+3HI+JM7coBRXUvNqEU2PHVrHpg==", 2915 | "dev": true, 2916 | "requires": { 2917 | "slice-ansi": "^3.0.0", 2918 | "string-width": "^4.2.0" 2919 | } 2920 | }, 2921 | "emoji-regex": { 2922 | "version": "8.0.0", 2923 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 2924 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 2925 | "dev": true 2926 | }, 2927 | "is-fullwidth-code-point": { 2928 | "version": "3.0.0", 2929 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 2930 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 2931 | "dev": true 2932 | }, 2933 | "slice-ansi": { 2934 | "version": "3.0.0", 2935 | "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-3.0.0.tgz", 2936 | "integrity": "sha512-pSyv7bSTC7ig9Dcgbw9AuRNUb5k5V6oDudjZoMBSr13qpLBG7tB+zgCkARjq7xIUgdz5P1Qe8u+rSGdouOOIyQ==", 2937 | "dev": true, 2938 | "requires": { 2939 | "ansi-styles": "^4.0.0", 2940 | "astral-regex": "^2.0.0", 2941 | "is-fullwidth-code-point": "^3.0.0" 2942 | } 2943 | }, 2944 | "string-width": { 2945 | "version": "4.2.3", 2946 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", 2947 | "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", 2948 | "dev": true, 2949 | "requires": { 2950 | "emoji-regex": "^8.0.0", 2951 | "is-fullwidth-code-point": "^3.0.0", 2952 | "strip-ansi": "^6.0.1" 2953 | } 2954 | }, 2955 | "strip-ansi": { 2956 | "version": "6.0.1", 2957 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 2958 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 2959 | "dev": true, 2960 | "requires": { 2961 | "ansi-regex": "^5.0.1" 2962 | } 2963 | } 2964 | } 2965 | }, 2966 | "load-json-file": { 2967 | "version": "4.0.0", 2968 | "resolved": "https://registry.npmjs.org/load-json-file/-/load-json-file-4.0.0.tgz", 2969 | "integrity": "sha1-L19Fq5HjMhYjT9U62rZo607AmTs=", 2970 | "requires": { 2971 | "graceful-fs": "^4.1.2", 2972 | "parse-json": "^4.0.0", 2973 | "pify": "^3.0.0", 2974 | "strip-bom": "^3.0.0" 2975 | } 2976 | }, 2977 | "log-update": { 2978 | "version": "4.0.0", 2979 | "resolved": "https://registry.npmjs.org/log-update/-/log-update-4.0.0.tgz", 2980 | "integrity": "sha512-9fkkDevMefjg0mmzWFBW8YkFP91OrizzkW3diF7CpG+S2EYdy4+TVfGwz1zeF8x7hCx1ovSPTOE9Ngib74qqUg==", 2981 | "dev": true, 2982 | "requires": { 2983 | "ansi-escapes": "^4.3.0", 2984 | "cli-cursor": "^3.1.0", 2985 | "slice-ansi": "^4.0.0", 2986 | "wrap-ansi": "^6.2.0" 2987 | }, 2988 | "dependencies": { 2989 | "ansi-regex": { 2990 | "version": "5.0.1", 2991 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 2992 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 2993 | "dev": true 2994 | }, 2995 | "ansi-styles": { 2996 | "version": "4.3.0", 2997 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 2998 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 2999 | "dev": true, 3000 | "requires": { 3001 | "color-convert": "^2.0.1" 3002 | } 3003 | }, 3004 | "emoji-regex": { 3005 | "version": "8.0.0", 3006 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 3007 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 3008 | "dev": true 3009 | }, 3010 | "is-fullwidth-code-point": { 3011 | "version": "3.0.0", 3012 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 3013 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 3014 | "dev": true 3015 | }, 3016 | "slice-ansi": { 3017 | "version": "4.0.0", 3018 | "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-4.0.0.tgz", 3019 | "integrity": "sha512-qMCMfhY040cVHT43K9BFygqYbUPFZKHOg7K73mtTWJRb8pyP3fzf4Ixd5SzdEJQ6MRUg/WBnOLxghZtKKurENQ==", 3020 | "dev": true, 3021 | "requires": { 3022 | "ansi-styles": "^4.0.0", 3023 | "astral-regex": "^2.0.0", 3024 | "is-fullwidth-code-point": "^3.0.0" 3025 | } 3026 | }, 3027 | "string-width": { 3028 | "version": "4.2.3", 3029 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", 3030 | "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", 3031 | "dev": true, 3032 | "requires": { 3033 | "emoji-regex": "^8.0.0", 3034 | "is-fullwidth-code-point": "^3.0.0", 3035 | "strip-ansi": "^6.0.1" 3036 | } 3037 | }, 3038 | "strip-ansi": { 3039 | "version": "6.0.1", 3040 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 3041 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 3042 | "dev": true, 3043 | "requires": { 3044 | "ansi-regex": "^5.0.1" 3045 | } 3046 | }, 3047 | "wrap-ansi": { 3048 | "version": "6.2.0", 3049 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-6.2.0.tgz", 3050 | "integrity": "sha512-r6lPcBGxZXlIcymEu7InxDMhdW0KDxpLgoFLcguasxCaJ/SOIZwINatK9KY/tf+ZrlywOKU0UDj3ATXUBfxJXA==", 3051 | "dev": true, 3052 | "requires": { 3053 | "ansi-styles": "^4.0.0", 3054 | "string-width": "^4.1.0", 3055 | "strip-ansi": "^6.0.0" 3056 | } 3057 | } 3058 | } 3059 | }, 3060 | "memorystream": { 3061 | "version": "0.3.1", 3062 | "resolved": "https://registry.npmjs.org/memorystream/-/memorystream-0.3.1.tgz", 3063 | "integrity": "sha1-htcJCzDORV1j+64S3aUaR93K+bI=" 3064 | }, 3065 | "merge-stream": { 3066 | "version": "2.0.0", 3067 | "resolved": "https://registry.npmjs.org/merge-stream/-/merge-stream-2.0.0.tgz", 3068 | "integrity": "sha512-abv/qOcuPfk3URPfDzmZU1LKmuw8kT+0nIHvKrKgFrwifol/doWcdA4ZqsWQ8ENrFKkd67Mfpo/LovbIUsbt3w==", 3069 | "dev": true 3070 | }, 3071 | "micromatch": { 3072 | "version": "4.0.4", 3073 | "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-4.0.4.tgz", 3074 | "integrity": "sha512-pRmzw/XUcwXGpD9aI9q/0XOwLNygjETJ8y0ao0wdqprrzDa4YnxLcz7fQRZr8voh8V10kGhABbNcHVk5wHgWwg==", 3075 | "dev": true, 3076 | "requires": { 3077 | "braces": "^3.0.1", 3078 | "picomatch": "^2.2.3" 3079 | } 3080 | }, 3081 | "mimic-fn": { 3082 | "version": "2.1.0", 3083 | "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-2.1.0.tgz", 3084 | "integrity": "sha512-OqbOk5oEQeAZ8WXWydlu9HJjz9WVdEIvamMCcXmuqUYjTknH/sqsWvhQ3vgwKFRR1HpjvNBKQ37nbJgYzGqGcg==", 3085 | "dev": true 3086 | }, 3087 | "minimatch": { 3088 | "version": "3.0.4", 3089 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", 3090 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 3091 | "requires": { 3092 | "brace-expansion": "^1.1.7" 3093 | } 3094 | }, 3095 | "minimist": { 3096 | "version": "1.2.5", 3097 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.5.tgz", 3098 | "integrity": "sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw==" 3099 | }, 3100 | "ms": { 3101 | "version": "2.1.2", 3102 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 3103 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 3104 | "dev": true 3105 | }, 3106 | "nanoid": { 3107 | "version": "3.1.31", 3108 | "resolved": "https://registry.npmjs.org/nanoid/-/nanoid-3.1.31.tgz", 3109 | "integrity": "sha512-ZivnJm0o9bb13p2Ot5CpgC2rQdzB9Uxm/mFZweqm5eMViqOJe3PV6LU2E30SiLgheesmcPrjquqraoolONSA0A==" 3110 | }, 3111 | "nice-try": { 3112 | "version": "1.0.5", 3113 | "resolved": "https://registry.npmjs.org/nice-try/-/nice-try-1.0.5.tgz", 3114 | "integrity": "sha512-1nh45deeb5olNY7eX82BkPO7SSxR5SSYJiPTrTdFUVYwAl8CKMA5N9PjTYkHiRjisVcxcQ1HXdLhx2qxxJzLNQ==" 3115 | }, 3116 | "normalize-package-data": { 3117 | "version": "2.5.0", 3118 | "resolved": "https://registry.npmjs.org/normalize-package-data/-/normalize-package-data-2.5.0.tgz", 3119 | "integrity": "sha512-/5CMN3T0R4XTj4DcGaexo+roZSdSFW/0AOOTROrjxzCG1wrWXEsGbRKevjlIL+ZDE4sZlJr5ED4YW0yqmkK+eA==", 3120 | "requires": { 3121 | "hosted-git-info": "^2.1.4", 3122 | "resolve": "^1.10.0", 3123 | "semver": "2 || 3 || 4 || 5", 3124 | "validate-npm-package-license": "^3.0.1" 3125 | } 3126 | }, 3127 | "normalize-path": { 3128 | "version": "3.0.0", 3129 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", 3130 | "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", 3131 | "dev": true 3132 | }, 3133 | "npm-run-all": { 3134 | "version": "4.1.5", 3135 | "resolved": "https://registry.npmjs.org/npm-run-all/-/npm-run-all-4.1.5.tgz", 3136 | "integrity": "sha512-Oo82gJDAVcaMdi3nuoKFavkIHBRVqQ1qvMb+9LHk/cF4P6B2m8aP04hGf7oL6wZ9BuGwX1onlLhpuoofSyoQDQ==", 3137 | "requires": { 3138 | "ansi-styles": "^3.2.1", 3139 | "chalk": "^2.4.1", 3140 | "cross-spawn": "^6.0.5", 3141 | "memorystream": "^0.3.1", 3142 | "minimatch": "^3.0.4", 3143 | "pidtree": "^0.3.0", 3144 | "read-pkg": "^3.0.0", 3145 | "shell-quote": "^1.6.1", 3146 | "string.prototype.padend": "^3.0.0" 3147 | }, 3148 | "dependencies": { 3149 | "ansi-styles": { 3150 | "version": "3.2.1", 3151 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 3152 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 3153 | "requires": { 3154 | "color-convert": "^1.9.0" 3155 | } 3156 | }, 3157 | "color-convert": { 3158 | "version": "1.9.3", 3159 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", 3160 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", 3161 | "requires": { 3162 | "color-name": "1.1.3" 3163 | } 3164 | }, 3165 | "color-name": { 3166 | "version": "1.1.3", 3167 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 3168 | "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=" 3169 | }, 3170 | "cross-spawn": { 3171 | "version": "6.0.5", 3172 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-6.0.5.tgz", 3173 | "integrity": "sha512-eTVLrBSt7fjbDygz805pMnstIs2VTBNkRm0qxZd+M7A5XDdxVRWO5MxGBXZhjY4cqLYLdtrGqRf8mBPmzwSpWQ==", 3174 | "requires": { 3175 | "nice-try": "^1.0.4", 3176 | "path-key": "^2.0.1", 3177 | "semver": "^5.5.0", 3178 | "shebang-command": "^1.2.0", 3179 | "which": "^1.2.9" 3180 | } 3181 | }, 3182 | "path-key": { 3183 | "version": "2.0.1", 3184 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-2.0.1.tgz", 3185 | "integrity": "sha1-QRyttXTFoUDTpLGRDUDYDMn0C0A=" 3186 | }, 3187 | "shebang-command": { 3188 | "version": "1.2.0", 3189 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-1.2.0.tgz", 3190 | "integrity": "sha1-RKrGW2lbAzmJaMOfNj/uXer98eo=", 3191 | "requires": { 3192 | "shebang-regex": "^1.0.0" 3193 | } 3194 | }, 3195 | "shebang-regex": { 3196 | "version": "1.0.0", 3197 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-1.0.0.tgz", 3198 | "integrity": "sha1-2kL0l0DAtC2yypcoVxyxkMmO/qM=" 3199 | }, 3200 | "which": { 3201 | "version": "1.3.1", 3202 | "resolved": "https://registry.npmjs.org/which/-/which-1.3.1.tgz", 3203 | "integrity": "sha512-HxJdYWq1MTIQbJ3nw0cqssHoTNU267KlrDuGZ1WYlxDStUtKUhOaJmh112/TZmHxxUfuJqPXSOm7tDyas0OSIQ==", 3204 | "requires": { 3205 | "isexe": "^2.0.0" 3206 | } 3207 | } 3208 | } 3209 | }, 3210 | "npm-run-path": { 3211 | "version": "4.0.1", 3212 | "resolved": "https://registry.npmjs.org/npm-run-path/-/npm-run-path-4.0.1.tgz", 3213 | "integrity": "sha512-S48WzZW777zhNIrn7gxOlISNAqi9ZC/uQFnRdbeIHhZhCA6UqpkOT8T1G7BvfdgP4Er8gF4sUbaS0i7QvIfCWw==", 3214 | "dev": true, 3215 | "requires": { 3216 | "path-key": "^3.0.0" 3217 | } 3218 | }, 3219 | "object-inspect": { 3220 | "version": "1.12.0", 3221 | "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.12.0.tgz", 3222 | "integrity": "sha512-Ho2z80bVIvJloH+YzRmpZVQe87+qASmBUKZDWgx9cu+KDrX2ZDH/3tMy+gXbZETVGs2M8YdxObOh7XAtim9Y0g==" 3223 | }, 3224 | "object-keys": { 3225 | "version": "1.1.1", 3226 | "resolved": "https://registry.npmjs.org/object-keys/-/object-keys-1.1.1.tgz", 3227 | "integrity": "sha512-NuAESUOUMrlIXOfHKzD6bpPu3tYt3xvjNdRIQ+FeT0lNb4K8WR70CaDxhuNguS2XG+GjkyMwOzsN5ZktImfhLA==" 3228 | }, 3229 | "object.assign": { 3230 | "version": "4.1.2", 3231 | "resolved": "https://registry.npmjs.org/object.assign/-/object.assign-4.1.2.tgz", 3232 | "integrity": "sha512-ixT2L5THXsApyiUPYKmW+2EHpXXe5Ii3M+f4e+aJFAHao5amFRW6J0OO6c/LU8Be47utCx2GL89hxGB6XSmKuQ==", 3233 | "requires": { 3234 | "call-bind": "^1.0.0", 3235 | "define-properties": "^1.1.3", 3236 | "has-symbols": "^1.0.1", 3237 | "object-keys": "^1.1.1" 3238 | } 3239 | }, 3240 | "onetime": { 3241 | "version": "5.1.2", 3242 | "resolved": "https://registry.npmjs.org/onetime/-/onetime-5.1.2.tgz", 3243 | "integrity": "sha512-kbpaSSGJTWdAY5KPVeMOKXSrPtr8C8C7wodJbcsd51jRnmD+GZu8Y0VoU6Dm5Z4vWr0Ig/1NKuWRKf7j5aaYSg==", 3244 | "dev": true, 3245 | "requires": { 3246 | "mimic-fn": "^2.1.0" 3247 | } 3248 | }, 3249 | "p-map": { 3250 | "version": "4.0.0", 3251 | "resolved": "https://registry.npmjs.org/p-map/-/p-map-4.0.0.tgz", 3252 | "integrity": "sha512-/bjOqmgETBYB5BoEeGVea8dmvHb2m9GLy1E9W43yeyfP6QQCZGFNa+XRceJEuDB6zqr+gKpIAmlLebMpykw/MQ==", 3253 | "dev": true, 3254 | "requires": { 3255 | "aggregate-error": "^3.0.0" 3256 | } 3257 | }, 3258 | "parse-json": { 3259 | "version": "4.0.0", 3260 | "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-4.0.0.tgz", 3261 | "integrity": "sha1-vjX1Qlvh9/bHRxhPmKeIy5lHfuA=", 3262 | "requires": { 3263 | "error-ex": "^1.3.1", 3264 | "json-parse-better-errors": "^1.0.1" 3265 | } 3266 | }, 3267 | "path-key": { 3268 | "version": "3.1.1", 3269 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", 3270 | "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", 3271 | "dev": true 3272 | }, 3273 | "path-parse": { 3274 | "version": "1.0.7", 3275 | "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.7.tgz", 3276 | "integrity": "sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==" 3277 | }, 3278 | "path-type": { 3279 | "version": "3.0.0", 3280 | "resolved": "https://registry.npmjs.org/path-type/-/path-type-3.0.0.tgz", 3281 | "integrity": "sha512-T2ZUsdZFHgA3u4e5PfPbjd7HDDpxPnQb5jN0SrDsjNSuVXHJqtwTnWqG0B1jZrgmJ/7lj1EmVIByWt1gxGkWvg==", 3282 | "requires": { 3283 | "pify": "^3.0.0" 3284 | } 3285 | }, 3286 | "picocolors": { 3287 | "version": "1.0.0", 3288 | "resolved": "https://registry.npmjs.org/picocolors/-/picocolors-1.0.0.tgz", 3289 | "integrity": "sha512-1fygroTLlHu66zi26VoTDv8yRgm0Fccecssto+MhsZ0D/DGW2sm8E8AjW7NU5VVTRt5GxbeZ5qBuJr+HyLYkjQ==" 3290 | }, 3291 | "picomatch": { 3292 | "version": "2.3.1", 3293 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz", 3294 | "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==", 3295 | "dev": true 3296 | }, 3297 | "pidtree": { 3298 | "version": "0.3.1", 3299 | "resolved": "https://registry.npmjs.org/pidtree/-/pidtree-0.3.1.tgz", 3300 | "integrity": "sha512-qQbW94hLHEqCg7nhby4yRC7G2+jYHY4Rguc2bjw7Uug4GIJuu1tvf2uHaZv5Q8zdt+WKJ6qK1FOI6amaWUo5FA==" 3301 | }, 3302 | "pify": { 3303 | "version": "3.0.0", 3304 | "resolved": "https://registry.npmjs.org/pify/-/pify-3.0.0.tgz", 3305 | "integrity": "sha1-5aSs0sEB/fPZpNB/DbxNtJ3SgXY=" 3306 | }, 3307 | "postcss": { 3308 | "version": "8.4.5", 3309 | "resolved": "https://registry.npmjs.org/postcss/-/postcss-8.4.5.tgz", 3310 | "integrity": "sha512-jBDboWM8qpaqwkMwItqTQTiFikhs/67OYVvblFFTM7MrZjt6yMKd6r2kgXizEbTTljacm4NldIlZnhbjr84QYg==", 3311 | "requires": { 3312 | "nanoid": "^3.1.30", 3313 | "picocolors": "^1.0.0", 3314 | "source-map-js": "^1.0.1" 3315 | } 3316 | }, 3317 | "preact": { 3318 | "version": "10.6.4", 3319 | "resolved": "https://registry.npmjs.org/preact/-/preact-10.6.4.tgz", 3320 | "integrity": "sha512-WyosM7pxGcndU8hY0OQlLd54tOU+qmG45QXj2dAYrL11HoyU/EzOSTlpJsirbBr1QW7lICxSsVJJmcmUglovHQ==", 3321 | "dev": true 3322 | }, 3323 | "prettier": { 3324 | "version": "2.5.1", 3325 | "resolved": "https://registry.npmjs.org/prettier/-/prettier-2.5.1.tgz", 3326 | "integrity": "sha512-vBZcPRUR5MZJwoyi3ZoyQlc1rXeEck8KgeC9AwwOn+exuxLxq5toTRDTSaVrXHxelDMHy9zlicw8u66yxoSUFg==", 3327 | "dev": true 3328 | }, 3329 | "read-pkg": { 3330 | "version": "3.0.0", 3331 | "resolved": "https://registry.npmjs.org/read-pkg/-/read-pkg-3.0.0.tgz", 3332 | "integrity": "sha1-nLxoaXj+5l0WwA4rGcI3/Pbjg4k=", 3333 | "requires": { 3334 | "load-json-file": "^4.0.0", 3335 | "normalize-package-data": "^2.3.2", 3336 | "path-type": "^3.0.0" 3337 | } 3338 | }, 3339 | "resolve": { 3340 | "version": "1.21.0", 3341 | "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.21.0.tgz", 3342 | "integrity": "sha512-3wCbTpk5WJlyE4mSOtDLhqQmGFi0/TD9VPwmiolnk8U0wRgMEktqCXd3vy5buTO3tljvalNvKrjHEfrd2WpEKA==", 3343 | "requires": { 3344 | "is-core-module": "^2.8.0", 3345 | "path-parse": "^1.0.7", 3346 | "supports-preserve-symlinks-flag": "^1.0.0" 3347 | } 3348 | }, 3349 | "restore-cursor": { 3350 | "version": "3.1.0", 3351 | "resolved": "https://registry.npmjs.org/restore-cursor/-/restore-cursor-3.1.0.tgz", 3352 | "integrity": "sha512-l+sSefzHpj5qimhFSE5a8nufZYAM3sBSVMAPtYkmC+4EH2anSGaEMXSD0izRQbu9nfyQ9y5JrVmp7E8oZrUjvA==", 3353 | "dev": true, 3354 | "requires": { 3355 | "onetime": "^5.1.0", 3356 | "signal-exit": "^3.0.2" 3357 | } 3358 | }, 3359 | "rfdc": { 3360 | "version": "1.3.0", 3361 | "resolved": "https://registry.npmjs.org/rfdc/-/rfdc-1.3.0.tgz", 3362 | "integrity": "sha512-V2hovdzFbOi77/WajaSMXk2OLm+xNIeQdMMuB7icj7bk6zi2F8GGAxigcnDFpJHbNyNcgyJDiP+8nOrY5cZGrA==", 3363 | "dev": true 3364 | }, 3365 | "rollup": { 3366 | "version": "2.63.0", 3367 | "resolved": "https://registry.npmjs.org/rollup/-/rollup-2.63.0.tgz", 3368 | "integrity": "sha512-nps0idjmD+NXl6OREfyYXMn/dar3WGcyKn+KBzPdaLecub3x/LrId0wUcthcr8oZUAcZAR8NKcfGGFlNgGL1kQ==", 3369 | "requires": { 3370 | "fsevents": "~2.3.2" 3371 | } 3372 | }, 3373 | "rxjs": { 3374 | "version": "7.5.2", 3375 | "resolved": "https://registry.npmjs.org/rxjs/-/rxjs-7.5.2.tgz", 3376 | "integrity": "sha512-PwDt186XaL3QN5qXj/H9DGyHhP3/RYYgZZwqBv9Tv8rsAaiwFH1IsJJlcgD37J7UW5a6O67qX0KWKS3/pu0m4w==", 3377 | "dev": true, 3378 | "requires": { 3379 | "tslib": "^2.1.0" 3380 | } 3381 | }, 3382 | "semver": { 3383 | "version": "5.7.1", 3384 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", 3385 | "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==" 3386 | }, 3387 | "shebang-command": { 3388 | "version": "2.0.0", 3389 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", 3390 | "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", 3391 | "dev": true, 3392 | "requires": { 3393 | "shebang-regex": "^3.0.0" 3394 | } 3395 | }, 3396 | "shebang-regex": { 3397 | "version": "3.0.0", 3398 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", 3399 | "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", 3400 | "dev": true 3401 | }, 3402 | "shell-quote": { 3403 | "version": "1.7.3", 3404 | "resolved": "https://registry.npmjs.org/shell-quote/-/shell-quote-1.7.3.tgz", 3405 | "integrity": "sha512-Vpfqwm4EnqGdlsBFNmHhxhElJYrdfcxPThu+ryKS5J8L/fhAwLazFZtq+S+TWZ9ANj2piSQLGj6NQg+lKPmxrw==" 3406 | }, 3407 | "side-channel": { 3408 | "version": "1.0.4", 3409 | "resolved": "https://registry.npmjs.org/side-channel/-/side-channel-1.0.4.tgz", 3410 | "integrity": "sha512-q5XPytqFEIKHkGdiMIrY10mvLRvnQh42/+GoBlFW3b2LXLE2xxJpZFdm94we0BaoV3RwJyGqg5wS7epxTv0Zvw==", 3411 | "requires": { 3412 | "call-bind": "^1.0.0", 3413 | "get-intrinsic": "^1.0.2", 3414 | "object-inspect": "^1.9.0" 3415 | } 3416 | }, 3417 | "signal-exit": { 3418 | "version": "3.0.6", 3419 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.6.tgz", 3420 | "integrity": "sha512-sDl4qMFpijcGw22U5w63KmD3cZJfBuFlVNbVMKje2keoKML7X2UzWbc4XrmEbDwg0NXJc3yv4/ox7b+JWb57kQ==", 3421 | "dev": true 3422 | }, 3423 | "slice-ansi": { 3424 | "version": "5.0.0", 3425 | "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-5.0.0.tgz", 3426 | "integrity": "sha512-FC+lgizVPfie0kkhqUScwRu1O/lF6NOgJmlCgK+/LYxDCTk8sGelYaHDhFcDN+Sn3Cv+3VSa4Byeo+IMCzpMgQ==", 3427 | "dev": true, 3428 | "requires": { 3429 | "ansi-styles": "^6.0.0", 3430 | "is-fullwidth-code-point": "^4.0.0" 3431 | } 3432 | }, 3433 | "source-map-js": { 3434 | "version": "1.0.1", 3435 | "resolved": "https://registry.npmjs.org/source-map-js/-/source-map-js-1.0.1.tgz", 3436 | "integrity": "sha512-4+TN2b3tqOCd/kaGRJ/sTYA0tR0mdXx26ipdolxcwtJVqEnqNYvlCAt1q3ypy4QMlYus+Zh34RNtYLoq2oQ4IA==" 3437 | }, 3438 | "spdx-correct": { 3439 | "version": "3.1.1", 3440 | "resolved": "https://registry.npmjs.org/spdx-correct/-/spdx-correct-3.1.1.tgz", 3441 | "integrity": "sha512-cOYcUWwhCuHCXi49RhFRCyJEK3iPj1Ziz9DpViV3tbZOwXD49QzIN3MpOLJNxh2qwq2lJJZaKMVw9qNi4jTC0w==", 3442 | "requires": { 3443 | "spdx-expression-parse": "^3.0.0", 3444 | "spdx-license-ids": "^3.0.0" 3445 | } 3446 | }, 3447 | "spdx-exceptions": { 3448 | "version": "2.3.0", 3449 | "resolved": "https://registry.npmjs.org/spdx-exceptions/-/spdx-exceptions-2.3.0.tgz", 3450 | "integrity": "sha512-/tTrYOC7PPI1nUAgx34hUpqXuyJG+DTHJTnIULG4rDygi4xu/tfgmq1e1cIRwRzwZgo4NLySi+ricLkZkw4i5A==" 3451 | }, 3452 | "spdx-expression-parse": { 3453 | "version": "3.0.1", 3454 | "resolved": "https://registry.npmjs.org/spdx-expression-parse/-/spdx-expression-parse-3.0.1.tgz", 3455 | "integrity": "sha512-cbqHunsQWnJNE6KhVSMsMeH5H/L9EpymbzqTQ3uLwNCLZ1Q481oWaofqH7nO6V07xlXwY6PhQdQ2IedWx/ZK4Q==", 3456 | "requires": { 3457 | "spdx-exceptions": "^2.1.0", 3458 | "spdx-license-ids": "^3.0.0" 3459 | } 3460 | }, 3461 | "spdx-license-ids": { 3462 | "version": "3.0.11", 3463 | "resolved": "https://registry.npmjs.org/spdx-license-ids/-/spdx-license-ids-3.0.11.tgz", 3464 | "integrity": "sha512-Ctl2BrFiM0X3MANYgj3CkygxhRmr9mi6xhejbdO960nF6EDJApTYpn0BQnDKlnNBULKiCN1n3w9EBkHK8ZWg+g==" 3465 | }, 3466 | "string-argv": { 3467 | "version": "0.3.1", 3468 | "resolved": "https://registry.npmjs.org/string-argv/-/string-argv-0.3.1.tgz", 3469 | "integrity": "sha512-a1uQGz7IyVy9YwhqjZIZu1c8JO8dNIe20xBmSS6qu9kv++k3JGzCVmprbNN5Kn+BgzD5E7YYwg1CcjuJMRNsvg==", 3470 | "dev": true 3471 | }, 3472 | "string-width": { 3473 | "version": "5.1.0", 3474 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-5.1.0.tgz", 3475 | "integrity": "sha512-7x54QnN21P+XL/v8SuNKvfgsUre6PXpN7mc77N3HlZv+f1SBRGmjxtOud2Z6FZ8DmdkD/IdjCaf9XXbnqmTZGQ==", 3476 | "dev": true, 3477 | "requires": { 3478 | "eastasianwidth": "^0.2.0", 3479 | "emoji-regex": "^9.2.2", 3480 | "strip-ansi": "^7.0.1" 3481 | } 3482 | }, 3483 | "string.prototype.padend": { 3484 | "version": "3.1.3", 3485 | "resolved": "https://registry.npmjs.org/string.prototype.padend/-/string.prototype.padend-3.1.3.tgz", 3486 | "integrity": "sha512-jNIIeokznm8SD/TZISQsZKYu7RJyheFNt84DUPrh482GC8RVp2MKqm2O5oBRdGxbDQoXrhhWtPIWQOiy20svUg==", 3487 | "requires": { 3488 | "call-bind": "^1.0.2", 3489 | "define-properties": "^1.1.3", 3490 | "es-abstract": "^1.19.1" 3491 | } 3492 | }, 3493 | "string.prototype.trimend": { 3494 | "version": "1.0.4", 3495 | "resolved": "https://registry.npmjs.org/string.prototype.trimend/-/string.prototype.trimend-1.0.4.tgz", 3496 | "integrity": "sha512-y9xCjw1P23Awk8EvTpcyL2NIr1j7wJ39f+k6lvRnSMz+mz9CGz9NYPelDk42kOz6+ql8xjfK8oYzy3jAP5QU5A==", 3497 | "requires": { 3498 | "call-bind": "^1.0.2", 3499 | "define-properties": "^1.1.3" 3500 | } 3501 | }, 3502 | "string.prototype.trimstart": { 3503 | "version": "1.0.4", 3504 | "resolved": "https://registry.npmjs.org/string.prototype.trimstart/-/string.prototype.trimstart-1.0.4.tgz", 3505 | "integrity": "sha512-jh6e984OBfvxS50tdY2nRZnoC5/mLFKOREQfw8t5yytkoUsJRNxvI/E39qu1sD0OtWI3OC0XgKSmcWwziwYuZw==", 3506 | "requires": { 3507 | "call-bind": "^1.0.2", 3508 | "define-properties": "^1.1.3" 3509 | } 3510 | }, 3511 | "strip-ansi": { 3512 | "version": "7.0.1", 3513 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-7.0.1.tgz", 3514 | "integrity": "sha512-cXNxvT8dFNRVfhVME3JAe98mkXDYN2O1l7jmcwMnOslDeESg1rF/OZMtK0nRAhiari1unG5cD4jG3rapUAkLbw==", 3515 | "dev": true, 3516 | "requires": { 3517 | "ansi-regex": "^6.0.1" 3518 | } 3519 | }, 3520 | "strip-bom": { 3521 | "version": "3.0.0", 3522 | "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-3.0.0.tgz", 3523 | "integrity": "sha1-IzTBjpx1n3vdVv3vfprj1YjmjtM=" 3524 | }, 3525 | "strip-final-newline": { 3526 | "version": "2.0.0", 3527 | "resolved": "https://registry.npmjs.org/strip-final-newline/-/strip-final-newline-2.0.0.tgz", 3528 | "integrity": "sha512-BrpvfNAE3dcvq7ll3xVumzjKjZQ5tI1sEUIKr3Uoks0XUl45St3FlatVqef9prk4jRDzhW6WZg+3bk93y6pLjA==", 3529 | "dev": true 3530 | }, 3531 | "supports-color": { 3532 | "version": "9.2.1", 3533 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-9.2.1.tgz", 3534 | "integrity": "sha512-Obv7ycoCTG51N7y175StI9BlAXrmgZrFhZOb0/PyjHBher/NmsdBgbbQ1Inhq+gIhz6+7Gb+jWF2Vqi7Mf1xnQ==", 3535 | "dev": true 3536 | }, 3537 | "supports-preserve-symlinks-flag": { 3538 | "version": "1.0.0", 3539 | "resolved": "https://registry.npmjs.org/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz", 3540 | "integrity": "sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w==" 3541 | }, 3542 | "through": { 3543 | "version": "2.3.8", 3544 | "resolved": "https://registry.npmjs.org/through/-/through-2.3.8.tgz", 3545 | "integrity": "sha1-DdTJ/6q8NXlgsbckEV1+Doai4fU=", 3546 | "dev": true 3547 | }, 3548 | "to-regex-range": { 3549 | "version": "5.0.1", 3550 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 3551 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 3552 | "dev": true, 3553 | "requires": { 3554 | "is-number": "^7.0.0" 3555 | } 3556 | }, 3557 | "tslib": { 3558 | "version": "2.3.1", 3559 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.3.1.tgz", 3560 | "integrity": "sha512-77EbyPPpMz+FRFRuAFlWMtmgUWGe9UOG2Z25NqCwiIjRhOf5iKGuzSe5P2w1laq+FkRy4p+PCuVkJSGkzTEKVw==", 3561 | "dev": true 3562 | }, 3563 | "type-fest": { 3564 | "version": "0.21.3", 3565 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.21.3.tgz", 3566 | "integrity": "sha512-t0rzBq87m3fVcduHDUFhKmyyX+9eo6WQjZvf51Ea/M0Q7+T374Jp1aUiyUl0GKxp8M/OETVHSDvmkyPgvX+X2w==", 3567 | "dev": true 3568 | }, 3569 | "unbox-primitive": { 3570 | "version": "1.0.1", 3571 | "resolved": "https://registry.npmjs.org/unbox-primitive/-/unbox-primitive-1.0.1.tgz", 3572 | "integrity": "sha512-tZU/3NqK3dA5gpE1KtyiJUrEB0lxnGkMFHptJ7q6ewdZ8s12QrODwNbhIJStmJkd1QDXa1NRA8aF2A1zk/Ypyw==", 3573 | "requires": { 3574 | "function-bind": "^1.1.1", 3575 | "has-bigints": "^1.0.1", 3576 | "has-symbols": "^1.0.2", 3577 | "which-boxed-primitive": "^1.0.2" 3578 | } 3579 | }, 3580 | "validate-npm-package-license": { 3581 | "version": "3.0.4", 3582 | "resolved": "https://registry.npmjs.org/validate-npm-package-license/-/validate-npm-package-license-3.0.4.tgz", 3583 | "integrity": "sha512-DpKm2Ui/xN7/HQKCtpZxoRWBhZ9Z0kqtygG8XCgNQ8ZlDnxuQmWhj566j8fN4Cu3/JmbhsDo7fcAJq4s9h27Ew==", 3584 | "requires": { 3585 | "spdx-correct": "^3.0.0", 3586 | "spdx-expression-parse": "^3.0.0" 3587 | } 3588 | }, 3589 | "vite": { 3590 | "version": "2.8.0-beta.1", 3591 | "resolved": "https://registry.npmjs.org/vite/-/vite-2.8.0-beta.1.tgz", 3592 | "integrity": "sha512-tAXGZKPGPntD7MXHm+pxSy8+aY8iC7u+qK+8pl3hQfj2mTwvpQq2Tk/oydsNIXIQz9ott76H9C89IvhOmp6BvQ==", 3593 | "requires": { 3594 | "esbuild": "0.14.3", 3595 | "fsevents": "~2.3.2", 3596 | "json5": "^2.2.0", 3597 | "postcss": "^8.4.5", 3598 | "resolve": "^1.20.0", 3599 | "rollup": "^2.59.0" 3600 | } 3601 | }, 3602 | "which": { 3603 | "version": "2.0.2", 3604 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", 3605 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", 3606 | "dev": true, 3607 | "requires": { 3608 | "isexe": "^2.0.0" 3609 | } 3610 | }, 3611 | "which-boxed-primitive": { 3612 | "version": "1.0.2", 3613 | "resolved": "https://registry.npmjs.org/which-boxed-primitive/-/which-boxed-primitive-1.0.2.tgz", 3614 | "integrity": "sha512-bwZdv0AKLpplFY2KZRX6TvyuN7ojjr7lwkg6ml0roIy9YeuSr7JS372qlNW18UQYzgYK9ziGcerWqZOmEn9VNg==", 3615 | "requires": { 3616 | "is-bigint": "^1.0.1", 3617 | "is-boolean-object": "^1.1.0", 3618 | "is-number-object": "^1.0.4", 3619 | "is-string": "^1.0.5", 3620 | "is-symbol": "^1.0.3" 3621 | } 3622 | }, 3623 | "wrap-ansi": { 3624 | "version": "7.0.0", 3625 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz", 3626 | "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==", 3627 | "dev": true, 3628 | "requires": { 3629 | "ansi-styles": "^4.0.0", 3630 | "string-width": "^4.1.0", 3631 | "strip-ansi": "^6.0.0" 3632 | }, 3633 | "dependencies": { 3634 | "ansi-regex": { 3635 | "version": "5.0.1", 3636 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 3637 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 3638 | "dev": true 3639 | }, 3640 | "ansi-styles": { 3641 | "version": "4.3.0", 3642 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 3643 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 3644 | "dev": true, 3645 | "requires": { 3646 | "color-convert": "^2.0.1" 3647 | } 3648 | }, 3649 | "emoji-regex": { 3650 | "version": "8.0.0", 3651 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 3652 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 3653 | "dev": true 3654 | }, 3655 | "is-fullwidth-code-point": { 3656 | "version": "3.0.0", 3657 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 3658 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 3659 | "dev": true 3660 | }, 3661 | "string-width": { 3662 | "version": "4.2.3", 3663 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", 3664 | "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", 3665 | "dev": true, 3666 | "requires": { 3667 | "emoji-regex": "^8.0.0", 3668 | "is-fullwidth-code-point": "^3.0.0", 3669 | "strip-ansi": "^6.0.1" 3670 | } 3671 | }, 3672 | "strip-ansi": { 3673 | "version": "6.0.1", 3674 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 3675 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 3676 | "dev": true, 3677 | "requires": { 3678 | "ansi-regex": "^5.0.1" 3679 | } 3680 | } 3681 | } 3682 | }, 3683 | "yaml": { 3684 | "version": "1.10.2", 3685 | "resolved": "https://registry.npmjs.org/yaml/-/yaml-1.10.2.tgz", 3686 | "integrity": "sha512-r3vXyErRCYJ7wg28yvBY5VSoAF8ZvlcW9/BwUzEtUsjvX/DKs24dIkuwjtuprwJJHsbyUbLApepYTR1BN4uHrg==", 3687 | "dev": true 3688 | } 3689 | } 3690 | } 3691 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "use-workerized-reducer", 3 | "version": "0.0.7", 4 | "description": "Like useReducer, but runs in a worker.", 5 | "scripts": { 6 | "build:generic": "vite build -c vite.config.generic.js", 7 | "build:preact": "vite build -c vite.config.preact.js", 8 | "build:react": "vite build -c vite.config.react.js", 9 | "build": "run-p build:*", 10 | "dev": "vite .", 11 | "prepare": "husky install" 12 | }, 13 | "keywords": [], 14 | "author": "Surma ", 15 | "license": "Apache-2.0", 16 | "devDependencies": { 17 | "husky": "^7.0.4", 18 | "lint-staged": "^12.1.7", 19 | "npm-run-all": "^4.1.5", 20 | "preact": "^10.6.4", 21 | "prettier": "^2.5.1", 22 | "vite": "^2.8.0-beta.1" 23 | }, 24 | "dependencies": { 25 | "immer": "^9.0.12" 26 | }, 27 | "lint-staged": { 28 | "*.{js,css,md}": "prettier --write" 29 | }, 30 | "repository": "github:surma/use-workerized-reducer", 31 | "module": "dist/generic/use-workerized-reducer.es.js", 32 | "exports": { 33 | ".": { 34 | "import": "./dist/generic/use-workerized-reducer.es.js" 35 | }, 36 | "./react": { 37 | "import": "./dist/react/use-workerized-reducer.es.js" 38 | }, 39 | "./preact": { 40 | "import": "./dist/preact/use-workerized-reducer.es.js" 41 | } 42 | } 43 | } 44 | -------------------------------------------------------------------------------- /src/use-workerized-reducer.preact.ts: -------------------------------------------------------------------------------- 1 | // @ts-ignore 2 | import { useState, useEffect, useMemo } from "preact/hooks"; 3 | import { useWorkerizedReducer as genericUseWorkerizedReducer } from "./use-workerized-reducer.js"; 4 | 5 | export { initWorkerizedReducer } from "./use-workerized-reducer.js"; 6 | 7 | export function useWorkerizedReducer( 8 | worker: Worker, 9 | reducerName: string, 10 | initialState: State 11 | ) { 12 | return genericUseWorkerizedReducer( 13 | worker, 14 | reducerName, 15 | initialState, 16 | useState, 17 | useEffect, 18 | useMemo 19 | ); 20 | } 21 | -------------------------------------------------------------------------------- /src/use-workerized-reducer.react.ts: -------------------------------------------------------------------------------- 1 | // @ts-ignore 2 | import { useState, useEffect, useMemo } from "react"; 3 | import { useWorkerizedReducer as genericUseWorkerizedReducer } from "./use-workerized-reducer.js"; 4 | 5 | export { initWorkerizedReducer } from "./use-workerized-reducer.js"; 6 | 7 | export function useWorkerizedReducer( 8 | worker: Worker, 9 | reducerName: string, 10 | initialState: State 11 | ) { 12 | return genericUseWorkerizedReducer( 13 | worker, 14 | reducerName, 15 | initialState, 16 | useState, 17 | useEffect, 18 | useMemo 19 | ); 20 | } 21 | -------------------------------------------------------------------------------- /src/use-workerized-reducer.ts: -------------------------------------------------------------------------------- 1 | import { 2 | produce, 3 | applyPatches, 4 | Patch, 5 | Draft, 6 | enablePatches, 7 | enableMapSet, 8 | } from "immer"; 9 | enablePatches(); 10 | enableMapSet(); 11 | 12 | export type Reducer = ( 13 | prevState: State, 14 | action: Action, 15 | localState: LocalState 16 | ) => State; 17 | export type DispatchFunc = (a: Action) => void; 18 | export type UseReducer = ( 19 | reducer: Reducer, 20 | initialState: State 21 | ) => [State, DispatchFunc]; 22 | export type UseEffect = ( 23 | callback: () => void | (() => void), 24 | inputs: ReadonlyArray 25 | ) => void; 26 | export type StateUpdater = (value: S | ((prevState: S) => S)) => void; 27 | export type UseState = (initialState: S | (() => S)) => [S, StateUpdater]; 28 | export interface MutableRef { 29 | current: T; 30 | } 31 | export type UseRef = (initialValue: T) => MutableRef; 32 | export type UseMemo = ( 33 | factory: () => T, 34 | inputs: ReadonlyArray | undefined 35 | ) => T; 36 | 37 | interface InitMessage { 38 | __uwrType: "init"; 39 | name: string; 40 | id: number; 41 | initialState: State; 42 | } 43 | 44 | interface DispatchMessage { 45 | __uwrType: "dispatch"; 46 | name: string; 47 | id: number; 48 | action: Action; 49 | } 50 | 51 | interface DestroyMessage { 52 | __uwrType: "destroy"; 53 | name: string; 54 | } 55 | 56 | interface PatchMessage { 57 | __uwrType: "patch"; 58 | id: number; 59 | patches: Patch[]; 60 | } 61 | 62 | type UWRMessage = 63 | | InitMessage 64 | | DispatchMessage 65 | | DestroyMessage; 66 | 67 | type DistributiveOmit = T extends infer R ? Omit : never; 68 | 69 | export function initWorkerizedReducer( 70 | reducerName: string, 71 | reducer: Reducer, Action>, 72 | initialLocalState: (initialState: State) => LocalState = () => ({} as any) 73 | ) { 74 | const activeReducers = new Map< 75 | String, 76 | WritableStream> 77 | >(); 78 | 79 | function sendPatch(id: number, patches: Patch[]) { 80 | const msg: PatchMessage = { 81 | __uwrType: "patch", 82 | id, 83 | patches, 84 | }; 85 | postMessage(msg); 86 | } 87 | 88 | function createMessageQueue() { 89 | let localState: LocalState; 90 | let state: State | null = null; 91 | return new WritableStream>({ 92 | async write(data, controller) { 93 | switch (data.__uwrType) { 94 | case "init": 95 | { 96 | const { id, initialState } = data; 97 | state = initialState; 98 | localState = initialLocalState(state); 99 | sendPatch(id, []); 100 | } 101 | break; 102 | case "dispatch": 103 | { 104 | const { id, action } = data; 105 | state = await produce( 106 | state, 107 | async (state) => { 108 | await reducer(state, action, localState); 109 | }, 110 | (patches) => sendPatch(id, patches) 111 | ); 112 | } 113 | break; 114 | case "destroy": 115 | { 116 | const { name } = data; 117 | activeReducers.delete(name); 118 | controller.error(); 119 | } 120 | break; 121 | } 122 | }, 123 | }); 124 | } 125 | 126 | function listener(ev: MessageEvent) { 127 | if (typeof ev.data !== "object" || !("__uwrType" in ev.data)) return; 128 | const data = ev.data as UWRMessage; 129 | if (data.__uwrType === "init") { 130 | const { name } = data; 131 | const [id, initReducerName] = JSON.parse(name) as [number, string]; 132 | if (initReducerName !== reducerName) return; 133 | if (activeReducers.has(name)) return; 134 | const ws = createMessageQueue(); 135 | activeReducers.set(name, ws); 136 | } 137 | const { name } = data; 138 | const ws = activeReducers.get(name); 139 | if (!ws) return; 140 | const w = ws.getWriter(); 141 | w.write(data); 142 | w.releaseLock(); 143 | } 144 | addEventListener("message", listener); 145 | } 146 | 147 | function uid() { 148 | return Array.from({ length: 16 }, () => 149 | Math.floor(Math.random() * 256).toString(16) 150 | ).join(""); 151 | } 152 | 153 | let idCounter = 0; 154 | export function useWorkerizedReducer( 155 | worker: Worker, 156 | reducerName: string, 157 | initialState: State, 158 | originalUseState: UseState, 159 | originalUseEffect: UseEffect, 160 | originalUseMemo: UseMemo 161 | ): [State | null, DispatchFunc, boolean] { 162 | const id = originalUseMemo(() => idCounter++, []); 163 | const [pendingIds] = originalUseState(new Set()); 164 | const [state, setState] = originalUseState(initialState); 165 | // Initially set to true until the initialState 166 | // has been applied in the worker. 167 | const [isBusy, setBusy] = originalUseState(true); 168 | 169 | function fullReducerName() { 170 | return JSON.stringify([id, reducerName]); 171 | } 172 | 173 | function send(payload: DistributiveOmit, 'id' | 'name'>) { 174 | const id = uid(); 175 | pendingIds.add(id); 176 | setBusy(true); 177 | worker.postMessage({ name: fullReducerName(), id, ...payload }); 178 | } 179 | 180 | async function dispatch(action: Action) { 181 | send({ 182 | __uwrType: "dispatch", 183 | action, 184 | }); 185 | } 186 | 187 | originalUseEffect(() => { 188 | function listener(ev: MessageEvent) { 189 | if (typeof ev.data !== "object" || !("__uwrType" in ev.data)) return; 190 | const data = ev.data as PatchMessage; 191 | // For safety 192 | if (data.__uwrType !== "patch") return; 193 | const { id, patches } = data; 194 | if (!pendingIds.has(id)) return; 195 | pendingIds.delete(id); 196 | if (pendingIds.size === 0) setBusy(false); 197 | setState((state) => { 198 | return applyPatches(state, patches); 199 | }); 200 | } 201 | worker.addEventListener("message", listener); 202 | send({ __uwrType: "init", initialState }); 203 | return () => { 204 | worker.removeEventListener("message", listener); 205 | send({ __uwrType: "destroy" }); 206 | }; 207 | }, []); 208 | 209 | return [state, dispatch, isBusy]; 210 | } 211 | -------------------------------------------------------------------------------- /tests/basic/app.jsx: -------------------------------------------------------------------------------- 1 | /* @jsx h */ 2 | 3 | import { h, render } from "preact"; 4 | import { useEffect } from "preact/hooks"; 5 | import { testSuite, externalPromise } from "/tests/test-utils.js"; 6 | import { useWorkerizedReducer } from "/dist/preact/use-workerized-reducer.es.js"; 7 | 8 | const worker = new Worker(new URL("./worker.js", import.meta.url), { 9 | type: "module", 10 | }); 11 | 12 | testSuite("Basic reducer functionality", async () => { 13 | const [promise, resolve] = externalPromise(); 14 | function App() { 15 | const [state, dispatch] = useWorkerizedReducer(worker, "reducer", { 16 | counter: 0, 17 | }); 18 | 19 | useEffect(() => { 20 | if (state.counter === 0) dispatch({ type: "increment" }); 21 | if (state.counter === 1) resolve(); 22 | }, [state]); 23 | 24 | return
{JSON.stringify(state, null, "  ")}
; 25 | } 26 | 27 | render(, document.all.main); 28 | 29 | return promise; 30 | }); 31 | -------------------------------------------------------------------------------- /tests/basic/index.html: -------------------------------------------------------------------------------- 1 | 2 |
3 | 4 | -------------------------------------------------------------------------------- /tests/basic/worker.js: -------------------------------------------------------------------------------- 1 | import { initWorkerizedReducer } from "/dist/preact/use-workerized-reducer.es.js"; 2 | 3 | initWorkerizedReducer("reducer", (state, { type }) => { 4 | if (type === "increment") { 5 | state.counter += 1; 6 | } 7 | }); 8 | -------------------------------------------------------------------------------- /tests/index.html: -------------------------------------------------------------------------------- 1 | 2 | 9 |
10 | 11 | 40 | -------------------------------------------------------------------------------- /tests/instant-dispatch/app.jsx: -------------------------------------------------------------------------------- 1 | /* @jsx h */ 2 | 3 | import { h, render } from "preact"; 4 | import { useEffect } from "preact/hooks"; 5 | import { testSuite, externalPromise } from "/tests/test-utils.js"; 6 | import { useWorkerizedReducer } from "/dist/preact/use-workerized-reducer.es.js"; 7 | 8 | const worker = new Worker(new URL("./worker.js", import.meta.url), { 9 | type: "module", 10 | }); 11 | 12 | testSuite("Dispatching on mount", async () => { 13 | const [promise, resolve] = externalPromise(); 14 | function App() { 15 | const [state, dispatch] = useWorkerizedReducer(worker, "reducer", { 16 | counter: 0, 17 | }); 18 | 19 | useEffect(() => dispatch({ type: "increment" }), []); 20 | if (state?.counter === 1) resolve(); 21 | 22 | return
{JSON.stringify(state, null, "  ")}
; 23 | } 24 | 25 | render(, document.all.main); 26 | 27 | return promise; 28 | }); 29 | -------------------------------------------------------------------------------- /tests/instant-dispatch/index.html: -------------------------------------------------------------------------------- 1 | 2 |
3 | 4 | -------------------------------------------------------------------------------- /tests/instant-dispatch/worker.js: -------------------------------------------------------------------------------- 1 | import { initWorkerizedReducer } from "/dist/preact/use-workerized-reducer.es.js"; 2 | 3 | initWorkerizedReducer("reducer", (state, { type }) => { 4 | if (type === "increment") { 5 | state.counter += 1; 6 | } 7 | }); 8 | -------------------------------------------------------------------------------- /tests/local-state/app.jsx: -------------------------------------------------------------------------------- 1 | /* @jsx h */ 2 | 3 | import { h, render } from "preact"; 4 | import { useEffect } from "preact/hooks"; 5 | import { testSuite, externalPromise } from "/tests/test-utils.js"; 6 | import { useWorkerizedReducer } from "/dist/preact/use-workerized-reducer.es.js"; 7 | 8 | const worker = new Worker(new URL("./worker.js", import.meta.url), { 9 | type: "module", 10 | }); 11 | 12 | testSuite("Holds local state", async () => { 13 | const [promise, resolve] = externalPromise(); 14 | function App() { 15 | const [state, dispatch] = useWorkerizedReducer(worker, "reducer", { 16 | counter: 0, 17 | }); 18 | 19 | useEffect(() => { 20 | if (state.counter === 0) dispatch({}); 21 | if (state.counter === 1) resolve(); 22 | }, [state]); 23 | 24 | return
{JSON.stringify(state, null, "  ")}
; 25 | } 26 | 27 | render(, document.all.main); 28 | 29 | return promise; 30 | }); 31 | -------------------------------------------------------------------------------- /tests/local-state/index.html: -------------------------------------------------------------------------------- 1 | 2 |
3 | 4 | -------------------------------------------------------------------------------- /tests/local-state/worker.js: -------------------------------------------------------------------------------- 1 | import { initWorkerizedReducer } from "/dist/preact/use-workerized-reducer.es.js"; 2 | 3 | initWorkerizedReducer( 4 | "reducer", 5 | (state, action, { increment }) => { 6 | state.counter += increment; 7 | }, 8 | () => ({ increment: 1 }) 9 | ); 10 | -------------------------------------------------------------------------------- /tests/multi-component/app.jsx: -------------------------------------------------------------------------------- 1 | /* @jsx h */ 2 | 3 | import { h, render, Fragment } from "preact"; 4 | import { useEffect } from "preact/hooks"; 5 | import { testSuite, externalPromise } from "/tests/test-utils.js"; 6 | import { useWorkerizedReducer } from "/dist/preact/use-workerized-reducer.es.js"; 7 | 8 | const worker = new Worker(new URL("./worker.js", import.meta.url), { 9 | type: "module", 10 | }); 11 | 12 | testSuite("Reusing a component", async () => { 13 | const [promise, resolve, reject] = externalPromise(); 14 | const checkState = { counter1: -1, counter2: -1 }; 15 | function check() { 16 | if (checkState.counter2 > 0) reject("Counter 2 got incremented"); 17 | if (checkState.counter1 == 1 && checkState.counter2 == 0) resolve(); 18 | } 19 | 20 | function Counter({ name, autoIncrement = false }) { 21 | const [state, dispatch] = useWorkerizedReducer(worker, "reducer", { 22 | counter: 0, 23 | }); 24 | 25 | checkState[name] = state?.counter; 26 | check(); 27 | 28 | useEffect(() => { 29 | if (autoIncrement) dispatch({ type: "increment" }); 30 | }, []); 31 | 32 | return
{JSON.stringify(state, null, "  ")}
; 33 | } 34 | 35 | function App() { 36 | return ( 37 | 38 | 39 | 40 | 41 | ); 42 | } 43 | 44 | render(, document.all.main); 45 | 46 | return promise; 47 | }); 48 | -------------------------------------------------------------------------------- /tests/multi-component/index.html: -------------------------------------------------------------------------------- 1 | 2 |
3 | 4 | -------------------------------------------------------------------------------- /tests/multi-component/worker.js: -------------------------------------------------------------------------------- 1 | import { initWorkerizedReducer } from "/dist/preact/use-workerized-reducer.es.js"; 2 | 3 | initWorkerizedReducer("reducer", (state, { type }) => { 4 | if (type === "increment") { 5 | state.counter += 1; 6 | } 7 | }); 8 | -------------------------------------------------------------------------------- /tests/remount/app.jsx: -------------------------------------------------------------------------------- 1 | /* @jsx h */ 2 | 3 | import { h, render } from "preact"; 4 | import { useState, useEffect } from "preact/hooks"; 5 | import { testSuite, externalPromise } from "/tests/test-utils.js"; 6 | import { useWorkerizedReducer } from "/dist/preact/use-workerized-reducer.es.js"; 7 | 8 | const worker = new Worker(new URL("./worker.js", import.meta.url), { 9 | type: "module", 10 | }); 11 | 12 | testSuite("Remounting", async () => { 13 | const [promise, resolve] = externalPromise(); 14 | function Counter({ provideState }) { 15 | const [state, dispatch] = useWorkerizedReducer(worker, "reducer", { 16 | counter: 0, 17 | }); 18 | 19 | useEffect(() => provideState({ state, dispatch }), [state]); 20 | return
{JSON.stringify(state, null, "  ")}
; 21 | } 22 | 23 | function App() { 24 | const [state, setState] = useState(0); 25 | 26 | if (state === 0) { 27 | return ( 28 |
29 | {state}:{" "} 30 | { 32 | if (state?.counter != 0) return; 33 | dispatch({ type: "increment" }); 34 | setState((state) => state + 1); 35 | }} 36 | /> 37 |
38 | ); 39 | } else if (state === 1) { 40 | setState((state) => state + 1); 41 | return
 {state} 
; 42 | } else if (state === 2) { 43 | return ( 44 |
45 | {state} 46 | { 48 | if (state?.counter == 0) resolve(); 49 | }} 50 | /> 51 |
52 | ); 53 | } 54 | } 55 | 56 | render(, document.all.main); 57 | 58 | return promise; 59 | }); 60 | -------------------------------------------------------------------------------- /tests/remount/index.html: -------------------------------------------------------------------------------- 1 | 2 |
3 | 4 | -------------------------------------------------------------------------------- /tests/remount/worker.js: -------------------------------------------------------------------------------- 1 | import { initWorkerizedReducer } from "/dist/preact/use-workerized-reducer.es.js"; 2 | 3 | initWorkerizedReducer("reducer", (state, { type }) => { 4 | if (type === "increment") { 5 | state.counter += 1; 6 | } 7 | }); 8 | -------------------------------------------------------------------------------- /tests/test-utils.js: -------------------------------------------------------------------------------- 1 | /** 2 | * Copyright 2021 Google Inc. All Rights Reserved. 3 | * Licensed under the Apache License, Version 2.0 (the "License"); 4 | * you may not use this file except in compliance with the License. 5 | * You may obtain a copy of the License at 6 | * http://www.apache.org/licenses/LICENSE-2.0 7 | * Unless required by applicable law or agreed to in writing, software 8 | * distributed under the License is distributed on an "AS IS" BASIS, 9 | * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 10 | * See the License for the specific language governing permissions and 11 | * limitations under the License. 12 | */ 13 | 14 | export function externalPromise() { 15 | let resolve, reject; 16 | const promise = new Promise((resolve_, reject_) => { 17 | resolve = resolve_; 18 | reject = reject_; 19 | }); 20 | return [promise, resolve, reject]; 21 | } 22 | 23 | export function doubleRaf() { 24 | return new Promise((resolve) => { 25 | requestAnimationFrame(() => { 26 | requestAnimationFrame(() => { 27 | resolve(); 28 | }); 29 | }); 30 | }); 31 | } 32 | 33 | export function fail(msg) { 34 | window.parent?.postMessage(msg, "*"); 35 | } 36 | 37 | export function success() { 38 | window.parent?.postMessage(true, "*"); 39 | } 40 | 41 | export function nextEvent(el, name) { 42 | return new Promise((resolve) => 43 | el.addEventListener(name, resolve, { once: true }) 44 | ); 45 | } 46 | 47 | export function assert(bool, msg) { 48 | if (!bool) { 49 | throw Error(msg); 50 | } 51 | } 52 | 53 | export function assertEquals(a, b, msg) { 54 | if (a !== b) { 55 | throw Error(`Expected ${a} == ${b}. ${msg}`); 56 | } 57 | } 58 | 59 | export function timeout(ms) { 60 | return new Promise((resolve) => setTimeout(resolve, ms)); 61 | } 62 | 63 | export async function testSuite(name, cb) { 64 | try { 65 | await Promise.race([ 66 | cb(), 67 | timeout(2000).then(() => { 68 | throw Error(`Timeout`); 69 | }), 70 | ]); 71 | } catch (e) { 72 | console.error(e); 73 | fail(`${name}: ${e}`); 74 | return; 75 | } 76 | success(); 77 | console.log("Test passed successfully"); 78 | } 79 | -------------------------------------------------------------------------------- /vite.baseconfig.js: -------------------------------------------------------------------------------- 1 | export default function (variant) { 2 | return { 3 | outDir: "./dist", 4 | build: { 5 | target: "es2019", 6 | emptyOutDir: false, 7 | lib: { 8 | entry: [ 9 | "./src/use-workerized-reducer", 10 | variant !== "generic" ? variant : null, 11 | "ts", 12 | ] 13 | .filter(Boolean) 14 | .join("."), 15 | fileName: `${variant}/use-workerized-reducer`, 16 | formats: ["es"], 17 | }, 18 | rollupOptions: { 19 | external: ["preact", "react", "preact/hooks"], 20 | }, 21 | }, 22 | optimizeDeps: {}, 23 | }; 24 | } 25 | -------------------------------------------------------------------------------- /vite.config.generic.js: -------------------------------------------------------------------------------- 1 | import generateConfig from "./vite.baseconfig.js"; 2 | 3 | export default generateConfig("generic"); 4 | -------------------------------------------------------------------------------- /vite.config.preact.js: -------------------------------------------------------------------------------- 1 | import generateConfig from "./vite.baseconfig.js"; 2 | 3 | export default generateConfig("preact"); 4 | -------------------------------------------------------------------------------- /vite.config.react.js: -------------------------------------------------------------------------------- 1 | import generateConfig from "./vite.baseconfig.js"; 2 | 3 | export default generateConfig("react"); 4 | --------------------------------------------------------------------------------