├── .eslintrc ├── .github └── workflows │ └── codeql-analysis.yml ├── .gitignore ├── .npmignore ├── .travis.yml ├── README.md ├── index.d.ts ├── lib └── index.js ├── package-lock.json ├── package.json └── test ├── .eslintrc ├── dot-prop-immutable-merge.spec.js ├── dot-prop-immutable-number.spec.js ├── dot-prop-immutable-toggle.spec.js ├── dot-prop-immutable.spec.js ├── eslint.spec.js ├── examples.spec.js ├── globals.js └── mocha.opts /.eslintrc: -------------------------------------------------------------------------------- 1 | { 2 | "extends": "@debitoor/eslint-config-debitoor", 3 | "env": { 4 | "node": true, 5 | } 6 | } -------------------------------------------------------------------------------- /.github/workflows/codeql-analysis.yml: -------------------------------------------------------------------------------- 1 | # For most projects, this workflow file will not need changing; you simply need 2 | # to commit it to your repository. 3 | # 4 | # You may wish to alter this file to override the set of languages analyzed, 5 | # or to provide custom queries or build logic. 6 | # 7 | # ******** NOTE ******** 8 | # We have attempted to detect the languages in your repository. Please check 9 | # the `language` matrix defined below to confirm you have the correct set of 10 | # supported CodeQL languages. 11 | # 12 | name: "CodeQL" 13 | 14 | on: 15 | push: 16 | branches: [ master ] 17 | pull_request: 18 | # The branches below must be a subset of the branches above 19 | branches: [ master ] 20 | schedule: 21 | - cron: '27 8 * * 3' 22 | 23 | jobs: 24 | analyze: 25 | name: Analyze 26 | runs-on: ubuntu-latest 27 | 28 | strategy: 29 | fail-fast: false 30 | matrix: 31 | language: [ 'javascript' ] 32 | # CodeQL supports [ 'cpp', 'csharp', 'go', 'java', 'javascript', 'python' ] 33 | # Learn more: 34 | # https://docs.github.com/en/free-pro-team@latest/github/finding-security-vulnerabilities-and-errors-in-your-code/configuring-code-scanning#changing-the-languages-that-are-analyzed 35 | 36 | steps: 37 | - name: Checkout repository 38 | uses: actions/checkout@v2 39 | 40 | # Initializes the CodeQL tools for scanning. 41 | - name: Initialize CodeQL 42 | uses: github/codeql-action/init@v1 43 | with: 44 | languages: ${{ matrix.language }} 45 | # If you wish to specify custom queries, you can do so here or in a config file. 46 | # By default, queries listed here will override any specified in a config file. 47 | # Prefix the list here with "+" to use these queries and those in the config file. 48 | # queries: ./path/to/local/query, your-org/your-repo/queries@main 49 | 50 | # Autobuild attempts to build any compiled languages (C/C++, C#, or Java). 51 | # If this step fails, then you should remove it and run the build manually (see below) 52 | - name: Autobuild 53 | uses: github/codeql-action/autobuild@v1 54 | 55 | # ℹ️ Command-line programs to run using the OS shell. 56 | # 📚 https://git.io/JvXDl 57 | 58 | # ✏️ If the Autobuild fails above, remove it and uncomment the following three lines 59 | # and modify them (or add more) to build your code if your project 60 | # uses a compiled language 61 | 62 | #- run: | 63 | # make bootstrap 64 | # make release 65 | 66 | - name: Perform CodeQL Analysis 67 | uses: github/codeql-action/analyze@v1 68 | -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | node_modules 2 | .DS_Store 3 | .idea 4 | npm-debug.log 5 | -------------------------------------------------------------------------------- /.npmignore: -------------------------------------------------------------------------------- 1 | test/ 2 | .gitignore 3 | .eslintrc 4 | .travis.yml -------------------------------------------------------------------------------- /.travis.yml: -------------------------------------------------------------------------------- 1 | language: node_js 2 | node_js: 3 | - 6 4 | - 8 5 | - 10 6 | - 12 7 | - lts/* # most recent lts 8 | - node # latest -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # dot-prop-immutable 2 | 3 | [![npm version](https://badge.fury.io/js/dot-prop-immutable.svg)](https://badge.fury.io/js/dot-prop-immutable) [![Build Status](https://travis-ci.com/debitoor/dot-prop-immutable.svg?branch=master)](https://travis-ci.com/debitoor/dot-prop-immutable) [![CodeQL](https://github.com/debitoor/dot-prop-immutable/actions/workflows/codeql-analysis.yml/badge.svg)](https://github.com/debitoor/dot-prop-immutable/actions/workflows/codeql-analysis.yml) 4 | 5 | > [!IMPORTANT] 6 | > **Unmaintained lib and repository.** If anybody would like to take ownership of the library, please get in touch! 7 | 8 | Immutable version of dot-prop with some extensions. 9 | 10 | ```bash 11 | npm install dot-prop-immutable 12 | ``` 13 | 14 | The motivation for this module is to have a simple utility for changing state in a React-Redux application without mutating the existing state of plain JavaScript objects. 15 | If you are going for real immutable data collections take a look at the cool library [Immutable.js](https://github.com/facebook/immutable-js). 16 | A good practice is not to mix the immutable data collections with mutable objects because it can lead to confusion. Immutable objects are not accessed by the default semantics, but implemented by setters and getters. 17 | 18 | This library implements 3 helper functions: 19 | 20 | ```bash 21 | get(object, path) --> value 22 | set(object, path, value) --> object 23 | delete(object, path) --> object 24 | ``` 25 | 26 | None of the functions mutate the input object. For efficiency, the returned object is not a deep clone of the original, but a shallow copy of the objects in the mutated path. 27 | 28 | ## Usage 29 | 30 | ```javascript 31 | const dotProp = require('dot-prop-immutable'); 32 | let state = { todos: [] }, index = 0; 33 | 34 | // Add todo: 35 | state = dotProp.set(state, 'todos', list => [...list, {text: 'cleanup', complete: false}]) 36 | // or with destructuring assignment 37 | state = {...state, todos: [...state.todos, {text: 'cleanup', complete: false}]}; 38 | //=> { todos: [{text: 'cleanup', complete: false}] } 39 | 40 | // Complete todo: 41 | state = dotProp.set(state, `todos.${index}.complete`, true) 42 | // or with destructuring assignment 43 | state = {...state, todos: [ 44 | ...state.todos.slice(0, index), 45 | {...state.todos[index], complete: true}, 46 | ...state.todos.slice(index + 1) 47 | ]}; 48 | //=> { todos: [{text: 'cleanup', complete: true}] } 49 | 50 | // Delete todo: 51 | state = dotProp.delete(state, `todos.${index}`) 52 | // or with destructuring assignment 53 | state = {...state, todos: [ 54 | ...state.todos.slice(0, index), 55 | ...state.todos.slice(index + 1) 56 | ]}; 57 | //=> { todos: [] } 58 | ``` 59 | ### get 60 | 61 | Access a nested property by a dot path 62 | 63 | ```javascript 64 | // Getter 65 | dotProp.get({foo: {bar: 'unicorn'}}, 'foo.bar') 66 | //=> 'unicorn' 67 | 68 | dotProp.get({foo: {bar: 'a'}}, 'foo.notDefined.deep') 69 | //=> undefined 70 | 71 | dotProp.get({foo: {bar: 'a'}}, 'foo.notDefined.deep', 'default value') 72 | //=> default value 73 | 74 | dotProp.get({foo: {'dot.dot': 'unicorn'}}, 'foo.dot\\.dot') 75 | //=> 'unicorn' 76 | ``` 77 | 78 | 79 | or use a property array as a path. 80 | 81 | ```javascript 82 | // Use an array as get path 83 | dotProp.get({foo: {'dot.dot': 'unicorn'}}, ['foo', 'dot.dot']) 84 | //=> 'unicorn' 85 | ``` 86 | 87 | 88 | It is also possible to index into an array where the special index `$end` refers to the last element of the array. 89 | 90 | ```javascript 91 | const obj = {foo: [{ bar: 'gold-unicorn'}, 'white-unicorn', 'silver-unicorn']}; 92 | 93 | // Index into array 94 | dotProp.get(obj, 'foo.1') 95 | //=> 'white-unicorn' 96 | 97 | dotProp.get(obj, 'foo.0.bar') 98 | //=> 'gold-unicorn' 99 | 100 | // Index into array with $end 101 | dotProp.get(obj, 'foo.$end') 102 | //=> 'silver-unicorn' 103 | 104 | // If obj is an array 105 | dotProp.get([{ bar: 'gold-unicorn'}, 'white-unicorn', 'silver-unicorn'], '0.bar') 106 | //=> 'gold-unicorn' 107 | 108 | ``` 109 | 110 | 111 | ### set 112 | 113 | Modify a nested property by a dot path 114 | 115 | ```javascript 116 | // Setter 117 | const obj = {foo: {bar: 'a'}}; 118 | 119 | const obj1 = dotProp.set(obj, 'foo.bar', 'b'); 120 | //obj1 => {foo: {bar: 'b'}} 121 | 122 | const obj2 = dotProp.set(obj1 , 'foo.baz', 'x'); 123 | //obj2 => {foo: {bar: 'b', baz: 'x'}} 124 | ``` 125 | 126 | where `obj`, `obj1`, `obj2`, `obj3` all are different objects. 127 | 128 | 129 | 130 | Use a function to modify the selected property, where first argument is the old value. 131 | 132 | ```javascript 133 | // Setter where value is a function (get and set current value) 134 | dotProp.set({foo: {bar: 'a'}}, 'foo.bar', v => v + 'bc') 135 | //=> {foo: {bar: 'abc'}} 136 | ``` 137 | 138 | 139 | Modify a nested array 140 | 141 | ```javascript 142 | const obj = {foo: [{ bar: 'gold-unicorn'}, 'white-unicorn', 'silver-unicorn']}; 143 | 144 | // Index into array 145 | dotProp.set(obj, 'foo.1', 'platin-unicorn') 146 | //=> {foo: [{bar: 'gold-unicorn'}, 'platin-unicorn', 'silver-unicorn']} 147 | 148 | dotProp.set(obj, 'foo.0.bar', 'platin-unicorn') 149 | //=> {foo: [{bar: 'platin-unicorn'}, 'white-unicorn', 'silver-unicorn']} 150 | 151 | // Index into array with $end 152 | dotProp.set(obj, 'foo.$end', 'platin-unicorn') 153 | //=> {foo: [{ bar: 'gold-unicorn'}, 'white-unicorn', 'platin-unicorn']} 154 | 155 | ``` 156 | 157 | 158 | ### delete 159 | 160 | Delete a nested property/array by a dot path 161 | 162 | ```javascript 163 | const obj = {foo: [{ bar: 'gold-unicorn'}, 'white-unicorn', 'silver-unicorn']}; 164 | 165 | // delete 166 | dotProp.delete(obj, 'foo.$end'); 167 | //=> {foo: [{ bar: 'gold-unicorn'}, 'white-unicorn']} 168 | 169 | dotProp.delete(obj, 'foo.0.bar'); 170 | //=> {foo: [{}, 'white-unicorn', 'silver-unicorn']} 171 | ``` 172 | 173 | ### toggle 174 | 175 | Toggle a boolean a value by a dot path. 176 | 177 | ```javascript 178 | const obj = {foo: { bar: true } }; 179 | 180 | // toggle 181 | dotProp.toggle(obj, 'foo.bar'); 182 | //=> {foo: { bar: false } } 183 | ``` 184 | ### merge 185 | 186 | Merge a value by a dot path. 187 | > The target value must be an object, array, null, or undefined. 188 | 189 | * If target is an object, Object.assign({}, target, param) is used. 190 | * If target an array, target.concat(param) is used. 191 | * If target is null or undefined, the value is simply set. 192 | 193 | ```javascript 194 | const obj = {foo: { bar: {a:1, b:2 } }; 195 | 196 | // merge object 197 | dotProp.merge(obj, 'foo.bar', {c:3} ); 198 | //=> {foo: { bar:{ a:1, b:2, c:3} } } 199 | 200 | var arr = {foo: { bar: [1, 2] } }; 201 | 202 | // merge array 203 | dotProp.merge(arr, 'foo.bar', [3, 4] ); 204 | //=> {foo: { bar:[1, 2, 3, 4 ] } 205 | ``` 206 | ## License 207 | 208 | [MIT](http://opensource.org/licenses/MIT) 209 | -------------------------------------------------------------------------------- /index.d.ts: -------------------------------------------------------------------------------- 1 | interface DotPropImmutable { 2 | get(source: I, path: number | string | (string | number)[], defaultValue?: any): T; 3 | set(source: I, path: number | string | (string | number)[], value: any): T; 4 | delete(source: I, path: number | string | (string | number)[]): Partial; 5 | toggle(source: I, path: number | string | (string | number)[]): T; 6 | merge(source: I, path: number | string | (string | number)[], value: any): T; 7 | } 8 | 9 | declare const dotPropImmutable: DotPropImmutable; 10 | 11 | export = dotPropImmutable; 12 | -------------------------------------------------------------------------------- /lib/index.js: -------------------------------------------------------------------------------- 1 | /** 2 | * Set a value by a dot path. 3 | * @param obj The object to evaluate. 4 | * @param prop The path to be set. 5 | * @param value The value to set. 6 | */ 7 | function set(obj, prop, value) { 8 | prop = typeof prop === 'number' ? propToArray(prop.toString()) : typeof prop === 'string' ? propToArray(prop) : prop; 9 | 10 | const setPropImmutableRec = (obj, prop, value, i) => { 11 | let clone, head = prop[i]; 12 | 13 | if (prop.length > i) { 14 | if (Array.isArray(obj)) { 15 | head = getArrayIndex(head, obj); 16 | clone = obj.slice(); 17 | } else { 18 | clone = Object.assign({}, obj); 19 | } 20 | clone[head] = setPropImmutableRec(obj[head] !== undefined ? obj[head] : {}, prop, value, i + 1); 21 | return clone; 22 | } 23 | 24 | return typeof value === 'function' ? value(obj) : value; 25 | }; 26 | 27 | return setPropImmutableRec(obj, prop, value, 0); 28 | } 29 | 30 | /** 31 | * Get a value by a dot path. 32 | * @param obj The object to evaluate. 33 | * @param prop The path to value that should be returned. 34 | * @param [value] The default value that should be returned when the target doesn't exist. 35 | */ 36 | function get(obj, prop, value) { 37 | prop = typeof prop === 'number' ? propToArray(prop.toString()) : typeof prop === 'string' ? propToArray(prop) : prop; 38 | 39 | for (var i = 0; i < prop.length; i++) { 40 | if (obj === null || typeof obj !== 'object') { 41 | return value; 42 | } 43 | let head = prop[i]; 44 | if (Array.isArray(obj) && head === '$end') { 45 | head = obj.length - 1; 46 | } 47 | obj = obj[head]; 48 | } 49 | 50 | if (typeof obj === 'undefined') { 51 | return value; 52 | } 53 | 54 | return obj; 55 | } 56 | 57 | /** 58 | * Delete a property by a dot path. 59 | * If target container is an object, the property is deleted. 60 | * If target container is an array, the index is deleted. 61 | * If target container is undefined, nothing is deleted. 62 | * @param obj The object to evaluate. 63 | * @param prop The path to the property or index that should be deleted. 64 | */ 65 | function _delete(obj, prop) { 66 | prop = typeof prop === 'number' ? propToArray(prop.toString()) : typeof prop === 'string' ? propToArray(prop) : prop; 67 | 68 | const deletePropImmutableRec = (obj, prop, i) => { 69 | let clone, head = prop[i]; 70 | 71 | if (obj === null || typeof obj !== 'object' || 72 | !Array.isArray(obj) && obj[head] === undefined) { 73 | 74 | return obj; 75 | } 76 | 77 | if (prop.length - 1 > i) { 78 | if (Array.isArray(obj)) { 79 | head = getArrayIndex(head, obj); 80 | clone = obj.slice(); 81 | } else { 82 | clone = Object.assign({}, obj); 83 | } 84 | 85 | clone[head] = deletePropImmutableRec(obj[head], prop, i + 1); 86 | return clone; 87 | } 88 | 89 | if (Array.isArray(obj)) { 90 | head = getArrayIndex(head, obj); 91 | clone = [].concat(obj.slice(0, head), obj.slice(head + 1)); 92 | } else { 93 | clone = Object.assign({}, obj); 94 | delete clone[head]; 95 | } 96 | 97 | return clone; 98 | }; 99 | 100 | return deletePropImmutableRec(obj, prop, 0); 101 | } 102 | 103 | /** 104 | * Toggles a value. The target value is evaluated using Boolean(currentValue). The result will always be a JSON boolean. 105 | * Be careful with strings as target value, as "true" and "false" will toggle to false, but "0" will toggle to true. 106 | * Here is what Javascript considers false: 0, -0, null, false, NaN, undefined, and the empty string ("") 107 | * @param obj The object to evaluate. 108 | * @param prop The path to the value. 109 | */ 110 | function toggle(obj, prop) { 111 | const curVal = get(obj, prop); 112 | return set(obj, prop, !Boolean(curVal)); 113 | } 114 | 115 | /** 116 | * Merges a value. The target value must be an object, array, null, or undefined. 117 | * If target is an object, Object.assign({}, target, param) is used. 118 | * If target an array, target.concat(param) is used. 119 | * If target is null or undefined, the value is simply set. 120 | * @param obj The object to evaluate. 121 | * @param prop The path to the value. 122 | * @param val The value to merge into the target value. 123 | */ 124 | function merge(obj, prop, val) { 125 | const curVal = get(obj, prop); 126 | if (typeof curVal === 'object') { 127 | if (Array.isArray(curVal)) { 128 | return set(obj, prop, curVal.concat(val)); 129 | } else if (curVal === null) { 130 | return set(obj, prop, val); 131 | } 132 | else { 133 | let merged = Object.assign({}, curVal, val); 134 | return set(obj, prop, merged); 135 | } 136 | } else if (typeof curVal === 'undefined') { 137 | return set(obj, prop, val); 138 | } 139 | else { 140 | return obj; 141 | } 142 | } 143 | 144 | function getArrayIndex(head, obj) { 145 | if (head === '$end') { 146 | head = Math.max(obj.length - 1, 0); 147 | } 148 | if (!/^\+?\d+$/.test(head)) { 149 | throw new Error(`Array index '${head}' has to be an integer`); 150 | } 151 | return parseInt(head); 152 | } 153 | 154 | function propToArray(prop) { 155 | return prop.split('.').reduce((ret, el, index, list) => { 156 | const last = index > 0 && list[index - 1]; 157 | if (last && /(?:^|[^\\])\\$/.test(last)) { 158 | const prev = ret.pop(); 159 | ret.push(prev.slice(0, -1) + '.' + el); 160 | } else { 161 | ret.push(el); 162 | } 163 | return ret; 164 | }, []); 165 | } 166 | 167 | module.exports = { 168 | set, 169 | get, 170 | delete: _delete, 171 | toggle, 172 | merge 173 | }; 174 | -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "dot-prop-immutable", 3 | "version": "2.1.1", 4 | "lockfileVersion": 1, 5 | "requires": true, 6 | "dependencies": { 7 | "@babel/code-frame": { 8 | "version": "7.5.5", 9 | "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.5.5.tgz", 10 | "integrity": "sha512-27d4lZoomVyo51VegxI20xZPuSHusqbQag/ztrBC7wegWoQ1nLREPVSKSW8byhTlzTKyNE4ifaTA6lCp7JjpFw==", 11 | "dev": true, 12 | "requires": { 13 | "@babel/highlight": "^7.0.0" 14 | } 15 | }, 16 | "@babel/highlight": { 17 | "version": "7.5.0", 18 | "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.5.0.tgz", 19 | "integrity": "sha512-7dV4eu9gBxoM0dAnj/BCFDW9LFU0zvTrkq0ugM7pnHEgguOEeOz1so2ZghEdzviYzQEED0r4EAgpsBChKy1TRQ==", 20 | "dev": true, 21 | "requires": { 22 | "chalk": "^2.0.0", 23 | "esutils": "^2.0.2", 24 | "js-tokens": "^4.0.0" 25 | } 26 | }, 27 | "@debitoor/eslint-config-debitoor": { 28 | "version": "3.0.2", 29 | "resolved": "https://registry.npmjs.org/@debitoor/eslint-config-debitoor/-/eslint-config-debitoor-3.0.2.tgz", 30 | "integrity": "sha512-ht3i49IsJjZtXaeT98INkhtq0kOmpLWFSKixOIR2IBtqTz9TmE8SmMXdK5WqOTQ7fl51w3vRofjmmncB0wYJZQ==", 31 | "dev": true 32 | }, 33 | "acorn": { 34 | "version": "7.1.1", 35 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-7.1.1.tgz", 36 | "integrity": "sha512-add7dgA5ppRPxCFJoAGfMDi7PIBXq1RtGo7BhbLaxwrXPOmw8gq48Y9ozT01hUKy9byMjlR20EJhu5zlkErEkg==", 37 | "dev": true 38 | }, 39 | "acorn-jsx": { 40 | "version": "5.0.2", 41 | "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.0.2.tgz", 42 | "integrity": "sha512-tiNTrP1MP0QrChmD2DdupCr6HWSFeKVw5d/dHTu4Y7rkAkRhU/Dt7dphAfIUyxtHpl/eBVip5uTNSpQJHylpAw==", 43 | "dev": true 44 | }, 45 | "ajv": { 46 | "version": "6.10.2", 47 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.10.2.tgz", 48 | "integrity": "sha512-TXtUUEYHuaTEbLZWIKUr5pmBuhDLy+8KYtPYdcV8qC+pOZL+NKqYwvWSRrVXHn+ZmRRAu8vJTAznH7Oag6RVRw==", 49 | "dev": true, 50 | "requires": { 51 | "fast-deep-equal": "^2.0.1", 52 | "fast-json-stable-stringify": "^2.0.0", 53 | "json-schema-traverse": "^0.4.1", 54 | "uri-js": "^4.2.2" 55 | } 56 | }, 57 | "ansi-colors": { 58 | "version": "3.2.3", 59 | "resolved": "https://registry.npmjs.org/ansi-colors/-/ansi-colors-3.2.3.tgz", 60 | "integrity": "sha512-LEHHyuhlPY3TmuUYMh2oz89lTShfvgbmzaBcxve9t/9Wuy7Dwf4yoAKcND7KFT1HAQfqZ12qtc+DUrBMeKF9nw==", 61 | "dev": true 62 | }, 63 | "ansi-escapes": { 64 | "version": "4.2.1", 65 | "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-4.2.1.tgz", 66 | "integrity": "sha512-Cg3ymMAdN10wOk/VYfLV7KCQyv7EDirJ64500sU7n9UlmioEtDuU5Gd+hj73hXSU/ex7tHJSssmyftDdkMLO8Q==", 67 | "dev": true, 68 | "requires": { 69 | "type-fest": "^0.5.2" 70 | } 71 | }, 72 | "ansi-regex": { 73 | "version": "3.0.0", 74 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-3.0.0.tgz", 75 | "integrity": "sha1-7QMXwyIGT3lGbAKWa922Bas32Zg=", 76 | "dev": true 77 | }, 78 | "ansi-styles": { 79 | "version": "3.2.1", 80 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 81 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 82 | "dev": true, 83 | "requires": { 84 | "color-convert": "^1.9.0" 85 | } 86 | }, 87 | "argparse": { 88 | "version": "1.0.10", 89 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.10.tgz", 90 | "integrity": "sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg==", 91 | "dev": true, 92 | "requires": { 93 | "sprintf-js": "~1.0.2" 94 | } 95 | }, 96 | "assertion-error": { 97 | "version": "1.1.0", 98 | "resolved": "https://registry.npmjs.org/assertion-error/-/assertion-error-1.1.0.tgz", 99 | "integrity": "sha512-jgsaNduz+ndvGyFt3uSuWqvy4lCnIJiovtouQN5JZHOKCS2QuhEdbcQHFhVksz2N2U9hXJo8odG7ETyWlEeuDw==", 100 | "dev": true 101 | }, 102 | "astral-regex": { 103 | "version": "1.0.0", 104 | "resolved": "https://registry.npmjs.org/astral-regex/-/astral-regex-1.0.0.tgz", 105 | "integrity": "sha512-+Ryf6g3BKoRc7jfp7ad8tM4TtMiaWvbF/1/sQcZPkkS7ag3D5nMBCe2UfOTONtAkaG0tO0ij3C5Lwmf1EiyjHg==", 106 | "dev": true 107 | }, 108 | "balanced-match": { 109 | "version": "1.0.0", 110 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz", 111 | "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=", 112 | "dev": true 113 | }, 114 | "brace-expansion": { 115 | "version": "1.1.11", 116 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 117 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 118 | "dev": true, 119 | "requires": { 120 | "balanced-match": "^1.0.0", 121 | "concat-map": "0.0.1" 122 | } 123 | }, 124 | "browser-stdout": { 125 | "version": "1.3.1", 126 | "resolved": "https://registry.npmjs.org/browser-stdout/-/browser-stdout-1.3.1.tgz", 127 | "integrity": "sha512-qhAVI1+Av2X7qelOfAIYwXONood6XlZE/fXaBSmW/T5SzLAmCgzi+eiWE7fUvbHaeNBQH13UftjpXxsfLkMpgw==", 128 | "dev": true 129 | }, 130 | "callsites": { 131 | "version": "3.1.0", 132 | "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", 133 | "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==", 134 | "dev": true 135 | }, 136 | "camelcase": { 137 | "version": "5.3.1", 138 | "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-5.3.1.tgz", 139 | "integrity": "sha512-L28STB170nwWS63UjtlEOE3dldQApaJXZkOI1uMFfzf3rRuPegHaHesyee+YxQ+W6SvRDQV6UrdOdRiR153wJg==", 140 | "dev": true 141 | }, 142 | "chai": { 143 | "version": "4.2.0", 144 | "resolved": "https://registry.npmjs.org/chai/-/chai-4.2.0.tgz", 145 | "integrity": "sha512-XQU3bhBukrOsQCuwZndwGcCVQHyZi53fQ6Ys1Fym7E4olpIqqZZhhoFJoaKVvV17lWQoXYwgWN2nF5crA8J2jw==", 146 | "dev": true, 147 | "requires": { 148 | "assertion-error": "^1.1.0", 149 | "check-error": "^1.0.2", 150 | "deep-eql": "^3.0.1", 151 | "get-func-name": "^2.0.0", 152 | "pathval": "^1.1.0", 153 | "type-detect": "^4.0.5" 154 | }, 155 | "dependencies": { 156 | "pathval": { 157 | "version": "1.1.0", 158 | "resolved": "https://registry.npmjs.org/pathval/-/pathval-1.1.0.tgz", 159 | "integrity": "sha1-uULm1L3mUwBe9rcTYd74cn0GReA=", 160 | "dev": true 161 | } 162 | } 163 | }, 164 | "chalk": { 165 | "version": "2.4.2", 166 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", 167 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", 168 | "dev": true, 169 | "requires": { 170 | "ansi-styles": "^3.2.1", 171 | "escape-string-regexp": "^1.0.5", 172 | "supports-color": "^5.3.0" 173 | }, 174 | "dependencies": { 175 | "supports-color": { 176 | "version": "5.5.0", 177 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 178 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 179 | "dev": true, 180 | "requires": { 181 | "has-flag": "^3.0.0" 182 | } 183 | } 184 | } 185 | }, 186 | "chardet": { 187 | "version": "0.7.0", 188 | "resolved": "https://registry.npmjs.org/chardet/-/chardet-0.7.0.tgz", 189 | "integrity": "sha512-mT8iDcrh03qDGRRmoA2hmBJnxpllMR+0/0qlzjqZES6NdiWDcZkCNAk4rPFZ9Q85r27unkiNNg8ZOiwZXBHwcA==", 190 | "dev": true 191 | }, 192 | "check-error": { 193 | "version": "1.0.2", 194 | "resolved": "https://registry.npmjs.org/check-error/-/check-error-1.0.2.tgz", 195 | "integrity": "sha1-V00xLt2Iu13YkS6Sht1sCu1KrII=", 196 | "dev": true 197 | }, 198 | "cli-cursor": { 199 | "version": "3.1.0", 200 | "resolved": "https://registry.npmjs.org/cli-cursor/-/cli-cursor-3.1.0.tgz", 201 | "integrity": "sha512-I/zHAwsKf9FqGoXM4WWRACob9+SNukZTd94DWF57E4toouRulbCxcUh6RKUEOQlYTHJnzkPMySvPNaaSLNfLZw==", 202 | "dev": true, 203 | "requires": { 204 | "restore-cursor": "^3.1.0" 205 | } 206 | }, 207 | "cli-width": { 208 | "version": "2.2.0", 209 | "resolved": "https://registry.npmjs.org/cli-width/-/cli-width-2.2.0.tgz", 210 | "integrity": "sha1-/xnt6Kml5XkyQUewwR8PvLq+1jk=", 211 | "dev": true 212 | }, 213 | "cliui": { 214 | "version": "6.0.0", 215 | "resolved": "https://registry.npmjs.org/cliui/-/cliui-6.0.0.tgz", 216 | "integrity": "sha512-t6wbgtoCXvAzst7QgXxJYqPt0usEfbgQdftEPbLL/cvv6HPE5VgvqCuAIDR0NgU52ds6rFwqrgakNLrHEjCbrQ==", 217 | "dev": true, 218 | "requires": { 219 | "string-width": "^4.2.0", 220 | "strip-ansi": "^6.0.0", 221 | "wrap-ansi": "^6.2.0" 222 | }, 223 | "dependencies": { 224 | "ansi-regex": { 225 | "version": "5.0.0", 226 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.0.tgz", 227 | "integrity": "sha512-bY6fj56OUQ0hU1KjFNDQuJFezqKdrAyFdIevADiqrWHwSlbmBNMHp5ak2f40Pm8JTFyM2mqxkG6ngkHO11f/lg==", 228 | "dev": true 229 | }, 230 | "ansi-styles": { 231 | "version": "4.3.0", 232 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", 233 | "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", 234 | "dev": true, 235 | "requires": { 236 | "color-convert": "^2.0.1" 237 | } 238 | }, 239 | "color-convert": { 240 | "version": "2.0.1", 241 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", 242 | "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", 243 | "dev": true, 244 | "requires": { 245 | "color-name": "~1.1.4" 246 | } 247 | }, 248 | "color-name": { 249 | "version": "1.1.4", 250 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", 251 | "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", 252 | "dev": true 253 | }, 254 | "emoji-regex": { 255 | "version": "8.0.0", 256 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 257 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 258 | "dev": true 259 | }, 260 | "is-fullwidth-code-point": { 261 | "version": "3.0.0", 262 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 263 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 264 | "dev": true 265 | }, 266 | "string-width": { 267 | "version": "4.2.2", 268 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.2.tgz", 269 | "integrity": "sha512-XBJbT3N4JhVumXE0eoLU9DCjcaF92KLNqTmFCnG1pf8duUxFGwtP6AD6nkjw9a3IdiRtL3E2w3JDiE/xi3vOeA==", 270 | "dev": true, 271 | "requires": { 272 | "emoji-regex": "^8.0.0", 273 | "is-fullwidth-code-point": "^3.0.0", 274 | "strip-ansi": "^6.0.0" 275 | } 276 | }, 277 | "strip-ansi": { 278 | "version": "6.0.0", 279 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.0.tgz", 280 | "integrity": "sha512-AuvKTrTfQNYNIctbR1K/YGTR1756GycPsg7b9bdV9Duqur4gv6aKqHXah67Z8ImS7WEz5QVcOtlfW2rZEugt6w==", 281 | "dev": true, 282 | "requires": { 283 | "ansi-regex": "^5.0.0" 284 | } 285 | }, 286 | "wrap-ansi": { 287 | "version": "6.2.0", 288 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-6.2.0.tgz", 289 | "integrity": "sha512-r6lPcBGxZXlIcymEu7InxDMhdW0KDxpLgoFLcguasxCaJ/SOIZwINatK9KY/tf+ZrlywOKU0UDj3ATXUBfxJXA==", 290 | "dev": true, 291 | "requires": { 292 | "ansi-styles": "^4.0.0", 293 | "string-width": "^4.1.0", 294 | "strip-ansi": "^6.0.0" 295 | } 296 | } 297 | } 298 | }, 299 | "code-point-at": { 300 | "version": "1.1.0", 301 | "resolved": "https://registry.npmjs.org/code-point-at/-/code-point-at-1.1.0.tgz", 302 | "integrity": "sha1-DQcLTQQ6W+ozovGkDi7bPZpMz3c=", 303 | "dev": true 304 | }, 305 | "color-convert": { 306 | "version": "1.9.3", 307 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", 308 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", 309 | "dev": true, 310 | "requires": { 311 | "color-name": "1.1.3" 312 | } 313 | }, 314 | "color-name": { 315 | "version": "1.1.3", 316 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 317 | "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=", 318 | "dev": true 319 | }, 320 | "concat-map": { 321 | "version": "0.0.1", 322 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 323 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=", 324 | "dev": true 325 | }, 326 | "cross-spawn": { 327 | "version": "6.0.5", 328 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-6.0.5.tgz", 329 | "integrity": "sha512-eTVLrBSt7fjbDygz805pMnstIs2VTBNkRm0qxZd+M7A5XDdxVRWO5MxGBXZhjY4cqLYLdtrGqRf8mBPmzwSpWQ==", 330 | "dev": true, 331 | "requires": { 332 | "nice-try": "^1.0.4", 333 | "path-key": "^2.0.1", 334 | "semver": "^5.5.0", 335 | "shebang-command": "^1.2.0", 336 | "which": "^1.2.9" 337 | } 338 | }, 339 | "debug": { 340 | "version": "3.2.6", 341 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.6.tgz", 342 | "integrity": "sha512-mel+jf7nrtEl5Pn1Qx46zARXKDpBbvzezse7p7LqINmdoIk8PYP5SySaxEmYv6TZ0JyEKA1hsCId6DIhgITtWQ==", 343 | "dev": true, 344 | "requires": { 345 | "ms": "^2.1.1" 346 | } 347 | }, 348 | "decamelize": { 349 | "version": "1.2.0", 350 | "resolved": "https://registry.npmjs.org/decamelize/-/decamelize-1.2.0.tgz", 351 | "integrity": "sha1-9lNNFRSCabIDUue+4m9QH5oZEpA=", 352 | "dev": true 353 | }, 354 | "deep-eql": { 355 | "version": "3.0.1", 356 | "resolved": "https://registry.npmjs.org/deep-eql/-/deep-eql-3.0.1.tgz", 357 | "integrity": "sha512-+QeIQyN5ZuO+3Uk5DYh6/1eKO0m0YmJFGNmFHGACpf1ClL1nmlV/p4gNgbl2pJGxgXb4faqo6UE+M5ACEMyVcw==", 358 | "dev": true, 359 | "requires": { 360 | "type-detect": "^4.0.0" 361 | } 362 | }, 363 | "deep-is": { 364 | "version": "0.1.3", 365 | "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.3.tgz", 366 | "integrity": "sha1-s2nW+128E+7PUk+RsHD+7cNXzzQ=", 367 | "dev": true 368 | }, 369 | "define-properties": { 370 | "version": "1.1.3", 371 | "resolved": "https://registry.npmjs.org/define-properties/-/define-properties-1.1.3.tgz", 372 | "integrity": "sha512-3MqfYKj2lLzdMSf8ZIZE/V+Zuy+BgD6f164e8K2w7dgnpKArBDerGYpM46IYYcjnkdPNMjPk9A6VFB8+3SKlXQ==", 373 | "dev": true, 374 | "requires": { 375 | "object-keys": "^1.0.12" 376 | } 377 | }, 378 | "diff": { 379 | "version": "3.5.0", 380 | "resolved": "https://registry.npmjs.org/diff/-/diff-3.5.0.tgz", 381 | "integrity": "sha512-A46qtFgd+g7pDZinpnwiRJtxbC1hpgf0uzP3iG89scHk0AUC7A1TGxf5OiiOUv/JMZR8GOt8hL900hV0bOy5xA==", 382 | "dev": true 383 | }, 384 | "doctrine": { 385 | "version": "3.0.0", 386 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-3.0.0.tgz", 387 | "integrity": "sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w==", 388 | "dev": true, 389 | "requires": { 390 | "esutils": "^2.0.2" 391 | } 392 | }, 393 | "emoji-regex": { 394 | "version": "7.0.3", 395 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-7.0.3.tgz", 396 | "integrity": "sha512-CwBLREIQ7LvYFB0WyRvwhq5N5qPhc6PMjD6bYggFlI5YyDgl+0vxq5VHbMOFqLg7hfWzmu8T5Z1QofhmTIhItA==", 397 | "dev": true 398 | }, 399 | "end-of-stream": { 400 | "version": "1.4.1", 401 | "resolved": "https://registry.npmjs.org/end-of-stream/-/end-of-stream-1.4.1.tgz", 402 | "integrity": "sha512-1MkrZNvWTKCaigbn+W15elq2BB/L22nqrSY5DKlo3X6+vclJm8Bb5djXJBmEX6fS3+zCh/F4VBK5Z2KxJt4s2Q==", 403 | "dev": true, 404 | "requires": { 405 | "once": "^1.4.0" 406 | } 407 | }, 408 | "es-abstract": { 409 | "version": "1.13.0", 410 | "resolved": "https://registry.npmjs.org/es-abstract/-/es-abstract-1.13.0.tgz", 411 | "integrity": "sha512-vDZfg/ykNxQVwup/8E1BZhVzFfBxs9NqMzGcvIJrqg5k2/5Za2bWo40dK2J1pgLngZ7c+Shh8lwYtLGyrwPutg==", 412 | "dev": true, 413 | "requires": { 414 | "es-to-primitive": "^1.2.0", 415 | "function-bind": "^1.1.1", 416 | "has": "^1.0.3", 417 | "is-callable": "^1.1.4", 418 | "is-regex": "^1.0.4", 419 | "object-keys": "^1.0.12" 420 | } 421 | }, 422 | "es-to-primitive": { 423 | "version": "1.2.0", 424 | "resolved": "https://registry.npmjs.org/es-to-primitive/-/es-to-primitive-1.2.0.tgz", 425 | "integrity": "sha512-qZryBOJjV//LaxLTV6UC//WewneB3LcXOL9NP++ozKVXsIIIpm/2c13UDiD9Jp2eThsecw9m3jPqDwTyobcdbg==", 426 | "dev": true, 427 | "requires": { 428 | "is-callable": "^1.1.4", 429 | "is-date-object": "^1.0.1", 430 | "is-symbol": "^1.0.2" 431 | } 432 | }, 433 | "escape-string-regexp": { 434 | "version": "1.0.5", 435 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", 436 | "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=", 437 | "dev": true 438 | }, 439 | "eslint": { 440 | "version": "6.8.0", 441 | "resolved": "https://registry.npmjs.org/eslint/-/eslint-6.8.0.tgz", 442 | "integrity": "sha512-K+Iayyo2LtyYhDSYwz5D5QdWw0hCacNzyq1Y821Xna2xSJj7cijoLLYmLxTQgcgZ9mC61nryMy9S7GRbYpI5Ig==", 443 | "dev": true, 444 | "requires": { 445 | "@babel/code-frame": "^7.0.0", 446 | "ajv": "^6.10.0", 447 | "chalk": "^2.1.0", 448 | "cross-spawn": "^6.0.5", 449 | "debug": "^4.0.1", 450 | "doctrine": "^3.0.0", 451 | "eslint-scope": "^5.0.0", 452 | "eslint-utils": "^1.4.3", 453 | "eslint-visitor-keys": "^1.1.0", 454 | "espree": "^6.1.2", 455 | "esquery": "^1.0.1", 456 | "esutils": "^2.0.2", 457 | "file-entry-cache": "^5.0.1", 458 | "functional-red-black-tree": "^1.0.1", 459 | "glob-parent": "^5.0.0", 460 | "globals": "^12.1.0", 461 | "ignore": "^4.0.6", 462 | "import-fresh": "^3.0.0", 463 | "imurmurhash": "^0.1.4", 464 | "inquirer": "^7.0.0", 465 | "is-glob": "^4.0.0", 466 | "js-yaml": "^3.13.1", 467 | "json-stable-stringify-without-jsonify": "^1.0.1", 468 | "levn": "^0.3.0", 469 | "lodash": "^4.17.14", 470 | "minimatch": "^3.0.4", 471 | "mkdirp": "^0.5.1", 472 | "natural-compare": "^1.4.0", 473 | "optionator": "^0.8.3", 474 | "progress": "^2.0.0", 475 | "regexpp": "^2.0.1", 476 | "semver": "^6.1.2", 477 | "strip-ansi": "^5.2.0", 478 | "strip-json-comments": "^3.0.1", 479 | "table": "^5.2.3", 480 | "text-table": "^0.2.0", 481 | "v8-compile-cache": "^2.0.3" 482 | }, 483 | "dependencies": { 484 | "ansi-regex": { 485 | "version": "5.0.0", 486 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.0.tgz", 487 | "integrity": "sha512-bY6fj56OUQ0hU1KjFNDQuJFezqKdrAyFdIevADiqrWHwSlbmBNMHp5ak2f40Pm8JTFyM2mqxkG6ngkHO11f/lg==", 488 | "dev": true 489 | }, 490 | "debug": { 491 | "version": "4.1.1", 492 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.1.1.tgz", 493 | "integrity": "sha512-pYAIzeRo8J6KPEaJ0VWOh5Pzkbw/RetuzehGM7QRRX5he4fPHx2rdKMB256ehJCkX+XRQm16eZLqLNS8RSZXZw==", 494 | "dev": true, 495 | "requires": { 496 | "ms": "^2.1.1" 497 | } 498 | }, 499 | "emoji-regex": { 500 | "version": "8.0.0", 501 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 502 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 503 | "dev": true 504 | }, 505 | "eslint-utils": { 506 | "version": "1.4.3", 507 | "resolved": "https://registry.npmjs.org/eslint-utils/-/eslint-utils-1.4.3.tgz", 508 | "integrity": "sha512-fbBN5W2xdY45KulGXmLHZ3c3FHfVYmKg0IrAKGOkT/464PQsx2UeIzfz1RmEci+KLm1bBaAzZAh8+/E+XAeZ8Q==", 509 | "dev": true, 510 | "requires": { 511 | "eslint-visitor-keys": "^1.1.0" 512 | } 513 | }, 514 | "globals": { 515 | "version": "12.3.0", 516 | "resolved": "https://registry.npmjs.org/globals/-/globals-12.3.0.tgz", 517 | "integrity": "sha512-wAfjdLgFsPZsklLJvOBUBmzYE8/CwhEqSBEMRXA3qxIiNtyqvjYurAtIfDh6chlEPUfmTY3MnZh5Hfh4q0UlIw==", 518 | "dev": true, 519 | "requires": { 520 | "type-fest": "^0.8.1" 521 | } 522 | }, 523 | "inquirer": { 524 | "version": "7.0.3", 525 | "resolved": "https://registry.npmjs.org/inquirer/-/inquirer-7.0.3.tgz", 526 | "integrity": "sha512-+OiOVeVydu4hnCGLCSX+wedovR/Yzskv9BFqUNNKq9uU2qg7LCcCo3R86S2E7WLo0y/x2pnEZfZe1CoYnORUAw==", 527 | "dev": true, 528 | "requires": { 529 | "ansi-escapes": "^4.2.1", 530 | "chalk": "^2.4.2", 531 | "cli-cursor": "^3.1.0", 532 | "cli-width": "^2.0.0", 533 | "external-editor": "^3.0.3", 534 | "figures": "^3.0.0", 535 | "lodash": "^4.17.15", 536 | "mute-stream": "0.0.8", 537 | "run-async": "^2.2.0", 538 | "rxjs": "^6.5.3", 539 | "string-width": "^4.1.0", 540 | "strip-ansi": "^5.1.0", 541 | "through": "^2.3.6" 542 | } 543 | }, 544 | "is-fullwidth-code-point": { 545 | "version": "3.0.0", 546 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 547 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 548 | "dev": true 549 | }, 550 | "optionator": { 551 | "version": "0.8.3", 552 | "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.8.3.tgz", 553 | "integrity": "sha512-+IW9pACdk3XWmmTXG8m3upGUJst5XRGzxMRjXzAuJ1XnIFNvfhjjIuYkDvysnPQ7qzqVzLt78BCruntqRhWQbA==", 554 | "dev": true, 555 | "requires": { 556 | "deep-is": "~0.1.3", 557 | "fast-levenshtein": "~2.0.6", 558 | "levn": "~0.3.0", 559 | "prelude-ls": "~1.1.2", 560 | "type-check": "~0.3.2", 561 | "word-wrap": "~1.2.3" 562 | } 563 | }, 564 | "rxjs": { 565 | "version": "6.5.4", 566 | "resolved": "https://registry.npmjs.org/rxjs/-/rxjs-6.5.4.tgz", 567 | "integrity": "sha512-naMQXcgEo3csAEGvw/NydRA0fuS2nDZJiw1YUWFKU7aPPAPGZEsD4Iimit96qwCieH6y614MCLYwdkrWx7z/7Q==", 568 | "dev": true, 569 | "requires": { 570 | "tslib": "^1.9.0" 571 | } 572 | }, 573 | "semver": { 574 | "version": "6.3.0", 575 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", 576 | "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==", 577 | "dev": true 578 | }, 579 | "string-width": { 580 | "version": "4.2.0", 581 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.0.tgz", 582 | "integrity": "sha512-zUz5JD+tgqtuDjMhwIg5uFVV3dtqZ9yQJlZVfq4I01/K5Paj5UHj7VyrQOJvzawSVlKpObApbfD0Ed6yJc+1eg==", 583 | "dev": true, 584 | "requires": { 585 | "emoji-regex": "^8.0.0", 586 | "is-fullwidth-code-point": "^3.0.0", 587 | "strip-ansi": "^6.0.0" 588 | }, 589 | "dependencies": { 590 | "strip-ansi": { 591 | "version": "6.0.0", 592 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.0.tgz", 593 | "integrity": "sha512-AuvKTrTfQNYNIctbR1K/YGTR1756GycPsg7b9bdV9Duqur4gv6aKqHXah67Z8ImS7WEz5QVcOtlfW2rZEugt6w==", 594 | "dev": true, 595 | "requires": { 596 | "ansi-regex": "^5.0.0" 597 | } 598 | } 599 | } 600 | }, 601 | "strip-ansi": { 602 | "version": "5.2.0", 603 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.2.0.tgz", 604 | "integrity": "sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA==", 605 | "dev": true, 606 | "requires": { 607 | "ansi-regex": "^4.1.0" 608 | }, 609 | "dependencies": { 610 | "ansi-regex": { 611 | "version": "4.1.0", 612 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.1.0.tgz", 613 | "integrity": "sha512-1apePfXM1UOSqw0o9IiFAovVz9M5S1Dg+4TrDwfMewQ6p/rmMueb7tWZjQ1rx4Loy1ArBggoqGpfqqdI4rondg==", 614 | "dev": true 615 | } 616 | } 617 | }, 618 | "strip-json-comments": { 619 | "version": "3.0.1", 620 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.0.1.tgz", 621 | "integrity": "sha512-VTyMAUfdm047mwKl+u79WIdrZxtFtn+nBxHeb844XBQ9uMNTuTHdx2hc5RiAJYqwTj3wc/xe5HLSdJSkJ+WfZw==", 622 | "dev": true 623 | }, 624 | "type-fest": { 625 | "version": "0.8.1", 626 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.8.1.tgz", 627 | "integrity": "sha512-4dbzIzqvjtgiM5rw1k5rEHtBANKmdudhGyBEajN01fEyhaAIhsoKNy6y7+IN93IfpFtwY9iqi7kD+xwKhQsNJA==", 628 | "dev": true 629 | } 630 | } 631 | }, 632 | "eslint-scope": { 633 | "version": "5.0.0", 634 | "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-5.0.0.tgz", 635 | "integrity": "sha512-oYrhJW7S0bxAFDvWqzvMPRm6pcgcnWc4QnofCAqRTRfQC0JcwenzGglTtsLyIuuWFfkqDG9vz67cnttSd53djw==", 636 | "dev": true, 637 | "requires": { 638 | "esrecurse": "^4.1.0", 639 | "estraverse": "^4.1.1" 640 | } 641 | }, 642 | "eslint-utils": { 643 | "version": "1.4.2", 644 | "resolved": "https://registry.npmjs.org/eslint-utils/-/eslint-utils-1.4.2.tgz", 645 | "integrity": "sha512-eAZS2sEUMlIeCjBeubdj45dmBHQwPHWyBcT1VSYB7o9x9WRRqKxyUoiXlRjyAwzN7YEzHJlYg0NmzDRWx6GP4Q==", 646 | "dev": true, 647 | "requires": { 648 | "eslint-visitor-keys": "^1.0.0" 649 | } 650 | }, 651 | "eslint-visitor-keys": { 652 | "version": "1.1.0", 653 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-1.1.0.tgz", 654 | "integrity": "sha512-8y9YjtM1JBJU/A9Kc+SbaOV4y29sSWckBwMHa+FGtVj5gN/sbnKDf6xJUl+8g7FAij9LVaP8C24DUiH/f/2Z9A==", 655 | "dev": true 656 | }, 657 | "espree": { 658 | "version": "6.1.2", 659 | "resolved": "https://registry.npmjs.org/espree/-/espree-6.1.2.tgz", 660 | "integrity": "sha512-2iUPuuPP+yW1PZaMSDM9eyVf8D5P0Hi8h83YtZ5bPc/zHYjII5khoixIUTMO794NOY8F/ThF1Bo8ncZILarUTA==", 661 | "dev": true, 662 | "requires": { 663 | "acorn": "^7.1.0", 664 | "acorn-jsx": "^5.1.0", 665 | "eslint-visitor-keys": "^1.1.0" 666 | }, 667 | "dependencies": { 668 | "acorn-jsx": { 669 | "version": "5.1.0", 670 | "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.1.0.tgz", 671 | "integrity": "sha512-tMUqwBWfLFbJbizRmEcWSLw6HnFzfdJs2sOJEOwwtVPMoH/0Ay+E703oZz78VSXZiiDcZrQ5XKjPIUQixhmgVw==", 672 | "dev": true 673 | } 674 | } 675 | }, 676 | "esquery": { 677 | "version": "1.0.1", 678 | "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.0.1.tgz", 679 | "integrity": "sha512-SmiyZ5zIWH9VM+SRUReLS5Q8a7GxtRdxEBVZpm98rJM7Sb+A9DVCndXfkeFUd3byderg+EbDkfnevfCwynWaNA==", 680 | "dev": true, 681 | "requires": { 682 | "estraverse": "^4.0.0" 683 | } 684 | }, 685 | "esrecurse": { 686 | "version": "4.2.1", 687 | "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.2.1.tgz", 688 | "integrity": "sha512-64RBB++fIOAXPw3P9cy89qfMlvZEXZkqqJkjqqXIvzP5ezRZjW+lPWjw35UX/3EhUPFYbg5ER4JYgDw4007/DQ==", 689 | "dev": true, 690 | "requires": { 691 | "estraverse": "^4.1.0" 692 | } 693 | }, 694 | "estraverse": { 695 | "version": "4.3.0", 696 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-4.3.0.tgz", 697 | "integrity": "sha512-39nnKffWz8xN1BU/2c79n9nB9HDzo0niYUqx6xyqUnyoAnQyyWpOTdZEeiCch8BBu515t4wp9ZmgVfVhn9EBpw==", 698 | "dev": true 699 | }, 700 | "esutils": { 701 | "version": "2.0.3", 702 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", 703 | "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==", 704 | "dev": true 705 | }, 706 | "execa": { 707 | "version": "1.0.0", 708 | "resolved": "https://registry.npmjs.org/execa/-/execa-1.0.0.tgz", 709 | "integrity": "sha512-adbxcyWV46qiHyvSp50TKt05tB4tK3HcmF7/nxfAdhnox83seTDbwnaqKO4sXRy7roHAIFqJP/Rw/AuEbX61LA==", 710 | "dev": true, 711 | "requires": { 712 | "cross-spawn": "^6.0.0", 713 | "get-stream": "^4.0.0", 714 | "is-stream": "^1.1.0", 715 | "npm-run-path": "^2.0.0", 716 | "p-finally": "^1.0.0", 717 | "signal-exit": "^3.0.0", 718 | "strip-eof": "^1.0.0" 719 | } 720 | }, 721 | "external-editor": { 722 | "version": "3.1.0", 723 | "resolved": "https://registry.npmjs.org/external-editor/-/external-editor-3.1.0.tgz", 724 | "integrity": "sha512-hMQ4CX1p1izmuLYyZqLMO/qGNw10wSv9QDCPfzXfyFrOaCSSoRfqE1Kf1s5an66J5JZC62NewG+mK49jOCtQew==", 725 | "dev": true, 726 | "requires": { 727 | "chardet": "^0.7.0", 728 | "iconv-lite": "^0.4.24", 729 | "tmp": "^0.0.33" 730 | } 731 | }, 732 | "fast-deep-equal": { 733 | "version": "2.0.1", 734 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-2.0.1.tgz", 735 | "integrity": "sha1-ewUhjd+WZ79/Nwv3/bLLFf3Qqkk=", 736 | "dev": true 737 | }, 738 | "fast-json-stable-stringify": { 739 | "version": "2.0.0", 740 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.0.0.tgz", 741 | "integrity": "sha1-1RQsDK7msRifh9OnYREGT4bIu/I=", 742 | "dev": true 743 | }, 744 | "fast-levenshtein": { 745 | "version": "2.0.6", 746 | "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", 747 | "integrity": "sha1-PYpcZog6FqMMqGQ+hR8Zuqd5eRc=", 748 | "dev": true 749 | }, 750 | "figures": { 751 | "version": "3.0.0", 752 | "resolved": "https://registry.npmjs.org/figures/-/figures-3.0.0.tgz", 753 | "integrity": "sha512-HKri+WoWoUgr83pehn/SIgLOMZ9nAWC6dcGj26RY2R4F50u4+RTUz0RCrUlOV3nKRAICW1UGzyb+kcX2qK1S/g==", 754 | "dev": true, 755 | "requires": { 756 | "escape-string-regexp": "^1.0.5" 757 | } 758 | }, 759 | "file-entry-cache": { 760 | "version": "5.0.1", 761 | "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-5.0.1.tgz", 762 | "integrity": "sha512-bCg29ictuBaKUwwArK4ouCaqDgLZcysCFLmM/Yn/FDoqndh/9vNuQfXRDvTuXKLxfD/JtZQGKFT8MGcJBK644g==", 763 | "dev": true, 764 | "requires": { 765 | "flat-cache": "^2.0.1" 766 | } 767 | }, 768 | "find-up": { 769 | "version": "3.0.0", 770 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-3.0.0.tgz", 771 | "integrity": "sha512-1yD6RmLI1XBfxugvORwlck6f75tYL+iR0jqwsOrOxMZyGYqUuDhJ0l4AXdO1iX/FTs9cBAMEk1gWSEx1kSbylg==", 772 | "dev": true, 773 | "requires": { 774 | "locate-path": "^3.0.0" 775 | } 776 | }, 777 | "flat": { 778 | "version": "4.1.0", 779 | "resolved": "https://registry.npmjs.org/flat/-/flat-4.1.0.tgz", 780 | "integrity": "sha512-Px/TiLIznH7gEDlPXcUD4KnBusa6kR6ayRUVcnEAbreRIuhkqow/mun59BuRXwoYk7ZQOLW1ZM05ilIvK38hFw==", 781 | "dev": true, 782 | "requires": { 783 | "is-buffer": "~2.0.3" 784 | }, 785 | "dependencies": { 786 | "is-buffer": { 787 | "version": "2.0.3", 788 | "resolved": "https://registry.npmjs.org/is-buffer/-/is-buffer-2.0.3.tgz", 789 | "integrity": "sha512-U15Q7MXTuZlrbymiz95PJpZxu8IlipAp4dtS3wOdgPXx3mqBnslrWU14kxfHB+Py/+2PVKSr37dMAgM2A4uArw==", 790 | "dev": true 791 | } 792 | } 793 | }, 794 | "flat-cache": { 795 | "version": "2.0.1", 796 | "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-2.0.1.tgz", 797 | "integrity": "sha512-LoQe6yDuUMDzQAEH8sgmh4Md6oZnc/7PjtwjNFSzveXqSHt6ka9fPBuso7IGf9Rz4uqnSnWiFH2B/zj24a5ReA==", 798 | "dev": true, 799 | "requires": { 800 | "flatted": "^2.0.0", 801 | "rimraf": "2.6.3", 802 | "write": "1.0.3" 803 | } 804 | }, 805 | "flatted": { 806 | "version": "2.0.1", 807 | "resolved": "https://registry.npmjs.org/flatted/-/flatted-2.0.1.tgz", 808 | "integrity": "sha512-a1hQMktqW9Nmqr5aktAux3JMNqaucxGcjtjWnZLHX7yyPCmlSV3M54nGYbqT8K+0GhF3NBgmJCc3ma+WOgX8Jg==", 809 | "dev": true 810 | }, 811 | "fs.realpath": { 812 | "version": "1.0.0", 813 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 814 | "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=", 815 | "dev": true 816 | }, 817 | "function-bind": { 818 | "version": "1.1.1", 819 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", 820 | "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==", 821 | "dev": true 822 | }, 823 | "functional-red-black-tree": { 824 | "version": "1.0.1", 825 | "resolved": "https://registry.npmjs.org/functional-red-black-tree/-/functional-red-black-tree-1.0.1.tgz", 826 | "integrity": "sha1-GwqzvVU7Kg1jmdKcDj6gslIHgyc=", 827 | "dev": true 828 | }, 829 | "get-caller-file": { 830 | "version": "2.0.5", 831 | "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-2.0.5.tgz", 832 | "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==", 833 | "dev": true 834 | }, 835 | "get-func-name": { 836 | "version": "2.0.0", 837 | "resolved": "https://registry.npmjs.org/get-func-name/-/get-func-name-2.0.0.tgz", 838 | "integrity": "sha1-6td0q+5y4gQJQzoGY2YCPdaIekE=", 839 | "dev": true 840 | }, 841 | "get-stream": { 842 | "version": "4.1.0", 843 | "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-4.1.0.tgz", 844 | "integrity": "sha512-GMat4EJ5161kIy2HevLlr4luNjBgvmj413KaQA7jt4V8B4RDsfpHk7WQ9GVqfYyyx8OS/L66Kox+rJRNklLK7w==", 845 | "dev": true, 846 | "requires": { 847 | "pump": "^3.0.0" 848 | } 849 | }, 850 | "glob": { 851 | "version": "7.1.4", 852 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.4.tgz", 853 | "integrity": "sha512-hkLPepehmnKk41pUGm3sYxoFs/umurYfYJCerbXEyFIWcAzvpipAgVkBqqT9RBKMGjnq6kMuyYwha6csxbiM1A==", 854 | "dev": true, 855 | "requires": { 856 | "fs.realpath": "^1.0.0", 857 | "inflight": "^1.0.4", 858 | "inherits": "2", 859 | "minimatch": "^3.0.4", 860 | "once": "^1.3.0", 861 | "path-is-absolute": "^1.0.0" 862 | } 863 | }, 864 | "glob-all": { 865 | "version": "3.2.1", 866 | "resolved": "https://registry.npmjs.org/glob-all/-/glob-all-3.2.1.tgz", 867 | "integrity": "sha512-x877rVkzB3ipid577QOp+eQCR6M5ZyiwrtaYgrX/z3EThaSPFtLDwBXFHc3sH1cG0R0vFYI5SRYeWMMSEyXkUw==", 868 | "dev": true, 869 | "requires": { 870 | "glob": "^7.1.2", 871 | "yargs": "^15.3.1" 872 | } 873 | }, 874 | "glob-parent": { 875 | "version": "5.1.2", 876 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", 877 | "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", 878 | "dev": true, 879 | "requires": { 880 | "is-glob": "^4.0.1" 881 | } 882 | }, 883 | "globals": { 884 | "version": "11.12.0", 885 | "resolved": "https://registry.npmjs.org/globals/-/globals-11.12.0.tgz", 886 | "integrity": "sha512-WOBp/EEGUiIsJSp7wcv/y6MO+lV9UoncWqxuFfm8eBwzWNgyfBd6Gz+IeKQ9jCmyhoH99g15M3T+QaVHFjizVA==", 887 | "dev": true 888 | }, 889 | "growl": { 890 | "version": "1.10.5", 891 | "resolved": "https://registry.npmjs.org/growl/-/growl-1.10.5.tgz", 892 | "integrity": "sha512-qBr4OuELkhPenW6goKVXiv47US3clb3/IbuWF9KNKEijAy9oeHxU9IgzjvJhHkUzhaj7rOUD7+YGWqUjLp5oSA==", 893 | "dev": true 894 | }, 895 | "has": { 896 | "version": "1.0.3", 897 | "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", 898 | "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", 899 | "dev": true, 900 | "requires": { 901 | "function-bind": "^1.1.1" 902 | } 903 | }, 904 | "has-flag": { 905 | "version": "3.0.0", 906 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 907 | "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=", 908 | "dev": true 909 | }, 910 | "has-symbols": { 911 | "version": "1.0.0", 912 | "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.0.tgz", 913 | "integrity": "sha1-uhqPGvKg/DllD1yFA2dwQSIGO0Q=", 914 | "dev": true 915 | }, 916 | "he": { 917 | "version": "1.2.0", 918 | "resolved": "https://registry.npmjs.org/he/-/he-1.2.0.tgz", 919 | "integrity": "sha512-F/1DnUGPopORZi0ni+CvrCgHQ5FyEAHRLSApuYWMmrbSwoN2Mn/7k+Gl38gJnR7yyDZk6WLXwiGod1JOWNDKGw==", 920 | "dev": true 921 | }, 922 | "iconv-lite": { 923 | "version": "0.4.24", 924 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", 925 | "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", 926 | "dev": true, 927 | "requires": { 928 | "safer-buffer": ">= 2.1.2 < 3" 929 | } 930 | }, 931 | "ignore": { 932 | "version": "4.0.6", 933 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-4.0.6.tgz", 934 | "integrity": "sha512-cyFDKrqc/YdcWFniJhzI42+AzS+gNwmUzOSFcRCQYwySuBBBy/KjuxWLZ/FHEH6Moq1NizMOBWyTcv8O4OZIMg==", 935 | "dev": true 936 | }, 937 | "import-fresh": { 938 | "version": "3.1.0", 939 | "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.1.0.tgz", 940 | "integrity": "sha512-PpuksHKGt8rXfWEr9m9EHIpgyyaltBy8+eF6GJM0QCAxMgxCfucMF3mjecK2QsJr0amJW7gTqh5/wht0z2UhEQ==", 941 | "dev": true, 942 | "requires": { 943 | "parent-module": "^1.0.0", 944 | "resolve-from": "^4.0.0" 945 | } 946 | }, 947 | "imurmurhash": { 948 | "version": "0.1.4", 949 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 950 | "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=", 951 | "dev": true 952 | }, 953 | "inflight": { 954 | "version": "1.0.6", 955 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 956 | "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", 957 | "dev": true, 958 | "requires": { 959 | "once": "^1.3.0", 960 | "wrappy": "1" 961 | } 962 | }, 963 | "inherits": { 964 | "version": "2.0.4", 965 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 966 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", 967 | "dev": true 968 | }, 969 | "inquirer": { 970 | "version": "6.5.1", 971 | "resolved": "https://registry.npmjs.org/inquirer/-/inquirer-6.5.1.tgz", 972 | "integrity": "sha512-uxNHBeQhRXIoHWTSNYUFhQVrHYFThIt6IVo2fFmSe8aBwdR3/w6b58hJpiL/fMukFkvGzjg+hSxFtwvVmKZmXw==", 973 | "dev": true, 974 | "requires": { 975 | "ansi-escapes": "^4.2.1", 976 | "chalk": "^2.4.2", 977 | "cli-cursor": "^3.1.0", 978 | "cli-width": "^2.0.0", 979 | "external-editor": "^3.0.3", 980 | "figures": "^3.0.0", 981 | "lodash": "^4.17.15", 982 | "mute-stream": "0.0.8", 983 | "run-async": "^2.2.0", 984 | "rxjs": "^6.4.0", 985 | "string-width": "^4.1.0", 986 | "strip-ansi": "^5.1.0", 987 | "through": "^2.3.6" 988 | }, 989 | "dependencies": { 990 | "ansi-regex": { 991 | "version": "4.1.0", 992 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.1.0.tgz", 993 | "integrity": "sha512-1apePfXM1UOSqw0o9IiFAovVz9M5S1Dg+4TrDwfMewQ6p/rmMueb7tWZjQ1rx4Loy1ArBggoqGpfqqdI4rondg==", 994 | "dev": true 995 | }, 996 | "emoji-regex": { 997 | "version": "8.0.0", 998 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 999 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 1000 | "dev": true 1001 | }, 1002 | "is-fullwidth-code-point": { 1003 | "version": "3.0.0", 1004 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 1005 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 1006 | "dev": true 1007 | }, 1008 | "string-width": { 1009 | "version": "4.1.0", 1010 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.1.0.tgz", 1011 | "integrity": "sha512-NrX+1dVVh+6Y9dnQ19pR0pP4FiEIlUvdTGn8pw6CKTNq5sgib2nIhmUNT5TAmhWmvKr3WcxBcP3E8nWezuipuQ==", 1012 | "dev": true, 1013 | "requires": { 1014 | "emoji-regex": "^8.0.0", 1015 | "is-fullwidth-code-point": "^3.0.0", 1016 | "strip-ansi": "^5.2.0" 1017 | } 1018 | }, 1019 | "strip-ansi": { 1020 | "version": "5.2.0", 1021 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.2.0.tgz", 1022 | "integrity": "sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA==", 1023 | "dev": true, 1024 | "requires": { 1025 | "ansi-regex": "^4.1.0" 1026 | } 1027 | } 1028 | } 1029 | }, 1030 | "is-callable": { 1031 | "version": "1.1.4", 1032 | "resolved": "https://registry.npmjs.org/is-callable/-/is-callable-1.1.4.tgz", 1033 | "integrity": "sha512-r5p9sxJjYnArLjObpjA4xu5EKI3CuKHkJXMhT7kwbpUyIFD1n5PMAsoPvWnvtZiNz7LjkYDRZhd7FlI0eMijEA==", 1034 | "dev": true 1035 | }, 1036 | "is-date-object": { 1037 | "version": "1.0.1", 1038 | "resolved": "https://registry.npmjs.org/is-date-object/-/is-date-object-1.0.1.tgz", 1039 | "integrity": "sha1-mqIOtq7rv/d/vTPnTKAbM1gdOhY=", 1040 | "dev": true 1041 | }, 1042 | "is-extglob": { 1043 | "version": "2.1.1", 1044 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 1045 | "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=", 1046 | "dev": true 1047 | }, 1048 | "is-fullwidth-code-point": { 1049 | "version": "2.0.0", 1050 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", 1051 | "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=", 1052 | "dev": true 1053 | }, 1054 | "is-glob": { 1055 | "version": "4.0.1", 1056 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.1.tgz", 1057 | "integrity": "sha512-5G0tKtBTFImOqDnLB2hG6Bp2qcKEFduo4tZu9MT/H6NQv/ghhy30o55ufafxJ/LdH79LLs2Kfrn85TLKyA7BUg==", 1058 | "dev": true, 1059 | "requires": { 1060 | "is-extglob": "^2.1.1" 1061 | } 1062 | }, 1063 | "is-promise": { 1064 | "version": "2.1.0", 1065 | "resolved": "https://registry.npmjs.org/is-promise/-/is-promise-2.1.0.tgz", 1066 | "integrity": "sha1-eaKp7OfwlugPNtKy87wWwf9L8/o=", 1067 | "dev": true 1068 | }, 1069 | "is-regex": { 1070 | "version": "1.0.4", 1071 | "resolved": "https://registry.npmjs.org/is-regex/-/is-regex-1.0.4.tgz", 1072 | "integrity": "sha1-VRdIm1RwkbCTDglWVM7SXul+lJE=", 1073 | "dev": true, 1074 | "requires": { 1075 | "has": "^1.0.1" 1076 | } 1077 | }, 1078 | "is-stream": { 1079 | "version": "1.1.0", 1080 | "resolved": "https://registry.npmjs.org/is-stream/-/is-stream-1.1.0.tgz", 1081 | "integrity": "sha1-EtSj3U5o4Lec6428hBc66A2RykQ=", 1082 | "dev": true 1083 | }, 1084 | "is-symbol": { 1085 | "version": "1.0.2", 1086 | "resolved": "https://registry.npmjs.org/is-symbol/-/is-symbol-1.0.2.tgz", 1087 | "integrity": "sha512-HS8bZ9ox60yCJLH9snBpIwv9pYUAkcuLhSA1oero1UB5y9aiQpRA8y2ex945AOtCZL1lJDeIk3G5LthswI46Lw==", 1088 | "dev": true, 1089 | "requires": { 1090 | "has-symbols": "^1.0.0" 1091 | } 1092 | }, 1093 | "isexe": { 1094 | "version": "2.0.0", 1095 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 1096 | "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=", 1097 | "dev": true 1098 | }, 1099 | "js-tokens": { 1100 | "version": "4.0.0", 1101 | "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", 1102 | "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==", 1103 | "dev": true 1104 | }, 1105 | "js-yaml": { 1106 | "version": "3.13.1", 1107 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.13.1.tgz", 1108 | "integrity": "sha512-YfbcO7jXDdyj0DGxYVSlSeQNHbD7XPWvrVWeVUujrQEoZzWJIRrCPoyk6kL6IAjAG2IolMK4T0hNUe0HOUs5Jw==", 1109 | "dev": true, 1110 | "requires": { 1111 | "argparse": "^1.0.7", 1112 | "esprima": "^4.0.0" 1113 | }, 1114 | "dependencies": { 1115 | "esprima": { 1116 | "version": "4.0.1", 1117 | "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz", 1118 | "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==", 1119 | "dev": true 1120 | } 1121 | } 1122 | }, 1123 | "json-schema-traverse": { 1124 | "version": "0.4.1", 1125 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", 1126 | "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", 1127 | "dev": true 1128 | }, 1129 | "json-stable-stringify-without-jsonify": { 1130 | "version": "1.0.1", 1131 | "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz", 1132 | "integrity": "sha1-nbe1lJatPzz+8wp1FC0tkwrXJlE=", 1133 | "dev": true 1134 | }, 1135 | "levn": { 1136 | "version": "0.3.0", 1137 | "resolved": "https://registry.npmjs.org/levn/-/levn-0.3.0.tgz", 1138 | "integrity": "sha1-OwmSTt+fCDwEkP3UwLxEIeBHZO4=", 1139 | "dev": true, 1140 | "requires": { 1141 | "prelude-ls": "~1.1.2", 1142 | "type-check": "~0.3.2" 1143 | } 1144 | }, 1145 | "locate-path": { 1146 | "version": "3.0.0", 1147 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-3.0.0.tgz", 1148 | "integrity": "sha512-7AO748wWnIhNqAuaty2ZWHkQHRSNfPVIsPIfwEOWO22AmaoVrWavlOcMR5nzTLNYvp36X220/maaRsrec1G65A==", 1149 | "dev": true, 1150 | "requires": { 1151 | "p-locate": "^3.0.0", 1152 | "path-exists": "^3.0.0" 1153 | }, 1154 | "dependencies": { 1155 | "path-exists": { 1156 | "version": "3.0.0", 1157 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-3.0.0.tgz", 1158 | "integrity": "sha1-zg6+ql94yxiSXqfYENe1mwEP1RU=", 1159 | "dev": true 1160 | } 1161 | } 1162 | }, 1163 | "lodash": { 1164 | "version": "4.17.21", 1165 | "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.21.tgz", 1166 | "integrity": "sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg==", 1167 | "dev": true 1168 | }, 1169 | "log-symbols": { 1170 | "version": "2.2.0", 1171 | "resolved": "https://registry.npmjs.org/log-symbols/-/log-symbols-2.2.0.tgz", 1172 | "integrity": "sha512-VeIAFslyIerEJLXHziedo2basKbMKtTw3vfn5IzG0XTjhAVEJyNHnL2p7vc+wBDSdQuUpNw3M2u6xb9QsAY5Eg==", 1173 | "dev": true, 1174 | "requires": { 1175 | "chalk": "^2.0.1" 1176 | } 1177 | }, 1178 | "map-age-cleaner": { 1179 | "version": "0.1.3", 1180 | "resolved": "https://registry.npmjs.org/map-age-cleaner/-/map-age-cleaner-0.1.3.tgz", 1181 | "integrity": "sha512-bJzx6nMoP6PDLPBFmg7+xRKeFZvFboMrGlxmNj9ClvX53KrmvM5bXFXEWjbz4cz1AFn+jWJ9z/DJSz7hrs0w3w==", 1182 | "dev": true, 1183 | "requires": { 1184 | "p-defer": "^1.0.0" 1185 | } 1186 | }, 1187 | "mem": { 1188 | "version": "4.3.0", 1189 | "resolved": "https://registry.npmjs.org/mem/-/mem-4.3.0.tgz", 1190 | "integrity": "sha512-qX2bG48pTqYRVmDB37rn/6PT7LcR8T7oAX3bf99u1Tt1nzxYfxkgqDwUwolPlXweM0XzBOBFzSx4kfp7KP1s/w==", 1191 | "dev": true, 1192 | "requires": { 1193 | "map-age-cleaner": "^0.1.1", 1194 | "mimic-fn": "^2.0.0", 1195 | "p-is-promise": "^2.0.0" 1196 | } 1197 | }, 1198 | "mimic-fn": { 1199 | "version": "2.1.0", 1200 | "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-2.1.0.tgz", 1201 | "integrity": "sha512-OqbOk5oEQeAZ8WXWydlu9HJjz9WVdEIvamMCcXmuqUYjTknH/sqsWvhQ3vgwKFRR1HpjvNBKQ37nbJgYzGqGcg==", 1202 | "dev": true 1203 | }, 1204 | "minimatch": { 1205 | "version": "3.0.4", 1206 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", 1207 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 1208 | "dev": true, 1209 | "requires": { 1210 | "brace-expansion": "^1.1.7" 1211 | } 1212 | }, 1213 | "minimist": { 1214 | "version": "1.2.5", 1215 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.5.tgz", 1216 | "integrity": "sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw==", 1217 | "dev": true 1218 | }, 1219 | "mkdirp": { 1220 | "version": "0.5.5", 1221 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.5.tgz", 1222 | "integrity": "sha512-NKmAlESf6jMGym1++R0Ra7wvhV+wFW63FaSOFPwRahvea0gMUcGUhVeAg/0BC0wiv9ih5NYPB1Wn1UEI1/L+xQ==", 1223 | "dev": true, 1224 | "requires": { 1225 | "minimist": "^1.2.5" 1226 | } 1227 | }, 1228 | "mocha": { 1229 | "version": "6.2.0", 1230 | "resolved": "https://registry.npmjs.org/mocha/-/mocha-6.2.0.tgz", 1231 | "integrity": "sha512-qwfFgY+7EKAAUAdv7VYMZQknI7YJSGesxHyhn6qD52DV8UcSZs5XwCifcZGMVIE4a5fbmhvbotxC0DLQ0oKohQ==", 1232 | "dev": true, 1233 | "requires": { 1234 | "ansi-colors": "3.2.3", 1235 | "browser-stdout": "1.3.1", 1236 | "debug": "3.2.6", 1237 | "diff": "3.5.0", 1238 | "escape-string-regexp": "1.0.5", 1239 | "find-up": "3.0.0", 1240 | "glob": "7.1.3", 1241 | "growl": "1.10.5", 1242 | "he": "1.2.0", 1243 | "js-yaml": "3.13.1", 1244 | "log-symbols": "2.2.0", 1245 | "minimatch": "3.0.4", 1246 | "mkdirp": "0.5.1", 1247 | "ms": "2.1.1", 1248 | "node-environment-flags": "1.0.5", 1249 | "object.assign": "4.1.0", 1250 | "strip-json-comments": "2.0.1", 1251 | "supports-color": "6.0.0", 1252 | "which": "1.3.1", 1253 | "wide-align": "1.1.3", 1254 | "yargs": "13.2.2", 1255 | "yargs-parser": "13.0.0", 1256 | "yargs-unparser": "1.5.0" 1257 | }, 1258 | "dependencies": { 1259 | "ansi-regex": { 1260 | "version": "4.1.0", 1261 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.1.0.tgz", 1262 | "integrity": "sha512-1apePfXM1UOSqw0o9IiFAovVz9M5S1Dg+4TrDwfMewQ6p/rmMueb7tWZjQ1rx4Loy1ArBggoqGpfqqdI4rondg==", 1263 | "dev": true 1264 | }, 1265 | "cliui": { 1266 | "version": "4.1.0", 1267 | "resolved": "https://registry.npmjs.org/cliui/-/cliui-4.1.0.tgz", 1268 | "integrity": "sha512-4FG+RSG9DL7uEwRUZXZn3SS34DiDPfzP0VOiEwtUWlE+AR2EIg+hSyvrIgUUfhdgR/UkAeW2QHgeP+hWrXs7jQ==", 1269 | "dev": true, 1270 | "requires": { 1271 | "string-width": "^2.1.1", 1272 | "strip-ansi": "^4.0.0", 1273 | "wrap-ansi": "^2.0.0" 1274 | }, 1275 | "dependencies": { 1276 | "string-width": { 1277 | "version": "2.1.1", 1278 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-2.1.1.tgz", 1279 | "integrity": "sha512-nOqH59deCq9SRHlxq1Aw85Jnt4w6KvLKqWVik6oA9ZklXLNIOlqg4F2yrT1MVaTjAqvVwdfeZ7w7aCvJD7ugkw==", 1280 | "dev": true, 1281 | "requires": { 1282 | "is-fullwidth-code-point": "^2.0.0", 1283 | "strip-ansi": "^4.0.0" 1284 | } 1285 | } 1286 | } 1287 | }, 1288 | "glob": { 1289 | "version": "7.1.3", 1290 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.3.tgz", 1291 | "integrity": "sha512-vcfuiIxogLV4DlGBHIUOwI0IbrJ8HWPc4MU7HzviGeNho/UJDfi6B5p3sHeWIQ0KGIU0Jpxi5ZHxemQfLkkAwQ==", 1292 | "dev": true, 1293 | "requires": { 1294 | "fs.realpath": "^1.0.0", 1295 | "inflight": "^1.0.4", 1296 | "inherits": "2", 1297 | "minimatch": "^3.0.4", 1298 | "once": "^1.3.0", 1299 | "path-is-absolute": "^1.0.0" 1300 | } 1301 | }, 1302 | "invert-kv": { 1303 | "version": "2.0.0", 1304 | "resolved": "https://registry.npmjs.org/invert-kv/-/invert-kv-2.0.0.tgz", 1305 | "integrity": "sha512-wPVv/y/QQ/Uiirj/vh3oP+1Ww+AWehmi1g5fFWGPF6IpCBCDVrhgHRMvrLfdYcwDh3QJbGXDW4JAuzxElLSqKA==", 1306 | "dev": true 1307 | }, 1308 | "lcid": { 1309 | "version": "2.0.0", 1310 | "resolved": "https://registry.npmjs.org/lcid/-/lcid-2.0.0.tgz", 1311 | "integrity": "sha512-avPEb8P8EGnwXKClwsNUgryVjllcRqtMYa49NTsbQagYuT1DcXnl1915oxWjoyGrXR6zH/Y0Zc96xWsPcoDKeA==", 1312 | "dev": true, 1313 | "requires": { 1314 | "invert-kv": "^2.0.0" 1315 | } 1316 | }, 1317 | "minimist": { 1318 | "version": "0.0.8", 1319 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-0.0.8.tgz", 1320 | "integrity": "sha1-hX/Kv8M5fSYluCKCYuhqp6ARsF0=", 1321 | "dev": true 1322 | }, 1323 | "mkdirp": { 1324 | "version": "0.5.1", 1325 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.1.tgz", 1326 | "integrity": "sha1-MAV0OOrGz3+MR2fzhkjWaX11yQM=", 1327 | "dev": true, 1328 | "requires": { 1329 | "minimist": "0.0.8" 1330 | } 1331 | }, 1332 | "os-locale": { 1333 | "version": "3.1.0", 1334 | "resolved": "https://registry.npmjs.org/os-locale/-/os-locale-3.1.0.tgz", 1335 | "integrity": "sha512-Z8l3R4wYWM40/52Z+S265okfFj8Kt2cC2MKY+xNi3kFs+XGI7WXu/I309QQQYbRW4ijiZ+yxs9pqEhJh0DqW3Q==", 1336 | "dev": true, 1337 | "requires": { 1338 | "execa": "^1.0.0", 1339 | "lcid": "^2.0.0", 1340 | "mem": "^4.0.0" 1341 | } 1342 | }, 1343 | "string-width": { 1344 | "version": "3.1.0", 1345 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-3.1.0.tgz", 1346 | "integrity": "sha512-vafcv6KjVZKSgz06oM/H6GDBrAtz8vdhQakGjFIvNrHA6y3HCF1CInLy+QLq8dTJPQ1b+KDUqDFctkdRW44e1w==", 1347 | "dev": true, 1348 | "requires": { 1349 | "emoji-regex": "^7.0.1", 1350 | "is-fullwidth-code-point": "^2.0.0", 1351 | "strip-ansi": "^5.1.0" 1352 | }, 1353 | "dependencies": { 1354 | "strip-ansi": { 1355 | "version": "5.2.0", 1356 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.2.0.tgz", 1357 | "integrity": "sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA==", 1358 | "dev": true, 1359 | "requires": { 1360 | "ansi-regex": "^4.1.0" 1361 | } 1362 | } 1363 | } 1364 | }, 1365 | "y18n": { 1366 | "version": "4.0.3", 1367 | "resolved": "https://registry.npmjs.org/y18n/-/y18n-4.0.3.tgz", 1368 | "integrity": "sha512-JKhqTOwSrqNA1NY5lSztJ1GrBiUodLMmIZuLiDaMRJ+itFd+ABVE8XBjOvIWL+rSqNDC74LCSFmlb/U4UZ4hJQ==", 1369 | "dev": true 1370 | }, 1371 | "yargs": { 1372 | "version": "13.2.2", 1373 | "resolved": "https://registry.npmjs.org/yargs/-/yargs-13.2.2.tgz", 1374 | "integrity": "sha512-WyEoxgyTD3w5XRpAQNYUB9ycVH/PQrToaTXdYXRdOXvEy1l19br+VJsc0vcO8PTGg5ro/l/GY7F/JMEBmI0BxA==", 1375 | "dev": true, 1376 | "requires": { 1377 | "cliui": "^4.0.0", 1378 | "find-up": "^3.0.0", 1379 | "get-caller-file": "^2.0.1", 1380 | "os-locale": "^3.1.0", 1381 | "require-directory": "^2.1.1", 1382 | "require-main-filename": "^2.0.0", 1383 | "set-blocking": "^2.0.0", 1384 | "string-width": "^3.0.0", 1385 | "which-module": "^2.0.0", 1386 | "y18n": "^4.0.0", 1387 | "yargs-parser": "^13.0.0" 1388 | } 1389 | }, 1390 | "yargs-parser": { 1391 | "version": "13.0.0", 1392 | "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-13.0.0.tgz", 1393 | "integrity": "sha512-w2LXjoL8oRdRQN+hOyppuXs+V/fVAYtpcrRxZuF7Kt/Oc+Jr2uAcVntaUTNT6w5ihoWfFDpNY8CPx1QskxZ/pw==", 1394 | "dev": true, 1395 | "requires": { 1396 | "camelcase": "^5.0.0", 1397 | "decamelize": "^1.2.0" 1398 | } 1399 | } 1400 | } 1401 | }, 1402 | "mocha-eslint": { 1403 | "version": "5.0.0", 1404 | "resolved": "https://registry.npmjs.org/mocha-eslint/-/mocha-eslint-5.0.0.tgz", 1405 | "integrity": "sha512-K6ewxXXVtVQA+/iIgXP5AQnNus+TxkjB/d3lK1j8Cj3Oc282As7G9j7o5WXAF+cCsGD9t4apS6hc9GqQtEbbVA==", 1406 | "dev": true, 1407 | "requires": { 1408 | "chalk": "^2.4.1", 1409 | "eslint": "^5.10.0", 1410 | "glob-all": "^3.1.0", 1411 | "replaceall": "^0.1.6" 1412 | }, 1413 | "dependencies": { 1414 | "acorn": { 1415 | "version": "6.4.1", 1416 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-6.4.1.tgz", 1417 | "integrity": "sha512-ZVA9k326Nwrj3Cj9jlh3wGFutC2ZornPNARZwsNYqQYgN0EsV2d53w5RN/co65Ohn4sUAUtb1rSUAOD6XN9idA==", 1418 | "dev": true 1419 | }, 1420 | "debug": { 1421 | "version": "4.1.1", 1422 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.1.1.tgz", 1423 | "integrity": "sha512-pYAIzeRo8J6KPEaJ0VWOh5Pzkbw/RetuzehGM7QRRX5he4fPHx2rdKMB256ehJCkX+XRQm16eZLqLNS8RSZXZw==", 1424 | "dev": true, 1425 | "requires": { 1426 | "ms": "^2.1.1" 1427 | } 1428 | }, 1429 | "eslint": { 1430 | "version": "5.16.0", 1431 | "resolved": "https://registry.npmjs.org/eslint/-/eslint-5.16.0.tgz", 1432 | "integrity": "sha512-S3Rz11i7c8AA5JPv7xAH+dOyq/Cu/VXHiHXBPOU1k/JAM5dXqQPt3qcrhpHSorXmrpu2g0gkIBVXAqCpzfoZIg==", 1433 | "dev": true, 1434 | "requires": { 1435 | "@babel/code-frame": "^7.0.0", 1436 | "ajv": "^6.9.1", 1437 | "chalk": "^2.1.0", 1438 | "cross-spawn": "^6.0.5", 1439 | "debug": "^4.0.1", 1440 | "doctrine": "^3.0.0", 1441 | "eslint-scope": "^4.0.3", 1442 | "eslint-utils": "^1.3.1", 1443 | "eslint-visitor-keys": "^1.0.0", 1444 | "espree": "^5.0.1", 1445 | "esquery": "^1.0.1", 1446 | "esutils": "^2.0.2", 1447 | "file-entry-cache": "^5.0.1", 1448 | "functional-red-black-tree": "^1.0.1", 1449 | "glob": "^7.1.2", 1450 | "globals": "^11.7.0", 1451 | "ignore": "^4.0.6", 1452 | "import-fresh": "^3.0.0", 1453 | "imurmurhash": "^0.1.4", 1454 | "inquirer": "^6.2.2", 1455 | "js-yaml": "^3.13.0", 1456 | "json-stable-stringify-without-jsonify": "^1.0.1", 1457 | "levn": "^0.3.0", 1458 | "lodash": "^4.17.11", 1459 | "minimatch": "^3.0.4", 1460 | "mkdirp": "^0.5.1", 1461 | "natural-compare": "^1.4.0", 1462 | "optionator": "^0.8.2", 1463 | "path-is-inside": "^1.0.2", 1464 | "progress": "^2.0.0", 1465 | "regexpp": "^2.0.1", 1466 | "semver": "^5.5.1", 1467 | "strip-ansi": "^4.0.0", 1468 | "strip-json-comments": "^2.0.1", 1469 | "table": "^5.2.3", 1470 | "text-table": "^0.2.0" 1471 | } 1472 | }, 1473 | "eslint-scope": { 1474 | "version": "4.0.3", 1475 | "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-4.0.3.tgz", 1476 | "integrity": "sha512-p7VutNr1O/QrxysMo3E45FjYDTeXBy0iTltPFNSqKAIfjDSXC+4dj+qfyuD8bfAXrW/y6lW3O76VaYNPKfpKrg==", 1477 | "dev": true, 1478 | "requires": { 1479 | "esrecurse": "^4.1.0", 1480 | "estraverse": "^4.1.1" 1481 | } 1482 | }, 1483 | "espree": { 1484 | "version": "5.0.1", 1485 | "resolved": "https://registry.npmjs.org/espree/-/espree-5.0.1.tgz", 1486 | "integrity": "sha512-qWAZcWh4XE/RwzLJejfcofscgMc9CamR6Tn1+XRXNzrvUSSbiAjGOI/fggztjIi7y9VLPqnICMIPiGyr8JaZ0A==", 1487 | "dev": true, 1488 | "requires": { 1489 | "acorn": "^6.0.7", 1490 | "acorn-jsx": "^5.0.0", 1491 | "eslint-visitor-keys": "^1.0.0" 1492 | } 1493 | } 1494 | } 1495 | }, 1496 | "ms": { 1497 | "version": "2.1.1", 1498 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.1.tgz", 1499 | "integrity": "sha512-tgp+dl5cGk28utYktBsrFqA7HKgrhgPsg6Z/EfhWI4gl1Hwq8B/GmY/0oXZ6nF8hDVesS/FpnYaD/kOWhYQvyg==", 1500 | "dev": true 1501 | }, 1502 | "mute-stream": { 1503 | "version": "0.0.8", 1504 | "resolved": "https://registry.npmjs.org/mute-stream/-/mute-stream-0.0.8.tgz", 1505 | "integrity": "sha512-nnbWWOkoWyUsTjKrhgD0dcz22mdkSnpYqbEjIm2nhwhuxlSkpywJmBo8h0ZqJdkp73mb90SssHkN4rsRaBAfAA==", 1506 | "dev": true 1507 | }, 1508 | "natural-compare": { 1509 | "version": "1.4.0", 1510 | "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", 1511 | "integrity": "sha1-Sr6/7tdUHywnrPspvbvRXI1bpPc=", 1512 | "dev": true 1513 | }, 1514 | "nice-try": { 1515 | "version": "1.0.5", 1516 | "resolved": "https://registry.npmjs.org/nice-try/-/nice-try-1.0.5.tgz", 1517 | "integrity": "sha512-1nh45deeb5olNY7eX82BkPO7SSxR5SSYJiPTrTdFUVYwAl8CKMA5N9PjTYkHiRjisVcxcQ1HXdLhx2qxxJzLNQ==", 1518 | "dev": true 1519 | }, 1520 | "node-environment-flags": { 1521 | "version": "1.0.5", 1522 | "resolved": "https://registry.npmjs.org/node-environment-flags/-/node-environment-flags-1.0.5.tgz", 1523 | "integrity": "sha512-VNYPRfGfmZLx0Ye20jWzHUjyTW/c+6Wq+iLhDzUI4XmhrDd9l/FozXV3F2xOaXjvp0co0+v1YSR3CMP6g+VvLQ==", 1524 | "dev": true, 1525 | "requires": { 1526 | "object.getownpropertydescriptors": "^2.0.3", 1527 | "semver": "^5.7.0" 1528 | } 1529 | }, 1530 | "npm-run-path": { 1531 | "version": "2.0.2", 1532 | "resolved": "https://registry.npmjs.org/npm-run-path/-/npm-run-path-2.0.2.tgz", 1533 | "integrity": "sha1-NakjLfo11wZ7TLLd8jV7GHFTbF8=", 1534 | "dev": true, 1535 | "requires": { 1536 | "path-key": "^2.0.0" 1537 | } 1538 | }, 1539 | "number-is-nan": { 1540 | "version": "1.0.1", 1541 | "resolved": "https://registry.npmjs.org/number-is-nan/-/number-is-nan-1.0.1.tgz", 1542 | "integrity": "sha1-CXtgK1NCKlIsGvuHkDGDNpQaAR0=", 1543 | "dev": true 1544 | }, 1545 | "object-keys": { 1546 | "version": "1.1.1", 1547 | "resolved": "https://registry.npmjs.org/object-keys/-/object-keys-1.1.1.tgz", 1548 | "integrity": "sha512-NuAESUOUMrlIXOfHKzD6bpPu3tYt3xvjNdRIQ+FeT0lNb4K8WR70CaDxhuNguS2XG+GjkyMwOzsN5ZktImfhLA==", 1549 | "dev": true 1550 | }, 1551 | "object.assign": { 1552 | "version": "4.1.0", 1553 | "resolved": "https://registry.npmjs.org/object.assign/-/object.assign-4.1.0.tgz", 1554 | "integrity": "sha512-exHJeq6kBKj58mqGyTQ9DFvrZC/eR6OwxzoM9YRoGBqrXYonaFyGiFMuc9VZrXf7DarreEwMpurG3dd+CNyW5w==", 1555 | "dev": true, 1556 | "requires": { 1557 | "define-properties": "^1.1.2", 1558 | "function-bind": "^1.1.1", 1559 | "has-symbols": "^1.0.0", 1560 | "object-keys": "^1.0.11" 1561 | } 1562 | }, 1563 | "object.getownpropertydescriptors": { 1564 | "version": "2.0.3", 1565 | "resolved": "https://registry.npmjs.org/object.getownpropertydescriptors/-/object.getownpropertydescriptors-2.0.3.tgz", 1566 | "integrity": "sha1-h1jIRvW0B62rDyNuCYbxSwUcqhY=", 1567 | "dev": true, 1568 | "requires": { 1569 | "define-properties": "^1.1.2", 1570 | "es-abstract": "^1.5.1" 1571 | } 1572 | }, 1573 | "once": { 1574 | "version": "1.4.0", 1575 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 1576 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 1577 | "dev": true, 1578 | "requires": { 1579 | "wrappy": "1" 1580 | } 1581 | }, 1582 | "onetime": { 1583 | "version": "5.1.0", 1584 | "resolved": "https://registry.npmjs.org/onetime/-/onetime-5.1.0.tgz", 1585 | "integrity": "sha512-5NcSkPHhwTVFIQN+TUqXoS5+dlElHXdpAWu9I0HP20YOtIi+aZ0Ct82jdlILDxjLEAWwvm+qj1m6aEtsDVmm6Q==", 1586 | "dev": true, 1587 | "requires": { 1588 | "mimic-fn": "^2.1.0" 1589 | } 1590 | }, 1591 | "optionator": { 1592 | "version": "0.8.2", 1593 | "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.8.2.tgz", 1594 | "integrity": "sha1-NkxeQJ0/TWMB1sC0wFu6UBgK62Q=", 1595 | "dev": true, 1596 | "requires": { 1597 | "deep-is": "~0.1.3", 1598 | "fast-levenshtein": "~2.0.4", 1599 | "levn": "~0.3.0", 1600 | "prelude-ls": "~1.1.2", 1601 | "type-check": "~0.3.2", 1602 | "wordwrap": "~1.0.0" 1603 | } 1604 | }, 1605 | "os-tmpdir": { 1606 | "version": "1.0.2", 1607 | "resolved": "https://registry.npmjs.org/os-tmpdir/-/os-tmpdir-1.0.2.tgz", 1608 | "integrity": "sha1-u+Z0BseaqFxc/sdm/lc0VV36EnQ=", 1609 | "dev": true 1610 | }, 1611 | "p-defer": { 1612 | "version": "1.0.0", 1613 | "resolved": "https://registry.npmjs.org/p-defer/-/p-defer-1.0.0.tgz", 1614 | "integrity": "sha1-n26xgvbJqozXQwBKfU+WsZaw+ww=", 1615 | "dev": true 1616 | }, 1617 | "p-finally": { 1618 | "version": "1.0.0", 1619 | "resolved": "https://registry.npmjs.org/p-finally/-/p-finally-1.0.0.tgz", 1620 | "integrity": "sha1-P7z7FbiZpEEjs0ttzBi3JDNqLK4=", 1621 | "dev": true 1622 | }, 1623 | "p-is-promise": { 1624 | "version": "2.1.0", 1625 | "resolved": "https://registry.npmjs.org/p-is-promise/-/p-is-promise-2.1.0.tgz", 1626 | "integrity": "sha512-Y3W0wlRPK8ZMRbNq97l4M5otioeA5lm1z7bkNkxCka8HSPjR0xRWmpCmc9utiaLP9Jb1eD8BgeIxTW4AIF45Pg==", 1627 | "dev": true 1628 | }, 1629 | "p-limit": { 1630 | "version": "2.2.1", 1631 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-2.2.1.tgz", 1632 | "integrity": "sha512-85Tk+90UCVWvbDavCLKPOLC9vvY8OwEX/RtKF+/1OADJMVlFfEHOiMTPVyxg7mk/dKa+ipdHm0OUkTvCpMTuwg==", 1633 | "dev": true, 1634 | "requires": { 1635 | "p-try": "^2.0.0" 1636 | } 1637 | }, 1638 | "p-locate": { 1639 | "version": "3.0.0", 1640 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-3.0.0.tgz", 1641 | "integrity": "sha512-x+12w/To+4GFfgJhBEpiDcLozRJGegY+Ei7/z0tSLkMmxGZNybVMSfWj9aJn8Z5Fc7dBUNJOOVgPv2H7IwulSQ==", 1642 | "dev": true, 1643 | "requires": { 1644 | "p-limit": "^2.0.0" 1645 | } 1646 | }, 1647 | "p-try": { 1648 | "version": "2.2.0", 1649 | "resolved": "https://registry.npmjs.org/p-try/-/p-try-2.2.0.tgz", 1650 | "integrity": "sha512-R4nPAVTAU0B9D35/Gk3uJf/7XYbQcyohSKdvAxIRSNghFl4e71hVoGnBNQz9cWaXxO2I10KTC+3jMdvvoKw6dQ==", 1651 | "dev": true 1652 | }, 1653 | "parent-module": { 1654 | "version": "1.0.1", 1655 | "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz", 1656 | "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==", 1657 | "dev": true, 1658 | "requires": { 1659 | "callsites": "^3.0.0" 1660 | } 1661 | }, 1662 | "path-exists": { 1663 | "version": "4.0.0", 1664 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz", 1665 | "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==", 1666 | "dev": true 1667 | }, 1668 | "path-is-absolute": { 1669 | "version": "1.0.1", 1670 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 1671 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=", 1672 | "dev": true 1673 | }, 1674 | "path-is-inside": { 1675 | "version": "1.0.2", 1676 | "resolved": "https://registry.npmjs.org/path-is-inside/-/path-is-inside-1.0.2.tgz", 1677 | "integrity": "sha1-NlQX3t5EQw0cEa9hAn+s8HS9/FM=", 1678 | "dev": true 1679 | }, 1680 | "path-key": { 1681 | "version": "2.0.1", 1682 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-2.0.1.tgz", 1683 | "integrity": "sha1-QRyttXTFoUDTpLGRDUDYDMn0C0A=", 1684 | "dev": true 1685 | }, 1686 | "prelude-ls": { 1687 | "version": "1.1.2", 1688 | "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.1.2.tgz", 1689 | "integrity": "sha1-IZMqVJ9eUv/ZqCf1cOBL5iqX2lQ=", 1690 | "dev": true 1691 | }, 1692 | "progress": { 1693 | "version": "2.0.3", 1694 | "resolved": "https://registry.npmjs.org/progress/-/progress-2.0.3.tgz", 1695 | "integrity": "sha512-7PiHtLll5LdnKIMw100I+8xJXR5gW2QwWYkT6iJva0bXitZKa/XMrSbdmg3r2Xnaidz9Qumd0VPaMrZlF9V9sA==", 1696 | "dev": true 1697 | }, 1698 | "pump": { 1699 | "version": "3.0.0", 1700 | "resolved": "https://registry.npmjs.org/pump/-/pump-3.0.0.tgz", 1701 | "integrity": "sha512-LwZy+p3SFs1Pytd/jYct4wpv49HiYCqd9Rlc5ZVdk0V+8Yzv6jR5Blk3TRmPL1ft69TxP0IMZGJ+WPFU2BFhww==", 1702 | "dev": true, 1703 | "requires": { 1704 | "end-of-stream": "^1.1.0", 1705 | "once": "^1.3.1" 1706 | } 1707 | }, 1708 | "punycode": { 1709 | "version": "2.1.1", 1710 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.1.1.tgz", 1711 | "integrity": "sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A==", 1712 | "dev": true 1713 | }, 1714 | "regexpp": { 1715 | "version": "2.0.1", 1716 | "resolved": "https://registry.npmjs.org/regexpp/-/regexpp-2.0.1.tgz", 1717 | "integrity": "sha512-lv0M6+TkDVniA3aD1Eg0DVpfU/booSu7Eev3TDO/mZKHBfVjgCGTV4t4buppESEYDtkArYFOxTJWv6S5C+iaNw==", 1718 | "dev": true 1719 | }, 1720 | "replaceall": { 1721 | "version": "0.1.6", 1722 | "resolved": "https://registry.npmjs.org/replaceall/-/replaceall-0.1.6.tgz", 1723 | "integrity": "sha1-gdgax663LX9cSUKt8ml6MiBojY4=", 1724 | "dev": true 1725 | }, 1726 | "require-directory": { 1727 | "version": "2.1.1", 1728 | "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz", 1729 | "integrity": "sha1-jGStX9MNqxyXbiNE/+f3kqam30I=", 1730 | "dev": true 1731 | }, 1732 | "require-main-filename": { 1733 | "version": "2.0.0", 1734 | "resolved": "https://registry.npmjs.org/require-main-filename/-/require-main-filename-2.0.0.tgz", 1735 | "integrity": "sha512-NKN5kMDylKuldxYLSUfrbo5Tuzh4hd+2E8NPPX02mZtn1VuREQToYe/ZdlJy+J3uCpfaiGF05e7B8W0iXbQHmg==", 1736 | "dev": true 1737 | }, 1738 | "resolve-from": { 1739 | "version": "4.0.0", 1740 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", 1741 | "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==", 1742 | "dev": true 1743 | }, 1744 | "restore-cursor": { 1745 | "version": "3.1.0", 1746 | "resolved": "https://registry.npmjs.org/restore-cursor/-/restore-cursor-3.1.0.tgz", 1747 | "integrity": "sha512-l+sSefzHpj5qimhFSE5a8nufZYAM3sBSVMAPtYkmC+4EH2anSGaEMXSD0izRQbu9nfyQ9y5JrVmp7E8oZrUjvA==", 1748 | "dev": true, 1749 | "requires": { 1750 | "onetime": "^5.1.0", 1751 | "signal-exit": "^3.0.2" 1752 | } 1753 | }, 1754 | "rimraf": { 1755 | "version": "2.6.3", 1756 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.6.3.tgz", 1757 | "integrity": "sha512-mwqeW5XsA2qAejG46gYdENaxXjx9onRNCfn7L0duuP4hCuTIi/QO7PDK07KJfp1d+izWPrzEJDcSqBa0OZQriA==", 1758 | "dev": true, 1759 | "requires": { 1760 | "glob": "^7.1.3" 1761 | } 1762 | }, 1763 | "run-async": { 1764 | "version": "2.3.0", 1765 | "resolved": "https://registry.npmjs.org/run-async/-/run-async-2.3.0.tgz", 1766 | "integrity": "sha1-A3GrSuC91yDUFm19/aZP96RFpsA=", 1767 | "dev": true, 1768 | "requires": { 1769 | "is-promise": "^2.1.0" 1770 | } 1771 | }, 1772 | "rxjs": { 1773 | "version": "6.5.2", 1774 | "resolved": "https://registry.npmjs.org/rxjs/-/rxjs-6.5.2.tgz", 1775 | "integrity": "sha512-HUb7j3kvb7p7eCUHE3FqjoDsC1xfZQ4AHFWfTKSpZ+sAhhz5X1WX0ZuUqWbzB2QhSLp3DoLUG+hMdEDKqWo2Zg==", 1776 | "dev": true, 1777 | "requires": { 1778 | "tslib": "^1.9.0" 1779 | } 1780 | }, 1781 | "safer-buffer": { 1782 | "version": "2.1.2", 1783 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", 1784 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==", 1785 | "dev": true 1786 | }, 1787 | "semver": { 1788 | "version": "5.7.1", 1789 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", 1790 | "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==", 1791 | "dev": true 1792 | }, 1793 | "set-blocking": { 1794 | "version": "2.0.0", 1795 | "resolved": "https://registry.npmjs.org/set-blocking/-/set-blocking-2.0.0.tgz", 1796 | "integrity": "sha1-BF+XgtARrppoA93TgrJDkrPYkPc=", 1797 | "dev": true 1798 | }, 1799 | "shebang-command": { 1800 | "version": "1.2.0", 1801 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-1.2.0.tgz", 1802 | "integrity": "sha1-RKrGW2lbAzmJaMOfNj/uXer98eo=", 1803 | "dev": true, 1804 | "requires": { 1805 | "shebang-regex": "^1.0.0" 1806 | } 1807 | }, 1808 | "shebang-regex": { 1809 | "version": "1.0.0", 1810 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-1.0.0.tgz", 1811 | "integrity": "sha1-2kL0l0DAtC2yypcoVxyxkMmO/qM=", 1812 | "dev": true 1813 | }, 1814 | "signal-exit": { 1815 | "version": "3.0.2", 1816 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.2.tgz", 1817 | "integrity": "sha1-tf3AjxKH6hF4Yo5BXiUTK3NkbG0=", 1818 | "dev": true 1819 | }, 1820 | "slice-ansi": { 1821 | "version": "2.1.0", 1822 | "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-2.1.0.tgz", 1823 | "integrity": "sha512-Qu+VC3EwYLldKa1fCxuuvULvSJOKEgk9pi8dZeCVK7TqBfUNTH4sFkk4joj8afVSfAYgJoSOetjx9QWOJ5mYoQ==", 1824 | "dev": true, 1825 | "requires": { 1826 | "ansi-styles": "^3.2.0", 1827 | "astral-regex": "^1.0.0", 1828 | "is-fullwidth-code-point": "^2.0.0" 1829 | } 1830 | }, 1831 | "sprintf-js": { 1832 | "version": "1.0.3", 1833 | "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz", 1834 | "integrity": "sha1-BOaSb2YolTVPPdAVIDYzuFcpfiw=", 1835 | "dev": true 1836 | }, 1837 | "string-width": { 1838 | "version": "2.1.1", 1839 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-2.1.1.tgz", 1840 | "integrity": "sha512-nOqH59deCq9SRHlxq1Aw85Jnt4w6KvLKqWVik6oA9ZklXLNIOlqg4F2yrT1MVaTjAqvVwdfeZ7w7aCvJD7ugkw==", 1841 | "dev": true, 1842 | "requires": { 1843 | "is-fullwidth-code-point": "^2.0.0", 1844 | "strip-ansi": "^4.0.0" 1845 | } 1846 | }, 1847 | "strip-ansi": { 1848 | "version": "4.0.0", 1849 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-4.0.0.tgz", 1850 | "integrity": "sha1-qEeQIusaw2iocTibY1JixQXuNo8=", 1851 | "dev": true, 1852 | "requires": { 1853 | "ansi-regex": "^3.0.0" 1854 | } 1855 | }, 1856 | "strip-eof": { 1857 | "version": "1.0.0", 1858 | "resolved": "https://registry.npmjs.org/strip-eof/-/strip-eof-1.0.0.tgz", 1859 | "integrity": "sha1-u0P/VZim6wXYm1n80SnJgzE2Br8=", 1860 | "dev": true 1861 | }, 1862 | "strip-json-comments": { 1863 | "version": "2.0.1", 1864 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-2.0.1.tgz", 1865 | "integrity": "sha1-PFMZQukIwml8DsNEhYwobHygpgo=", 1866 | "dev": true 1867 | }, 1868 | "supports-color": { 1869 | "version": "6.0.0", 1870 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-6.0.0.tgz", 1871 | "integrity": "sha512-on9Kwidc1IUQo+bQdhi8+Tijpo0e1SS6RoGo2guUwn5vdaxw8RXOF9Vb2ws+ihWOmh4JnCJOvaziZWP1VABaLg==", 1872 | "dev": true, 1873 | "requires": { 1874 | "has-flag": "^3.0.0" 1875 | } 1876 | }, 1877 | "table": { 1878 | "version": "5.4.6", 1879 | "resolved": "https://registry.npmjs.org/table/-/table-5.4.6.tgz", 1880 | "integrity": "sha512-wmEc8m4fjnob4gt5riFRtTu/6+4rSe12TpAELNSqHMfF3IqnA+CH37USM6/YR3qRZv7e56kAEAtd6nKZaxe0Ug==", 1881 | "dev": true, 1882 | "requires": { 1883 | "ajv": "^6.10.2", 1884 | "lodash": "^4.17.14", 1885 | "slice-ansi": "^2.1.0", 1886 | "string-width": "^3.0.0" 1887 | }, 1888 | "dependencies": { 1889 | "ansi-regex": { 1890 | "version": "4.1.0", 1891 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.1.0.tgz", 1892 | "integrity": "sha512-1apePfXM1UOSqw0o9IiFAovVz9M5S1Dg+4TrDwfMewQ6p/rmMueb7tWZjQ1rx4Loy1ArBggoqGpfqqdI4rondg==", 1893 | "dev": true 1894 | }, 1895 | "string-width": { 1896 | "version": "3.1.0", 1897 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-3.1.0.tgz", 1898 | "integrity": "sha512-vafcv6KjVZKSgz06oM/H6GDBrAtz8vdhQakGjFIvNrHA6y3HCF1CInLy+QLq8dTJPQ1b+KDUqDFctkdRW44e1w==", 1899 | "dev": true, 1900 | "requires": { 1901 | "emoji-regex": "^7.0.1", 1902 | "is-fullwidth-code-point": "^2.0.0", 1903 | "strip-ansi": "^5.1.0" 1904 | } 1905 | }, 1906 | "strip-ansi": { 1907 | "version": "5.2.0", 1908 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.2.0.tgz", 1909 | "integrity": "sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA==", 1910 | "dev": true, 1911 | "requires": { 1912 | "ansi-regex": "^4.1.0" 1913 | } 1914 | } 1915 | } 1916 | }, 1917 | "text-table": { 1918 | "version": "0.2.0", 1919 | "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz", 1920 | "integrity": "sha1-f17oI66AUgfACvLfSoTsP8+lcLQ=", 1921 | "dev": true 1922 | }, 1923 | "through": { 1924 | "version": "2.3.8", 1925 | "resolved": "https://registry.npmjs.org/through/-/through-2.3.8.tgz", 1926 | "integrity": "sha1-DdTJ/6q8NXlgsbckEV1+Doai4fU=", 1927 | "dev": true 1928 | }, 1929 | "tmp": { 1930 | "version": "0.0.33", 1931 | "resolved": "https://registry.npmjs.org/tmp/-/tmp-0.0.33.tgz", 1932 | "integrity": "sha512-jRCJlojKnZ3addtTOjdIqoRuPEKBvNXcGYqzO6zWZX8KfKEpnGY5jfggJQ3EjKuu8D4bJRr0y+cYJFmYbImXGw==", 1933 | "dev": true, 1934 | "requires": { 1935 | "os-tmpdir": "~1.0.2" 1936 | } 1937 | }, 1938 | "tslib": { 1939 | "version": "1.10.0", 1940 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.10.0.tgz", 1941 | "integrity": "sha512-qOebF53frne81cf0S9B41ByenJ3/IuH8yJKngAX35CmiZySA0khhkovshKK+jGCaMnVomla7gVlIcc3EvKPbTQ==", 1942 | "dev": true 1943 | }, 1944 | "type-check": { 1945 | "version": "0.3.2", 1946 | "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.3.2.tgz", 1947 | "integrity": "sha1-WITKtRLPHTVeP7eE8wgEsrUg23I=", 1948 | "dev": true, 1949 | "requires": { 1950 | "prelude-ls": "~1.1.2" 1951 | } 1952 | }, 1953 | "type-detect": { 1954 | "version": "4.0.8", 1955 | "resolved": "https://registry.npmjs.org/type-detect/-/type-detect-4.0.8.tgz", 1956 | "integrity": "sha512-0fr/mIH1dlO+x7TlcMy+bIDqKPsw/70tVyeHW787goQjhmqaZe10uwLujubK9q9Lg6Fiho1KUKDYz0Z7k7g5/g==", 1957 | "dev": true 1958 | }, 1959 | "type-fest": { 1960 | "version": "0.5.2", 1961 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.5.2.tgz", 1962 | "integrity": "sha512-DWkS49EQKVX//Tbupb9TFa19c7+MK1XmzkrZUR8TAktmE/DizXoaoJV6TZ/tSIPXipqNiRI6CyAe7x69Jb6RSw==", 1963 | "dev": true 1964 | }, 1965 | "uri-js": { 1966 | "version": "4.2.2", 1967 | "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.2.2.tgz", 1968 | "integrity": "sha512-KY9Frmirql91X2Qgjry0Wd4Y+YTdrdZheS8TFwvkbLWf/G5KNJDCh6pKL5OZctEW4+0Baa5idK2ZQuELRwPznQ==", 1969 | "dev": true, 1970 | "requires": { 1971 | "punycode": "^2.1.0" 1972 | } 1973 | }, 1974 | "v8-compile-cache": { 1975 | "version": "2.1.0", 1976 | "resolved": "https://registry.npmjs.org/v8-compile-cache/-/v8-compile-cache-2.1.0.tgz", 1977 | "integrity": "sha512-usZBT3PW+LOjM25wbqIlZwPeJV+3OSz3M1k1Ws8snlW39dZyYL9lOGC5FgPVHfk0jKmjiDV8Z0mIbVQPiwFs7g==", 1978 | "dev": true 1979 | }, 1980 | "which": { 1981 | "version": "1.3.1", 1982 | "resolved": "https://registry.npmjs.org/which/-/which-1.3.1.tgz", 1983 | "integrity": "sha512-HxJdYWq1MTIQbJ3nw0cqssHoTNU267KlrDuGZ1WYlxDStUtKUhOaJmh112/TZmHxxUfuJqPXSOm7tDyas0OSIQ==", 1984 | "dev": true, 1985 | "requires": { 1986 | "isexe": "^2.0.0" 1987 | } 1988 | }, 1989 | "which-module": { 1990 | "version": "2.0.0", 1991 | "resolved": "https://registry.npmjs.org/which-module/-/which-module-2.0.0.tgz", 1992 | "integrity": "sha1-2e8H3Od7mQK4o6j6SzHD4/fm6Ho=", 1993 | "dev": true 1994 | }, 1995 | "wide-align": { 1996 | "version": "1.1.3", 1997 | "resolved": "https://registry.npmjs.org/wide-align/-/wide-align-1.1.3.tgz", 1998 | "integrity": "sha512-QGkOQc8XL6Bt5PwnsExKBPuMKBxnGxWWW3fU55Xt4feHozMUhdUMaBCk290qpm/wG5u/RSKzwdAC4i51YigihA==", 1999 | "dev": true, 2000 | "requires": { 2001 | "string-width": "^1.0.2 || 2" 2002 | } 2003 | }, 2004 | "word-wrap": { 2005 | "version": "1.2.3", 2006 | "resolved": "https://registry.npmjs.org/word-wrap/-/word-wrap-1.2.3.tgz", 2007 | "integrity": "sha512-Hz/mrNwitNRh/HUAtM/VT/5VH+ygD6DV7mYKZAtHOrbs8U7lvPS6xf7EJKMF0uW1KJCl0H701g3ZGus+muE5vQ==", 2008 | "dev": true 2009 | }, 2010 | "wordwrap": { 2011 | "version": "1.0.0", 2012 | "resolved": "https://registry.npmjs.org/wordwrap/-/wordwrap-1.0.0.tgz", 2013 | "integrity": "sha1-J1hIEIkUVqQXHI0CJkQa3pDLyus=", 2014 | "dev": true 2015 | }, 2016 | "wrap-ansi": { 2017 | "version": "2.1.0", 2018 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-2.1.0.tgz", 2019 | "integrity": "sha1-2Pw9KE3QV5T+hJc8rs3Rz4JP3YU=", 2020 | "dev": true, 2021 | "requires": { 2022 | "string-width": "^1.0.1", 2023 | "strip-ansi": "^3.0.1" 2024 | }, 2025 | "dependencies": { 2026 | "ansi-regex": { 2027 | "version": "2.1.1", 2028 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-2.1.1.tgz", 2029 | "integrity": "sha1-w7M6te42DYbg5ijwRorn7yfWVN8=", 2030 | "dev": true 2031 | }, 2032 | "is-fullwidth-code-point": { 2033 | "version": "1.0.0", 2034 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-1.0.0.tgz", 2035 | "integrity": "sha1-754xOG8DGn8NZDr4L95QxFfvAMs=", 2036 | "dev": true, 2037 | "requires": { 2038 | "number-is-nan": "^1.0.0" 2039 | } 2040 | }, 2041 | "string-width": { 2042 | "version": "1.0.2", 2043 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-1.0.2.tgz", 2044 | "integrity": "sha1-EYvfW4zcUaKn5w0hHgfisLmxB9M=", 2045 | "dev": true, 2046 | "requires": { 2047 | "code-point-at": "^1.0.0", 2048 | "is-fullwidth-code-point": "^1.0.0", 2049 | "strip-ansi": "^3.0.0" 2050 | } 2051 | }, 2052 | "strip-ansi": { 2053 | "version": "3.0.1", 2054 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-3.0.1.tgz", 2055 | "integrity": "sha1-ajhfuIU9lS1f8F0Oiq+UJ43GPc8=", 2056 | "dev": true, 2057 | "requires": { 2058 | "ansi-regex": "^2.0.0" 2059 | } 2060 | } 2061 | } 2062 | }, 2063 | "wrappy": { 2064 | "version": "1.0.2", 2065 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 2066 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=", 2067 | "dev": true 2068 | }, 2069 | "write": { 2070 | "version": "1.0.3", 2071 | "resolved": "https://registry.npmjs.org/write/-/write-1.0.3.tgz", 2072 | "integrity": "sha512-/lg70HAjtkUgWPVZhZcm+T4hkL8Zbtp1nFNOn3lRrxnlv50SRBv7cR7RqR+GMsd3hUXy9hWBo4CHTbFTcOYwig==", 2073 | "dev": true, 2074 | "requires": { 2075 | "mkdirp": "^0.5.1" 2076 | } 2077 | }, 2078 | "y18n": { 2079 | "version": "4.0.3", 2080 | "resolved": "https://registry.npmjs.org/y18n/-/y18n-4.0.3.tgz", 2081 | "integrity": "sha512-JKhqTOwSrqNA1NY5lSztJ1GrBiUodLMmIZuLiDaMRJ+itFd+ABVE8XBjOvIWL+rSqNDC74LCSFmlb/U4UZ4hJQ==", 2082 | "dev": true 2083 | }, 2084 | "yargs": { 2085 | "version": "15.4.1", 2086 | "resolved": "https://registry.npmjs.org/yargs/-/yargs-15.4.1.tgz", 2087 | "integrity": "sha512-aePbxDmcYW++PaqBsJ+HYUFwCdv4LVvdnhBy78E57PIor8/OVvhMrADFFEDh8DHDFRv/O9i3lPhsENjO7QX0+A==", 2088 | "dev": true, 2089 | "requires": { 2090 | "cliui": "^6.0.0", 2091 | "decamelize": "^1.2.0", 2092 | "find-up": "^4.1.0", 2093 | "get-caller-file": "^2.0.1", 2094 | "require-directory": "^2.1.1", 2095 | "require-main-filename": "^2.0.0", 2096 | "set-blocking": "^2.0.0", 2097 | "string-width": "^4.2.0", 2098 | "which-module": "^2.0.0", 2099 | "y18n": "^4.0.0", 2100 | "yargs-parser": "^18.1.2" 2101 | }, 2102 | "dependencies": { 2103 | "ansi-regex": { 2104 | "version": "5.0.0", 2105 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.0.tgz", 2106 | "integrity": "sha512-bY6fj56OUQ0hU1KjFNDQuJFezqKdrAyFdIevADiqrWHwSlbmBNMHp5ak2f40Pm8JTFyM2mqxkG6ngkHO11f/lg==", 2107 | "dev": true 2108 | }, 2109 | "emoji-regex": { 2110 | "version": "8.0.0", 2111 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", 2112 | "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", 2113 | "dev": true 2114 | }, 2115 | "find-up": { 2116 | "version": "4.1.0", 2117 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-4.1.0.tgz", 2118 | "integrity": "sha512-PpOwAdQ/YlXQ2vj8a3h8IipDuYRi3wceVQQGYWxNINccq40Anw7BlsEXCMbt1Zt+OLA6Fq9suIpIWD0OsnISlw==", 2119 | "dev": true, 2120 | "requires": { 2121 | "locate-path": "^5.0.0", 2122 | "path-exists": "^4.0.0" 2123 | } 2124 | }, 2125 | "is-fullwidth-code-point": { 2126 | "version": "3.0.0", 2127 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", 2128 | "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", 2129 | "dev": true 2130 | }, 2131 | "locate-path": { 2132 | "version": "5.0.0", 2133 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-5.0.0.tgz", 2134 | "integrity": "sha512-t7hw9pI+WvuwNJXwk5zVHpyhIqzg2qTlklJOf0mVxGSbe3Fp2VieZcduNYjaLDoy6p9uGpQEGWG87WpMKlNq8g==", 2135 | "dev": true, 2136 | "requires": { 2137 | "p-locate": "^4.1.0" 2138 | } 2139 | }, 2140 | "p-locate": { 2141 | "version": "4.1.0", 2142 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-4.1.0.tgz", 2143 | "integrity": "sha512-R79ZZ/0wAxKGu3oYMlz8jy/kbhsNrS7SKZ7PxEHBgJ5+F2mtFW2fK2cOtBh1cHYkQsbzFV7I+EoRKe6Yt0oK7A==", 2144 | "dev": true, 2145 | "requires": { 2146 | "p-limit": "^2.2.0" 2147 | } 2148 | }, 2149 | "string-width": { 2150 | "version": "4.2.2", 2151 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.2.tgz", 2152 | "integrity": "sha512-XBJbT3N4JhVumXE0eoLU9DCjcaF92KLNqTmFCnG1pf8duUxFGwtP6AD6nkjw9a3IdiRtL3E2w3JDiE/xi3vOeA==", 2153 | "dev": true, 2154 | "requires": { 2155 | "emoji-regex": "^8.0.0", 2156 | "is-fullwidth-code-point": "^3.0.0", 2157 | "strip-ansi": "^6.0.0" 2158 | } 2159 | }, 2160 | "strip-ansi": { 2161 | "version": "6.0.0", 2162 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.0.tgz", 2163 | "integrity": "sha512-AuvKTrTfQNYNIctbR1K/YGTR1756GycPsg7b9bdV9Duqur4gv6aKqHXah67Z8ImS7WEz5QVcOtlfW2rZEugt6w==", 2164 | "dev": true, 2165 | "requires": { 2166 | "ansi-regex": "^5.0.0" 2167 | } 2168 | }, 2169 | "yargs-parser": { 2170 | "version": "18.1.3", 2171 | "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-18.1.3.tgz", 2172 | "integrity": "sha512-o50j0JeToy/4K6OZcaQmW6lyXXKhq7csREXcDwk2omFPJEwUNOVtJKvmDr9EI1fAJZUyZcRF7kxGBWmRXudrCQ==", 2173 | "dev": true, 2174 | "requires": { 2175 | "camelcase": "^5.0.0", 2176 | "decamelize": "^1.2.0" 2177 | } 2178 | } 2179 | } 2180 | }, 2181 | "yargs-unparser": { 2182 | "version": "1.5.0", 2183 | "resolved": "https://registry.npmjs.org/yargs-unparser/-/yargs-unparser-1.5.0.tgz", 2184 | "integrity": "sha512-HK25qidFTCVuj/D1VfNiEndpLIeJN78aqgR23nL3y4N0U/91cOAzqfHlF8n2BvoNDcZmJKin3ddNSvOxSr8flw==", 2185 | "dev": true, 2186 | "requires": { 2187 | "flat": "^4.1.0", 2188 | "lodash": "^4.17.11", 2189 | "yargs": "^12.0.5" 2190 | }, 2191 | "dependencies": { 2192 | "camelcase": { 2193 | "version": "5.3.1", 2194 | "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-5.3.1.tgz", 2195 | "integrity": "sha512-L28STB170nwWS63UjtlEOE3dldQApaJXZkOI1uMFfzf3rRuPegHaHesyee+YxQ+W6SvRDQV6UrdOdRiR153wJg==", 2196 | "dev": true 2197 | }, 2198 | "cliui": { 2199 | "version": "4.1.0", 2200 | "resolved": "https://registry.npmjs.org/cliui/-/cliui-4.1.0.tgz", 2201 | "integrity": "sha512-4FG+RSG9DL7uEwRUZXZn3SS34DiDPfzP0VOiEwtUWlE+AR2EIg+hSyvrIgUUfhdgR/UkAeW2QHgeP+hWrXs7jQ==", 2202 | "dev": true, 2203 | "requires": { 2204 | "string-width": "^2.1.1", 2205 | "strip-ansi": "^4.0.0", 2206 | "wrap-ansi": "^2.0.0" 2207 | } 2208 | }, 2209 | "get-caller-file": { 2210 | "version": "1.0.3", 2211 | "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-1.0.3.tgz", 2212 | "integrity": "sha512-3t6rVToeoZfYSGd8YoLFR2DJkiQrIiUrGcjvFX2mDw3bn6k2OtwHN0TNCLbBO+w8qTvimhDkv+LSscbJY1vE6w==", 2213 | "dev": true 2214 | }, 2215 | "invert-kv": { 2216 | "version": "2.0.0", 2217 | "resolved": "https://registry.npmjs.org/invert-kv/-/invert-kv-2.0.0.tgz", 2218 | "integrity": "sha512-wPVv/y/QQ/Uiirj/vh3oP+1Ww+AWehmi1g5fFWGPF6IpCBCDVrhgHRMvrLfdYcwDh3QJbGXDW4JAuzxElLSqKA==", 2219 | "dev": true 2220 | }, 2221 | "lcid": { 2222 | "version": "2.0.0", 2223 | "resolved": "https://registry.npmjs.org/lcid/-/lcid-2.0.0.tgz", 2224 | "integrity": "sha512-avPEb8P8EGnwXKClwsNUgryVjllcRqtMYa49NTsbQagYuT1DcXnl1915oxWjoyGrXR6zH/Y0Zc96xWsPcoDKeA==", 2225 | "dev": true, 2226 | "requires": { 2227 | "invert-kv": "^2.0.0" 2228 | } 2229 | }, 2230 | "os-locale": { 2231 | "version": "3.1.0", 2232 | "resolved": "https://registry.npmjs.org/os-locale/-/os-locale-3.1.0.tgz", 2233 | "integrity": "sha512-Z8l3R4wYWM40/52Z+S265okfFj8Kt2cC2MKY+xNi3kFs+XGI7WXu/I309QQQYbRW4ijiZ+yxs9pqEhJh0DqW3Q==", 2234 | "dev": true, 2235 | "requires": { 2236 | "execa": "^1.0.0", 2237 | "lcid": "^2.0.0", 2238 | "mem": "^4.0.0" 2239 | } 2240 | }, 2241 | "require-main-filename": { 2242 | "version": "1.0.1", 2243 | "resolved": "https://registry.npmjs.org/require-main-filename/-/require-main-filename-1.0.1.tgz", 2244 | "integrity": "sha1-l/cXtp1IeE9fUmpsWqj/3aBVpNE=", 2245 | "dev": true 2246 | }, 2247 | "yargs": { 2248 | "version": "12.0.5", 2249 | "resolved": "https://registry.npmjs.org/yargs/-/yargs-12.0.5.tgz", 2250 | "integrity": "sha512-Lhz8TLaYnxq/2ObqHDql8dX8CJi97oHxrjUcYtzKbbykPtVW9WB+poxI+NM2UIzsMgNCZTIf0AQwsjK5yMAqZw==", 2251 | "dev": true, 2252 | "requires": { 2253 | "cliui": "^4.0.0", 2254 | "decamelize": "^1.2.0", 2255 | "find-up": "^3.0.0", 2256 | "get-caller-file": "^1.0.1", 2257 | "os-locale": "^3.0.0", 2258 | "require-directory": "^2.1.1", 2259 | "require-main-filename": "^1.0.1", 2260 | "set-blocking": "^2.0.0", 2261 | "string-width": "^2.0.0", 2262 | "which-module": "^2.0.0", 2263 | "y18n": "^3.2.1 || ^4.0.0", 2264 | "yargs-parser": "^11.1.1" 2265 | } 2266 | }, 2267 | "yargs-parser": { 2268 | "version": "11.1.1", 2269 | "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-11.1.1.tgz", 2270 | "integrity": "sha512-C6kB/WJDiaxONLJQnF8ccx9SEeoTTLek8RVbaOIsrAUS8VrBEXfmeSnCZxygc+XC2sNMBIwOOnfcxiynjHsVSQ==", 2271 | "dev": true, 2272 | "requires": { 2273 | "camelcase": "^5.0.0", 2274 | "decamelize": "^1.2.0" 2275 | } 2276 | } 2277 | } 2278 | } 2279 | } 2280 | } 2281 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "dot-prop-immutable", 3 | "version": "2.1.1", 4 | "description": "Immutable version of dot-prop with some extensions", 5 | "main": "lib/index.js", 6 | "types": "index.d.ts", 7 | "scripts": { 8 | "postversion": "git push && git push --tags", 9 | "preversion": "npm test", 10 | "test": "mocha" 11 | }, 12 | "repository": { 13 | "type": "git", 14 | "url": "https://github.com/debitoor/dot-prop-immutable" 15 | }, 16 | "author": "Debitoor", 17 | "license": "MIT", 18 | "bugs": { 19 | "url": "https://github.com/debitoor/dot-prop-immutable/issues" 20 | }, 21 | "keywords": [ 22 | "immutable", 23 | "dot-prop", 24 | "react", 25 | "redux", 26 | "obj", 27 | "object", 28 | "prop", 29 | "property", 30 | "dot", 31 | "path", 32 | "get", 33 | "access", 34 | "notation" 35 | ], 36 | "homepage": "https://github.com/debitoor/dot-prop-immutable", 37 | "devDependencies": { 38 | "@debitoor/eslint-config-debitoor": "3.0.2", 39 | "chai": "4.2.0", 40 | "eslint": "6.8.0", 41 | "mocha": "6.2.0", 42 | "mocha-eslint": "5.0.0" 43 | }, 44 | "engines": { 45 | "node": ">=6.0.0" 46 | } 47 | } 48 | -------------------------------------------------------------------------------- /test/.eslintrc: -------------------------------------------------------------------------------- 1 | { 2 | "extends": "../.eslintrc", 3 | "env": { 4 | "mocha": true 5 | }, 6 | "globals": { 7 | "expect": true 8 | } 9 | } -------------------------------------------------------------------------------- /test/dot-prop-immutable-merge.spec.js: -------------------------------------------------------------------------------- 1 | const dotProp = require('../lib'); 2 | 3 | describe('dot-prop-immutable.merge.spec.js', () => { 4 | 5 | const obj = { 6 | a: 1, 7 | b: { 8 | x: 1, 9 | y: 2 10 | }, 11 | c: [1, 2], 12 | d: null, 13 | 'b.x': 10 14 | }; 15 | 16 | const arr = [1, { a: [1, 2] }]; 17 | 18 | let result; 19 | describe('when have an object', () => { 20 | 21 | describe('merge an object value into object', () => { 22 | 23 | before(() => { 24 | result = dotProp.merge(obj, 'b', { z: 3 }); 25 | }); 26 | 27 | it('should merge prop', () => { 28 | expect(result).to.eql({ 29 | a: 1, 30 | b: { 31 | x: 1, 32 | y: 2, 33 | z: 3 34 | }, 35 | c: [1, 2], 36 | d: null, 37 | 'b.x': 10 38 | }); 39 | }); 40 | 41 | it('invariant', objInvariant); 42 | 43 | }); 44 | 45 | describe('merge an array value into array', () => { 46 | 47 | before(() => { 48 | result = dotProp.merge(obj, 'c', [3, 4]); 49 | }); 50 | 51 | it('should merge prop', () => { 52 | expect(result).to.eql({ 53 | a: 1, 54 | b: { 55 | x: 1, 56 | y: 2 57 | }, 58 | c: [1, 2, 3, 4], 59 | d: null, 60 | 'b.x': 10 61 | }); 62 | }); 63 | 64 | it('invariant', objInvariant); 65 | 66 | }); 67 | 68 | describe('merge an object value into null', () => { 69 | 70 | before(() => { 71 | result = dotProp.merge(obj, 'd', { foo: 'bar' }); 72 | }); 73 | 74 | it('should merge prop', () => { 75 | expect(result).to.eql({ 76 | a: 1, 77 | b: { 78 | x: 1, 79 | y: 2 80 | }, 81 | c: [1, 2], 82 | d: { foo: 'bar' }, 83 | 'b.x': 10 84 | }); 85 | }); 86 | 87 | it('invariant', objInvariant); 88 | 89 | }); 90 | 91 | describe('merge an object value into undefined', () => { 92 | 93 | before(() => { 94 | result = dotProp.merge(obj, 'z', { foo: 'bar' }); 95 | }); 96 | 97 | it('should merge prop', () => { 98 | expect(result).to.eql({ 99 | a: 1, 100 | b: { 101 | x: 1, 102 | y: 2 103 | }, 104 | c: [1, 2], 105 | d: null, 106 | z: { foo: 'bar' }, 107 | 'b.x': 10 108 | }); 109 | }); 110 | 111 | it('invariant', objInvariant); 112 | 113 | }); 114 | 115 | describe('when have an array', () => { 116 | it('invariant', arrInvariant); 117 | }); 118 | }); 119 | 120 | function objInvariant() { 121 | expect(obj).to.eql({ 122 | a: 1, 123 | b: { 124 | x: 1, 125 | y: 2 126 | }, 127 | c: [1, 2], 128 | d: null, 129 | 'b.x': 10 130 | }); 131 | } 132 | 133 | function arrInvariant() { 134 | expect(arr).to.eql( 135 | [1, { a: [1, 2] }] 136 | ); 137 | } 138 | }); 139 | 140 | 141 | -------------------------------------------------------------------------------- /test/dot-prop-immutable-number.spec.js: -------------------------------------------------------------------------------- 1 | const dotProp = require('../lib'); 2 | 3 | describe('dot-prop-immutable.number.spec.js', () => { 4 | 5 | const arr = [1, { a: false }]; 6 | 7 | let result; 8 | describe('when have an array', () => { 9 | 10 | describe('when set prop using number as path', () => { 11 | 12 | before(() => { 13 | result = dotProp.set(arr, 1, 3); 14 | }); 15 | 16 | it('should replace prop', () => { 17 | expect(result).to.eql([ 18 | 1, 19 | 3 20 | ]); 21 | }); 22 | 23 | it('invariant', arrInvariant); 24 | }); 25 | 26 | 27 | describe('when get prop using number as path', () => { 28 | 29 | before(() => { 30 | result = dotProp.get(arr, 1); 31 | }); 32 | 33 | it('should get prop', () => { 34 | expect(result).to.eql({ a: false }); 35 | }); 36 | 37 | it('invariant', arrInvariant); 38 | }); 39 | 40 | describe('when delete prop using number as path', () => { 41 | 42 | before(() => { 43 | result = dotProp.delete(arr, 1); 44 | }); 45 | 46 | it('should delete prop', () => { 47 | expect(result).to.eql([ 48 | 1 49 | ]); 50 | }); 51 | it('invariant', arrInvariant); 52 | }); 53 | }); 54 | 55 | function arrInvariant() { 56 | expect(arr).to.eql( 57 | [1, { a: false }] 58 | ); 59 | } 60 | }); 61 | 62 | 63 | -------------------------------------------------------------------------------- /test/dot-prop-immutable-toggle.spec.js: -------------------------------------------------------------------------------- 1 | const dotProp = require('../lib'); 2 | 3 | describe('dot-prop-immutable.toggle.spec.js', () => { 4 | 5 | const arr = [1, { a: false }]; 6 | 7 | let result; 8 | describe('when have an array', () => { 9 | 10 | describe('toggle a value', () => { 11 | 12 | before(() => { 13 | result = dotProp.toggle(arr, '1.a'); 14 | }); 15 | 16 | 17 | it('should toggle prop', () => { 18 | expect(result).to.eql( 19 | [1, { a: true }]); 20 | }); 21 | 22 | it('invariant', arrInvariant); 23 | }); 24 | }); 25 | 26 | function arrInvariant() { 27 | expect(arr).to.eql( 28 | [1, { a: false }] 29 | ); 30 | } 31 | }); 32 | 33 | 34 | -------------------------------------------------------------------------------- /test/dot-prop-immutable.spec.js: -------------------------------------------------------------------------------- 1 | const dotProp = require('../lib'); 2 | 3 | describe('dot-prop-immutable.spec.js', () => { 4 | 5 | const obj = { 6 | a: 1, 7 | b: { 8 | x: 1, 9 | y: 2 10 | }, 11 | c: [1, 2], 12 | 'b.x': 10 13 | }; 14 | 15 | const deeplyNestedObj = { 16 | flavour: { 17 | spicy: { 18 | pepper: { 19 | bell: 'mild', 20 | habanero: 'strong' 21 | } 22 | }, 23 | 'dotty.dot.flavours': { 24 | dalmatian: 'stracciatella' 25 | } 26 | }, 27 | 'www.example.com': 'domain' 28 | }; 29 | 30 | const arr = [1, { a: false }]; 31 | 32 | const arrWithUndefined = [1, undefined, 4]; 33 | 34 | let result; 35 | 36 | describe('when set', () => { 37 | 38 | describe('when have an object', () => { 39 | 40 | describe('when set prop', () => { 41 | 42 | before(() => { 43 | result = dotProp.set(obj, 'b', 3); 44 | }); 45 | 46 | it('should replace prop', () => { 47 | expect(result).to.eql({ 48 | a: 1, 49 | b: 3, 50 | c: [1, 2], 51 | 'b.x': 10 52 | }); 53 | }); 54 | 55 | it('invariant', objInvariant); 56 | }); 57 | 58 | describe('when set prop empty object', () => { 59 | 60 | before(() => { 61 | result = dotProp.set({}, 'b', 3); 62 | }); 63 | 64 | it('should replace prop', () => { 65 | expect(result).to.eql({ 66 | b: 3 67 | }); 68 | }); 69 | }); 70 | 71 | describe('when set prop empty path', () => { 72 | 73 | before(() => { 74 | result = dotProp.set({}, '', 3); 75 | }); 76 | 77 | it('should replace prop', () => { 78 | expect(result).to.eql({ 79 | '': 3 80 | }); 81 | }); 82 | }); 83 | 84 | describe('when set prop with function', () => { 85 | 86 | before(() => { 87 | result = dotProp.set(obj, 'a', v => v + 1); 88 | }); 89 | 90 | it('should replace prop', () => { 91 | expect(result).to.eql({ 92 | a: 2, 93 | b: { 94 | x: 1, 95 | y: 2 96 | }, 97 | c: [1, 2], 98 | 'b.x': 10 99 | }); 100 | }); 101 | 102 | it('invariant', objInvariant); 103 | }); 104 | 105 | describe('when set deep prop', () => { 106 | 107 | before(() => { 108 | result = dotProp.set(obj, 'b.x', 3); 109 | }); 110 | 111 | it('should replace prop', () => { 112 | expect(result).to.eql({ 113 | a: 1, 114 | b: { 115 | x: 3, 116 | y: 2 117 | }, 118 | c: [1, 2], 119 | 'b.x': 10 120 | }); 121 | }); 122 | 123 | it('invariant', objInvariant); 124 | }); 125 | 126 | describe('when set deep prop not defined', () => { 127 | 128 | before(() => { 129 | result = dotProp.set(obj, 'b.z.w', 3); 130 | }); 131 | 132 | it('should replace prop', () => { 133 | expect(result).to.eql({ 134 | a: 1, 135 | b: { 136 | x: 1, 137 | y: 2, 138 | z: { 139 | w: 3 140 | } 141 | }, 142 | c: [1, 2], 143 | 'b.x': 10 144 | }); 145 | }); 146 | 147 | it('invariant', objInvariant); 148 | }); 149 | 150 | describe('when set array[index]', () => { 151 | 152 | before(() => { 153 | result = dotProp.set(obj, 'c.0', 3); 154 | }); 155 | 156 | it('should replace prop', () => { 157 | expect(result).to.eql({ 158 | a: 1, 159 | b: { 160 | x: 1, 161 | y: 2 162 | }, 163 | c: [3, 2], 164 | 'b.x': 10 165 | }); 166 | }); 167 | 168 | it('invariant', objInvariant); 169 | }); 170 | 171 | describe('when set array[index] with function', () => { 172 | 173 | before(() => { 174 | result = dotProp.set(obj, 'c.0', v => v * 3); 175 | }); 176 | 177 | it('should replace prop', () => { 178 | expect(result).to.eql({ 179 | a: 1, 180 | b: { 181 | x: 1, 182 | y: 2 183 | }, 184 | c: [3, 2], 185 | 'b.x': 10 186 | }); 187 | }); 188 | 189 | it('invariant', objInvariant); 190 | }); 191 | 192 | describe('when set array[index] prop not defined', () => { 193 | 194 | before(() => { 195 | result = dotProp.set(obj, 'c.1.z.w', 3); 196 | }); 197 | 198 | it('should replace prop', () => { 199 | expect(result).to.eql({ 200 | a: 1, 201 | b: { 202 | x: 1, 203 | y: 2 204 | }, 205 | c: [1, { z: { w: 3 } }], 206 | 'b.x': 10 207 | }); 208 | }); 209 | 210 | it('invariant', objInvariant); 211 | }); 212 | 213 | describe('when set array[index] out of index', () => { 214 | 215 | before(() => { 216 | result = dotProp.set(obj, 'c.3', 3); 217 | }); 218 | 219 | it('should replace prop', () => { 220 | const c = [1, 2]; 221 | c[3] = 3; 222 | expect(result).to.eql({ 223 | a: 1, 224 | b: { 225 | x: 1, 226 | y: 2 227 | }, 228 | c: c, 229 | 'b.x': 10 230 | }); 231 | }); 232 | 233 | it('invariant', objInvariant); 234 | }); 235 | 236 | describe('when set array[$end]', () => { 237 | 238 | before(() => { 239 | result = dotProp.set(obj, 'c.$end', 3); 240 | }); 241 | 242 | it('should replace prop', () => { 243 | expect(result).to.eql({ 244 | a: 1, 245 | b: { 246 | x: 1, 247 | y: 2 248 | }, 249 | c: [1, 3], 250 | 'b.x': 10 251 | }); 252 | }); 253 | 254 | it('invariant', objInvariant); 255 | }); 256 | 257 | describe('when set array[index] and index not integer', () => { 258 | let error; 259 | 260 | before(() => { 261 | try { 262 | dotProp.set(obj, 'c.w', 3); 263 | } catch (err) { 264 | error = err; 265 | } 266 | }); 267 | 268 | it('should throw an error', () => { 269 | expect(error.message).to.eql('Array index \'w\' has to be an integer'); 270 | }); 271 | 272 | it('invariant', objInvariant); 273 | }); 274 | }); 275 | 276 | describe('when have an array', () => { 277 | 278 | describe('when set array[index]', () => { 279 | 280 | before(() => { 281 | result = dotProp.set(arr, '0', 3); 282 | }); 283 | 284 | it('should replace prop', () => { 285 | expect(result).to.eql( 286 | [3, { a: false }] 287 | ); 288 | }); 289 | 290 | it('invariant', arrInvariant); 291 | }); 292 | 293 | describe('when set array[index] deep prop', () => { 294 | 295 | before(() => { 296 | result = dotProp.set(arr, '1.a', v => !v); 297 | }); 298 | 299 | it('should replace prop', () => { 300 | expect(result).to.eql( 301 | [1, { a: true }] 302 | ); 303 | }); 304 | 305 | it('invariant', arrInvariant); 306 | }); 307 | }); 308 | }); 309 | 310 | describe('when get', () => { 311 | 312 | describe('when have an object', () => { 313 | 314 | describe('when get prop', () => { 315 | 316 | it('should get prop', () => { 317 | expect(dotProp.get(obj, 'b')).to.eql({ x: 1, y: 2 }); 318 | }); 319 | it('should get prop default', () => { 320 | expect(dotProp.get(obj, 'd', 'default')).to.eql('default'); 321 | }); 322 | }); 323 | 324 | describe('when get prop empty object', () => { 325 | 326 | it('should get prop', () => { 327 | expect(dotProp.get({}, 'b')).to.equal(undefined); 328 | }); 329 | it('should get prop default', () => { 330 | expect(dotProp.get({}, 'b', 'default')).to.equal('default'); 331 | }); 332 | }); 333 | 334 | describe('when get prop empty path', () => { 335 | 336 | it('should get prop', () => { 337 | expect(dotProp.get(obj, '')).to.equal(undefined); 338 | }); 339 | it('should get prop default', () => { 340 | expect(dotProp.get(obj, '', 'default')).to.equal('default'); 341 | }); 342 | }); 343 | 344 | describe('when get deep prop', () => { 345 | 346 | it('should get prop', () => { 347 | expect(dotProp.get(obj, 'b.x')).to.equal(1); 348 | }); 349 | it('should get prop default', () => { 350 | expect(dotProp.get(obj, 'b.z', 'default')).to.equal('default'); 351 | }); 352 | }); 353 | 354 | describe('when get dotted prop', () => { 355 | 356 | it('should get prop', () => { 357 | expect(dotProp.get(obj, 'b\\.x')).to.equal(10); 358 | }); 359 | it('should get prop default', () => { 360 | expect(dotProp.get(obj, 'b\\.y', 'default')).to.equal('default'); 361 | }); 362 | it('should get deeply nested key', () => { 363 | expect(dotProp.get(deeplyNestedObj, 'flavour.spicy.pepper.bell', 'default')).to.equal('mild'); 364 | }); 365 | it('should get deeply nested key with multiple dots in selector', () => { 366 | expect(dotProp.get(deeplyNestedObj, 'flavour.dotty\\.dot\\.flavours.dalmatian', 'default')).to.equal('stracciatella'); 367 | }); 368 | it('should get key with multiple dots in selector', () => { 369 | expect(dotProp.get(deeplyNestedObj, 'www\\.example\\.com', 'default')).to.equal('domain'); 370 | }); 371 | }); 372 | 373 | describe('when get deep prop not defined', () => { 374 | 375 | it('should return undefined', () => { 376 | expect(dotProp.get(obj, 'b.z.w')).to.equal(undefined); 377 | }); 378 | 379 | it('should return the default value', () => { 380 | expect(dotProp.get(obj, 'b.z.w', 'something')).to.equal('something'); 381 | }); 382 | }); 383 | 384 | describe('when get intermediate deep prop is null', () => { 385 | 386 | it('should return default value', () => { 387 | expect(dotProp.get({ b: { z: null } }, 'b.z.w')).to.equal(undefined); 388 | expect(dotProp.get({ b: { z: null } }, 'b.z.w', 'default')).to.equal('default'); 389 | }); 390 | }); 391 | 392 | describe('when get array[index]', () => { 393 | 394 | it('should get index', () => { 395 | expect(dotProp.get(obj, 'c.0')).to.equal(1); 396 | }); 397 | it('should get index default', () => { 398 | expect(dotProp.get(obj, 'c.2', 'default')).to.equal('default'); 399 | }); 400 | }); 401 | 402 | describe('when get array[index] prop not defined', () => { 403 | 404 | it('should return undefined', () => { 405 | expect(dotProp.get(obj, 'c.1.z.w')).to.equal(undefined); 406 | }); 407 | it('should return default', () => { 408 | expect(dotProp.get(obj, 'c.1.z.w', 'default')).to.equal('default'); 409 | }); 410 | }); 411 | 412 | describe('when get array[index] out of index', () => { 413 | 414 | it('should return undefined', () => { 415 | expect(dotProp.get(obj, 'c.3')).to.equal(undefined); 416 | }); 417 | }); 418 | 419 | describe('when get array[$end]', () => { 420 | 421 | it('should get end index', () => { 422 | expect(dotProp.get(obj, 'c.$end')).to.equal(2); 423 | }); 424 | }); 425 | 426 | describe('when get undefined prop on array', () => { 427 | 428 | it('should return undefined', () => { 429 | expect(dotProp.get(obj, 'c.w')).to.equal(undefined); 430 | }); 431 | it('should return default', () => { 432 | expect(dotProp.get(obj, 'c.w', 'default')).to.equal('default'); 433 | }); 434 | }); 435 | }); 436 | 437 | describe('when have an array', () => { 438 | 439 | describe('when get array[index]', () => { 440 | 441 | it('should get index', () => { 442 | expect(dotProp.get(arr, '0')).to.equal(1); 443 | }); 444 | it('should return default when index not present', () => { 445 | expect(dotProp.get(arr, '2', 'default')).to.equal('default'); 446 | }); 447 | }); 448 | 449 | describe('when get array[index] deep prop', () => { 450 | 451 | it('should replace prop', () => { 452 | expect(dotProp.get(arr, '1.a')).to.equal(false); 453 | }); 454 | it('should return default when not present', () => { 455 | expect(dotProp.get(arr, '1.b', 'default')).to.equal('default'); 456 | }); 457 | }); 458 | 459 | }); 460 | }); 461 | 462 | describe('when delete', () => { 463 | 464 | describe('when have an object', () => { 465 | 466 | describe('when delete prop', () => { 467 | 468 | before(() => { 469 | result = dotProp.delete(obj, 'b'); 470 | }); 471 | 472 | it('should prop', () => { 473 | expect(result).to.eql({ 474 | a: 1, 475 | c: [1, 2], 476 | 'b.x': 10 477 | }); 478 | }); 479 | 480 | it('invariant', objInvariant); 481 | }); 482 | 483 | describe('when delete prop empty object', () => { 484 | 485 | before(() => { 486 | result = dotProp.delete({}, 'b'); 487 | }); 488 | 489 | it('should delete prop', () => { 490 | expect(result).to.eql({}); 491 | }); 492 | }); 493 | 494 | describe('when delete prop empty path', () => { 495 | 496 | before(() => { 497 | result = dotProp.delete({}, ''); 498 | }); 499 | 500 | it('should delete prop', () => { }); 501 | }); 502 | 503 | describe('when delete deep prop', () => { 504 | 505 | before(() => { 506 | result = dotProp.delete(obj, 'b.x'); 507 | }); 508 | 509 | it('should delete prop', () => { 510 | expect(result).to.eql({ 511 | a: 1, 512 | b: { 513 | y: 2 514 | }, 515 | c: [1, 2], 516 | 'b.x': 10 517 | }); 518 | }); 519 | 520 | it('invariant', objInvariant); 521 | }); 522 | 523 | describe('when delete deep prop not defined', () => { 524 | 525 | before(() => { 526 | result = dotProp.delete(obj, 'b.z.w'); 527 | }); 528 | 529 | it('should delete prop', () => { 530 | expect(result).to.eql({ 531 | a: 1, 532 | b: { 533 | x: 1, 534 | y: 2 535 | }, 536 | c: [1, 2], 537 | 'b.x': 10 538 | }); 539 | }); 540 | 541 | it('invariant', objInvariant); 542 | }); 543 | 544 | describe('when delete deep prop is null', () => { 545 | 546 | before(() => { 547 | result = dotProp.delete({ b: { z: null } }, 'b.z.w'); 548 | }); 549 | 550 | it('should delete prop', () => { 551 | expect(result).to.eql({ b: { z: null } }); 552 | }); 553 | }); 554 | 555 | describe('when delete array[index]', () => { 556 | 557 | before(() => { 558 | result = dotProp.delete(obj, 'c.0'); 559 | }); 560 | 561 | it('should delete prop', () => { 562 | expect(result).to.eql({ 563 | a: 1, 564 | b: { 565 | x: 1, 566 | y: 2 567 | }, 568 | c: [2], 569 | 'b.x': 10 570 | }); 571 | }); 572 | 573 | it('invariant', objInvariant); 574 | }); 575 | 576 | describe('when delete array[index] with function', () => { 577 | 578 | before(() => { 579 | result = dotProp.set(obj, 'c.0', v => v * 3); 580 | }); 581 | 582 | it('should delete prop', () => { 583 | expect(result).to.eql({ 584 | a: 1, 585 | b: { 586 | x: 1, 587 | y: 2 588 | }, 589 | c: [3, 2], 590 | 'b.x': 10 591 | }); 592 | }); 593 | 594 | it('invariant', objInvariant); 595 | }); 596 | 597 | describe('when delete array[index] prop not defined', () => { 598 | 599 | before(() => { 600 | result = dotProp.delete(obj, 'c.1.z.w'); 601 | }); 602 | 603 | it('should delete prop', () => { 604 | expect(result).to.eql({ 605 | a: 1, 606 | b: { 607 | x: 1, 608 | y: 2 609 | }, 610 | c: [1, 2], 611 | 'b.x': 10 612 | }); 613 | }); 614 | 615 | it('invariant', objInvariant); 616 | }); 617 | 618 | describe('when delete array[index] out of index', () => { 619 | 620 | before(() => { 621 | result = dotProp.delete(obj, 'c.3'); 622 | }); 623 | 624 | it('should delete prop', () => { 625 | expect(result).to.eql({ 626 | a: 1, 627 | b: { 628 | x: 1, 629 | y: 2 630 | }, 631 | c: [1, 2], 632 | 'b.x': 10 633 | }); 634 | }); 635 | 636 | it('invariant', objInvariant); 637 | }); 638 | 639 | describe('when delete array[$end]', () => { 640 | 641 | before(() => { 642 | result = dotProp.delete(obj, 'c.$end'); 643 | }); 644 | 645 | it('should delete prop', () => { 646 | expect(result).to.eql({ 647 | a: 1, 648 | b: { 649 | x: 1, 650 | y: 2 651 | }, 652 | c: [1], 653 | 'b.x': 10 654 | }); 655 | }); 656 | 657 | it('invariant', objInvariant); 658 | }); 659 | 660 | describe('when delete array[index] and index not integer', () => { 661 | let error; 662 | 663 | before(() => { 664 | try { 665 | dotProp.delete(obj, 'c.w'); 666 | } catch (err) { 667 | error = err; 668 | } 669 | }); 670 | 671 | it('should throw an error', () => { 672 | expect(error.message).to.eql('Array index \'w\' has to be an integer'); 673 | }); 674 | 675 | it('invariant', objInvariant); 676 | }); 677 | }); 678 | 679 | describe('when have an array', () => { 680 | 681 | describe('when delete array[index]', () => { 682 | 683 | before(() => { 684 | result = dotProp.delete(arr, '0'); 685 | }); 686 | 687 | it('should delete prop', () => { 688 | expect(result).to.eql( 689 | [{ a: false }] 690 | ); 691 | }); 692 | 693 | it('invariant', arrInvariant); 694 | }); 695 | 696 | describe('when delete array[index] deep prop', () => { 697 | 698 | before(() => { 699 | result = dotProp.delete(arr, '1.a'); 700 | }); 701 | 702 | it('should delete prop', () => { 703 | expect(result).to.eql( 704 | [1, {}] 705 | ); 706 | }); 707 | 708 | it('invariant', arrInvariant); 709 | }); 710 | 711 | describe('when delete array[index] which element is undefined', () => { 712 | 713 | before(() => { 714 | result = dotProp.delete(arrWithUndefined, '1'); 715 | }); 716 | 717 | it('should delete the element', () => { 718 | expect(result).to.eql( 719 | [1, 4] 720 | ); 721 | }); 722 | }); 723 | }); 724 | }); 725 | 726 | function objInvariant() { 727 | expect(obj).to.eql({ 728 | a: 1, 729 | b: { 730 | x: 1, 731 | y: 2 732 | }, 733 | c: [1, 2], 734 | 'b.x': 10 735 | }); 736 | } 737 | 738 | function arrInvariant() { 739 | expect(arr).to.eql( 740 | [1, { a: false }] 741 | ); 742 | } 743 | }); 744 | 745 | 746 | -------------------------------------------------------------------------------- /test/eslint.spec.js: -------------------------------------------------------------------------------- 1 | require('mocha-eslint')([ 2 | 'src', 3 | 'test' 4 | ]); -------------------------------------------------------------------------------- /test/examples.spec.js: -------------------------------------------------------------------------------- 1 | const dotProp = require('../lib'); 2 | 3 | describe('examples.spec.js', () => { 4 | 5 | describe('when get', () => { 6 | 7 | it('prop', () => { 8 | expect(dotProp.get({ foo: { bar: 'unicorn' } }, 'foo.bar')).to.eql('unicorn'); 9 | }); 10 | 11 | it('prop undefined', () => { 12 | expect(dotProp.get({ foo: { bar: 'a' } }, 'foo.notDefined.deep')).to.eql(undefined); 13 | }); 14 | 15 | it('prop with dot', () => { 16 | expect(dotProp.get({ foo: { 'dot.dot': 'unicorn' } }, 'foo.dot\\.dot')).to.eql('unicorn'); 17 | }); 18 | 19 | it('use an array as get path', () => { 20 | expect(dotProp.get({ foo: { 'dot.dot': 'unicorn' } }, ['foo', 'dot.dot'])).to.eql('unicorn'); 21 | }); 22 | 23 | it('index', () => { 24 | expect(dotProp.get({ foo: [{ bar: 'gold-unicorn' }, 'white-unicorn', 'silver-unicorn'] }, 'foo.1')).to.eql('white-unicorn'); 25 | }); 26 | 27 | it('index deep', () => { 28 | expect(dotProp.get({ foo: [{ bar: 'gold-unicorn' }, 'white-unicorn', 'silver-unicorn'] }, 'foo.0.bar')).to.eql('gold-unicorn'); 29 | }); 30 | 31 | it('array index', () => { 32 | expect(dotProp.get([{ bar: 'gold-unicorn' }, 'white-unicorn', 'silver-unicorn'], '0.bar')).to.eql('gold-unicorn'); 33 | }); 34 | 35 | it('prop as number', () => { 36 | expect(dotProp.get([{ foo: 'silver-unicorn' }], 0)).to.eql({ foo: 'silver-unicorn' }); 37 | }); 38 | 39 | it('index $end', () => { 40 | expect(dotProp.get({ foo: [{ bar: 'gold-unicorn' }, 'white-unicorn', 'silver-unicorn'] }, 'foo.$end')).to.eql('silver-unicorn'); 41 | expect(dotProp.get({ foo: [] }, 'foo.$end')).to.eql(undefined); 42 | expect(dotProp.set({ foo: [] }, 'foo.$end', 'bar')).to.eql({ foo: ['bar'] }); 43 | }); 44 | }); 45 | 46 | describe('when set', () => { 47 | const obj = { foo: { bar: 'a' } }; 48 | let obj1, obj2, obj3; 49 | 50 | describe('when prop', () => { 51 | 52 | before(() => { 53 | obj1 = dotProp.set(obj, 'foo.bar', 'b'); 54 | }); 55 | 56 | it('obj1', () => { 57 | expect(obj1).to.eql({ foo: { bar: 'b' } }); 58 | }); 59 | 60 | describe('when prop undefined', () => { 61 | 62 | before(() => { 63 | obj2 = dotProp.set(obj1, 'foo.baz', 'x'); 64 | }); 65 | 66 | it('obj2', () => { 67 | expect(obj2).to.eql({ foo: { bar: 'b', baz: 'x' } }); 68 | }); 69 | 70 | describe('when prop undefined', () => { 71 | 72 | before(() => { 73 | obj3 = dotProp.set(obj2, 'foo.dot\\.dot', 'unicorn'); 74 | }); 75 | 76 | it('obj3', () => { 77 | expect(obj3).to.eql({ foo: { bar: 'b', baz: 'x', 'dot.dot': 'unicorn' } }); 78 | }); 79 | 80 | it('obj !== obj1', () => { 81 | expect(obj).to.not.eql(obj1); 82 | }); 83 | 84 | it('obj1 !== obj2', () => { 85 | expect(obj1).to.not.eql(obj2); 86 | }); 87 | 88 | it('obj2 !== obj3', () => { 89 | expect(obj2).to.not.eql(obj3); 90 | }); 91 | }); 92 | }); 93 | }); 94 | 95 | it('Use an array as set path', () => { 96 | expect(dotProp.set({ foo: { bar: 'b', baz: 'x' } }, ['foo', 'dot.dot'], 'unicorn')).to.eql( 97 | { foo: { bar: 'b', baz: 'x', 'dot.dot': 'unicorn' } } 98 | ); 99 | }); 100 | 101 | it('Setter where value is a function', () => { 102 | expect(dotProp.set(obj, 'foo.bar', v => v + 'bc')).to.eql( 103 | { foo: { bar: 'abc' } } 104 | ); 105 | }); 106 | 107 | it('Index into array', () => { 108 | expect(dotProp.set({ foo: [{ bar: 'gold-unicorn' }, 'white-unicorn', 'silver-unicorn'] }, 'foo.1', 'platin-unicorn')).to.eql( 109 | { foo: [{ bar: 'gold-unicorn' }, 'platin-unicorn', 'silver-unicorn'] } 110 | ); 111 | }); 112 | 113 | it('Index into array deep', () => { 114 | expect(dotProp.set({ foo: [{ bar: 'gold-unicorn' }, 'white-unicorn', 'silver-unicorn'] }, 'foo.0.bar', 'platin-unicorn')).to.eql( 115 | { foo: [{ bar: 'platin-unicorn' }, 'white-unicorn', 'silver-unicorn'] } 116 | ); 117 | }); 118 | 119 | it('Array', () => { 120 | expect(dotProp.set([{ bar: 'gold-unicorn' }, 'white-unicorn', 'silver-unicorn'], '0.bar', 'platin-unicorn')).to.eql( 121 | [{ bar: 'platin-unicorn' }, 'white-unicorn', 'silver-unicorn'] 122 | ); 123 | }); 124 | 125 | it('Index into array', () => { 126 | expect(dotProp.set({ foo: [{ bar: 'gold-unicorn' }, 'white-unicorn', 'silver-unicorn'] }, 'foo.$end', 'platin-unicorn')).to.eql( 127 | { foo: [{ bar: 'gold-unicorn' }, 'white-unicorn', 'platin-unicorn'] } 128 | ); 129 | }); 130 | }); 131 | 132 | describe('when delete', () => { 133 | 134 | it('Array element by index', () => { 135 | expect(dotProp.delete({ foo: [{ bar: 'gold-unicorn' }, 'white-unicorn', 'silver-unicorn'] }, 'foo.1')).to.eql( 136 | { foo: [{ bar: 'gold-unicorn' }, 'silver-unicorn'] } 137 | ); 138 | }); 139 | 140 | it('Array element by $end', () => { 141 | expect(dotProp.delete({ foo: [{ bar: 'gold-unicorn' }, 'white-unicorn', 'silver-unicorn'] }, 'foo.$end')).to.eql( 142 | { foo: [{ bar: 'gold-unicorn' }, 'white-unicorn'] } 143 | ); 144 | }); 145 | 146 | it('Out of array', () => { 147 | expect(dotProp.delete({ foo: [{ bar: 'gold-unicorn' }, 'white-unicorn', 'silver-unicorn'] }, 'foo.10')).to.eql( 148 | { foo: [{ bar: 'gold-unicorn' }, 'white-unicorn', 'silver-unicorn'] } 149 | ); 150 | }); 151 | 152 | it('Array indexed by a property', () => { 153 | try { 154 | dotProp.delete({ foo: [{ bar: 'gold-unicorn' }, 'white-unicorn', 'silver-unicorn'] }, 'foo.bar'); 155 | } catch (err) { 156 | expect(err.message).to.equal('Array index \'bar\' has to be an integer'); 157 | expect(err).to.be.an('error'); 158 | } 159 | }); 160 | 161 | it('Deep prop', () => { 162 | expect(dotProp.delete({ foo: [{ bar: 'gold-unicorn' }, 'white-unicorn', 'silver-unicorn'] }, 'foo.0.bar')).to.eql( 163 | { foo: [{}, 'white-unicorn', 'silver-unicorn'] } 164 | ); 165 | }); 166 | }); 167 | }); 168 | -------------------------------------------------------------------------------- /test/globals.js: -------------------------------------------------------------------------------- 1 | const chai = require('chai'); 2 | global.expect = chai.expect; 3 | -------------------------------------------------------------------------------- /test/mocha.opts: -------------------------------------------------------------------------------- 1 | --require ./test/globals.js 2 | --reporter spec 3 | --ui bdd 4 | --recursive 5 | --colors 6 | --timeout 2000 7 | --slow 100 8 | --------------------------------------------------------------------------------