├── .gitignore ├── .npmignore ├── CHANGELOG.md ├── LICENSE ├── README.md ├── images ├── patchState-path-autocompletion.gif └── patchState-typed-value.gif ├── package-lock.json ├── package.json ├── src ├── index.ts ├── store.spec.ts └── store.ts ├── tsconfig-cjs.json └── tsconfig.json /.gitignore: -------------------------------------------------------------------------------- 1 | /lib 2 | node_modules 3 | .idea 4 | -------------------------------------------------------------------------------- /.npmignore: -------------------------------------------------------------------------------- 1 | .DS_Store 2 | tsconfig.json 3 | src 4 | -------------------------------------------------------------------------------- /CHANGELOG.md: -------------------------------------------------------------------------------- 1 | # Changelog 2 | 3 | All notable changes to this project will be documented in this file. 4 | 5 | The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/), 6 | and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html). 7 | 8 | ## [3.1.0] - 2022-02-08 9 | 10 | ### Changed 11 | 12 | * Updated dependencies to support TypeScript@4.5.x and rxjs@7.x (and consequently Angular@13 in cases where `rxjs-observable-store` package is used in Angular projects). 13 | 14 | ## [3.0.4] - 2020-08-20 15 | 16 | ### Changed 17 | 18 | * Removed one level of overloads for `patchState`/`onChanges` methods to prevent `error TS2589: Type instantiation is excessively deep and possibly infinite.` error when using `rxjs-observable-store` with TypeScript versions above `3.9.x`. 19 | 20 | ## [3.0.3] - 2020-06-30 21 | 22 | ### Changed 23 | 24 | * Update `author` in `package.json`. 25 | 26 | ## [3.0.2] - 2020-06-30 27 | 28 | ### Added 29 | 30 | * Build CommonJS and ESM versions of rxjs-observable-store package. 31 | 32 | ## [3.0.1] - 2020-06-29 33 | 34 | ### Changed 35 | 36 | * Changed all references from https://jurebajt.com to https://georgebyte.com. 37 | 38 | ## [3.0.0] - 2020-06-29 39 | 40 | ### Added 41 | 42 | * Added `onChanges` method to `Store`. 43 | 44 | ### Changed 45 | 46 | * Built the rxjs-observable-store package with TypeScript version 3.6.5. 47 | 48 | ## [2.0.4] - 2019-12-03 49 | 50 | ### Changed 51 | 52 | * Downgraded TypeScript version to 3.5.3. 53 | 54 | ## [2.0.3] - 2019-12-03 55 | 56 | ### Changed 57 | 58 | * Downgraded TypeScript version to 3.6.3. 59 | 60 | ## [2.0.2] - 2019-12-03 61 | 62 | ### Changed 63 | 64 | * Updated dependencies. 65 | 66 | ## [2.0.1] - 2019-09-09 67 | 68 | ### Changed 69 | 70 | * Updated README to include TypeScript version requirement. 71 | 72 | ## 2.0.0 - 2019-09-09 73 | 74 | ### Added 75 | 76 | * Added `patchState` method to `Store`. 77 | * Added CHANGELOG file. 78 | 79 | ### Changed 80 | 81 | * Improved unit tests' coverage. 82 | * Updated npm dependencies. 83 | * Updated README with API documentation and better usage example. 84 | 85 | [3.1.0]: https://github.com/georgebyte/rxjs-observable-store/compare/v3.0.4...v3.1.0 86 | [3.0.4]: https://github.com/georgebyte/rxjs-observable-store/compare/v3.0.3...v3.0.4 87 | [3.0.3]: https://github.com/georgebyte/rxjs-observable-store/compare/v3.0.2...v3.0.3 88 | [3.0.2]: https://github.com/georgebyte/rxjs-observable-store/compare/v3.0.1...v3.0.2 89 | [3.0.1]: https://github.com/georgebyte/rxjs-observable-store/compare/v3.0.0...v3.0.1 90 | [3.0.0]: https://github.com/georgebyte/rxjs-observable-store/compare/v2.0.4...v3.0.0 91 | [2.0.4]: https://github.com/georgebyte/rxjs-observable-store/compare/v2.0.3...v2.0.4 92 | [2.0.3]: https://github.com/georgebyte/rxjs-observable-store/compare/v2.0.2...v2.0.3 93 | [2.0.2]: https://github.com/georgebyte/rxjs-observable-store/compare/v2.0.1...v2.0.2 94 | [2.0.1]: https://github.com/georgebyte/rxjs-observable-store/compare/v2.0.0...v2.0.1 95 | -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | MIT License 2 | 3 | Copyright (c) 2020 George Byte (Jure Bajt) 4 | 5 | Permission is hereby granted, free of charge, to any person obtaining a copy 6 | of this software and associated documentation files (the "Software"), to deal 7 | in the Software without restriction, including without limitation the rights 8 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 9 | copies of the Software, and to permit persons to whom the Software is 10 | furnished to do so, subject to the following conditions: 11 | 12 | The above copyright notice and this permission notice shall be included in all 13 | copies or substantial portions of the Software. 14 | 15 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 16 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 17 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 18 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 19 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 20 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE 21 | SOFTWARE. 22 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # rxjs-observable-store 2 | 3 | [![npm](https://img.shields.io/npm/v/rxjs-observable-store.svg?style=flat-square)](https://www.npmjs.com/package/rxjs-observable-store) 4 | [![npm](https://img.shields.io/npm/dm/rxjs-observable-store.svg?style=flat-square)](https://www.npmjs.com/package/rxjs-observable-store) 5 | [![MIT licensed](https://img.shields.io/badge/license-MIT-blue.svg?style=flat-square)](https://github.com/georgebyte/rxjs-observable-store/blob/master/LICENSE) 6 | 7 | A state management solution implemented using RxJS to mimic Redux architecture. 8 | 9 | Read my blog post [State management in Angular with observable store services](https://georgebyte.com/state-management-in-angular-with-observable-store-services/) to learn more about how to use the `rxjs-observable-store` package to manage state in front-end applications. 10 | 11 | ## Getting started 12 | 13 | **Prerequisites:** 14 | Lowest TypeScript support starts at version 3.5. 15 | 16 | **Installation:** 17 | 18 | ```bash 19 | npm install rxjs-observable-store --save 20 | ``` 21 | 22 | **Usage example:** 23 | 24 | ```typescript 25 | import {Store} from 'rxjs-observable-store'; 26 | 27 | class ExampleState { 28 | exampleText = 'initial text'; 29 | exampleObject = { 30 | property1: { 31 | nestedValue: { 32 | value: 1000, 33 | }, 34 | }, 35 | }; 36 | } 37 | 38 | class ExampleStore extends Store { 39 | constructor() { 40 | super(new ExampleState()); 41 | } 42 | 43 | updateExampleText() { 44 | this.setState({ 45 | ...this.state, 46 | exampleText: 'updated text', 47 | }); 48 | } 49 | 50 | updateNestedValue() { 51 | this.patchState( 52 | 2000, 53 | 'exampleObject', 54 | 'property1', 55 | 'nestedValue', 56 | 'value' 57 | ); 58 | } 59 | } 60 | 61 | class TestComponent { 62 | store: ExampleStore; 63 | 64 | constructor() { 65 | this.store = new ExampleStore(); 66 | 67 | this.store.state$.subscribe(state => { 68 | // Logs the updated state on every state change 69 | console.log(state); 70 | }); 71 | 72 | this.store.onChanges('exampleObject', 'property1', 'nestedValue', 'value').subscribe(value => { 73 | // Logs the updated value only when state.exampleObject.property1.nestedValue.value changes 74 | console.log(value); 75 | }); 76 | 77 | setTimeout(() => { 78 | this.store.updateExampleText(); 79 | }, 1000); 80 | 81 | setTimeout(() => { 82 | this.store.updateNestedValue(); 83 | }, 2000); 84 | } 85 | } 86 | ``` 87 | 88 | ## API 89 | 90 | **Store's public properties:** 91 | 92 | **`state: `** 93 | Current state snapshot. 94 | 95 | **`state$: Observable`** 96 | RxJS Observable of state. 97 | 98 | **Store's public methods:** 99 | 100 | **`onChanges(...path: (string|number|symbol)[]): Observable`** 101 | Get an RxJS Observable of state at `path` used to subscribe to partial state changes. 102 | 103 | **`setState(nextState: S): void`** 104 | Set store's state to `nextState`. 105 | 106 | **`patchState(value: any, ...path: (string|number|symbol)[]): void`** 107 | Set store's state at `path` to `value`. 108 | 109 | Notes: 110 | 111 | * When using TypeScript, errors are thrown for nonexisting `path` and wrong `value` type: 112 | ![patchState typed value](images/patchState-typed-value.gif "patchState typed value") 113 | * Path autocompletion works as well (9 levels deep): 114 | ![patchState path autocompletion](images/patchState-path-autocompletion.gif "patchState path autocompletion") 115 | -------------------------------------------------------------------------------- /images/patchState-path-autocompletion.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/georgebyte/rxjs-observable-store/b4c63bc827e6e35d65bae812e478893e9bb974ea/images/patchState-path-autocompletion.gif -------------------------------------------------------------------------------- /images/patchState-typed-value.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/georgebyte/rxjs-observable-store/b4c63bc827e6e35d65bae812e478893e9bb974ea/images/patchState-typed-value.gif -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "rxjs-observable-store", 3 | "version": "3.1.0", 4 | "lockfileVersion": 1, 5 | "requires": true, 6 | "dependencies": { 7 | "@ampproject/remapping": { 8 | "version": "2.1.0", 9 | "resolved": "https://registry.npmjs.org/@ampproject/remapping/-/remapping-2.1.0.tgz", 10 | "integrity": "sha512-d5RysTlJ7hmw5Tw4UxgxcY3lkMe92n8sXCcuLPAyIAHK6j8DefDwtGnVVDgOnv+RnEosulDJ9NPKQL27bDId0g==", 11 | "dev": true, 12 | "requires": { 13 | "@jridgewell/trace-mapping": "^0.3.0" 14 | } 15 | }, 16 | "@babel/code-frame": { 17 | "version": "7.16.7", 18 | "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.16.7.tgz", 19 | "integrity": "sha512-iAXqUn8IIeBTNd72xsFlgaXHkMBMt6y4HJp1tIaK465CWLT/fG1aqB7ykr95gHHmlBdGbFeWWfyB4NJJ0nmeIg==", 20 | "dev": true, 21 | "requires": { 22 | "@babel/highlight": "^7.16.7" 23 | } 24 | }, 25 | "@babel/compat-data": { 26 | "version": "7.17.0", 27 | "resolved": "https://registry.npmjs.org/@babel/compat-data/-/compat-data-7.17.0.tgz", 28 | "integrity": "sha512-392byTlpGWXMv4FbyWw3sAZ/FrW/DrwqLGXpy0mbyNe9Taqv1mg9yON5/o0cnr8XYCkFTZbC1eV+c+LAROgrng==", 29 | "dev": true 30 | }, 31 | "@babel/core": { 32 | "version": "7.17.0", 33 | "resolved": "https://registry.npmjs.org/@babel/core/-/core-7.17.0.tgz", 34 | "integrity": "sha512-x/5Ea+RO5MvF9ize5DeVICJoVrNv0Mi2RnIABrZEKYvPEpldXwauPkgvYA17cKa6WpU3LoYvYbuEMFtSNFsarA==", 35 | "dev": true, 36 | "requires": { 37 | "@ampproject/remapping": "^2.0.0", 38 | "@babel/code-frame": "^7.16.7", 39 | "@babel/generator": "^7.17.0", 40 | "@babel/helper-compilation-targets": "^7.16.7", 41 | "@babel/helper-module-transforms": "^7.16.7", 42 | "@babel/helpers": "^7.17.0", 43 | "@babel/parser": "^7.17.0", 44 | "@babel/template": "^7.16.7", 45 | "@babel/traverse": "^7.17.0", 46 | "@babel/types": "^7.17.0", 47 | "convert-source-map": "^1.7.0", 48 | "debug": "^4.1.0", 49 | "gensync": "^1.0.0-beta.2", 50 | "json5": "^2.1.2", 51 | "semver": "^6.3.0" 52 | } 53 | }, 54 | "@babel/generator": { 55 | "version": "7.17.0", 56 | "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.17.0.tgz", 57 | "integrity": "sha512-I3Omiv6FGOC29dtlZhkfXO6pgkmukJSlT26QjVvS1DGZe/NzSVCPG41X0tS21oZkJYlovfj9qDWgKP+Cn4bXxw==", 58 | "dev": true, 59 | "requires": { 60 | "@babel/types": "^7.17.0", 61 | "jsesc": "^2.5.1", 62 | "source-map": "^0.5.0" 63 | }, 64 | "dependencies": { 65 | "source-map": { 66 | "version": "0.5.7", 67 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.5.7.tgz", 68 | "integrity": "sha1-igOdLRAh0i0eoUyA2OpGi6LvP8w=", 69 | "dev": true 70 | } 71 | } 72 | }, 73 | "@babel/helper-compilation-targets": { 74 | "version": "7.16.7", 75 | "resolved": "https://registry.npmjs.org/@babel/helper-compilation-targets/-/helper-compilation-targets-7.16.7.tgz", 76 | "integrity": "sha512-mGojBwIWcwGD6rfqgRXVlVYmPAv7eOpIemUG3dGnDdCY4Pae70ROij3XmfrH6Fa1h1aiDylpglbZyktfzyo/hA==", 77 | "dev": true, 78 | "requires": { 79 | "@babel/compat-data": "^7.16.4", 80 | "@babel/helper-validator-option": "^7.16.7", 81 | "browserslist": "^4.17.5", 82 | "semver": "^6.3.0" 83 | } 84 | }, 85 | "@babel/helper-environment-visitor": { 86 | "version": "7.16.7", 87 | "resolved": "https://registry.npmjs.org/@babel/helper-environment-visitor/-/helper-environment-visitor-7.16.7.tgz", 88 | "integrity": "sha512-SLLb0AAn6PkUeAfKJCCOl9e1R53pQlGAfc4y4XuMRZfqeMYLE0dM1LMhqbGAlGQY0lfw5/ohoYWAe9V1yibRag==", 89 | "dev": true, 90 | "requires": { 91 | "@babel/types": "^7.16.7" 92 | } 93 | }, 94 | "@babel/helper-function-name": { 95 | "version": "7.16.7", 96 | "resolved": "https://registry.npmjs.org/@babel/helper-function-name/-/helper-function-name-7.16.7.tgz", 97 | "integrity": "sha512-QfDfEnIUyyBSR3HtrtGECuZ6DAyCkYFp7GHl75vFtTnn6pjKeK0T1DB5lLkFvBea8MdaiUABx3osbgLyInoejA==", 98 | "dev": true, 99 | "requires": { 100 | "@babel/helper-get-function-arity": "^7.16.7", 101 | "@babel/template": "^7.16.7", 102 | "@babel/types": "^7.16.7" 103 | } 104 | }, 105 | "@babel/helper-get-function-arity": { 106 | "version": "7.16.7", 107 | "resolved": "https://registry.npmjs.org/@babel/helper-get-function-arity/-/helper-get-function-arity-7.16.7.tgz", 108 | "integrity": "sha512-flc+RLSOBXzNzVhcLu6ujeHUrD6tANAOU5ojrRx/as+tbzf8+stUCj7+IfRRoAbEZqj/ahXEMsjhOhgeZsrnTw==", 109 | "dev": true, 110 | "requires": { 111 | "@babel/types": "^7.16.7" 112 | } 113 | }, 114 | "@babel/helper-hoist-variables": { 115 | "version": "7.16.7", 116 | "resolved": "https://registry.npmjs.org/@babel/helper-hoist-variables/-/helper-hoist-variables-7.16.7.tgz", 117 | "integrity": "sha512-m04d/0Op34H5v7pbZw6pSKP7weA6lsMvfiIAMeIvkY/R4xQtBSMFEigu9QTZ2qB/9l22vsxtM8a+Q8CzD255fg==", 118 | "dev": true, 119 | "requires": { 120 | "@babel/types": "^7.16.7" 121 | } 122 | }, 123 | "@babel/helper-module-imports": { 124 | "version": "7.16.7", 125 | "resolved": "https://registry.npmjs.org/@babel/helper-module-imports/-/helper-module-imports-7.16.7.tgz", 126 | "integrity": "sha512-LVtS6TqjJHFc+nYeITRo6VLXve70xmq7wPhWTqDJusJEgGmkAACWwMiTNrvfoQo6hEhFwAIixNkvB0jPXDL8Wg==", 127 | "dev": true, 128 | "requires": { 129 | "@babel/types": "^7.16.7" 130 | } 131 | }, 132 | "@babel/helper-module-transforms": { 133 | "version": "7.16.7", 134 | "resolved": "https://registry.npmjs.org/@babel/helper-module-transforms/-/helper-module-transforms-7.16.7.tgz", 135 | "integrity": "sha512-gaqtLDxJEFCeQbYp9aLAefjhkKdjKcdh6DB7jniIGU3Pz52WAmP268zK0VgPz9hUNkMSYeH976K2/Y6yPadpng==", 136 | "dev": true, 137 | "requires": { 138 | "@babel/helper-environment-visitor": "^7.16.7", 139 | "@babel/helper-module-imports": "^7.16.7", 140 | "@babel/helper-simple-access": "^7.16.7", 141 | "@babel/helper-split-export-declaration": "^7.16.7", 142 | "@babel/helper-validator-identifier": "^7.16.7", 143 | "@babel/template": "^7.16.7", 144 | "@babel/traverse": "^7.16.7", 145 | "@babel/types": "^7.16.7" 146 | } 147 | }, 148 | "@babel/helper-plugin-utils": { 149 | "version": "7.16.7", 150 | "resolved": "https://registry.npmjs.org/@babel/helper-plugin-utils/-/helper-plugin-utils-7.16.7.tgz", 151 | "integrity": "sha512-Qg3Nk7ZxpgMrsox6HreY1ZNKdBq7K72tDSliA6dCl5f007jR4ne8iD5UzuNnCJH2xBf2BEEVGr+/OL6Gdp7RxA==", 152 | "dev": true 153 | }, 154 | "@babel/helper-simple-access": { 155 | "version": "7.16.7", 156 | "resolved": "https://registry.npmjs.org/@babel/helper-simple-access/-/helper-simple-access-7.16.7.tgz", 157 | "integrity": "sha512-ZIzHVyoeLMvXMN/vok/a4LWRy8G2v205mNP0XOuf9XRLyX5/u9CnVulUtDgUTama3lT+bf/UqucuZjqiGuTS1g==", 158 | "dev": true, 159 | "requires": { 160 | "@babel/types": "^7.16.7" 161 | } 162 | }, 163 | "@babel/helper-split-export-declaration": { 164 | "version": "7.16.7", 165 | "resolved": "https://registry.npmjs.org/@babel/helper-split-export-declaration/-/helper-split-export-declaration-7.16.7.tgz", 166 | "integrity": "sha512-xbWoy/PFoxSWazIToT9Sif+jJTlrMcndIsaOKvTA6u7QEo7ilkRZpjew18/W3c7nm8fXdUDXh02VXTbZ0pGDNw==", 167 | "dev": true, 168 | "requires": { 169 | "@babel/types": "^7.16.7" 170 | } 171 | }, 172 | "@babel/helper-validator-identifier": { 173 | "version": "7.16.7", 174 | "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.16.7.tgz", 175 | "integrity": "sha512-hsEnFemeiW4D08A5gUAZxLBTXpZ39P+a+DGDsHw1yxqyQ/jzFEnxf5uTEGp+3bzAbNOxU1paTgYS4ECU/IgfDw==", 176 | "dev": true 177 | }, 178 | "@babel/helper-validator-option": { 179 | "version": "7.16.7", 180 | "resolved": "https://registry.npmjs.org/@babel/helper-validator-option/-/helper-validator-option-7.16.7.tgz", 181 | "integrity": "sha512-TRtenOuRUVo9oIQGPC5G9DgK4743cdxvtOw0weQNpZXaS16SCBi5MNjZF8vba3ETURjZpTbVn7Vvcf2eAwFozQ==", 182 | "dev": true 183 | }, 184 | "@babel/helpers": { 185 | "version": "7.17.0", 186 | "resolved": "https://registry.npmjs.org/@babel/helpers/-/helpers-7.17.0.tgz", 187 | "integrity": "sha512-Xe/9NFxjPwELUvW2dsukcMZIp6XwPSbI4ojFBJuX5ramHuVE22SVcZIwqzdWo5uCgeTXW8qV97lMvSOjq+1+nQ==", 188 | "dev": true, 189 | "requires": { 190 | "@babel/template": "^7.16.7", 191 | "@babel/traverse": "^7.17.0", 192 | "@babel/types": "^7.17.0" 193 | } 194 | }, 195 | "@babel/highlight": { 196 | "version": "7.16.10", 197 | "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.16.10.tgz", 198 | "integrity": "sha512-5FnTQLSLswEj6IkgVw5KusNUUFY9ZGqe/TRFnP/BKYHYgfh7tc+C7mwiy95/yNP7Dh9x580Vv8r7u7ZfTBFxdw==", 199 | "dev": true, 200 | "requires": { 201 | "@babel/helper-validator-identifier": "^7.16.7", 202 | "chalk": "^2.0.0", 203 | "js-tokens": "^4.0.0" 204 | }, 205 | "dependencies": { 206 | "ansi-styles": { 207 | "version": "3.2.1", 208 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 209 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 210 | "dev": true, 211 | "requires": { 212 | "color-convert": "^1.9.0" 213 | } 214 | }, 215 | "chalk": { 216 | "version": "2.4.2", 217 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", 218 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", 219 | "dev": true, 220 | "requires": { 221 | "ansi-styles": "^3.2.1", 222 | "escape-string-regexp": "^1.0.5", 223 | "supports-color": "^5.3.0" 224 | } 225 | }, 226 | "color-convert": { 227 | "version": "1.9.3", 228 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", 229 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", 230 | "dev": true, 231 | "requires": { 232 | "color-name": "1.1.3" 233 | } 234 | }, 235 | "color-name": { 236 | "version": "1.1.3", 237 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 238 | "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=", 239 | "dev": true 240 | }, 241 | "has-flag": { 242 | "version": "3.0.0", 243 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 244 | "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=", 245 | "dev": true 246 | }, 247 | "supports-color": { 248 | "version": "5.5.0", 249 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 250 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 251 | "dev": true, 252 | "requires": { 253 | "has-flag": "^3.0.0" 254 | } 255 | } 256 | } 257 | }, 258 | "@babel/parser": { 259 | "version": "7.17.0", 260 | "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.17.0.tgz", 261 | "integrity": "sha512-VKXSCQx5D8S04ej+Dqsr1CzYvvWgf20jIw2D+YhQCrIlr2UZGaDds23Y0xg75/skOxpLCRpUZvk/1EAVkGoDOw==", 262 | "dev": true 263 | }, 264 | "@babel/plugin-syntax-async-generators": { 265 | "version": "7.8.4", 266 | "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-async-generators/-/plugin-syntax-async-generators-7.8.4.tgz", 267 | "integrity": "sha512-tycmZxkGfZaxhMRbXlPXuVFpdWlXpir2W4AMhSJgRKzk/eDlIXOhb2LHWoLpDF7TEHylV5zNhykX6KAgHJmTNw==", 268 | "dev": true, 269 | "requires": { 270 | "@babel/helper-plugin-utils": "^7.8.0" 271 | } 272 | }, 273 | "@babel/plugin-syntax-bigint": { 274 | "version": "7.8.3", 275 | "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-bigint/-/plugin-syntax-bigint-7.8.3.tgz", 276 | "integrity": "sha512-wnTnFlG+YxQm3vDxpGE57Pj0srRU4sHE/mDkt1qv2YJJSeUAec2ma4WLUnUPeKjyrfntVwe/N6dCXpU+zL3Npg==", 277 | "dev": true, 278 | "requires": { 279 | "@babel/helper-plugin-utils": "^7.8.0" 280 | } 281 | }, 282 | "@babel/plugin-syntax-class-properties": { 283 | "version": "7.12.13", 284 | "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-class-properties/-/plugin-syntax-class-properties-7.12.13.tgz", 285 | "integrity": "sha512-fm4idjKla0YahUNgFNLCB0qySdsoPiZP3iQE3rky0mBUtMZ23yDJ9SJdg6dXTSDnulOVqiF3Hgr9nbXvXTQZYA==", 286 | "dev": true, 287 | "requires": { 288 | "@babel/helper-plugin-utils": "^7.12.13" 289 | } 290 | }, 291 | "@babel/plugin-syntax-import-meta": { 292 | "version": "7.10.4", 293 | "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-import-meta/-/plugin-syntax-import-meta-7.10.4.tgz", 294 | "integrity": "sha512-Yqfm+XDx0+Prh3VSeEQCPU81yC+JWZ2pDPFSS4ZdpfZhp4MkFMaDC1UqseovEKwSUpnIL7+vK+Clp7bfh0iD7g==", 295 | "dev": true, 296 | "requires": { 297 | "@babel/helper-plugin-utils": "^7.10.4" 298 | } 299 | }, 300 | "@babel/plugin-syntax-json-strings": { 301 | "version": "7.8.3", 302 | "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-json-strings/-/plugin-syntax-json-strings-7.8.3.tgz", 303 | "integrity": "sha512-lY6kdGpWHvjoe2vk4WrAapEuBR69EMxZl+RoGRhrFGNYVK8mOPAW8VfbT/ZgrFbXlDNiiaxQnAtgVCZ6jv30EA==", 304 | "dev": true, 305 | "requires": { 306 | "@babel/helper-plugin-utils": "^7.8.0" 307 | } 308 | }, 309 | "@babel/plugin-syntax-logical-assignment-operators": { 310 | "version": "7.10.4", 311 | "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-logical-assignment-operators/-/plugin-syntax-logical-assignment-operators-7.10.4.tgz", 312 | "integrity": "sha512-d8waShlpFDinQ5MtvGU9xDAOzKH47+FFoney2baFIoMr952hKOLp1HR7VszoZvOsV/4+RRszNY7D17ba0te0ig==", 313 | "dev": true, 314 | "requires": { 315 | "@babel/helper-plugin-utils": "^7.10.4" 316 | } 317 | }, 318 | "@babel/plugin-syntax-nullish-coalescing-operator": { 319 | "version": "7.8.3", 320 | "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-nullish-coalescing-operator/-/plugin-syntax-nullish-coalescing-operator-7.8.3.tgz", 321 | "integrity": "sha512-aSff4zPII1u2QD7y+F8oDsz19ew4IGEJg9SVW+bqwpwtfFleiQDMdzA/R+UlWDzfnHFCxxleFT0PMIrR36XLNQ==", 322 | "dev": true, 323 | "requires": { 324 | "@babel/helper-plugin-utils": "^7.8.0" 325 | } 326 | }, 327 | "@babel/plugin-syntax-numeric-separator": { 328 | "version": "7.10.4", 329 | "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-numeric-separator/-/plugin-syntax-numeric-separator-7.10.4.tgz", 330 | "integrity": "sha512-9H6YdfkcK/uOnY/K7/aA2xpzaAgkQn37yzWUMRK7OaPOqOpGS1+n0H5hxT9AUw9EsSjPW8SVyMJwYRtWs3X3ug==", 331 | "dev": true, 332 | "requires": { 333 | "@babel/helper-plugin-utils": "^7.10.4" 334 | } 335 | }, 336 | "@babel/plugin-syntax-object-rest-spread": { 337 | "version": "7.8.3", 338 | "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-object-rest-spread/-/plugin-syntax-object-rest-spread-7.8.3.tgz", 339 | "integrity": "sha512-XoqMijGZb9y3y2XskN+P1wUGiVwWZ5JmoDRwx5+3GmEplNyVM2s2Dg8ILFQm8rWM48orGy5YpI5Bl8U1y7ydlA==", 340 | "dev": true, 341 | "requires": { 342 | "@babel/helper-plugin-utils": "^7.8.0" 343 | } 344 | }, 345 | "@babel/plugin-syntax-optional-catch-binding": { 346 | "version": "7.8.3", 347 | "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-optional-catch-binding/-/plugin-syntax-optional-catch-binding-7.8.3.tgz", 348 | "integrity": "sha512-6VPD0Pc1lpTqw0aKoeRTMiB+kWhAoT24PA+ksWSBrFtl5SIRVpZlwN3NNPQjehA2E/91FV3RjLWoVTglWcSV3Q==", 349 | "dev": true, 350 | "requires": { 351 | "@babel/helper-plugin-utils": "^7.8.0" 352 | } 353 | }, 354 | "@babel/plugin-syntax-optional-chaining": { 355 | "version": "7.8.3", 356 | "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-optional-chaining/-/plugin-syntax-optional-chaining-7.8.3.tgz", 357 | "integrity": "sha512-KoK9ErH1MBlCPxV0VANkXW2/dw4vlbGDrFgz8bmUsBGYkFRcbRwMh6cIJubdPrkxRwuGdtCk0v/wPTKbQgBjkg==", 358 | "dev": true, 359 | "requires": { 360 | "@babel/helper-plugin-utils": "^7.8.0" 361 | } 362 | }, 363 | "@babel/plugin-syntax-top-level-await": { 364 | "version": "7.14.5", 365 | "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-top-level-await/-/plugin-syntax-top-level-await-7.14.5.tgz", 366 | "integrity": "sha512-hx++upLv5U1rgYfwe1xBQUhRmU41NEvpUvrp8jkrSCdvGSnM5/qdRMtylJ6PG5OFkBaHkbTAKTnd3/YyESRHFw==", 367 | "dev": true, 368 | "requires": { 369 | "@babel/helper-plugin-utils": "^7.14.5" 370 | } 371 | }, 372 | "@babel/plugin-syntax-typescript": { 373 | "version": "7.16.7", 374 | "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-typescript/-/plugin-syntax-typescript-7.16.7.tgz", 375 | "integrity": "sha512-YhUIJHHGkqPgEcMYkPCKTyGUdoGKWtopIycQyjJH8OjvRgOYsXsaKehLVPScKJWAULPxMa4N1vCe6szREFlZ7A==", 376 | "dev": true, 377 | "requires": { 378 | "@babel/helper-plugin-utils": "^7.16.7" 379 | } 380 | }, 381 | "@babel/template": { 382 | "version": "7.16.7", 383 | "resolved": "https://registry.npmjs.org/@babel/template/-/template-7.16.7.tgz", 384 | "integrity": "sha512-I8j/x8kHUrbYRTUxXrrMbfCa7jxkE7tZre39x3kjr9hvI82cK1FfqLygotcWN5kdPGWcLdWMHpSBavse5tWw3w==", 385 | "dev": true, 386 | "requires": { 387 | "@babel/code-frame": "^7.16.7", 388 | "@babel/parser": "^7.16.7", 389 | "@babel/types": "^7.16.7" 390 | } 391 | }, 392 | "@babel/traverse": { 393 | "version": "7.17.0", 394 | "resolved": "https://registry.npmjs.org/@babel/traverse/-/traverse-7.17.0.tgz", 395 | "integrity": "sha512-fpFIXvqD6kC7c7PUNnZ0Z8cQXlarCLtCUpt2S1Dx7PjoRtCFffvOkHHSom+m5HIxMZn5bIBVb71lhabcmjEsqg==", 396 | "dev": true, 397 | "requires": { 398 | "@babel/code-frame": "^7.16.7", 399 | "@babel/generator": "^7.17.0", 400 | "@babel/helper-environment-visitor": "^7.16.7", 401 | "@babel/helper-function-name": "^7.16.7", 402 | "@babel/helper-hoist-variables": "^7.16.7", 403 | "@babel/helper-split-export-declaration": "^7.16.7", 404 | "@babel/parser": "^7.17.0", 405 | "@babel/types": "^7.17.0", 406 | "debug": "^4.1.0", 407 | "globals": "^11.1.0" 408 | } 409 | }, 410 | "@babel/types": { 411 | "version": "7.17.0", 412 | "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.17.0.tgz", 413 | "integrity": "sha512-TmKSNO4D5rzhL5bjWFcVHHLETzfQ/AmbKpKPOSjlP0WoHZ6L911fgoOKY4Alp/emzG4cHJdyN49zpgkbXFEHHw==", 414 | "dev": true, 415 | "requires": { 416 | "@babel/helper-validator-identifier": "^7.16.7", 417 | "to-fast-properties": "^2.0.0" 418 | } 419 | }, 420 | "@bcoe/v8-coverage": { 421 | "version": "0.2.3", 422 | "resolved": "https://registry.npmjs.org/@bcoe/v8-coverage/-/v8-coverage-0.2.3.tgz", 423 | "integrity": "sha512-0hYQ8SB4Db5zvZB4axdMHGwEaQjkZzFjQiN9LVYvIFB2nSUHW9tYpxWriPrWDASIxiaXax83REcLxuSdnGPZtw==", 424 | "dev": true 425 | }, 426 | "@istanbuljs/load-nyc-config": { 427 | "version": "1.1.0", 428 | "resolved": "https://registry.npmjs.org/@istanbuljs/load-nyc-config/-/load-nyc-config-1.1.0.tgz", 429 | "integrity": "sha512-VjeHSlIzpv/NyD3N0YuHfXOPDIixcA1q2ZV98wsMqcYlPmv2n3Yb2lYP9XMElnaFVXg5A7YLTeLu6V84uQDjmQ==", 430 | "dev": true, 431 | "requires": { 432 | "camelcase": "^5.3.1", 433 | "find-up": "^4.1.0", 434 | "get-package-type": "^0.1.0", 435 | "js-yaml": "^3.13.1", 436 | "resolve-from": "^5.0.0" 437 | } 438 | }, 439 | "@istanbuljs/schema": { 440 | "version": "0.1.3", 441 | "resolved": "https://registry.npmjs.org/@istanbuljs/schema/-/schema-0.1.3.tgz", 442 | "integrity": "sha512-ZXRY4jNvVgSVQ8DL3LTcakaAtXwTVUxE81hslsyD2AtoXW/wVob10HkOJ1X/pAlcI7D+2YoZKg5do8G/w6RYgA==", 443 | "dev": true 444 | }, 445 | "@jest/console": { 446 | "version": "27.5.0", 447 | "resolved": "https://registry.npmjs.org/@jest/console/-/console-27.5.0.tgz", 448 | "integrity": "sha512-WUzX5neFb0IOQOy/7A2VhiGdxJKk85Xns2Oq29JaHmtnSel+BsjwyQZxzAs2Xxfd2i452fwdDG9ox/IWi81bdQ==", 449 | "dev": true, 450 | "requires": { 451 | "@jest/types": "^27.5.0", 452 | "@types/node": "*", 453 | "chalk": "^4.0.0", 454 | "jest-message-util": "^27.5.0", 455 | "jest-util": "^27.5.0", 456 | "slash": "^3.0.0" 457 | } 458 | }, 459 | "@jest/core": { 460 | "version": "27.5.0", 461 | "resolved": "https://registry.npmjs.org/@jest/core/-/core-27.5.0.tgz", 462 | "integrity": "sha512-DcUTkZyon+dRozTEjy38Bgt3PIU51GdUJuz3uHKg5maGtmCaYqPUGiM3Xddqi7eIMC7E3fTGIlHqH9i0pTOy6Q==", 463 | "dev": true, 464 | "requires": { 465 | "@jest/console": "^27.5.0", 466 | "@jest/reporters": "^27.5.0", 467 | "@jest/test-result": "^27.5.0", 468 | "@jest/transform": "^27.5.0", 469 | "@jest/types": "^27.5.0", 470 | "@types/node": "*", 471 | "ansi-escapes": "^4.2.1", 472 | "chalk": "^4.0.0", 473 | "emittery": "^0.8.1", 474 | "exit": "^0.1.2", 475 | "graceful-fs": "^4.2.9", 476 | "jest-changed-files": "^27.5.0", 477 | "jest-config": "^27.5.0", 478 | "jest-haste-map": "^27.5.0", 479 | "jest-message-util": "^27.5.0", 480 | "jest-regex-util": "^27.5.0", 481 | "jest-resolve": "^27.5.0", 482 | "jest-resolve-dependencies": "^27.5.0", 483 | "jest-runner": "^27.5.0", 484 | "jest-runtime": "^27.5.0", 485 | "jest-snapshot": "^27.5.0", 486 | "jest-util": "^27.5.0", 487 | "jest-validate": "^27.5.0", 488 | "jest-watcher": "^27.5.0", 489 | "micromatch": "^4.0.4", 490 | "rimraf": "^3.0.0", 491 | "slash": "^3.0.0", 492 | "strip-ansi": "^6.0.0" 493 | } 494 | }, 495 | "@jest/environment": { 496 | "version": "27.5.0", 497 | "resolved": "https://registry.npmjs.org/@jest/environment/-/environment-27.5.0.tgz", 498 | "integrity": "sha512-lg0JFsMaLKgpwzs0knOg21Z4OQwaJoBLutnmYzip4tyLTXP21VYWtYGpLXgx42fw/Mw05m1WDXWKgwR6WnsiTw==", 499 | "dev": true, 500 | "requires": { 501 | "@jest/fake-timers": "^27.5.0", 502 | "@jest/types": "^27.5.0", 503 | "@types/node": "*", 504 | "jest-mock": "^27.5.0" 505 | } 506 | }, 507 | "@jest/fake-timers": { 508 | "version": "27.5.0", 509 | "resolved": "https://registry.npmjs.org/@jest/fake-timers/-/fake-timers-27.5.0.tgz", 510 | "integrity": "sha512-e3WrlpqSHq3HAQ03JFjTn8YCrsyg640/sr1rjkM2rNv8z1ufjudpv4xq6DvvTJYB6FuUrfg0g+7bSKPet5QfCQ==", 511 | "dev": true, 512 | "requires": { 513 | "@jest/types": "^27.5.0", 514 | "@sinonjs/fake-timers": "^8.0.1", 515 | "@types/node": "*", 516 | "jest-message-util": "^27.5.0", 517 | "jest-mock": "^27.5.0", 518 | "jest-util": "^27.5.0" 519 | } 520 | }, 521 | "@jest/globals": { 522 | "version": "27.5.0", 523 | "resolved": "https://registry.npmjs.org/@jest/globals/-/globals-27.5.0.tgz", 524 | "integrity": "sha512-wWpMnTiR65Q4JD7fr2BqN+ZDbi99mmILnEM6u7AaX4geASEIVvQsiB4RCvwZrIX5YZCsAjviJQVq9CYddLABkg==", 525 | "dev": true, 526 | "requires": { 527 | "@jest/environment": "^27.5.0", 528 | "@jest/types": "^27.5.0", 529 | "expect": "^27.5.0" 530 | } 531 | }, 532 | "@jest/reporters": { 533 | "version": "27.5.0", 534 | "resolved": "https://registry.npmjs.org/@jest/reporters/-/reporters-27.5.0.tgz", 535 | "integrity": "sha512-DG+BmVSx2uaJSTKz5z1eScgHTQ6/cZ5CCKSpmpr4sXQPwV2V5aUMOBDwXX1MnqNRhH7/Rq9K97ynnocvho5aMA==", 536 | "dev": true, 537 | "requires": { 538 | "@bcoe/v8-coverage": "^0.2.3", 539 | "@jest/console": "^27.5.0", 540 | "@jest/test-result": "^27.5.0", 541 | "@jest/transform": "^27.5.0", 542 | "@jest/types": "^27.5.0", 543 | "@types/node": "*", 544 | "chalk": "^4.0.0", 545 | "collect-v8-coverage": "^1.0.0", 546 | "exit": "^0.1.2", 547 | "glob": "^7.1.2", 548 | "graceful-fs": "^4.2.9", 549 | "istanbul-lib-coverage": "^3.0.0", 550 | "istanbul-lib-instrument": "^5.1.0", 551 | "istanbul-lib-report": "^3.0.0", 552 | "istanbul-lib-source-maps": "^4.0.0", 553 | "istanbul-reports": "^3.1.3", 554 | "jest-haste-map": "^27.5.0", 555 | "jest-resolve": "^27.5.0", 556 | "jest-util": "^27.5.0", 557 | "jest-worker": "^27.5.0", 558 | "slash": "^3.0.0", 559 | "source-map": "^0.6.0", 560 | "string-length": "^4.0.1", 561 | "terminal-link": "^2.0.0", 562 | "v8-to-istanbul": "^8.1.0" 563 | } 564 | }, 565 | "@jest/source-map": { 566 | "version": "27.5.0", 567 | "resolved": "https://registry.npmjs.org/@jest/source-map/-/source-map-27.5.0.tgz", 568 | "integrity": "sha512-0xr7VZ+JNCRrlCyRMYhquUm8eU3kNdGDaIW4s3L625bNjk273v9ZhAm3YczIuzJzYH0pnjT+QSCiZQegWKjeow==", 569 | "dev": true, 570 | "requires": { 571 | "callsites": "^3.0.0", 572 | "graceful-fs": "^4.2.9", 573 | "source-map": "^0.6.0" 574 | } 575 | }, 576 | "@jest/test-result": { 577 | "version": "27.5.0", 578 | "resolved": "https://registry.npmjs.org/@jest/test-result/-/test-result-27.5.0.tgz", 579 | "integrity": "sha512-Lxecvx5mN6WIeynIyW0dWDQm8UPGMHvTwxUPK+OsZaqBDMGaNDSZtw53VoVk7HyT6AcRblMR/pfa0XucmH4hGw==", 580 | "dev": true, 581 | "requires": { 582 | "@jest/console": "^27.5.0", 583 | "@jest/types": "^27.5.0", 584 | "@types/istanbul-lib-coverage": "^2.0.0", 585 | "collect-v8-coverage": "^1.0.0" 586 | } 587 | }, 588 | "@jest/test-sequencer": { 589 | "version": "27.5.0", 590 | "resolved": "https://registry.npmjs.org/@jest/test-sequencer/-/test-sequencer-27.5.0.tgz", 591 | "integrity": "sha512-WzjcDflqbpWe+SnJPCvB2gB6haGfrkzAgzY6Pb1aq+EPoVAj2mwBaKN0ROWI4H87aSslCjq2M+BUQFNJ8VpnDA==", 592 | "dev": true, 593 | "requires": { 594 | "@jest/test-result": "^27.5.0", 595 | "graceful-fs": "^4.2.9", 596 | "jest-haste-map": "^27.5.0", 597 | "jest-runtime": "^27.5.0" 598 | } 599 | }, 600 | "@jest/transform": { 601 | "version": "27.5.0", 602 | "resolved": "https://registry.npmjs.org/@jest/transform/-/transform-27.5.0.tgz", 603 | "integrity": "sha512-yXUy/iO3TH1itxJ9BF7LLjuXt8TtgtjAl0PBQbUaCvRa+L0yYBob6uayW9dFRX/CDQweouLhvmXh44zRiaB+yA==", 604 | "dev": true, 605 | "requires": { 606 | "@babel/core": "^7.1.0", 607 | "@jest/types": "^27.5.0", 608 | "babel-plugin-istanbul": "^6.1.1", 609 | "chalk": "^4.0.0", 610 | "convert-source-map": "^1.4.0", 611 | "fast-json-stable-stringify": "^2.0.0", 612 | "graceful-fs": "^4.2.9", 613 | "jest-haste-map": "^27.5.0", 614 | "jest-regex-util": "^27.5.0", 615 | "jest-util": "^27.5.0", 616 | "micromatch": "^4.0.4", 617 | "pirates": "^4.0.4", 618 | "slash": "^3.0.0", 619 | "source-map": "^0.6.1", 620 | "write-file-atomic": "^3.0.0" 621 | } 622 | }, 623 | "@jest/types": { 624 | "version": "27.5.0", 625 | "resolved": "https://registry.npmjs.org/@jest/types/-/types-27.5.0.tgz", 626 | "integrity": "sha512-oDHEp7gwSgA82RZ6pzUL3ugM2njP/lVB1MsxRZNOBk+CoNvh9SpH1lQixPFc/kDlV50v59csiW4HLixWmhmgPQ==", 627 | "dev": true, 628 | "requires": { 629 | "@types/istanbul-lib-coverage": "^2.0.0", 630 | "@types/istanbul-reports": "^3.0.0", 631 | "@types/node": "*", 632 | "@types/yargs": "^16.0.0", 633 | "chalk": "^4.0.0" 634 | } 635 | }, 636 | "@jridgewell/resolve-uri": { 637 | "version": "3.0.4", 638 | "resolved": "https://registry.npmjs.org/@jridgewell/resolve-uri/-/resolve-uri-3.0.4.tgz", 639 | "integrity": "sha512-cz8HFjOFfUBtvN+NXYSFMHYRdxZMaEl0XypVrhzxBgadKIXhIkRd8aMeHhmF56Sl7SuS8OnUpQ73/k9LE4VnLg==", 640 | "dev": true 641 | }, 642 | "@jridgewell/sourcemap-codec": { 643 | "version": "1.4.10", 644 | "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.4.10.tgz", 645 | "integrity": "sha512-Ht8wIW5v165atIX1p+JvKR5ONzUyF4Ac8DZIQ5kZs9zrb6M8SJNXpx1zn04rn65VjBMygRoMXcyYwNK0fT7bEg==", 646 | "dev": true 647 | }, 648 | "@jridgewell/trace-mapping": { 649 | "version": "0.3.2", 650 | "resolved": "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.2.tgz", 651 | "integrity": "sha512-9KzzH4kMjA2XmBRHfqG2/Vtl7s92l6uNDd0wW7frDE+EUvQFGqNXhWp0UGJjSkt3v2AYjzOZn1QO9XaTNJIt1Q==", 652 | "dev": true, 653 | "requires": { 654 | "@jridgewell/resolve-uri": "^3.0.3", 655 | "@jridgewell/sourcemap-codec": "^1.4.10" 656 | } 657 | }, 658 | "@sinonjs/commons": { 659 | "version": "1.8.3", 660 | "resolved": "https://registry.npmjs.org/@sinonjs/commons/-/commons-1.8.3.tgz", 661 | "integrity": "sha512-xkNcLAn/wZaX14RPlwizcKicDk9G3F8m2nU3L7Ukm5zBgTwiT0wsoFAHx9Jq56fJA1z/7uKGtCRu16sOUCLIHQ==", 662 | "dev": true, 663 | "requires": { 664 | "type-detect": "4.0.8" 665 | } 666 | }, 667 | "@sinonjs/fake-timers": { 668 | "version": "8.1.0", 669 | "resolved": "https://registry.npmjs.org/@sinonjs/fake-timers/-/fake-timers-8.1.0.tgz", 670 | "integrity": "sha512-OAPJUAtgeINhh/TAlUID4QTs53Njm7xzddaVlEs/SXwgtiD1tW22zAB/W1wdqfrpmikgaWQ9Fw6Ws+hsiRm5Vg==", 671 | "dev": true, 672 | "requires": { 673 | "@sinonjs/commons": "^1.7.0" 674 | } 675 | }, 676 | "@tootallnate/once": { 677 | "version": "1.1.2", 678 | "resolved": "https://registry.npmjs.org/@tootallnate/once/-/once-1.1.2.tgz", 679 | "integrity": "sha512-RbzJvlNzmRq5c3O09UipeuXno4tA1FE6ikOjxZK0tuxVv3412l64l5t1W5pj4+rJq9vpkm/kwiR07aZXnsKPxw==", 680 | "dev": true 681 | }, 682 | "@types/babel__core": { 683 | "version": "7.1.18", 684 | "resolved": "https://registry.npmjs.org/@types/babel__core/-/babel__core-7.1.18.tgz", 685 | "integrity": "sha512-S7unDjm/C7z2A2R9NzfKCK1I+BAALDtxEmsJBwlB3EzNfb929ykjL++1CK9LO++EIp2fQrC8O+BwjKvz6UeDyQ==", 686 | "dev": true, 687 | "requires": { 688 | "@babel/parser": "^7.1.0", 689 | "@babel/types": "^7.0.0", 690 | "@types/babel__generator": "*", 691 | "@types/babel__template": "*", 692 | "@types/babel__traverse": "*" 693 | } 694 | }, 695 | "@types/babel__generator": { 696 | "version": "7.6.4", 697 | "resolved": "https://registry.npmjs.org/@types/babel__generator/-/babel__generator-7.6.4.tgz", 698 | "integrity": "sha512-tFkciB9j2K755yrTALxD44McOrk+gfpIpvC3sxHjRawj6PfnQxrse4Clq5y/Rq+G3mrBurMax/lG8Qn2t9mSsg==", 699 | "dev": true, 700 | "requires": { 701 | "@babel/types": "^7.0.0" 702 | } 703 | }, 704 | "@types/babel__template": { 705 | "version": "7.4.1", 706 | "resolved": "https://registry.npmjs.org/@types/babel__template/-/babel__template-7.4.1.tgz", 707 | "integrity": "sha512-azBFKemX6kMg5Io+/rdGT0dkGreboUVR0Cdm3fz9QJWpaQGJRQXl7C+6hOTCZcMll7KFyEQpgbYI2lHdsS4U7g==", 708 | "dev": true, 709 | "requires": { 710 | "@babel/parser": "^7.1.0", 711 | "@babel/types": "^7.0.0" 712 | } 713 | }, 714 | "@types/babel__traverse": { 715 | "version": "7.14.2", 716 | "resolved": "https://registry.npmjs.org/@types/babel__traverse/-/babel__traverse-7.14.2.tgz", 717 | "integrity": "sha512-K2waXdXBi2302XUdcHcR1jCeU0LL4TD9HRs/gk0N2Xvrht+G/BfJa4QObBQZfhMdxiCpV3COl5Nfq4uKTeTnJA==", 718 | "dev": true, 719 | "requires": { 720 | "@babel/types": "^7.3.0" 721 | } 722 | }, 723 | "@types/color-name": { 724 | "version": "1.1.1", 725 | "resolved": "https://registry.npmjs.org/@types/color-name/-/color-name-1.1.1.tgz", 726 | "integrity": "sha512-rr+OQyAjxze7GgWrSaJwydHStIhHq2lvY3BOC2Mj7KnzI7XK0Uw1TOOdI9lDoajEbSWLiYgoo4f1R51erQfhPQ==", 727 | "dev": true 728 | }, 729 | "@types/graceful-fs": { 730 | "version": "4.1.5", 731 | "resolved": "https://registry.npmjs.org/@types/graceful-fs/-/graceful-fs-4.1.5.tgz", 732 | "integrity": "sha512-anKkLmZZ+xm4p8JWBf4hElkM4XR+EZeA2M9BAkkTldmcyDY4mbdIJnRghDJH3Ov5ooY7/UAoENtmdMSkaAd7Cw==", 733 | "dev": true, 734 | "requires": { 735 | "@types/node": "*" 736 | } 737 | }, 738 | "@types/istanbul-lib-coverage": { 739 | "version": "2.0.3", 740 | "resolved": "https://registry.npmjs.org/@types/istanbul-lib-coverage/-/istanbul-lib-coverage-2.0.3.tgz", 741 | "integrity": "sha512-sz7iLqvVUg1gIedBOvlkxPlc8/uVzyS5OwGz1cKjXzkl3FpL3al0crU8YGU1WoHkxn0Wxbw5tyi6hvzJKNzFsw==", 742 | "dev": true 743 | }, 744 | "@types/istanbul-lib-report": { 745 | "version": "3.0.0", 746 | "resolved": "https://registry.npmjs.org/@types/istanbul-lib-report/-/istanbul-lib-report-3.0.0.tgz", 747 | "integrity": "sha512-plGgXAPfVKFoYfa9NpYDAkseG+g6Jr294RqeqcqDixSbU34MZVJRi/P+7Y8GDpzkEwLaGZZOpKIEmeVZNtKsrg==", 748 | "dev": true, 749 | "requires": { 750 | "@types/istanbul-lib-coverage": "*" 751 | } 752 | }, 753 | "@types/istanbul-reports": { 754 | "version": "3.0.1", 755 | "resolved": "https://registry.npmjs.org/@types/istanbul-reports/-/istanbul-reports-3.0.1.tgz", 756 | "integrity": "sha512-c3mAZEuK0lvBp8tmuL74XRKn1+y2dcwOUpH7x4WrF6gk1GIgiluDRgMYQtw2OFcBvAJWlt6ASU3tSqxp0Uu0Aw==", 757 | "dev": true, 758 | "requires": { 759 | "@types/istanbul-lib-report": "*" 760 | } 761 | }, 762 | "@types/jest": { 763 | "version": "27.4.0", 764 | "resolved": "https://registry.npmjs.org/@types/jest/-/jest-27.4.0.tgz", 765 | "integrity": "sha512-gHl8XuC1RZ8H2j5sHv/JqsaxXkDDM9iDOgu0Wp8sjs4u/snb2PVehyWXJPr+ORA0RPpgw231mnutWI1+0hgjIQ==", 766 | "dev": true, 767 | "requires": { 768 | "jest-diff": "^27.0.0", 769 | "pretty-format": "^27.0.0" 770 | }, 771 | "dependencies": { 772 | "ansi-regex": { 773 | "version": "5.0.1", 774 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 775 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 776 | "dev": true 777 | }, 778 | "chalk": { 779 | "version": "4.1.2", 780 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", 781 | "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", 782 | "dev": true, 783 | "requires": { 784 | "ansi-styles": "^4.1.0", 785 | "supports-color": "^7.1.0" 786 | } 787 | }, 788 | "diff-sequences": { 789 | "version": "27.5.0", 790 | "resolved": "https://registry.npmjs.org/diff-sequences/-/diff-sequences-27.5.0.tgz", 791 | "integrity": "sha512-ZsOBWnhXiH+Zn0DcBNX/tiQsqrREHs/6oQsEVy2VJJjrTblykPima11pyHMSA/7PGmD+fwclTnKVKL/qtNREDQ==", 792 | "dev": true 793 | }, 794 | "jest-diff": { 795 | "version": "27.5.0", 796 | "resolved": "https://registry.npmjs.org/jest-diff/-/jest-diff-27.5.0.tgz", 797 | "integrity": "sha512-zztvHDCq/QcAVv+o6rts0reupSOxyrX+KLQEOMWCW2trZgcBFgp/oTK7hJCGpXvEIqKrQzyQlaPKn9W04+IMQg==", 798 | "dev": true, 799 | "requires": { 800 | "chalk": "^4.0.0", 801 | "diff-sequences": "^27.5.0", 802 | "jest-get-type": "^27.5.0", 803 | "pretty-format": "^27.5.0" 804 | } 805 | }, 806 | "jest-get-type": { 807 | "version": "27.5.0", 808 | "resolved": "https://registry.npmjs.org/jest-get-type/-/jest-get-type-27.5.0.tgz", 809 | "integrity": "sha512-Vp6O8a52M/dahXRG/E0EJuWQROps2mDQ0sJYPgO8HskhdLwj9ajgngy2OAqZgV6e/RcU67WUHq6TgfvJb8flbA==", 810 | "dev": true 811 | }, 812 | "pretty-format": { 813 | "version": "27.5.0", 814 | "resolved": "https://registry.npmjs.org/pretty-format/-/pretty-format-27.5.0.tgz", 815 | "integrity": "sha512-xEi6BRPZ+J1AIS4BAtFC/+rh5jXlXObGZjx5+OSpM95vR/PGla78bFVHMy5GdZjP9wk3AHAMHROXq/r69zXltw==", 816 | "dev": true, 817 | "requires": { 818 | "ansi-regex": "^5.0.1", 819 | "ansi-styles": "^5.0.0", 820 | "react-is": "^17.0.1" 821 | }, 822 | "dependencies": { 823 | "ansi-styles": { 824 | "version": "5.2.0", 825 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-5.2.0.tgz", 826 | "integrity": "sha512-Cxwpt2SfTzTtXcfOlzGEee8O+c+MmUgGrNiBcXnuWxuFJHe6a5Hz7qwhwe5OgaSYI0IJvkLqWX1ASG+cJOkEiA==", 827 | "dev": true 828 | } 829 | } 830 | }, 831 | "react-is": { 832 | "version": "17.0.2", 833 | "resolved": "https://registry.npmjs.org/react-is/-/react-is-17.0.2.tgz", 834 | "integrity": "sha512-w2GsyukL62IJnlaff/nRegPQR94C/XXamvMWmSHRJ4y7Ts/4ocGRmTHvOs8PSE6pB3dWOrD/nueuU5sduBsQ4w==", 835 | "dev": true 836 | } 837 | } 838 | }, 839 | "@types/node": { 840 | "version": "14.0.14", 841 | "resolved": "https://registry.npmjs.org/@types/node/-/node-14.0.14.tgz", 842 | "integrity": "sha512-syUgf67ZQpaJj01/tRTknkMNoBBLWJOBODF0Zm4NrXmiSuxjymFrxnTu1QVYRubhVkRcZLYZG8STTwJRdVm/WQ==", 843 | "dev": true 844 | }, 845 | "@types/prettier": { 846 | "version": "2.4.3", 847 | "resolved": "https://registry.npmjs.org/@types/prettier/-/prettier-2.4.3.tgz", 848 | "integrity": "sha512-QzSuZMBuG5u8HqYz01qtMdg/Jfctlnvj1z/lYnIDXs/golxw0fxtRAHd9KrzjR7Yxz1qVeI00o0kiO3PmVdJ9w==", 849 | "dev": true 850 | }, 851 | "@types/stack-utils": { 852 | "version": "2.0.1", 853 | "resolved": "https://registry.npmjs.org/@types/stack-utils/-/stack-utils-2.0.1.tgz", 854 | "integrity": "sha512-Hl219/BT5fLAaz6NDkSuhzasy49dwQS/DSdu4MdggFB8zcXv7vflBI3xp7FEmkmdDkBUI2bPUNeMttp2knYdxw==", 855 | "dev": true 856 | }, 857 | "@types/yargs": { 858 | "version": "16.0.4", 859 | "resolved": "https://registry.npmjs.org/@types/yargs/-/yargs-16.0.4.tgz", 860 | "integrity": "sha512-T8Yc9wt/5LbJyCaLiHPReJa0kApcIgJ7Bn735GjItUfh08Z1pJvu8QZqb9s+mMvKV6WUQRV7K2R46YbjMXTTJw==", 861 | "dev": true, 862 | "requires": { 863 | "@types/yargs-parser": "*" 864 | } 865 | }, 866 | "@types/yargs-parser": { 867 | "version": "15.0.0", 868 | "resolved": "https://registry.npmjs.org/@types/yargs-parser/-/yargs-parser-15.0.0.tgz", 869 | "integrity": "sha512-FA/BWv8t8ZWJ+gEOnLLd8ygxH/2UFbAvgEonyfN6yWGLKc7zVjbpl2Y4CTjid9h2RfgPP6SEt6uHwEOply00yw==", 870 | "dev": true 871 | }, 872 | "abab": { 873 | "version": "2.0.5", 874 | "resolved": "https://registry.npmjs.org/abab/-/abab-2.0.5.tgz", 875 | "integrity": "sha512-9IK9EadsbHo6jLWIpxpR6pL0sazTXV6+SQv25ZB+F7Bj9mJNaOc4nCRabwd5M/JwmUa8idz6Eci6eKfJryPs6Q==", 876 | "dev": true 877 | }, 878 | "acorn": { 879 | "version": "8.7.0", 880 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.7.0.tgz", 881 | "integrity": "sha512-V/LGr1APy+PXIwKebEWrkZPwoeoF+w1jiOBUmuxuiUIaOHtob8Qc9BTrYo7VuI5fR8tqsy+buA2WFooR5olqvQ==", 882 | "dev": true 883 | }, 884 | "acorn-globals": { 885 | "version": "6.0.0", 886 | "resolved": "https://registry.npmjs.org/acorn-globals/-/acorn-globals-6.0.0.tgz", 887 | "integrity": "sha512-ZQl7LOWaF5ePqqcX4hLuv/bLXYQNfNWw2c0/yX/TsPRKamzHcTGQnlCjHT3TsmkOUVEPS3crCxiPfdzE/Trlhg==", 888 | "dev": true, 889 | "requires": { 890 | "acorn": "^7.1.1", 891 | "acorn-walk": "^7.1.1" 892 | }, 893 | "dependencies": { 894 | "acorn": { 895 | "version": "7.4.1", 896 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-7.4.1.tgz", 897 | "integrity": "sha512-nQyp0o1/mNdbTO1PO6kHkwSrmgZ0MT/jCCpNiwbUjGoRN4dlBhqJtoQuCnEOKzgTVwg0ZWiCoQy6SxMebQVh8A==", 898 | "dev": true 899 | } 900 | } 901 | }, 902 | "acorn-walk": { 903 | "version": "7.2.0", 904 | "resolved": "https://registry.npmjs.org/acorn-walk/-/acorn-walk-7.2.0.tgz", 905 | "integrity": "sha512-OPdCF6GsMIP+Az+aWfAAOEt2/+iVDKE7oy6lJ098aoe59oAmK76qV6Gw60SbZ8jHuG2wH058GF4pLFbYamYrVA==", 906 | "dev": true 907 | }, 908 | "agent-base": { 909 | "version": "6.0.2", 910 | "resolved": "https://registry.npmjs.org/agent-base/-/agent-base-6.0.2.tgz", 911 | "integrity": "sha512-RZNwNclF7+MS/8bDg70amg32dyeZGZxiDuQmZxKLAlQjr3jGyLx+4Kkk58UO7D2QdgFIQCovuSuZESne6RG6XQ==", 912 | "dev": true, 913 | "requires": { 914 | "debug": "4" 915 | } 916 | }, 917 | "ansi-escapes": { 918 | "version": "4.3.2", 919 | "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-4.3.2.tgz", 920 | "integrity": "sha512-gKXj5ALrKWQLsYG9jlTRmR/xKluxHV+Z9QEwNIgCfM1/uwPMCuzVVnh5mwTd+OuBZcwSIMbqssNWRm1lE51QaQ==", 921 | "dev": true, 922 | "requires": { 923 | "type-fest": "^0.21.3" 924 | } 925 | }, 926 | "ansi-regex": { 927 | "version": "5.0.1", 928 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", 929 | "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", 930 | "dev": true 931 | }, 932 | "ansi-styles": { 933 | "version": "4.2.1", 934 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.2.1.tgz", 935 | "integrity": "sha512-9VGjrMsG1vePxcSweQsN20KY/c4zN0h9fLjqAbwbPfahM3t+NL+M9HC8xeXG2I8pX5NoamTGNuomEUFI7fcUjA==", 936 | "dev": true, 937 | "requires": { 938 | "@types/color-name": "^1.1.1", 939 | "color-convert": "^2.0.1" 940 | } 941 | }, 942 | "anymatch": { 943 | "version": "3.1.2", 944 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.2.tgz", 945 | "integrity": "sha512-P43ePfOAIupkguHUycrc4qJ9kz8ZiuOUijaETwX7THt0Y/GNK7v0aa8rY816xWjZ7rJdA5XdMcpVFTKMq+RvWg==", 946 | "dev": true, 947 | "requires": { 948 | "normalize-path": "^3.0.0", 949 | "picomatch": "^2.0.4" 950 | } 951 | }, 952 | "argparse": { 953 | "version": "1.0.10", 954 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.10.tgz", 955 | "integrity": "sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg==", 956 | "dev": true, 957 | "requires": { 958 | "sprintf-js": "~1.0.2" 959 | } 960 | }, 961 | "asynckit": { 962 | "version": "0.4.0", 963 | "resolved": "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz", 964 | "integrity": "sha1-x57Zf380y48robyXkLzDZkdLS3k=", 965 | "dev": true 966 | }, 967 | "babel-jest": { 968 | "version": "27.5.0", 969 | "resolved": "https://registry.npmjs.org/babel-jest/-/babel-jest-27.5.0.tgz", 970 | "integrity": "sha512-puhCyvBTNLevhbd1oyw6t3gWBicWoUARQYKCBB/B1moif17NbyhxbsfadqZIw8zfJJD+W7Vw0Nb20pEjLxkXqQ==", 971 | "dev": true, 972 | "requires": { 973 | "@jest/transform": "^27.5.0", 974 | "@jest/types": "^27.5.0", 975 | "@types/babel__core": "^7.1.14", 976 | "babel-plugin-istanbul": "^6.1.1", 977 | "babel-preset-jest": "^27.5.0", 978 | "chalk": "^4.0.0", 979 | "graceful-fs": "^4.2.9", 980 | "slash": "^3.0.0" 981 | } 982 | }, 983 | "babel-plugin-istanbul": { 984 | "version": "6.1.1", 985 | "resolved": "https://registry.npmjs.org/babel-plugin-istanbul/-/babel-plugin-istanbul-6.1.1.tgz", 986 | "integrity": "sha512-Y1IQok9821cC9onCx5otgFfRm7Lm+I+wwxOx738M/WLPZ9Q42m4IG5W0FNX8WLL2gYMZo3JkuXIH2DOpWM+qwA==", 987 | "dev": true, 988 | "requires": { 989 | "@babel/helper-plugin-utils": "^7.0.0", 990 | "@istanbuljs/load-nyc-config": "^1.0.0", 991 | "@istanbuljs/schema": "^0.1.2", 992 | "istanbul-lib-instrument": "^5.0.4", 993 | "test-exclude": "^6.0.0" 994 | } 995 | }, 996 | "babel-plugin-jest-hoist": { 997 | "version": "27.5.0", 998 | "resolved": "https://registry.npmjs.org/babel-plugin-jest-hoist/-/babel-plugin-jest-hoist-27.5.0.tgz", 999 | "integrity": "sha512-ztwNkHl+g1GaoQcb8f2BER4C3LMvSXuF7KVqtUioXQgScSEnkl6lLgCILUYIR+CPTwL8H3F/PNLze64HPWF9JA==", 1000 | "dev": true, 1001 | "requires": { 1002 | "@babel/template": "^7.3.3", 1003 | "@babel/types": "^7.3.3", 1004 | "@types/babel__core": "^7.0.0", 1005 | "@types/babel__traverse": "^7.0.6" 1006 | } 1007 | }, 1008 | "babel-preset-current-node-syntax": { 1009 | "version": "1.0.1", 1010 | "resolved": "https://registry.npmjs.org/babel-preset-current-node-syntax/-/babel-preset-current-node-syntax-1.0.1.tgz", 1011 | "integrity": "sha512-M7LQ0bxarkxQoN+vz5aJPsLBn77n8QgTFmo8WK0/44auK2xlCXrYcUxHFxgU7qW5Yzw/CjmLRK2uJzaCd7LvqQ==", 1012 | "dev": true, 1013 | "requires": { 1014 | "@babel/plugin-syntax-async-generators": "^7.8.4", 1015 | "@babel/plugin-syntax-bigint": "^7.8.3", 1016 | "@babel/plugin-syntax-class-properties": "^7.8.3", 1017 | "@babel/plugin-syntax-import-meta": "^7.8.3", 1018 | "@babel/plugin-syntax-json-strings": "^7.8.3", 1019 | "@babel/plugin-syntax-logical-assignment-operators": "^7.8.3", 1020 | "@babel/plugin-syntax-nullish-coalescing-operator": "^7.8.3", 1021 | "@babel/plugin-syntax-numeric-separator": "^7.8.3", 1022 | "@babel/plugin-syntax-object-rest-spread": "^7.8.3", 1023 | "@babel/plugin-syntax-optional-catch-binding": "^7.8.3", 1024 | "@babel/plugin-syntax-optional-chaining": "^7.8.3", 1025 | "@babel/plugin-syntax-top-level-await": "^7.8.3" 1026 | } 1027 | }, 1028 | "babel-preset-jest": { 1029 | "version": "27.5.0", 1030 | "resolved": "https://registry.npmjs.org/babel-preset-jest/-/babel-preset-jest-27.5.0.tgz", 1031 | "integrity": "sha512-7bfu1cJBlgK/nKfTvMlElzA3jpi6GzDWX3fntnyP2cQSzoi/KUz6ewGlcb3PSRYZGyv+uPnVHY0Im3JbsViqgA==", 1032 | "dev": true, 1033 | "requires": { 1034 | "babel-plugin-jest-hoist": "^27.5.0", 1035 | "babel-preset-current-node-syntax": "^1.0.0" 1036 | } 1037 | }, 1038 | "balanced-match": { 1039 | "version": "1.0.0", 1040 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz", 1041 | "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=", 1042 | "dev": true 1043 | }, 1044 | "brace-expansion": { 1045 | "version": "1.1.11", 1046 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 1047 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 1048 | "dev": true, 1049 | "requires": { 1050 | "balanced-match": "^1.0.0", 1051 | "concat-map": "0.0.1" 1052 | } 1053 | }, 1054 | "braces": { 1055 | "version": "3.0.2", 1056 | "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", 1057 | "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", 1058 | "dev": true, 1059 | "requires": { 1060 | "fill-range": "^7.0.1" 1061 | } 1062 | }, 1063 | "browser-process-hrtime": { 1064 | "version": "1.0.0", 1065 | "resolved": "https://registry.npmjs.org/browser-process-hrtime/-/browser-process-hrtime-1.0.0.tgz", 1066 | "integrity": "sha512-9o5UecI3GhkpM6DrXr69PblIuWxPKk9Y0jHBRhdocZ2y7YECBFCsHm79Pr3OyR2AvjhDkabFJaDJMYRazHgsow==", 1067 | "dev": true 1068 | }, 1069 | "browserslist": { 1070 | "version": "4.19.1", 1071 | "resolved": "https://registry.npmjs.org/browserslist/-/browserslist-4.19.1.tgz", 1072 | "integrity": "sha512-u2tbbG5PdKRTUoctO3NBD8FQ5HdPh1ZXPHzp1rwaa5jTc+RV9/+RlWiAIKmjRPQF+xbGM9Kklj5bZQFa2s/38A==", 1073 | "dev": true, 1074 | "requires": { 1075 | "caniuse-lite": "^1.0.30001286", 1076 | "electron-to-chromium": "^1.4.17", 1077 | "escalade": "^3.1.1", 1078 | "node-releases": "^2.0.1", 1079 | "picocolors": "^1.0.0" 1080 | } 1081 | }, 1082 | "bs-logger": { 1083 | "version": "0.2.6", 1084 | "resolved": "https://registry.npmjs.org/bs-logger/-/bs-logger-0.2.6.tgz", 1085 | "integrity": "sha512-pd8DCoxmbgc7hyPKOvxtqNcjYoOsABPQdcCUjGp3d42VR2CX1ORhk2A87oqqu5R1kk+76nsxZupkmyd+MVtCog==", 1086 | "dev": true, 1087 | "requires": { 1088 | "fast-json-stable-stringify": "2.x" 1089 | } 1090 | }, 1091 | "bser": { 1092 | "version": "2.1.1", 1093 | "resolved": "https://registry.npmjs.org/bser/-/bser-2.1.1.tgz", 1094 | "integrity": "sha512-gQxTNE/GAfIIrmHLUE3oJyp5FO6HRBfhjnw4/wMmA63ZGDJnWBmgY/lyQBpnDUkGmAhbSe39tx2d/iTOAfglwQ==", 1095 | "dev": true, 1096 | "requires": { 1097 | "node-int64": "^0.4.0" 1098 | } 1099 | }, 1100 | "buffer-from": { 1101 | "version": "1.1.2", 1102 | "resolved": "https://registry.npmjs.org/buffer-from/-/buffer-from-1.1.2.tgz", 1103 | "integrity": "sha512-E+XQCRwSbaaiChtv6k6Dwgc+bx+Bs6vuKJHHl5kox/BaKbhiXzqQOwK4cO22yElGp2OCmjwVhT3HmxgyPGnJfQ==", 1104 | "dev": true 1105 | }, 1106 | "callsites": { 1107 | "version": "3.1.0", 1108 | "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", 1109 | "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==", 1110 | "dev": true 1111 | }, 1112 | "camelcase": { 1113 | "version": "5.3.1", 1114 | "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-5.3.1.tgz", 1115 | "integrity": "sha512-L28STB170nwWS63UjtlEOE3dldQApaJXZkOI1uMFfzf3rRuPegHaHesyee+YxQ+W6SvRDQV6UrdOdRiR153wJg==", 1116 | "dev": true 1117 | }, 1118 | "caniuse-lite": { 1119 | "version": "1.0.30001309", 1120 | "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001309.tgz", 1121 | "integrity": "sha512-Pl8vfigmBXXq+/yUz1jUwULeq9xhMJznzdc/xwl4WclDAuebcTHVefpz8lE/bMI+UN7TOkSSe7B7RnZd6+dzjA==", 1122 | "dev": true 1123 | }, 1124 | "chalk": { 1125 | "version": "4.1.2", 1126 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", 1127 | "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", 1128 | "dev": true, 1129 | "requires": { 1130 | "ansi-styles": "^4.1.0", 1131 | "supports-color": "^7.1.0" 1132 | } 1133 | }, 1134 | "char-regex": { 1135 | "version": "1.0.2", 1136 | "resolved": "https://registry.npmjs.org/char-regex/-/char-regex-1.0.2.tgz", 1137 | "integrity": "sha512-kWWXztvZ5SBQV+eRgKFeh8q5sLuZY2+8WUIzlxWVTg+oGwY14qylx1KbKzHd8P6ZYkAg0xyIDU9JMHhyJMZ1jw==", 1138 | "dev": true 1139 | }, 1140 | "ci-info": { 1141 | "version": "3.3.0", 1142 | "resolved": "https://registry.npmjs.org/ci-info/-/ci-info-3.3.0.tgz", 1143 | "integrity": "sha512-riT/3vI5YpVH6/qomlDnJow6TBee2PBKSEpx3O32EGPYbWGIRsIlGRms3Sm74wYE1JMo8RnO04Hb12+v1J5ICw==", 1144 | "dev": true 1145 | }, 1146 | "cjs-module-lexer": { 1147 | "version": "1.2.2", 1148 | "resolved": "https://registry.npmjs.org/cjs-module-lexer/-/cjs-module-lexer-1.2.2.tgz", 1149 | "integrity": "sha512-cOU9usZw8/dXIXKtwa8pM0OTJQuJkxMN6w30csNRUerHfeQ5R6U3kkU/FtJeIf3M202OHfY2U8ccInBG7/xogA==", 1150 | "dev": true 1151 | }, 1152 | "cliui": { 1153 | "version": "7.0.4", 1154 | "resolved": "https://registry.npmjs.org/cliui/-/cliui-7.0.4.tgz", 1155 | "integrity": "sha512-OcRE68cOsVMXp1Yvonl/fzkQOyjLSu/8bhPDfQt0e0/Eb283TKP20Fs2MqoPsr9SwA595rRCA+QMzYc9nBP+JQ==", 1156 | "dev": true, 1157 | "requires": { 1158 | "string-width": "^4.2.0", 1159 | "strip-ansi": "^6.0.0", 1160 | "wrap-ansi": "^7.0.0" 1161 | } 1162 | }, 1163 | "co": { 1164 | "version": "4.6.0", 1165 | "resolved": "https://registry.npmjs.org/co/-/co-4.6.0.tgz", 1166 | "integrity": "sha1-bqa989hTrlTMuOR7+gvz+QMfsYQ=", 1167 | "dev": true 1168 | }, 1169 | "collect-v8-coverage": { 1170 | "version": "1.0.1", 1171 | "resolved": "https://registry.npmjs.org/collect-v8-coverage/-/collect-v8-coverage-1.0.1.tgz", 1172 | "integrity": "sha512-iBPtljfCNcTKNAto0KEtDfZ3qzjJvqE3aTGZsbhjSBlorqpXJlaWWtPO35D+ZImoC3KWejX64o+yPGxhWSTzfg==", 1173 | "dev": true 1174 | }, 1175 | "color-convert": { 1176 | "version": "2.0.1", 1177 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 1178 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 1179 | "dev": true, 1180 | "requires": { 1181 | "color-name": "~1.1.4" 1182 | } 1183 | }, 1184 | "color-name": { 1185 | "version": "1.1.4", 1186 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 1187 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 1188 | "dev": true 1189 | }, 1190 | "combined-stream": { 1191 | "version": "1.0.8", 1192 | "resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.8.tgz", 1193 | "integrity": "sha512-FQN4MRfuJeHf7cBbBMJFXhKSDq+2kAArBlmRBvcvFE5BB1HZKXtSFASDhdlz9zOYwxh8lDdnvmMOe/+5cdoEdg==", 1194 | "dev": true, 1195 | "requires": { 1196 | "delayed-stream": "~1.0.0" 1197 | } 1198 | }, 1199 | "concat-map": { 1200 | "version": "0.0.1", 1201 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 1202 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=", 1203 | "dev": true 1204 | }, 1205 | "convert-source-map": { 1206 | "version": "1.8.0", 1207 | "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-1.8.0.tgz", 1208 | "integrity": "sha512-+OQdjP49zViI/6i7nIJpA8rAl4sV/JdPfU9nZs3VqOwGIgizICvuN2ru6fMd+4llL0tar18UYJXfZ/TWtmhUjA==", 1209 | "dev": true, 1210 | "requires": { 1211 | "safe-buffer": "~5.1.1" 1212 | } 1213 | }, 1214 | "cross-spawn": { 1215 | "version": "7.0.3", 1216 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz", 1217 | "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==", 1218 | "dev": true, 1219 | "requires": { 1220 | "path-key": "^3.1.0", 1221 | "shebang-command": "^2.0.0", 1222 | "which": "^2.0.1" 1223 | } 1224 | }, 1225 | "cssom": { 1226 | "version": "0.4.4", 1227 | "resolved": "https://registry.npmjs.org/cssom/-/cssom-0.4.4.tgz", 1228 | "integrity": "sha512-p3pvU7r1MyyqbTk+WbNJIgJjG2VmTIaB10rI93LzVPrmDJKkzKYMtxxyAvQXR/NS6otuzveI7+7BBq3SjBS2mw==", 1229 | "dev": true 1230 | }, 1231 | "cssstyle": { 1232 | "version": "2.3.0", 1233 | "resolved": "https://registry.npmjs.org/cssstyle/-/cssstyle-2.3.0.tgz", 1234 | "integrity": "sha512-AZL67abkUzIuvcHqk7c09cezpGNcxUxU4Ioi/05xHk4DQeTkWmGYftIE6ctU6AEt+Gn4n1lDStOtj7FKycP71A==", 1235 | "dev": true, 1236 | "requires": { 1237 | "cssom": "~0.3.6" 1238 | }, 1239 | "dependencies": { 1240 | "cssom": { 1241 | "version": "0.3.8", 1242 | "resolved": "https://registry.npmjs.org/cssom/-/cssom-0.3.8.tgz", 1243 | "integrity": "sha512-b0tGHbfegbhPJpxpiBPU2sCkigAqtM9O121le6bbOlgyV+NyGyCmVfJ6QW9eRjz8CpNfWEOYBIMIGRYkLwsIYg==", 1244 | "dev": true 1245 | } 1246 | } 1247 | }, 1248 | "data-urls": { 1249 | "version": "2.0.0", 1250 | "resolved": "https://registry.npmjs.org/data-urls/-/data-urls-2.0.0.tgz", 1251 | "integrity": "sha512-X5eWTSXO/BJmpdIKCRuKUgSCgAN0OwliVK3yPKbwIWU1Tdw5BRajxlzMidvh+gwko9AfQ9zIj52pzF91Q3YAvQ==", 1252 | "dev": true, 1253 | "requires": { 1254 | "abab": "^2.0.3", 1255 | "whatwg-mimetype": "^2.3.0", 1256 | "whatwg-url": "^8.0.0" 1257 | } 1258 | }, 1259 | "debug": { 1260 | "version": "4.3.3", 1261 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.3.tgz", 1262 | "integrity": "sha512-/zxw5+vh1Tfv+4Qn7a5nsbcJKPaSvCDhojn6FEl9vupwK2VCSDtEiEtqr8DFtzYFOdz63LBkxec7DYuc2jon6Q==", 1263 | "dev": true, 1264 | "requires": { 1265 | "ms": "2.1.2" 1266 | } 1267 | }, 1268 | "decimal.js": { 1269 | "version": "10.3.1", 1270 | "resolved": "https://registry.npmjs.org/decimal.js/-/decimal.js-10.3.1.tgz", 1271 | "integrity": "sha512-V0pfhfr8suzyPGOx3nmq4aHqabehUZn6Ch9kyFpV79TGDTWFmHqUqXdabR7QHqxzrYolF4+tVmJhUG4OURg5dQ==", 1272 | "dev": true 1273 | }, 1274 | "dedent": { 1275 | "version": "0.7.0", 1276 | "resolved": "https://registry.npmjs.org/dedent/-/dedent-0.7.0.tgz", 1277 | "integrity": "sha1-JJXduvbrh0q7Dhvp3yLS5aVEMmw=", 1278 | "dev": true 1279 | }, 1280 | "deep-is": { 1281 | "version": "0.1.4", 1282 | "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.4.tgz", 1283 | "integrity": "sha512-oIPzksmTg4/MriiaYGO+okXDT7ztn/w3Eptv/+gSIdMdKsJo0u4CfYNFJPy+4SKMuCqGw2wxnA+URMg3t8a/bQ==", 1284 | "dev": true 1285 | }, 1286 | "deepmerge": { 1287 | "version": "4.2.2", 1288 | "resolved": "https://registry.npmjs.org/deepmerge/-/deepmerge-4.2.2.tgz", 1289 | "integrity": "sha512-FJ3UgI4gIl+PHZm53knsuSFpE+nESMr7M4v9QcgB7S63Kj/6WqMiFQJpBBYz1Pt+66bZpP3Q7Lye0Oo9MPKEdg==", 1290 | "dev": true 1291 | }, 1292 | "delayed-stream": { 1293 | "version": "1.0.0", 1294 | "resolved": "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz", 1295 | "integrity": "sha1-3zrhmayt+31ECqrgsp4icrJOxhk=", 1296 | "dev": true 1297 | }, 1298 | "detect-newline": { 1299 | "version": "3.1.0", 1300 | "resolved": "https://registry.npmjs.org/detect-newline/-/detect-newline-3.1.0.tgz", 1301 | "integrity": "sha512-TLz+x/vEXm/Y7P7wn1EJFNLxYpUD4TgMosxY6fAVJUnJMbupHBOncxyWUG9OpTaH9EBD7uFI5LfEgmMOc54DsA==", 1302 | "dev": true 1303 | }, 1304 | "diff-sequences": { 1305 | "version": "27.5.0", 1306 | "resolved": "https://registry.npmjs.org/diff-sequences/-/diff-sequences-27.5.0.tgz", 1307 | "integrity": "sha512-ZsOBWnhXiH+Zn0DcBNX/tiQsqrREHs/6oQsEVy2VJJjrTblykPima11pyHMSA/7PGmD+fwclTnKVKL/qtNREDQ==", 1308 | "dev": true 1309 | }, 1310 | "domexception": { 1311 | "version": "2.0.1", 1312 | "resolved": "https://registry.npmjs.org/domexception/-/domexception-2.0.1.tgz", 1313 | "integrity": "sha512-yxJ2mFy/sibVQlu5qHjOkf9J3K6zgmCxgJ94u2EdvDOV09H+32LtRswEcUsmUWN72pVLOEnTSRaIVVzVQgS0dg==", 1314 | "dev": true, 1315 | "requires": { 1316 | "webidl-conversions": "^5.0.0" 1317 | }, 1318 | "dependencies": { 1319 | "webidl-conversions": { 1320 | "version": "5.0.0", 1321 | "resolved": "https://registry.npmjs.org/webidl-conversions/-/webidl-conversions-5.0.0.tgz", 1322 | "integrity": "sha512-VlZwKPCkYKxQgeSbH5EyngOmRp7Ww7I9rQLERETtf5ofd9pGeswWiOtogpEO850jziPRarreGxn5QIiTqpb2wA==", 1323 | "dev": true 1324 | } 1325 | } 1326 | }, 1327 | "electron-to-chromium": { 1328 | "version": "1.4.66", 1329 | "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.4.66.tgz", 1330 | "integrity": "sha512-f1RXFMsvwufWLwYUxTiP7HmjprKXrqEWHiQkjAYa9DJeVIlZk5v8gBGcaV+FhtXLly6C1OTVzQY+2UQrACiLlg==", 1331 | "dev": true 1332 | }, 1333 | "emittery": { 1334 | "version": "0.8.1", 1335 | "resolved": "https://registry.npmjs.org/emittery/-/emittery-0.8.1.tgz", 1336 | "integrity": "sha512-uDfvUjVrfGJJhymx/kz6prltenw1u7WrCg1oa94zYY8xxVpLLUu045LAT0dhDZdXG58/EpPL/5kA180fQ/qudg==", 1337 | "dev": true 1338 | }, 1339 | "emoji-regex": { 1340 | "version": "8.0.0", 1341 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 1342 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 1343 | "dev": true 1344 | }, 1345 | "escalade": { 1346 | "version": "3.1.1", 1347 | "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.1.1.tgz", 1348 | "integrity": "sha512-k0er2gUkLf8O0zKJiAhmkTnJlTvINGv7ygDNPbeIsX/TJjGJZHuh9B2UxbsaEkmlEo9MfhrSzmhIlhRlI2GXnw==", 1349 | "dev": true 1350 | }, 1351 | "escape-string-regexp": { 1352 | "version": "1.0.5", 1353 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", 1354 | "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=", 1355 | "dev": true 1356 | }, 1357 | "escodegen": { 1358 | "version": "2.0.0", 1359 | "resolved": "https://registry.npmjs.org/escodegen/-/escodegen-2.0.0.tgz", 1360 | "integrity": "sha512-mmHKys/C8BFUGI+MAWNcSYoORYLMdPzjrknd2Vc+bUsjN5bXcr8EhrNB+UTqfL1y3I9c4fw2ihgtMPQLBRiQxw==", 1361 | "dev": true, 1362 | "requires": { 1363 | "esprima": "^4.0.1", 1364 | "estraverse": "^5.2.0", 1365 | "esutils": "^2.0.2", 1366 | "optionator": "^0.8.1", 1367 | "source-map": "~0.6.1" 1368 | } 1369 | }, 1370 | "esprima": { 1371 | "version": "4.0.1", 1372 | "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz", 1373 | "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==", 1374 | "dev": true 1375 | }, 1376 | "estraverse": { 1377 | "version": "5.3.0", 1378 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.3.0.tgz", 1379 | "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==", 1380 | "dev": true 1381 | }, 1382 | "esutils": { 1383 | "version": "2.0.3", 1384 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", 1385 | "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==", 1386 | "dev": true 1387 | }, 1388 | "execa": { 1389 | "version": "5.1.1", 1390 | "resolved": "https://registry.npmjs.org/execa/-/execa-5.1.1.tgz", 1391 | "integrity": "sha512-8uSpZZocAZRBAPIEINJj3Lo9HyGitllczc27Eh5YYojjMFMn8yHMDMaUHE2Jqfq05D/wucwI4JGURyXt1vchyg==", 1392 | "dev": true, 1393 | "requires": { 1394 | "cross-spawn": "^7.0.3", 1395 | "get-stream": "^6.0.0", 1396 | "human-signals": "^2.1.0", 1397 | "is-stream": "^2.0.0", 1398 | "merge-stream": "^2.0.0", 1399 | "npm-run-path": "^4.0.1", 1400 | "onetime": "^5.1.2", 1401 | "signal-exit": "^3.0.3", 1402 | "strip-final-newline": "^2.0.0" 1403 | } 1404 | }, 1405 | "exit": { 1406 | "version": "0.1.2", 1407 | "resolved": "https://registry.npmjs.org/exit/-/exit-0.1.2.tgz", 1408 | "integrity": "sha1-BjJjj42HfMghB9MKD/8aF8uhzQw=", 1409 | "dev": true 1410 | }, 1411 | "expect": { 1412 | "version": "27.5.0", 1413 | "resolved": "https://registry.npmjs.org/expect/-/expect-27.5.0.tgz", 1414 | "integrity": "sha512-z73GZ132cBqrapO0X6BeRjyBXqOt9YeRtnDteHJIQqp5s2pZ41Hz23VUbsVFMfkrsFLU9GwoIRS0ZzLuFK8M5w==", 1415 | "dev": true, 1416 | "requires": { 1417 | "@jest/types": "^27.5.0", 1418 | "jest-get-type": "^27.5.0", 1419 | "jest-matcher-utils": "^27.5.0", 1420 | "jest-message-util": "^27.5.0" 1421 | } 1422 | }, 1423 | "fast-json-stable-stringify": { 1424 | "version": "2.1.0", 1425 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz", 1426 | "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==", 1427 | "dev": true 1428 | }, 1429 | "fast-levenshtein": { 1430 | "version": "2.0.6", 1431 | "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", 1432 | "integrity": "sha1-PYpcZog6FqMMqGQ+hR8Zuqd5eRc=", 1433 | "dev": true 1434 | }, 1435 | "fb-watchman": { 1436 | "version": "2.0.1", 1437 | "resolved": "https://registry.npmjs.org/fb-watchman/-/fb-watchman-2.0.1.tgz", 1438 | "integrity": "sha512-DkPJKQeY6kKwmuMretBhr7G6Vodr7bFwDYTXIkfG1gjvNpaxBTQV3PbXg6bR1c1UP4jPOX0jHUbbHANL9vRjVg==", 1439 | "dev": true, 1440 | "requires": { 1441 | "bser": "2.1.1" 1442 | } 1443 | }, 1444 | "fill-range": { 1445 | "version": "7.0.1", 1446 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", 1447 | "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", 1448 | "dev": true, 1449 | "requires": { 1450 | "to-regex-range": "^5.0.1" 1451 | } 1452 | }, 1453 | "find-up": { 1454 | "version": "4.1.0", 1455 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-4.1.0.tgz", 1456 | "integrity": "sha512-PpOwAdQ/YlXQ2vj8a3h8IipDuYRi3wceVQQGYWxNINccq40Anw7BlsEXCMbt1Zt+OLA6Fq9suIpIWD0OsnISlw==", 1457 | "dev": true, 1458 | "requires": { 1459 | "locate-path": "^5.0.0", 1460 | "path-exists": "^4.0.0" 1461 | } 1462 | }, 1463 | "form-data": { 1464 | "version": "3.0.1", 1465 | "resolved": "https://registry.npmjs.org/form-data/-/form-data-3.0.1.tgz", 1466 | "integrity": "sha512-RHkBKtLWUVwd7SqRIvCZMEvAMoGUp0XU+seQiZejj0COz3RI3hWP4sCv3gZWWLjJTd7rGwcsF5eKZGii0r/hbg==", 1467 | "dev": true, 1468 | "requires": { 1469 | "asynckit": "^0.4.0", 1470 | "combined-stream": "^1.0.8", 1471 | "mime-types": "^2.1.12" 1472 | } 1473 | }, 1474 | "fs.realpath": { 1475 | "version": "1.0.0", 1476 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 1477 | "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=", 1478 | "dev": true 1479 | }, 1480 | "fsevents": { 1481 | "version": "2.3.2", 1482 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.2.tgz", 1483 | "integrity": "sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==", 1484 | "dev": true, 1485 | "optional": true 1486 | }, 1487 | "function-bind": { 1488 | "version": "1.1.1", 1489 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", 1490 | "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==", 1491 | "dev": true 1492 | }, 1493 | "gensync": { 1494 | "version": "1.0.0-beta.2", 1495 | "resolved": "https://registry.npmjs.org/gensync/-/gensync-1.0.0-beta.2.tgz", 1496 | "integrity": "sha512-3hN7NaskYvMDLQY55gnW3NQ+mesEAepTqlg+VEbj7zzqEMBVNhzcGYYeqFo/TlYz6eQiFcp1HcsCZO+nGgS8zg==", 1497 | "dev": true 1498 | }, 1499 | "get-caller-file": { 1500 | "version": "2.0.5", 1501 | "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-2.0.5.tgz", 1502 | "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==", 1503 | "dev": true 1504 | }, 1505 | "get-package-type": { 1506 | "version": "0.1.0", 1507 | "resolved": "https://registry.npmjs.org/get-package-type/-/get-package-type-0.1.0.tgz", 1508 | "integrity": "sha512-pjzuKtY64GYfWizNAJ0fr9VqttZkNiK2iS430LtIHzjBEr6bX8Am2zm4sW4Ro5wjWW5cAlRL1qAMTcXbjNAO2Q==", 1509 | "dev": true 1510 | }, 1511 | "get-stream": { 1512 | "version": "6.0.1", 1513 | "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-6.0.1.tgz", 1514 | "integrity": "sha512-ts6Wi+2j3jQjqi70w5AlN8DFnkSwC+MqmxEzdEALB2qXZYV3X/b1CTfgPLGJNMeAWxdPfU8FO1ms3NUfaHCPYg==", 1515 | "dev": true 1516 | }, 1517 | "glob": { 1518 | "version": "7.1.6", 1519 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.6.tgz", 1520 | "integrity": "sha512-LwaxwyZ72Lk7vZINtNNrywX0ZuLyStrdDtabefZKAY5ZGJhVtgdznluResxNmPitE0SAO+O26sWTHeKSI2wMBA==", 1521 | "dev": true, 1522 | "requires": { 1523 | "fs.realpath": "^1.0.0", 1524 | "inflight": "^1.0.4", 1525 | "inherits": "2", 1526 | "minimatch": "^3.0.4", 1527 | "once": "^1.3.0", 1528 | "path-is-absolute": "^1.0.0" 1529 | } 1530 | }, 1531 | "globals": { 1532 | "version": "11.12.0", 1533 | "resolved": "https://registry.npmjs.org/globals/-/globals-11.12.0.tgz", 1534 | "integrity": "sha512-WOBp/EEGUiIsJSp7wcv/y6MO+lV9UoncWqxuFfm8eBwzWNgyfBd6Gz+IeKQ9jCmyhoH99g15M3T+QaVHFjizVA==", 1535 | "dev": true 1536 | }, 1537 | "graceful-fs": { 1538 | "version": "4.2.9", 1539 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.9.tgz", 1540 | "integrity": "sha512-NtNxqUcXgpW2iMrfqSfR73Glt39K+BLwWsPs94yR63v45T0Wbej7eRmL5cWfwEgqXnmjQp3zaJTshdRW/qC2ZQ==", 1541 | "dev": true 1542 | }, 1543 | "has": { 1544 | "version": "1.0.3", 1545 | "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", 1546 | "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", 1547 | "dev": true, 1548 | "requires": { 1549 | "function-bind": "^1.1.1" 1550 | } 1551 | }, 1552 | "has-flag": { 1553 | "version": "4.0.0", 1554 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", 1555 | "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", 1556 | "dev": true 1557 | }, 1558 | "html-encoding-sniffer": { 1559 | "version": "2.0.1", 1560 | "resolved": "https://registry.npmjs.org/html-encoding-sniffer/-/html-encoding-sniffer-2.0.1.tgz", 1561 | "integrity": "sha512-D5JbOMBIR/TVZkubHT+OyT2705QvogUW4IBn6nHd756OwieSF9aDYFj4dv6HHEVGYbHaLETa3WggZYWWMyy3ZQ==", 1562 | "dev": true, 1563 | "requires": { 1564 | "whatwg-encoding": "^1.0.5" 1565 | } 1566 | }, 1567 | "html-escaper": { 1568 | "version": "2.0.2", 1569 | "resolved": "https://registry.npmjs.org/html-escaper/-/html-escaper-2.0.2.tgz", 1570 | "integrity": "sha512-H2iMtd0I4Mt5eYiapRdIDjp+XzelXQ0tFE4JS7YFwFevXXMmOp9myNrUvCg0D6ws8iqkRPBfKHgbwig1SmlLfg==", 1571 | "dev": true 1572 | }, 1573 | "http-proxy-agent": { 1574 | "version": "4.0.1", 1575 | "resolved": "https://registry.npmjs.org/http-proxy-agent/-/http-proxy-agent-4.0.1.tgz", 1576 | "integrity": "sha512-k0zdNgqWTGA6aeIRVpvfVob4fL52dTfaehylg0Y4UvSySvOq/Y+BOyPrgpUrA7HylqvU8vIZGsRuXmspskV0Tg==", 1577 | "dev": true, 1578 | "requires": { 1579 | "@tootallnate/once": "1", 1580 | "agent-base": "6", 1581 | "debug": "4" 1582 | } 1583 | }, 1584 | "https-proxy-agent": { 1585 | "version": "5.0.0", 1586 | "resolved": "https://registry.npmjs.org/https-proxy-agent/-/https-proxy-agent-5.0.0.tgz", 1587 | "integrity": "sha512-EkYm5BcKUGiduxzSt3Eppko+PiNWNEpa4ySk9vTC6wDsQJW9rHSa+UhGNJoRYp7bz6Ht1eaRIa6QaJqO5rCFbA==", 1588 | "dev": true, 1589 | "requires": { 1590 | "agent-base": "6", 1591 | "debug": "4" 1592 | } 1593 | }, 1594 | "human-signals": { 1595 | "version": "2.1.0", 1596 | "resolved": "https://registry.npmjs.org/human-signals/-/human-signals-2.1.0.tgz", 1597 | "integrity": "sha512-B4FFZ6q/T2jhhksgkbEW3HBvWIfDW85snkQgawt07S7J5QXTk6BkNV+0yAeZrM5QpMAdYlocGoljn0sJ/WQkFw==", 1598 | "dev": true 1599 | }, 1600 | "iconv-lite": { 1601 | "version": "0.4.24", 1602 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", 1603 | "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", 1604 | "dev": true, 1605 | "requires": { 1606 | "safer-buffer": ">= 2.1.2 < 3" 1607 | } 1608 | }, 1609 | "import-local": { 1610 | "version": "3.1.0", 1611 | "resolved": "https://registry.npmjs.org/import-local/-/import-local-3.1.0.tgz", 1612 | "integrity": "sha512-ASB07uLtnDs1o6EHjKpX34BKYDSqnFerfTOJL2HvMqF70LnxpjkzDB8J44oT9pu4AMPkQwf8jl6szgvNd2tRIg==", 1613 | "dev": true, 1614 | "requires": { 1615 | "pkg-dir": "^4.2.0", 1616 | "resolve-cwd": "^3.0.0" 1617 | } 1618 | }, 1619 | "imurmurhash": { 1620 | "version": "0.1.4", 1621 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 1622 | "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=", 1623 | "dev": true 1624 | }, 1625 | "inflight": { 1626 | "version": "1.0.6", 1627 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 1628 | "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", 1629 | "dev": true, 1630 | "requires": { 1631 | "once": "^1.3.0", 1632 | "wrappy": "1" 1633 | } 1634 | }, 1635 | "inherits": { 1636 | "version": "2.0.4", 1637 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 1638 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", 1639 | "dev": true 1640 | }, 1641 | "is-core-module": { 1642 | "version": "2.8.1", 1643 | "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.8.1.tgz", 1644 | "integrity": "sha512-SdNCUs284hr40hFTFP6l0IfZ/RSrMXF3qgoRHd3/79unUTvrFO/JoXwkGm+5J/Oe3E/b5GsnG330uUNgRpu1PA==", 1645 | "dev": true, 1646 | "requires": { 1647 | "has": "^1.0.3" 1648 | } 1649 | }, 1650 | "is-fullwidth-code-point": { 1651 | "version": "3.0.0", 1652 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 1653 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 1654 | "dev": true 1655 | }, 1656 | "is-generator-fn": { 1657 | "version": "2.1.0", 1658 | "resolved": "https://registry.npmjs.org/is-generator-fn/-/is-generator-fn-2.1.0.tgz", 1659 | "integrity": "sha512-cTIB4yPYL/Grw0EaSzASzg6bBy9gqCofvWN8okThAYIxKJZC+udlRAmGbM0XLeniEJSs8uEgHPGuHSe1XsOLSQ==", 1660 | "dev": true 1661 | }, 1662 | "is-number": { 1663 | "version": "7.0.0", 1664 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", 1665 | "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", 1666 | "dev": true 1667 | }, 1668 | "is-potential-custom-element-name": { 1669 | "version": "1.0.1", 1670 | "resolved": "https://registry.npmjs.org/is-potential-custom-element-name/-/is-potential-custom-element-name-1.0.1.tgz", 1671 | "integrity": "sha512-bCYeRA2rVibKZd+s2625gGnGF/t7DSqDs4dP7CrLA1m7jKWz6pps0LpYLJN8Q64HtmPKJ1hrN3nzPNKFEKOUiQ==", 1672 | "dev": true 1673 | }, 1674 | "is-stream": { 1675 | "version": "2.0.1", 1676 | "resolved": "https://registry.npmjs.org/is-stream/-/is-stream-2.0.1.tgz", 1677 | "integrity": "sha512-hFoiJiTl63nn+kstHGBtewWSKnQLpyb155KHheA1l39uvtO9nWIop1p3udqPcUd/xbF1VLMO4n7OI6p7RbngDg==", 1678 | "dev": true 1679 | }, 1680 | "is-typedarray": { 1681 | "version": "1.0.0", 1682 | "resolved": "https://registry.npmjs.org/is-typedarray/-/is-typedarray-1.0.0.tgz", 1683 | "integrity": "sha1-5HnICFjfDBsR3dppQPlgEfzaSpo=", 1684 | "dev": true 1685 | }, 1686 | "isexe": { 1687 | "version": "2.0.0", 1688 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 1689 | "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=", 1690 | "dev": true 1691 | }, 1692 | "istanbul-lib-coverage": { 1693 | "version": "3.2.0", 1694 | "resolved": "https://registry.npmjs.org/istanbul-lib-coverage/-/istanbul-lib-coverage-3.2.0.tgz", 1695 | "integrity": "sha512-eOeJ5BHCmHYvQK7xt9GkdHuzuCGS1Y6g9Gvnx3Ym33fz/HpLRYxiS0wHNr+m/MBC8B647Xt608vCDEvhl9c6Mw==", 1696 | "dev": true 1697 | }, 1698 | "istanbul-lib-instrument": { 1699 | "version": "5.1.0", 1700 | "resolved": "https://registry.npmjs.org/istanbul-lib-instrument/-/istanbul-lib-instrument-5.1.0.tgz", 1701 | "integrity": "sha512-czwUz525rkOFDJxfKK6mYfIs9zBKILyrZQxjz3ABhjQXhbhFsSbo1HW/BFcsDnfJYJWA6thRR5/TUY2qs5W99Q==", 1702 | "dev": true, 1703 | "requires": { 1704 | "@babel/core": "^7.12.3", 1705 | "@babel/parser": "^7.14.7", 1706 | "@istanbuljs/schema": "^0.1.2", 1707 | "istanbul-lib-coverage": "^3.2.0", 1708 | "semver": "^6.3.0" 1709 | } 1710 | }, 1711 | "istanbul-lib-report": { 1712 | "version": "3.0.0", 1713 | "resolved": "https://registry.npmjs.org/istanbul-lib-report/-/istanbul-lib-report-3.0.0.tgz", 1714 | "integrity": "sha512-wcdi+uAKzfiGT2abPpKZ0hSU1rGQjUQnLvtY5MpQ7QCTahD3VODhcu4wcfY1YtkGaDD5yuydOLINXsfbus9ROw==", 1715 | "dev": true, 1716 | "requires": { 1717 | "istanbul-lib-coverage": "^3.0.0", 1718 | "make-dir": "^3.0.0", 1719 | "supports-color": "^7.1.0" 1720 | } 1721 | }, 1722 | "istanbul-lib-source-maps": { 1723 | "version": "4.0.1", 1724 | "resolved": "https://registry.npmjs.org/istanbul-lib-source-maps/-/istanbul-lib-source-maps-4.0.1.tgz", 1725 | "integrity": "sha512-n3s8EwkdFIJCG3BPKBYvskgXGoy88ARzvegkitk60NxRdwltLOTaH7CUiMRXvwYorl0Q712iEjcWB+fK/MrWVw==", 1726 | "dev": true, 1727 | "requires": { 1728 | "debug": "^4.1.1", 1729 | "istanbul-lib-coverage": "^3.0.0", 1730 | "source-map": "^0.6.1" 1731 | } 1732 | }, 1733 | "istanbul-reports": { 1734 | "version": "3.1.4", 1735 | "resolved": "https://registry.npmjs.org/istanbul-reports/-/istanbul-reports-3.1.4.tgz", 1736 | "integrity": "sha512-r1/DshN4KSE7xWEknZLLLLDn5CJybV3nw01VTkp6D5jzLuELlcbudfj/eSQFvrKsJuTVCGnePO7ho82Nw9zzfw==", 1737 | "dev": true, 1738 | "requires": { 1739 | "html-escaper": "^2.0.0", 1740 | "istanbul-lib-report": "^3.0.0" 1741 | } 1742 | }, 1743 | "jest": { 1744 | "version": "27.5.0", 1745 | "resolved": "https://registry.npmjs.org/jest/-/jest-27.5.0.tgz", 1746 | "integrity": "sha512-sCMZhL9zy0fiFc4H0cKlXq7BcghMSxm5ZnEyaPWTteArU5ix6JjOKyOXSUBGLTQCmt5kuX9zEvQ9BSshHOPB3A==", 1747 | "dev": true, 1748 | "requires": { 1749 | "@jest/core": "^27.5.0", 1750 | "import-local": "^3.0.2", 1751 | "jest-cli": "^27.5.0" 1752 | }, 1753 | "dependencies": { 1754 | "jest-cli": { 1755 | "version": "27.5.0", 1756 | "resolved": "https://registry.npmjs.org/jest-cli/-/jest-cli-27.5.0.tgz", 1757 | "integrity": "sha512-9ANs79Goz1ULKtG7HDm/F//4E69v8EFOLXRIHmeC/eK1xTUeQGlU6XP0Zwst386sKaKB4O60qhWY/UaTBS2MLA==", 1758 | "dev": true, 1759 | "requires": { 1760 | "@jest/core": "^27.5.0", 1761 | "@jest/test-result": "^27.5.0", 1762 | "@jest/types": "^27.5.0", 1763 | "chalk": "^4.0.0", 1764 | "exit": "^0.1.2", 1765 | "graceful-fs": "^4.2.9", 1766 | "import-local": "^3.0.2", 1767 | "jest-config": "^27.5.0", 1768 | "jest-util": "^27.5.0", 1769 | "jest-validate": "^27.5.0", 1770 | "prompts": "^2.0.1", 1771 | "yargs": "^16.2.0" 1772 | } 1773 | } 1774 | } 1775 | }, 1776 | "jest-changed-files": { 1777 | "version": "27.5.0", 1778 | "resolved": "https://registry.npmjs.org/jest-changed-files/-/jest-changed-files-27.5.0.tgz", 1779 | "integrity": "sha512-BGWKI7E6ORqbF5usF1oA4ftbkhVZVrXr8jB0/BrU6TAn3kfOVwX2Zx6pKIXYutJ+qNEjT8Da/gGak0ajya/StA==", 1780 | "dev": true, 1781 | "requires": { 1782 | "@jest/types": "^27.5.0", 1783 | "execa": "^5.0.0", 1784 | "throat": "^6.0.1" 1785 | } 1786 | }, 1787 | "jest-circus": { 1788 | "version": "27.5.0", 1789 | "resolved": "https://registry.npmjs.org/jest-circus/-/jest-circus-27.5.0.tgz", 1790 | "integrity": "sha512-+NPd1OxpAHYKjbW8dgL0huFgmtZRKSUKee/UtRgZJEfAxCeA12d7sp0coh5EGDBpW4fCk1Pcia/2dG+j6BQvdw==", 1791 | "dev": true, 1792 | "requires": { 1793 | "@jest/environment": "^27.5.0", 1794 | "@jest/test-result": "^27.5.0", 1795 | "@jest/types": "^27.5.0", 1796 | "@types/node": "*", 1797 | "chalk": "^4.0.0", 1798 | "co": "^4.6.0", 1799 | "dedent": "^0.7.0", 1800 | "expect": "^27.5.0", 1801 | "is-generator-fn": "^2.0.0", 1802 | "jest-each": "^27.5.0", 1803 | "jest-matcher-utils": "^27.5.0", 1804 | "jest-message-util": "^27.5.0", 1805 | "jest-runtime": "^27.5.0", 1806 | "jest-snapshot": "^27.5.0", 1807 | "jest-util": "^27.5.0", 1808 | "pretty-format": "^27.5.0", 1809 | "slash": "^3.0.0", 1810 | "stack-utils": "^2.0.3", 1811 | "throat": "^6.0.1" 1812 | } 1813 | }, 1814 | "jest-config": { 1815 | "version": "27.5.0", 1816 | "resolved": "https://registry.npmjs.org/jest-config/-/jest-config-27.5.0.tgz", 1817 | "integrity": "sha512-eOIpvpXFz5WHuIYZN1QmvBLEjsSk3w+IAC/2jBpZClbprF53Bj9meBMgAbE15DSkaaJBDFmhXXd1L2eCLaWxQw==", 1818 | "dev": true, 1819 | "requires": { 1820 | "@babel/core": "^7.8.0", 1821 | "@jest/test-sequencer": "^27.5.0", 1822 | "@jest/types": "^27.5.0", 1823 | "babel-jest": "^27.5.0", 1824 | "chalk": "^4.0.0", 1825 | "ci-info": "^3.2.0", 1826 | "deepmerge": "^4.2.2", 1827 | "glob": "^7.1.1", 1828 | "graceful-fs": "^4.2.9", 1829 | "jest-circus": "^27.5.0", 1830 | "jest-environment-jsdom": "^27.5.0", 1831 | "jest-environment-node": "^27.5.0", 1832 | "jest-get-type": "^27.5.0", 1833 | "jest-jasmine2": "^27.5.0", 1834 | "jest-regex-util": "^27.5.0", 1835 | "jest-resolve": "^27.5.0", 1836 | "jest-runner": "^27.5.0", 1837 | "jest-util": "^27.5.0", 1838 | "jest-validate": "^27.5.0", 1839 | "micromatch": "^4.0.4", 1840 | "pretty-format": "^27.5.0", 1841 | "slash": "^3.0.0" 1842 | } 1843 | }, 1844 | "jest-diff": { 1845 | "version": "27.5.0", 1846 | "resolved": "https://registry.npmjs.org/jest-diff/-/jest-diff-27.5.0.tgz", 1847 | "integrity": "sha512-zztvHDCq/QcAVv+o6rts0reupSOxyrX+KLQEOMWCW2trZgcBFgp/oTK7hJCGpXvEIqKrQzyQlaPKn9W04+IMQg==", 1848 | "dev": true, 1849 | "requires": { 1850 | "chalk": "^4.0.0", 1851 | "diff-sequences": "^27.5.0", 1852 | "jest-get-type": "^27.5.0", 1853 | "pretty-format": "^27.5.0" 1854 | } 1855 | }, 1856 | "jest-docblock": { 1857 | "version": "27.5.0", 1858 | "resolved": "https://registry.npmjs.org/jest-docblock/-/jest-docblock-27.5.0.tgz", 1859 | "integrity": "sha512-U4MtJgdZn2x+jpPzd7NAYvDmgJAA5h9QxVAwsyuH7IymGzY8VGHhAkHcIGOmtmdC61ORLxCbEhj6fCJsaCWzXA==", 1860 | "dev": true, 1861 | "requires": { 1862 | "detect-newline": "^3.0.0" 1863 | } 1864 | }, 1865 | "jest-each": { 1866 | "version": "27.5.0", 1867 | "resolved": "https://registry.npmjs.org/jest-each/-/jest-each-27.5.0.tgz", 1868 | "integrity": "sha512-2vpajSdDMZmAxjSP1f4BG9KKduwHtuaI0w66oqLUkfaGUU7Ix/W+d8BW0h3/QEJiew7hR0GSblqdFwTEEbhBdw==", 1869 | "dev": true, 1870 | "requires": { 1871 | "@jest/types": "^27.5.0", 1872 | "chalk": "^4.0.0", 1873 | "jest-get-type": "^27.5.0", 1874 | "jest-util": "^27.5.0", 1875 | "pretty-format": "^27.5.0" 1876 | } 1877 | }, 1878 | "jest-environment-jsdom": { 1879 | "version": "27.5.0", 1880 | "resolved": "https://registry.npmjs.org/jest-environment-jsdom/-/jest-environment-jsdom-27.5.0.tgz", 1881 | "integrity": "sha512-sX49N8rjp6HSHeGpNgLk6mtHRd1IPAnE/u7wLQkb6Tz/1E08Q++Y8Zk/IbpVdcFywbzH1icFqEuDuHJ6o+uXXg==", 1882 | "dev": true, 1883 | "requires": { 1884 | "@jest/environment": "^27.5.0", 1885 | "@jest/fake-timers": "^27.5.0", 1886 | "@jest/types": "^27.5.0", 1887 | "@types/node": "*", 1888 | "jest-mock": "^27.5.0", 1889 | "jest-util": "^27.5.0", 1890 | "jsdom": "^16.6.0" 1891 | } 1892 | }, 1893 | "jest-environment-node": { 1894 | "version": "27.5.0", 1895 | "resolved": "https://registry.npmjs.org/jest-environment-node/-/jest-environment-node-27.5.0.tgz", 1896 | "integrity": "sha512-7UzisMMfGyrURhS/eUa7p7mgaqN3ajHylsjOgfcn0caNeYRZq4LHKZLfAxrPM34DWLnBZcRupEJlpQsizdSUsw==", 1897 | "dev": true, 1898 | "requires": { 1899 | "@jest/environment": "^27.5.0", 1900 | "@jest/fake-timers": "^27.5.0", 1901 | "@jest/types": "^27.5.0", 1902 | "@types/node": "*", 1903 | "jest-mock": "^27.5.0", 1904 | "jest-util": "^27.5.0" 1905 | } 1906 | }, 1907 | "jest-get-type": { 1908 | "version": "27.5.0", 1909 | "resolved": "https://registry.npmjs.org/jest-get-type/-/jest-get-type-27.5.0.tgz", 1910 | "integrity": "sha512-Vp6O8a52M/dahXRG/E0EJuWQROps2mDQ0sJYPgO8HskhdLwj9ajgngy2OAqZgV6e/RcU67WUHq6TgfvJb8flbA==", 1911 | "dev": true 1912 | }, 1913 | "jest-haste-map": { 1914 | "version": "27.5.0", 1915 | "resolved": "https://registry.npmjs.org/jest-haste-map/-/jest-haste-map-27.5.0.tgz", 1916 | "integrity": "sha512-0KfckSBEKV+D6e0toXmIj4zzp72EiBnvkC0L+xYxenkLhAdkp2/8tye4AgMzz7Fqb1r8SWtz7+s1UQLrxMBang==", 1917 | "dev": true, 1918 | "requires": { 1919 | "@jest/types": "^27.5.0", 1920 | "@types/graceful-fs": "^4.1.2", 1921 | "@types/node": "*", 1922 | "anymatch": "^3.0.3", 1923 | "fb-watchman": "^2.0.0", 1924 | "fsevents": "^2.3.2", 1925 | "graceful-fs": "^4.2.9", 1926 | "jest-regex-util": "^27.5.0", 1927 | "jest-serializer": "^27.5.0", 1928 | "jest-util": "^27.5.0", 1929 | "jest-worker": "^27.5.0", 1930 | "micromatch": "^4.0.4", 1931 | "walker": "^1.0.7" 1932 | } 1933 | }, 1934 | "jest-jasmine2": { 1935 | "version": "27.5.0", 1936 | "resolved": "https://registry.npmjs.org/jest-jasmine2/-/jest-jasmine2-27.5.0.tgz", 1937 | "integrity": "sha512-X7sT3HLNjjrBEepilxzPyNhNdyunaFBepo1L3T/fvYb9tb8Wb8qY576gwIa+SZcqYUqAA7/bT3EpZI4lAp0Qew==", 1938 | "dev": true, 1939 | "requires": { 1940 | "@jest/environment": "^27.5.0", 1941 | "@jest/source-map": "^27.5.0", 1942 | "@jest/test-result": "^27.5.0", 1943 | "@jest/types": "^27.5.0", 1944 | "@types/node": "*", 1945 | "chalk": "^4.0.0", 1946 | "co": "^4.6.0", 1947 | "expect": "^27.5.0", 1948 | "is-generator-fn": "^2.0.0", 1949 | "jest-each": "^27.5.0", 1950 | "jest-matcher-utils": "^27.5.0", 1951 | "jest-message-util": "^27.5.0", 1952 | "jest-runtime": "^27.5.0", 1953 | "jest-snapshot": "^27.5.0", 1954 | "jest-util": "^27.5.0", 1955 | "pretty-format": "^27.5.0", 1956 | "throat": "^6.0.1" 1957 | } 1958 | }, 1959 | "jest-leak-detector": { 1960 | "version": "27.5.0", 1961 | "resolved": "https://registry.npmjs.org/jest-leak-detector/-/jest-leak-detector-27.5.0.tgz", 1962 | "integrity": "sha512-Ak3k+DD3ao5d4/zzJrxAQ5UV5wiCrp47jH94ZD4/vXSzQgE6WBVDfg83VtculLILO7Y6/Q/7yzKSrtN9Na8luA==", 1963 | "dev": true, 1964 | "requires": { 1965 | "jest-get-type": "^27.5.0", 1966 | "pretty-format": "^27.5.0" 1967 | } 1968 | }, 1969 | "jest-matcher-utils": { 1970 | "version": "27.5.0", 1971 | "resolved": "https://registry.npmjs.org/jest-matcher-utils/-/jest-matcher-utils-27.5.0.tgz", 1972 | "integrity": "sha512-5ruyzWMGb1ilCWD6ECwNdOhQBeIXAjHmHd5c3uO6quR7RIMHPRP2ucOaejz2j+0R0Ko4GanWM6SqXAeF8nYN5g==", 1973 | "dev": true, 1974 | "requires": { 1975 | "chalk": "^4.0.0", 1976 | "jest-diff": "^27.5.0", 1977 | "jest-get-type": "^27.5.0", 1978 | "pretty-format": "^27.5.0" 1979 | } 1980 | }, 1981 | "jest-message-util": { 1982 | "version": "27.5.0", 1983 | "resolved": "https://registry.npmjs.org/jest-message-util/-/jest-message-util-27.5.0.tgz", 1984 | "integrity": "sha512-lfbWRhTtmZMEHPAtl0SrvNzK1F4UnVNMHOliRQT2BJ4sBFzIb0gBCHA4ebWD4o6l1fUyvDPxM01K9OIMQTAdQw==", 1985 | "dev": true, 1986 | "requires": { 1987 | "@babel/code-frame": "^7.12.13", 1988 | "@jest/types": "^27.5.0", 1989 | "@types/stack-utils": "^2.0.0", 1990 | "chalk": "^4.0.0", 1991 | "graceful-fs": "^4.2.9", 1992 | "micromatch": "^4.0.4", 1993 | "pretty-format": "^27.5.0", 1994 | "slash": "^3.0.0", 1995 | "stack-utils": "^2.0.3" 1996 | } 1997 | }, 1998 | "jest-mock": { 1999 | "version": "27.5.0", 2000 | "resolved": "https://registry.npmjs.org/jest-mock/-/jest-mock-27.5.0.tgz", 2001 | "integrity": "sha512-PHluG6MJGng82/sxh8OiB9fnxzNn3cazceSHCAmAKs4g5rMhc3EZCrJXv+4w61rA2WGagMUj7QLLrA1SRlFpzQ==", 2002 | "dev": true, 2003 | "requires": { 2004 | "@jest/types": "^27.5.0", 2005 | "@types/node": "*" 2006 | } 2007 | }, 2008 | "jest-pnp-resolver": { 2009 | "version": "1.2.2", 2010 | "resolved": "https://registry.npmjs.org/jest-pnp-resolver/-/jest-pnp-resolver-1.2.2.tgz", 2011 | "integrity": "sha512-olV41bKSMm8BdnuMsewT4jqlZ8+3TCARAXjZGT9jcoSnrfUnRCqnMoF9XEeoWjbzObpqF9dRhHQj0Xb9QdF6/w==", 2012 | "dev": true 2013 | }, 2014 | "jest-regex-util": { 2015 | "version": "27.5.0", 2016 | "resolved": "https://registry.npmjs.org/jest-regex-util/-/jest-regex-util-27.5.0.tgz", 2017 | "integrity": "sha512-e9LqSd6HsDsqd7KS3rNyYwmQAaG9jq4U3LbnwVxN/y3nNlDzm2OFs596uo9zrUY+AV1opXq6ome78tRDUCRWfA==", 2018 | "dev": true 2019 | }, 2020 | "jest-resolve": { 2021 | "version": "27.5.0", 2022 | "resolved": "https://registry.npmjs.org/jest-resolve/-/jest-resolve-27.5.0.tgz", 2023 | "integrity": "sha512-PkDpYEGV/nFqThnIrlPtj8oTxyAV3iuuS6or7dZYyUWaHr/tyyVb5qfBmZS6FEr7ozBHgjrF1bgcgIefnlicbw==", 2024 | "dev": true, 2025 | "requires": { 2026 | "@jest/types": "^27.5.0", 2027 | "chalk": "^4.0.0", 2028 | "graceful-fs": "^4.2.9", 2029 | "jest-haste-map": "^27.5.0", 2030 | "jest-pnp-resolver": "^1.2.2", 2031 | "jest-util": "^27.5.0", 2032 | "jest-validate": "^27.5.0", 2033 | "resolve": "^1.20.0", 2034 | "resolve.exports": "^1.1.0", 2035 | "slash": "^3.0.0" 2036 | } 2037 | }, 2038 | "jest-resolve-dependencies": { 2039 | "version": "27.5.0", 2040 | "resolved": "https://registry.npmjs.org/jest-resolve-dependencies/-/jest-resolve-dependencies-27.5.0.tgz", 2041 | "integrity": "sha512-xQsy7CmrT4CJxdNUEdzZU2M/v6YmtQ/pkJM+sx7TA1siG1zfsZuo78PZvzglwRMQFr88f3Su4Om8OEBAic+SMw==", 2042 | "dev": true, 2043 | "requires": { 2044 | "@jest/types": "^27.5.0", 2045 | "jest-regex-util": "^27.5.0", 2046 | "jest-snapshot": "^27.5.0" 2047 | } 2048 | }, 2049 | "jest-runner": { 2050 | "version": "27.5.0", 2051 | "resolved": "https://registry.npmjs.org/jest-runner/-/jest-runner-27.5.0.tgz", 2052 | "integrity": "sha512-RMzXhkJLLOKKgUPY2trpyVBijaFmswMtgoCCBk2PQVRHC6yo1vLd1/jmFP39s5OXXnt7rntuzKSYvxl+QUibqQ==", 2053 | "dev": true, 2054 | "requires": { 2055 | "@jest/console": "^27.5.0", 2056 | "@jest/environment": "^27.5.0", 2057 | "@jest/test-result": "^27.5.0", 2058 | "@jest/transform": "^27.5.0", 2059 | "@jest/types": "^27.5.0", 2060 | "@types/node": "*", 2061 | "chalk": "^4.0.0", 2062 | "emittery": "^0.8.1", 2063 | "graceful-fs": "^4.2.9", 2064 | "jest-docblock": "^27.5.0", 2065 | "jest-environment-jsdom": "^27.5.0", 2066 | "jest-environment-node": "^27.5.0", 2067 | "jest-haste-map": "^27.5.0", 2068 | "jest-leak-detector": "^27.5.0", 2069 | "jest-message-util": "^27.5.0", 2070 | "jest-resolve": "^27.5.0", 2071 | "jest-runtime": "^27.5.0", 2072 | "jest-util": "^27.5.0", 2073 | "jest-worker": "^27.5.0", 2074 | "source-map-support": "^0.5.6", 2075 | "throat": "^6.0.1" 2076 | } 2077 | }, 2078 | "jest-runtime": { 2079 | "version": "27.5.0", 2080 | "resolved": "https://registry.npmjs.org/jest-runtime/-/jest-runtime-27.5.0.tgz", 2081 | "integrity": "sha512-T7APxCPjN3p3ePcLuypbWtD0UZHyAdvIADZ9ABI/sFZ9t/Rf2xIUd6D7RzZIX+unewJRooVGWrgDIgeUuj0OUA==", 2082 | "dev": true, 2083 | "requires": { 2084 | "@jest/environment": "^27.5.0", 2085 | "@jest/fake-timers": "^27.5.0", 2086 | "@jest/globals": "^27.5.0", 2087 | "@jest/source-map": "^27.5.0", 2088 | "@jest/test-result": "^27.5.0", 2089 | "@jest/transform": "^27.5.0", 2090 | "@jest/types": "^27.5.0", 2091 | "chalk": "^4.0.0", 2092 | "cjs-module-lexer": "^1.0.0", 2093 | "collect-v8-coverage": "^1.0.0", 2094 | "execa": "^5.0.0", 2095 | "glob": "^7.1.3", 2096 | "graceful-fs": "^4.2.9", 2097 | "jest-haste-map": "^27.5.0", 2098 | "jest-message-util": "^27.5.0", 2099 | "jest-mock": "^27.5.0", 2100 | "jest-regex-util": "^27.5.0", 2101 | "jest-resolve": "^27.5.0", 2102 | "jest-snapshot": "^27.5.0", 2103 | "jest-util": "^27.5.0", 2104 | "slash": "^3.0.0", 2105 | "strip-bom": "^4.0.0" 2106 | } 2107 | }, 2108 | "jest-serializer": { 2109 | "version": "27.5.0", 2110 | "resolved": "https://registry.npmjs.org/jest-serializer/-/jest-serializer-27.5.0.tgz", 2111 | "integrity": "sha512-aSDFqQlVXtBH+Zb5dl9mCvTSFkabixk/9P9cpngL4yJKpmEi9USxfDhONFMzJrtftPvZw3PcltUVmtFZTB93rg==", 2112 | "dev": true, 2113 | "requires": { 2114 | "@types/node": "*", 2115 | "graceful-fs": "^4.2.9" 2116 | } 2117 | }, 2118 | "jest-snapshot": { 2119 | "version": "27.5.0", 2120 | "resolved": "https://registry.npmjs.org/jest-snapshot/-/jest-snapshot-27.5.0.tgz", 2121 | "integrity": "sha512-cAJj15uqWGkro0bfcv/EgusBnqNgCpRruFQZghsMYTq4Fm2lk/VhAf8DgRr8wvhR6Ue1hkeL8tn70Cw4t8x/5A==", 2122 | "dev": true, 2123 | "requires": { 2124 | "@babel/core": "^7.7.2", 2125 | "@babel/generator": "^7.7.2", 2126 | "@babel/plugin-syntax-typescript": "^7.7.2", 2127 | "@babel/traverse": "^7.7.2", 2128 | "@babel/types": "^7.0.0", 2129 | "@jest/transform": "^27.5.0", 2130 | "@jest/types": "^27.5.0", 2131 | "@types/babel__traverse": "^7.0.4", 2132 | "@types/prettier": "^2.1.5", 2133 | "babel-preset-current-node-syntax": "^1.0.0", 2134 | "chalk": "^4.0.0", 2135 | "expect": "^27.5.0", 2136 | "graceful-fs": "^4.2.9", 2137 | "jest-diff": "^27.5.0", 2138 | "jest-get-type": "^27.5.0", 2139 | "jest-haste-map": "^27.5.0", 2140 | "jest-matcher-utils": "^27.5.0", 2141 | "jest-message-util": "^27.5.0", 2142 | "jest-util": "^27.5.0", 2143 | "natural-compare": "^1.4.0", 2144 | "pretty-format": "^27.5.0", 2145 | "semver": "^7.3.2" 2146 | }, 2147 | "dependencies": { 2148 | "semver": { 2149 | "version": "7.3.5", 2150 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.5.tgz", 2151 | "integrity": "sha512-PoeGJYh8HK4BTO/a9Tf6ZG3veo/A7ZVsYrSA6J8ny9nb3B1VrpkuN+z9OE5wfE5p6H4LchYZsegiQgbJD94ZFQ==", 2152 | "dev": true, 2153 | "requires": { 2154 | "lru-cache": "^6.0.0" 2155 | } 2156 | } 2157 | } 2158 | }, 2159 | "jest-util": { 2160 | "version": "27.5.0", 2161 | "resolved": "https://registry.npmjs.org/jest-util/-/jest-util-27.5.0.tgz", 2162 | "integrity": "sha512-FUUqOx0gAzJy3ytatT1Ss372M1kmhczn8x7aE0++11oPGW1FyD/5NjYBI8w1KOXFm6IVjtaZm2szfJJL+CHs0g==", 2163 | "dev": true, 2164 | "requires": { 2165 | "@jest/types": "^27.5.0", 2166 | "@types/node": "*", 2167 | "chalk": "^4.0.0", 2168 | "ci-info": "^3.2.0", 2169 | "graceful-fs": "^4.2.9", 2170 | "picomatch": "^2.2.3" 2171 | } 2172 | }, 2173 | "jest-validate": { 2174 | "version": "27.5.0", 2175 | "resolved": "https://registry.npmjs.org/jest-validate/-/jest-validate-27.5.0.tgz", 2176 | "integrity": "sha512-2XZzQWNrY9Ypo11mm4ZeVjvr++CQG/45XnmA2aWwx155lTwy1JGFI8LpQ2dBCSAeO21ooqg/FCIvv9WwfnPClA==", 2177 | "dev": true, 2178 | "requires": { 2179 | "@jest/types": "^27.5.0", 2180 | "camelcase": "^6.2.0", 2181 | "chalk": "^4.0.0", 2182 | "jest-get-type": "^27.5.0", 2183 | "leven": "^3.1.0", 2184 | "pretty-format": "^27.5.0" 2185 | }, 2186 | "dependencies": { 2187 | "camelcase": { 2188 | "version": "6.3.0", 2189 | "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-6.3.0.tgz", 2190 | "integrity": "sha512-Gmy6FhYlCY7uOElZUSbxo2UCDH8owEk996gkbrpsgGtrJLM3J7jGxl9Ic7Qwwj4ivOE5AWZWRMecDdF7hqGjFA==", 2191 | "dev": true 2192 | } 2193 | } 2194 | }, 2195 | "jest-watcher": { 2196 | "version": "27.5.0", 2197 | "resolved": "https://registry.npmjs.org/jest-watcher/-/jest-watcher-27.5.0.tgz", 2198 | "integrity": "sha512-MhIeIvEd6dnnspE0OfYrqHOAfZZdyFqx/k8U2nvVFSkLYf22qAFfyNWPVQYcwqKVNobcOhJoT0kV/nRHGbqK8A==", 2199 | "dev": true, 2200 | "requires": { 2201 | "@jest/test-result": "^27.5.0", 2202 | "@jest/types": "^27.5.0", 2203 | "@types/node": "*", 2204 | "ansi-escapes": "^4.2.1", 2205 | "chalk": "^4.0.0", 2206 | "jest-util": "^27.5.0", 2207 | "string-length": "^4.0.1" 2208 | } 2209 | }, 2210 | "jest-worker": { 2211 | "version": "27.5.0", 2212 | "resolved": "https://registry.npmjs.org/jest-worker/-/jest-worker-27.5.0.tgz", 2213 | "integrity": "sha512-8OEHiPNOPTfaWnJ2SUHM8fmgeGq37uuGsQBvGKQJl1f+6WIy6g7G3fE2ruI5294bUKUI9FaCWt5hDvO8HSwsSg==", 2214 | "dev": true, 2215 | "requires": { 2216 | "@types/node": "*", 2217 | "merge-stream": "^2.0.0", 2218 | "supports-color": "^8.0.0" 2219 | }, 2220 | "dependencies": { 2221 | "supports-color": { 2222 | "version": "8.1.1", 2223 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-8.1.1.tgz", 2224 | "integrity": "sha512-MpUEN2OodtUzxvKQl72cUF7RQ5EiHsGvSsVG0ia9c5RbWGL2CI4C7EpPS8UTBIplnlzZiNuV56w+FuNxy3ty2Q==", 2225 | "dev": true, 2226 | "requires": { 2227 | "has-flag": "^4.0.0" 2228 | } 2229 | } 2230 | } 2231 | }, 2232 | "js-tokens": { 2233 | "version": "4.0.0", 2234 | "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", 2235 | "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==", 2236 | "dev": true 2237 | }, 2238 | "js-yaml": { 2239 | "version": "3.14.1", 2240 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.14.1.tgz", 2241 | "integrity": "sha512-okMH7OXXJ7YrN9Ok3/SXrnu4iX9yOk+25nqX4imS2npuvTYDmo/QEZoqwZkYaIDk3jVvBOTOIEgEhaLOynBS9g==", 2242 | "dev": true, 2243 | "requires": { 2244 | "argparse": "^1.0.7", 2245 | "esprima": "^4.0.0" 2246 | } 2247 | }, 2248 | "jsdom": { 2249 | "version": "16.7.0", 2250 | "resolved": "https://registry.npmjs.org/jsdom/-/jsdom-16.7.0.tgz", 2251 | "integrity": "sha512-u9Smc2G1USStM+s/x1ru5Sxrl6mPYCbByG1U/hUmqaVsm4tbNyS7CicOSRyuGQYZhTu0h84qkZZQ/I+dzizSVw==", 2252 | "dev": true, 2253 | "requires": { 2254 | "abab": "^2.0.5", 2255 | "acorn": "^8.2.4", 2256 | "acorn-globals": "^6.0.0", 2257 | "cssom": "^0.4.4", 2258 | "cssstyle": "^2.3.0", 2259 | "data-urls": "^2.0.0", 2260 | "decimal.js": "^10.2.1", 2261 | "domexception": "^2.0.1", 2262 | "escodegen": "^2.0.0", 2263 | "form-data": "^3.0.0", 2264 | "html-encoding-sniffer": "^2.0.1", 2265 | "http-proxy-agent": "^4.0.1", 2266 | "https-proxy-agent": "^5.0.0", 2267 | "is-potential-custom-element-name": "^1.0.1", 2268 | "nwsapi": "^2.2.0", 2269 | "parse5": "6.0.1", 2270 | "saxes": "^5.0.1", 2271 | "symbol-tree": "^3.2.4", 2272 | "tough-cookie": "^4.0.0", 2273 | "w3c-hr-time": "^1.0.2", 2274 | "w3c-xmlserializer": "^2.0.0", 2275 | "webidl-conversions": "^6.1.0", 2276 | "whatwg-encoding": "^1.0.5", 2277 | "whatwg-mimetype": "^2.3.0", 2278 | "whatwg-url": "^8.5.0", 2279 | "ws": "^7.4.6", 2280 | "xml-name-validator": "^3.0.0" 2281 | } 2282 | }, 2283 | "jsesc": { 2284 | "version": "2.5.2", 2285 | "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-2.5.2.tgz", 2286 | "integrity": "sha512-OYu7XEzjkCQ3C5Ps3QIZsQfNpqoJyZZA99wd9aWd05NCtC5pWOkShK2mkL6HXQR6/Cy2lbNdPlZBpuQHXE63gA==", 2287 | "dev": true 2288 | }, 2289 | "json5": { 2290 | "version": "2.1.3", 2291 | "resolved": "https://registry.npmjs.org/json5/-/json5-2.1.3.tgz", 2292 | "integrity": "sha512-KXPvOm8K9IJKFM0bmdn8QXh7udDh1g/giieX0NLCaMnb4hEiVFqnop2ImTXCc5e0/oHz3LTqmHGtExn5hfMkOA==", 2293 | "dev": true, 2294 | "requires": { 2295 | "minimist": "^1.2.5" 2296 | } 2297 | }, 2298 | "kleur": { 2299 | "version": "3.0.3", 2300 | "resolved": "https://registry.npmjs.org/kleur/-/kleur-3.0.3.tgz", 2301 | "integrity": "sha512-eTIzlVOSUR+JxdDFepEYcBMtZ9Qqdef+rnzWdRZuMbOywu5tO2w2N7rqjoANZ5k9vywhL6Br1VRjUIgTQx4E8w==", 2302 | "dev": true 2303 | }, 2304 | "leven": { 2305 | "version": "3.1.0", 2306 | "resolved": "https://registry.npmjs.org/leven/-/leven-3.1.0.tgz", 2307 | "integrity": "sha512-qsda+H8jTaUaN/x5vzW2rzc+8Rw4TAQ/4KjB46IwK5VH+IlVeeeje/EoZRpiXvIqjFgK84QffqPztGI3VBLG1A==", 2308 | "dev": true 2309 | }, 2310 | "levn": { 2311 | "version": "0.3.0", 2312 | "resolved": "https://registry.npmjs.org/levn/-/levn-0.3.0.tgz", 2313 | "integrity": "sha1-OwmSTt+fCDwEkP3UwLxEIeBHZO4=", 2314 | "dev": true, 2315 | "requires": { 2316 | "prelude-ls": "~1.1.2", 2317 | "type-check": "~0.3.2" 2318 | } 2319 | }, 2320 | "locate-path": { 2321 | "version": "5.0.0", 2322 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-5.0.0.tgz", 2323 | "integrity": "sha512-t7hw9pI+WvuwNJXwk5zVHpyhIqzg2qTlklJOf0mVxGSbe3Fp2VieZcduNYjaLDoy6p9uGpQEGWG87WpMKlNq8g==", 2324 | "dev": true, 2325 | "requires": { 2326 | "p-locate": "^4.1.0" 2327 | } 2328 | }, 2329 | "lodash": { 2330 | "version": "4.17.21", 2331 | "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.21.tgz", 2332 | "integrity": "sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg==", 2333 | "dev": true 2334 | }, 2335 | "lodash.memoize": { 2336 | "version": "4.1.2", 2337 | "resolved": "https://registry.npmjs.org/lodash.memoize/-/lodash.memoize-4.1.2.tgz", 2338 | "integrity": "sha1-vMbEmkKihA7Zl/Mj6tpezRguC/4=", 2339 | "dev": true 2340 | }, 2341 | "lru-cache": { 2342 | "version": "6.0.0", 2343 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", 2344 | "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", 2345 | "dev": true, 2346 | "requires": { 2347 | "yallist": "^4.0.0" 2348 | } 2349 | }, 2350 | "make-dir": { 2351 | "version": "3.1.0", 2352 | "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-3.1.0.tgz", 2353 | "integrity": "sha512-g3FeP20LNwhALb/6Cz6Dd4F2ngze0jz7tbzrD2wAV+o9FeNHe4rL+yK2md0J/fiSf1sa1ADhXqi5+oVwOM/eGw==", 2354 | "dev": true, 2355 | "requires": { 2356 | "semver": "^6.0.0" 2357 | } 2358 | }, 2359 | "make-error": { 2360 | "version": "1.3.6", 2361 | "resolved": "https://registry.npmjs.org/make-error/-/make-error-1.3.6.tgz", 2362 | "integrity": "sha512-s8UhlNe7vPKomQhC1qFelMokr/Sc3AgNbso3n74mVPA5LTZwkB9NlXf4XPamLxJE8h0gh73rM94xvwRT2CVInw==", 2363 | "dev": true 2364 | }, 2365 | "makeerror": { 2366 | "version": "1.0.12", 2367 | "resolved": "https://registry.npmjs.org/makeerror/-/makeerror-1.0.12.tgz", 2368 | "integrity": "sha512-JmqCvUhmt43madlpFzG4BQzG2Z3m6tvQDNKdClZnO3VbIudJYmxsT0FNJMeiB2+JTSlTQTSbU8QdesVmwJcmLg==", 2369 | "dev": true, 2370 | "requires": { 2371 | "tmpl": "1.0.5" 2372 | } 2373 | }, 2374 | "merge-stream": { 2375 | "version": "2.0.0", 2376 | "resolved": "https://registry.npmjs.org/merge-stream/-/merge-stream-2.0.0.tgz", 2377 | "integrity": "sha512-abv/qOcuPfk3URPfDzmZU1LKmuw8kT+0nIHvKrKgFrwifol/doWcdA4ZqsWQ8ENrFKkd67Mfpo/LovbIUsbt3w==", 2378 | "dev": true 2379 | }, 2380 | "micromatch": { 2381 | "version": "4.0.4", 2382 | "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-4.0.4.tgz", 2383 | "integrity": "sha512-pRmzw/XUcwXGpD9aI9q/0XOwLNygjETJ8y0ao0wdqprrzDa4YnxLcz7fQRZr8voh8V10kGhABbNcHVk5wHgWwg==", 2384 | "dev": true, 2385 | "requires": { 2386 | "braces": "^3.0.1", 2387 | "picomatch": "^2.2.3" 2388 | } 2389 | }, 2390 | "mime-db": { 2391 | "version": "1.51.0", 2392 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.51.0.tgz", 2393 | "integrity": "sha512-5y8A56jg7XVQx2mbv1lu49NR4dokRnhZYTtL+KGfaa27uq4pSTXkwQkFJl4pkRMyNFz/EtYDSkiiEHx3F7UN6g==", 2394 | "dev": true 2395 | }, 2396 | "mime-types": { 2397 | "version": "2.1.34", 2398 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.34.tgz", 2399 | "integrity": "sha512-6cP692WwGIs9XXdOO4++N+7qjqv0rqxxVvJ3VHPh/Sc9mVZcQP+ZGhkKiTvWMQRr2tbHkJP/Yn7Y0npb3ZBs4A==", 2400 | "dev": true, 2401 | "requires": { 2402 | "mime-db": "1.51.0" 2403 | } 2404 | }, 2405 | "mimic-fn": { 2406 | "version": "2.1.0", 2407 | "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-2.1.0.tgz", 2408 | "integrity": "sha512-OqbOk5oEQeAZ8WXWydlu9HJjz9WVdEIvamMCcXmuqUYjTknH/sqsWvhQ3vgwKFRR1HpjvNBKQ37nbJgYzGqGcg==", 2409 | "dev": true 2410 | }, 2411 | "minimatch": { 2412 | "version": "3.0.4", 2413 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", 2414 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 2415 | "dev": true, 2416 | "requires": { 2417 | "brace-expansion": "^1.1.7" 2418 | } 2419 | }, 2420 | "minimist": { 2421 | "version": "1.2.5", 2422 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.5.tgz", 2423 | "integrity": "sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw==", 2424 | "dev": true 2425 | }, 2426 | "ms": { 2427 | "version": "2.1.2", 2428 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 2429 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 2430 | "dev": true 2431 | }, 2432 | "natural-compare": { 2433 | "version": "1.4.0", 2434 | "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", 2435 | "integrity": "sha1-Sr6/7tdUHywnrPspvbvRXI1bpPc=", 2436 | "dev": true 2437 | }, 2438 | "node-int64": { 2439 | "version": "0.4.0", 2440 | "resolved": "https://registry.npmjs.org/node-int64/-/node-int64-0.4.0.tgz", 2441 | "integrity": "sha1-h6kGXNs1XTGC2PlM4RGIuCXGijs=", 2442 | "dev": true 2443 | }, 2444 | "node-releases": { 2445 | "version": "2.0.1", 2446 | "resolved": "https://registry.npmjs.org/node-releases/-/node-releases-2.0.1.tgz", 2447 | "integrity": "sha512-CqyzN6z7Q6aMeF/ktcMVTzhAHCEpf8SOarwpzpf8pNBY2k5/oM34UHldUwp8VKI7uxct2HxSRdJjBaZeESzcxA==", 2448 | "dev": true 2449 | }, 2450 | "normalize-path": { 2451 | "version": "3.0.0", 2452 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", 2453 | "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", 2454 | "dev": true 2455 | }, 2456 | "npm-run-path": { 2457 | "version": "4.0.1", 2458 | "resolved": "https://registry.npmjs.org/npm-run-path/-/npm-run-path-4.0.1.tgz", 2459 | "integrity": "sha512-S48WzZW777zhNIrn7gxOlISNAqi9ZC/uQFnRdbeIHhZhCA6UqpkOT8T1G7BvfdgP4Er8gF4sUbaS0i7QvIfCWw==", 2460 | "dev": true, 2461 | "requires": { 2462 | "path-key": "^3.0.0" 2463 | } 2464 | }, 2465 | "nwsapi": { 2466 | "version": "2.2.0", 2467 | "resolved": "https://registry.npmjs.org/nwsapi/-/nwsapi-2.2.0.tgz", 2468 | "integrity": "sha512-h2AatdwYH+JHiZpv7pt/gSX1XoRGb7L/qSIeuqA6GwYoF9w1vP1cw42TO0aI2pNyshRK5893hNSl+1//vHK7hQ==", 2469 | "dev": true 2470 | }, 2471 | "once": { 2472 | "version": "1.4.0", 2473 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 2474 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 2475 | "dev": true, 2476 | "requires": { 2477 | "wrappy": "1" 2478 | } 2479 | }, 2480 | "onetime": { 2481 | "version": "5.1.2", 2482 | "resolved": "https://registry.npmjs.org/onetime/-/onetime-5.1.2.tgz", 2483 | "integrity": "sha512-kbpaSSGJTWdAY5KPVeMOKXSrPtr8C8C7wodJbcsd51jRnmD+GZu8Y0VoU6Dm5Z4vWr0Ig/1NKuWRKf7j5aaYSg==", 2484 | "dev": true, 2485 | "requires": { 2486 | "mimic-fn": "^2.1.0" 2487 | } 2488 | }, 2489 | "optionator": { 2490 | "version": "0.8.3", 2491 | "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.8.3.tgz", 2492 | "integrity": "sha512-+IW9pACdk3XWmmTXG8m3upGUJst5XRGzxMRjXzAuJ1XnIFNvfhjjIuYkDvysnPQ7qzqVzLt78BCruntqRhWQbA==", 2493 | "dev": true, 2494 | "requires": { 2495 | "deep-is": "~0.1.3", 2496 | "fast-levenshtein": "~2.0.6", 2497 | "levn": "~0.3.0", 2498 | "prelude-ls": "~1.1.2", 2499 | "type-check": "~0.3.2", 2500 | "word-wrap": "~1.2.3" 2501 | } 2502 | }, 2503 | "p-limit": { 2504 | "version": "2.3.0", 2505 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-2.3.0.tgz", 2506 | "integrity": "sha512-//88mFWSJx8lxCzwdAABTJL2MyWB12+eIY7MDL2SqLmAkeKU9qxRvWuSyTjm3FUmpBEMuFfckAIqEaVGUDxb6w==", 2507 | "dev": true, 2508 | "requires": { 2509 | "p-try": "^2.0.0" 2510 | } 2511 | }, 2512 | "p-locate": { 2513 | "version": "4.1.0", 2514 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-4.1.0.tgz", 2515 | "integrity": "sha512-R79ZZ/0wAxKGu3oYMlz8jy/kbhsNrS7SKZ7PxEHBgJ5+F2mtFW2fK2cOtBh1cHYkQsbzFV7I+EoRKe6Yt0oK7A==", 2516 | "dev": true, 2517 | "requires": { 2518 | "p-limit": "^2.2.0" 2519 | } 2520 | }, 2521 | "p-try": { 2522 | "version": "2.2.0", 2523 | "resolved": "https://registry.npmjs.org/p-try/-/p-try-2.2.0.tgz", 2524 | "integrity": "sha512-R4nPAVTAU0B9D35/Gk3uJf/7XYbQcyohSKdvAxIRSNghFl4e71hVoGnBNQz9cWaXxO2I10KTC+3jMdvvoKw6dQ==", 2525 | "dev": true 2526 | }, 2527 | "parse5": { 2528 | "version": "6.0.1", 2529 | "resolved": "https://registry.npmjs.org/parse5/-/parse5-6.0.1.tgz", 2530 | "integrity": "sha512-Ofn/CTFzRGTTxwpNEs9PP93gXShHcTq255nzRYSKe8AkVpZY7e1fpmTfOyoIvjP5HG7Z2ZM7VS9PPhQGW2pOpw==", 2531 | "dev": true 2532 | }, 2533 | "path-exists": { 2534 | "version": "4.0.0", 2535 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz", 2536 | "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==", 2537 | "dev": true 2538 | }, 2539 | "path-is-absolute": { 2540 | "version": "1.0.1", 2541 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 2542 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=", 2543 | "dev": true 2544 | }, 2545 | "path-key": { 2546 | "version": "3.1.1", 2547 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", 2548 | "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", 2549 | "dev": true 2550 | }, 2551 | "path-parse": { 2552 | "version": "1.0.7", 2553 | "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.7.tgz", 2554 | "integrity": "sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==", 2555 | "dev": true 2556 | }, 2557 | "picocolors": { 2558 | "version": "1.0.0", 2559 | "resolved": "https://registry.npmjs.org/picocolors/-/picocolors-1.0.0.tgz", 2560 | "integrity": "sha512-1fygroTLlHu66zi26VoTDv8yRgm0Fccecssto+MhsZ0D/DGW2sm8E8AjW7NU5VVTRt5GxbeZ5qBuJr+HyLYkjQ==", 2561 | "dev": true 2562 | }, 2563 | "picomatch": { 2564 | "version": "2.3.1", 2565 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz", 2566 | "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==", 2567 | "dev": true 2568 | }, 2569 | "pirates": { 2570 | "version": "4.0.5", 2571 | "resolved": "https://registry.npmjs.org/pirates/-/pirates-4.0.5.tgz", 2572 | "integrity": "sha512-8V9+HQPupnaXMA23c5hvl69zXvTwTzyAYasnkb0Tts4XvO4CliqONMOnvlq26rkhLC3nWDFBJf73LU1e1VZLaQ==", 2573 | "dev": true 2574 | }, 2575 | "pkg-dir": { 2576 | "version": "4.2.0", 2577 | "resolved": "https://registry.npmjs.org/pkg-dir/-/pkg-dir-4.2.0.tgz", 2578 | "integrity": "sha512-HRDzbaKjC+AOWVXxAU/x54COGeIv9eb+6CkDSQoNTt4XyWoIJvuPsXizxu/Fr23EiekbtZwmh1IcIG/l/a10GQ==", 2579 | "dev": true, 2580 | "requires": { 2581 | "find-up": "^4.0.0" 2582 | } 2583 | }, 2584 | "prelude-ls": { 2585 | "version": "1.1.2", 2586 | "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.1.2.tgz", 2587 | "integrity": "sha1-IZMqVJ9eUv/ZqCf1cOBL5iqX2lQ=", 2588 | "dev": true 2589 | }, 2590 | "pretty-format": { 2591 | "version": "27.5.0", 2592 | "resolved": "https://registry.npmjs.org/pretty-format/-/pretty-format-27.5.0.tgz", 2593 | "integrity": "sha512-xEi6BRPZ+J1AIS4BAtFC/+rh5jXlXObGZjx5+OSpM95vR/PGla78bFVHMy5GdZjP9wk3AHAMHROXq/r69zXltw==", 2594 | "dev": true, 2595 | "requires": { 2596 | "ansi-regex": "^5.0.1", 2597 | "ansi-styles": "^5.0.0", 2598 | "react-is": "^17.0.1" 2599 | }, 2600 | "dependencies": { 2601 | "ansi-styles": { 2602 | "version": "5.2.0", 2603 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-5.2.0.tgz", 2604 | "integrity": "sha512-Cxwpt2SfTzTtXcfOlzGEee8O+c+MmUgGrNiBcXnuWxuFJHe6a5Hz7qwhwe5OgaSYI0IJvkLqWX1ASG+cJOkEiA==", 2605 | "dev": true 2606 | } 2607 | } 2608 | }, 2609 | "prompts": { 2610 | "version": "2.4.2", 2611 | "resolved": "https://registry.npmjs.org/prompts/-/prompts-2.4.2.tgz", 2612 | "integrity": "sha512-NxNv/kLguCA7p3jE8oL2aEBsrJWgAakBpgmgK6lpPWV+WuOmY6r2/zbAVnP+T8bQlA0nzHXSJSJW0Hq7ylaD2Q==", 2613 | "dev": true, 2614 | "requires": { 2615 | "kleur": "^3.0.3", 2616 | "sisteransi": "^1.0.5" 2617 | } 2618 | }, 2619 | "psl": { 2620 | "version": "1.8.0", 2621 | "resolved": "https://registry.npmjs.org/psl/-/psl-1.8.0.tgz", 2622 | "integrity": "sha512-RIdOzyoavK+hA18OGGWDqUTsCLhtA7IcZ/6NCs4fFJaHBDab+pDDmDIByWFRQJq2Cd7r1OoQxBGKOaztq+hjIQ==", 2623 | "dev": true 2624 | }, 2625 | "punycode": { 2626 | "version": "2.1.1", 2627 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.1.1.tgz", 2628 | "integrity": "sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A==", 2629 | "dev": true 2630 | }, 2631 | "react-is": { 2632 | "version": "17.0.2", 2633 | "resolved": "https://registry.npmjs.org/react-is/-/react-is-17.0.2.tgz", 2634 | "integrity": "sha512-w2GsyukL62IJnlaff/nRegPQR94C/XXamvMWmSHRJ4y7Ts/4ocGRmTHvOs8PSE6pB3dWOrD/nueuU5sduBsQ4w==", 2635 | "dev": true 2636 | }, 2637 | "require-directory": { 2638 | "version": "2.1.1", 2639 | "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz", 2640 | "integrity": "sha1-jGStX9MNqxyXbiNE/+f3kqam30I=", 2641 | "dev": true 2642 | }, 2643 | "resolve": { 2644 | "version": "1.22.0", 2645 | "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.22.0.tgz", 2646 | "integrity": "sha512-Hhtrw0nLeSrFQ7phPp4OOcVjLPIeMnRlr5mcnVuMe7M/7eBn98A3hmFRLoFo3DLZkivSYwhRUJTyPyWAk56WLw==", 2647 | "dev": true, 2648 | "requires": { 2649 | "is-core-module": "^2.8.1", 2650 | "path-parse": "^1.0.7", 2651 | "supports-preserve-symlinks-flag": "^1.0.0" 2652 | } 2653 | }, 2654 | "resolve-cwd": { 2655 | "version": "3.0.0", 2656 | "resolved": "https://registry.npmjs.org/resolve-cwd/-/resolve-cwd-3.0.0.tgz", 2657 | "integrity": "sha512-OrZaX2Mb+rJCpH/6CpSqt9xFVpN++x01XnN2ie9g6P5/3xelLAkXWVADpdz1IHD/KFfEXyE6V0U01OQ3UO2rEg==", 2658 | "dev": true, 2659 | "requires": { 2660 | "resolve-from": "^5.0.0" 2661 | } 2662 | }, 2663 | "resolve-from": { 2664 | "version": "5.0.0", 2665 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-5.0.0.tgz", 2666 | "integrity": "sha512-qYg9KP24dD5qka9J47d0aVky0N+b4fTU89LN9iDnjB5waksiC49rvMB0PrUJQGoTmH50XPiqOvAjDfaijGxYZw==", 2667 | "dev": true 2668 | }, 2669 | "resolve.exports": { 2670 | "version": "1.1.0", 2671 | "resolved": "https://registry.npmjs.org/resolve.exports/-/resolve.exports-1.1.0.tgz", 2672 | "integrity": "sha512-J1l+Zxxp4XK3LUDZ9m60LRJF/mAe4z6a4xyabPHk7pvK5t35dACV32iIjJDFeWZFfZlO29w6SZ67knR0tHzJtQ==", 2673 | "dev": true 2674 | }, 2675 | "rimraf": { 2676 | "version": "3.0.2", 2677 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz", 2678 | "integrity": "sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA==", 2679 | "dev": true, 2680 | "requires": { 2681 | "glob": "^7.1.3" 2682 | } 2683 | }, 2684 | "rxjs": { 2685 | "version": "7.5.2", 2686 | "resolved": "https://registry.npmjs.org/rxjs/-/rxjs-7.5.2.tgz", 2687 | "integrity": "sha512-PwDt186XaL3QN5qXj/H9DGyHhP3/RYYgZZwqBv9Tv8rsAaiwFH1IsJJlcgD37J7UW5a6O67qX0KWKS3/pu0m4w==", 2688 | "dev": true, 2689 | "requires": { 2690 | "tslib": "^2.1.0" 2691 | } 2692 | }, 2693 | "safe-buffer": { 2694 | "version": "5.1.2", 2695 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 2696 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==", 2697 | "dev": true 2698 | }, 2699 | "safer-buffer": { 2700 | "version": "2.1.2", 2701 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", 2702 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==", 2703 | "dev": true 2704 | }, 2705 | "saxes": { 2706 | "version": "5.0.1", 2707 | "resolved": "https://registry.npmjs.org/saxes/-/saxes-5.0.1.tgz", 2708 | "integrity": "sha512-5LBh1Tls8c9xgGjw3QrMwETmTMVk0oFgvrFSvWx62llR2hcEInrKNZ2GZCCuuy2lvWrdl5jhbpeqc5hRYKFOcw==", 2709 | "dev": true, 2710 | "requires": { 2711 | "xmlchars": "^2.2.0" 2712 | } 2713 | }, 2714 | "semver": { 2715 | "version": "6.3.0", 2716 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", 2717 | "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==", 2718 | "dev": true 2719 | }, 2720 | "shebang-command": { 2721 | "version": "2.0.0", 2722 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", 2723 | "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", 2724 | "dev": true, 2725 | "requires": { 2726 | "shebang-regex": "^3.0.0" 2727 | } 2728 | }, 2729 | "shebang-regex": { 2730 | "version": "3.0.0", 2731 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", 2732 | "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", 2733 | "dev": true 2734 | }, 2735 | "signal-exit": { 2736 | "version": "3.0.7", 2737 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.7.tgz", 2738 | "integrity": "sha512-wnD2ZE+l+SPC/uoS0vXeE9L1+0wuaMqKlfz9AMUo38JsyLSBWSFcHR1Rri62LZc12vLr1gb3jl7iwQhgwpAbGQ==", 2739 | "dev": true 2740 | }, 2741 | "sisteransi": { 2742 | "version": "1.0.5", 2743 | "resolved": "https://registry.npmjs.org/sisteransi/-/sisteransi-1.0.5.tgz", 2744 | "integrity": "sha512-bLGGlR1QxBcynn2d5YmDX4MGjlZvy2MRBDRNHLJ8VI6l6+9FUiyTFNJ0IveOSP0bcXgVDPRcfGqA0pjaqUpfVg==", 2745 | "dev": true 2746 | }, 2747 | "slash": { 2748 | "version": "3.0.0", 2749 | "resolved": "https://registry.npmjs.org/slash/-/slash-3.0.0.tgz", 2750 | "integrity": "sha512-g9Q1haeby36OSStwb4ntCGGGaKsaVSjQ68fBxoQcutl5fS1vuY18H3wSt3jFyFtrkx+Kz0V1G85A4MyAdDMi2Q==", 2751 | "dev": true 2752 | }, 2753 | "source-map": { 2754 | "version": "0.6.1", 2755 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", 2756 | "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", 2757 | "dev": true 2758 | }, 2759 | "source-map-support": { 2760 | "version": "0.5.21", 2761 | "resolved": "https://registry.npmjs.org/source-map-support/-/source-map-support-0.5.21.tgz", 2762 | "integrity": "sha512-uBHU3L3czsIyYXKX88fdrGovxdSCoTGDRZ6SYXtSRxLZUzHg5P/66Ht6uoUlHu9EZod+inXhKo3qQgwXUT/y1w==", 2763 | "dev": true, 2764 | "requires": { 2765 | "buffer-from": "^1.0.0", 2766 | "source-map": "^0.6.0" 2767 | } 2768 | }, 2769 | "sprintf-js": { 2770 | "version": "1.0.3", 2771 | "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz", 2772 | "integrity": "sha1-BOaSb2YolTVPPdAVIDYzuFcpfiw=", 2773 | "dev": true 2774 | }, 2775 | "stack-utils": { 2776 | "version": "2.0.5", 2777 | "resolved": "https://registry.npmjs.org/stack-utils/-/stack-utils-2.0.5.tgz", 2778 | "integrity": "sha512-xrQcmYhOsn/1kX+Vraq+7j4oE2j/6BFscZ0etmYg81xuM8Gq0022Pxb8+IqgOFUIaxHs0KaSb7T1+OegiNrNFA==", 2779 | "dev": true, 2780 | "requires": { 2781 | "escape-string-regexp": "^2.0.0" 2782 | }, 2783 | "dependencies": { 2784 | "escape-string-regexp": { 2785 | "version": "2.0.0", 2786 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-2.0.0.tgz", 2787 | "integrity": "sha512-UpzcLCXolUWcNu5HtVMHYdXJjArjsF9C0aNnquZYY4uW/Vu0miy5YoWvbV345HauVvcAUnpRuhMMcqTcGOY2+w==", 2788 | "dev": true 2789 | } 2790 | } 2791 | }, 2792 | "string-length": { 2793 | "version": "4.0.2", 2794 | "resolved": "https://registry.npmjs.org/string-length/-/string-length-4.0.2.tgz", 2795 | "integrity": "sha512-+l6rNN5fYHNhZZy41RXsYptCjA2Igmq4EG7kZAYFQI1E1VTXarr6ZPXBg6eq7Y6eK4FEhY6AJlyuFIb/v/S0VQ==", 2796 | "dev": true, 2797 | "requires": { 2798 | "char-regex": "^1.0.2", 2799 | "strip-ansi": "^6.0.0" 2800 | } 2801 | }, 2802 | "string-width": { 2803 | "version": "4.2.3", 2804 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", 2805 | "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", 2806 | "dev": true, 2807 | "requires": { 2808 | "emoji-regex": "^8.0.0", 2809 | "is-fullwidth-code-point": "^3.0.0", 2810 | "strip-ansi": "^6.0.1" 2811 | } 2812 | }, 2813 | "strip-ansi": { 2814 | "version": "6.0.1", 2815 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", 2816 | "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", 2817 | "dev": true, 2818 | "requires": { 2819 | "ansi-regex": "^5.0.1" 2820 | } 2821 | }, 2822 | "strip-bom": { 2823 | "version": "4.0.0", 2824 | "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-4.0.0.tgz", 2825 | "integrity": "sha512-3xurFv5tEgii33Zi8Jtp55wEIILR9eh34FAW00PZf+JnSsTmV/ioewSgQl97JHvgjoRGwPShsWm+IdrxB35d0w==", 2826 | "dev": true 2827 | }, 2828 | "strip-final-newline": { 2829 | "version": "2.0.0", 2830 | "resolved": "https://registry.npmjs.org/strip-final-newline/-/strip-final-newline-2.0.0.tgz", 2831 | "integrity": "sha512-BrpvfNAE3dcvq7ll3xVumzjKjZQ5tI1sEUIKr3Uoks0XUl45St3FlatVqef9prk4jRDzhW6WZg+3bk93y6pLjA==", 2832 | "dev": true 2833 | }, 2834 | "supports-color": { 2835 | "version": "7.1.0", 2836 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.1.0.tgz", 2837 | "integrity": "sha512-oRSIpR8pxT1Wr2FquTNnGet79b3BWljqOuoW/h4oBhxJ/HUbX5nX6JSruTkvXDCFMwDPvsaTTbvMLKZWSy0R5g==", 2838 | "dev": true, 2839 | "requires": { 2840 | "has-flag": "^4.0.0" 2841 | } 2842 | }, 2843 | "supports-hyperlinks": { 2844 | "version": "2.2.0", 2845 | "resolved": "https://registry.npmjs.org/supports-hyperlinks/-/supports-hyperlinks-2.2.0.tgz", 2846 | "integrity": "sha512-6sXEzV5+I5j8Bmq9/vUphGRM/RJNT9SCURJLjwfOg51heRtguGWDzcaBlgAzKhQa0EVNpPEKzQuBwZ8S8WaCeQ==", 2847 | "dev": true, 2848 | "requires": { 2849 | "has-flag": "^4.0.0", 2850 | "supports-color": "^7.0.0" 2851 | } 2852 | }, 2853 | "supports-preserve-symlinks-flag": { 2854 | "version": "1.0.0", 2855 | "resolved": "https://registry.npmjs.org/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz", 2856 | "integrity": "sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w==", 2857 | "dev": true 2858 | }, 2859 | "symbol-tree": { 2860 | "version": "3.2.4", 2861 | "resolved": "https://registry.npmjs.org/symbol-tree/-/symbol-tree-3.2.4.tgz", 2862 | "integrity": "sha512-9QNk5KwDF+Bvz+PyObkmSYjI5ksVUYtjW7AU22r2NKcfLJcXp96hkDWU3+XndOsUb+AQ9QhfzfCT2O+CNWT5Tw==", 2863 | "dev": true 2864 | }, 2865 | "terminal-link": { 2866 | "version": "2.1.1", 2867 | "resolved": "https://registry.npmjs.org/terminal-link/-/terminal-link-2.1.1.tgz", 2868 | "integrity": "sha512-un0FmiRUQNr5PJqy9kP7c40F5BOfpGlYTrxonDChEZB7pzZxRNp/bt+ymiy9/npwXya9KH99nJ/GXFIiUkYGFQ==", 2869 | "dev": true, 2870 | "requires": { 2871 | "ansi-escapes": "^4.2.1", 2872 | "supports-hyperlinks": "^2.0.0" 2873 | } 2874 | }, 2875 | "test-exclude": { 2876 | "version": "6.0.0", 2877 | "resolved": "https://registry.npmjs.org/test-exclude/-/test-exclude-6.0.0.tgz", 2878 | "integrity": "sha512-cAGWPIyOHU6zlmg88jwm7VRyXnMN7iV68OGAbYDk/Mh/xC/pzVPlQtY6ngoIH/5/tciuhGfvESU8GrHrcxD56w==", 2879 | "dev": true, 2880 | "requires": { 2881 | "@istanbuljs/schema": "^0.1.2", 2882 | "glob": "^7.1.4", 2883 | "minimatch": "^3.0.4" 2884 | } 2885 | }, 2886 | "throat": { 2887 | "version": "6.0.1", 2888 | "resolved": "https://registry.npmjs.org/throat/-/throat-6.0.1.tgz", 2889 | "integrity": "sha512-8hmiGIJMDlwjg7dlJ4yKGLK8EsYqKgPWbG3b4wjJddKNwc7N7Dpn08Df4szr/sZdMVeOstrdYSsqzX6BYbcB+w==", 2890 | "dev": true 2891 | }, 2892 | "tmpl": { 2893 | "version": "1.0.5", 2894 | "resolved": "https://registry.npmjs.org/tmpl/-/tmpl-1.0.5.tgz", 2895 | "integrity": "sha512-3f0uOEAQwIqGuWW2MVzYg8fV/QNnc/IpuJNG837rLuczAaLVHslWHZQj4IGiEl5Hs3kkbhwL9Ab7Hrsmuj+Smw==", 2896 | "dev": true 2897 | }, 2898 | "to-fast-properties": { 2899 | "version": "2.0.0", 2900 | "resolved": "https://registry.npmjs.org/to-fast-properties/-/to-fast-properties-2.0.0.tgz", 2901 | "integrity": "sha1-3F5pjL0HkmW8c+A3doGk5Og/YW4=", 2902 | "dev": true 2903 | }, 2904 | "to-regex-range": { 2905 | "version": "5.0.1", 2906 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", 2907 | "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", 2908 | "dev": true, 2909 | "requires": { 2910 | "is-number": "^7.0.0" 2911 | } 2912 | }, 2913 | "tough-cookie": { 2914 | "version": "4.0.0", 2915 | "resolved": "https://registry.npmjs.org/tough-cookie/-/tough-cookie-4.0.0.tgz", 2916 | "integrity": "sha512-tHdtEpQCMrc1YLrMaqXXcj6AxhYi/xgit6mZu1+EDWUn+qhUf8wMQoFIy9NXuq23zAwtcB0t/MjACGR18pcRbg==", 2917 | "dev": true, 2918 | "requires": { 2919 | "psl": "^1.1.33", 2920 | "punycode": "^2.1.1", 2921 | "universalify": "^0.1.2" 2922 | } 2923 | }, 2924 | "tr46": { 2925 | "version": "2.1.0", 2926 | "resolved": "https://registry.npmjs.org/tr46/-/tr46-2.1.0.tgz", 2927 | "integrity": "sha512-15Ih7phfcdP5YxqiB+iDtLoaTz4Nd35+IiAv0kQ5FNKHzXgdWqPoTIqEDDJmXceQt4JZk6lVPT8lnDlPpGDppw==", 2928 | "dev": true, 2929 | "requires": { 2930 | "punycode": "^2.1.1" 2931 | } 2932 | }, 2933 | "ts-jest": { 2934 | "version": "27.1.3", 2935 | "resolved": "https://registry.npmjs.org/ts-jest/-/ts-jest-27.1.3.tgz", 2936 | "integrity": "sha512-6Nlura7s6uM9BVUAoqLH7JHyMXjz8gluryjpPXxr3IxZdAXnU6FhjvVLHFtfd1vsE1p8zD1OJfskkc0jhTSnkA==", 2937 | "dev": true, 2938 | "requires": { 2939 | "bs-logger": "0.x", 2940 | "fast-json-stable-stringify": "2.x", 2941 | "jest-util": "^27.0.0", 2942 | "json5": "2.x", 2943 | "lodash.memoize": "4.x", 2944 | "make-error": "1.x", 2945 | "semver": "7.x", 2946 | "yargs-parser": "20.x" 2947 | }, 2948 | "dependencies": { 2949 | "@jest/types": { 2950 | "version": "27.5.0", 2951 | "resolved": "https://registry.npmjs.org/@jest/types/-/types-27.5.0.tgz", 2952 | "integrity": "sha512-oDHEp7gwSgA82RZ6pzUL3ugM2njP/lVB1MsxRZNOBk+CoNvh9SpH1lQixPFc/kDlV50v59csiW4HLixWmhmgPQ==", 2953 | "dev": true, 2954 | "requires": { 2955 | "@types/istanbul-lib-coverage": "^2.0.0", 2956 | "@types/istanbul-reports": "^3.0.0", 2957 | "@types/node": "*", 2958 | "@types/yargs": "^16.0.0", 2959 | "chalk": "^4.0.0" 2960 | } 2961 | }, 2962 | "@types/istanbul-reports": { 2963 | "version": "3.0.1", 2964 | "resolved": "https://registry.npmjs.org/@types/istanbul-reports/-/istanbul-reports-3.0.1.tgz", 2965 | "integrity": "sha512-c3mAZEuK0lvBp8tmuL74XRKn1+y2dcwOUpH7x4WrF6gk1GIgiluDRgMYQtw2OFcBvAJWlt6ASU3tSqxp0Uu0Aw==", 2966 | "dev": true, 2967 | "requires": { 2968 | "@types/istanbul-lib-report": "*" 2969 | } 2970 | }, 2971 | "@types/yargs": { 2972 | "version": "16.0.4", 2973 | "resolved": "https://registry.npmjs.org/@types/yargs/-/yargs-16.0.4.tgz", 2974 | "integrity": "sha512-T8Yc9wt/5LbJyCaLiHPReJa0kApcIgJ7Bn735GjItUfh08Z1pJvu8QZqb9s+mMvKV6WUQRV7K2R46YbjMXTTJw==", 2975 | "dev": true, 2976 | "requires": { 2977 | "@types/yargs-parser": "*" 2978 | } 2979 | }, 2980 | "chalk": { 2981 | "version": "4.1.2", 2982 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", 2983 | "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", 2984 | "dev": true, 2985 | "requires": { 2986 | "ansi-styles": "^4.1.0", 2987 | "supports-color": "^7.1.0" 2988 | } 2989 | }, 2990 | "ci-info": { 2991 | "version": "3.3.0", 2992 | "resolved": "https://registry.npmjs.org/ci-info/-/ci-info-3.3.0.tgz", 2993 | "integrity": "sha512-riT/3vI5YpVH6/qomlDnJow6TBee2PBKSEpx3O32EGPYbWGIRsIlGRms3Sm74wYE1JMo8RnO04Hb12+v1J5ICw==", 2994 | "dev": true 2995 | }, 2996 | "graceful-fs": { 2997 | "version": "4.2.9", 2998 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.9.tgz", 2999 | "integrity": "sha512-NtNxqUcXgpW2iMrfqSfR73Glt39K+BLwWsPs94yR63v45T0Wbej7eRmL5cWfwEgqXnmjQp3zaJTshdRW/qC2ZQ==", 3000 | "dev": true 3001 | }, 3002 | "jest-util": { 3003 | "version": "27.5.0", 3004 | "resolved": "https://registry.npmjs.org/jest-util/-/jest-util-27.5.0.tgz", 3005 | "integrity": "sha512-FUUqOx0gAzJy3ytatT1Ss372M1kmhczn8x7aE0++11oPGW1FyD/5NjYBI8w1KOXFm6IVjtaZm2szfJJL+CHs0g==", 3006 | "dev": true, 3007 | "requires": { 3008 | "@jest/types": "^27.5.0", 3009 | "@types/node": "*", 3010 | "chalk": "^4.0.0", 3011 | "ci-info": "^3.2.0", 3012 | "graceful-fs": "^4.2.9", 3013 | "picomatch": "^2.2.3" 3014 | } 3015 | }, 3016 | "picomatch": { 3017 | "version": "2.3.1", 3018 | "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz", 3019 | "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==", 3020 | "dev": true 3021 | }, 3022 | "semver": { 3023 | "version": "7.3.5", 3024 | "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.5.tgz", 3025 | "integrity": "sha512-PoeGJYh8HK4BTO/a9Tf6ZG3veo/A7ZVsYrSA6J8ny9nb3B1VrpkuN+z9OE5wfE5p6H4LchYZsegiQgbJD94ZFQ==", 3026 | "dev": true, 3027 | "requires": { 3028 | "lru-cache": "^6.0.0" 3029 | } 3030 | }, 3031 | "yargs-parser": { 3032 | "version": "20.2.9", 3033 | "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-20.2.9.tgz", 3034 | "integrity": "sha512-y11nGElTIV+CT3Zv9t7VKl+Q3hTQoT9a1Qzezhhl6Rp21gJ/IVTW7Z3y9EWXhuUBC2Shnf+DX0antecpAwSP8w==", 3035 | "dev": true 3036 | } 3037 | } 3038 | }, 3039 | "ts-toolbelt": { 3040 | "version": "9.6.0", 3041 | "resolved": "https://registry.npmjs.org/ts-toolbelt/-/ts-toolbelt-9.6.0.tgz", 3042 | "integrity": "sha512-nsZd8ZeNUzukXPlJmTBwUAuABDe/9qtVDelJeT/qW0ow3ZS3BsQJtNkan1802aM9Uf68/Y8ljw86Hu0h5IUW3w==" 3043 | }, 3044 | "tslib": { 3045 | "version": "2.3.1", 3046 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.3.1.tgz", 3047 | "integrity": "sha512-77EbyPPpMz+FRFRuAFlWMtmgUWGe9UOG2Z25NqCwiIjRhOf5iKGuzSe5P2w1laq+FkRy4p+PCuVkJSGkzTEKVw==", 3048 | "dev": true 3049 | }, 3050 | "type-check": { 3051 | "version": "0.3.2", 3052 | "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.3.2.tgz", 3053 | "integrity": "sha1-WITKtRLPHTVeP7eE8wgEsrUg23I=", 3054 | "dev": true, 3055 | "requires": { 3056 | "prelude-ls": "~1.1.2" 3057 | } 3058 | }, 3059 | "type-detect": { 3060 | "version": "4.0.8", 3061 | "resolved": "https://registry.npmjs.org/type-detect/-/type-detect-4.0.8.tgz", 3062 | "integrity": "sha512-0fr/mIH1dlO+x7TlcMy+bIDqKPsw/70tVyeHW787goQjhmqaZe10uwLujubK9q9Lg6Fiho1KUKDYz0Z7k7g5/g==", 3063 | "dev": true 3064 | }, 3065 | "type-fest": { 3066 | "version": "0.21.3", 3067 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.21.3.tgz", 3068 | "integrity": "sha512-t0rzBq87m3fVcduHDUFhKmyyX+9eo6WQjZvf51Ea/M0Q7+T374Jp1aUiyUl0GKxp8M/OETVHSDvmkyPgvX+X2w==", 3069 | "dev": true 3070 | }, 3071 | "typedarray-to-buffer": { 3072 | "version": "3.1.5", 3073 | "resolved": "https://registry.npmjs.org/typedarray-to-buffer/-/typedarray-to-buffer-3.1.5.tgz", 3074 | "integrity": "sha512-zdu8XMNEDepKKR+XYOXAVPtWui0ly0NtohUscw+UmaHiAWT8hrV1rr//H6V+0DvJ3OQ19S979M0laLfX8rm82Q==", 3075 | "dev": true, 3076 | "requires": { 3077 | "is-typedarray": "^1.0.0" 3078 | } 3079 | }, 3080 | "typescript": { 3081 | "version": "4.5.5", 3082 | "resolved": "https://registry.npmjs.org/typescript/-/typescript-4.5.5.tgz", 3083 | "integrity": "sha512-TCTIul70LyWe6IJWT8QSYeA54WQe8EjQFU4wY52Fasj5UKx88LNYKCgBEHcOMOrFF1rKGbD8v/xcNWVUq9SymA==", 3084 | "dev": true 3085 | }, 3086 | "universalify": { 3087 | "version": "0.1.2", 3088 | "resolved": "https://registry.npmjs.org/universalify/-/universalify-0.1.2.tgz", 3089 | "integrity": "sha512-rBJeI5CXAlmy1pV+617WB9J63U6XcazHHF2f2dbJix4XzpUF0RS3Zbj0FGIOCAva5P/d/GBOYaACQ1w+0azUkg==", 3090 | "dev": true 3091 | }, 3092 | "v8-to-istanbul": { 3093 | "version": "8.1.1", 3094 | "resolved": "https://registry.npmjs.org/v8-to-istanbul/-/v8-to-istanbul-8.1.1.tgz", 3095 | "integrity": "sha512-FGtKtv3xIpR6BYhvgH8MI/y78oT7d8Au3ww4QIxymrCtZEh5b8gCw2siywE+puhEmuWKDtmfrvF5UlB298ut3w==", 3096 | "dev": true, 3097 | "requires": { 3098 | "@types/istanbul-lib-coverage": "^2.0.1", 3099 | "convert-source-map": "^1.6.0", 3100 | "source-map": "^0.7.3" 3101 | }, 3102 | "dependencies": { 3103 | "source-map": { 3104 | "version": "0.7.3", 3105 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.7.3.tgz", 3106 | "integrity": "sha512-CkCj6giN3S+n9qrYiBTX5gystlENnRW5jZeNLHpe6aue+SrHcG5VYwujhW9s4dY31mEGsxBDrHR6oI69fTXsaQ==", 3107 | "dev": true 3108 | } 3109 | } 3110 | }, 3111 | "w3c-hr-time": { 3112 | "version": "1.0.2", 3113 | "resolved": "https://registry.npmjs.org/w3c-hr-time/-/w3c-hr-time-1.0.2.tgz", 3114 | "integrity": "sha512-z8P5DvDNjKDoFIHK7q8r8lackT6l+jo/Ye3HOle7l9nICP9lf1Ci25fy9vHd0JOWewkIFzXIEig3TdKT7JQ5fQ==", 3115 | "dev": true, 3116 | "requires": { 3117 | "browser-process-hrtime": "^1.0.0" 3118 | } 3119 | }, 3120 | "w3c-xmlserializer": { 3121 | "version": "2.0.0", 3122 | "resolved": "https://registry.npmjs.org/w3c-xmlserializer/-/w3c-xmlserializer-2.0.0.tgz", 3123 | "integrity": "sha512-4tzD0mF8iSiMiNs30BiLO3EpfGLZUT2MSX/G+o7ZywDzliWQ3OPtTZ0PTC3B3ca1UAf4cJMHB+2Bf56EriJuRA==", 3124 | "dev": true, 3125 | "requires": { 3126 | "xml-name-validator": "^3.0.0" 3127 | } 3128 | }, 3129 | "walker": { 3130 | "version": "1.0.8", 3131 | "resolved": "https://registry.npmjs.org/walker/-/walker-1.0.8.tgz", 3132 | "integrity": "sha512-ts/8E8l5b7kY0vlWLewOkDXMmPdLcVV4GmOQLyxuSswIJsweeFZtAsMF7k1Nszz+TYBQrlYRmzOnr398y1JemQ==", 3133 | "dev": true, 3134 | "requires": { 3135 | "makeerror": "1.0.12" 3136 | } 3137 | }, 3138 | "webidl-conversions": { 3139 | "version": "6.1.0", 3140 | "resolved": "https://registry.npmjs.org/webidl-conversions/-/webidl-conversions-6.1.0.tgz", 3141 | "integrity": "sha512-qBIvFLGiBpLjfwmYAaHPXsn+ho5xZnGvyGvsarywGNc8VyQJUMHJ8OBKGGrPER0okBeMDaan4mNBlgBROxuI8w==", 3142 | "dev": true 3143 | }, 3144 | "whatwg-encoding": { 3145 | "version": "1.0.5", 3146 | "resolved": "https://registry.npmjs.org/whatwg-encoding/-/whatwg-encoding-1.0.5.tgz", 3147 | "integrity": "sha512-b5lim54JOPN9HtzvK9HFXvBma/rnfFeqsic0hSpjtDbVxR3dJKLc+KB4V6GgiGOvl7CY/KNh8rxSo9DKQrnUEw==", 3148 | "dev": true, 3149 | "requires": { 3150 | "iconv-lite": "0.4.24" 3151 | } 3152 | }, 3153 | "whatwg-mimetype": { 3154 | "version": "2.3.0", 3155 | "resolved": "https://registry.npmjs.org/whatwg-mimetype/-/whatwg-mimetype-2.3.0.tgz", 3156 | "integrity": "sha512-M4yMwr6mAnQz76TbJm914+gPpB/nCwvZbJU28cUD6dR004SAxDLOOSUaB1JDRqLtaOV/vi0IC5lEAGFgrjGv/g==", 3157 | "dev": true 3158 | }, 3159 | "whatwg-url": { 3160 | "version": "8.7.0", 3161 | "resolved": "https://registry.npmjs.org/whatwg-url/-/whatwg-url-8.7.0.tgz", 3162 | "integrity": "sha512-gAojqb/m9Q8a5IV96E3fHJM70AzCkgt4uXYX2O7EmuyOnLrViCQlsEBmF9UQIu3/aeAIp2U17rtbpZWNntQqdg==", 3163 | "dev": true, 3164 | "requires": { 3165 | "lodash": "^4.7.0", 3166 | "tr46": "^2.1.0", 3167 | "webidl-conversions": "^6.1.0" 3168 | } 3169 | }, 3170 | "which": { 3171 | "version": "2.0.2", 3172 | "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", 3173 | "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", 3174 | "dev": true, 3175 | "requires": { 3176 | "isexe": "^2.0.0" 3177 | } 3178 | }, 3179 | "word-wrap": { 3180 | "version": "1.2.3", 3181 | "resolved": "https://registry.npmjs.org/word-wrap/-/word-wrap-1.2.3.tgz", 3182 | "integrity": "sha512-Hz/mrNwitNRh/HUAtM/VT/5VH+ygD6DV7mYKZAtHOrbs8U7lvPS6xf7EJKMF0uW1KJCl0H701g3ZGus+muE5vQ==", 3183 | "dev": true 3184 | }, 3185 | "wrap-ansi": { 3186 | "version": "7.0.0", 3187 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz", 3188 | "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==", 3189 | "dev": true, 3190 | "requires": { 3191 | "ansi-styles": "^4.0.0", 3192 | "string-width": "^4.1.0", 3193 | "strip-ansi": "^6.0.0" 3194 | } 3195 | }, 3196 | "wrappy": { 3197 | "version": "1.0.2", 3198 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 3199 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=", 3200 | "dev": true 3201 | }, 3202 | "write-file-atomic": { 3203 | "version": "3.0.3", 3204 | "resolved": "https://registry.npmjs.org/write-file-atomic/-/write-file-atomic-3.0.3.tgz", 3205 | "integrity": "sha512-AvHcyZ5JnSfq3ioSyjrBkH9yW4m7Ayk8/9My/DD9onKeu/94fwrMocemO2QAJFAlnnDN+ZDS+ZjAR5ua1/PV/Q==", 3206 | "dev": true, 3207 | "requires": { 3208 | "imurmurhash": "^0.1.4", 3209 | "is-typedarray": "^1.0.0", 3210 | "signal-exit": "^3.0.2", 3211 | "typedarray-to-buffer": "^3.1.5" 3212 | } 3213 | }, 3214 | "ws": { 3215 | "version": "7.5.7", 3216 | "resolved": "https://registry.npmjs.org/ws/-/ws-7.5.7.tgz", 3217 | "integrity": "sha512-KMvVuFzpKBuiIXW3E4u3mySRO2/mCHSyZDJQM5NQ9Q9KHWHWh0NHgfbRMLLrceUK5qAL4ytALJbpRMjixFZh8A==", 3218 | "dev": true 3219 | }, 3220 | "xml-name-validator": { 3221 | "version": "3.0.0", 3222 | "resolved": "https://registry.npmjs.org/xml-name-validator/-/xml-name-validator-3.0.0.tgz", 3223 | "integrity": "sha512-A5CUptxDsvxKJEU3yO6DuWBSJz/qizqzJKOMIfUJHETbBw/sFaDxgd6fxm1ewUaM0jZ444Fc5vC5ROYurg/4Pw==", 3224 | "dev": true 3225 | }, 3226 | "xmlchars": { 3227 | "version": "2.2.0", 3228 | "resolved": "https://registry.npmjs.org/xmlchars/-/xmlchars-2.2.0.tgz", 3229 | "integrity": "sha512-JZnDKK8B0RCDw84FNdDAIpZK+JuJw+s7Lz8nksI7SIuU3UXJJslUthsi+uWBUYOwPFwW7W7PRLRfUKpxjtjFCw==", 3230 | "dev": true 3231 | }, 3232 | "y18n": { 3233 | "version": "5.0.8", 3234 | "resolved": "https://registry.npmjs.org/y18n/-/y18n-5.0.8.tgz", 3235 | "integrity": "sha512-0pfFzegeDWJHJIAmTLRP2DwHjdF5s7jo9tuztdQxAhINCdvS+3nGINqPd00AphqJR/0LhANUS6/+7SCb98YOfA==", 3236 | "dev": true 3237 | }, 3238 | "yallist": { 3239 | "version": "4.0.0", 3240 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", 3241 | "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", 3242 | "dev": true 3243 | }, 3244 | "yargs": { 3245 | "version": "16.2.0", 3246 | "resolved": "https://registry.npmjs.org/yargs/-/yargs-16.2.0.tgz", 3247 | "integrity": "sha512-D1mvvtDG0L5ft/jGWkLpG1+m0eQxOfaBvTNELraWj22wSVUMWxZUvYgJYcKh6jGGIkJFhH4IZPQhR4TKpc8mBw==", 3248 | "dev": true, 3249 | "requires": { 3250 | "cliui": "^7.0.2", 3251 | "escalade": "^3.1.1", 3252 | "get-caller-file": "^2.0.5", 3253 | "require-directory": "^2.1.1", 3254 | "string-width": "^4.2.0", 3255 | "y18n": "^5.0.5", 3256 | "yargs-parser": "^20.2.2" 3257 | } 3258 | }, 3259 | "yargs-parser": { 3260 | "version": "20.2.9", 3261 | "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-20.2.9.tgz", 3262 | "integrity": "sha512-y11nGElTIV+CT3Zv9t7VKl+Q3hTQoT9a1Qzezhhl6Rp21gJ/IVTW7Z3y9EWXhuUBC2Shnf+DX0antecpAwSP8w==", 3263 | "dev": true 3264 | } 3265 | } 3266 | } 3267 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "rxjs-observable-store", 3 | "version": "3.1.0", 4 | "description": "A state management solution implemented using RxJS to mimic Redux architecture.", 5 | "keywords": [ 6 | "rxjs", 7 | "observable", 8 | "store", 9 | "redux", 10 | "angular", 11 | "state management" 12 | ], 13 | "license": "MIT", 14 | "author": { 15 | "name": "George Byte", 16 | "url": "https://georgebyte.com" 17 | }, 18 | "homepage": "https://georgebyte.com/state-management-in-angular-with-observable-store-services/", 19 | "repository": { 20 | "type": "git", 21 | "url": "git+https://github.com/georgebyte/rxjs-observable-store.git" 22 | }, 23 | "bugs": { 24 | "url": "https://github.com/georgebyte/rxjs-observable-store/issues" 25 | }, 26 | "main": "./lib/cjs/index.js", 27 | "module": "./lib/esm/index.js", 28 | "typings": "./lib/esm/index.d.ts", 29 | "scripts": { 30 | "test": "jest", 31 | "build": "rimraf lib/**/* && tsc -p tsconfig.json && tsc -p tsconfig-cjs.json", 32 | "prepare": "npm run build" 33 | }, 34 | "files": [ 35 | "lib/" 36 | ], 37 | "jest": { 38 | "moduleFileExtensions": [ 39 | "ts", 40 | "js" 41 | ], 42 | "transform": { 43 | "\\.ts$": "ts-jest" 44 | }, 45 | "testRegex": "/src/.*\\.spec\\.ts$" 46 | }, 47 | "dependencies": { 48 | "ts-toolbelt": "~9.6.0" 49 | }, 50 | "peerDependencies": { 51 | "rxjs": "7.x" 52 | }, 53 | "devDependencies": { 54 | "@types/jest": "^27.4.0", 55 | "jest": "^27.5.0", 56 | "rimraf": "^3.0.2", 57 | "rxjs": "7.x", 58 | "ts-jest": "~27.1.3", 59 | "typescript": "~4.5.5" 60 | } 61 | } 62 | -------------------------------------------------------------------------------- /src/index.ts: -------------------------------------------------------------------------------- 1 | export {Store} from './store'; 2 | -------------------------------------------------------------------------------- /src/store.spec.ts: -------------------------------------------------------------------------------- 1 | import {take} from 'rxjs/operators'; 2 | import {Store} from './store'; 3 | 4 | interface OptionalSublevel { 5 | firstSublevel1?: { 6 | value1: string; 7 | value2: string; 8 | value3?: string; 9 | }; 10 | } 11 | 12 | class TestStoreState { 13 | optionalSublevel?: OptionalSublevel = {}; 14 | twoSublevels = { 15 | firstSublevel1: { 16 | secondSublevel1: { 17 | value1: 'twoSublevels-firstSublevel1-secondSublevel1: value1', 18 | value2: 'twoSublevels-firstSublevel1-secondSublevel1: value2', 19 | }, 20 | secondSublevel2: { 21 | value1: 'twoSublevels-firstSublevel1-secondSublevel2: value1', 22 | value2: 'twoSublevels-firstSublevel1-secondSublevel2: value2', 23 | }, 24 | }, 25 | }; 26 | } 27 | 28 | class TestStore extends Store { 29 | constructor() { 30 | super(new TestStoreState()); 31 | } 32 | } 33 | 34 | interface TestStoreStateInterface { 35 | value1: string; 36 | value2: string; 37 | value3?: string; 38 | nullableTwoSublevels?: { 39 | firstSublevel1?: { 40 | secondSublevel1: { 41 | value1: string; 42 | }; 43 | }; 44 | }; 45 | oneSublevel: { 46 | value1: string; 47 | value2: string; 48 | value3?: string; 49 | }; 50 | twoSublevels?: { 51 | firstSublevel1: { 52 | secondSublevel1: { 53 | value1: string; 54 | value2: string; 55 | value3?: string; 56 | }; 57 | secondSublevel2: { 58 | value1: string; 59 | value2: string; 60 | value3?: string; 61 | }; 62 | }; 63 | firstSublevel2: { 64 | secondSublevel1: { 65 | value1: string; 66 | value2: string; 67 | value3?: string; 68 | }; 69 | secondSublevel2: { 70 | value1: string; 71 | value2: string; 72 | value3?: string; 73 | }; 74 | }; 75 | firstSublevel3?: { 76 | secondSublevel1: { 77 | value1: string; 78 | value2: string; 79 | value3?: string; 80 | }; 81 | secondSublevel2: { 82 | value1: string; 83 | value2: string; 84 | value3?: string; 85 | }; 86 | }; 87 | }; 88 | fiveSublevels?: { 89 | firstSublevel1: { 90 | secondSublevel1: { 91 | thirdSublevel1: { 92 | fourthSublevel1: { 93 | fifthSublevel1: { 94 | value1: string; 95 | value2: string; 96 | value3?: string; 97 | }; 98 | fifthSublevel2: { 99 | value1: string; 100 | value2: string; 101 | value3?: string; 102 | }; 103 | }; 104 | fourthSublevel2?: { 105 | fifthSublevel1: { 106 | value1: string; 107 | value2: string; 108 | value3?: string; 109 | }; 110 | }; 111 | }; 112 | }; 113 | secondSublevel2: { 114 | value1: string; 115 | value2: string; 116 | value3?: string; 117 | }; 118 | }; 119 | }; 120 | } 121 | 122 | class TestStoreImplementingInterfaceState implements TestStoreStateInterface { 123 | value1 = 'root: value1'; 124 | value2 = 'root: value2'; 125 | oneSublevel = { 126 | value1: 'oneSublevel: value1', 127 | value2: 'oneSublevel: value2', 128 | }; 129 | nullableTwoSublevels = {firstSublevel1: null}; 130 | twoSublevels = { 131 | firstSublevel1: { 132 | secondSublevel1: { 133 | value1: 'twoSublevels-firstSublevel1-secondSublevel1: value1', 134 | value2: 'twoSublevels-firstSublevel1-secondSublevel1: value2', 135 | }, 136 | secondSublevel2: { 137 | value1: 'twoSublevels-firstSublevel1-secondSublevel2: value1', 138 | value2: 'twoSublevels-firstSublevel1-secondSublevel2: value2', 139 | }, 140 | }, 141 | firstSublevel2: { 142 | secondSublevel1: { 143 | value1: 'twoSublevels-firstSublevel2-secondSublevel1: value1', 144 | value2: 'twoSublevels-firstSublevel2-secondSublevel1: value2', 145 | }, 146 | secondSublevel2: { 147 | value1: 'twoSublevels-firstSublevel2-secondSublevel2: value1', 148 | value2: 'twoSublevels-firstSublevel2-secondSublevel2: value2', 149 | }, 150 | }, 151 | }; 152 | fiveSublevels = { 153 | firstSublevel1: { 154 | secondSublevel1: { 155 | thirdSublevel1: { 156 | fourthSublevel1: { 157 | fifthSublevel1: { 158 | value1: 159 | 'fiveSublevels-firstSublevel1-secondSublevel1-thirdSublevel1-fourthSublevel1-fifthSublevel1: value1', 160 | value2: 161 | 'fiveSublevels-firstSublevel1-secondSublevel1-thirdSublevel1-fourthSublevel1-fifthSublevel1: value2', 162 | }, 163 | fifthSublevel2: { 164 | value1: 165 | 'fiveSublevels-firstSublevel1-secondSublevel1-thirdSublevel1-fourthSublevel1-fifthSublevel2: value1', 166 | value2: 167 | 'fiveSublevels-firstSublevel1-secondSublevel1-thirdSublevel1-fourthSublevel1-fifthSublevel2: value2', 168 | }, 169 | }, 170 | }, 171 | }, 172 | secondSublevel2: { 173 | value1: 'fiveSublevels-firstSublevel1-secondSublevel2: value1', 174 | value2: 'fiveSublevels-firstSublevel1-secondSublevel2: value2', 175 | }, 176 | }, 177 | }; 178 | } 179 | 180 | class TestStoreImplementingInterface extends Store { 181 | constructor() { 182 | super(new TestStoreImplementingInterfaceState()); 183 | } 184 | } 185 | 186 | describe('Store', () => { 187 | describe('with state not implementing an interface', () => { 188 | let store: TestStore; 189 | 190 | beforeEach(() => { 191 | store = new TestStore(); 192 | }); 193 | 194 | it('should set state correctly via setState() call', () => { 195 | const mockedNewState = { 196 | twoSublevels: { 197 | firstSublevel1: { 198 | secondSublevel1: { 199 | value1: 200 | 'twoSublevels-firstSublevel1-secondSublevel1: value1 updated', 201 | value2: 202 | 'twoSublevels-firstSublevel1-secondSublevel1: value2 updated', 203 | }, 204 | secondSublevel2: { 205 | value1: 206 | 'twoSublevels-firstSublevel1-secondSublevel2: value1 updated', 207 | value2: 208 | 'twoSublevels-firstSublevel1-secondSublevel2: value2 updated', 209 | }, 210 | }, 211 | }, 212 | }; 213 | store.setState(mockedNewState); 214 | expect(store.state).toEqual(mockedNewState); 215 | }); 216 | 217 | it('should create values correctly on "optionalSublevel-firstSublevel1" when "optionalSublevel" === {}', () => { 218 | const newValue = 'optionalSublevel-firstSublevel1: value2 created'; 219 | const expectedState = new TestStoreState(); 220 | Object.assign(expectedState.optionalSublevel, { 221 | firstSublevel1: {value2: newValue}, 222 | }); 223 | store.patchState( 224 | newValue, 225 | 'optionalSublevel', 226 | 'firstSublevel1', 227 | 'value2' 228 | ); 229 | expect(store.state).toEqual(expectedState); 230 | }); 231 | 232 | it('should update values correctly on "twoSublevels-firstSublevel1-secondSublevel2"', () => { 233 | const newValue = 234 | 'twoSublevels-firstSublevel1-secondSublevel2: value2 updated'; 235 | const expectedState = new TestStoreState(); 236 | Object.assign( 237 | expectedState.twoSublevels.firstSublevel1.secondSublevel2, 238 | {value2: newValue} 239 | ); 240 | store.patchState( 241 | newValue, 242 | 'twoSublevels', 243 | 'firstSublevel1', 244 | 'secondSublevel2', 245 | 'value2' 246 | ); 247 | expect(store.state).toEqual(expectedState); 248 | }); 249 | }); 250 | 251 | describe('with state implementing an interface', () => { 252 | let store: TestStoreImplementingInterface; 253 | 254 | beforeEach(() => { 255 | store = new TestStoreImplementingInterface(); 256 | }); 257 | 258 | it('should set state correctly via setState() call', () => { 259 | const mockedNewState = { 260 | value1: 'root: value1 updated', 261 | value2: 'root: value2 updated', 262 | oneSublevel: { 263 | value1: 'oneSublevel: value1 updated', 264 | value2: 'oneSublevel: value2 updated', 265 | value3: 'oneSublevel: value3 updated', 266 | }, 267 | }; 268 | store.setState(mockedNewState); 269 | expect(store.state).toEqual(mockedNewState); 270 | }); 271 | 272 | it('should update values correctly on "root"', () => { 273 | const newValue = 'root: value1 updated'; 274 | const expectedState = new TestStoreImplementingInterfaceState(); 275 | Object.assign(expectedState, {value1: newValue}); 276 | store.patchState(newValue, 'value1'); 277 | expect(store.state).toEqual(expectedState); 278 | }); 279 | 280 | it('should create values correctly on "root" for non-existing paths', () => { 281 | const newValue = 'root: value3 created'; 282 | const expectedState = new TestStoreImplementingInterfaceState(); 283 | Object.assign(expectedState, {value3: newValue}); 284 | store.patchState(newValue, 'value3'); 285 | expect(store.state).toEqual(expectedState); 286 | }); 287 | 288 | it('should create values correctly on "nullableTwoSublevels" when "firstSublevel1" === null', () => { 289 | const newValue = 290 | 'nullableTwoSublevels-firstSublevel1-secondSublevel1: value1 created'; 291 | const expectedState = new TestStoreImplementingInterfaceState(); 292 | Object.assign(expectedState, { 293 | nullableTwoSublevels: { 294 | firstSublevel1: {secondSublevel1: {value1: newValue}}, 295 | }, 296 | }); 297 | store.patchState( 298 | newValue, 299 | 'nullableTwoSublevels', 300 | 'firstSublevel1', 301 | 'secondSublevel1', 302 | 'value1' 303 | ); 304 | expect(store.state).toEqual(expectedState); 305 | }); 306 | 307 | it('should update values correctly on "oneSublevel"', () => { 308 | const newValue = 'oneSublevel: value2 updated'; 309 | const expectedState = new TestStoreImplementingInterfaceState(); 310 | Object.assign(expectedState.oneSublevel, {value2: newValue}); 311 | store.patchState(newValue, 'oneSublevel', 'value2'); 312 | expect(store.state).toEqual(expectedState); 313 | }); 314 | 315 | it('should create values correctly on "oneSublevel" for non-existing paths', () => { 316 | const newValue = 'oneSublevel: value3 created'; 317 | const expectedState = new TestStoreImplementingInterfaceState(); 318 | Object.assign(expectedState.oneSublevel, {value3: newValue}); 319 | store.patchState(newValue, 'oneSublevel', 'value3'); 320 | expect(store.state).toEqual(expectedState); 321 | }); 322 | 323 | it('should update values correctly on "twoSublevels-firstSublevel1-secondSublevel1"', () => { 324 | const newValue = 325 | 'twoSublevels-firstSublevel1-secondSublevel1: value1 updated'; 326 | const expectedState = new TestStoreImplementingInterfaceState(); 327 | Object.assign( 328 | expectedState.twoSublevels.firstSublevel1.secondSublevel1, 329 | {value1: newValue} 330 | ); 331 | store.patchState( 332 | newValue, 333 | 'twoSublevels', 334 | 'firstSublevel1', 335 | 'secondSublevel1', 336 | 'value1' 337 | ); 338 | expect(store.state).toEqual(expectedState); 339 | }); 340 | 341 | it('should create values correctly on "twoSublevels-firstSublevel1-secondSublevel1" for non-existing paths', () => { 342 | const newValue = 343 | 'twoSublevels-firstSublevel1-secondSublevel1: value3 created'; 344 | const expectedState = new TestStoreImplementingInterfaceState(); 345 | Object.assign( 346 | expectedState.twoSublevels.firstSublevel1.secondSublevel1, 347 | {value3: newValue} 348 | ); 349 | store.patchState( 350 | newValue, 351 | 'twoSublevels', 352 | 'firstSublevel1', 353 | 'secondSublevel1', 354 | 'value3' 355 | ); 356 | expect(store.state).toEqual(expectedState); 357 | }); 358 | 359 | it('should update values correctly on "twoSublevels-firstSublevel2-secondSublevel2"', () => { 360 | const newValue = 361 | 'twoSublevels-firstSublevel2-secondSublevel2: value2 updated'; 362 | const expectedState = new TestStoreImplementingInterfaceState(); 363 | Object.assign( 364 | expectedState.twoSublevels.firstSublevel2.secondSublevel2, 365 | {value2: newValue} 366 | ); 367 | store.patchState( 368 | newValue, 369 | 'twoSublevels', 370 | 'firstSublevel2', 371 | 'secondSublevel2', 372 | 'value2' 373 | ); 374 | expect(store.state).toEqual(expectedState); 375 | }); 376 | 377 | it('should create values correctly on "twoSublevels-firstSublevel2-secondSublevel2" for non-existing paths', () => { 378 | const newValue = 379 | 'twoSublevels-firstSublevel2-secondSublevel2: value3 created'; 380 | const expectedState = new TestStoreImplementingInterfaceState(); 381 | Object.assign( 382 | expectedState.twoSublevels.firstSublevel2.secondSublevel2, 383 | {value3: newValue} 384 | ); 385 | store.patchState( 386 | newValue, 387 | 'twoSublevels', 388 | 'firstSublevel2', 389 | 'secondSublevel2', 390 | 'value3' 391 | ); 392 | expect(store.state).toEqual(expectedState); 393 | }); 394 | 395 | it('should create values correctly on "twoSublevels" for non-existing paths', () => { 396 | const newValue = { 397 | secondSublevel1: { 398 | value1: 399 | 'twoSublevels-firstSublevel3-secondSublevel1: value1 created', 400 | value2: 401 | 'twoSublevels-firstSublevel3-secondSublevel1: value2 created', 402 | }, 403 | secondSublevel2: { 404 | value1: 405 | 'twoSublevels-firstSublevel3-secondSublevel2: value1 created', 406 | value2: 407 | 'twoSublevels-firstSublevel3-secondSublevel2: value2 created', 408 | }, 409 | }; 410 | const expectedState = new TestStoreImplementingInterfaceState(); 411 | Object.assign(expectedState.twoSublevels, { 412 | firstSublevel3: newValue, 413 | }); 414 | store.patchState(newValue, 'twoSublevels', 'firstSublevel3'); 415 | expect(store.state).toEqual(expectedState); 416 | }); 417 | 418 | it('should update values correctly on "fiveSublevels-firstSublevel1-secondSublevel1-thirdSublevel1-fourthSublevel1-fifthSublevel1"', () => { 419 | const newValue = 420 | 'fiveSublevels-firstSublevel1-secondSublevel1-thirdSublevel1-fourthSublevel1-fifthSublevel1: value2 updated'; 421 | const expectedState = new TestStoreImplementingInterfaceState(); 422 | Object.assign( 423 | expectedState.fiveSublevels.firstSublevel1.secondSublevel1 424 | .thirdSublevel1.fourthSublevel1.fifthSublevel1, 425 | {value2: newValue} 426 | ); 427 | store.patchState( 428 | newValue, 429 | 'fiveSublevels', 430 | 'firstSublevel1', 431 | 'secondSublevel1', 432 | 'thirdSublevel1', 433 | 'fourthSublevel1', 434 | 'fifthSublevel1', 435 | 'value2' 436 | ); 437 | expect(store.state).toEqual(expectedState); 438 | }); 439 | 440 | it('should create values correctly on "fiveSublevels-firstSublevel1-secondSublevel1-thirdSublevel1-fourthSublevel1-fifthSublevel2" for non-existing paths', () => { 441 | const newValue = 442 | 'fiveSublevels-firstSublevel1-secondSublevel1-thirdSublevel1-fourthSublevel1-fifthSublevel2: value3 created'; 443 | const expectedState = new TestStoreImplementingInterfaceState(); 444 | Object.assign( 445 | expectedState.fiveSublevels.firstSublevel1.secondSublevel1 446 | .thirdSublevel1.fourthSublevel1.fifthSublevel2, 447 | {value3: newValue} 448 | ); 449 | store.patchState( 450 | newValue, 451 | 'fiveSublevels', 452 | 'firstSublevel1', 453 | 'secondSublevel1', 454 | 'thirdSublevel1', 455 | 'fourthSublevel1', 456 | 'fifthSublevel2', 457 | 'value3' 458 | ); 459 | expect(store.state).toEqual(expectedState); 460 | }); 461 | 462 | it('should create values correctly on "fiveSublevels-firstSublevel1-secondSublevel1-thirdSublevel1" for non-existing paths', () => { 463 | const newValue = { 464 | fifthSublevel1: { 465 | value1: 466 | 'fiveSublevels-firstSublevel1-secondSublevel1-thirdSublevel1-fourthSublevel2-fifthSublevel1: value1 created', 467 | value2: 468 | 'fiveSublevels-firstSublevel1-secondSublevel1-thirdSublevel1-fourthSublevel2-fifthSublevel1: value2 created', 469 | value3: 470 | 'fiveSublevels-firstSublevel1-secondSublevel1-thirdSublevel1-fourthSublevel2-fifthSublevel1: value3 created', 471 | }, 472 | }; 473 | const expectedState = new TestStoreImplementingInterfaceState(); 474 | Object.assign( 475 | expectedState.fiveSublevels.firstSublevel1.secondSublevel1 476 | .thirdSublevel1, 477 | {fourthSublevel2: newValue} 478 | ); 479 | store.patchState( 480 | newValue, 481 | 'fiveSublevels', 482 | 'firstSublevel1', 483 | 'secondSublevel1', 484 | 'thirdSublevel1', 485 | 'fourthSublevel2' 486 | ); 487 | expect(store.state).toEqual(expectedState); 488 | }); 489 | 490 | it('should get values on "twoSublevels-firstSublevel1-secondSublevel1"', done => { 491 | const result = []; 492 | store.onChanges('twoSublevels', 'firstSublevel1', 'secondSublevel1', 'value1') 493 | .pipe(take(2)) 494 | .subscribe({ 495 | next(val) { 496 | result.push(val); 497 | }, 498 | complete() { 499 | expect(result).toEqual([ 500 | 'twoSublevels-firstSublevel1-secondSublevel1: value1', 501 | 'twoSublevels-firstSublevel1-secondSublevel1: value1 patched' 502 | ]); 503 | done(); 504 | } 505 | }); 506 | 507 | store.patchState( 508 | 'twoSublevels-firstSublevel1-secondSublevel1: value1 patched', 509 | 'twoSublevels', 510 | 'firstSublevel1', 511 | 'secondSublevel1', 512 | 'value1' 513 | ); 514 | }); 515 | 516 | it('should skip unchanged value on "oneSublevel"', done => { 517 | const result = []; 518 | store.onChanges('oneSublevel', 'value1') 519 | .pipe(take(2)) 520 | .subscribe({ 521 | next(val) { 522 | result.push(val); 523 | }, 524 | complete() { 525 | expect(result).toEqual([ 526 | 'oneSublevel: value1', 527 | 'oneSublevel: value1 patched' 528 | ]); 529 | done(); 530 | } 531 | }); 532 | 533 | store.patchState('oneSublevel: value1', 'oneSublevel', 'value1'); 534 | store.patchState('oneSublevel: value1 patched', 'oneSublevel', 'value1'); 535 | }); 536 | 537 | it('should get null value on "nullableTwoSublevels-firstSublevel1"', done => { 538 | const result = []; 539 | store.onChanges('nullableTwoSublevels', 'firstSublevel1') 540 | .pipe(take(2)) 541 | .subscribe({ 542 | next(val) { 543 | result.push(val); 544 | }, 545 | complete() { 546 | expect(result).toEqual([ 547 | null, 548 | {secondSublevel1: {value1: ''}} 549 | ]); 550 | done(); 551 | } 552 | }); 553 | 554 | store.patchState({secondSublevel1: {value1: ''}}, 'nullableTwoSublevels', 'firstSublevel1'); 555 | }); 556 | 557 | it('should get undefined value on "nullableTwoSublevels" when "firstSublevel1" === null', done => { 558 | const result = []; 559 | store.onChanges('nullableTwoSublevels', 'firstSublevel1', 'secondSublevel1', 'value1') 560 | .pipe(take(2)) 561 | .subscribe({ 562 | next(val) { 563 | result.push(val); 564 | }, 565 | complete() { 566 | expect(result).toEqual([ 567 | undefined, 568 | 'value1' 569 | ]); 570 | done(); 571 | } 572 | }); 573 | 574 | store.patchState({secondSublevel1: {value1: 'value1'}}, 'nullableTwoSublevels', 'firstSublevel1'); 575 | }); 576 | 577 | it('should skip unchanged object (same reference) on "oneSublevel"', done => { 578 | const result = []; 579 | const initialValue = {value1: 'value1', value2: 'value2'}; 580 | store.patchState(initialValue, 'oneSublevel'); 581 | store.onChanges('oneSublevel') 582 | .pipe(take(2)) 583 | .subscribe({ 584 | next(val) { 585 | result.push(val); 586 | }, 587 | complete() { 588 | expect(result).toEqual([ 589 | initialValue, 590 | {value1: 'value1 patched', value2: 'value2'} 591 | ]); 592 | done(); 593 | } 594 | }); 595 | 596 | store.patchState(initialValue, 'oneSublevel'); 597 | store.patchState({value1: 'value1 patched', value2: 'value2'}, 'oneSublevel'); 598 | }); 599 | }); 600 | }); 601 | -------------------------------------------------------------------------------- /src/store.ts: -------------------------------------------------------------------------------- 1 | import {BehaviorSubject, Observable} from 'rxjs'; 2 | import {distinctUntilChanged, map} from 'rxjs/operators'; 3 | import {Object, Tuple} from 'ts-toolbelt'; 4 | 5 | type Index = string | number | symbol; 6 | 7 | export class Store { 8 | state$: Observable; 9 | private _state$: BehaviorSubject; 10 | 11 | protected constructor(initialState: S) { 12 | this._state$ = new BehaviorSubject(initialState); 13 | this.state$ = this._state$.asObservable(); 14 | } 15 | 16 | get state(): S { 17 | return this._state$.getValue(); 18 | } 19 | 20 | setState(nextState: S) { 21 | this._state$.next(nextState); 22 | } 23 | 24 | // prettier-ignore 25 | patchState< 26 | P1 extends keyof Object.Path 27 | >(value: Object.Path, part1: P1): void; 28 | // prettier-ignore 29 | patchState< 30 | P1 extends keyof Object.Path, 31 | P2 extends keyof Object.Path 32 | >(value: Object.Path, part1: P1, part2: P2): void; 33 | // prettier-ignore 34 | patchState< 35 | P1 extends keyof Object.Path, 36 | P2 extends keyof Object.Path, 37 | P3 extends keyof Object.Path 38 | >(value: Object.Path, part1: P1, part2: P2, part3: P3): void 39 | // prettier-ignore 40 | patchState< 41 | P1 extends keyof Object.Path, 42 | P2 extends keyof Object.Path, 43 | P3 extends keyof Object.Path, 44 | P4 extends keyof Object.Path 45 | >(value: Object.Path, part1: P1, part2: P2, part3: P3, part4: P4): void 46 | // prettier-ignore 47 | patchState< 48 | P1 extends keyof Object.Path, 49 | P2 extends keyof Object.Path, 50 | P3 extends keyof Object.Path, 51 | P4 extends keyof Object.Path, 52 | P5 extends keyof Object.Path 53 | >(value: Object.Path, part1: P1, part2: P2, part3: P3, part4: P4, part5: P5): void 54 | // prettier-ignore 55 | patchState< 56 | P1 extends keyof Object.Path, 57 | P2 extends keyof Object.Path, 58 | P3 extends keyof Object.Path, 59 | P4 extends keyof Object.Path, 60 | P5 extends keyof Object.Path, 61 | P6 extends keyof Object.Path 62 | >(value: Object.Path, part1: P1, part2: P2, part3: P3, part4: P4, part5: P5, part6: P6): void 63 | // prettier-ignore 64 | patchState< 65 | P1 extends keyof Object.Path, 66 | P2 extends keyof Object.Path, 67 | P3 extends keyof Object.Path, 68 | P4 extends keyof Object.Path, 69 | P5 extends keyof Object.Path, 70 | P6 extends keyof Object.Path, 71 | P7 extends keyof Object.Path 72 | >(value: Object.Path, part1: P1, part2: P2, part3: P3, part4: P4, part5: P5, part6: P6, part7: P7): void 73 | // prettier-ignore 74 | patchState< 75 | P1 extends keyof Object.Path, 76 | P2 extends keyof Object.Path, 77 | P3 extends keyof Object.Path, 78 | P4 extends keyof Object.Path, 79 | P5 extends keyof Object.Path, 80 | P6 extends keyof Object.Path, 81 | P7 extends keyof Object.Path, 82 | P8 extends keyof Object.Path 83 | >(value: Object.Path, part1: P1, part2: P2, part3: P3, part4: P4, part5: P5, part6: P6, part7: P7, part8: P8): void 84 | // prettier-ignore 85 | patchState< 86 | P1 extends keyof Object.Path, 87 | P2 extends keyof Object.Path, 88 | P3 extends keyof Object.Path, 89 | P4 extends keyof Object.Path, 90 | P5 extends keyof Object.Path, 91 | P6 extends keyof Object.Path, 92 | P7 extends keyof Object.Path, 93 | P8 extends keyof Object.Path, 94 | P9 extends keyof Object.Path 95 | >(value: Object.Path, part1: P1, part2: P2, part3: P3, part4: P4, part5: P5, part6: P6, part7: P7, part8: P8, part9: P9): void 96 | // prettier-ignore 97 | patchState< 98 | P1 extends keyof Object.Path, 99 | P2 extends keyof Object.Path, 100 | P3 extends keyof Object.Path, 101 | P4 extends keyof Object.Path, 102 | P5 extends keyof Object.Path, 103 | P6 extends keyof Object.Path, 104 | P7 extends keyof Object.Path, 105 | P8 extends keyof Object.Path, 106 | P9 extends keyof Object.Path, 107 | R extends Index[] 108 | >(value: Object.Path>, part1: P1, part2: P2, part3: P3, part4: P4, part5: P5, part6: P6, part7: P7, part8: P8, part9: P9, ...rest: R): void 109 | 110 | patchState(value: any, ...path: Index[]) { 111 | if (path.length < 1) { 112 | return; 113 | } 114 | this.setState(this.getUpdatedState(value, this.state, path)); 115 | } 116 | 117 | // prettier-ignore 118 | onChanges>(part1: P1): Observable>; 119 | // prettier-ignore 120 | onChanges< 121 | P1 extends keyof Object.Path, 122 | P2 extends keyof Object.Path 123 | >(part1: P1, part2: P2): Observable>; 124 | // prettier-ignore 125 | onChanges< 126 | P1 extends keyof Object.Path, 127 | P2 extends keyof Object.Path, 128 | P3 extends keyof Object.Path 129 | >(part1: P1, part2: P2, part3: P3): Observable> 130 | // prettier-ignore 131 | onChanges< 132 | P1 extends keyof Object.Path, 133 | P2 extends keyof Object.Path, 134 | P3 extends keyof Object.Path, 135 | P4 extends keyof Object.Path 136 | >(part1: P1, part2: P2, part3: P3, part4: P4): Observable> 137 | // prettier-ignore 138 | onChanges< 139 | P1 extends keyof Object.Path, 140 | P2 extends keyof Object.Path, 141 | P3 extends keyof Object.Path, 142 | P4 extends keyof Object.Path, 143 | P5 extends keyof Object.Path 144 | >(part1: P1, part2: P2, part3: P3, part4: P4, part5: P5): Observable> 145 | // prettier-ignore 146 | onChanges< 147 | P1 extends keyof Object.Path, 148 | P2 extends keyof Object.Path, 149 | P3 extends keyof Object.Path, 150 | P4 extends keyof Object.Path, 151 | P5 extends keyof Object.Path, 152 | P6 extends keyof Object.Path 153 | >(part1: P1, part2: P2, part3: P3, part4: P4, part5: P5, part6: P6): Observable> 154 | // prettier-ignore 155 | onChanges< 156 | P1 extends keyof Object.Path, 157 | P2 extends keyof Object.Path, 158 | P3 extends keyof Object.Path, 159 | P4 extends keyof Object.Path, 160 | P5 extends keyof Object.Path, 161 | P6 extends keyof Object.Path, 162 | P7 extends keyof Object.Path 163 | >(part1: P1, part2: P2, part3: P3, part4: P4, part5: P5, part6: P6, part7: P7): Observable> 164 | // prettier-ignore 165 | onChanges< 166 | P1 extends keyof Object.Path, 167 | P2 extends keyof Object.Path, 168 | P3 extends keyof Object.Path, 169 | P4 extends keyof Object.Path, 170 | P5 extends keyof Object.Path, 171 | P6 extends keyof Object.Path, 172 | P7 extends keyof Object.Path, 173 | P8 extends keyof Object.Path 174 | >(part1: P1, part2: P2, part3: P3, part4: P4, part5: P5, part6: P6, part7: P7, part8: P8): Observable> 175 | // prettier-ignore 176 | onChanges< 177 | P1 extends keyof Object.Path, 178 | P2 extends keyof Object.Path, 179 | P3 extends keyof Object.Path, 180 | P4 extends keyof Object.Path, 181 | P5 extends keyof Object.Path, 182 | P6 extends keyof Object.Path, 183 | P7 extends keyof Object.Path, 184 | P8 extends keyof Object.Path, 185 | P9 extends keyof Object.Path 186 | >(part1: P1, part2: P2, part3: P3, part4: P4, part5: P5, part6: P6, part7: P7, part8: P8, part9: P9): Observable> 187 | // prettier-ignore 188 | onChanges< 189 | P1 extends keyof Object.Path, 190 | P2 extends keyof Object.Path, 191 | P3 extends keyof Object.Path, 192 | P4 extends keyof Object.Path, 193 | P5 extends keyof Object.Path, 194 | P6 extends keyof Object.Path, 195 | P7 extends keyof Object.Path, 196 | P8 extends keyof Object.Path, 197 | P9 extends keyof Object.Path, 198 | R extends Index[] 199 | >(part1: P1, part2: P2, part3: P3, part4: P4, part5: P5, part6: P6, part7: P7, part8: P8, part9: P9, ...rest: R): Observable>> 200 | 201 | onChanges(...path: Index[]) { 202 | return this.state$.pipe( 203 | map(state => 204 | path.reduce((result, part) => { 205 | if (result === undefined || result === null) { 206 | return undefined; 207 | } 208 | return result[part]; 209 | }, state) 210 | ), 211 | distinctUntilChanged() 212 | ); 213 | } 214 | 215 | private getUpdatedState(value: any, stateSubtree: any, path: Index[]): any { 216 | const key = path[0]; 217 | if (path.length === 1) { 218 | return { 219 | ...stateSubtree, 220 | [key]: value, 221 | }; 222 | } 223 | if (stateSubtree[key] === undefined || stateSubtree[key] === null) { 224 | return { 225 | ...stateSubtree, 226 | [key]: this.createStateSubtree(value, path.slice(1)), 227 | }; 228 | } 229 | return { 230 | ...stateSubtree, 231 | [key]: this.getUpdatedState( 232 | value, 233 | stateSubtree[key], 234 | path.slice(1) 235 | ), 236 | }; 237 | } 238 | 239 | private createStateSubtree(value: any, path: Index[]): any { 240 | const key = path[0]; 241 | if (path.length === 1) { 242 | return { 243 | [key]: value, 244 | }; 245 | } 246 | return { 247 | [key]: this.createStateSubtree(value, path.slice(1)), 248 | }; 249 | } 250 | } 251 | -------------------------------------------------------------------------------- /tsconfig-cjs.json: -------------------------------------------------------------------------------- 1 | { 2 | "extends": "./tsconfig.json", 3 | "compilerOptions": { 4 | "module": "CommonJS", 5 | "outDir": "./lib/cjs" 6 | } 7 | } 8 | -------------------------------------------------------------------------------- /tsconfig.json: -------------------------------------------------------------------------------- 1 | { 2 | "compilerOptions": { 3 | "target": "ES5", 4 | "module": "ES2015", 5 | "moduleResolution": "Node", 6 | "declaration": true, 7 | "outDir": "./lib/esm", 8 | "strict": false 9 | }, 10 | "include": [ 11 | "src/index.ts" 12 | ] 13 | } 14 | --------------------------------------------------------------------------------