├── .editorconfig ├── .eslintrc.json ├── .gitignore ├── CHANGELOG.md ├── README.md ├── index.js ├── index.mjs ├── package-lock.json ├── package.json ├── rollup.config.js └── src └── index.js /.editorconfig: -------------------------------------------------------------------------------- 1 | root = true 2 | 3 | [*] 4 | end_of_line = lf 5 | insert_final_newline = true 6 | 7 | [*.{js,css,html,svelte}] 8 | charset = utf-8 9 | indent_style = tab 10 | indent_size = 4 11 | trim_trailing_whitespace = true -------------------------------------------------------------------------------- /.eslintrc.json: -------------------------------------------------------------------------------- 1 | { 2 | "root": true, 3 | "rules": { 4 | "indent": [ 5 | 2, 6 | "tab", 7 | { 8 | "SwitchCase": 1 9 | } 10 | ], 11 | "semi": [ 12 | 2, 13 | "always" 14 | ], 15 | "keyword-spacing": [ 16 | 2, 17 | { 18 | "before": true, 19 | "after": true 20 | } 21 | ], 22 | "space-before-blocks": [ 23 | 2, 24 | "always" 25 | ], 26 | "no-mixed-spaces-and-tabs": [ 27 | 2, 28 | "smart-tabs" 29 | ], 30 | "no-cond-assign": 0, 31 | "no-unused-vars": 2, 32 | "object-shorthand": [ 33 | 2, 34 | "always" 35 | ], 36 | "no-const-assign": 2, 37 | "no-class-assign": 2, 38 | "no-this-before-super": 2, 39 | "no-var": 2, 40 | "no-unreachable": 2, 41 | "valid-typeof": 2, 42 | "quote-props": [ 43 | 2, 44 | "as-needed" 45 | ], 46 | "one-var": [ 47 | 2, 48 | "consecutive" 49 | ], 50 | "prefer-arrow-callback": 2, 51 | "prefer-const": [ 52 | 2, 53 | { 54 | "destructuring": "all" 55 | } 56 | ], 57 | "arrow-spacing": 2, 58 | "no-inner-declarations": 0 59 | }, 60 | "env": { 61 | "es6": true, 62 | "browser": true, 63 | "node": true, 64 | "mocha": true 65 | }, 66 | "extends": [ 67 | "eslint:recommended", 68 | "plugin:import/errors", 69 | "plugin:import/warnings" 70 | ], 71 | "parser":"babel-eslint", 72 | "parserOptions": { 73 | "ecmaVersion": 6, 74 | "sourceType": "module" 75 | }, 76 | "settings": { 77 | "import/core-modules": [ 78 | "svelte" 79 | ] 80 | } 81 | } -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | .DS_Store 2 | Thumbs.db 3 | node_modules 4 | *.log 5 | -------------------------------------------------------------------------------- /CHANGELOG.md: -------------------------------------------------------------------------------- 1 | # svelte-transitions-morph changelog 2 | 3 | ## 1.1.0 4 | * Fix for dynamic imports 5 | 6 | ## 1.0.1 7 | 8 | * Readme & Demos 9 | * module.js => index.mjs for es6 10 | 11 | ## 1.0.0 12 | 13 | * First release 14 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # svelte-page-router 2 | 3 | Simple wrapper based on pagejs to make DX similar to config-based router. Play well with [Svelte 3](https://v3.svelte.technology). 4 | 5 | ## Usage 6 | 7 | Install with npm or yarn: 8 | 9 | ```bash 10 | npm install --save svelte-page-router 11 | ``` 12 | 13 | Then import router to your `main.js` file: 14 | 15 | ```javascript 16 | import Router from 'svelte-page-router'; 17 | 18 | import App from './App.svelte'; 19 | 20 | const options = { 21 | click: true, 22 | popstate: true, 23 | dispatch: true, 24 | hashbang: false, 25 | }; 26 | 27 | const router = new Router({ 28 | routes: [{ 29 | path: '/static', 30 | component: import('./pages/Static') 31 | },{ 32 | path: '/dynamic/:id/:type?', 33 | component: ctx => import('~/pages/Dynamic') // for lazy-loaded routes 34 | },{ 35 | path: '/secure', 36 | component: import('~/pages/Secure'), 37 | before(ctx, next) { 38 | (/* check authorization */) ? 39 | next() : 40 | router.redirect('/static'); 41 | } 42 | }, { 43 | path: '*', 44 | component: import('~/pages/NotFound'), 45 | }], 46 | hooks: [ 47 | (ctx, next) => { 48 | /* simple hooks to modify context for any route */ 49 | next(); 50 | } 51 | ], 52 | ...options 53 | }); 54 | 55 | // simple integrate with Svelte 56 | 57 | const app = new App({ 58 | target: document.body, 59 | props: { component: null } 60 | }); 61 | 62 | router.enter((ctx, next) => { 63 | app.$set({ ...ctx }); 64 | tick().then(next); 65 | }); 66 | 67 | router.exit((ctx, next) => { 68 | app.$set({ component: null }); 69 | tick().then(next); 70 | }); 71 | 72 | router.start(); 73 | ``` 74 | 75 | Switch pages in `App.svelte`: 76 | 77 | ```html 78 | 87 | 88 | 99 | ``` 100 | 101 | Use `preload` function to preload some data before page component will be rendered: 102 | 103 | ```html 104 | 109 | 110 | 117 | 118 | 121 | ``` 122 | 123 | ## Context 124 | 125 | Is a context object from [pagejs](http://visionmedia.github.io/page.js/#context) with additional property `component` which is a Svelte component associated with the current route. 126 | 127 | ## Methods 128 | 129 | ```javascript 130 | router.base(); // base path 131 | router.strict(true); // strict matching 132 | 133 | router.before((ctx, next) => { /* ... */ }); // guard before any route 134 | router.after((ctx, next) => { /* ... */ }); // guard after any route 135 | 136 | router.enter((ctx, next) => { /* ... */ }); // guard entring any route 137 | router.exit((ctx, next) => { /* ... */ }); // guard exiting any route 138 | 139 | router.start(); // start listening 140 | router.stop(); // stop listening 141 | 142 | router.redirect('/some'); // redirects 143 | router.back(); // history back 144 | ``` 145 | 146 | ## License 147 | 148 | MIT 149 | -------------------------------------------------------------------------------- /index.js: -------------------------------------------------------------------------------- 1 | (function (global, factory) { 2 | typeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory(require('page')) : 3 | typeof define === 'function' && define.amd ? define(['page'], factory) : 4 | (global = global || self, global.pageRouter = factory(global.page)); 5 | }(this, function (page) { 'use strict'; 6 | 7 | page = page && page.hasOwnProperty('default') ? page['default'] : page; 8 | 9 | class index { 10 | 11 | constructor({ routes = [], hooks = [], ...options }) { 12 | 13 | this._routes = routes; 14 | this._hooks = hooks; 15 | this._options = options; 16 | 17 | this._before = null; 18 | this._enter = null; 19 | this._after = null; 20 | this._exit = null; 21 | 22 | page('*', (ctx, next) => { 23 | const qs = ctx.querystring ? ctx.querystring.replace('?', '').split('&') : []; 24 | ctx.query = qs.reduce((query, param) => { 25 | const [key, val] = param.split('='); 26 | query[key] = decodeURIComponent(val); 27 | return query; 28 | }, {}); 29 | 30 | Promise.all(this._hooks.map(p => p(ctx))).then(next); 31 | }); 32 | } 33 | 34 | base(path) { 35 | page.base(path); 36 | } 37 | 38 | strict(enable) { 39 | page.strict(enable); 40 | } 41 | 42 | before(callback) { 43 | typeof callback === 'function' && (this._before = callback); 44 | } 45 | 46 | enter(callback) { 47 | typeof callback === 'function' && (this._enter = callback); 48 | } 49 | 50 | after(callback) { 51 | typeof callback === 'function' && (this._after = callback); 52 | } 53 | 54 | exit(callback) { 55 | typeof callback === 'function' && (this._exit = callback); 56 | } 57 | 58 | start() { 59 | 60 | typeof this._before === 'function' && page('*', this._before); 61 | 62 | this._routes.forEach(({ path, before, after, exit, component }) => { 63 | 64 | const callbacks = []; 65 | 66 | typeof before === 'function' && callbacks.push(before); 67 | 68 | callbacks.push((ctx, next) => { 69 | typeof component === 'function' && (component = component(ctx)); 70 | 71 | ctx.handled = true; // it's important for redirects 72 | 73 | Promise.resolve(component).then(component => { 74 | (component.preload ? 75 | component.preload(ctx) : 76 | Promise.resolve() 77 | ).then((state = {}) => { 78 | Object.assign(ctx.state, state); 79 | ctx.save(); 80 | ctx.component = component.default || component; 81 | return next(); 82 | }); 83 | }); 84 | }); 85 | 86 | typeof this._enter === 'function' && callbacks.push(this._enter); 87 | typeof after === 'function' && callbacks.push(after); 88 | 89 | page(path, ...callbacks); 90 | 91 | typeof exit === 'function' && page.exit(path, exit); 92 | }); 93 | 94 | typeof this._after === 'function' && page('*', this._after); 95 | typeof this._exit === 'function' && page.exit('*', this._exit); 96 | 97 | page.start(this._options); 98 | } 99 | 100 | stop() { 101 | page.stop(); 102 | } 103 | 104 | show(...args) { 105 | page.show(...args); 106 | } 107 | 108 | redirect(...args) { 109 | page.redirect(...args); 110 | } 111 | 112 | back(...args) { 113 | page.back(...args); 114 | } 115 | } 116 | 117 | return index; 118 | 119 | })); 120 | -------------------------------------------------------------------------------- /index.mjs: -------------------------------------------------------------------------------- 1 | import page from 'page'; 2 | 3 | class index { 4 | 5 | constructor({ routes = [], hooks = [], ...options }) { 6 | 7 | this._routes = routes; 8 | this._hooks = hooks; 9 | this._options = options; 10 | 11 | this._before = null; 12 | this._enter = null; 13 | this._after = null; 14 | this._exit = null; 15 | 16 | page('*', (ctx, next) => { 17 | const qs = ctx.querystring ? ctx.querystring.replace('?', '').split('&') : []; 18 | ctx.query = qs.reduce((query, param) => { 19 | const [key, val] = param.split('='); 20 | query[key] = decodeURIComponent(val); 21 | return query; 22 | }, {}); 23 | 24 | Promise.all(this._hooks.map(p => p(ctx))).then(next); 25 | }); 26 | } 27 | 28 | base(path) { 29 | page.base(path); 30 | } 31 | 32 | strict(enable) { 33 | page.strict(enable); 34 | } 35 | 36 | before(callback) { 37 | typeof callback === 'function' && (this._before = callback); 38 | } 39 | 40 | enter(callback) { 41 | typeof callback === 'function' && (this._enter = callback); 42 | } 43 | 44 | after(callback) { 45 | typeof callback === 'function' && (this._after = callback); 46 | } 47 | 48 | exit(callback) { 49 | typeof callback === 'function' && (this._exit = callback); 50 | } 51 | 52 | start() { 53 | 54 | typeof this._before === 'function' && page('*', this._before); 55 | 56 | this._routes.forEach(({ path, before, after, exit, component }) => { 57 | 58 | const callbacks = []; 59 | 60 | typeof before === 'function' && callbacks.push(before); 61 | 62 | callbacks.push((ctx, next) => { 63 | typeof component === 'function' && (component = component(ctx)); 64 | 65 | ctx.handled = true; // it's important for redirects 66 | 67 | Promise.resolve(component).then(component => { 68 | (component.preload ? 69 | component.preload(ctx) : 70 | Promise.resolve() 71 | ).then((state = {}) => { 72 | Object.assign(ctx.state, state); 73 | ctx.save(); 74 | ctx.component = component.default || component; 75 | return next(); 76 | }); 77 | }); 78 | }); 79 | 80 | typeof this._enter === 'function' && callbacks.push(this._enter); 81 | typeof after === 'function' && callbacks.push(after); 82 | 83 | page(path, ...callbacks); 84 | 85 | typeof exit === 'function' && page.exit(path, exit); 86 | }); 87 | 88 | typeof this._after === 'function' && page('*', this._after); 89 | typeof this._exit === 'function' && page.exit('*', this._exit); 90 | 91 | page.start(this._options); 92 | } 93 | 94 | stop() { 95 | page.stop(); 96 | } 97 | 98 | show(...args) { 99 | page.show(...args); 100 | } 101 | 102 | redirect(...args) { 103 | page.redirect(...args); 104 | } 105 | 106 | back(...args) { 107 | page.back(...args); 108 | } 109 | } 110 | 111 | export default index; 112 | -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "svelte-page-router", 3 | "version": "1.1.0", 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/generator": { 17 | "version": "7.5.5", 18 | "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.5.5.tgz", 19 | "integrity": "sha512-ETI/4vyTSxTzGnU2c49XHv2zhExkv9JHLTwDAFz85kmcwuShvYG2H08FwgIguQf4JC75CBnXAUM5PqeF4fj0nQ==", 20 | "dev": true, 21 | "requires": { 22 | "@babel/types": "^7.5.5", 23 | "jsesc": "^2.5.1", 24 | "lodash": "^4.17.13", 25 | "source-map": "^0.5.0", 26 | "trim-right": "^1.0.1" 27 | } 28 | }, 29 | "@babel/helper-function-name": { 30 | "version": "7.1.0", 31 | "resolved": "https://registry.npmjs.org/@babel/helper-function-name/-/helper-function-name-7.1.0.tgz", 32 | "integrity": "sha512-A95XEoCpb3TO+KZzJ4S/5uW5fNe26DjBGqf1o9ucyLyCmi1dXq/B3c8iaWTfBk3VvetUxl16e8tIrd5teOCfGw==", 33 | "dev": true, 34 | "requires": { 35 | "@babel/helper-get-function-arity": "^7.0.0", 36 | "@babel/template": "^7.1.0", 37 | "@babel/types": "^7.0.0" 38 | } 39 | }, 40 | "@babel/helper-get-function-arity": { 41 | "version": "7.0.0", 42 | "resolved": "https://registry.npmjs.org/@babel/helper-get-function-arity/-/helper-get-function-arity-7.0.0.tgz", 43 | "integrity": "sha512-r2DbJeg4svYvt3HOS74U4eWKsUAMRH01Z1ds1zx8KNTPtpTL5JAsdFv8BNyOpVqdFhHkkRDIg5B4AsxmkjAlmQ==", 44 | "dev": true, 45 | "requires": { 46 | "@babel/types": "^7.0.0" 47 | } 48 | }, 49 | "@babel/helper-split-export-declaration": { 50 | "version": "7.4.4", 51 | "resolved": "https://registry.npmjs.org/@babel/helper-split-export-declaration/-/helper-split-export-declaration-7.4.4.tgz", 52 | "integrity": "sha512-Ro/XkzLf3JFITkW6b+hNxzZ1n5OQ80NvIUdmHspih1XAhtN3vPTuUFT4eQnela+2MaZ5ulH+iyP513KJrxbN7Q==", 53 | "dev": true, 54 | "requires": { 55 | "@babel/types": "^7.4.4" 56 | } 57 | }, 58 | "@babel/highlight": { 59 | "version": "7.5.0", 60 | "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.5.0.tgz", 61 | "integrity": "sha512-7dV4eu9gBxoM0dAnj/BCFDW9LFU0zvTrkq0ugM7pnHEgguOEeOz1so2ZghEdzviYzQEED0r4EAgpsBChKy1TRQ==", 62 | "dev": true, 63 | "requires": { 64 | "chalk": "^2.0.0", 65 | "esutils": "^2.0.2", 66 | "js-tokens": "^4.0.0" 67 | } 68 | }, 69 | "@babel/parser": { 70 | "version": "7.5.5", 71 | "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.5.5.tgz", 72 | "integrity": "sha512-E5BN68cqR7dhKan1SfqgPGhQ178bkVKpXTPEXnFJBrEt8/DKRZlybmy+IgYLTeN7tp1R5Ccmbm2rBk17sHYU3g==", 73 | "dev": true 74 | }, 75 | "@babel/template": { 76 | "version": "7.4.4", 77 | "resolved": "https://registry.npmjs.org/@babel/template/-/template-7.4.4.tgz", 78 | "integrity": "sha512-CiGzLN9KgAvgZsnivND7rkA+AeJ9JB0ciPOD4U59GKbQP2iQl+olF1l76kJOupqidozfZ32ghwBEJDhnk9MEcw==", 79 | "dev": true, 80 | "requires": { 81 | "@babel/code-frame": "^7.0.0", 82 | "@babel/parser": "^7.4.4", 83 | "@babel/types": "^7.4.4" 84 | } 85 | }, 86 | "@babel/traverse": { 87 | "version": "7.5.5", 88 | "resolved": "https://registry.npmjs.org/@babel/traverse/-/traverse-7.5.5.tgz", 89 | "integrity": "sha512-MqB0782whsfffYfSjH4TM+LMjrJnhCNEDMDIjeTpl+ASaUvxcjoiVCo/sM1GhS1pHOXYfWVCYneLjMckuUxDaQ==", 90 | "dev": true, 91 | "requires": { 92 | "@babel/code-frame": "^7.5.5", 93 | "@babel/generator": "^7.5.5", 94 | "@babel/helper-function-name": "^7.1.0", 95 | "@babel/helper-split-export-declaration": "^7.4.4", 96 | "@babel/parser": "^7.5.5", 97 | "@babel/types": "^7.5.5", 98 | "debug": "^4.1.0", 99 | "globals": "^11.1.0", 100 | "lodash": "^4.17.13" 101 | } 102 | }, 103 | "@babel/types": { 104 | "version": "7.5.5", 105 | "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.5.5.tgz", 106 | "integrity": "sha512-s63F9nJioLqOlW3UkyMd+BYhXt44YuaFm/VV0VwuteqjYwRrObkU7ra9pY4wAJR3oXi8hJrMcrcJdO/HH33vtw==", 107 | "dev": true, 108 | "requires": { 109 | "esutils": "^2.0.2", 110 | "lodash": "^4.17.13", 111 | "to-fast-properties": "^2.0.0" 112 | } 113 | }, 114 | "@types/estree": { 115 | "version": "0.0.39", 116 | "resolved": "https://registry.npmjs.org/@types/estree/-/estree-0.0.39.tgz", 117 | "integrity": "sha512-EYNwp3bU+98cpU4lAWYYL7Zz+2gryWH1qbdDTidVd6hkiR6weksdbMadyXKXNPEkQFhXM+hVO9ZygomHXp+AIw==", 118 | "dev": true 119 | }, 120 | "@types/node": { 121 | "version": "12.6.8", 122 | "resolved": "https://registry.npmjs.org/@types/node/-/node-12.6.8.tgz", 123 | "integrity": "sha512-aX+gFgA5GHcDi89KG5keey2zf0WfZk/HAQotEamsK2kbey+8yGKcson0hbK8E+v0NArlCJQCqMP161YhV6ZXLg==", 124 | "dev": true 125 | }, 126 | "acorn": { 127 | "version": "6.4.1", 128 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-6.4.1.tgz", 129 | "integrity": "sha512-ZVA9k326Nwrj3Cj9jlh3wGFutC2ZornPNARZwsNYqQYgN0EsV2d53w5RN/co65Ohn4sUAUtb1rSUAOD6XN9idA==", 130 | "dev": true 131 | }, 132 | "acorn-jsx": { 133 | "version": "5.0.1", 134 | "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.0.1.tgz", 135 | "integrity": "sha512-HJ7CfNHrfJLlNTzIEUTj43LNWGkqpRLxm3YjAlcD0ACydk9XynzYsCBHxut+iqt+1aBXkx9UP/w/ZqMr13XIzg==", 136 | "dev": true 137 | }, 138 | "ajv": { 139 | "version": "6.10.2", 140 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.10.2.tgz", 141 | "integrity": "sha512-TXtUUEYHuaTEbLZWIKUr5pmBuhDLy+8KYtPYdcV8qC+pOZL+NKqYwvWSRrVXHn+ZmRRAu8vJTAznH7Oag6RVRw==", 142 | "dev": true, 143 | "requires": { 144 | "fast-deep-equal": "^2.0.1", 145 | "fast-json-stable-stringify": "^2.0.0", 146 | "json-schema-traverse": "^0.4.1", 147 | "uri-js": "^4.2.2" 148 | } 149 | }, 150 | "ansi-escapes": { 151 | "version": "3.2.0", 152 | "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-3.2.0.tgz", 153 | "integrity": "sha512-cBhpre4ma+U0T1oM5fXg7Dy1Jw7zzwv7lt/GoCpr+hDQJoYnKVPLL4dCvSEFMmQurOQvSrwT7SL/DAlhBI97RQ==", 154 | "dev": true 155 | }, 156 | "ansi-regex": { 157 | "version": "3.0.0", 158 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-3.0.0.tgz", 159 | "integrity": "sha1-7QMXwyIGT3lGbAKWa922Bas32Zg=", 160 | "dev": true 161 | }, 162 | "ansi-styles": { 163 | "version": "3.2.1", 164 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 165 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 166 | "dev": true, 167 | "requires": { 168 | "color-convert": "^1.9.0" 169 | } 170 | }, 171 | "argparse": { 172 | "version": "1.0.10", 173 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.10.tgz", 174 | "integrity": "sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg==", 175 | "dev": true, 176 | "requires": { 177 | "sprintf-js": "~1.0.2" 178 | } 179 | }, 180 | "array-includes": { 181 | "version": "3.0.3", 182 | "resolved": "https://registry.npmjs.org/array-includes/-/array-includes-3.0.3.tgz", 183 | "integrity": "sha1-GEtI9i2S10UrsxsyMWXH+L0CJm0=", 184 | "dev": true, 185 | "requires": { 186 | "define-properties": "^1.1.2", 187 | "es-abstract": "^1.7.0" 188 | } 189 | }, 190 | "astral-regex": { 191 | "version": "1.0.0", 192 | "resolved": "https://registry.npmjs.org/astral-regex/-/astral-regex-1.0.0.tgz", 193 | "integrity": "sha512-+Ryf6g3BKoRc7jfp7ad8tM4TtMiaWvbF/1/sQcZPkkS7ag3D5nMBCe2UfOTONtAkaG0tO0ij3C5Lwmf1EiyjHg==", 194 | "dev": true 195 | }, 196 | "babel-eslint": { 197 | "version": "10.0.2", 198 | "resolved": "https://registry.npmjs.org/babel-eslint/-/babel-eslint-10.0.2.tgz", 199 | "integrity": "sha512-UdsurWPtgiPgpJ06ryUnuaSXC2s0WoSZnQmEpbAH65XZSdwowgN5MvyP7e88nW07FYXv72erVtpBkxyDVKhH1Q==", 200 | "dev": true, 201 | "requires": { 202 | "@babel/code-frame": "^7.0.0", 203 | "@babel/parser": "^7.0.0", 204 | "@babel/traverse": "^7.0.0", 205 | "@babel/types": "^7.0.0", 206 | "eslint-scope": "3.7.1", 207 | "eslint-visitor-keys": "^1.0.0" 208 | } 209 | }, 210 | "balanced-match": { 211 | "version": "1.0.0", 212 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz", 213 | "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=", 214 | "dev": true 215 | }, 216 | "brace-expansion": { 217 | "version": "1.1.11", 218 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 219 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 220 | "dev": true, 221 | "requires": { 222 | "balanced-match": "^1.0.0", 223 | "concat-map": "0.0.1" 224 | } 225 | }, 226 | "callsites": { 227 | "version": "3.1.0", 228 | "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", 229 | "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==", 230 | "dev": true 231 | }, 232 | "chalk": { 233 | "version": "2.4.2", 234 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", 235 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", 236 | "dev": true, 237 | "requires": { 238 | "ansi-styles": "^3.2.1", 239 | "escape-string-regexp": "^1.0.5", 240 | "supports-color": "^5.3.0" 241 | } 242 | }, 243 | "chardet": { 244 | "version": "0.7.0", 245 | "resolved": "https://registry.npmjs.org/chardet/-/chardet-0.7.0.tgz", 246 | "integrity": "sha512-mT8iDcrh03qDGRRmoA2hmBJnxpllMR+0/0qlzjqZES6NdiWDcZkCNAk4rPFZ9Q85r27unkiNNg8ZOiwZXBHwcA==", 247 | "dev": true 248 | }, 249 | "cli-cursor": { 250 | "version": "2.1.0", 251 | "resolved": "https://registry.npmjs.org/cli-cursor/-/cli-cursor-2.1.0.tgz", 252 | "integrity": "sha1-s12sN2R5+sw+lHR9QdDQ9SOP/LU=", 253 | "dev": true, 254 | "requires": { 255 | "restore-cursor": "^2.0.0" 256 | } 257 | }, 258 | "cli-width": { 259 | "version": "2.2.0", 260 | "resolved": "https://registry.npmjs.org/cli-width/-/cli-width-2.2.0.tgz", 261 | "integrity": "sha1-/xnt6Kml5XkyQUewwR8PvLq+1jk=", 262 | "dev": true 263 | }, 264 | "color-convert": { 265 | "version": "1.9.3", 266 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", 267 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", 268 | "dev": true, 269 | "requires": { 270 | "color-name": "1.1.3" 271 | } 272 | }, 273 | "color-name": { 274 | "version": "1.1.3", 275 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 276 | "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=", 277 | "dev": true 278 | }, 279 | "concat-map": { 280 | "version": "0.0.1", 281 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 282 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=", 283 | "dev": true 284 | }, 285 | "contains-path": { 286 | "version": "0.1.0", 287 | "resolved": "https://registry.npmjs.org/contains-path/-/contains-path-0.1.0.tgz", 288 | "integrity": "sha1-/ozxhP9mcLa67wGp1IYaXL7EEgo=", 289 | "dev": true 290 | }, 291 | "cross-spawn": { 292 | "version": "6.0.5", 293 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-6.0.5.tgz", 294 | "integrity": "sha512-eTVLrBSt7fjbDygz805pMnstIs2VTBNkRm0qxZd+M7A5XDdxVRWO5MxGBXZhjY4cqLYLdtrGqRf8mBPmzwSpWQ==", 295 | "dev": true, 296 | "requires": { 297 | "nice-try": "^1.0.4", 298 | "path-key": "^2.0.1", 299 | "semver": "^5.5.0", 300 | "shebang-command": "^1.2.0", 301 | "which": "^1.2.9" 302 | }, 303 | "dependencies": { 304 | "semver": { 305 | "version": "5.7.0", 306 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.0.tgz", 307 | "integrity": "sha512-Ya52jSX2u7QKghxeoFGpLwCtGlt7j0oY9DYb5apt9nPlJ42ID+ulTXESnt/qAQcoSERyZ5sl3LDIOw0nAn/5DA==", 308 | "dev": true 309 | } 310 | } 311 | }, 312 | "debug": { 313 | "version": "4.1.1", 314 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.1.1.tgz", 315 | "integrity": "sha512-pYAIzeRo8J6KPEaJ0VWOh5Pzkbw/RetuzehGM7QRRX5he4fPHx2rdKMB256ehJCkX+XRQm16eZLqLNS8RSZXZw==", 316 | "dev": true, 317 | "requires": { 318 | "ms": "^2.1.1" 319 | } 320 | }, 321 | "deep-is": { 322 | "version": "0.1.3", 323 | "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.3.tgz", 324 | "integrity": "sha1-s2nW+128E+7PUk+RsHD+7cNXzzQ=", 325 | "dev": true 326 | }, 327 | "define-properties": { 328 | "version": "1.1.3", 329 | "resolved": "https://registry.npmjs.org/define-properties/-/define-properties-1.1.3.tgz", 330 | "integrity": "sha512-3MqfYKj2lLzdMSf8ZIZE/V+Zuy+BgD6f164e8K2w7dgnpKArBDerGYpM46IYYcjnkdPNMjPk9A6VFB8+3SKlXQ==", 331 | "dev": true, 332 | "requires": { 333 | "object-keys": "^1.0.12" 334 | } 335 | }, 336 | "doctrine": { 337 | "version": "3.0.0", 338 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-3.0.0.tgz", 339 | "integrity": "sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w==", 340 | "dev": true, 341 | "requires": { 342 | "esutils": "^2.0.2" 343 | } 344 | }, 345 | "emoji-regex": { 346 | "version": "7.0.3", 347 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-7.0.3.tgz", 348 | "integrity": "sha512-CwBLREIQ7LvYFB0WyRvwhq5N5qPhc6PMjD6bYggFlI5YyDgl+0vxq5VHbMOFqLg7hfWzmu8T5Z1QofhmTIhItA==", 349 | "dev": true 350 | }, 351 | "error-ex": { 352 | "version": "1.3.2", 353 | "resolved": "https://registry.npmjs.org/error-ex/-/error-ex-1.3.2.tgz", 354 | "integrity": "sha512-7dFHNmqeFSEt2ZBsCriorKnn3Z2pj+fd9kmI6QoWw4//DL+icEBfc0U7qJCisqrTsKTjw4fNFy2pW9OqStD84g==", 355 | "dev": true, 356 | "requires": { 357 | "is-arrayish": "^0.2.1" 358 | } 359 | }, 360 | "es-abstract": { 361 | "version": "1.13.0", 362 | "resolved": "https://registry.npmjs.org/es-abstract/-/es-abstract-1.13.0.tgz", 363 | "integrity": "sha512-vDZfg/ykNxQVwup/8E1BZhVzFfBxs9NqMzGcvIJrqg5k2/5Za2bWo40dK2J1pgLngZ7c+Shh8lwYtLGyrwPutg==", 364 | "dev": true, 365 | "requires": { 366 | "es-to-primitive": "^1.2.0", 367 | "function-bind": "^1.1.1", 368 | "has": "^1.0.3", 369 | "is-callable": "^1.1.4", 370 | "is-regex": "^1.0.4", 371 | "object-keys": "^1.0.12" 372 | } 373 | }, 374 | "es-to-primitive": { 375 | "version": "1.2.0", 376 | "resolved": "https://registry.npmjs.org/es-to-primitive/-/es-to-primitive-1.2.0.tgz", 377 | "integrity": "sha512-qZryBOJjV//LaxLTV6UC//WewneB3LcXOL9NP++ozKVXsIIIpm/2c13UDiD9Jp2eThsecw9m3jPqDwTyobcdbg==", 378 | "dev": true, 379 | "requires": { 380 | "is-callable": "^1.1.4", 381 | "is-date-object": "^1.0.1", 382 | "is-symbol": "^1.0.2" 383 | } 384 | }, 385 | "escape-string-regexp": { 386 | "version": "1.0.5", 387 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", 388 | "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=", 389 | "dev": true 390 | }, 391 | "eslint": { 392 | "version": "6.1.0", 393 | "resolved": "https://registry.npmjs.org/eslint/-/eslint-6.1.0.tgz", 394 | "integrity": "sha512-QhrbdRD7ofuV09IuE2ySWBz0FyXCq0rriLTZXZqaWSI79CVtHVRdkFuFTViiqzZhkCgfOh9USpriuGN2gIpZDQ==", 395 | "dev": true, 396 | "requires": { 397 | "@babel/code-frame": "^7.0.0", 398 | "ajv": "^6.10.0", 399 | "chalk": "^2.1.0", 400 | "cross-spawn": "^6.0.5", 401 | "debug": "^4.0.1", 402 | "doctrine": "^3.0.0", 403 | "eslint-scope": "^5.0.0", 404 | "eslint-utils": "^1.3.1", 405 | "eslint-visitor-keys": "^1.0.0", 406 | "espree": "^6.0.0", 407 | "esquery": "^1.0.1", 408 | "esutils": "^2.0.2", 409 | "file-entry-cache": "^5.0.1", 410 | "functional-red-black-tree": "^1.0.1", 411 | "glob-parent": "^5.0.0", 412 | "globals": "^11.7.0", 413 | "ignore": "^4.0.6", 414 | "import-fresh": "^3.0.0", 415 | "imurmurhash": "^0.1.4", 416 | "inquirer": "^6.4.1", 417 | "is-glob": "^4.0.0", 418 | "js-yaml": "^3.13.1", 419 | "json-stable-stringify-without-jsonify": "^1.0.1", 420 | "levn": "^0.3.0", 421 | "lodash": "^4.17.14", 422 | "minimatch": "^3.0.4", 423 | "mkdirp": "^0.5.1", 424 | "natural-compare": "^1.4.0", 425 | "optionator": "^0.8.2", 426 | "progress": "^2.0.0", 427 | "regexpp": "^2.0.1", 428 | "semver": "^6.1.2", 429 | "strip-ansi": "^5.2.0", 430 | "strip-json-comments": "^3.0.1", 431 | "table": "^5.2.3", 432 | "text-table": "^0.2.0", 433 | "v8-compile-cache": "^2.0.3" 434 | }, 435 | "dependencies": { 436 | "eslint-scope": { 437 | "version": "5.0.0", 438 | "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-5.0.0.tgz", 439 | "integrity": "sha512-oYrhJW7S0bxAFDvWqzvMPRm6pcgcnWc4QnofCAqRTRfQC0JcwenzGglTtsLyIuuWFfkqDG9vz67cnttSd53djw==", 440 | "dev": true, 441 | "requires": { 442 | "esrecurse": "^4.1.0", 443 | "estraverse": "^4.1.1" 444 | } 445 | } 446 | } 447 | }, 448 | "eslint-import-resolver-node": { 449 | "version": "0.3.2", 450 | "resolved": "https://registry.npmjs.org/eslint-import-resolver-node/-/eslint-import-resolver-node-0.3.2.tgz", 451 | "integrity": "sha512-sfmTqJfPSizWu4aymbPr4Iidp5yKm8yDkHp+Ir3YiTHiiDfxh69mOUsmiqW6RZ9zRXFaF64GtYmN7e+8GHBv6Q==", 452 | "dev": true, 453 | "requires": { 454 | "debug": "^2.6.9", 455 | "resolve": "^1.5.0" 456 | }, 457 | "dependencies": { 458 | "debug": { 459 | "version": "2.6.9", 460 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 461 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 462 | "dev": true, 463 | "requires": { 464 | "ms": "2.0.0" 465 | } 466 | }, 467 | "ms": { 468 | "version": "2.0.0", 469 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 470 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=", 471 | "dev": true 472 | } 473 | } 474 | }, 475 | "eslint-module-utils": { 476 | "version": "2.4.1", 477 | "resolved": "https://registry.npmjs.org/eslint-module-utils/-/eslint-module-utils-2.4.1.tgz", 478 | "integrity": "sha512-H6DOj+ejw7Tesdgbfs4jeS4YMFrT8uI8xwd1gtQqXssaR0EQ26L+2O/w6wkYFy2MymON0fTwHmXBvvfLNZVZEw==", 479 | "dev": true, 480 | "requires": { 481 | "debug": "^2.6.8", 482 | "pkg-dir": "^2.0.0" 483 | }, 484 | "dependencies": { 485 | "debug": { 486 | "version": "2.6.9", 487 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 488 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 489 | "dev": true, 490 | "requires": { 491 | "ms": "2.0.0" 492 | } 493 | }, 494 | "ms": { 495 | "version": "2.0.0", 496 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 497 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=", 498 | "dev": true 499 | } 500 | } 501 | }, 502 | "eslint-plugin-import": { 503 | "version": "2.18.2", 504 | "resolved": "https://registry.npmjs.org/eslint-plugin-import/-/eslint-plugin-import-2.18.2.tgz", 505 | "integrity": "sha512-5ohpsHAiUBRNaBWAF08izwUGlbrJoJJ+W9/TBwsGoR1MnlgfwMIKrFeSjWbt6moabiXW9xNvtFz+97KHRfI4HQ==", 506 | "dev": true, 507 | "requires": { 508 | "array-includes": "^3.0.3", 509 | "contains-path": "^0.1.0", 510 | "debug": "^2.6.9", 511 | "doctrine": "1.5.0", 512 | "eslint-import-resolver-node": "^0.3.2", 513 | "eslint-module-utils": "^2.4.0", 514 | "has": "^1.0.3", 515 | "minimatch": "^3.0.4", 516 | "object.values": "^1.1.0", 517 | "read-pkg-up": "^2.0.0", 518 | "resolve": "^1.11.0" 519 | }, 520 | "dependencies": { 521 | "debug": { 522 | "version": "2.6.9", 523 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 524 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 525 | "dev": true, 526 | "requires": { 527 | "ms": "2.0.0" 528 | } 529 | }, 530 | "doctrine": { 531 | "version": "1.5.0", 532 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-1.5.0.tgz", 533 | "integrity": "sha1-N53Ocw9hZvds76TmcHoVmwLFpvo=", 534 | "dev": true, 535 | "requires": { 536 | "esutils": "^2.0.2", 537 | "isarray": "^1.0.0" 538 | } 539 | }, 540 | "isarray": { 541 | "version": "1.0.0", 542 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", 543 | "integrity": "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE=", 544 | "dev": true 545 | }, 546 | "ms": { 547 | "version": "2.0.0", 548 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 549 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=", 550 | "dev": true 551 | } 552 | } 553 | }, 554 | "eslint-scope": { 555 | "version": "3.7.1", 556 | "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-3.7.1.tgz", 557 | "integrity": "sha1-PWPD7f2gLgbgGkUq2IyqzHzctug=", 558 | "dev": true, 559 | "requires": { 560 | "esrecurse": "^4.1.0", 561 | "estraverse": "^4.1.1" 562 | } 563 | }, 564 | "eslint-utils": { 565 | "version": "1.4.3", 566 | "resolved": "https://registry.npmjs.org/eslint-utils/-/eslint-utils-1.4.3.tgz", 567 | "integrity": "sha512-fbBN5W2xdY45KulGXmLHZ3c3FHfVYmKg0IrAKGOkT/464PQsx2UeIzfz1RmEci+KLm1bBaAzZAh8+/E+XAeZ8Q==", 568 | "dev": true, 569 | "requires": { 570 | "eslint-visitor-keys": "^1.1.0" 571 | }, 572 | "dependencies": { 573 | "eslint-visitor-keys": { 574 | "version": "1.1.0", 575 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-1.1.0.tgz", 576 | "integrity": "sha512-8y9YjtM1JBJU/A9Kc+SbaOV4y29sSWckBwMHa+FGtVj5gN/sbnKDf6xJUl+8g7FAij9LVaP8C24DUiH/f/2Z9A==", 577 | "dev": true 578 | } 579 | } 580 | }, 581 | "eslint-visitor-keys": { 582 | "version": "1.0.0", 583 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-1.0.0.tgz", 584 | "integrity": "sha512-qzm/XxIbxm/FHyH341ZrbnMUpe+5Bocte9xkmFMzPMjRaZMcXww+MpBptFvtU+79L362nqiLhekCxCxDPaUMBQ==", 585 | "dev": true 586 | }, 587 | "espree": { 588 | "version": "6.0.0", 589 | "resolved": "https://registry.npmjs.org/espree/-/espree-6.0.0.tgz", 590 | "integrity": "sha512-lJvCS6YbCn3ImT3yKkPe0+tJ+mH6ljhGNjHQH9mRtiO6gjhVAOhVXW1yjnwqGwTkK3bGbye+hb00nFNmu0l/1Q==", 591 | "dev": true, 592 | "requires": { 593 | "acorn": "^6.0.7", 594 | "acorn-jsx": "^5.0.0", 595 | "eslint-visitor-keys": "^1.0.0" 596 | } 597 | }, 598 | "esprima": { 599 | "version": "4.0.1", 600 | "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz", 601 | "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==", 602 | "dev": true 603 | }, 604 | "esquery": { 605 | "version": "1.0.1", 606 | "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.0.1.tgz", 607 | "integrity": "sha512-SmiyZ5zIWH9VM+SRUReLS5Q8a7GxtRdxEBVZpm98rJM7Sb+A9DVCndXfkeFUd3byderg+EbDkfnevfCwynWaNA==", 608 | "dev": true, 609 | "requires": { 610 | "estraverse": "^4.0.0" 611 | } 612 | }, 613 | "esrecurse": { 614 | "version": "4.2.1", 615 | "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.2.1.tgz", 616 | "integrity": "sha512-64RBB++fIOAXPw3P9cy89qfMlvZEXZkqqJkjqqXIvzP5ezRZjW+lPWjw35UX/3EhUPFYbg5ER4JYgDw4007/DQ==", 617 | "dev": true, 618 | "requires": { 619 | "estraverse": "^4.1.0" 620 | } 621 | }, 622 | "estraverse": { 623 | "version": "4.2.0", 624 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-4.2.0.tgz", 625 | "integrity": "sha1-De4/7TH81GlhjOc0IJn8GvoL2xM=", 626 | "dev": true 627 | }, 628 | "esutils": { 629 | "version": "2.0.2", 630 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.2.tgz", 631 | "integrity": "sha1-Cr9PHKpbyx96nYrMbepPqqBLrJs=", 632 | "dev": true 633 | }, 634 | "external-editor": { 635 | "version": "3.1.0", 636 | "resolved": "https://registry.npmjs.org/external-editor/-/external-editor-3.1.0.tgz", 637 | "integrity": "sha512-hMQ4CX1p1izmuLYyZqLMO/qGNw10wSv9QDCPfzXfyFrOaCSSoRfqE1Kf1s5an66J5JZC62NewG+mK49jOCtQew==", 638 | "dev": true, 639 | "requires": { 640 | "chardet": "^0.7.0", 641 | "iconv-lite": "^0.4.24", 642 | "tmp": "^0.0.33" 643 | } 644 | }, 645 | "fast-deep-equal": { 646 | "version": "2.0.1", 647 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-2.0.1.tgz", 648 | "integrity": "sha1-ewUhjd+WZ79/Nwv3/bLLFf3Qqkk=", 649 | "dev": true 650 | }, 651 | "fast-json-stable-stringify": { 652 | "version": "2.0.0", 653 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.0.0.tgz", 654 | "integrity": "sha1-1RQsDK7msRifh9OnYREGT4bIu/I=", 655 | "dev": true 656 | }, 657 | "fast-levenshtein": { 658 | "version": "2.0.6", 659 | "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", 660 | "integrity": "sha1-PYpcZog6FqMMqGQ+hR8Zuqd5eRc=", 661 | "dev": true 662 | }, 663 | "figures": { 664 | "version": "2.0.0", 665 | "resolved": "https://registry.npmjs.org/figures/-/figures-2.0.0.tgz", 666 | "integrity": "sha1-OrGi0qYsi/tDGgyUy3l6L84nyWI=", 667 | "dev": true, 668 | "requires": { 669 | "escape-string-regexp": "^1.0.5" 670 | } 671 | }, 672 | "file-entry-cache": { 673 | "version": "5.0.1", 674 | "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-5.0.1.tgz", 675 | "integrity": "sha512-bCg29ictuBaKUwwArK4ouCaqDgLZcysCFLmM/Yn/FDoqndh/9vNuQfXRDvTuXKLxfD/JtZQGKFT8MGcJBK644g==", 676 | "dev": true, 677 | "requires": { 678 | "flat-cache": "^2.0.1" 679 | } 680 | }, 681 | "find-up": { 682 | "version": "2.1.0", 683 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-2.1.0.tgz", 684 | "integrity": "sha1-RdG35QbHF93UgndaK3eSCjwMV6c=", 685 | "dev": true, 686 | "requires": { 687 | "locate-path": "^2.0.0" 688 | } 689 | }, 690 | "flat-cache": { 691 | "version": "2.0.1", 692 | "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-2.0.1.tgz", 693 | "integrity": "sha512-LoQe6yDuUMDzQAEH8sgmh4Md6oZnc/7PjtwjNFSzveXqSHt6ka9fPBuso7IGf9Rz4uqnSnWiFH2B/zj24a5ReA==", 694 | "dev": true, 695 | "requires": { 696 | "flatted": "^2.0.0", 697 | "rimraf": "2.6.3", 698 | "write": "1.0.3" 699 | } 700 | }, 701 | "flatted": { 702 | "version": "2.0.1", 703 | "resolved": "https://registry.npmjs.org/flatted/-/flatted-2.0.1.tgz", 704 | "integrity": "sha512-a1hQMktqW9Nmqr5aktAux3JMNqaucxGcjtjWnZLHX7yyPCmlSV3M54nGYbqT8K+0GhF3NBgmJCc3ma+WOgX8Jg==", 705 | "dev": true 706 | }, 707 | "fs.realpath": { 708 | "version": "1.0.0", 709 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 710 | "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=", 711 | "dev": true 712 | }, 713 | "function-bind": { 714 | "version": "1.1.1", 715 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", 716 | "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==", 717 | "dev": true 718 | }, 719 | "functional-red-black-tree": { 720 | "version": "1.0.1", 721 | "resolved": "https://registry.npmjs.org/functional-red-black-tree/-/functional-red-black-tree-1.0.1.tgz", 722 | "integrity": "sha1-GwqzvVU7Kg1jmdKcDj6gslIHgyc=", 723 | "dev": true 724 | }, 725 | "glob": { 726 | "version": "7.1.4", 727 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.4.tgz", 728 | "integrity": "sha512-hkLPepehmnKk41pUGm3sYxoFs/umurYfYJCerbXEyFIWcAzvpipAgVkBqqT9RBKMGjnq6kMuyYwha6csxbiM1A==", 729 | "dev": true, 730 | "requires": { 731 | "fs.realpath": "^1.0.0", 732 | "inflight": "^1.0.4", 733 | "inherits": "2", 734 | "minimatch": "^3.0.4", 735 | "once": "^1.3.0", 736 | "path-is-absolute": "^1.0.0" 737 | } 738 | }, 739 | "glob-parent": { 740 | "version": "5.0.0", 741 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.0.0.tgz", 742 | "integrity": "sha512-Z2RwiujPRGluePM6j699ktJYxmPpJKCfpGA13jz2hmFZC7gKetzrWvg5KN3+OsIFmydGyZ1AVwERCq1w/ZZwRg==", 743 | "dev": true, 744 | "requires": { 745 | "is-glob": "^4.0.1" 746 | } 747 | }, 748 | "globals": { 749 | "version": "11.12.0", 750 | "resolved": "https://registry.npmjs.org/globals/-/globals-11.12.0.tgz", 751 | "integrity": "sha512-WOBp/EEGUiIsJSp7wcv/y6MO+lV9UoncWqxuFfm8eBwzWNgyfBd6Gz+IeKQ9jCmyhoH99g15M3T+QaVHFjizVA==", 752 | "dev": true 753 | }, 754 | "graceful-fs": { 755 | "version": "4.2.0", 756 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.0.tgz", 757 | "integrity": "sha512-jpSvDPV4Cq/bgtpndIWbI5hmYxhQGHPC4d4cqBPb4DLniCfhJokdXhwhaDuLBGLQdvvRum/UiX6ECVIPvDXqdg==", 758 | "dev": true 759 | }, 760 | "has": { 761 | "version": "1.0.3", 762 | "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", 763 | "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", 764 | "dev": true, 765 | "requires": { 766 | "function-bind": "^1.1.1" 767 | } 768 | }, 769 | "has-flag": { 770 | "version": "3.0.0", 771 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 772 | "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=", 773 | "dev": true 774 | }, 775 | "has-symbols": { 776 | "version": "1.0.0", 777 | "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.0.tgz", 778 | "integrity": "sha1-uhqPGvKg/DllD1yFA2dwQSIGO0Q=", 779 | "dev": true 780 | }, 781 | "hosted-git-info": { 782 | "version": "2.7.1", 783 | "resolved": "https://registry.npmjs.org/hosted-git-info/-/hosted-git-info-2.7.1.tgz", 784 | "integrity": "sha512-7T/BxH19zbcCTa8XkMlbK5lTo1WtgkFi3GvdWEyNuc4Vex7/9Dqbnpsf4JMydcfj9HCg4zUWFTL3Za6lapg5/w==", 785 | "dev": true 786 | }, 787 | "iconv-lite": { 788 | "version": "0.4.24", 789 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", 790 | "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", 791 | "dev": true, 792 | "requires": { 793 | "safer-buffer": ">= 2.1.2 < 3" 794 | } 795 | }, 796 | "ignore": { 797 | "version": "4.0.6", 798 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-4.0.6.tgz", 799 | "integrity": "sha512-cyFDKrqc/YdcWFniJhzI42+AzS+gNwmUzOSFcRCQYwySuBBBy/KjuxWLZ/FHEH6Moq1NizMOBWyTcv8O4OZIMg==", 800 | "dev": true 801 | }, 802 | "import-fresh": { 803 | "version": "3.1.0", 804 | "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.1.0.tgz", 805 | "integrity": "sha512-PpuksHKGt8rXfWEr9m9EHIpgyyaltBy8+eF6GJM0QCAxMgxCfucMF3mjecK2QsJr0amJW7gTqh5/wht0z2UhEQ==", 806 | "dev": true, 807 | "requires": { 808 | "parent-module": "^1.0.0", 809 | "resolve-from": "^4.0.0" 810 | } 811 | }, 812 | "imurmurhash": { 813 | "version": "0.1.4", 814 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 815 | "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=", 816 | "dev": true 817 | }, 818 | "inflight": { 819 | "version": "1.0.6", 820 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 821 | "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", 822 | "dev": true, 823 | "requires": { 824 | "once": "^1.3.0", 825 | "wrappy": "1" 826 | } 827 | }, 828 | "inherits": { 829 | "version": "2.0.4", 830 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 831 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", 832 | "dev": true 833 | }, 834 | "inquirer": { 835 | "version": "6.5.0", 836 | "resolved": "https://registry.npmjs.org/inquirer/-/inquirer-6.5.0.tgz", 837 | "integrity": "sha512-scfHejeG/lVZSpvCXpsB4j/wQNPM5JC8kiElOI0OUTwmc1RTpXr4H32/HOlQHcZiYl2z2VElwuCVDRG8vFmbnA==", 838 | "dev": true, 839 | "requires": { 840 | "ansi-escapes": "^3.2.0", 841 | "chalk": "^2.4.2", 842 | "cli-cursor": "^2.1.0", 843 | "cli-width": "^2.0.0", 844 | "external-editor": "^3.0.3", 845 | "figures": "^2.0.0", 846 | "lodash": "^4.17.12", 847 | "mute-stream": "0.0.7", 848 | "run-async": "^2.2.0", 849 | "rxjs": "^6.4.0", 850 | "string-width": "^2.1.0", 851 | "strip-ansi": "^5.1.0", 852 | "through": "^2.3.6" 853 | } 854 | }, 855 | "is-arrayish": { 856 | "version": "0.2.1", 857 | "resolved": "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.2.1.tgz", 858 | "integrity": "sha1-d8mYQFJ6qOyxqLppe4BkWnqSap0=", 859 | "dev": true 860 | }, 861 | "is-callable": { 862 | "version": "1.1.4", 863 | "resolved": "https://registry.npmjs.org/is-callable/-/is-callable-1.1.4.tgz", 864 | "integrity": "sha512-r5p9sxJjYnArLjObpjA4xu5EKI3CuKHkJXMhT7kwbpUyIFD1n5PMAsoPvWnvtZiNz7LjkYDRZhd7FlI0eMijEA==", 865 | "dev": true 866 | }, 867 | "is-date-object": { 868 | "version": "1.0.1", 869 | "resolved": "https://registry.npmjs.org/is-date-object/-/is-date-object-1.0.1.tgz", 870 | "integrity": "sha1-mqIOtq7rv/d/vTPnTKAbM1gdOhY=", 871 | "dev": true 872 | }, 873 | "is-extglob": { 874 | "version": "2.1.1", 875 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 876 | "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=", 877 | "dev": true 878 | }, 879 | "is-fullwidth-code-point": { 880 | "version": "2.0.0", 881 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", 882 | "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=", 883 | "dev": true 884 | }, 885 | "is-glob": { 886 | "version": "4.0.1", 887 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.1.tgz", 888 | "integrity": "sha512-5G0tKtBTFImOqDnLB2hG6Bp2qcKEFduo4tZu9MT/H6NQv/ghhy30o55ufafxJ/LdH79LLs2Kfrn85TLKyA7BUg==", 889 | "dev": true, 890 | "requires": { 891 | "is-extglob": "^2.1.1" 892 | } 893 | }, 894 | "is-promise": { 895 | "version": "2.1.0", 896 | "resolved": "https://registry.npmjs.org/is-promise/-/is-promise-2.1.0.tgz", 897 | "integrity": "sha1-eaKp7OfwlugPNtKy87wWwf9L8/o=", 898 | "dev": true 899 | }, 900 | "is-regex": { 901 | "version": "1.0.4", 902 | "resolved": "https://registry.npmjs.org/is-regex/-/is-regex-1.0.4.tgz", 903 | "integrity": "sha1-VRdIm1RwkbCTDglWVM7SXul+lJE=", 904 | "dev": true, 905 | "requires": { 906 | "has": "^1.0.1" 907 | } 908 | }, 909 | "is-symbol": { 910 | "version": "1.0.2", 911 | "resolved": "https://registry.npmjs.org/is-symbol/-/is-symbol-1.0.2.tgz", 912 | "integrity": "sha512-HS8bZ9ox60yCJLH9snBpIwv9pYUAkcuLhSA1oero1UB5y9aiQpRA8y2ex945AOtCZL1lJDeIk3G5LthswI46Lw==", 913 | "dev": true, 914 | "requires": { 915 | "has-symbols": "^1.0.0" 916 | } 917 | }, 918 | "isarray": { 919 | "version": "0.0.1", 920 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-0.0.1.tgz", 921 | "integrity": "sha1-ihis/Kmo9Bd+Cav8YDiTmwXR7t8=" 922 | }, 923 | "isexe": { 924 | "version": "2.0.0", 925 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 926 | "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=", 927 | "dev": true 928 | }, 929 | "js-tokens": { 930 | "version": "4.0.0", 931 | "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", 932 | "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==", 933 | "dev": true 934 | }, 935 | "js-yaml": { 936 | "version": "3.13.1", 937 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.13.1.tgz", 938 | "integrity": "sha512-YfbcO7jXDdyj0DGxYVSlSeQNHbD7XPWvrVWeVUujrQEoZzWJIRrCPoyk6kL6IAjAG2IolMK4T0hNUe0HOUs5Jw==", 939 | "dev": true, 940 | "requires": { 941 | "argparse": "^1.0.7", 942 | "esprima": "^4.0.0" 943 | } 944 | }, 945 | "jsesc": { 946 | "version": "2.5.2", 947 | "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-2.5.2.tgz", 948 | "integrity": "sha512-OYu7XEzjkCQ3C5Ps3QIZsQfNpqoJyZZA99wd9aWd05NCtC5pWOkShK2mkL6HXQR6/Cy2lbNdPlZBpuQHXE63gA==", 949 | "dev": true 950 | }, 951 | "json-schema-traverse": { 952 | "version": "0.4.1", 953 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", 954 | "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", 955 | "dev": true 956 | }, 957 | "json-stable-stringify-without-jsonify": { 958 | "version": "1.0.1", 959 | "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz", 960 | "integrity": "sha1-nbe1lJatPzz+8wp1FC0tkwrXJlE=", 961 | "dev": true 962 | }, 963 | "levn": { 964 | "version": "0.3.0", 965 | "resolved": "https://registry.npmjs.org/levn/-/levn-0.3.0.tgz", 966 | "integrity": "sha1-OwmSTt+fCDwEkP3UwLxEIeBHZO4=", 967 | "dev": true, 968 | "requires": { 969 | "prelude-ls": "~1.1.2", 970 | "type-check": "~0.3.2" 971 | } 972 | }, 973 | "load-json-file": { 974 | "version": "2.0.0", 975 | "resolved": "https://registry.npmjs.org/load-json-file/-/load-json-file-2.0.0.tgz", 976 | "integrity": "sha1-eUfkIUmvgNaWy/eXvKq8/h/inKg=", 977 | "dev": true, 978 | "requires": { 979 | "graceful-fs": "^4.1.2", 980 | "parse-json": "^2.2.0", 981 | "pify": "^2.0.0", 982 | "strip-bom": "^3.0.0" 983 | } 984 | }, 985 | "locate-path": { 986 | "version": "2.0.0", 987 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-2.0.0.tgz", 988 | "integrity": "sha1-K1aLJl7slExtnA3pw9u7ygNUzY4=", 989 | "dev": true, 990 | "requires": { 991 | "p-locate": "^2.0.0", 992 | "path-exists": "^3.0.0" 993 | } 994 | }, 995 | "lodash": { 996 | "version": "4.17.15", 997 | "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.15.tgz", 998 | "integrity": "sha512-8xOcRHvCjnocdS5cpwXQXVzmmh5e5+saE2QGoeQmbKmRS6J3VQppPOIt0MnmE+4xlZoumy0GPG0D0MVIQbNA1A==", 999 | "dev": true 1000 | }, 1001 | "mimic-fn": { 1002 | "version": "1.2.0", 1003 | "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-1.2.0.tgz", 1004 | "integrity": "sha512-jf84uxzwiuiIVKiOLpfYk7N46TSy8ubTonmneY9vrpHNAnp0QBt2BxWV9dO3/j+BoVAb+a5G6YDPW3M5HOdMWQ==", 1005 | "dev": true 1006 | }, 1007 | "minimatch": { 1008 | "version": "3.0.4", 1009 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", 1010 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 1011 | "dev": true, 1012 | "requires": { 1013 | "brace-expansion": "^1.1.7" 1014 | } 1015 | }, 1016 | "minimist": { 1017 | "version": "0.0.8", 1018 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-0.0.8.tgz", 1019 | "integrity": "sha1-hX/Kv8M5fSYluCKCYuhqp6ARsF0=", 1020 | "dev": true 1021 | }, 1022 | "mkdirp": { 1023 | "version": "0.5.1", 1024 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.1.tgz", 1025 | "integrity": "sha1-MAV0OOrGz3+MR2fzhkjWaX11yQM=", 1026 | "dev": true, 1027 | "requires": { 1028 | "minimist": "0.0.8" 1029 | } 1030 | }, 1031 | "ms": { 1032 | "version": "2.1.2", 1033 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 1034 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 1035 | "dev": true 1036 | }, 1037 | "mute-stream": { 1038 | "version": "0.0.7", 1039 | "resolved": "https://registry.npmjs.org/mute-stream/-/mute-stream-0.0.7.tgz", 1040 | "integrity": "sha1-MHXOk7whuPq0PhvE2n6BFe0ee6s=", 1041 | "dev": true 1042 | }, 1043 | "natural-compare": { 1044 | "version": "1.4.0", 1045 | "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", 1046 | "integrity": "sha1-Sr6/7tdUHywnrPspvbvRXI1bpPc=", 1047 | "dev": true 1048 | }, 1049 | "nice-try": { 1050 | "version": "1.0.5", 1051 | "resolved": "https://registry.npmjs.org/nice-try/-/nice-try-1.0.5.tgz", 1052 | "integrity": "sha512-1nh45deeb5olNY7eX82BkPO7SSxR5SSYJiPTrTdFUVYwAl8CKMA5N9PjTYkHiRjisVcxcQ1HXdLhx2qxxJzLNQ==", 1053 | "dev": true 1054 | }, 1055 | "normalize-package-data": { 1056 | "version": "2.5.0", 1057 | "resolved": "https://registry.npmjs.org/normalize-package-data/-/normalize-package-data-2.5.0.tgz", 1058 | "integrity": "sha512-/5CMN3T0R4XTj4DcGaexo+roZSdSFW/0AOOTROrjxzCG1wrWXEsGbRKevjlIL+ZDE4sZlJr5ED4YW0yqmkK+eA==", 1059 | "dev": true, 1060 | "requires": { 1061 | "hosted-git-info": "^2.1.4", 1062 | "resolve": "^1.10.0", 1063 | "semver": "2 || 3 || 4 || 5", 1064 | "validate-npm-package-license": "^3.0.1" 1065 | }, 1066 | "dependencies": { 1067 | "semver": { 1068 | "version": "5.7.0", 1069 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.0.tgz", 1070 | "integrity": "sha512-Ya52jSX2u7QKghxeoFGpLwCtGlt7j0oY9DYb5apt9nPlJ42ID+ulTXESnt/qAQcoSERyZ5sl3LDIOw0nAn/5DA==", 1071 | "dev": true 1072 | } 1073 | } 1074 | }, 1075 | "object-keys": { 1076 | "version": "1.1.1", 1077 | "resolved": "https://registry.npmjs.org/object-keys/-/object-keys-1.1.1.tgz", 1078 | "integrity": "sha512-NuAESUOUMrlIXOfHKzD6bpPu3tYt3xvjNdRIQ+FeT0lNb4K8WR70CaDxhuNguS2XG+GjkyMwOzsN5ZktImfhLA==", 1079 | "dev": true 1080 | }, 1081 | "object.values": { 1082 | "version": "1.1.0", 1083 | "resolved": "https://registry.npmjs.org/object.values/-/object.values-1.1.0.tgz", 1084 | "integrity": "sha512-8mf0nKLAoFX6VlNVdhGj31SVYpaNFtUnuoOXWyFEstsWRgU837AK+JYM0iAxwkSzGRbwn8cbFmgbyxj1j4VbXg==", 1085 | "dev": true, 1086 | "requires": { 1087 | "define-properties": "^1.1.3", 1088 | "es-abstract": "^1.12.0", 1089 | "function-bind": "^1.1.1", 1090 | "has": "^1.0.3" 1091 | } 1092 | }, 1093 | "once": { 1094 | "version": "1.4.0", 1095 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 1096 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 1097 | "dev": true, 1098 | "requires": { 1099 | "wrappy": "1" 1100 | } 1101 | }, 1102 | "onetime": { 1103 | "version": "2.0.1", 1104 | "resolved": "https://registry.npmjs.org/onetime/-/onetime-2.0.1.tgz", 1105 | "integrity": "sha1-BnQoIw/WdEOyeUsiu6UotoZ5YtQ=", 1106 | "dev": true, 1107 | "requires": { 1108 | "mimic-fn": "^1.0.0" 1109 | } 1110 | }, 1111 | "optionator": { 1112 | "version": "0.8.2", 1113 | "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.8.2.tgz", 1114 | "integrity": "sha1-NkxeQJ0/TWMB1sC0wFu6UBgK62Q=", 1115 | "dev": true, 1116 | "requires": { 1117 | "deep-is": "~0.1.3", 1118 | "fast-levenshtein": "~2.0.4", 1119 | "levn": "~0.3.0", 1120 | "prelude-ls": "~1.1.2", 1121 | "type-check": "~0.3.2", 1122 | "wordwrap": "~1.0.0" 1123 | } 1124 | }, 1125 | "os-tmpdir": { 1126 | "version": "1.0.2", 1127 | "resolved": "https://registry.npmjs.org/os-tmpdir/-/os-tmpdir-1.0.2.tgz", 1128 | "integrity": "sha1-u+Z0BseaqFxc/sdm/lc0VV36EnQ=", 1129 | "dev": true 1130 | }, 1131 | "p-limit": { 1132 | "version": "1.3.0", 1133 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-1.3.0.tgz", 1134 | "integrity": "sha512-vvcXsLAJ9Dr5rQOPk7toZQZJApBl2K4J6dANSsEuh6QI41JYcsS/qhTGa9ErIUUgK3WNQoJYvylxvjqmiqEA9Q==", 1135 | "dev": true, 1136 | "requires": { 1137 | "p-try": "^1.0.0" 1138 | } 1139 | }, 1140 | "p-locate": { 1141 | "version": "2.0.0", 1142 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-2.0.0.tgz", 1143 | "integrity": "sha1-IKAQOyIqcMj9OcwuWAaA893l7EM=", 1144 | "dev": true, 1145 | "requires": { 1146 | "p-limit": "^1.1.0" 1147 | } 1148 | }, 1149 | "p-try": { 1150 | "version": "1.0.0", 1151 | "resolved": "https://registry.npmjs.org/p-try/-/p-try-1.0.0.tgz", 1152 | "integrity": "sha1-y8ec26+P1CKOE/Yh8rGiN8GyB7M=", 1153 | "dev": true 1154 | }, 1155 | "page": { 1156 | "version": "1.11.4", 1157 | "resolved": "https://registry.npmjs.org/page/-/page-1.11.4.tgz", 1158 | "integrity": "sha512-8JMZzcE5W4qk+/DtmogN57cI+Yscy7xTYCpfSO7s3Tx6LjZuAfHFQY1+cKIAy60NaXdzVD6nOc3objaVbE0HJg==", 1159 | "requires": { 1160 | "path-to-regexp": "~1.2.1" 1161 | } 1162 | }, 1163 | "parent-module": { 1164 | "version": "1.0.1", 1165 | "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz", 1166 | "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==", 1167 | "dev": true, 1168 | "requires": { 1169 | "callsites": "^3.0.0" 1170 | } 1171 | }, 1172 | "parse-json": { 1173 | "version": "2.2.0", 1174 | "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-2.2.0.tgz", 1175 | "integrity": "sha1-9ID0BDTvgHQfhGkJn43qGPVaTck=", 1176 | "dev": true, 1177 | "requires": { 1178 | "error-ex": "^1.2.0" 1179 | } 1180 | }, 1181 | "path-exists": { 1182 | "version": "3.0.0", 1183 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-3.0.0.tgz", 1184 | "integrity": "sha1-zg6+ql94yxiSXqfYENe1mwEP1RU=", 1185 | "dev": true 1186 | }, 1187 | "path-is-absolute": { 1188 | "version": "1.0.1", 1189 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 1190 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=", 1191 | "dev": true 1192 | }, 1193 | "path-key": { 1194 | "version": "2.0.1", 1195 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-2.0.1.tgz", 1196 | "integrity": "sha1-QRyttXTFoUDTpLGRDUDYDMn0C0A=", 1197 | "dev": true 1198 | }, 1199 | "path-parse": { 1200 | "version": "1.0.6", 1201 | "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.6.tgz", 1202 | "integrity": "sha512-GSmOT2EbHrINBf9SR7CDELwlJ8AENk3Qn7OikK4nFYAu3Ote2+JYNVvkpAEQm3/TLNEJFD/xZJjzyxg3KBWOzw==", 1203 | "dev": true 1204 | }, 1205 | "path-to-regexp": { 1206 | "version": "1.2.1", 1207 | "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-1.2.1.tgz", 1208 | "integrity": "sha1-szcFwUAjTYc8hyHHuf2LVB7Tr/k=", 1209 | "requires": { 1210 | "isarray": "0.0.1" 1211 | } 1212 | }, 1213 | "path-type": { 1214 | "version": "2.0.0", 1215 | "resolved": "https://registry.npmjs.org/path-type/-/path-type-2.0.0.tgz", 1216 | "integrity": "sha1-8BLMuEFbcJb8LaoQVMPXI4lZTHM=", 1217 | "dev": true, 1218 | "requires": { 1219 | "pify": "^2.0.0" 1220 | } 1221 | }, 1222 | "pify": { 1223 | "version": "2.3.0", 1224 | "resolved": "https://registry.npmjs.org/pify/-/pify-2.3.0.tgz", 1225 | "integrity": "sha1-7RQaasBDqEnqWISY59yosVMw6Qw=", 1226 | "dev": true 1227 | }, 1228 | "pkg-dir": { 1229 | "version": "2.0.0", 1230 | "resolved": "https://registry.npmjs.org/pkg-dir/-/pkg-dir-2.0.0.tgz", 1231 | "integrity": "sha1-9tXREJ4Z1j7fQo4L1X4Sd3YVM0s=", 1232 | "dev": true, 1233 | "requires": { 1234 | "find-up": "^2.1.0" 1235 | } 1236 | }, 1237 | "prelude-ls": { 1238 | "version": "1.1.2", 1239 | "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.1.2.tgz", 1240 | "integrity": "sha1-IZMqVJ9eUv/ZqCf1cOBL5iqX2lQ=", 1241 | "dev": true 1242 | }, 1243 | "progress": { 1244 | "version": "2.0.3", 1245 | "resolved": "https://registry.npmjs.org/progress/-/progress-2.0.3.tgz", 1246 | "integrity": "sha512-7PiHtLll5LdnKIMw100I+8xJXR5gW2QwWYkT6iJva0bXitZKa/XMrSbdmg3r2Xnaidz9Qumd0VPaMrZlF9V9sA==", 1247 | "dev": true 1248 | }, 1249 | "punycode": { 1250 | "version": "2.1.1", 1251 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.1.1.tgz", 1252 | "integrity": "sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A==", 1253 | "dev": true 1254 | }, 1255 | "read-pkg": { 1256 | "version": "2.0.0", 1257 | "resolved": "https://registry.npmjs.org/read-pkg/-/read-pkg-2.0.0.tgz", 1258 | "integrity": "sha1-jvHAYjxqbbDcZxPEv6xGMysjaPg=", 1259 | "dev": true, 1260 | "requires": { 1261 | "load-json-file": "^2.0.0", 1262 | "normalize-package-data": "^2.3.2", 1263 | "path-type": "^2.0.0" 1264 | } 1265 | }, 1266 | "read-pkg-up": { 1267 | "version": "2.0.0", 1268 | "resolved": "https://registry.npmjs.org/read-pkg-up/-/read-pkg-up-2.0.0.tgz", 1269 | "integrity": "sha1-a3KoBImE4MQeeVEP1en6mbO1Sb4=", 1270 | "dev": true, 1271 | "requires": { 1272 | "find-up": "^2.0.0", 1273 | "read-pkg": "^2.0.0" 1274 | } 1275 | }, 1276 | "regexpp": { 1277 | "version": "2.0.1", 1278 | "resolved": "https://registry.npmjs.org/regexpp/-/regexpp-2.0.1.tgz", 1279 | "integrity": "sha512-lv0M6+TkDVniA3aD1Eg0DVpfU/booSu7Eev3TDO/mZKHBfVjgCGTV4t4buppESEYDtkArYFOxTJWv6S5C+iaNw==", 1280 | "dev": true 1281 | }, 1282 | "resolve": { 1283 | "version": "1.11.1", 1284 | "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.11.1.tgz", 1285 | "integrity": "sha512-vIpgF6wfuJOZI7KKKSP+HmiKggadPQAdsp5HiC1mvqnfp0gF1vdwgBWZIdrVft9pgqoMFQN+R7BSWZiBxx+BBw==", 1286 | "dev": true, 1287 | "requires": { 1288 | "path-parse": "^1.0.6" 1289 | } 1290 | }, 1291 | "resolve-from": { 1292 | "version": "4.0.0", 1293 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", 1294 | "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==", 1295 | "dev": true 1296 | }, 1297 | "restore-cursor": { 1298 | "version": "2.0.0", 1299 | "resolved": "https://registry.npmjs.org/restore-cursor/-/restore-cursor-2.0.0.tgz", 1300 | "integrity": "sha1-n37ih/gv0ybU/RYpI9YhKe7g368=", 1301 | "dev": true, 1302 | "requires": { 1303 | "onetime": "^2.0.0", 1304 | "signal-exit": "^3.0.2" 1305 | } 1306 | }, 1307 | "rimraf": { 1308 | "version": "2.6.3", 1309 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.6.3.tgz", 1310 | "integrity": "sha512-mwqeW5XsA2qAejG46gYdENaxXjx9onRNCfn7L0duuP4hCuTIi/QO7PDK07KJfp1d+izWPrzEJDcSqBa0OZQriA==", 1311 | "dev": true, 1312 | "requires": { 1313 | "glob": "^7.1.3" 1314 | } 1315 | }, 1316 | "rollup": { 1317 | "version": "1.17.0", 1318 | "resolved": "https://registry.npmjs.org/rollup/-/rollup-1.17.0.tgz", 1319 | "integrity": "sha512-k/j1m0NIsI4SYgCJR4MWPstGJOWfJyd6gycKoMhyoKPVXxm+L49XtbUwZyFsrSU2YXsOkM4u1ll9CS/ZgJBUpw==", 1320 | "dev": true, 1321 | "requires": { 1322 | "@types/estree": "0.0.39", 1323 | "@types/node": "^12.6.2", 1324 | "acorn": "^6.2.0" 1325 | } 1326 | }, 1327 | "run-async": { 1328 | "version": "2.3.0", 1329 | "resolved": "https://registry.npmjs.org/run-async/-/run-async-2.3.0.tgz", 1330 | "integrity": "sha1-A3GrSuC91yDUFm19/aZP96RFpsA=", 1331 | "dev": true, 1332 | "requires": { 1333 | "is-promise": "^2.1.0" 1334 | } 1335 | }, 1336 | "rxjs": { 1337 | "version": "6.5.2", 1338 | "resolved": "https://registry.npmjs.org/rxjs/-/rxjs-6.5.2.tgz", 1339 | "integrity": "sha512-HUb7j3kvb7p7eCUHE3FqjoDsC1xfZQ4AHFWfTKSpZ+sAhhz5X1WX0ZuUqWbzB2QhSLp3DoLUG+hMdEDKqWo2Zg==", 1340 | "dev": true, 1341 | "requires": { 1342 | "tslib": "^1.9.0" 1343 | } 1344 | }, 1345 | "safer-buffer": { 1346 | "version": "2.1.2", 1347 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", 1348 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==", 1349 | "dev": true 1350 | }, 1351 | "semver": { 1352 | "version": "6.2.0", 1353 | "resolved": "https://registry.npmjs.org/semver/-/semver-6.2.0.tgz", 1354 | "integrity": "sha512-jdFC1VdUGT/2Scgbimf7FSx9iJLXoqfglSF+gJeuNWVpiE37OIbc1jywR/GJyFdz3mnkz2/id0L0J/cr0izR5A==", 1355 | "dev": true 1356 | }, 1357 | "shebang-command": { 1358 | "version": "1.2.0", 1359 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-1.2.0.tgz", 1360 | "integrity": "sha1-RKrGW2lbAzmJaMOfNj/uXer98eo=", 1361 | "dev": true, 1362 | "requires": { 1363 | "shebang-regex": "^1.0.0" 1364 | } 1365 | }, 1366 | "shebang-regex": { 1367 | "version": "1.0.0", 1368 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-1.0.0.tgz", 1369 | "integrity": "sha1-2kL0l0DAtC2yypcoVxyxkMmO/qM=", 1370 | "dev": true 1371 | }, 1372 | "signal-exit": { 1373 | "version": "3.0.2", 1374 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.2.tgz", 1375 | "integrity": "sha1-tf3AjxKH6hF4Yo5BXiUTK3NkbG0=", 1376 | "dev": true 1377 | }, 1378 | "slice-ansi": { 1379 | "version": "2.1.0", 1380 | "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-2.1.0.tgz", 1381 | "integrity": "sha512-Qu+VC3EwYLldKa1fCxuuvULvSJOKEgk9pi8dZeCVK7TqBfUNTH4sFkk4joj8afVSfAYgJoSOetjx9QWOJ5mYoQ==", 1382 | "dev": true, 1383 | "requires": { 1384 | "ansi-styles": "^3.2.0", 1385 | "astral-regex": "^1.0.0", 1386 | "is-fullwidth-code-point": "^2.0.0" 1387 | } 1388 | }, 1389 | "source-map": { 1390 | "version": "0.5.7", 1391 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.5.7.tgz", 1392 | "integrity": "sha1-igOdLRAh0i0eoUyA2OpGi6LvP8w=", 1393 | "dev": true 1394 | }, 1395 | "spdx-correct": { 1396 | "version": "3.1.0", 1397 | "resolved": "https://registry.npmjs.org/spdx-correct/-/spdx-correct-3.1.0.tgz", 1398 | "integrity": "sha512-lr2EZCctC2BNR7j7WzJ2FpDznxky1sjfxvvYEyzxNyb6lZXHODmEoJeFu4JupYlkfha1KZpJyoqiJ7pgA1qq8Q==", 1399 | "dev": true, 1400 | "requires": { 1401 | "spdx-expression-parse": "^3.0.0", 1402 | "spdx-license-ids": "^3.0.0" 1403 | } 1404 | }, 1405 | "spdx-exceptions": { 1406 | "version": "2.2.0", 1407 | "resolved": "https://registry.npmjs.org/spdx-exceptions/-/spdx-exceptions-2.2.0.tgz", 1408 | "integrity": "sha512-2XQACfElKi9SlVb1CYadKDXvoajPgBVPn/gOQLrTvHdElaVhr7ZEbqJaRnJLVNeaI4cMEAgVCeBMKF6MWRDCRA==", 1409 | "dev": true 1410 | }, 1411 | "spdx-expression-parse": { 1412 | "version": "3.0.0", 1413 | "resolved": "https://registry.npmjs.org/spdx-expression-parse/-/spdx-expression-parse-3.0.0.tgz", 1414 | "integrity": "sha512-Yg6D3XpRD4kkOmTpdgbUiEJFKghJH03fiC1OPll5h/0sO6neh2jqRDVHOQ4o/LMea0tgCkbMgea5ip/e+MkWyg==", 1415 | "dev": true, 1416 | "requires": { 1417 | "spdx-exceptions": "^2.1.0", 1418 | "spdx-license-ids": "^3.0.0" 1419 | } 1420 | }, 1421 | "spdx-license-ids": { 1422 | "version": "3.0.5", 1423 | "resolved": "https://registry.npmjs.org/spdx-license-ids/-/spdx-license-ids-3.0.5.tgz", 1424 | "integrity": "sha512-J+FWzZoynJEXGphVIS+XEh3kFSjZX/1i9gFBaWQcB+/tmpe2qUsSBABpcxqxnAxFdiUFEgAX1bjYGQvIZmoz9Q==", 1425 | "dev": true 1426 | }, 1427 | "sprintf-js": { 1428 | "version": "1.0.3", 1429 | "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz", 1430 | "integrity": "sha1-BOaSb2YolTVPPdAVIDYzuFcpfiw=", 1431 | "dev": true 1432 | }, 1433 | "string-width": { 1434 | "version": "2.1.1", 1435 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-2.1.1.tgz", 1436 | "integrity": "sha512-nOqH59deCq9SRHlxq1Aw85Jnt4w6KvLKqWVik6oA9ZklXLNIOlqg4F2yrT1MVaTjAqvVwdfeZ7w7aCvJD7ugkw==", 1437 | "dev": true, 1438 | "requires": { 1439 | "is-fullwidth-code-point": "^2.0.0", 1440 | "strip-ansi": "^4.0.0" 1441 | }, 1442 | "dependencies": { 1443 | "strip-ansi": { 1444 | "version": "4.0.0", 1445 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-4.0.0.tgz", 1446 | "integrity": "sha1-qEeQIusaw2iocTibY1JixQXuNo8=", 1447 | "dev": true, 1448 | "requires": { 1449 | "ansi-regex": "^3.0.0" 1450 | } 1451 | } 1452 | } 1453 | }, 1454 | "strip-ansi": { 1455 | "version": "5.2.0", 1456 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.2.0.tgz", 1457 | "integrity": "sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA==", 1458 | "dev": true, 1459 | "requires": { 1460 | "ansi-regex": "^4.1.0" 1461 | }, 1462 | "dependencies": { 1463 | "ansi-regex": { 1464 | "version": "4.1.0", 1465 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.1.0.tgz", 1466 | "integrity": "sha512-1apePfXM1UOSqw0o9IiFAovVz9M5S1Dg+4TrDwfMewQ6p/rmMueb7tWZjQ1rx4Loy1ArBggoqGpfqqdI4rondg==", 1467 | "dev": true 1468 | } 1469 | } 1470 | }, 1471 | "strip-bom": { 1472 | "version": "3.0.0", 1473 | "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-3.0.0.tgz", 1474 | "integrity": "sha1-IzTBjpx1n3vdVv3vfprj1YjmjtM=", 1475 | "dev": true 1476 | }, 1477 | "strip-json-comments": { 1478 | "version": "3.0.1", 1479 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.0.1.tgz", 1480 | "integrity": "sha512-VTyMAUfdm047mwKl+u79WIdrZxtFtn+nBxHeb844XBQ9uMNTuTHdx2hc5RiAJYqwTj3wc/xe5HLSdJSkJ+WfZw==", 1481 | "dev": true 1482 | }, 1483 | "supports-color": { 1484 | "version": "5.5.0", 1485 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 1486 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 1487 | "dev": true, 1488 | "requires": { 1489 | "has-flag": "^3.0.0" 1490 | } 1491 | }, 1492 | "table": { 1493 | "version": "5.4.4", 1494 | "resolved": "https://registry.npmjs.org/table/-/table-5.4.4.tgz", 1495 | "integrity": "sha512-IIfEAUx5QlODLblLrGTTLJA7Tk0iLSGBvgY8essPRVNGHAzThujww1YqHLs6h3HfTg55h++RzLHH5Xw/rfv+mg==", 1496 | "dev": true, 1497 | "requires": { 1498 | "ajv": "^6.10.2", 1499 | "lodash": "^4.17.14", 1500 | "slice-ansi": "^2.1.0", 1501 | "string-width": "^3.0.0" 1502 | }, 1503 | "dependencies": { 1504 | "string-width": { 1505 | "version": "3.1.0", 1506 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-3.1.0.tgz", 1507 | "integrity": "sha512-vafcv6KjVZKSgz06oM/H6GDBrAtz8vdhQakGjFIvNrHA6y3HCF1CInLy+QLq8dTJPQ1b+KDUqDFctkdRW44e1w==", 1508 | "dev": true, 1509 | "requires": { 1510 | "emoji-regex": "^7.0.1", 1511 | "is-fullwidth-code-point": "^2.0.0", 1512 | "strip-ansi": "^5.1.0" 1513 | } 1514 | } 1515 | } 1516 | }, 1517 | "text-table": { 1518 | "version": "0.2.0", 1519 | "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz", 1520 | "integrity": "sha1-f17oI66AUgfACvLfSoTsP8+lcLQ=", 1521 | "dev": true 1522 | }, 1523 | "through": { 1524 | "version": "2.3.8", 1525 | "resolved": "https://registry.npmjs.org/through/-/through-2.3.8.tgz", 1526 | "integrity": "sha1-DdTJ/6q8NXlgsbckEV1+Doai4fU=", 1527 | "dev": true 1528 | }, 1529 | "tmp": { 1530 | "version": "0.0.33", 1531 | "resolved": "https://registry.npmjs.org/tmp/-/tmp-0.0.33.tgz", 1532 | "integrity": "sha512-jRCJlojKnZ3addtTOjdIqoRuPEKBvNXcGYqzO6zWZX8KfKEpnGY5jfggJQ3EjKuu8D4bJRr0y+cYJFmYbImXGw==", 1533 | "dev": true, 1534 | "requires": { 1535 | "os-tmpdir": "~1.0.2" 1536 | } 1537 | }, 1538 | "to-fast-properties": { 1539 | "version": "2.0.0", 1540 | "resolved": "https://registry.npmjs.org/to-fast-properties/-/to-fast-properties-2.0.0.tgz", 1541 | "integrity": "sha1-3F5pjL0HkmW8c+A3doGk5Og/YW4=", 1542 | "dev": true 1543 | }, 1544 | "trim-right": { 1545 | "version": "1.0.1", 1546 | "resolved": "https://registry.npmjs.org/trim-right/-/trim-right-1.0.1.tgz", 1547 | "integrity": "sha1-yy4SAwZ+DI3h9hQJS5/kVwTqYAM=", 1548 | "dev": true 1549 | }, 1550 | "tslib": { 1551 | "version": "1.10.0", 1552 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.10.0.tgz", 1553 | "integrity": "sha512-qOebF53frne81cf0S9B41ByenJ3/IuH8yJKngAX35CmiZySA0khhkovshKK+jGCaMnVomla7gVlIcc3EvKPbTQ==", 1554 | "dev": true 1555 | }, 1556 | "type-check": { 1557 | "version": "0.3.2", 1558 | "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.3.2.tgz", 1559 | "integrity": "sha1-WITKtRLPHTVeP7eE8wgEsrUg23I=", 1560 | "dev": true, 1561 | "requires": { 1562 | "prelude-ls": "~1.1.2" 1563 | } 1564 | }, 1565 | "uri-js": { 1566 | "version": "4.2.2", 1567 | "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.2.2.tgz", 1568 | "integrity": "sha512-KY9Frmirql91X2Qgjry0Wd4Y+YTdrdZheS8TFwvkbLWf/G5KNJDCh6pKL5OZctEW4+0Baa5idK2ZQuELRwPznQ==", 1569 | "dev": true, 1570 | "requires": { 1571 | "punycode": "^2.1.0" 1572 | } 1573 | }, 1574 | "v8-compile-cache": { 1575 | "version": "2.0.3", 1576 | "resolved": "https://registry.npmjs.org/v8-compile-cache/-/v8-compile-cache-2.0.3.tgz", 1577 | "integrity": "sha512-CNmdbwQMBjwr9Gsmohvm0pbL954tJrNzf6gWL3K+QMQf00PF7ERGrEiLgjuU3mKreLC2MeGhUsNV9ybTbLgd3w==", 1578 | "dev": true 1579 | }, 1580 | "validate-npm-package-license": { 1581 | "version": "3.0.4", 1582 | "resolved": "https://registry.npmjs.org/validate-npm-package-license/-/validate-npm-package-license-3.0.4.tgz", 1583 | "integrity": "sha512-DpKm2Ui/xN7/HQKCtpZxoRWBhZ9Z0kqtygG8XCgNQ8ZlDnxuQmWhj566j8fN4Cu3/JmbhsDo7fcAJq4s9h27Ew==", 1584 | "dev": true, 1585 | "requires": { 1586 | "spdx-correct": "^3.0.0", 1587 | "spdx-expression-parse": "^3.0.0" 1588 | } 1589 | }, 1590 | "which": { 1591 | "version": "1.3.1", 1592 | "resolved": "https://registry.npmjs.org/which/-/which-1.3.1.tgz", 1593 | "integrity": "sha512-HxJdYWq1MTIQbJ3nw0cqssHoTNU267KlrDuGZ1WYlxDStUtKUhOaJmh112/TZmHxxUfuJqPXSOm7tDyas0OSIQ==", 1594 | "dev": true, 1595 | "requires": { 1596 | "isexe": "^2.0.0" 1597 | } 1598 | }, 1599 | "wordwrap": { 1600 | "version": "1.0.0", 1601 | "resolved": "https://registry.npmjs.org/wordwrap/-/wordwrap-1.0.0.tgz", 1602 | "integrity": "sha1-J1hIEIkUVqQXHI0CJkQa3pDLyus=", 1603 | "dev": true 1604 | }, 1605 | "wrappy": { 1606 | "version": "1.0.2", 1607 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 1608 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=", 1609 | "dev": true 1610 | }, 1611 | "write": { 1612 | "version": "1.0.3", 1613 | "resolved": "https://registry.npmjs.org/write/-/write-1.0.3.tgz", 1614 | "integrity": "sha512-/lg70HAjtkUgWPVZhZcm+T4hkL8Zbtp1nFNOn3lRrxnlv50SRBv7cR7RqR+GMsd3hUXy9hWBo4CHTbFTcOYwig==", 1615 | "dev": true, 1616 | "requires": { 1617 | "mkdirp": "^0.5.1" 1618 | } 1619 | } 1620 | } 1621 | } 1622 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "svelte-page-router", 3 | "version": "1.1.0", 4 | "description": "Simple wrapper based on pagejs to make DX similar to config-based router.", 5 | "main": "index.js", 6 | "module": "index.mjs", 7 | "scripts": { 8 | "test": "echo \"Error: no test specified\" && exit 1", 9 | "build": "rollup -c", 10 | "prepublish": "npm run lint && npm run build", 11 | "lint": "eslint src" 12 | }, 13 | "files": [ 14 | "index.js", 15 | "index.mjs" 16 | ], 17 | "repository": { 18 | "type": "git", 19 | "url": "git+https://github.com/PaulMaly/svelte-page-router.git" 20 | }, 21 | "keywords": [ 22 | "svelte", 23 | "routing", 24 | "router", 25 | "pagejs" 26 | ], 27 | "author": "PaulMaly", 28 | "license": "MIT", 29 | "bugs": { 30 | "url": "https://github.com/PaulMaly/svelte-page-router/issues" 31 | }, 32 | "homepage": "https://github.com/PaulMaly/svelte-page-router#readme", 33 | "devDependencies": { 34 | "babel-eslint": "latest", 35 | "eslint": "latest", 36 | "eslint-plugin-import": "latest", 37 | "rollup": "latest" 38 | }, 39 | "dependencies": { 40 | "page": "latest" 41 | } 42 | } 43 | -------------------------------------------------------------------------------- /rollup.config.js: -------------------------------------------------------------------------------- 1 | import pkg from './package.json'; 2 | 3 | const name = pkg.name 4 | .replace(/^(@\S+\/)?(svelte-)?(\S+)/, '$3') 5 | .replace(/-\w/g, m => m[1].toUpperCase()); 6 | 7 | export default { 8 | input: 'src/index.js', 9 | output: [ 10 | { file: pkg.module, format: 'es' }, 11 | { file: pkg.main, 'format': 'umd', name } 12 | ] 13 | }; -------------------------------------------------------------------------------- /src/index.js: -------------------------------------------------------------------------------- 1 | import page from 'page'; 2 | 3 | export default class { 4 | 5 | constructor({ routes = [], hooks = [], ...options }) { 6 | 7 | this._routes = routes; 8 | this._hooks = hooks; 9 | this._options = options; 10 | 11 | this._before = null; 12 | this._enter = null; 13 | this._after = null; 14 | this._exit = null; 15 | 16 | page('*', (ctx, next) => { 17 | const qs = ctx.querystring ? ctx.querystring.replace('?', '').split('&') : []; 18 | ctx.query = qs.reduce((query, param) => { 19 | const [key, val] = param.split('='); 20 | query[key] = decodeURIComponent(val); 21 | return query; 22 | }, {}); 23 | 24 | Promise.all(this._hooks.map(p => p(ctx))).then(next); 25 | }); 26 | } 27 | 28 | base(path) { 29 | page.base(path); 30 | } 31 | 32 | strict(enable) { 33 | page.strict(enable); 34 | } 35 | 36 | before(callback) { 37 | typeof callback === 'function' && (this._before = callback); 38 | } 39 | 40 | enter(callback) { 41 | typeof callback === 'function' && (this._enter = callback); 42 | } 43 | 44 | after(callback) { 45 | typeof callback === 'function' && (this._after = callback); 46 | } 47 | 48 | exit(callback) { 49 | typeof callback === 'function' && (this._exit = callback); 50 | } 51 | 52 | start() { 53 | 54 | typeof this._before === 'function' && page('*', this._before); 55 | 56 | this._routes.forEach(({ path, before, after, exit, component }) => { 57 | 58 | const callbacks = []; 59 | 60 | typeof before === 'function' && callbacks.push(before); 61 | 62 | callbacks.push((ctx, next) => { 63 | typeof component === 'function' && (component = component(ctx)); 64 | ctx.handled = true; // it's important for redirects 65 | Promise.resolve(component).then(component => { 66 | (component.preload ? 67 | component.preload(ctx) : 68 | Promise.resolve() 69 | ).then((state = {}) => { 70 | Object.assign(ctx.state, state); 71 | ctx.save(); 72 | ctx.component = component.default || component; 73 | return next(); 74 | }); 75 | }); 76 | }); 77 | 78 | typeof this._enter === 'function' && callbacks.push(this._enter); 79 | typeof after === 'function' && callbacks.push(after); 80 | 81 | page(path, ...callbacks); 82 | 83 | typeof exit === 'function' && page.exit(path, exit); 84 | }); 85 | 86 | typeof this._after === 'function' && page('*', this._after); 87 | typeof this._exit === 'function' && page.exit('*', this._exit); 88 | 89 | page.start(this._options); 90 | } 91 | 92 | stop() { 93 | page.stop(); 94 | } 95 | 96 | show(...args) { 97 | page.show(...args); 98 | } 99 | 100 | redirect(...args) { 101 | page.redirect(...args); 102 | } 103 | 104 | back(...args) { 105 | page.back(...args); 106 | } 107 | } 108 | --------------------------------------------------------------------------------