├── angular-table ├── src │ ├── assets │ │ └── .gitkeep │ ├── app │ │ ├── app.component.css │ │ ├── app.module.ts │ │ ├── table-machine.ts │ │ ├── app.component.html │ │ └── app.component.ts │ ├── environments │ │ ├── environment.prod.ts │ │ └── environment.ts │ ├── styles.css │ ├── favicon.ico │ ├── tsconfig.app.json │ ├── tsconfig.spec.json │ ├── index.html │ ├── tslint.json │ ├── main.ts │ ├── test.ts │ ├── karma.conf.js │ └── polyfills.ts ├── .prettierrc.js ├── browserslist ├── tsconfig.json ├── .gitignore ├── README.md ├── package.json ├── tslint.json └── angular.json ├── react-table ├── src │ ├── index.css │ ├── react-app-env.d.ts │ ├── index.tsx │ ├── logo.svg │ ├── App.tsx │ └── serviceWorker.js ├── public │ ├── favicon.ico │ ├── manifest.json │ └── index.html ├── tsconfig.json ├── .gitignore ├── package.json └── README.md ├── vue-table ├── babel.config.js ├── public │ ├── favicon.ico │ └── index.html ├── src │ ├── main.js │ └── App.vue ├── README.md ├── .gitignore └── package.json ├── svelte-table ├── public │ ├── favicon.png │ ├── index.html │ ├── index.css │ └── index.js ├── src │ ├── main.js │ ├── useMachine.js │ └── App.svelte ├── .gitignore ├── package.json ├── README.md ├── rollup.config.js └── package-lock.json ├── package.json ├── scripts └── copy-xstate-table.js ├── .gitignore ├── README.md └── xstate-table ├── index.css └── index.js /angular-table/src/assets/.gitkeep: -------------------------------------------------------------------------------- 1 | -------------------------------------------------------------------------------- /angular-table/src/app/app.component.css: -------------------------------------------------------------------------------- 1 | -------------------------------------------------------------------------------- /react-table/src/index.css: -------------------------------------------------------------------------------- 1 | :root { 2 | --theme-color: #00b3e6; 3 | } 4 | -------------------------------------------------------------------------------- /react-table/src/react-app-env.d.ts: -------------------------------------------------------------------------------- 1 | /// 2 | -------------------------------------------------------------------------------- /vue-table/babel.config.js: -------------------------------------------------------------------------------- 1 | module.exports = { 2 | presets: [ 3 | '@vue/app' 4 | ], 5 | } 6 | -------------------------------------------------------------------------------- /angular-table/src/environments/environment.prod.ts: -------------------------------------------------------------------------------- 1 | export const environment = { 2 | production: true 3 | }; 4 | -------------------------------------------------------------------------------- /angular-table/src/styles.css: -------------------------------------------------------------------------------- 1 | @import "xstate-table"; 2 | 3 | :root { 4 | --theme-color: #b52e31; 5 | } 6 | -------------------------------------------------------------------------------- /vue-table/public/favicon.ico: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/timdeschryver/xstate-table/HEAD/vue-table/public/favicon.ico -------------------------------------------------------------------------------- /angular-table/src/favicon.ico: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/timdeschryver/xstate-table/HEAD/angular-table/src/favicon.ico -------------------------------------------------------------------------------- /react-table/public/favicon.ico: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/timdeschryver/xstate-table/HEAD/react-table/public/favicon.ico -------------------------------------------------------------------------------- /svelte-table/public/favicon.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/timdeschryver/xstate-table/HEAD/svelte-table/public/favicon.png -------------------------------------------------------------------------------- /angular-table/.prettierrc.js: -------------------------------------------------------------------------------- 1 | exports.module = { 2 | trailingComma: "all", 3 | tabWidth: 2, 4 | semi: false, 5 | singleQuote: true 6 | }; 7 | -------------------------------------------------------------------------------- /svelte-table/src/main.js: -------------------------------------------------------------------------------- 1 | import App from "./App.svelte"; 2 | 3 | const app = new App({ 4 | target: document.body 5 | }); 6 | 7 | export default app; 8 | -------------------------------------------------------------------------------- /vue-table/src/main.js: -------------------------------------------------------------------------------- 1 | import Vue from 'vue' 2 | import App from './App.vue' 3 | import 'xstate-table/index.css'; 4 | 5 | Vue.config.productionTip = false 6 | 7 | new Vue({ 8 | render: h => h(App), 9 | }).$mount('#app') 10 | -------------------------------------------------------------------------------- /angular-table/src/tsconfig.app.json: -------------------------------------------------------------------------------- 1 | { 2 | "extends": "../tsconfig.json", 3 | "compilerOptions": { 4 | "outDir": "../out-tsc/app", 5 | "types": [] 6 | }, 7 | "exclude": [ 8 | "test.ts", 9 | "**/*.spec.ts", 10 | ] 11 | } 12 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "xstate-table", 3 | "version": "1.0.0", 4 | "description": "", 5 | "main": "index.js", 6 | "scripts": { 7 | "copy": "node ./scripts/copy-xstate-table" 8 | }, 9 | "keywords": [], 10 | "author": "", 11 | "license": "ISC", 12 | "devDependencies": { 13 | "fs-extra": "^8.1.0" 14 | } 15 | } 16 | -------------------------------------------------------------------------------- /angular-table/src/app/app.module.ts: -------------------------------------------------------------------------------- 1 | import { BrowserModule } from "@angular/platform-browser"; 2 | import { NgModule } from "@angular/core"; 3 | 4 | import { AppComponent } from "./app.component"; 5 | 6 | @NgModule({ 7 | declarations: [AppComponent], 8 | imports: [BrowserModule], 9 | bootstrap: [AppComponent] 10 | }) 11 | export class AppModule {} 12 | -------------------------------------------------------------------------------- /angular-table/src/tsconfig.spec.json: -------------------------------------------------------------------------------- 1 | { 2 | "extends": "../tsconfig.json", 3 | "compilerOptions": { 4 | "outDir": "../out-tsc/spec", 5 | "types": [ 6 | "jasmine", 7 | "node" 8 | ] 9 | }, 10 | "files": [ 11 | "test.ts", 12 | "polyfills.ts" 13 | ], 14 | "include": [ 15 | "**/*.spec.ts", 16 | "**/*.d.ts" 17 | ] 18 | } 19 | -------------------------------------------------------------------------------- /angular-table/src/index.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | AngularTable 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | -------------------------------------------------------------------------------- /react-table/public/manifest.json: -------------------------------------------------------------------------------- 1 | { 2 | "short_name": "React App", 3 | "name": "Create React App Sample", 4 | "icons": [ 5 | { 6 | "src": "favicon.ico", 7 | "sizes": "64x64 32x32 24x24 16x16", 8 | "type": "image/x-icon" 9 | } 10 | ], 11 | "start_url": ".", 12 | "display": "standalone", 13 | "theme_color": "#000000", 14 | "background_color": "#ffffff" 15 | } 16 | -------------------------------------------------------------------------------- /angular-table/src/tslint.json: -------------------------------------------------------------------------------- 1 | { 2 | "extends": "../tslint.json", 3 | "rules": { 4 | "directive-selector": [ 5 | true, 6 | "attribute", 7 | "app", 8 | "camelCase" 9 | ], 10 | "component-selector": [ 11 | true, 12 | "element", 13 | "app", 14 | "kebab-case" 15 | ] 16 | } 17 | } 18 | -------------------------------------------------------------------------------- /angular-table/browserslist: -------------------------------------------------------------------------------- 1 | # This file is currently used by autoprefixer to adjust CSS to support the below specified browsers 2 | # For additional information regarding the format and rule options, please see: 3 | # https://github.com/browserslist/browserslist#queries 4 | # 5 | # For IE 9-11 support, please remove 'not' from the last line of the file and adjust as needed 6 | 7 | > 0.5% 8 | last 2 versions 9 | Firefox ESR 10 | not dead 11 | not IE 9-11 -------------------------------------------------------------------------------- /angular-table/src/main.ts: -------------------------------------------------------------------------------- 1 | import { enableProdMode } from '@angular/core'; 2 | import { platformBrowserDynamic } from '@angular/platform-browser-dynamic'; 3 | 4 | import { AppModule } from './app/app.module'; 5 | import { environment } from './environments/environment'; 6 | 7 | if (environment.production) { 8 | enableProdMode(); 9 | } 10 | 11 | platformBrowserDynamic().bootstrapModule(AppModule) 12 | .catch(err => console.error(err)); 13 | 14 | -------------------------------------------------------------------------------- /svelte-table/public/index.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 7 | Svelte app 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | -------------------------------------------------------------------------------- /vue-table/README.md: -------------------------------------------------------------------------------- 1 | # vue-table 2 | 3 | ## Project setup 4 | ``` 5 | yarn install 6 | ``` 7 | 8 | ### Compiles and hot-reloads for development 9 | ``` 10 | yarn run serve 11 | ``` 12 | 13 | ### Compiles and minifies for production 14 | ``` 15 | yarn run build 16 | ``` 17 | 18 | ### Run your tests 19 | ``` 20 | yarn run test 21 | ``` 22 | 23 | ### Lints and fixes files 24 | ``` 25 | yarn run lint 26 | ``` 27 | 28 | ### Customize configuration 29 | See [Configuration Reference](https://cli.vuejs.org/config/). 30 | -------------------------------------------------------------------------------- /react-table/src/index.tsx: -------------------------------------------------------------------------------- 1 | import React from 'react'; 2 | import ReactDOM from 'react-dom'; 3 | import 'xstate-table/index.css'; 4 | import './index.css'; 5 | import App from './App'; 6 | import * as serviceWorker from './serviceWorker'; 7 | 8 | ReactDOM.render(, document.getElementById('root')); 9 | 10 | // If you want your app to work offline and load faster, you can change 11 | // unregister() to register() below. Note this comes with some pitfalls. 12 | // Learn more about service workers: https://bit.ly/CRA-PWA 13 | serviceWorker.unregister(); 14 | -------------------------------------------------------------------------------- /angular-table/tsconfig.json: -------------------------------------------------------------------------------- 1 | { 2 | "compileOnSave": false, 3 | "compilerOptions": { 4 | "baseUrl": "./", 5 | "downlevelIteration": true, 6 | "importHelpers": true, 7 | "outDir": "./dist/out-tsc", 8 | "sourceMap": true, 9 | "declaration": false, 10 | "module": "esnext", 11 | "moduleResolution": "node", 12 | "emitDecoratorMetadata": true, 13 | "experimentalDecorators": true, 14 | "target": "es2015", 15 | "typeRoots": [ 16 | "node_modules/@types" 17 | ], 18 | "lib": [ 19 | "es2017", 20 | "dom" 21 | ] 22 | } 23 | } 24 | -------------------------------------------------------------------------------- /svelte-table/src/useMachine.js: -------------------------------------------------------------------------------- 1 | import { readable } from "svelte/store"; 2 | import { interpret } from "xstate"; 3 | 4 | export function useMachine(machine, options) { 5 | const service = interpret(machine, options); 6 | 7 | const store = readable(machine.initialState, set => { 8 | service.onTransition(state => { 9 | if (state.changed) { 10 | set(state); 11 | } 12 | }); 13 | 14 | service.start(); 15 | 16 | return () => { 17 | service.stop(); 18 | }; 19 | }); 20 | 21 | return { 22 | state: store, 23 | send: service.send 24 | }; 25 | } 26 | -------------------------------------------------------------------------------- /vue-table/public/index.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | vue-table 9 | 10 | 11 | 14 |
15 | 16 | 17 | 18 | -------------------------------------------------------------------------------- /react-table/tsconfig.json: -------------------------------------------------------------------------------- 1 | { 2 | "compilerOptions": { 3 | "target": "es5", 4 | "lib": [ 5 | "dom", 6 | "dom.iterable", 7 | "esnext" 8 | ], 9 | "allowJs": true, 10 | "skipLibCheck": true, 11 | "esModuleInterop": true, 12 | "allowSyntheticDefaultImports": true, 13 | "forceConsistentCasingInFileNames": true, 14 | "module": "esnext", 15 | "moduleResolution": "node", 16 | "resolveJsonModule": true, 17 | "isolatedModules": true, 18 | "noEmit": true, 19 | "jsx": "preserve", 20 | "strict": false, 21 | "downlevelIteration": true 22 | }, 23 | "include": [ 24 | "src" 25 | ] 26 | } 27 | -------------------------------------------------------------------------------- /scripts/copy-xstate-table.js: -------------------------------------------------------------------------------- 1 | var fs = require("fs-extra"); 2 | 3 | function copy(destination) { 4 | fs.copy('./xstate-table', `./${destination}-table/node_modules/xstate-table`, function (err) { 5 | if (err) return console.error(err) 6 | console.log(`✔ ${destination} copied`) 7 | }); 8 | } 9 | 10 | copy('angular') 11 | copy('react') 12 | copy('svelte') 13 | copy('vue') 14 | 15 | // make it myself easy here, don't want to extend the svelte builder to include the css needed for this demo 16 | // just copy xstate-table to the public folder 🤷‍♂️ 17 | fs.copy('./xstate-table/', `./svelte-table/public/`, function (err) { 18 | if (err) return console.error(err) 19 | console.log(`✔ xstate-table/index.css copied`) 20 | }); -------------------------------------------------------------------------------- /angular-table/src/test.ts: -------------------------------------------------------------------------------- 1 | // This file is required by karma.conf.js and loads recursively all the .spec and framework files 2 | 3 | import 'zone.js/dist/zone-testing'; 4 | import { getTestBed } from '@angular/core/testing'; 5 | import { 6 | BrowserDynamicTestingModule, 7 | platformBrowserDynamicTesting 8 | } from '@angular/platform-browser-dynamic/testing'; 9 | 10 | declare const require: any; 11 | 12 | // First, initialize the Angular testing environment. 13 | getTestBed().initTestEnvironment( 14 | BrowserDynamicTestingModule, 15 | platformBrowserDynamicTesting() 16 | ); 17 | // Then we find all the tests. 18 | const context = require.context('./', true, /\.spec\.ts$/); 19 | // And load the modules. 20 | context.keys().map(context); 21 | -------------------------------------------------------------------------------- /angular-table/src/environments/environment.ts: -------------------------------------------------------------------------------- 1 | // This file can be replaced during build by using the `fileReplacements` array. 2 | // `ng build --prod` replaces `environment.ts` with `environment.prod.ts`. 3 | // The list of file replacements can be found in `angular.json`. 4 | 5 | export const environment = { 6 | production: false 7 | }; 8 | 9 | /* 10 | * For easier debugging in development mode, you can import the following file 11 | * to ignore zone related error stack frames such as `zone.run`, `zoneDelegate.invokeTask`. 12 | * 13 | * This import should be commented out in production mode because it will have a negative impact 14 | * on performance if an error is thrown. 15 | */ 16 | // import 'zone.js/dist/zone-error'; // Included with Angular CLI. 17 | -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | # See http://help.github.com/ignore-files/ for more about ignoring files. 2 | 3 | public/bundle.* 4 | 5 | # dependencies 6 | /.pnp 7 | .pnp.js 8 | 9 | # production 10 | /build 11 | 12 | # misc 13 | .env.local 14 | .env.development.local 15 | .env.test.local 16 | .env.production.local 17 | 18 | # compiled output 19 | /dist 20 | /tmp 21 | /out-tsc 22 | 23 | # dependencies 24 | /node_modules 25 | 26 | # IDEs and editors 27 | /.idea 28 | .project 29 | .classpath 30 | .c9/ 31 | *.launch 32 | .settings/ 33 | *.sublime-workspace 34 | 35 | # IDE - VSCode 36 | .vscode/* 37 | !.vscode/settings.json 38 | !.vscode/tasks.json 39 | !.vscode/launch.json 40 | !.vscode/extensions.json 41 | 42 | # misc 43 | /.sass-cache 44 | /connect.lock 45 | /coverage 46 | /libpeerconnection.log 47 | npm-debug.log 48 | yarn-error.log 49 | testem.log 50 | /typings 51 | 52 | # System Files 53 | .DS_Store 54 | Thumbs.db 55 | -------------------------------------------------------------------------------- /vue-table/.gitignore: -------------------------------------------------------------------------------- 1 | # See http://help.github.com/ignore-files/ for more about ignoring files. 2 | 3 | public/bundle.* 4 | 5 | # dependencies 6 | /.pnp 7 | .pnp.js 8 | 9 | # production 10 | /build 11 | 12 | # misc 13 | .env.local 14 | .env.development.local 15 | .env.test.local 16 | .env.production.local 17 | 18 | # compiled output 19 | /dist 20 | /tmp 21 | /out-tsc 22 | 23 | # dependencies 24 | /node_modules 25 | 26 | # IDEs and editors 27 | /.idea 28 | .project 29 | .classpath 30 | .c9/ 31 | *.launch 32 | .settings/ 33 | *.sublime-workspace 34 | 35 | # IDE - VSCode 36 | .vscode/* 37 | !.vscode/settings.json 38 | !.vscode/tasks.json 39 | !.vscode/launch.json 40 | !.vscode/extensions.json 41 | 42 | # misc 43 | /.sass-cache 44 | /connect.lock 45 | /coverage 46 | /libpeerconnection.log 47 | npm-debug.log 48 | yarn-error.log 49 | testem.log 50 | /typings 51 | 52 | # System Files 53 | .DS_Store 54 | Thumbs.db 55 | -------------------------------------------------------------------------------- /angular-table/.gitignore: -------------------------------------------------------------------------------- 1 | # See http://help.github.com/ignore-files/ for more about ignoring files. 2 | 3 | public/bundle.* 4 | 5 | # dependencies 6 | /.pnp 7 | .pnp.js 8 | 9 | # production 10 | /build 11 | 12 | # misc 13 | .env.local 14 | .env.development.local 15 | .env.test.local 16 | .env.production.local 17 | 18 | # compiled output 19 | /dist 20 | /tmp 21 | /out-tsc 22 | 23 | # dependencies 24 | /node_modules 25 | 26 | # IDEs and editors 27 | /.idea 28 | .project 29 | .classpath 30 | .c9/ 31 | *.launch 32 | .settings/ 33 | *.sublime-workspace 34 | 35 | # IDE - VSCode 36 | .vscode/* 37 | !.vscode/settings.json 38 | !.vscode/tasks.json 39 | !.vscode/launch.json 40 | !.vscode/extensions.json 41 | 42 | # misc 43 | /.sass-cache 44 | /connect.lock 45 | /coverage 46 | /libpeerconnection.log 47 | npm-debug.log 48 | yarn-error.log 49 | testem.log 50 | /typings 51 | 52 | # System Files 53 | .DS_Store 54 | Thumbs.db 55 | -------------------------------------------------------------------------------- /react-table/.gitignore: -------------------------------------------------------------------------------- 1 | # See http://help.github.com/ignore-files/ for more about ignoring files. 2 | 3 | public/bundle.* 4 | 5 | # dependencies 6 | /.pnp 7 | .pnp.js 8 | 9 | # production 10 | /build 11 | 12 | # misc 13 | .env.local 14 | .env.development.local 15 | .env.test.local 16 | .env.production.local 17 | 18 | # compiled output 19 | /dist 20 | /tmp 21 | /out-tsc 22 | 23 | # dependencies 24 | /node_modules 25 | 26 | # IDEs and editors 27 | /.idea 28 | .project 29 | .classpath 30 | .c9/ 31 | *.launch 32 | .settings/ 33 | *.sublime-workspace 34 | 35 | # IDE - VSCode 36 | .vscode/* 37 | !.vscode/settings.json 38 | !.vscode/tasks.json 39 | !.vscode/launch.json 40 | !.vscode/extensions.json 41 | 42 | # misc 43 | /.sass-cache 44 | /connect.lock 45 | /coverage 46 | /libpeerconnection.log 47 | npm-debug.log 48 | yarn-error.log 49 | testem.log 50 | /typings 51 | 52 | # System Files 53 | .DS_Store 54 | Thumbs.db 55 | -------------------------------------------------------------------------------- /svelte-table/.gitignore: -------------------------------------------------------------------------------- 1 | # See http://help.github.com/ignore-files/ for more about ignoring files. 2 | 3 | public/bundle.* 4 | 5 | # dependencies 6 | /.pnp 7 | .pnp.js 8 | 9 | # production 10 | /build 11 | 12 | # misc 13 | .env.local 14 | .env.development.local 15 | .env.test.local 16 | .env.production.local 17 | 18 | # compiled output 19 | /dist 20 | /tmp 21 | /out-tsc 22 | 23 | # dependencies 24 | /node_modules 25 | 26 | # IDEs and editors 27 | /.idea 28 | .project 29 | .classpath 30 | .c9/ 31 | *.launch 32 | .settings/ 33 | *.sublime-workspace 34 | 35 | # IDE - VSCode 36 | .vscode/* 37 | !.vscode/settings.json 38 | !.vscode/tasks.json 39 | !.vscode/launch.json 40 | !.vscode/extensions.json 41 | 42 | # misc 43 | /.sass-cache 44 | /connect.lock 45 | /coverage 46 | /libpeerconnection.log 47 | npm-debug.log 48 | yarn-error.log 49 | testem.log 50 | /typings 51 | 52 | # System Files 53 | .DS_Store 54 | Thumbs.db 55 | -------------------------------------------------------------------------------- /angular-table/src/app/table-machine.ts: -------------------------------------------------------------------------------- 1 | import { Injectable, OnDestroy } from "@angular/core"; 2 | import { interpret, Interpreter, Machine, StateMachine } from "xstate"; 3 | import { fromEventPattern, Subject, Observable, Subscription } from "rxjs"; 4 | 5 | @Injectable() 6 | export class TableMachine implements OnDestroy { 7 | subs = new Subscription(); 8 | actions$ = new Subject(); 9 | state$: Observable; 10 | 11 | private service: Interpreter; 12 | 13 | setupMachine(machine: StateMachine) { 14 | this.service = interpret(machine); 15 | 16 | this.state$ = fromEventPattern( 17 | (handler: any) => { 18 | this.service.onTransition(handler).start(); 19 | 20 | return this.service; 21 | }, 22 | (handler, service) => service.stop() 23 | ); 24 | 25 | this.subs.add(this.actions$.subscribe(this.service.send)); 26 | } 27 | 28 | ngOnDestroy() { 29 | this.subs.unsubscribe(); 30 | } 31 | } 32 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # XState-table 2 | 3 | An experiment to create a table with behavior and to be able to re-use the code across frameworks. 4 | Every framework has its own template language, but the behavior code can be shared because it's using XState. 5 | 6 | The table can: 7 | 8 | - single select 9 | - multiple select with ctrl 10 | - select range with shift 11 | - select multiple ranges with ctrl+shift 12 | - multiple select via drag 13 | - disable action buttons based on selection 14 | 15 | ## Examples 16 | 17 | - [Angular](https://stackblitz.com/edit/xstate-angular-table) 18 | - [React](https://codesandbox.io/s/1dtmk) 19 | - [Svelte](https://codesandbox.io/s/yb6lq) 20 | - [Vue](https://codesandbox.io/s/707t4) 21 | 22 | ## This repository 23 | 24 | To run the code for a framework: 25 | 26 | - first install the dependencies (with `npm install` or `yarn`) in the root folder (this step is needed to copy the `xstate-table` code) 27 | - move to the specific folder and install the dependencies 28 | -------------------------------------------------------------------------------- /react-table/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "react-table", 3 | "version": "0.1.0", 4 | "private": true, 5 | "dependencies": { 6 | "@types/jest": "^24.0.15", 7 | "@types/node": "^12.0.10", 8 | "@types/react": "^16.8.22", 9 | "@types/react-dom": "^16.8.4", 10 | "@xstate/react": "^0.7.0", 11 | "faker": "^4.1.0", 12 | "react": "^16.8.6", 13 | "react-dom": "^16.8.6", 14 | "react-scripts": "3.0.1", 15 | "typescript": "^3.5.2", 16 | "xstate": "^4.6.3" 17 | }, 18 | "scripts": { 19 | "start": "react-scripts start", 20 | "build": "react-scripts build", 21 | "test": "react-scripts test", 22 | "eject": "react-scripts eject", 23 | "postinstall": "cd .. && npm run copy" 24 | }, 25 | "eslintConfig": { 26 | "extends": "react-app" 27 | }, 28 | "browserslist": { 29 | "production": [ 30 | ">0.2%", 31 | "not dead", 32 | "not op_mini all" 33 | ], 34 | "development": [ 35 | "last 1 chrome version", 36 | "last 1 firefox version", 37 | "last 1 safari version" 38 | ] 39 | } 40 | } 41 | -------------------------------------------------------------------------------- /angular-table/src/karma.conf.js: -------------------------------------------------------------------------------- 1 | // Karma configuration file, see link for more information 2 | // https://karma-runner.github.io/1.0/config/configuration-file.html 3 | 4 | module.exports = function (config) { 5 | config.set({ 6 | basePath: '', 7 | frameworks: ['jasmine', '@angular-devkit/build-angular'], 8 | plugins: [ 9 | require('karma-jasmine'), 10 | require('karma-chrome-launcher'), 11 | require('karma-jasmine-html-reporter'), 12 | require('karma-coverage-istanbul-reporter'), 13 | require('@angular-devkit/build-angular/plugins/karma') 14 | ], 15 | client: { 16 | clearContext: false // leave Jasmine Spec Runner output visible in browser 17 | }, 18 | coverageIstanbulReporter: { 19 | dir: require('path').join(__dirname, '../coverage'), 20 | reports: ['html', 'lcovonly'], 21 | fixWebpackSourcePaths: true 22 | }, 23 | reporters: ['progress', 'kjhtml'], 24 | port: 9876, 25 | colors: true, 26 | logLevel: config.LOG_INFO, 27 | autoWatch: true, 28 | browsers: ['Chrome'], 29 | singleRun: false 30 | }); 31 | }; -------------------------------------------------------------------------------- /svelte-table/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "svelte-app", 3 | "version": "1.0.0", 4 | "devDependencies": { 5 | "@types/faker": "^4.1.5", 6 | "eslint": "^6.0.1", 7 | "eslint-config-prettier": "^6.0.0", 8 | "eslint-plugin-prettier": "^3.1.0", 9 | "eslint-plugin-svelte3": "^2.2.2", 10 | "npm-run-all": "^4.1.5", 11 | "prettier": "^1.18.2", 12 | "rollup": "^1.10.1", 13 | "rollup-plugin-commonjs": "^9.3.4", 14 | "rollup-plugin-livereload": "^1.0.0", 15 | "rollup-plugin-node-resolve": "^4.2.3", 16 | "rollup-plugin-replace": "^2.2.0", 17 | "rollup-plugin-svelte": "^5.0.3", 18 | "rollup-plugin-terser": "^4.0.4", 19 | "svelte": "^3.0.0" 20 | }, 21 | "dependencies": { 22 | "faker": "^4.1.0", 23 | "sirv-cli": "^0.4.4", 24 | "xstate": "^4.6.3" 25 | }, 26 | "scripts": { 27 | "build": "rollup -c", 28 | "autobuild": "rollup -c -w", 29 | "dev": "run-p start:dev autobuild", 30 | "start": "sirv public --single", 31 | "start:dev": "sirv public --single --dev", 32 | "lint": "eslint --ext js,svelte src", 33 | "postinstall": "cd .. && npm run copy" 34 | } 35 | } 36 | -------------------------------------------------------------------------------- /angular-table/README.md: -------------------------------------------------------------------------------- 1 | # AngularTable 2 | 3 | This project was generated with [Angular CLI](https://github.com/angular/angular-cli) version 6.2.5. 4 | 5 | ## Development server 6 | 7 | Run `ng serve` for a dev server. Navigate to `http://localhost:4200/`. The app will automatically reload if you change any of the source files. 8 | 9 | ## Code scaffolding 10 | 11 | Run `ng generate component component-name` to generate a new component. You can also use `ng generate directive|pipe|service|class|guard|interface|enum|module`. 12 | 13 | ## Build 14 | 15 | Run `ng build` to build the project. The build artifacts will be stored in the `dist/` directory. Use the `--prod` flag for a production build. 16 | 17 | ## Running unit tests 18 | 19 | Run `ng test` to execute the unit tests via [Karma](https://karma-runner.github.io). 20 | 21 | ## Running end-to-end tests 22 | 23 | Run `ng e2e` to execute the end-to-end tests via [Protractor](http://www.protractortest.org/). 24 | 25 | ## Further help 26 | 27 | To get more help on the Angular CLI use `ng help` or go check out the [Angular CLI README](https://github.com/angular/angular-cli/blob/master/README.md). 28 | -------------------------------------------------------------------------------- /angular-table/src/app/app.component.html: -------------------------------------------------------------------------------- 1 |
5 |
6 |
7 | 8 | 11 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 32 | 33 | 34 | 35 | 36 | 37 | 38 |
IdNameAddressEmail
{{ row.id }}{{ row.name }}{{ row.address }}{{ row.email }}
39 |
40 |
41 | -------------------------------------------------------------------------------- /vue-table/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "vue-table", 3 | "version": "0.1.0", 4 | "private": true, 5 | "scripts": { 6 | "serve": "vue-cli-service serve", 7 | "build": "vue-cli-service build", 8 | "lint": "vue-cli-service lint", 9 | "postinstall": "cd .. && npm run copy" 10 | }, 11 | "dependencies": { 12 | "core-js": "^2.6.5", 13 | "css-loader": "^3.0.0", 14 | "faker": "^4.1.0", 15 | "node-sass": "^4.12.0", 16 | "sass-loader": "^7.1.0", 17 | "vue": "^2.6.10", 18 | "xstate": "^4.6.4" 19 | }, 20 | "devDependencies": { 21 | "@vue/cli-plugin-babel": "^3.9.0", 22 | "@vue/cli-plugin-eslint": "^3.9.0", 23 | "@vue/cli-service": "^3.9.0", 24 | "babel-eslint": "^10.0.1", 25 | "eslint": "^5.16.0", 26 | "eslint-plugin-vue": "^5.0.0", 27 | "vue-template-compiler": "^2.6.10" 28 | }, 29 | "eslintConfig": { 30 | "root": true, 31 | "env": { 32 | "node": true 33 | }, 34 | "extends": [ 35 | "plugin:vue/essential", 36 | "eslint:recommended" 37 | ], 38 | "rules": {}, 39 | "parserOptions": { 40 | "parser": "babel-eslint" 41 | } 42 | }, 43 | "postcss": { 44 | "plugins": { 45 | "autoprefixer": {} 46 | } 47 | }, 48 | "browserslist": [ 49 | "> 1%", 50 | "last 2 versions" 51 | ] 52 | } 53 | -------------------------------------------------------------------------------- /angular-table/src/polyfills.ts: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | /** 5 | * Web Animations `@angular/platform-browser/animations` 6 | * Only required if AnimationBuilder is used within the application and using IE/Edge or Safari. 7 | * Standard animation support in Angular DOES NOT require any polyfills (as of Angular 6.0). 8 | **/ 9 | // import 'web-animations-js'; // Run `npm install --save web-animations-js`. 10 | 11 | /** 12 | * By default, zone.js will patch all possible macroTask and DomEvents 13 | * user can disable parts of macroTask/DomEvents patch by setting following flags 14 | */ 15 | 16 | // (window as any).__Zone_disable_requestAnimationFrame = true; // disable patch requestAnimationFrame 17 | // (window as any).__Zone_disable_on_property = true; // disable patch onProperty such as onclick 18 | // (window as any).__zone_symbol__BLACK_LISTED_EVENTS = ['scroll', 'mousemove']; // disable patch specified eventNames 19 | 20 | /* 21 | * in IE/Edge developer tools, the addEventListener will also be wrapped by zone.js 22 | * with the following flag, it will bypass `zone.js` patch for IE/Edge 23 | */ 24 | // (window as any).__Zone_enable_cross_context_check = true; 25 | 26 | /*************************************************************************************************** 27 | * Zone JS is required by default for Angular itself. 28 | */ 29 | import 'zone.js/dist/zone'; // Included with Angular CLI. 30 | 31 | 32 | 33 | /*************************************************************************************************** 34 | * APPLICATION IMPORTS 35 | */ 36 | -------------------------------------------------------------------------------- /angular-table/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "angular-table", 3 | "version": "0.0.0", 4 | "scripts": { 5 | "ng": "ng", 6 | "start": "ng serve", 7 | "build": "ng build", 8 | "test": "ng test", 9 | "lint": "ng lint", 10 | "e2e": "ng e2e", 11 | "postinstall": "cd .. && npm run copy" 12 | }, 13 | "private": true, 14 | "dependencies": { 15 | "@angular/animations": "^8.0.3", 16 | "@angular/common": "^8.0.3", 17 | "@angular/compiler": "^8.0.3", 18 | "@angular/core": "^8.0.3", 19 | "@angular/forms": "^8.0.3", 20 | "@angular/platform-browser": "^8.0.3", 21 | "@angular/platform-browser-dynamic": "^8.0.3", 22 | "@angular/router": "^8.0.3", 23 | "core-js": "^2.5.4", 24 | "faker": "^4.1.0", 25 | "rxjs": "~6.5.2", 26 | "tslib": "^1.9.0", 27 | "xstate": "^4.6.3", 28 | "zone.js": "~0.9.1" 29 | }, 30 | "devDependencies": { 31 | "@angular-devkit/build-angular": "~0.800.6", 32 | "@angular/cli": "~8.0.6", 33 | "@angular/compiler-cli": "^8.0.3", 34 | "@angular/language-service": "^8.0.3", 35 | "@types/jasmine": "~2.8.8", 36 | "@types/jasminewd2": "~2.0.3", 37 | "@types/node": "~8.9.4", 38 | "codelyzer": "^5.0.1", 39 | "jasmine-core": "~2.99.1", 40 | "jasmine-spec-reporter": "~4.2.1", 41 | "karma": "~3.0.0", 42 | "karma-chrome-launcher": "~2.2.0", 43 | "karma-coverage-istanbul-reporter": "~2.0.1", 44 | "karma-jasmine": "~1.1.2", 45 | "karma-jasmine-html-reporter": "^0.2.2", 46 | "protractor": "~5.4.0", 47 | "ts-node": "~7.0.0", 48 | "tslint": "~5.11.0", 49 | "typescript": "~3.4.5" 50 | } 51 | } 52 | -------------------------------------------------------------------------------- /svelte-table/README.md: -------------------------------------------------------------------------------- 1 | *Psst — looking for a shareable component template? Go here --> [sveltejs/component-template](https://github.com/sveltejs/component-template)* 2 | 3 | --- 4 | 5 | # svelte app 6 | 7 | This is a project template for [Svelte](https://svelte.dev) apps. It lives at https://github.com/sveltejs/template. 8 | 9 | To create a new project based on this template using [degit](https://github.com/Rich-Harris/degit): 10 | 11 | ```bash 12 | npx degit sveltejs/template svelte-app 13 | cd svelte-app 14 | ``` 15 | 16 | *Note that you will need to have [Node.js](https://nodejs.org) installed.* 17 | 18 | 19 | ## Get started 20 | 21 | Install the dependencies... 22 | 23 | ```bash 24 | cd svelte-app 25 | npm install 26 | ``` 27 | 28 | ...then start [Rollup](https://rollupjs.org): 29 | 30 | ```bash 31 | npm run dev 32 | ``` 33 | 34 | Navigate to [localhost:5000](http://localhost:5000). You should see your app running. Edit a component file in `src`, save it, and reload the page to see your changes. 35 | 36 | 37 | ## Deploying to the web 38 | 39 | ### With [now](https://zeit.co/now) 40 | 41 | Install `now` if you haven't already: 42 | 43 | ```bash 44 | npm install -g now 45 | ``` 46 | 47 | Then, from within your project folder: 48 | 49 | ```bash 50 | now 51 | ``` 52 | 53 | As an alternative, use the [Now desktop client](https://zeit.co/download) and simply drag the unzipped project folder to the taskbar icon. 54 | 55 | ### With [surge](https://surge.sh/) 56 | 57 | Install `surge` if you haven't already: 58 | 59 | ```bash 60 | npm install -g surge 61 | ``` 62 | 63 | Then, from within your project folder: 64 | 65 | ```bash 66 | npm run build 67 | surge public 68 | ``` 69 | -------------------------------------------------------------------------------- /svelte-table/rollup.config.js: -------------------------------------------------------------------------------- 1 | import svelte from "rollup-plugin-svelte"; 2 | import resolve from "rollup-plugin-node-resolve"; 3 | import commonjs from "rollup-plugin-commonjs"; 4 | import livereload from "rollup-plugin-livereload"; 5 | import replace from "rollup-plugin-replace"; 6 | import { terser } from "rollup-plugin-terser"; 7 | 8 | const production = !process.env.ROLLUP_WATCH; 9 | 10 | export default { 11 | input: "src/main.js", 12 | output: { 13 | sourcemap: true, 14 | format: "iife", 15 | name: "app", 16 | file: "public/bundle.js" 17 | }, 18 | plugins: [ 19 | svelte({ 20 | // enable run-time checks when not in production 21 | dev: !production, 22 | // we'll extract any component CSS out into 23 | // a separate file — better for performance 24 | css: css => { 25 | css.write("public/bundle.css"); 26 | } 27 | }), 28 | 29 | // If you have external dependencies installed from 30 | // npm, you'll most likely need these plugins. In 31 | // some cases you'll need additional configuration — 32 | // consult the documentation for details: 33 | // https://github.com/rollup/rollup-plugin-commonjs 34 | resolve({ browser: true }), 35 | commonjs(), 36 | 37 | replace({ 38 | "process.env.NODE_ENV": JSON.stringify("production") 39 | }), 40 | 41 | // Watch the `public` directory and refresh the 42 | // browser on changes when not in production 43 | !production && livereload("public"), 44 | 45 | // If we're building for production (npm run build 46 | // instead of npm run dev), minify 47 | production && terser() 48 | ], 49 | watch: { 50 | clearScreen: false 51 | } 52 | }; 53 | -------------------------------------------------------------------------------- /react-table/public/index.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 12 | 13 | 22 | React App 23 | 24 | 25 | 26 |
27 | 37 | 38 | 39 | -------------------------------------------------------------------------------- /angular-table/src/app/app.component.ts: -------------------------------------------------------------------------------- 1 | import { 2 | Component, 3 | HostListener, 4 | ViewChildren, 5 | QueryList, 6 | ElementRef, 7 | OnInit 8 | } from "@angular/core"; 9 | import { tableMachine, findElementsInSelectArea } from "xstate-table"; 10 | import faker from "faker"; 11 | import { TableMachine } from "./table-machine"; 12 | 13 | @Component({ 14 | selector: "app-root", 15 | templateUrl: "./app.component.html", 16 | styleUrls: ["./app.component.css"], 17 | providers: [TableMachine] 18 | }) 19 | export class AppComponent implements OnInit { 20 | title = "angular-table"; 21 | 22 | @ViewChildren("rows", { read: ElementRef }) rows: QueryList; 23 | 24 | constructor(public machine: TableMachine) {} 25 | 26 | ngOnInit() { 27 | this.machine.setupMachine( 28 | tableMachine.withConfig( 29 | {}, 30 | { 31 | rows: Array.from({ length: 100 }, (_, i) => ({ 32 | id: i + 10000, 33 | name: faker.name.findName(), 34 | address: faker.address.streetAddress(), 35 | email: faker.internet.email() 36 | })), 37 | selectedIds: [10002], 38 | delay: 300, 39 | findElementsInSelectArea: (ctx, selectArea) => 40 | findElementsInSelectArea(ctx, selectArea, () => 41 | this.rows.toArray().map(r => r.nativeElement) 42 | ) 43 | } 44 | ) 45 | ); 46 | } 47 | 48 | rowClick(evt, id) { 49 | this.machine.actions$.next({ type: evt.type, evt, id }); 50 | } 51 | 52 | @HostListener("body:mousedown", ["$event"]) 53 | @HostListener("body:mousemove", ["$event"]) 54 | @HostListener("body:mouseup", ["$event"]) 55 | mouse(evt: MouseEvent) { 56 | this.machine.actions$.next({ type: evt.type, evt }); 57 | } 58 | } 59 | -------------------------------------------------------------------------------- /svelte-table/src/App.svelte: -------------------------------------------------------------------------------- 1 | 26 | 27 | 32 | 33 | send({type: evt.type, evt})} 35 | on:mousemove={(evt) => send({type: evt.type, evt})} 36 | on:mouseup={(evt) => send({type: evt.type, evt})} 37 | /> 38 | 39 |
40 |
41 | 42 |
43 | 44 | 45 | 46 | 47 | 48 | 49 | 50 | 51 | 52 | 53 | 54 | 55 | 56 | 57 | {#each context.rows as row, index} 58 | send({type: evt.type, evt, id: row.id})} 61 | class:selected={context.selectedIds.includes(row.id)}> 62 | 63 | 64 | 65 | 66 | 67 | {/each} 68 | 69 |
IdNameAddressEmail
{row.id}{row.name}{row.address}{row.email}
70 |
71 |
-------------------------------------------------------------------------------- /xstate-table/index.css: -------------------------------------------------------------------------------- 1 | :root { 2 | --mouse-x1: 0px; 3 | --mouse-y1: 0px; 4 | --mouse-x2: 0px; 5 | --mouse-y2: 0px; 6 | } 7 | 8 | html, 9 | body { 10 | position: relative; 11 | width: 100%; 12 | height: 100%; 13 | user-select: none; 14 | } 15 | 16 | body { 17 | color: #333; 18 | margin: 0; 19 | padding: 13px 47px; 20 | box-sizing: border-box; 21 | background: var(--theme-color, rgba(239, 212, 3, 1)); 22 | } 23 | 24 | button { 25 | font-family: inherit; 26 | font-size: inherit; 27 | padding: 0.4em; 28 | margin: 0 0 0.5em 0; 29 | box-sizing: border-box; 30 | border-radius: 2px; 31 | background-color: rgba(0, 0, 0, 0.2); 32 | color: rgba(255, 255, 255, 0.8); 33 | border: 1px solid currentColor; 34 | } 35 | 36 | button:active { 37 | background-color: rgba(0, 0, 0, 0); 38 | } 39 | 40 | button:focus { 41 | background-color: rgba(0, 0, 0, 0.4); 42 | } 43 | 44 | button[disabled] { 45 | background-color: rgba(0, 0, 0, 0.6); 46 | } 47 | 48 | .selectbox { 49 | color: rgba(255, 255, 255, 0.5); 50 | background: rgba(0, 0, 0, 0.1); 51 | border: 2px solid currentColor; 52 | position: absolute; 53 | left: calc(var(--mouse-x1)); 54 | top: calc(var(--mouse-y1)); 55 | width: calc((var(--mouse-x2) - var(--mouse-x1))); 56 | height: calc((var(--mouse-y2) - var(--mouse-y1))); 57 | transition: opacity 0.3s ease-in-out; 58 | z-index: 3; 59 | opacity: 0; 60 | } 61 | 62 | [data-state*="state.dragging"] .selectbox { 63 | opacity: 1; 64 | } 65 | 66 | table { 67 | width: 100%; 68 | text-align: left; 69 | border-collapse: collapse; 70 | } 71 | 72 | tr { 73 | border: 1px solid transparent; 74 | } 75 | 76 | th, 77 | td { 78 | padding: 15px; 79 | } 80 | 81 | tbody tr:nth-child(odd) { 82 | background-color: rgba(255, 255, 255, 0.4); 83 | } 84 | 85 | tbody tr:nth-child(even) { 86 | background-color: rgba(255, 255, 255, 0.6); 87 | } 88 | 89 | thead tr { 90 | background-color: rgba(0, 0, 0, 0.2); 91 | color: rgba(255, 255, 255, 0.8); 92 | text-transform: uppercase; 93 | font-weight: bold; 94 | } 95 | 96 | tbody tr.selected { 97 | transition: all 300ms; 98 | background-color: rgba(255, 255, 255, 0.1); 99 | box-shadow: 5px 5px 5px 0px rgba(0, 0, 0, 0.3); 100 | } 101 | -------------------------------------------------------------------------------- /svelte-table/public/index.css: -------------------------------------------------------------------------------- 1 | :root { 2 | --mouse-x1: 0px; 3 | --mouse-y1: 0px; 4 | --mouse-x2: 0px; 5 | --mouse-y2: 0px; 6 | } 7 | 8 | html, 9 | body { 10 | position: relative; 11 | width: 100%; 12 | height: 100%; 13 | user-select: none; 14 | } 15 | 16 | body { 17 | color: #333; 18 | margin: 0; 19 | padding: 13px 47px; 20 | box-sizing: border-box; 21 | background: var(--theme-color, rgba(239, 212, 3, 1)); 22 | } 23 | 24 | button { 25 | font-family: inherit; 26 | font-size: inherit; 27 | padding: 0.4em; 28 | margin: 0 0 0.5em 0; 29 | box-sizing: border-box; 30 | border-radius: 2px; 31 | background-color: rgba(0, 0, 0, 0.2); 32 | color: rgba(255, 255, 255, 0.8); 33 | border: 1px solid currentColor; 34 | } 35 | 36 | button:active { 37 | background-color: rgba(0, 0, 0, 0); 38 | } 39 | 40 | button:focus { 41 | background-color: rgba(0, 0, 0, 0.4); 42 | } 43 | 44 | button[disabled] { 45 | background-color: rgba(0, 0, 0, 0.6); 46 | } 47 | 48 | .selectbox { 49 | color: rgba(255, 255, 255, 0.5); 50 | background: rgba(0, 0, 0, 0.1); 51 | border: 2px solid currentColor; 52 | position: absolute; 53 | left: calc(var(--mouse-x1)); 54 | top: calc(var(--mouse-y1)); 55 | width: calc((var(--mouse-x2) - var(--mouse-x1))); 56 | height: calc((var(--mouse-y2) - var(--mouse-y1))); 57 | transition: opacity 0.3s ease-in-out; 58 | z-index: 3; 59 | opacity: 0; 60 | } 61 | 62 | [data-state*="state.dragging"] .selectbox { 63 | opacity: 1; 64 | } 65 | 66 | table { 67 | width: 100%; 68 | text-align: left; 69 | border-collapse: collapse; 70 | } 71 | 72 | tr { 73 | border: 1px solid transparent; 74 | } 75 | 76 | th, 77 | td { 78 | padding: 15px; 79 | } 80 | 81 | tbody tr:nth-child(odd) { 82 | background-color: rgba(255, 255, 255, 0.4); 83 | } 84 | 85 | tbody tr:nth-child(even) { 86 | background-color: rgba(255, 255, 255, 0.6); 87 | } 88 | 89 | thead tr { 90 | background-color: rgba(0, 0, 0, 0.2); 91 | color: rgba(255, 255, 255, 0.8); 92 | text-transform: uppercase; 93 | font-weight: bold; 94 | } 95 | 96 | tbody tr.selected { 97 | transition: all 300ms; 98 | background-color: rgba(255, 255, 255, 0.1); 99 | box-shadow: 5px 5px 5px 0px rgba(0, 0, 0, 0.3); 100 | } 101 | -------------------------------------------------------------------------------- /react-table/src/logo.svg: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | -------------------------------------------------------------------------------- /angular-table/tslint.json: -------------------------------------------------------------------------------- 1 | { 2 | "rulesDirectory": ["node_modules/codelyzer"], 3 | "rules": { 4 | "arrow-return-shorthand": true, 5 | "callable-types": true, 6 | "class-name": true, 7 | "comment-format": [true, "check-space"], 8 | "curly": true, 9 | "deprecation": { 10 | "severity": "warn" 11 | }, 12 | "eofline": true, 13 | "forin": true, 14 | "import-blacklist": [true, "rxjs/Rx"], 15 | "import-spacing": true, 16 | "indent": [true, "spaces"], 17 | "interface-over-type-literal": true, 18 | "label-position": true, 19 | "max-line-length": [true, 140], 20 | "member-access": false, 21 | "member-ordering": [ 22 | true, 23 | { 24 | "order": [ 25 | "static-field", 26 | "instance-field", 27 | "static-method", 28 | "instance-method" 29 | ] 30 | } 31 | ], 32 | "no-arg": true, 33 | "no-bitwise": true, 34 | "no-console": [true, "debug", "info", "time", "timeEnd", "trace"], 35 | "no-construct": true, 36 | "no-debugger": true, 37 | "no-duplicate-super": true, 38 | "no-empty": false, 39 | "no-empty-interface": true, 40 | "no-eval": true, 41 | "no-inferrable-types": [true, "ignore-params"], 42 | "no-misused-new": true, 43 | "no-non-null-assertion": true, 44 | "no-redundant-jsdoc": true, 45 | "no-shadowed-variable": true, 46 | "no-string-literal": false, 47 | "no-string-throw": true, 48 | "no-switch-case-fall-through": true, 49 | "no-trailing-whitespace": true, 50 | "no-unnecessary-initializer": true, 51 | "no-unused-expression": true, 52 | "no-use-before-declare": true, 53 | "no-var-keyword": true, 54 | "object-literal-sort-keys": false, 55 | "one-line": [ 56 | true, 57 | "check-open-brace", 58 | "check-catch", 59 | "check-else", 60 | "check-whitespace" 61 | ], 62 | "prefer-const": true, 63 | "radix": true, 64 | "semicolon": [true, "always"], 65 | "triple-equals": [true, "allow-null-check"], 66 | "typedef-whitespace": [ 67 | true, 68 | { 69 | "call-signature": "nospace", 70 | "index-signature": "nospace", 71 | "parameter": "nospace", 72 | "property-declaration": "nospace", 73 | "variable-declaration": "nospace" 74 | } 75 | ], 76 | "unified-signatures": true, 77 | "variable-name": false, 78 | "whitespace": [ 79 | true, 80 | "check-branch", 81 | "check-decl", 82 | "check-operator", 83 | "check-separator", 84 | "check-type" 85 | ], 86 | "no-output-on-prefix": true, 87 | "no-inputs-metadata-property": true, 88 | "no-outputs-metadata-property": true, 89 | "no-host-metadata-property": true, 90 | "no-input-rename": true, 91 | "no-output-rename": true, 92 | "use-lifecycle-interface": true, 93 | "use-pipe-transform-interface": true, 94 | "component-class-suffix": true, 95 | "directive-class-suffix": true 96 | } 97 | } 98 | -------------------------------------------------------------------------------- /vue-table/src/App.vue: -------------------------------------------------------------------------------- 1 | 40 | 41 | 95 | 96 | 101 | -------------------------------------------------------------------------------- /react-table/README.md: -------------------------------------------------------------------------------- 1 | This project was bootstrapped with [Create React App](https://github.com/facebook/create-react-app). 2 | 3 | ## Available Scripts 4 | 5 | In the project directory, you can run: 6 | 7 | ### `npm start` 8 | 9 | Runs the app in the development mode.
10 | Open [http://localhost:3000](http://localhost:3000) to view it in the browser. 11 | 12 | The page will reload if you make edits.
13 | You will also see any lint errors in the console. 14 | 15 | ### `npm test` 16 | 17 | Launches the test runner in the interactive watch mode.
18 | See the section about [running tests](https://facebook.github.io/create-react-app/docs/running-tests) for more information. 19 | 20 | ### `npm run build` 21 | 22 | Builds the app for production to the `build` folder.
23 | It correctly bundles React in production mode and optimizes the build for the best performance. 24 | 25 | The build is minified and the filenames include the hashes.
26 | Your app is ready to be deployed! 27 | 28 | See the section about [deployment](https://facebook.github.io/create-react-app/docs/deployment) for more information. 29 | 30 | ### `npm run eject` 31 | 32 | **Note: this is a one-way operation. Once you `eject`, you can’t go back!** 33 | 34 | If you aren’t satisfied with the build tool and configuration choices, you can `eject` at any time. This command will remove the single build dependency from your project. 35 | 36 | Instead, it will copy all the configuration files and the transitive dependencies (Webpack, Babel, ESLint, etc) right into your project so you have full control over them. All of the commands except `eject` will still work, but they will point to the copied scripts so you can tweak them. At this point you’re on your own. 37 | 38 | You don’t have to ever use `eject`. The curated feature set is suitable for small and middle deployments, and you shouldn’t feel obligated to use this feature. However we understand that this tool wouldn’t be useful if you couldn’t customize it when you are ready for it. 39 | 40 | ## Learn More 41 | 42 | You can learn more in the [Create React App documentation](https://facebook.github.io/create-react-app/docs/getting-started). 43 | 44 | To learn React, check out the [React documentation](https://reactjs.org/). 45 | 46 | ### Code Splitting 47 | 48 | This section has moved here: https://facebook.github.io/create-react-app/docs/code-splitting 49 | 50 | ### Analyzing the Bundle Size 51 | 52 | This section has moved here: https://facebook.github.io/create-react-app/docs/analyzing-the-bundle-size 53 | 54 | ### Making a Progressive Web App 55 | 56 | This section has moved here: https://facebook.github.io/create-react-app/docs/making-a-progressive-web-app 57 | 58 | ### Advanced Configuration 59 | 60 | This section has moved here: https://facebook.github.io/create-react-app/docs/advanced-configuration 61 | 62 | ### Deployment 63 | 64 | This section has moved here: https://facebook.github.io/create-react-app/docs/deployment 65 | 66 | ### `npm run build` fails to minify 67 | 68 | This section has moved here: https://facebook.github.io/create-react-app/docs/troubleshooting#npm-run-build-fails-to-minify 69 | -------------------------------------------------------------------------------- /react-table/src/App.tsx: -------------------------------------------------------------------------------- 1 | import React, { useRef, useEffect } from 'react'; 2 | import { tableMachine, findElementsInSelectArea } from 'xstate-table'; 3 | import { useMachine } from '@xstate/react'; 4 | import faker from 'faker'; 5 | 6 | function App() { 7 | const [state, send] = useMachine(tableMachine.withConfig( 8 | { 9 | }, 10 | { 11 | rows: Array.from({ length: 100 }, (_, i) => ({ 12 | id: i + 10000, 13 | name: faker.name.findName(), 14 | address: faker.address.streetAddress(), 15 | email: faker.internet.email(), 16 | ref: React.createRef() 17 | })), 18 | selectedIds: [10002], 19 | delay: 300, 20 | findElementsInSelectArea: (ctx, selectArea) => findElementsInSelectArea(ctx, selectArea, ctx => ctx.rows.map(r => r.ref.current)) 21 | } 22 | )); 23 | 24 | const mouseEvent = evt => send({type: evt.type, evt}) 25 | 26 | useEventListener('mousedown', mouseEvent); 27 | useEventListener('mousemove', mouseEvent); 28 | useEventListener('mouseup', mouseEvent); 29 | 30 | const rows = state.context.rows.map(row => { 31 | const className = state.context.selectedIds.includes(row.id) ? 'selected' : ''; 32 | return ( 33 | send({type: evt.type, evt, id: row.id })} 38 | className={className}> 39 | {row.id} 40 | {row.name} 41 | {row.address} 42 | {row.email} 43 | 44 | ) 45 | }); 46 | 47 | 48 | return ( 49 |
50 |
51 |
52 | 53 | 54 | 55 | 56 | 57 | 58 | 59 | 60 | 61 | 62 | 63 | 64 | 65 | 66 | {rows} 67 | 68 |
IdNameAddressEmail
69 |
70 |
71 | ); 72 | } 73 | 74 | export default App; 75 | 76 | // https://usehooks.com/useEventListener/ 77 | function useEventListener(eventName, handler, element = document.body){ 78 | // Create a ref that stores handler 79 | const savedHandler = useRef(); 80 | 81 | // Update ref.current value if handler changes. 82 | // This allows our effect below to always get latest handler ... 83 | // ... without us needing to pass it in effect deps array ... 84 | // ... and potentially cause effect to re-run every render. 85 | useEffect(() => { 86 | savedHandler.current = handler; 87 | }, [handler]); 88 | 89 | useEffect( 90 | () => { 91 | // Make sure element supports addEventListener 92 | const isSupported = element && element.addEventListener; 93 | if (!isSupported) return; 94 | 95 | // Create event listener that calls handler function stored in ref 96 | const eventListener = event => (savedHandler as any).current(event); 97 | 98 | // Add event listener 99 | element.addEventListener(eventName, eventListener); 100 | 101 | // Remove event listener on cleanup 102 | return () => { 103 | element.removeEventListener(eventName, eventListener); 104 | }; 105 | }, 106 | [eventName, element] // Re-run if eventName or element changes 107 | ); 108 | }; -------------------------------------------------------------------------------- /angular-table/angular.json: -------------------------------------------------------------------------------- 1 | { 2 | "$schema": "./node_modules/@angular/cli/lib/config/schema.json", 3 | "version": 1, 4 | "newProjectRoot": "projects", 5 | "projects": { 6 | "angular-table": { 7 | "root": "", 8 | "sourceRoot": "src", 9 | "projectType": "application", 10 | "prefix": "app", 11 | "schematics": {}, 12 | "architect": { 13 | "build": { 14 | "builder": "@angular-devkit/build-angular:browser", 15 | "options": { 16 | "outputPath": "dist/angular-table", 17 | "index": "src/index.html", 18 | "main": "src/main.ts", 19 | "polyfills": "src/polyfills.ts", 20 | "tsConfig": "src/tsconfig.app.json", 21 | "assets": [ 22 | "src/favicon.ico", 23 | "src/assets" 24 | ], 25 | "styles": [ 26 | "src/styles.css" 27 | ], 28 | "scripts": [] 29 | }, 30 | "configurations": { 31 | "production": { 32 | "fileReplacements": [ 33 | { 34 | "replace": "src/environments/environment.ts", 35 | "with": "src/environments/environment.prod.ts" 36 | } 37 | ], 38 | "optimization": true, 39 | "outputHashing": "all", 40 | "sourceMap": false, 41 | "extractCss": true, 42 | "namedChunks": false, 43 | "aot": true, 44 | "extractLicenses": true, 45 | "vendorChunk": false, 46 | "buildOptimizer": true 47 | } 48 | } 49 | }, 50 | "serve": { 51 | "builder": "@angular-devkit/build-angular:dev-server", 52 | "options": { 53 | "browserTarget": "angular-table:build" 54 | }, 55 | "configurations": { 56 | "production": { 57 | "browserTarget": "angular-table:build:production" 58 | } 59 | } 60 | }, 61 | "extract-i18n": { 62 | "builder": "@angular-devkit/build-angular:extract-i18n", 63 | "options": { 64 | "browserTarget": "angular-table:build" 65 | } 66 | }, 67 | "test": { 68 | "builder": "@angular-devkit/build-angular:karma", 69 | "options": { 70 | "main": "src/test.ts", 71 | "polyfills": "src/polyfills.ts", 72 | "tsConfig": "src/tsconfig.spec.json", 73 | "karmaConfig": "src/karma.conf.js", 74 | "styles": [ 75 | "src/styles.css" 76 | ], 77 | "scripts": [], 78 | "assets": [ 79 | "src/favicon.ico", 80 | "src/assets" 81 | ] 82 | } 83 | }, 84 | "lint": { 85 | "builder": "@angular-devkit/build-angular:tslint", 86 | "options": { 87 | "tsConfig": [ 88 | "src/tsconfig.app.json", 89 | "src/tsconfig.spec.json" 90 | ], 91 | "exclude": [ 92 | "**/node_modules/**" 93 | ] 94 | } 95 | } 96 | } 97 | }, 98 | "angular-table-e2e": { 99 | "root": "e2e/", 100 | "projectType": "application", 101 | "architect": { 102 | "e2e": { 103 | "builder": "@angular-devkit/build-angular:protractor", 104 | "options": { 105 | "protractorConfig": "e2e/protractor.conf.js", 106 | "devServerTarget": "angular-table:serve" 107 | }, 108 | "configurations": { 109 | "production": { 110 | "devServerTarget": "angular-table:serve:production" 111 | } 112 | } 113 | }, 114 | "lint": { 115 | "builder": "@angular-devkit/build-angular:tslint", 116 | "options": { 117 | "tsConfig": "e2e/tsconfig.e2e.json", 118 | "exclude": [ 119 | "**/node_modules/**" 120 | ] 121 | } 122 | } 123 | } 124 | } 125 | }, 126 | "defaultProject": "angular-table" 127 | } -------------------------------------------------------------------------------- /react-table/src/serviceWorker.js: -------------------------------------------------------------------------------- 1 | // This optional code is used to register a service worker. 2 | // register() is not called by default. 3 | 4 | // This lets the app load faster on subsequent visits in production, and gives 5 | // it offline capabilities. However, it also means that developers (and users) 6 | // will only see deployed updates on subsequent visits to a page, after all the 7 | // existing tabs open on the page have been closed, since previously cached 8 | // resources are updated in the background. 9 | 10 | // To learn more about the benefits of this model and instructions on how to 11 | // opt-in, read https://bit.ly/CRA-PWA 12 | 13 | const isLocalhost = Boolean( 14 | window.location.hostname === 'localhost' || 15 | // [::1] is the IPv6 localhost address. 16 | window.location.hostname === '[::1]' || 17 | // 127.0.0.1/8 is considered localhost for IPv4. 18 | window.location.hostname.match( 19 | /^127(?:\.(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)){3}$/ 20 | ) 21 | ); 22 | 23 | export function register(config) { 24 | if (process.env.NODE_ENV === 'production' && 'serviceWorker' in navigator) { 25 | // The URL constructor is available in all browsers that support SW. 26 | const publicUrl = new URL(process.env.PUBLIC_URL, window.location.href); 27 | if (publicUrl.origin !== window.location.origin) { 28 | // Our service worker won't work if PUBLIC_URL is on a different origin 29 | // from what our page is served on. This might happen if a CDN is used to 30 | // serve assets; see https://github.com/facebook/create-react-app/issues/2374 31 | return; 32 | } 33 | 34 | window.addEventListener('load', () => { 35 | const swUrl = `${process.env.PUBLIC_URL}/service-worker.js`; 36 | 37 | if (isLocalhost) { 38 | // This is running on localhost. Let's check if a service worker still exists or not. 39 | checkValidServiceWorker(swUrl, config); 40 | 41 | // Add some additional logging to localhost, pointing developers to the 42 | // service worker/PWA documentation. 43 | navigator.serviceWorker.ready.then(() => { 44 | console.log( 45 | 'This web app is being served cache-first by a service ' + 46 | 'worker. To learn more, visit https://bit.ly/CRA-PWA' 47 | ); 48 | }); 49 | } else { 50 | // Is not localhost. Just register service worker 51 | registerValidSW(swUrl, config); 52 | } 53 | }); 54 | } 55 | } 56 | 57 | function registerValidSW(swUrl, config) { 58 | navigator.serviceWorker 59 | .register(swUrl) 60 | .then(registration => { 61 | registration.onupdatefound = () => { 62 | const installingWorker = registration.installing; 63 | if (installingWorker == null) { 64 | return; 65 | } 66 | installingWorker.onstatechange = () => { 67 | if (installingWorker.state === 'installed') { 68 | if (navigator.serviceWorker.controller) { 69 | // At this point, the updated precached content has been fetched, 70 | // but the previous service worker will still serve the older 71 | // content until all client tabs are closed. 72 | console.log( 73 | 'New content is available and will be used when all ' + 74 | 'tabs for this page are closed. See https://bit.ly/CRA-PWA.' 75 | ); 76 | 77 | // Execute callback 78 | if (config && config.onUpdate) { 79 | config.onUpdate(registration); 80 | } 81 | } else { 82 | // At this point, everything has been precached. 83 | // It's the perfect time to display a 84 | // "Content is cached for offline use." message. 85 | console.log('Content is cached for offline use.'); 86 | 87 | // Execute callback 88 | if (config && config.onSuccess) { 89 | config.onSuccess(registration); 90 | } 91 | } 92 | } 93 | }; 94 | }; 95 | }) 96 | .catch(error => { 97 | console.error('Error during service worker registration:', error); 98 | }); 99 | } 100 | 101 | function checkValidServiceWorker(swUrl, config) { 102 | // Check if the service worker can be found. If it can't reload the page. 103 | fetch(swUrl) 104 | .then(response => { 105 | // Ensure service worker exists, and that we really are getting a JS file. 106 | const contentType = response.headers.get('content-type'); 107 | if ( 108 | response.status === 404 || 109 | (contentType != null && contentType.indexOf('javascript') === -1) 110 | ) { 111 | // No service worker found. Probably a different app. Reload the page. 112 | navigator.serviceWorker.ready.then(registration => { 113 | registration.unregister().then(() => { 114 | window.location.reload(); 115 | }); 116 | }); 117 | } else { 118 | // Service worker found. Proceed as normal. 119 | registerValidSW(swUrl, config); 120 | } 121 | }) 122 | .catch(() => { 123 | console.log( 124 | 'No internet connection found. App is running in offline mode.' 125 | ); 126 | }); 127 | } 128 | 129 | export function unregister() { 130 | if ('serviceWorker' in navigator) { 131 | navigator.serviceWorker.ready.then(registration => { 132 | registration.unregister(); 133 | }); 134 | } 135 | } 136 | -------------------------------------------------------------------------------- /xstate-table/index.js: -------------------------------------------------------------------------------- 1 | import { Machine, actions } from "xstate"; 2 | const { assign, send } = actions; 3 | 4 | export function findElementsInSelectArea(ctx, selectArea, selector = (_ctx) => [...document.querySelectorAll("[data-row-id]")]) { 5 | const rows = selector(ctx).filter(row => { 6 | const { left, right, top, bottom } = row.getBoundingClientRect(); 7 | 8 | return ( 9 | selectArea.x1 <= right && 10 | selectArea.x2 >= left && 11 | selectArea.y1 <= bottom + document.documentElement.scrollTop && 12 | selectArea.y2 >= top + document.documentElement.scrollTop 13 | ); 14 | }); 15 | return rows.map(row => +row.getAttribute("data-row-id")); 16 | } 17 | 18 | function selectedIdsInRange(ctx, id) { 19 | const toIndex = ctx.rows.findIndex(r => r.id === id); 20 | const prevIndex = 21 | ctx.prevId >= 0 ? ctx.rows.findIndex(r => r.id === ctx.prevId) : toIndex; 22 | 23 | const minIndex = Math.min(prevIndex, toIndex); 24 | const maxIndex = Math.max(prevIndex, toIndex); 25 | 26 | const rangeRows = ctx.rows 27 | .filter((_, index) => index >= minIndex && index <= maxIndex) 28 | .map(r => r.id); 29 | return rangeRows; 30 | } 31 | 32 | export const tableMachine = Machine( 33 | { 34 | id: "table", 35 | type: "parallel", 36 | context: { 37 | rows: [], 38 | selectedIds: [], 39 | prevId: undefined, 40 | x1: undefined, 41 | y1: undefined, 42 | selectArea: undefined, 43 | delay: 0, 44 | findElementsInSelectArea 45 | }, 46 | states: { 47 | state: { 48 | initial: "idle", 49 | states: { 50 | idle: { 51 | entry: send("reset", { 52 | delay: "CONFIG_DELAY" 53 | }), 54 | on: { 55 | click: [ 56 | { actions: "ctrlShiftClick", cond: "isCtrlShiftClick" }, 57 | { actions: "ctrlClick", cond: "isCtrlClick" }, 58 | { actions: "shiftClick", cond: "isShiftClick" }, 59 | { actions: "click" } 60 | ], 61 | mousedown: { 62 | target: "dragging", 63 | actions: "mousedown" 64 | }, 65 | reset: { 66 | actions: ["reset", "redrawSelectArea"] 67 | } 68 | } 69 | }, 70 | dragging: { 71 | on: { 72 | mousemove: { 73 | actions: ["mousemove", "redrawSelectArea"] 74 | }, 75 | mouseup: "idle" 76 | } 77 | } 78 | } 79 | }, 80 | selection: { 81 | initial: "unknown", 82 | on: { 83 | click: "selection", 84 | mouseup: "selection", 85 | mousemove: "selection" 86 | }, 87 | states: { 88 | unknown: { 89 | on: { 90 | "": [ 91 | { 92 | target: "SINGLE_SELECTION", 93 | cond: "hasSingleSelection" 94 | }, 95 | { 96 | target: "MULTI_SELECTION", 97 | cond: "hasMultipleSelections" 98 | }, 99 | { 100 | target: "EMPTY_SELECTION", 101 | } 102 | ] 103 | } 104 | }, 105 | SINGLE_SELECTION: {}, 106 | MULTI_SELECTION: {}, 107 | EMPTY_SELECTION: {} 108 | } 109 | } 110 | } 111 | }, 112 | { 113 | actions: { 114 | click: assign((ctx, { id }) => { 115 | return { 116 | selectArea: undefined, 117 | prevId: id, 118 | selectedIds: [id] 119 | }; 120 | }), 121 | ctrlClick: assign((ctx, { id }) => { 122 | if (ctx.selectedIds.includes(id)) { 123 | return { 124 | selectArea: undefined, 125 | prevId: id, 126 | selectedIds: ctx.selectedIds.filter(r => r !== id) 127 | }; 128 | } 129 | 130 | return { 131 | selectArea: undefined, 132 | prevId: id, 133 | selectedIds: ctx.selectedIds.concat(id) 134 | }; 135 | }), 136 | shiftClick: assign((ctx, { id }) => { 137 | const selectedIds = selectedIdsInRange(ctx, id); 138 | return { 139 | selectArea: undefined, 140 | selectedIds 141 | }; 142 | }), 143 | ctrlShiftClick: assign((ctx, { id }) => { 144 | const selectedIds = selectedIdsInRange(ctx, id); 145 | return { 146 | selectArea: undefined, 147 | selectedIds: [...new Set(ctx.selectedIds.concat(selectedIds))] 148 | }; 149 | }), 150 | mousedown: assign((_, { evt }) => { 151 | return { 152 | x1: evt.pageX, 153 | y1: evt.pageY 154 | }; 155 | }), 156 | mousemove: assign((ctx, { evt }) => { 157 | const selectArea = { 158 | x1: Math.min(ctx.x1, evt.pageX), 159 | y1: Math.min(ctx.y1, evt.pageY), 160 | x2: Math.max(ctx.x1, evt.pageX), 161 | y2: Math.max(ctx.y1, evt.pageY) 162 | }; 163 | 164 | const idsInArea = (ctx.findElementsInSelectArea || 165 | findElementsInSelectArea)(ctx, selectArea); 166 | const selectedIds = evt.ctrlKey 167 | ? ctx.selectedIds.concat(idsInArea) 168 | : idsInArea; 169 | 170 | return { 171 | selectArea, 172 | selectedIds 173 | }; 174 | }), 175 | reset: assign(() => ({ 176 | x1: undefined, 177 | y1: undefined, 178 | selectArea: undefined 179 | })), 180 | redrawSelectArea: (ctx) => { 181 | if(ctx.selectArea) { 182 | document.documentElement.style.setProperty('--mouse-x1', ctx.selectArea.x1 + 'px'); 183 | document.documentElement.style.setProperty('--mouse-y1', ctx.selectArea.y1 + 'px'); 184 | document.documentElement.style.setProperty('--mouse-x2', ctx.selectArea.x2 + 'px'); 185 | document.documentElement.style.setProperty('--mouse-y2', ctx.selectArea.y2 + 'px'); 186 | } else { 187 | document.documentElement.style.setProperty('--mouse-x1', '0'); 188 | document.documentElement.style.setProperty('--mouse-y1', '0'); 189 | document.documentElement.style.setProperty('--mouse-x2', '0'); 190 | document.documentElement.style.setProperty('--mouse-y2', '0'); 191 | } 192 | } 193 | }, 194 | guards: { 195 | hasSingleSelection: ctx => ctx.selectedIds.length === 1, 196 | hasMultipleSelections: ctx => ctx.selectedIds.length > 1, 197 | isCtrlShiftClick: (_, { evt }) => evt.ctrlKey && evt.shiftKey, 198 | isCtrlClick: (_, { evt }) => evt.ctrlKey, 199 | isShiftClick: (_, { evt }) => evt.shiftKey 200 | }, 201 | delays: { 202 | CONFIG_DELAY: context => context.delay 203 | } 204 | } 205 | ); 206 | -------------------------------------------------------------------------------- /svelte-table/public/index.js: -------------------------------------------------------------------------------- 1 | import { Machine, actions } from "xstate"; 2 | const { assign, send } = actions; 3 | 4 | export function findElementsInSelectArea(ctx, selectArea, selector = (_ctx) => [...document.querySelectorAll("[data-row-id]")]) { 5 | const rows = selector(ctx).filter(row => { 6 | const { left, right, top, bottom } = row.getBoundingClientRect(); 7 | 8 | return ( 9 | selectArea.x1 <= right && 10 | selectArea.x2 >= left && 11 | selectArea.y1 <= bottom + document.documentElement.scrollTop && 12 | selectArea.y2 >= top + document.documentElement.scrollTop 13 | ); 14 | }); 15 | return rows.map(row => +row.getAttribute("data-row-id")); 16 | } 17 | 18 | function selectedIdsInRange(ctx, id) { 19 | const toIndex = ctx.rows.findIndex(r => r.id === id); 20 | const prevIndex = 21 | ctx.prevId >= 0 ? ctx.rows.findIndex(r => r.id === ctx.prevId) : toIndex; 22 | 23 | const minIndex = Math.min(prevIndex, toIndex); 24 | const maxIndex = Math.max(prevIndex, toIndex); 25 | 26 | const rangeRows = ctx.rows 27 | .filter((_, index) => index >= minIndex && index <= maxIndex) 28 | .map(r => r.id); 29 | return rangeRows; 30 | } 31 | 32 | export const tableMachine = Machine( 33 | { 34 | id: "table", 35 | type: "parallel", 36 | context: { 37 | rows: [], 38 | selectedIds: [], 39 | prevId: undefined, 40 | x1: undefined, 41 | y1: undefined, 42 | selectArea: undefined, 43 | delay: 0, 44 | findElementsInSelectArea 45 | }, 46 | states: { 47 | state: { 48 | initial: "idle", 49 | states: { 50 | idle: { 51 | entry: send("reset", { 52 | delay: "CONFIG_DELAY" 53 | }), 54 | on: { 55 | click: [ 56 | { actions: "ctrlShiftClick", cond: "isCtrlShiftClick" }, 57 | { actions: "ctrlClick", cond: "isCtrlClick" }, 58 | { actions: "shiftClick", cond: "isShiftClick" }, 59 | { actions: "click" } 60 | ], 61 | mousedown: { 62 | target: "dragging", 63 | actions: "mousedown" 64 | }, 65 | reset: { 66 | actions: ["reset", "redrawSelectArea"] 67 | } 68 | } 69 | }, 70 | dragging: { 71 | on: { 72 | mousemove: { 73 | actions: ["mousemove", "redrawSelectArea"] 74 | }, 75 | mouseup: "idle" 76 | } 77 | } 78 | } 79 | }, 80 | selection: { 81 | initial: "unknown", 82 | on: { 83 | click: "selection", 84 | mouseup: "selection", 85 | mousemove: "selection" 86 | }, 87 | states: { 88 | unknown: { 89 | on: { 90 | "": [ 91 | { 92 | target: "SINGLE_SELECTION", 93 | cond: "hasSingleSelection" 94 | }, 95 | { 96 | target: "MULTI_SELECTION", 97 | cond: "hasMultipleSelections" 98 | }, 99 | { 100 | target: "EMPTY_SELECTION", 101 | } 102 | ] 103 | } 104 | }, 105 | SINGLE_SELECTION: {}, 106 | MULTI_SELECTION: {}, 107 | EMPTY_SELECTION: {} 108 | } 109 | } 110 | } 111 | }, 112 | { 113 | actions: { 114 | click: assign((ctx, { evt, id }) => { 115 | return { 116 | selectArea: undefined, 117 | prevId: id, 118 | selectedIds: [id] 119 | }; 120 | }), 121 | ctrlClick: assign((ctx, { id }) => { 122 | if (ctx.selectedIds.includes(id)) { 123 | return { 124 | selectArea: undefined, 125 | prevId: id, 126 | selectedIds: ctx.selectedIds.filter(r => r !== id) 127 | }; 128 | } 129 | 130 | return { 131 | selectArea: undefined, 132 | prevId: id, 133 | selectedIds: ctx.selectedIds.concat(id) 134 | }; 135 | }), 136 | shiftClick: assign((ctx, { id }) => { 137 | const selectedIds = selectedIdsInRange(ctx, id); 138 | return { 139 | selectArea: undefined, 140 | selectedIds 141 | }; 142 | }), 143 | ctrlShiftClick: assign((ctx, { id }) => { 144 | const selectedIds = selectedIdsInRange(ctx, id); 145 | return { 146 | selectArea: undefined, 147 | selectedIds: [...new Set(ctx.selectedIds.concat(selectedIds))] 148 | }; 149 | }), 150 | mousedown: assign((_, { evt }) => { 151 | return { 152 | x1: evt.pageX, 153 | y1: evt.pageY 154 | }; 155 | }), 156 | mousemove: assign((ctx, { evt }) => { 157 | const selectArea = { 158 | x1: Math.min(ctx.x1, evt.pageX), 159 | y1: Math.min(ctx.y1, evt.pageY), 160 | x2: Math.max(ctx.x1, evt.pageX), 161 | y2: Math.max(ctx.y1, evt.pageY) 162 | }; 163 | 164 | const idsInArea = (ctx.findElementsInSelectArea || 165 | findElementsInSelectArea)(ctx, selectArea); 166 | const selectedIds = evt.ctrlKey 167 | ? ctx.selectedIds.concat(idsInArea) 168 | : idsInArea; 169 | 170 | return { 171 | selectArea, 172 | selectedIds 173 | }; 174 | }), 175 | reset: assign(() => ({ 176 | x1: undefined, 177 | y1: undefined, 178 | selectArea: undefined 179 | })), 180 | redrawSelectArea: (ctx) => { 181 | if(ctx.selectArea) { 182 | document.documentElement.style.setProperty('--mouse-x1', ctx.selectArea.x1 + 'px'); 183 | document.documentElement.style.setProperty('--mouse-y1', ctx.selectArea.y1 + 'px'); 184 | document.documentElement.style.setProperty('--mouse-x2', ctx.selectArea.x2 + 'px'); 185 | document.documentElement.style.setProperty('--mouse-y2', ctx.selectArea.y2 + 'px'); 186 | } else { 187 | document.documentElement.style.setProperty('--mouse-x1', '0'); 188 | document.documentElement.style.setProperty('--mouse-y1', '0'); 189 | document.documentElement.style.setProperty('--mouse-x2', '0'); 190 | document.documentElement.style.setProperty('--mouse-y2', '0'); 191 | } 192 | } 193 | }, 194 | guards: { 195 | hasSingleSelection: ctx => ctx.selectedIds.length === 1, 196 | hasMultipleSelections: ctx => ctx.selectedIds.length > 1, 197 | isCtrlShiftClick: (_, { evt }) => evt.ctrlKey && evt.shiftKey, 198 | isCtrlClick: (_, { evt }) => evt.ctrlKey, 199 | isShiftClick: (_, { evt }) => evt.shiftKey 200 | }, 201 | delays: { 202 | CONFIG_DELAY: context => context.delay 203 | } 204 | } 205 | ); 206 | -------------------------------------------------------------------------------- /svelte-table/package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "svelte-app", 3 | "version": "1.0.0", 4 | "lockfileVersion": 1, 5 | "requires": true, 6 | "dependencies": { 7 | "@babel/code-frame": { 8 | "version": "7.0.0", 9 | "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.0.0.tgz", 10 | "integrity": "sha512-OfC2uemaknXr87bdLUkWog7nYuliM9Ij5HUcajsVcMCpQrcLmtxRbVFTIqmcSkSeYRBFBRxs2FiUqFJDLdiebA==", 11 | "dev": true, 12 | "requires": { 13 | "@babel/highlight": "^7.0.0" 14 | } 15 | }, 16 | "@babel/highlight": { 17 | "version": "7.0.0", 18 | "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.0.0.tgz", 19 | "integrity": "sha512-UFMC4ZeFC48Tpvj7C8UgLvtkaUuovQX+5xNWrsIoMG8o2z+XFKjKaN9iVmS84dPwVN00W4wPmqvYoZF3EGAsfw==", 20 | "dev": true, 21 | "requires": { 22 | "chalk": "^2.0.0", 23 | "esutils": "^2.0.2", 24 | "js-tokens": "^4.0.0" 25 | } 26 | }, 27 | "@polka/url": { 28 | "version": "0.5.0", 29 | "resolved": "https://registry.npmjs.org/@polka/url/-/url-0.5.0.tgz", 30 | "integrity": "sha512-oZLYFEAzUKyi3SKnXvj32ZCEGH6RDnao7COuCVhDydMS9NrCSVXhM79VaKyP5+Zc33m0QXEd2DN3UkU7OsHcfw==" 31 | }, 32 | "@types/estree": { 33 | "version": "0.0.39", 34 | "resolved": "https://registry.npmjs.org/@types/estree/-/estree-0.0.39.tgz", 35 | "integrity": "sha512-EYNwp3bU+98cpU4lAWYYL7Zz+2gryWH1qbdDTidVd6hkiR6weksdbMadyXKXNPEkQFhXM+hVO9ZygomHXp+AIw==", 36 | "dev": true 37 | }, 38 | "@types/faker": { 39 | "version": "4.1.5", 40 | "resolved": "https://registry.npmjs.org/@types/faker/-/faker-4.1.5.tgz", 41 | "integrity": "sha512-YSDqoBEWYGdNk53xSkkb6REaUaVSlIjxIAGjj/nbLzlZOit7kUU+nA2zC2qQkIVO4MQ+3zl4Sz7aw+kbpHHHUQ==", 42 | "dev": true 43 | }, 44 | "@types/node": { 45 | "version": "12.0.10", 46 | "resolved": "https://registry.npmjs.org/@types/node/-/node-12.0.10.tgz", 47 | "integrity": "sha512-LcsGbPomWsad6wmMNv7nBLw7YYYyfdYcz6xryKYQhx89c3XXan+8Q6AJ43G5XDIaklaVkK3mE4fCb0SBvMiPSQ==", 48 | "dev": true 49 | }, 50 | "@types/resolve": { 51 | "version": "0.0.8", 52 | "resolved": "https://registry.npmjs.org/@types/resolve/-/resolve-0.0.8.tgz", 53 | "integrity": "sha512-auApPaJf3NPfe18hSoJkp8EbZzer2ISk7o8mCC3M9he/a04+gbMF97NkpD2S8riMGvm4BMRI59/SZQSaLTKpsQ==", 54 | "dev": true, 55 | "requires": { 56 | "@types/node": "*" 57 | } 58 | }, 59 | "@vuepress/plugin-google-analytics": { 60 | "version": "1.0.2", 61 | "resolved": "https://registry.npmjs.org/@vuepress/plugin-google-analytics/-/plugin-google-analytics-1.0.2.tgz", 62 | "integrity": "sha512-NdU18hTBW4TkNK80dgpPu4yq/smNkIUZi9gL5hCiuW43BnXFA7WFfhGcvZJ61+keNDr6gw9UIv4HQuFFPoRXQA==" 63 | }, 64 | "acorn": { 65 | "version": "6.1.1", 66 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-6.1.1.tgz", 67 | "integrity": "sha512-jPTiwtOxaHNaAPg/dmrJ/beuzLRnXtB0kQPQ8JpotKJgTB6rX6c8mlf315941pyjBSaPg8NHXS9fhP4u17DpGA==", 68 | "dev": true 69 | }, 70 | "acorn-jsx": { 71 | "version": "5.0.1", 72 | "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.0.1.tgz", 73 | "integrity": "sha512-HJ7CfNHrfJLlNTzIEUTj43LNWGkqpRLxm3YjAlcD0ACydk9XynzYsCBHxut+iqt+1aBXkx9UP/w/ZqMr13XIzg==", 74 | "dev": true 75 | }, 76 | "ajv": { 77 | "version": "6.10.0", 78 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.10.0.tgz", 79 | "integrity": "sha512-nffhOpkymDECQyR0mnsUtoCE8RlX38G0rYP+wgLWFyZuUyuuojSSvi/+euOiQBIn63whYwYVIIH1TvE3tu4OEg==", 80 | "dev": true, 81 | "requires": { 82 | "fast-deep-equal": "^2.0.1", 83 | "fast-json-stable-stringify": "^2.0.0", 84 | "json-schema-traverse": "^0.4.1", 85 | "uri-js": "^4.2.2" 86 | } 87 | }, 88 | "ansi-escapes": { 89 | "version": "3.2.0", 90 | "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-3.2.0.tgz", 91 | "integrity": "sha512-cBhpre4ma+U0T1oM5fXg7Dy1Jw7zzwv7lt/GoCpr+hDQJoYnKVPLL4dCvSEFMmQurOQvSrwT7SL/DAlhBI97RQ==", 92 | "dev": true 93 | }, 94 | "ansi-regex": { 95 | "version": "3.0.0", 96 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-3.0.0.tgz", 97 | "integrity": "sha1-7QMXwyIGT3lGbAKWa922Bas32Zg=", 98 | "dev": true 99 | }, 100 | "ansi-styles": { 101 | "version": "3.2.1", 102 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 103 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 104 | "dev": true, 105 | "requires": { 106 | "color-convert": "^1.9.0" 107 | } 108 | }, 109 | "anymatch": { 110 | "version": "2.0.0", 111 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-2.0.0.tgz", 112 | "integrity": "sha512-5teOsQWABXHHBFP9y3skS5P3d/WfWXpv3FUpy+LorMrNYaT9pI4oLMQX7jzQ2KklNpGpWHzdCXTDT2Y3XGlZBw==", 113 | "dev": true, 114 | "requires": { 115 | "micromatch": "^3.1.4", 116 | "normalize-path": "^2.1.1" 117 | }, 118 | "dependencies": { 119 | "normalize-path": { 120 | "version": "2.1.1", 121 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-2.1.1.tgz", 122 | "integrity": "sha1-GrKLVW4Zg2Oowab35vogE3/mrtk=", 123 | "dev": true, 124 | "requires": { 125 | "remove-trailing-separator": "^1.0.1" 126 | } 127 | } 128 | } 129 | }, 130 | "argparse": { 131 | "version": "1.0.10", 132 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.10.tgz", 133 | "integrity": "sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg==", 134 | "dev": true, 135 | "requires": { 136 | "sprintf-js": "~1.0.2" 137 | } 138 | }, 139 | "arr-diff": { 140 | "version": "4.0.0", 141 | "resolved": "https://registry.npmjs.org/arr-diff/-/arr-diff-4.0.0.tgz", 142 | "integrity": "sha1-1kYQdP6/7HHn4VI1dhoyml3HxSA=", 143 | "dev": true 144 | }, 145 | "arr-flatten": { 146 | "version": "1.1.0", 147 | "resolved": "https://registry.npmjs.org/arr-flatten/-/arr-flatten-1.1.0.tgz", 148 | "integrity": "sha512-L3hKV5R/p5o81R7O02IGnwpDmkp6E982XhtbuwSe3O4qOtMMMtodicASA1Cny2U+aCXcNpml+m4dPsvsJ3jatg==", 149 | "dev": true 150 | }, 151 | "arr-union": { 152 | "version": "3.1.0", 153 | "resolved": "https://registry.npmjs.org/arr-union/-/arr-union-3.1.0.tgz", 154 | "integrity": "sha1-45sJrqne+Gao8gbiiK9jkZuuOcQ=", 155 | "dev": true 156 | }, 157 | "array-filter": { 158 | "version": "0.0.1", 159 | "resolved": "https://registry.npmjs.org/array-filter/-/array-filter-0.0.1.tgz", 160 | "integrity": "sha1-fajPLiZijtcygDWB/SH2fKzS7uw=", 161 | "dev": true 162 | }, 163 | "array-map": { 164 | "version": "0.0.0", 165 | "resolved": "https://registry.npmjs.org/array-map/-/array-map-0.0.0.tgz", 166 | "integrity": "sha1-iKK6tz0c97zVwbEYoAP2b2ZfpmI=", 167 | "dev": true 168 | }, 169 | "array-reduce": { 170 | "version": "0.0.0", 171 | "resolved": "https://registry.npmjs.org/array-reduce/-/array-reduce-0.0.0.tgz", 172 | "integrity": "sha1-FziZ0//Rx9k4PkR5Ul2+J4yrXys=", 173 | "dev": true 174 | }, 175 | "array-unique": { 176 | "version": "0.3.2", 177 | "resolved": "https://registry.npmjs.org/array-unique/-/array-unique-0.3.2.tgz", 178 | "integrity": "sha1-qJS3XUvE9s1nnvMkSp/Y9Gri1Cg=", 179 | "dev": true 180 | }, 181 | "assign-symbols": { 182 | "version": "1.0.0", 183 | "resolved": "https://registry.npmjs.org/assign-symbols/-/assign-symbols-1.0.0.tgz", 184 | "integrity": "sha1-WWZ/QfrdTyDMvCu5a41Pf3jsA2c=", 185 | "dev": true 186 | }, 187 | "astral-regex": { 188 | "version": "1.0.0", 189 | "resolved": "https://registry.npmjs.org/astral-regex/-/astral-regex-1.0.0.tgz", 190 | "integrity": "sha512-+Ryf6g3BKoRc7jfp7ad8tM4TtMiaWvbF/1/sQcZPkkS7ag3D5nMBCe2UfOTONtAkaG0tO0ij3C5Lwmf1EiyjHg==", 191 | "dev": true 192 | }, 193 | "async-each": { 194 | "version": "1.0.3", 195 | "resolved": "https://registry.npmjs.org/async-each/-/async-each-1.0.3.tgz", 196 | "integrity": "sha512-z/WhQ5FPySLdvREByI2vZiTWwCnF0moMJ1hK9YQwDTHKh6I7/uSckMetoRGb5UBZPC1z0jlw+n/XCgjeH7y1AQ==", 197 | "dev": true 198 | }, 199 | "atob": { 200 | "version": "2.1.2", 201 | "resolved": "https://registry.npmjs.org/atob/-/atob-2.1.2.tgz", 202 | "integrity": "sha512-Wm6ukoaOGJi/73p/cl2GvLjTI5JM1k/O14isD73YML8StrH/7/lRFgmg8nICZgD3bZZvjwCGxtMOD3wWNAu8cg==", 203 | "dev": true 204 | }, 205 | "balanced-match": { 206 | "version": "1.0.0", 207 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz", 208 | "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=", 209 | "dev": true 210 | }, 211 | "base": { 212 | "version": "0.11.2", 213 | "resolved": "https://registry.npmjs.org/base/-/base-0.11.2.tgz", 214 | "integrity": "sha512-5T6P4xPgpp0YDFvSWwEZ4NoE3aM4QBQXDzmVbraCkFj8zHM+mba8SyqB5DbZWyR7mYHo6Y7BdQo3MoA4m0TeQg==", 215 | "dev": true, 216 | "requires": { 217 | "cache-base": "^1.0.1", 218 | "class-utils": "^0.3.5", 219 | "component-emitter": "^1.2.1", 220 | "define-property": "^1.0.0", 221 | "isobject": "^3.0.1", 222 | "mixin-deep": "^1.2.0", 223 | "pascalcase": "^0.1.1" 224 | }, 225 | "dependencies": { 226 | "define-property": { 227 | "version": "1.0.0", 228 | "resolved": "https://registry.npmjs.org/define-property/-/define-property-1.0.0.tgz", 229 | "integrity": "sha1-dp66rz9KY6rTr56NMEybvnm/sOY=", 230 | "dev": true, 231 | "requires": { 232 | "is-descriptor": "^1.0.0" 233 | } 234 | }, 235 | "is-accessor-descriptor": { 236 | "version": "1.0.0", 237 | "resolved": "https://registry.npmjs.org/is-accessor-descriptor/-/is-accessor-descriptor-1.0.0.tgz", 238 | "integrity": "sha512-m5hnHTkcVsPfqx3AKlyttIPb7J+XykHvJP2B9bZDjlhLIoEq4XoK64Vg7boZlVWYK6LUY94dYPEE7Lh0ZkZKcQ==", 239 | "dev": true, 240 | "requires": { 241 | "kind-of": "^6.0.0" 242 | } 243 | }, 244 | "is-data-descriptor": { 245 | "version": "1.0.0", 246 | "resolved": "https://registry.npmjs.org/is-data-descriptor/-/is-data-descriptor-1.0.0.tgz", 247 | "integrity": "sha512-jbRXy1FmtAoCjQkVmIVYwuuqDFUbaOeDjmed1tOGPrsMhtJA4rD9tkgA0F1qJ3gRFRXcHYVkdeaP50Q5rE/jLQ==", 248 | "dev": true, 249 | "requires": { 250 | "kind-of": "^6.0.0" 251 | } 252 | }, 253 | "is-descriptor": { 254 | "version": "1.0.2", 255 | "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-1.0.2.tgz", 256 | "integrity": "sha512-2eis5WqQGV7peooDyLmNEPUrps9+SXX5c9pL3xEB+4e9HnGuDa7mB7kHxHw4CbqS9k1T2hOH3miL8n8WtiYVtg==", 257 | "dev": true, 258 | "requires": { 259 | "is-accessor-descriptor": "^1.0.0", 260 | "is-data-descriptor": "^1.0.0", 261 | "kind-of": "^6.0.2" 262 | } 263 | } 264 | } 265 | }, 266 | "binary-extensions": { 267 | "version": "1.13.1", 268 | "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-1.13.1.tgz", 269 | "integrity": "sha512-Un7MIEDdUC5gNpcGDV97op1Ywk748MpHcFTHoYs6qnj1Z3j7I53VG3nwZhKzoBZmbdRNnb6WRdFlwl7tSDuZGw==", 270 | "dev": true 271 | }, 272 | "brace-expansion": { 273 | "version": "1.1.11", 274 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 275 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 276 | "dev": true, 277 | "requires": { 278 | "balanced-match": "^1.0.0", 279 | "concat-map": "0.0.1" 280 | } 281 | }, 282 | "braces": { 283 | "version": "2.3.2", 284 | "resolved": "https://registry.npmjs.org/braces/-/braces-2.3.2.tgz", 285 | "integrity": "sha512-aNdbnj9P8PjdXU4ybaWLK2IF3jc/EoDYbC7AazW6to3TRsfXxscC9UXOB5iDiEQrkyIbWp2SLQda4+QAa7nc3w==", 286 | "dev": true, 287 | "requires": { 288 | "arr-flatten": "^1.1.0", 289 | "array-unique": "^0.3.2", 290 | "extend-shallow": "^2.0.1", 291 | "fill-range": "^4.0.0", 292 | "isobject": "^3.0.1", 293 | "repeat-element": "^1.1.2", 294 | "snapdragon": "^0.8.1", 295 | "snapdragon-node": "^2.0.1", 296 | "split-string": "^3.0.2", 297 | "to-regex": "^3.0.1" 298 | }, 299 | "dependencies": { 300 | "extend-shallow": { 301 | "version": "2.0.1", 302 | "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", 303 | "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", 304 | "dev": true, 305 | "requires": { 306 | "is-extendable": "^0.1.0" 307 | } 308 | } 309 | } 310 | }, 311 | "buffer-from": { 312 | "version": "1.1.1", 313 | "resolved": "https://registry.npmjs.org/buffer-from/-/buffer-from-1.1.1.tgz", 314 | "integrity": "sha512-MQcXEUbCKtEo7bhqEs6560Hyd4XaovZlO/k9V3hjVUF/zwW7KBVdSK4gIt/bzwS9MbR5qob+F5jusZsb0YQK2A==", 315 | "dev": true 316 | }, 317 | "builtin-modules": { 318 | "version": "3.1.0", 319 | "resolved": "https://registry.npmjs.org/builtin-modules/-/builtin-modules-3.1.0.tgz", 320 | "integrity": "sha512-k0KL0aWZuBt2lrxrcASWDfwOLMnodeQjodT/1SxEQAXsHANgo6ZC/VEaSEHCXt7aSTZ4/4H5LKa+tBXmW7Vtvw==", 321 | "dev": true 322 | }, 323 | "cache-base": { 324 | "version": "1.0.1", 325 | "resolved": "https://registry.npmjs.org/cache-base/-/cache-base-1.0.1.tgz", 326 | "integrity": "sha512-AKcdTnFSWATd5/GCPRxr2ChwIJ85CeyrEyjRHlKxQ56d4XJMGym0uAiKn0xbLOGOl3+yRpOTi484dVCEc5AUzQ==", 327 | "dev": true, 328 | "requires": { 329 | "collection-visit": "^1.0.0", 330 | "component-emitter": "^1.2.1", 331 | "get-value": "^2.0.6", 332 | "has-value": "^1.0.0", 333 | "isobject": "^3.0.1", 334 | "set-value": "^2.0.0", 335 | "to-object-path": "^0.3.0", 336 | "union-value": "^1.0.0", 337 | "unset-value": "^1.0.0" 338 | } 339 | }, 340 | "callsites": { 341 | "version": "3.1.0", 342 | "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", 343 | "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==", 344 | "dev": true 345 | }, 346 | "chalk": { 347 | "version": "2.4.2", 348 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", 349 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", 350 | "dev": true, 351 | "requires": { 352 | "ansi-styles": "^3.2.1", 353 | "escape-string-regexp": "^1.0.5", 354 | "supports-color": "^5.3.0" 355 | } 356 | }, 357 | "chardet": { 358 | "version": "0.7.0", 359 | "resolved": "https://registry.npmjs.org/chardet/-/chardet-0.7.0.tgz", 360 | "integrity": "sha512-mT8iDcrh03qDGRRmoA2hmBJnxpllMR+0/0qlzjqZES6NdiWDcZkCNAk4rPFZ9Q85r27unkiNNg8ZOiwZXBHwcA==", 361 | "dev": true 362 | }, 363 | "chokidar": { 364 | "version": "2.1.6", 365 | "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-2.1.6.tgz", 366 | "integrity": "sha512-V2jUo67OKkc6ySiRpJrjlpJKl9kDuG+Xb8VgsGzb+aEouhgS1D0weyPU4lEzdAcsCAvrih2J2BqyXqHWvVLw5g==", 367 | "dev": true, 368 | "requires": { 369 | "anymatch": "^2.0.0", 370 | "async-each": "^1.0.1", 371 | "braces": "^2.3.2", 372 | "fsevents": "^1.2.7", 373 | "glob-parent": "^3.1.0", 374 | "inherits": "^2.0.3", 375 | "is-binary-path": "^1.0.0", 376 | "is-glob": "^4.0.0", 377 | "normalize-path": "^3.0.0", 378 | "path-is-absolute": "^1.0.0", 379 | "readdirp": "^2.2.1", 380 | "upath": "^1.1.1" 381 | } 382 | }, 383 | "class-utils": { 384 | "version": "0.3.6", 385 | "resolved": "https://registry.npmjs.org/class-utils/-/class-utils-0.3.6.tgz", 386 | "integrity": "sha512-qOhPa/Fj7s6TY8H8esGu5QNpMMQxz79h+urzrNYN6mn+9BnxlDGf5QZ+XeCDsxSjPqsSR56XOZOJmpeurnLMeg==", 387 | "dev": true, 388 | "requires": { 389 | "arr-union": "^3.1.0", 390 | "define-property": "^0.2.5", 391 | "isobject": "^3.0.0", 392 | "static-extend": "^0.1.1" 393 | }, 394 | "dependencies": { 395 | "define-property": { 396 | "version": "0.2.5", 397 | "resolved": "https://registry.npmjs.org/define-property/-/define-property-0.2.5.tgz", 398 | "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=", 399 | "dev": true, 400 | "requires": { 401 | "is-descriptor": "^0.1.0" 402 | } 403 | } 404 | } 405 | }, 406 | "cli-cursor": { 407 | "version": "2.1.0", 408 | "resolved": "https://registry.npmjs.org/cli-cursor/-/cli-cursor-2.1.0.tgz", 409 | "integrity": "sha1-s12sN2R5+sw+lHR9QdDQ9SOP/LU=", 410 | "dev": true, 411 | "requires": { 412 | "restore-cursor": "^2.0.0" 413 | } 414 | }, 415 | "cli-width": { 416 | "version": "2.2.0", 417 | "resolved": "https://registry.npmjs.org/cli-width/-/cli-width-2.2.0.tgz", 418 | "integrity": "sha1-/xnt6Kml5XkyQUewwR8PvLq+1jk=", 419 | "dev": true 420 | }, 421 | "collection-visit": { 422 | "version": "1.0.0", 423 | "resolved": "https://registry.npmjs.org/collection-visit/-/collection-visit-1.0.0.tgz", 424 | "integrity": "sha1-S8A3PBZLwykbTTaMgpzxqApZ3KA=", 425 | "dev": true, 426 | "requires": { 427 | "map-visit": "^1.0.0", 428 | "object-visit": "^1.0.0" 429 | } 430 | }, 431 | "color-convert": { 432 | "version": "1.9.3", 433 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", 434 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", 435 | "dev": true, 436 | "requires": { 437 | "color-name": "1.1.3" 438 | } 439 | }, 440 | "color-name": { 441 | "version": "1.1.3", 442 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 443 | "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=", 444 | "dev": true 445 | }, 446 | "commander": { 447 | "version": "2.20.0", 448 | "resolved": "https://registry.npmjs.org/commander/-/commander-2.20.0.tgz", 449 | "integrity": "sha512-7j2y+40w61zy6YC2iRNpUe/NwhNyoXrYpHMrSunaMG64nRnaf96zO/KMQR4OyN/UnE5KLyEBnKHd4aG3rskjpQ==", 450 | "dev": true 451 | }, 452 | "component-emitter": { 453 | "version": "1.3.0", 454 | "resolved": "https://registry.npmjs.org/component-emitter/-/component-emitter-1.3.0.tgz", 455 | "integrity": "sha512-Rd3se6QB+sO1TwqZjscQrurpEPIfO0/yYnSin6Q/rD3mOutHvUrCAhJub3r90uNb+SESBuE0QYoB90YdfatsRg==", 456 | "dev": true 457 | }, 458 | "concat-map": { 459 | "version": "0.0.1", 460 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 461 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=", 462 | "dev": true 463 | }, 464 | "console-clear": { 465 | "version": "1.1.1", 466 | "resolved": "https://registry.npmjs.org/console-clear/-/console-clear-1.1.1.tgz", 467 | "integrity": "sha512-pMD+MVR538ipqkG5JXeOEbKWS5um1H4LUUccUQG68qpeqBYbzYy79Gh55jkd2TtPdRfUaLWdv6LPP//5Zt0aPQ==" 468 | }, 469 | "copy-descriptor": { 470 | "version": "0.1.1", 471 | "resolved": "https://registry.npmjs.org/copy-descriptor/-/copy-descriptor-0.1.1.tgz", 472 | "integrity": "sha1-Z29us8OZl8LuGsOpJP1hJHSPV40=", 473 | "dev": true 474 | }, 475 | "core-util-is": { 476 | "version": "1.0.2", 477 | "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.2.tgz", 478 | "integrity": "sha1-tf1UIgqivFq1eqtxQMlAdUUDwac=", 479 | "dev": true 480 | }, 481 | "cross-spawn": { 482 | "version": "6.0.5", 483 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-6.0.5.tgz", 484 | "integrity": "sha512-eTVLrBSt7fjbDygz805pMnstIs2VTBNkRm0qxZd+M7A5XDdxVRWO5MxGBXZhjY4cqLYLdtrGqRf8mBPmzwSpWQ==", 485 | "dev": true, 486 | "requires": { 487 | "nice-try": "^1.0.4", 488 | "path-key": "^2.0.1", 489 | "semver": "^5.5.0", 490 | "shebang-command": "^1.2.0", 491 | "which": "^1.2.9" 492 | } 493 | }, 494 | "debug": { 495 | "version": "2.6.9", 496 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 497 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 498 | "dev": true, 499 | "requires": { 500 | "ms": "2.0.0" 501 | } 502 | }, 503 | "decode-uri-component": { 504 | "version": "0.2.0", 505 | "resolved": "https://registry.npmjs.org/decode-uri-component/-/decode-uri-component-0.2.0.tgz", 506 | "integrity": "sha1-6zkTMzRYd1y4TNGh+uBiEGu4dUU=", 507 | "dev": true 508 | }, 509 | "deep-is": { 510 | "version": "0.1.3", 511 | "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.3.tgz", 512 | "integrity": "sha1-s2nW+128E+7PUk+RsHD+7cNXzzQ=", 513 | "dev": true 514 | }, 515 | "define-properties": { 516 | "version": "1.1.3", 517 | "resolved": "https://registry.npmjs.org/define-properties/-/define-properties-1.1.3.tgz", 518 | "integrity": "sha512-3MqfYKj2lLzdMSf8ZIZE/V+Zuy+BgD6f164e8K2w7dgnpKArBDerGYpM46IYYcjnkdPNMjPk9A6VFB8+3SKlXQ==", 519 | "dev": true, 520 | "requires": { 521 | "object-keys": "^1.0.12" 522 | } 523 | }, 524 | "define-property": { 525 | "version": "2.0.2", 526 | "resolved": "https://registry.npmjs.org/define-property/-/define-property-2.0.2.tgz", 527 | "integrity": "sha512-jwK2UV4cnPpbcG7+VRARKTZPUWowwXA8bzH5NP6ud0oeAxyYPuGZUAC7hMugpCdz4BeSZl2Dl9k66CHJ/46ZYQ==", 528 | "dev": true, 529 | "requires": { 530 | "is-descriptor": "^1.0.2", 531 | "isobject": "^3.0.1" 532 | }, 533 | "dependencies": { 534 | "is-accessor-descriptor": { 535 | "version": "1.0.0", 536 | "resolved": "https://registry.npmjs.org/is-accessor-descriptor/-/is-accessor-descriptor-1.0.0.tgz", 537 | "integrity": "sha512-m5hnHTkcVsPfqx3AKlyttIPb7J+XykHvJP2B9bZDjlhLIoEq4XoK64Vg7boZlVWYK6LUY94dYPEE7Lh0ZkZKcQ==", 538 | "dev": true, 539 | "requires": { 540 | "kind-of": "^6.0.0" 541 | } 542 | }, 543 | "is-data-descriptor": { 544 | "version": "1.0.0", 545 | "resolved": "https://registry.npmjs.org/is-data-descriptor/-/is-data-descriptor-1.0.0.tgz", 546 | "integrity": "sha512-jbRXy1FmtAoCjQkVmIVYwuuqDFUbaOeDjmed1tOGPrsMhtJA4rD9tkgA0F1qJ3gRFRXcHYVkdeaP50Q5rE/jLQ==", 547 | "dev": true, 548 | "requires": { 549 | "kind-of": "^6.0.0" 550 | } 551 | }, 552 | "is-descriptor": { 553 | "version": "1.0.2", 554 | "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-1.0.2.tgz", 555 | "integrity": "sha512-2eis5WqQGV7peooDyLmNEPUrps9+SXX5c9pL3xEB+4e9HnGuDa7mB7kHxHw4CbqS9k1T2hOH3miL8n8WtiYVtg==", 556 | "dev": true, 557 | "requires": { 558 | "is-accessor-descriptor": "^1.0.0", 559 | "is-data-descriptor": "^1.0.0", 560 | "kind-of": "^6.0.2" 561 | } 562 | } 563 | } 564 | }, 565 | "doctrine": { 566 | "version": "3.0.0", 567 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-3.0.0.tgz", 568 | "integrity": "sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w==", 569 | "dev": true, 570 | "requires": { 571 | "esutils": "^2.0.2" 572 | } 573 | }, 574 | "emoji-regex": { 575 | "version": "7.0.3", 576 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-7.0.3.tgz", 577 | "integrity": "sha512-CwBLREIQ7LvYFB0WyRvwhq5N5qPhc6PMjD6bYggFlI5YyDgl+0vxq5VHbMOFqLg7hfWzmu8T5Z1QofhmTIhItA==", 578 | "dev": true 579 | }, 580 | "error-ex": { 581 | "version": "1.3.2", 582 | "resolved": "https://registry.npmjs.org/error-ex/-/error-ex-1.3.2.tgz", 583 | "integrity": "sha512-7dFHNmqeFSEt2ZBsCriorKnn3Z2pj+fd9kmI6QoWw4//DL+icEBfc0U7qJCisqrTsKTjw4fNFy2pW9OqStD84g==", 584 | "dev": true, 585 | "requires": { 586 | "is-arrayish": "^0.2.1" 587 | } 588 | }, 589 | "es-abstract": { 590 | "version": "1.13.0", 591 | "resolved": "https://registry.npmjs.org/es-abstract/-/es-abstract-1.13.0.tgz", 592 | "integrity": "sha512-vDZfg/ykNxQVwup/8E1BZhVzFfBxs9NqMzGcvIJrqg5k2/5Za2bWo40dK2J1pgLngZ7c+Shh8lwYtLGyrwPutg==", 593 | "dev": true, 594 | "requires": { 595 | "es-to-primitive": "^1.2.0", 596 | "function-bind": "^1.1.1", 597 | "has": "^1.0.3", 598 | "is-callable": "^1.1.4", 599 | "is-regex": "^1.0.4", 600 | "object-keys": "^1.0.12" 601 | } 602 | }, 603 | "es-to-primitive": { 604 | "version": "1.2.0", 605 | "resolved": "https://registry.npmjs.org/es-to-primitive/-/es-to-primitive-1.2.0.tgz", 606 | "integrity": "sha512-qZryBOJjV//LaxLTV6UC//WewneB3LcXOL9NP++ozKVXsIIIpm/2c13UDiD9Jp2eThsecw9m3jPqDwTyobcdbg==", 607 | "dev": true, 608 | "requires": { 609 | "is-callable": "^1.1.4", 610 | "is-date-object": "^1.0.1", 611 | "is-symbol": "^1.0.2" 612 | } 613 | }, 614 | "escape-string-regexp": { 615 | "version": "1.0.5", 616 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", 617 | "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=", 618 | "dev": true 619 | }, 620 | "eslint": { 621 | "version": "6.0.1", 622 | "resolved": "https://registry.npmjs.org/eslint/-/eslint-6.0.1.tgz", 623 | "integrity": "sha512-DyQRaMmORQ+JsWShYsSg4OPTjY56u1nCjAmICrE8vLWqyLKxhFXOthwMj1SA8xwfrv0CofLNVnqbfyhwCkaO0w==", 624 | "dev": true, 625 | "requires": { 626 | "@babel/code-frame": "^7.0.0", 627 | "ajv": "^6.10.0", 628 | "chalk": "^2.1.0", 629 | "cross-spawn": "^6.0.5", 630 | "debug": "^4.0.1", 631 | "doctrine": "^3.0.0", 632 | "eslint-scope": "^4.0.3", 633 | "eslint-utils": "^1.3.1", 634 | "eslint-visitor-keys": "^1.0.0", 635 | "espree": "^6.0.0", 636 | "esquery": "^1.0.1", 637 | "esutils": "^2.0.2", 638 | "file-entry-cache": "^5.0.1", 639 | "functional-red-black-tree": "^1.0.1", 640 | "glob-parent": "^3.1.0", 641 | "globals": "^11.7.0", 642 | "ignore": "^4.0.6", 643 | "import-fresh": "^3.0.0", 644 | "imurmurhash": "^0.1.4", 645 | "inquirer": "^6.2.2", 646 | "is-glob": "^4.0.0", 647 | "js-yaml": "^3.13.1", 648 | "json-stable-stringify-without-jsonify": "^1.0.1", 649 | "levn": "^0.3.0", 650 | "lodash": "^4.17.11", 651 | "minimatch": "^3.0.4", 652 | "mkdirp": "^0.5.1", 653 | "natural-compare": "^1.4.0", 654 | "optionator": "^0.8.2", 655 | "progress": "^2.0.0", 656 | "regexpp": "^2.0.1", 657 | "semver": "^5.5.1", 658 | "strip-ansi": "^4.0.0", 659 | "strip-json-comments": "^2.0.1", 660 | "table": "^5.2.3", 661 | "text-table": "^0.2.0" 662 | }, 663 | "dependencies": { 664 | "debug": { 665 | "version": "4.1.1", 666 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.1.1.tgz", 667 | "integrity": "sha512-pYAIzeRo8J6KPEaJ0VWOh5Pzkbw/RetuzehGM7QRRX5he4fPHx2rdKMB256ehJCkX+XRQm16eZLqLNS8RSZXZw==", 668 | "dev": true, 669 | "requires": { 670 | "ms": "^2.1.1" 671 | } 672 | }, 673 | "ms": { 674 | "version": "2.1.2", 675 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 676 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 677 | "dev": true 678 | } 679 | } 680 | }, 681 | "eslint-config-prettier": { 682 | "version": "6.0.0", 683 | "resolved": "https://registry.npmjs.org/eslint-config-prettier/-/eslint-config-prettier-6.0.0.tgz", 684 | "integrity": "sha512-vDrcCFE3+2ixNT5H83g28bO/uYAwibJxerXPj+E7op4qzBCsAV36QfvdAyVOoNxKAH2Os/e01T/2x++V0LPukA==", 685 | "dev": true, 686 | "requires": { 687 | "get-stdin": "^6.0.0" 688 | } 689 | }, 690 | "eslint-plugin-prettier": { 691 | "version": "3.1.0", 692 | "resolved": "https://registry.npmjs.org/eslint-plugin-prettier/-/eslint-plugin-prettier-3.1.0.tgz", 693 | "integrity": "sha512-XWX2yVuwVNLOUhQijAkXz+rMPPoCr7WFiAl8ig6I7Xn+pPVhDhzg4DxHpmbeb0iqjO9UronEA3Tb09ChnFVHHA==", 694 | "dev": true, 695 | "requires": { 696 | "prettier-linter-helpers": "^1.0.0" 697 | } 698 | }, 699 | "eslint-plugin-svelte3": { 700 | "version": "2.2.2", 701 | "resolved": "https://registry.npmjs.org/eslint-plugin-svelte3/-/eslint-plugin-svelte3-2.2.2.tgz", 702 | "integrity": "sha512-7Fq5mF93D4kWmsBjq/l/BkNMHAONqDi5yJx272oGshMDMKdtO+aO0lbyOhGE1KWQhInF50VAnWFPbGl7paS2WA==", 703 | "dev": true 704 | }, 705 | "eslint-scope": { 706 | "version": "4.0.3", 707 | "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-4.0.3.tgz", 708 | "integrity": "sha512-p7VutNr1O/QrxysMo3E45FjYDTeXBy0iTltPFNSqKAIfjDSXC+4dj+qfyuD8bfAXrW/y6lW3O76VaYNPKfpKrg==", 709 | "dev": true, 710 | "requires": { 711 | "esrecurse": "^4.1.0", 712 | "estraverse": "^4.1.1" 713 | } 714 | }, 715 | "eslint-utils": { 716 | "version": "1.3.1", 717 | "resolved": "https://registry.npmjs.org/eslint-utils/-/eslint-utils-1.3.1.tgz", 718 | "integrity": "sha512-Z7YjnIldX+2XMcjr7ZkgEsOj/bREONV60qYeB/bjMAqqqZ4zxKyWX+BOUkdmRmA9riiIPVvo5x86m5elviOk0Q==", 719 | "dev": true 720 | }, 721 | "eslint-visitor-keys": { 722 | "version": "1.0.0", 723 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-1.0.0.tgz", 724 | "integrity": "sha512-qzm/XxIbxm/FHyH341ZrbnMUpe+5Bocte9xkmFMzPMjRaZMcXww+MpBptFvtU+79L362nqiLhekCxCxDPaUMBQ==", 725 | "dev": true 726 | }, 727 | "espree": { 728 | "version": "6.0.0", 729 | "resolved": "https://registry.npmjs.org/espree/-/espree-6.0.0.tgz", 730 | "integrity": "sha512-lJvCS6YbCn3ImT3yKkPe0+tJ+mH6ljhGNjHQH9mRtiO6gjhVAOhVXW1yjnwqGwTkK3bGbye+hb00nFNmu0l/1Q==", 731 | "dev": true, 732 | "requires": { 733 | "acorn": "^6.0.7", 734 | "acorn-jsx": "^5.0.0", 735 | "eslint-visitor-keys": "^1.0.0" 736 | } 737 | }, 738 | "esprima": { 739 | "version": "4.0.1", 740 | "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz", 741 | "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==", 742 | "dev": true 743 | }, 744 | "esquery": { 745 | "version": "1.0.1", 746 | "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.0.1.tgz", 747 | "integrity": "sha512-SmiyZ5zIWH9VM+SRUReLS5Q8a7GxtRdxEBVZpm98rJM7Sb+A9DVCndXfkeFUd3byderg+EbDkfnevfCwynWaNA==", 748 | "dev": true, 749 | "requires": { 750 | "estraverse": "^4.0.0" 751 | } 752 | }, 753 | "esrecurse": { 754 | "version": "4.2.1", 755 | "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.2.1.tgz", 756 | "integrity": "sha512-64RBB++fIOAXPw3P9cy89qfMlvZEXZkqqJkjqqXIvzP5ezRZjW+lPWjw35UX/3EhUPFYbg5ER4JYgDw4007/DQ==", 757 | "dev": true, 758 | "requires": { 759 | "estraverse": "^4.1.0" 760 | } 761 | }, 762 | "estraverse": { 763 | "version": "4.2.0", 764 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-4.2.0.tgz", 765 | "integrity": "sha1-De4/7TH81GlhjOc0IJn8GvoL2xM=", 766 | "dev": true 767 | }, 768 | "estree-walker": { 769 | "version": "0.6.1", 770 | "resolved": "https://registry.npmjs.org/estree-walker/-/estree-walker-0.6.1.tgz", 771 | "integrity": "sha512-SqmZANLWS0mnatqbSfRP5g8OXZC12Fgg1IwNtLsyHDzJizORW4khDfjPqJZsemPWBB2uqykUah5YpQ6epsqC/w==", 772 | "dev": true 773 | }, 774 | "esutils": { 775 | "version": "2.0.2", 776 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.2.tgz", 777 | "integrity": "sha1-Cr9PHKpbyx96nYrMbepPqqBLrJs=", 778 | "dev": true 779 | }, 780 | "expand-brackets": { 781 | "version": "2.1.4", 782 | "resolved": "https://registry.npmjs.org/expand-brackets/-/expand-brackets-2.1.4.tgz", 783 | "integrity": "sha1-t3c14xXOMPa27/D4OwQVGiJEliI=", 784 | "dev": true, 785 | "requires": { 786 | "debug": "^2.3.3", 787 | "define-property": "^0.2.5", 788 | "extend-shallow": "^2.0.1", 789 | "posix-character-classes": "^0.1.0", 790 | "regex-not": "^1.0.0", 791 | "snapdragon": "^0.8.1", 792 | "to-regex": "^3.0.1" 793 | }, 794 | "dependencies": { 795 | "define-property": { 796 | "version": "0.2.5", 797 | "resolved": "https://registry.npmjs.org/define-property/-/define-property-0.2.5.tgz", 798 | "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=", 799 | "dev": true, 800 | "requires": { 801 | "is-descriptor": "^0.1.0" 802 | } 803 | }, 804 | "extend-shallow": { 805 | "version": "2.0.1", 806 | "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", 807 | "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", 808 | "dev": true, 809 | "requires": { 810 | "is-extendable": "^0.1.0" 811 | } 812 | } 813 | } 814 | }, 815 | "extend-shallow": { 816 | "version": "3.0.2", 817 | "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-3.0.2.tgz", 818 | "integrity": "sha1-Jqcarwc7OfshJxcnRhMcJwQCjbg=", 819 | "dev": true, 820 | "requires": { 821 | "assign-symbols": "^1.0.0", 822 | "is-extendable": "^1.0.1" 823 | }, 824 | "dependencies": { 825 | "is-extendable": { 826 | "version": "1.0.1", 827 | "resolved": "https://registry.npmjs.org/is-extendable/-/is-extendable-1.0.1.tgz", 828 | "integrity": "sha512-arnXMxT1hhoKo9k1LZdmlNyJdDDfy2v0fXjFlmok4+i8ul/6WlbVge9bhM74OpNPQPMGUToDtz+KXa1PneJxOA==", 829 | "dev": true, 830 | "requires": { 831 | "is-plain-object": "^2.0.4" 832 | } 833 | } 834 | } 835 | }, 836 | "external-editor": { 837 | "version": "3.0.3", 838 | "resolved": "https://registry.npmjs.org/external-editor/-/external-editor-3.0.3.tgz", 839 | "integrity": "sha512-bn71H9+qWoOQKyZDo25mOMVpSmXROAsTJVVVYzrrtol3d4y+AsKjf4Iwl2Q+IuT0kFSQ1qo166UuIwqYq7mGnA==", 840 | "dev": true, 841 | "requires": { 842 | "chardet": "^0.7.0", 843 | "iconv-lite": "^0.4.24", 844 | "tmp": "^0.0.33" 845 | } 846 | }, 847 | "extglob": { 848 | "version": "2.0.4", 849 | "resolved": "https://registry.npmjs.org/extglob/-/extglob-2.0.4.tgz", 850 | "integrity": "sha512-Nmb6QXkELsuBr24CJSkilo6UHHgbekK5UiZgfE6UHD3Eb27YC6oD+bhcT+tJ6cl8dmsgdQxnWlcry8ksBIBLpw==", 851 | "dev": true, 852 | "requires": { 853 | "array-unique": "^0.3.2", 854 | "define-property": "^1.0.0", 855 | "expand-brackets": "^2.1.4", 856 | "extend-shallow": "^2.0.1", 857 | "fragment-cache": "^0.2.1", 858 | "regex-not": "^1.0.0", 859 | "snapdragon": "^0.8.1", 860 | "to-regex": "^3.0.1" 861 | }, 862 | "dependencies": { 863 | "define-property": { 864 | "version": "1.0.0", 865 | "resolved": "https://registry.npmjs.org/define-property/-/define-property-1.0.0.tgz", 866 | "integrity": "sha1-dp66rz9KY6rTr56NMEybvnm/sOY=", 867 | "dev": true, 868 | "requires": { 869 | "is-descriptor": "^1.0.0" 870 | } 871 | }, 872 | "extend-shallow": { 873 | "version": "2.0.1", 874 | "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", 875 | "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", 876 | "dev": true, 877 | "requires": { 878 | "is-extendable": "^0.1.0" 879 | } 880 | }, 881 | "is-accessor-descriptor": { 882 | "version": "1.0.0", 883 | "resolved": "https://registry.npmjs.org/is-accessor-descriptor/-/is-accessor-descriptor-1.0.0.tgz", 884 | "integrity": "sha512-m5hnHTkcVsPfqx3AKlyttIPb7J+XykHvJP2B9bZDjlhLIoEq4XoK64Vg7boZlVWYK6LUY94dYPEE7Lh0ZkZKcQ==", 885 | "dev": true, 886 | "requires": { 887 | "kind-of": "^6.0.0" 888 | } 889 | }, 890 | "is-data-descriptor": { 891 | "version": "1.0.0", 892 | "resolved": "https://registry.npmjs.org/is-data-descriptor/-/is-data-descriptor-1.0.0.tgz", 893 | "integrity": "sha512-jbRXy1FmtAoCjQkVmIVYwuuqDFUbaOeDjmed1tOGPrsMhtJA4rD9tkgA0F1qJ3gRFRXcHYVkdeaP50Q5rE/jLQ==", 894 | "dev": true, 895 | "requires": { 896 | "kind-of": "^6.0.0" 897 | } 898 | }, 899 | "is-descriptor": { 900 | "version": "1.0.2", 901 | "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-1.0.2.tgz", 902 | "integrity": "sha512-2eis5WqQGV7peooDyLmNEPUrps9+SXX5c9pL3xEB+4e9HnGuDa7mB7kHxHw4CbqS9k1T2hOH3miL8n8WtiYVtg==", 903 | "dev": true, 904 | "requires": { 905 | "is-accessor-descriptor": "^1.0.0", 906 | "is-data-descriptor": "^1.0.0", 907 | "kind-of": "^6.0.2" 908 | } 909 | } 910 | } 911 | }, 912 | "faker": { 913 | "version": "4.1.0", 914 | "resolved": "https://registry.npmjs.org/faker/-/faker-4.1.0.tgz", 915 | "integrity": "sha1-HkW7vsxndLPBlfrSg1EJxtdIzD8=" 916 | }, 917 | "fast-deep-equal": { 918 | "version": "2.0.1", 919 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-2.0.1.tgz", 920 | "integrity": "sha1-ewUhjd+WZ79/Nwv3/bLLFf3Qqkk=", 921 | "dev": true 922 | }, 923 | "fast-diff": { 924 | "version": "1.2.0", 925 | "resolved": "https://registry.npmjs.org/fast-diff/-/fast-diff-1.2.0.tgz", 926 | "integrity": "sha512-xJuoT5+L99XlZ8twedaRf6Ax2TgQVxvgZOYoPKqZufmJib0tL2tegPBOZb1pVNgIhlqDlA0eO0c3wBvQcmzx4w==", 927 | "dev": true 928 | }, 929 | "fast-json-stable-stringify": { 930 | "version": "2.0.0", 931 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.0.0.tgz", 932 | "integrity": "sha1-1RQsDK7msRifh9OnYREGT4bIu/I=", 933 | "dev": true 934 | }, 935 | "fast-levenshtein": { 936 | "version": "2.0.6", 937 | "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", 938 | "integrity": "sha1-PYpcZog6FqMMqGQ+hR8Zuqd5eRc=", 939 | "dev": true 940 | }, 941 | "figures": { 942 | "version": "2.0.0", 943 | "resolved": "https://registry.npmjs.org/figures/-/figures-2.0.0.tgz", 944 | "integrity": "sha1-OrGi0qYsi/tDGgyUy3l6L84nyWI=", 945 | "dev": true, 946 | "requires": { 947 | "escape-string-regexp": "^1.0.5" 948 | } 949 | }, 950 | "file-entry-cache": { 951 | "version": "5.0.1", 952 | "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-5.0.1.tgz", 953 | "integrity": "sha512-bCg29ictuBaKUwwArK4ouCaqDgLZcysCFLmM/Yn/FDoqndh/9vNuQfXRDvTuXKLxfD/JtZQGKFT8MGcJBK644g==", 954 | "dev": true, 955 | "requires": { 956 | "flat-cache": "^2.0.1" 957 | } 958 | }, 959 | "fill-range": { 960 | "version": "4.0.0", 961 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-4.0.0.tgz", 962 | "integrity": "sha1-1USBHUKPmOsGpj3EAtJAPDKMOPc=", 963 | "dev": true, 964 | "requires": { 965 | "extend-shallow": "^2.0.1", 966 | "is-number": "^3.0.0", 967 | "repeat-string": "^1.6.1", 968 | "to-regex-range": "^2.1.0" 969 | }, 970 | "dependencies": { 971 | "extend-shallow": { 972 | "version": "2.0.1", 973 | "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", 974 | "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", 975 | "dev": true, 976 | "requires": { 977 | "is-extendable": "^0.1.0" 978 | } 979 | } 980 | } 981 | }, 982 | "flat-cache": { 983 | "version": "2.0.1", 984 | "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-2.0.1.tgz", 985 | "integrity": "sha512-LoQe6yDuUMDzQAEH8sgmh4Md6oZnc/7PjtwjNFSzveXqSHt6ka9fPBuso7IGf9Rz4uqnSnWiFH2B/zj24a5ReA==", 986 | "dev": true, 987 | "requires": { 988 | "flatted": "^2.0.0", 989 | "rimraf": "2.6.3", 990 | "write": "1.0.3" 991 | } 992 | }, 993 | "flatted": { 994 | "version": "2.0.1", 995 | "resolved": "https://registry.npmjs.org/flatted/-/flatted-2.0.1.tgz", 996 | "integrity": "sha512-a1hQMktqW9Nmqr5aktAux3JMNqaucxGcjtjWnZLHX7yyPCmlSV3M54nGYbqT8K+0GhF3NBgmJCc3ma+WOgX8Jg==", 997 | "dev": true 998 | }, 999 | "for-in": { 1000 | "version": "1.0.2", 1001 | "resolved": "https://registry.npmjs.org/for-in/-/for-in-1.0.2.tgz", 1002 | "integrity": "sha1-gQaNKVqBQuwKxybG4iAMMPttXoA=", 1003 | "dev": true 1004 | }, 1005 | "fragment-cache": { 1006 | "version": "0.2.1", 1007 | "resolved": "https://registry.npmjs.org/fragment-cache/-/fragment-cache-0.2.1.tgz", 1008 | "integrity": "sha1-QpD60n8T6Jvn8zeZxrxaCr//DRk=", 1009 | "dev": true, 1010 | "requires": { 1011 | "map-cache": "^0.2.2" 1012 | } 1013 | }, 1014 | "fs.realpath": { 1015 | "version": "1.0.0", 1016 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 1017 | "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=", 1018 | "dev": true 1019 | }, 1020 | "fsevents": { 1021 | "version": "1.2.9", 1022 | "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-1.2.9.tgz", 1023 | "integrity": "sha512-oeyj2H3EjjonWcFjD5NvZNE9Rqe4UW+nQBU2HNeKw0koVLEFIhtyETyAakeAM3de7Z/SW5kcA+fZUait9EApnw==", 1024 | "dev": true, 1025 | "optional": true, 1026 | "requires": { 1027 | "nan": "^2.12.1", 1028 | "node-pre-gyp": "^0.12.0" 1029 | }, 1030 | "dependencies": { 1031 | "abbrev": { 1032 | "version": "1.1.1", 1033 | "bundled": true, 1034 | "dev": true, 1035 | "optional": true 1036 | }, 1037 | "ansi-regex": { 1038 | "version": "2.1.1", 1039 | "bundled": true, 1040 | "dev": true 1041 | }, 1042 | "aproba": { 1043 | "version": "1.2.0", 1044 | "bundled": true, 1045 | "dev": true, 1046 | "optional": true 1047 | }, 1048 | "are-we-there-yet": { 1049 | "version": "1.1.5", 1050 | "bundled": true, 1051 | "dev": true, 1052 | "optional": true, 1053 | "requires": { 1054 | "delegates": "^1.0.0", 1055 | "readable-stream": "^2.0.6" 1056 | } 1057 | }, 1058 | "balanced-match": { 1059 | "version": "1.0.0", 1060 | "bundled": true, 1061 | "dev": true 1062 | }, 1063 | "brace-expansion": { 1064 | "version": "1.1.11", 1065 | "bundled": true, 1066 | "dev": true, 1067 | "requires": { 1068 | "balanced-match": "^1.0.0", 1069 | "concat-map": "0.0.1" 1070 | } 1071 | }, 1072 | "chownr": { 1073 | "version": "1.1.1", 1074 | "bundled": true, 1075 | "dev": true, 1076 | "optional": true 1077 | }, 1078 | "code-point-at": { 1079 | "version": "1.1.0", 1080 | "bundled": true, 1081 | "dev": true 1082 | }, 1083 | "concat-map": { 1084 | "version": "0.0.1", 1085 | "bundled": true, 1086 | "dev": true 1087 | }, 1088 | "console-control-strings": { 1089 | "version": "1.1.0", 1090 | "bundled": true, 1091 | "dev": true 1092 | }, 1093 | "core-util-is": { 1094 | "version": "1.0.2", 1095 | "bundled": true, 1096 | "dev": true, 1097 | "optional": true 1098 | }, 1099 | "debug": { 1100 | "version": "4.1.1", 1101 | "bundled": true, 1102 | "dev": true, 1103 | "optional": true, 1104 | "requires": { 1105 | "ms": "^2.1.1" 1106 | } 1107 | }, 1108 | "deep-extend": { 1109 | "version": "0.6.0", 1110 | "bundled": true, 1111 | "dev": true, 1112 | "optional": true 1113 | }, 1114 | "delegates": { 1115 | "version": "1.0.0", 1116 | "bundled": true, 1117 | "dev": true, 1118 | "optional": true 1119 | }, 1120 | "detect-libc": { 1121 | "version": "1.0.3", 1122 | "bundled": true, 1123 | "dev": true, 1124 | "optional": true 1125 | }, 1126 | "fs-minipass": { 1127 | "version": "1.2.5", 1128 | "bundled": true, 1129 | "dev": true, 1130 | "optional": true, 1131 | "requires": { 1132 | "minipass": "^2.2.1" 1133 | } 1134 | }, 1135 | "fs.realpath": { 1136 | "version": "1.0.0", 1137 | "bundled": true, 1138 | "dev": true, 1139 | "optional": true 1140 | }, 1141 | "gauge": { 1142 | "version": "2.7.4", 1143 | "bundled": true, 1144 | "dev": true, 1145 | "optional": true, 1146 | "requires": { 1147 | "aproba": "^1.0.3", 1148 | "console-control-strings": "^1.0.0", 1149 | "has-unicode": "^2.0.0", 1150 | "object-assign": "^4.1.0", 1151 | "signal-exit": "^3.0.0", 1152 | "string-width": "^1.0.1", 1153 | "strip-ansi": "^3.0.1", 1154 | "wide-align": "^1.1.0" 1155 | } 1156 | }, 1157 | "glob": { 1158 | "version": "7.1.3", 1159 | "bundled": true, 1160 | "dev": true, 1161 | "optional": true, 1162 | "requires": { 1163 | "fs.realpath": "^1.0.0", 1164 | "inflight": "^1.0.4", 1165 | "inherits": "2", 1166 | "minimatch": "^3.0.4", 1167 | "once": "^1.3.0", 1168 | "path-is-absolute": "^1.0.0" 1169 | } 1170 | }, 1171 | "has-unicode": { 1172 | "version": "2.0.1", 1173 | "bundled": true, 1174 | "dev": true, 1175 | "optional": true 1176 | }, 1177 | "iconv-lite": { 1178 | "version": "0.4.24", 1179 | "bundled": true, 1180 | "dev": true, 1181 | "optional": true, 1182 | "requires": { 1183 | "safer-buffer": ">= 2.1.2 < 3" 1184 | } 1185 | }, 1186 | "ignore-walk": { 1187 | "version": "3.0.1", 1188 | "bundled": true, 1189 | "dev": true, 1190 | "optional": true, 1191 | "requires": { 1192 | "minimatch": "^3.0.4" 1193 | } 1194 | }, 1195 | "inflight": { 1196 | "version": "1.0.6", 1197 | "bundled": true, 1198 | "dev": true, 1199 | "optional": true, 1200 | "requires": { 1201 | "once": "^1.3.0", 1202 | "wrappy": "1" 1203 | } 1204 | }, 1205 | "inherits": { 1206 | "version": "2.0.3", 1207 | "bundled": true, 1208 | "dev": true 1209 | }, 1210 | "ini": { 1211 | "version": "1.3.5", 1212 | "bundled": true, 1213 | "dev": true, 1214 | "optional": true 1215 | }, 1216 | "is-fullwidth-code-point": { 1217 | "version": "1.0.0", 1218 | "bundled": true, 1219 | "dev": true, 1220 | "requires": { 1221 | "number-is-nan": "^1.0.0" 1222 | } 1223 | }, 1224 | "isarray": { 1225 | "version": "1.0.0", 1226 | "bundled": true, 1227 | "dev": true, 1228 | "optional": true 1229 | }, 1230 | "minimatch": { 1231 | "version": "3.0.4", 1232 | "bundled": true, 1233 | "dev": true, 1234 | "requires": { 1235 | "brace-expansion": "^1.1.7" 1236 | } 1237 | }, 1238 | "minimist": { 1239 | "version": "0.0.8", 1240 | "bundled": true, 1241 | "dev": true 1242 | }, 1243 | "minipass": { 1244 | "version": "2.3.5", 1245 | "bundled": true, 1246 | "dev": true, 1247 | "requires": { 1248 | "safe-buffer": "^5.1.2", 1249 | "yallist": "^3.0.0" 1250 | } 1251 | }, 1252 | "minizlib": { 1253 | "version": "1.2.1", 1254 | "bundled": true, 1255 | "dev": true, 1256 | "optional": true, 1257 | "requires": { 1258 | "minipass": "^2.2.1" 1259 | } 1260 | }, 1261 | "mkdirp": { 1262 | "version": "0.5.1", 1263 | "bundled": true, 1264 | "dev": true, 1265 | "requires": { 1266 | "minimist": "0.0.8" 1267 | } 1268 | }, 1269 | "ms": { 1270 | "version": "2.1.1", 1271 | "bundled": true, 1272 | "dev": true, 1273 | "optional": true 1274 | }, 1275 | "needle": { 1276 | "version": "2.3.0", 1277 | "bundled": true, 1278 | "dev": true, 1279 | "optional": true, 1280 | "requires": { 1281 | "debug": "^4.1.0", 1282 | "iconv-lite": "^0.4.4", 1283 | "sax": "^1.2.4" 1284 | } 1285 | }, 1286 | "node-pre-gyp": { 1287 | "version": "0.12.0", 1288 | "bundled": true, 1289 | "dev": true, 1290 | "optional": true, 1291 | "requires": { 1292 | "detect-libc": "^1.0.2", 1293 | "mkdirp": "^0.5.1", 1294 | "needle": "^2.2.1", 1295 | "nopt": "^4.0.1", 1296 | "npm-packlist": "^1.1.6", 1297 | "npmlog": "^4.0.2", 1298 | "rc": "^1.2.7", 1299 | "rimraf": "^2.6.1", 1300 | "semver": "^5.3.0", 1301 | "tar": "^4" 1302 | } 1303 | }, 1304 | "nopt": { 1305 | "version": "4.0.1", 1306 | "bundled": true, 1307 | "dev": true, 1308 | "optional": true, 1309 | "requires": { 1310 | "abbrev": "1", 1311 | "osenv": "^0.1.4" 1312 | } 1313 | }, 1314 | "npm-bundled": { 1315 | "version": "1.0.6", 1316 | "bundled": true, 1317 | "dev": true, 1318 | "optional": true 1319 | }, 1320 | "npm-packlist": { 1321 | "version": "1.4.1", 1322 | "bundled": true, 1323 | "dev": true, 1324 | "optional": true, 1325 | "requires": { 1326 | "ignore-walk": "^3.0.1", 1327 | "npm-bundled": "^1.0.1" 1328 | } 1329 | }, 1330 | "npmlog": { 1331 | "version": "4.1.2", 1332 | "bundled": true, 1333 | "dev": true, 1334 | "optional": true, 1335 | "requires": { 1336 | "are-we-there-yet": "~1.1.2", 1337 | "console-control-strings": "~1.1.0", 1338 | "gauge": "~2.7.3", 1339 | "set-blocking": "~2.0.0" 1340 | } 1341 | }, 1342 | "number-is-nan": { 1343 | "version": "1.0.1", 1344 | "bundled": true, 1345 | "dev": true 1346 | }, 1347 | "object-assign": { 1348 | "version": "4.1.1", 1349 | "bundled": true, 1350 | "dev": true, 1351 | "optional": true 1352 | }, 1353 | "once": { 1354 | "version": "1.4.0", 1355 | "bundled": true, 1356 | "dev": true, 1357 | "requires": { 1358 | "wrappy": "1" 1359 | } 1360 | }, 1361 | "os-homedir": { 1362 | "version": "1.0.2", 1363 | "bundled": true, 1364 | "dev": true, 1365 | "optional": true 1366 | }, 1367 | "os-tmpdir": { 1368 | "version": "1.0.2", 1369 | "bundled": true, 1370 | "dev": true, 1371 | "optional": true 1372 | }, 1373 | "osenv": { 1374 | "version": "0.1.5", 1375 | "bundled": true, 1376 | "dev": true, 1377 | "optional": true, 1378 | "requires": { 1379 | "os-homedir": "^1.0.0", 1380 | "os-tmpdir": "^1.0.0" 1381 | } 1382 | }, 1383 | "path-is-absolute": { 1384 | "version": "1.0.1", 1385 | "bundled": true, 1386 | "dev": true, 1387 | "optional": true 1388 | }, 1389 | "process-nextick-args": { 1390 | "version": "2.0.0", 1391 | "bundled": true, 1392 | "dev": true, 1393 | "optional": true 1394 | }, 1395 | "rc": { 1396 | "version": "1.2.8", 1397 | "bundled": true, 1398 | "dev": true, 1399 | "optional": true, 1400 | "requires": { 1401 | "deep-extend": "^0.6.0", 1402 | "ini": "~1.3.0", 1403 | "minimist": "^1.2.0", 1404 | "strip-json-comments": "~2.0.1" 1405 | }, 1406 | "dependencies": { 1407 | "minimist": { 1408 | "version": "1.2.0", 1409 | "bundled": true, 1410 | "dev": true, 1411 | "optional": true 1412 | } 1413 | } 1414 | }, 1415 | "readable-stream": { 1416 | "version": "2.3.6", 1417 | "bundled": true, 1418 | "dev": true, 1419 | "optional": true, 1420 | "requires": { 1421 | "core-util-is": "~1.0.0", 1422 | "inherits": "~2.0.3", 1423 | "isarray": "~1.0.0", 1424 | "process-nextick-args": "~2.0.0", 1425 | "safe-buffer": "~5.1.1", 1426 | "string_decoder": "~1.1.1", 1427 | "util-deprecate": "~1.0.1" 1428 | } 1429 | }, 1430 | "rimraf": { 1431 | "version": "2.6.3", 1432 | "bundled": true, 1433 | "dev": true, 1434 | "optional": true, 1435 | "requires": { 1436 | "glob": "^7.1.3" 1437 | } 1438 | }, 1439 | "safe-buffer": { 1440 | "version": "5.1.2", 1441 | "bundled": true, 1442 | "dev": true 1443 | }, 1444 | "safer-buffer": { 1445 | "version": "2.1.2", 1446 | "bundled": true, 1447 | "dev": true, 1448 | "optional": true 1449 | }, 1450 | "sax": { 1451 | "version": "1.2.4", 1452 | "bundled": true, 1453 | "dev": true, 1454 | "optional": true 1455 | }, 1456 | "semver": { 1457 | "version": "5.7.0", 1458 | "bundled": true, 1459 | "dev": true, 1460 | "optional": true 1461 | }, 1462 | "set-blocking": { 1463 | "version": "2.0.0", 1464 | "bundled": true, 1465 | "dev": true, 1466 | "optional": true 1467 | }, 1468 | "signal-exit": { 1469 | "version": "3.0.2", 1470 | "bundled": true, 1471 | "dev": true, 1472 | "optional": true 1473 | }, 1474 | "string-width": { 1475 | "version": "1.0.2", 1476 | "bundled": true, 1477 | "dev": true, 1478 | "requires": { 1479 | "code-point-at": "^1.0.0", 1480 | "is-fullwidth-code-point": "^1.0.0", 1481 | "strip-ansi": "^3.0.0" 1482 | } 1483 | }, 1484 | "string_decoder": { 1485 | "version": "1.1.1", 1486 | "bundled": true, 1487 | "dev": true, 1488 | "optional": true, 1489 | "requires": { 1490 | "safe-buffer": "~5.1.0" 1491 | } 1492 | }, 1493 | "strip-ansi": { 1494 | "version": "3.0.1", 1495 | "bundled": true, 1496 | "dev": true, 1497 | "requires": { 1498 | "ansi-regex": "^2.0.0" 1499 | } 1500 | }, 1501 | "strip-json-comments": { 1502 | "version": "2.0.1", 1503 | "bundled": true, 1504 | "dev": true, 1505 | "optional": true 1506 | }, 1507 | "tar": { 1508 | "version": "4.4.8", 1509 | "bundled": true, 1510 | "dev": true, 1511 | "optional": true, 1512 | "requires": { 1513 | "chownr": "^1.1.1", 1514 | "fs-minipass": "^1.2.5", 1515 | "minipass": "^2.3.4", 1516 | "minizlib": "^1.1.1", 1517 | "mkdirp": "^0.5.0", 1518 | "safe-buffer": "^5.1.2", 1519 | "yallist": "^3.0.2" 1520 | } 1521 | }, 1522 | "util-deprecate": { 1523 | "version": "1.0.2", 1524 | "bundled": true, 1525 | "dev": true, 1526 | "optional": true 1527 | }, 1528 | "wide-align": { 1529 | "version": "1.1.3", 1530 | "bundled": true, 1531 | "dev": true, 1532 | "optional": true, 1533 | "requires": { 1534 | "string-width": "^1.0.2 || 2" 1535 | } 1536 | }, 1537 | "wrappy": { 1538 | "version": "1.0.2", 1539 | "bundled": true, 1540 | "dev": true 1541 | }, 1542 | "yallist": { 1543 | "version": "3.0.3", 1544 | "bundled": true, 1545 | "dev": true 1546 | } 1547 | } 1548 | }, 1549 | "function-bind": { 1550 | "version": "1.1.1", 1551 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", 1552 | "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==", 1553 | "dev": true 1554 | }, 1555 | "functional-red-black-tree": { 1556 | "version": "1.0.1", 1557 | "resolved": "https://registry.npmjs.org/functional-red-black-tree/-/functional-red-black-tree-1.0.1.tgz", 1558 | "integrity": "sha1-GwqzvVU7Kg1jmdKcDj6gslIHgyc=", 1559 | "dev": true 1560 | }, 1561 | "get-port": { 1562 | "version": "3.2.0", 1563 | "resolved": "https://registry.npmjs.org/get-port/-/get-port-3.2.0.tgz", 1564 | "integrity": "sha1-3Xzn3hh8Bsi/NTeWrHHgmfCYDrw=" 1565 | }, 1566 | "get-stdin": { 1567 | "version": "6.0.0", 1568 | "resolved": "https://registry.npmjs.org/get-stdin/-/get-stdin-6.0.0.tgz", 1569 | "integrity": "sha512-jp4tHawyV7+fkkSKyvjuLZswblUtz+SQKzSWnBbii16BuZksJlU1wuBYXY75r+duh/llF1ur6oNwi+2ZzjKZ7g==", 1570 | "dev": true 1571 | }, 1572 | "get-value": { 1573 | "version": "2.0.6", 1574 | "resolved": "https://registry.npmjs.org/get-value/-/get-value-2.0.6.tgz", 1575 | "integrity": "sha1-3BXKHGcjh8p2vTesCjlbogQqLCg=", 1576 | "dev": true 1577 | }, 1578 | "glob": { 1579 | "version": "7.1.4", 1580 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.4.tgz", 1581 | "integrity": "sha512-hkLPepehmnKk41pUGm3sYxoFs/umurYfYJCerbXEyFIWcAzvpipAgVkBqqT9RBKMGjnq6kMuyYwha6csxbiM1A==", 1582 | "dev": true, 1583 | "requires": { 1584 | "fs.realpath": "^1.0.0", 1585 | "inflight": "^1.0.4", 1586 | "inherits": "2", 1587 | "minimatch": "^3.0.4", 1588 | "once": "^1.3.0", 1589 | "path-is-absolute": "^1.0.0" 1590 | } 1591 | }, 1592 | "glob-parent": { 1593 | "version": "3.1.0", 1594 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-3.1.0.tgz", 1595 | "integrity": "sha1-nmr2KZ2NO9K9QEMIMr0RPfkGxa4=", 1596 | "dev": true, 1597 | "requires": { 1598 | "is-glob": "^3.1.0", 1599 | "path-dirname": "^1.0.0" 1600 | }, 1601 | "dependencies": { 1602 | "is-glob": { 1603 | "version": "3.1.0", 1604 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-3.1.0.tgz", 1605 | "integrity": "sha1-e6WuJCF4BKxwcHuWkiVnSGzD6Eo=", 1606 | "dev": true, 1607 | "requires": { 1608 | "is-extglob": "^2.1.0" 1609 | } 1610 | } 1611 | } 1612 | }, 1613 | "globals": { 1614 | "version": "11.12.0", 1615 | "resolved": "https://registry.npmjs.org/globals/-/globals-11.12.0.tgz", 1616 | "integrity": "sha512-WOBp/EEGUiIsJSp7wcv/y6MO+lV9UoncWqxuFfm8eBwzWNgyfBd6Gz+IeKQ9jCmyhoH99g15M3T+QaVHFjizVA==", 1617 | "dev": true 1618 | }, 1619 | "graceful-fs": { 1620 | "version": "4.1.15", 1621 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.1.15.tgz", 1622 | "integrity": "sha512-6uHUhOPEBgQ24HM+r6b/QwWfZq+yiFcipKFrOFiBEnWdy5sdzYoi+pJeQaPI5qOLRFqWmAXUPQNsielzdLoecA==", 1623 | "dev": true 1624 | }, 1625 | "has": { 1626 | "version": "1.0.3", 1627 | "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", 1628 | "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", 1629 | "dev": true, 1630 | "requires": { 1631 | "function-bind": "^1.1.1" 1632 | } 1633 | }, 1634 | "has-flag": { 1635 | "version": "3.0.0", 1636 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 1637 | "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=", 1638 | "dev": true 1639 | }, 1640 | "has-symbols": { 1641 | "version": "1.0.0", 1642 | "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.0.tgz", 1643 | "integrity": "sha1-uhqPGvKg/DllD1yFA2dwQSIGO0Q=", 1644 | "dev": true 1645 | }, 1646 | "has-value": { 1647 | "version": "1.0.0", 1648 | "resolved": "https://registry.npmjs.org/has-value/-/has-value-1.0.0.tgz", 1649 | "integrity": "sha1-GLKB2lhbHFxR3vJMkw7SmgvmsXc=", 1650 | "dev": true, 1651 | "requires": { 1652 | "get-value": "^2.0.6", 1653 | "has-values": "^1.0.0", 1654 | "isobject": "^3.0.0" 1655 | } 1656 | }, 1657 | "has-values": { 1658 | "version": "1.0.0", 1659 | "resolved": "https://registry.npmjs.org/has-values/-/has-values-1.0.0.tgz", 1660 | "integrity": "sha1-lbC2P+whRmGab+V/51Yo1aOe/k8=", 1661 | "dev": true, 1662 | "requires": { 1663 | "is-number": "^3.0.0", 1664 | "kind-of": "^4.0.0" 1665 | }, 1666 | "dependencies": { 1667 | "kind-of": { 1668 | "version": "4.0.0", 1669 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-4.0.0.tgz", 1670 | "integrity": "sha1-IIE989cSkosgc3hpGkUGb65y3Vc=", 1671 | "dev": true, 1672 | "requires": { 1673 | "is-buffer": "^1.1.5" 1674 | } 1675 | } 1676 | } 1677 | }, 1678 | "hosted-git-info": { 1679 | "version": "2.7.1", 1680 | "resolved": "https://registry.npmjs.org/hosted-git-info/-/hosted-git-info-2.7.1.tgz", 1681 | "integrity": "sha512-7T/BxH19zbcCTa8XkMlbK5lTo1WtgkFi3GvdWEyNuc4Vex7/9Dqbnpsf4JMydcfj9HCg4zUWFTL3Za6lapg5/w==", 1682 | "dev": true 1683 | }, 1684 | "iconv-lite": { 1685 | "version": "0.4.24", 1686 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", 1687 | "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", 1688 | "dev": true, 1689 | "requires": { 1690 | "safer-buffer": ">= 2.1.2 < 3" 1691 | } 1692 | }, 1693 | "ignore": { 1694 | "version": "4.0.6", 1695 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-4.0.6.tgz", 1696 | "integrity": "sha512-cyFDKrqc/YdcWFniJhzI42+AzS+gNwmUzOSFcRCQYwySuBBBy/KjuxWLZ/FHEH6Moq1NizMOBWyTcv8O4OZIMg==", 1697 | "dev": true 1698 | }, 1699 | "import-fresh": { 1700 | "version": "3.0.0", 1701 | "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.0.0.tgz", 1702 | "integrity": "sha512-pOnA9tfM3Uwics+SaBLCNyZZZbK+4PTu0OPZtLlMIrv17EdBoC15S9Kn8ckJ9TZTyKb3ywNE5y1yeDxxGA7nTQ==", 1703 | "dev": true, 1704 | "requires": { 1705 | "parent-module": "^1.0.0", 1706 | "resolve-from": "^4.0.0" 1707 | } 1708 | }, 1709 | "imurmurhash": { 1710 | "version": "0.1.4", 1711 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 1712 | "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=", 1713 | "dev": true 1714 | }, 1715 | "inflight": { 1716 | "version": "1.0.6", 1717 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 1718 | "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", 1719 | "dev": true, 1720 | "requires": { 1721 | "once": "^1.3.0", 1722 | "wrappy": "1" 1723 | } 1724 | }, 1725 | "inherits": { 1726 | "version": "2.0.4", 1727 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 1728 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", 1729 | "dev": true 1730 | }, 1731 | "inquirer": { 1732 | "version": "6.4.1", 1733 | "resolved": "https://registry.npmjs.org/inquirer/-/inquirer-6.4.1.tgz", 1734 | "integrity": "sha512-/Jw+qPZx4EDYsaT6uz7F4GJRNFMRdKNeUZw3ZnKV8lyuUgz/YWRCSUAJMZSVhSq4Ec0R2oYnyi6b3d4JXcL5Nw==", 1735 | "dev": true, 1736 | "requires": { 1737 | "ansi-escapes": "^3.2.0", 1738 | "chalk": "^2.4.2", 1739 | "cli-cursor": "^2.1.0", 1740 | "cli-width": "^2.0.0", 1741 | "external-editor": "^3.0.3", 1742 | "figures": "^2.0.0", 1743 | "lodash": "^4.17.11", 1744 | "mute-stream": "0.0.7", 1745 | "run-async": "^2.2.0", 1746 | "rxjs": "^6.4.0", 1747 | "string-width": "^2.1.0", 1748 | "strip-ansi": "^5.1.0", 1749 | "through": "^2.3.6" 1750 | }, 1751 | "dependencies": { 1752 | "ansi-regex": { 1753 | "version": "4.1.0", 1754 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.1.0.tgz", 1755 | "integrity": "sha512-1apePfXM1UOSqw0o9IiFAovVz9M5S1Dg+4TrDwfMewQ6p/rmMueb7tWZjQ1rx4Loy1ArBggoqGpfqqdI4rondg==", 1756 | "dev": true 1757 | }, 1758 | "strip-ansi": { 1759 | "version": "5.2.0", 1760 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.2.0.tgz", 1761 | "integrity": "sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA==", 1762 | "dev": true, 1763 | "requires": { 1764 | "ansi-regex": "^4.1.0" 1765 | } 1766 | } 1767 | } 1768 | }, 1769 | "is-accessor-descriptor": { 1770 | "version": "0.1.6", 1771 | "resolved": "https://registry.npmjs.org/is-accessor-descriptor/-/is-accessor-descriptor-0.1.6.tgz", 1772 | "integrity": "sha1-qeEss66Nh2cn7u84Q/igiXtcmNY=", 1773 | "dev": true, 1774 | "requires": { 1775 | "kind-of": "^3.0.2" 1776 | }, 1777 | "dependencies": { 1778 | "kind-of": { 1779 | "version": "3.2.2", 1780 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", 1781 | "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", 1782 | "dev": true, 1783 | "requires": { 1784 | "is-buffer": "^1.1.5" 1785 | } 1786 | } 1787 | } 1788 | }, 1789 | "is-arrayish": { 1790 | "version": "0.2.1", 1791 | "resolved": "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.2.1.tgz", 1792 | "integrity": "sha1-d8mYQFJ6qOyxqLppe4BkWnqSap0=", 1793 | "dev": true 1794 | }, 1795 | "is-binary-path": { 1796 | "version": "1.0.1", 1797 | "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-1.0.1.tgz", 1798 | "integrity": "sha1-dfFmQrSA8YenEcgUFh/TpKdlWJg=", 1799 | "dev": true, 1800 | "requires": { 1801 | "binary-extensions": "^1.0.0" 1802 | } 1803 | }, 1804 | "is-buffer": { 1805 | "version": "1.1.6", 1806 | "resolved": "https://registry.npmjs.org/is-buffer/-/is-buffer-1.1.6.tgz", 1807 | "integrity": "sha512-NcdALwpXkTm5Zvvbk7owOUSvVvBKDgKP5/ewfXEznmQFfs4ZRmanOeKBTjRVjka3QFoN6XJ+9F3USqfHqTaU5w==", 1808 | "dev": true 1809 | }, 1810 | "is-callable": { 1811 | "version": "1.1.4", 1812 | "resolved": "https://registry.npmjs.org/is-callable/-/is-callable-1.1.4.tgz", 1813 | "integrity": "sha512-r5p9sxJjYnArLjObpjA4xu5EKI3CuKHkJXMhT7kwbpUyIFD1n5PMAsoPvWnvtZiNz7LjkYDRZhd7FlI0eMijEA==", 1814 | "dev": true 1815 | }, 1816 | "is-data-descriptor": { 1817 | "version": "0.1.4", 1818 | "resolved": "https://registry.npmjs.org/is-data-descriptor/-/is-data-descriptor-0.1.4.tgz", 1819 | "integrity": "sha1-C17mSDiOLIYCgueT8YVv7D8wG1Y=", 1820 | "dev": true, 1821 | "requires": { 1822 | "kind-of": "^3.0.2" 1823 | }, 1824 | "dependencies": { 1825 | "kind-of": { 1826 | "version": "3.2.2", 1827 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", 1828 | "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", 1829 | "dev": true, 1830 | "requires": { 1831 | "is-buffer": "^1.1.5" 1832 | } 1833 | } 1834 | } 1835 | }, 1836 | "is-date-object": { 1837 | "version": "1.0.1", 1838 | "resolved": "https://registry.npmjs.org/is-date-object/-/is-date-object-1.0.1.tgz", 1839 | "integrity": "sha1-mqIOtq7rv/d/vTPnTKAbM1gdOhY=", 1840 | "dev": true 1841 | }, 1842 | "is-descriptor": { 1843 | "version": "0.1.6", 1844 | "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-0.1.6.tgz", 1845 | "integrity": "sha512-avDYr0SB3DwO9zsMov0gKCESFYqCnE4hq/4z3TdUlukEy5t9C0YRq7HLrsN52NAcqXKaepeCD0n+B0arnVG3Hg==", 1846 | "dev": true, 1847 | "requires": { 1848 | "is-accessor-descriptor": "^0.1.6", 1849 | "is-data-descriptor": "^0.1.4", 1850 | "kind-of": "^5.0.0" 1851 | }, 1852 | "dependencies": { 1853 | "kind-of": { 1854 | "version": "5.1.0", 1855 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-5.1.0.tgz", 1856 | "integrity": "sha512-NGEErnH6F2vUuXDh+OlbcKW7/wOcfdRHaZ7VWtqCztfHri/++YKmP51OdWeGPuqCOba6kk2OTe5d02VmTB80Pw==", 1857 | "dev": true 1858 | } 1859 | } 1860 | }, 1861 | "is-extendable": { 1862 | "version": "0.1.1", 1863 | "resolved": "https://registry.npmjs.org/is-extendable/-/is-extendable-0.1.1.tgz", 1864 | "integrity": "sha1-YrEQ4omkcUGOPsNqYX1HLjAd/Ik=", 1865 | "dev": true 1866 | }, 1867 | "is-extglob": { 1868 | "version": "2.1.1", 1869 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", 1870 | "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=", 1871 | "dev": true 1872 | }, 1873 | "is-fullwidth-code-point": { 1874 | "version": "2.0.0", 1875 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", 1876 | "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=", 1877 | "dev": true 1878 | }, 1879 | "is-glob": { 1880 | "version": "4.0.1", 1881 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.1.tgz", 1882 | "integrity": "sha512-5G0tKtBTFImOqDnLB2hG6Bp2qcKEFduo4tZu9MT/H6NQv/ghhy30o55ufafxJ/LdH79LLs2Kfrn85TLKyA7BUg==", 1883 | "dev": true, 1884 | "requires": { 1885 | "is-extglob": "^2.1.1" 1886 | } 1887 | }, 1888 | "is-module": { 1889 | "version": "1.0.0", 1890 | "resolved": "https://registry.npmjs.org/is-module/-/is-module-1.0.0.tgz", 1891 | "integrity": "sha1-Mlj7afeMFNW4FdZkM2tM/7ZEFZE=", 1892 | "dev": true 1893 | }, 1894 | "is-number": { 1895 | "version": "3.0.0", 1896 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-3.0.0.tgz", 1897 | "integrity": "sha1-JP1iAaR4LPUFYcgQJ2r8fRLXEZU=", 1898 | "dev": true, 1899 | "requires": { 1900 | "kind-of": "^3.0.2" 1901 | }, 1902 | "dependencies": { 1903 | "kind-of": { 1904 | "version": "3.2.2", 1905 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", 1906 | "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", 1907 | "dev": true, 1908 | "requires": { 1909 | "is-buffer": "^1.1.5" 1910 | } 1911 | } 1912 | } 1913 | }, 1914 | "is-plain-object": { 1915 | "version": "2.0.4", 1916 | "resolved": "https://registry.npmjs.org/is-plain-object/-/is-plain-object-2.0.4.tgz", 1917 | "integrity": "sha512-h5PpgXkWitc38BBMYawTYMWJHFZJVnBquFE57xFpjB8pJFiF6gZ+bU+WyI/yqXiFR5mdLsgYNaPe8uao6Uv9Og==", 1918 | "dev": true, 1919 | "requires": { 1920 | "isobject": "^3.0.1" 1921 | } 1922 | }, 1923 | "is-promise": { 1924 | "version": "2.1.0", 1925 | "resolved": "https://registry.npmjs.org/is-promise/-/is-promise-2.1.0.tgz", 1926 | "integrity": "sha1-eaKp7OfwlugPNtKy87wWwf9L8/o=", 1927 | "dev": true 1928 | }, 1929 | "is-regex": { 1930 | "version": "1.0.4", 1931 | "resolved": "https://registry.npmjs.org/is-regex/-/is-regex-1.0.4.tgz", 1932 | "integrity": "sha1-VRdIm1RwkbCTDglWVM7SXul+lJE=", 1933 | "dev": true, 1934 | "requires": { 1935 | "has": "^1.0.1" 1936 | } 1937 | }, 1938 | "is-symbol": { 1939 | "version": "1.0.2", 1940 | "resolved": "https://registry.npmjs.org/is-symbol/-/is-symbol-1.0.2.tgz", 1941 | "integrity": "sha512-HS8bZ9ox60yCJLH9snBpIwv9pYUAkcuLhSA1oero1UB5y9aiQpRA8y2ex945AOtCZL1lJDeIk3G5LthswI46Lw==", 1942 | "dev": true, 1943 | "requires": { 1944 | "has-symbols": "^1.0.0" 1945 | } 1946 | }, 1947 | "is-windows": { 1948 | "version": "1.0.2", 1949 | "resolved": "https://registry.npmjs.org/is-windows/-/is-windows-1.0.2.tgz", 1950 | "integrity": "sha512-eXK1UInq2bPmjyX6e3VHIzMLobc4J94i4AWn+Hpq3OU5KkrRC96OAcR3PRJ/pGu6m8TRnBHP9dkXQVsT/COVIA==", 1951 | "dev": true 1952 | }, 1953 | "isarray": { 1954 | "version": "1.0.0", 1955 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", 1956 | "integrity": "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE=", 1957 | "dev": true 1958 | }, 1959 | "isexe": { 1960 | "version": "2.0.0", 1961 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 1962 | "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=", 1963 | "dev": true 1964 | }, 1965 | "isobject": { 1966 | "version": "3.0.1", 1967 | "resolved": "https://registry.npmjs.org/isobject/-/isobject-3.0.1.tgz", 1968 | "integrity": "sha1-TkMekrEalzFjaqH5yNHMvP2reN8=", 1969 | "dev": true 1970 | }, 1971 | "jest-worker": { 1972 | "version": "24.6.0", 1973 | "resolved": "https://registry.npmjs.org/jest-worker/-/jest-worker-24.6.0.tgz", 1974 | "integrity": "sha512-jDwgW5W9qGNvpI1tNnvajh0a5IE/PuGLFmHk6aR/BZFz8tSgGw17GsDPXAJ6p91IvYDjOw8GpFbvvZGAK+DPQQ==", 1975 | "dev": true, 1976 | "requires": { 1977 | "merge-stream": "^1.0.1", 1978 | "supports-color": "^6.1.0" 1979 | }, 1980 | "dependencies": { 1981 | "supports-color": { 1982 | "version": "6.1.0", 1983 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-6.1.0.tgz", 1984 | "integrity": "sha512-qe1jfm1Mg7Nq/NSh6XE24gPXROEVsWHxC1LIx//XNlD9iw7YZQGjZNjYN7xGaEG6iKdA8EtNFW6R0gjnVXp+wQ==", 1985 | "dev": true, 1986 | "requires": { 1987 | "has-flag": "^3.0.0" 1988 | } 1989 | } 1990 | } 1991 | }, 1992 | "js-tokens": { 1993 | "version": "4.0.0", 1994 | "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", 1995 | "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==", 1996 | "dev": true 1997 | }, 1998 | "js-yaml": { 1999 | "version": "3.13.1", 2000 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.13.1.tgz", 2001 | "integrity": "sha512-YfbcO7jXDdyj0DGxYVSlSeQNHbD7XPWvrVWeVUujrQEoZzWJIRrCPoyk6kL6IAjAG2IolMK4T0hNUe0HOUs5Jw==", 2002 | "dev": true, 2003 | "requires": { 2004 | "argparse": "^1.0.7", 2005 | "esprima": "^4.0.0" 2006 | } 2007 | }, 2008 | "json-parse-better-errors": { 2009 | "version": "1.0.2", 2010 | "resolved": "https://registry.npmjs.org/json-parse-better-errors/-/json-parse-better-errors-1.0.2.tgz", 2011 | "integrity": "sha512-mrqyZKfX5EhL7hvqcV6WG1yYjnjeuYDzDhhcAAUrq8Po85NBQBJP+ZDUT75qZQ98IkUoBqdkExkukOU7Ts2wrw==", 2012 | "dev": true 2013 | }, 2014 | "json-schema-traverse": { 2015 | "version": "0.4.1", 2016 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", 2017 | "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", 2018 | "dev": true 2019 | }, 2020 | "json-stable-stringify-without-jsonify": { 2021 | "version": "1.0.1", 2022 | "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz", 2023 | "integrity": "sha1-nbe1lJatPzz+8wp1FC0tkwrXJlE=", 2024 | "dev": true 2025 | }, 2026 | "jsonify": { 2027 | "version": "0.0.0", 2028 | "resolved": "https://registry.npmjs.org/jsonify/-/jsonify-0.0.0.tgz", 2029 | "integrity": "sha1-LHS27kHZPKUbe1qu6PUDYx0lKnM=", 2030 | "dev": true 2031 | }, 2032 | "kind-of": { 2033 | "version": "6.0.2", 2034 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-6.0.2.tgz", 2035 | "integrity": "sha512-s5kLOcnH0XqDO+FvuaLX8DDjZ18CGFk7VygH40QoKPUQhW4e2rvM0rwUq0t8IQDOwYSeLK01U90OjzBTme2QqA==", 2036 | "dev": true 2037 | }, 2038 | "kleur": { 2039 | "version": "3.0.3", 2040 | "resolved": "https://registry.npmjs.org/kleur/-/kleur-3.0.3.tgz", 2041 | "integrity": "sha512-eTIzlVOSUR+JxdDFepEYcBMtZ9Qqdef+rnzWdRZuMbOywu5tO2w2N7rqjoANZ5k9vywhL6Br1VRjUIgTQx4E8w==" 2042 | }, 2043 | "levn": { 2044 | "version": "0.3.0", 2045 | "resolved": "https://registry.npmjs.org/levn/-/levn-0.3.0.tgz", 2046 | "integrity": "sha1-OwmSTt+fCDwEkP3UwLxEIeBHZO4=", 2047 | "dev": true, 2048 | "requires": { 2049 | "prelude-ls": "~1.1.2", 2050 | "type-check": "~0.3.2" 2051 | } 2052 | }, 2053 | "livereload": { 2054 | "version": "0.8.0", 2055 | "resolved": "https://registry.npmjs.org/livereload/-/livereload-0.8.0.tgz", 2056 | "integrity": "sha512-Hi5Na6VIK3e8zlgOS50fu+iOTKWj5hM0BE7NKpZkwnfWTnktTjA38ZUXa2NlJww8/GrdVhpnxdqlLad5fkO27g==", 2057 | "dev": true, 2058 | "requires": { 2059 | "chokidar": "^2.1.5", 2060 | "opts": ">= 1.2.0", 2061 | "ws": "^1.1.5" 2062 | } 2063 | }, 2064 | "load-json-file": { 2065 | "version": "4.0.0", 2066 | "resolved": "https://registry.npmjs.org/load-json-file/-/load-json-file-4.0.0.tgz", 2067 | "integrity": "sha1-L19Fq5HjMhYjT9U62rZo607AmTs=", 2068 | "dev": true, 2069 | "requires": { 2070 | "graceful-fs": "^4.1.2", 2071 | "parse-json": "^4.0.0", 2072 | "pify": "^3.0.0", 2073 | "strip-bom": "^3.0.0" 2074 | } 2075 | }, 2076 | "local-access": { 2077 | "version": "1.0.1", 2078 | "resolved": "https://registry.npmjs.org/local-access/-/local-access-1.0.1.tgz", 2079 | "integrity": "sha512-ykt2pgN0aqIy6KQC1CqdWTWkmUwNgaOS6dcpHVjyBJONA+Xi7AtSB1vuxC/U/0tjIP3wcRudwQk1YYzUvzk2bA==" 2080 | }, 2081 | "lodash": { 2082 | "version": "4.17.11", 2083 | "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.11.tgz", 2084 | "integrity": "sha512-cQKh8igo5QUhZ7lg38DYWAxMvjSAKG0A8wGSVimP07SIUEK2UO+arSRKbRZWtelMtN5V0Hkwh5ryOto/SshYIg==", 2085 | "dev": true 2086 | }, 2087 | "magic-string": { 2088 | "version": "0.25.2", 2089 | "resolved": "https://registry.npmjs.org/magic-string/-/magic-string-0.25.2.tgz", 2090 | "integrity": "sha512-iLs9mPjh9IuTtRsqqhNGYcZXGei0Nh/A4xirrsqW7c+QhKVFL2vm7U09ru6cHRD22azaP/wMDgI+HCqbETMTtg==", 2091 | "dev": true, 2092 | "requires": { 2093 | "sourcemap-codec": "^1.4.4" 2094 | } 2095 | }, 2096 | "map-cache": { 2097 | "version": "0.2.2", 2098 | "resolved": "https://registry.npmjs.org/map-cache/-/map-cache-0.2.2.tgz", 2099 | "integrity": "sha1-wyq9C9ZSXZsFFkW7TyasXcmKDb8=", 2100 | "dev": true 2101 | }, 2102 | "map-visit": { 2103 | "version": "1.0.0", 2104 | "resolved": "https://registry.npmjs.org/map-visit/-/map-visit-1.0.0.tgz", 2105 | "integrity": "sha1-7Nyo8TFE5mDxtb1B8S80edmN+48=", 2106 | "dev": true, 2107 | "requires": { 2108 | "object-visit": "^1.0.0" 2109 | } 2110 | }, 2111 | "memorystream": { 2112 | "version": "0.3.1", 2113 | "resolved": "https://registry.npmjs.org/memorystream/-/memorystream-0.3.1.tgz", 2114 | "integrity": "sha1-htcJCzDORV1j+64S3aUaR93K+bI=", 2115 | "dev": true 2116 | }, 2117 | "merge-stream": { 2118 | "version": "1.0.1", 2119 | "resolved": "https://registry.npmjs.org/merge-stream/-/merge-stream-1.0.1.tgz", 2120 | "integrity": "sha1-QEEgLVCKNCugAXQAjfDCUbjBNeE=", 2121 | "dev": true, 2122 | "requires": { 2123 | "readable-stream": "^2.0.1" 2124 | } 2125 | }, 2126 | "micromatch": { 2127 | "version": "3.1.10", 2128 | "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-3.1.10.tgz", 2129 | "integrity": "sha512-MWikgl9n9M3w+bpsY3He8L+w9eF9338xRl8IAO5viDizwSzziFEyUzo2xrrloB64ADbTf8uA8vRqqttDTOmccg==", 2130 | "dev": true, 2131 | "requires": { 2132 | "arr-diff": "^4.0.0", 2133 | "array-unique": "^0.3.2", 2134 | "braces": "^2.3.1", 2135 | "define-property": "^2.0.2", 2136 | "extend-shallow": "^3.0.2", 2137 | "extglob": "^2.0.4", 2138 | "fragment-cache": "^0.2.1", 2139 | "kind-of": "^6.0.2", 2140 | "nanomatch": "^1.2.9", 2141 | "object.pick": "^1.3.0", 2142 | "regex-not": "^1.0.0", 2143 | "snapdragon": "^0.8.1", 2144 | "to-regex": "^3.0.2" 2145 | } 2146 | }, 2147 | "mime": { 2148 | "version": "2.4.4", 2149 | "resolved": "https://registry.npmjs.org/mime/-/mime-2.4.4.tgz", 2150 | "integrity": "sha512-LRxmNwziLPT828z+4YkNzloCFC2YM4wrB99k+AV5ZbEyfGNWfG8SO1FUXLmLDBSo89NrJZ4DIWeLjy1CHGhMGA==" 2151 | }, 2152 | "mimic-fn": { 2153 | "version": "1.2.0", 2154 | "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-1.2.0.tgz", 2155 | "integrity": "sha512-jf84uxzwiuiIVKiOLpfYk7N46TSy8ubTonmneY9vrpHNAnp0QBt2BxWV9dO3/j+BoVAb+a5G6YDPW3M5HOdMWQ==", 2156 | "dev": true 2157 | }, 2158 | "minimatch": { 2159 | "version": "3.0.4", 2160 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", 2161 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 2162 | "dev": true, 2163 | "requires": { 2164 | "brace-expansion": "^1.1.7" 2165 | } 2166 | }, 2167 | "minimist": { 2168 | "version": "0.0.8", 2169 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-0.0.8.tgz", 2170 | "integrity": "sha1-hX/Kv8M5fSYluCKCYuhqp6ARsF0=", 2171 | "dev": true 2172 | }, 2173 | "mixin-deep": { 2174 | "version": "1.3.2", 2175 | "resolved": "https://registry.npmjs.org/mixin-deep/-/mixin-deep-1.3.2.tgz", 2176 | "integrity": "sha512-WRoDn//mXBiJ1H40rqa3vH0toePwSsGb45iInWlTySa+Uu4k3tYUSxa2v1KqAiLtvlrSzaExqS1gtk96A9zvEA==", 2177 | "dev": true, 2178 | "requires": { 2179 | "for-in": "^1.0.2", 2180 | "is-extendable": "^1.0.1" 2181 | }, 2182 | "dependencies": { 2183 | "is-extendable": { 2184 | "version": "1.0.1", 2185 | "resolved": "https://registry.npmjs.org/is-extendable/-/is-extendable-1.0.1.tgz", 2186 | "integrity": "sha512-arnXMxT1hhoKo9k1LZdmlNyJdDDfy2v0fXjFlmok4+i8ul/6WlbVge9bhM74OpNPQPMGUToDtz+KXa1PneJxOA==", 2187 | "dev": true, 2188 | "requires": { 2189 | "is-plain-object": "^2.0.4" 2190 | } 2191 | } 2192 | } 2193 | }, 2194 | "mkdirp": { 2195 | "version": "0.5.1", 2196 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.1.tgz", 2197 | "integrity": "sha1-MAV0OOrGz3+MR2fzhkjWaX11yQM=", 2198 | "dev": true, 2199 | "requires": { 2200 | "minimist": "0.0.8" 2201 | } 2202 | }, 2203 | "mri": { 2204 | "version": "1.1.4", 2205 | "resolved": "https://registry.npmjs.org/mri/-/mri-1.1.4.tgz", 2206 | "integrity": "sha512-6y7IjGPm8AzlvoUrwAaw1tLnUBudaS3752vcd8JtrpGGQn+rXIe63LFVHm/YMwtqAuh+LJPCFdlLYPWM1nYn6w==" 2207 | }, 2208 | "ms": { 2209 | "version": "2.0.0", 2210 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 2211 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=", 2212 | "dev": true 2213 | }, 2214 | "mute-stream": { 2215 | "version": "0.0.7", 2216 | "resolved": "https://registry.npmjs.org/mute-stream/-/mute-stream-0.0.7.tgz", 2217 | "integrity": "sha1-MHXOk7whuPq0PhvE2n6BFe0ee6s=", 2218 | "dev": true 2219 | }, 2220 | "nan": { 2221 | "version": "2.14.0", 2222 | "resolved": "https://registry.npmjs.org/nan/-/nan-2.14.0.tgz", 2223 | "integrity": "sha512-INOFj37C7k3AfaNTtX8RhsTw7qRy7eLET14cROi9+5HAVbbHuIWUHEauBv5qT4Av2tWasiTY1Jw6puUNqRJXQg==", 2224 | "dev": true, 2225 | "optional": true 2226 | }, 2227 | "nanomatch": { 2228 | "version": "1.2.13", 2229 | "resolved": "https://registry.npmjs.org/nanomatch/-/nanomatch-1.2.13.tgz", 2230 | "integrity": "sha512-fpoe2T0RbHwBTBUOftAfBPaDEi06ufaUai0mE6Yn1kacc3SnTErfb/h+X94VXzI64rKFHYImXSvdwGGCmwOqCA==", 2231 | "dev": true, 2232 | "requires": { 2233 | "arr-diff": "^4.0.0", 2234 | "array-unique": "^0.3.2", 2235 | "define-property": "^2.0.2", 2236 | "extend-shallow": "^3.0.2", 2237 | "fragment-cache": "^0.2.1", 2238 | "is-windows": "^1.0.2", 2239 | "kind-of": "^6.0.2", 2240 | "object.pick": "^1.3.0", 2241 | "regex-not": "^1.0.0", 2242 | "snapdragon": "^0.8.1", 2243 | "to-regex": "^3.0.1" 2244 | } 2245 | }, 2246 | "natural-compare": { 2247 | "version": "1.4.0", 2248 | "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", 2249 | "integrity": "sha1-Sr6/7tdUHywnrPspvbvRXI1bpPc=", 2250 | "dev": true 2251 | }, 2252 | "nice-try": { 2253 | "version": "1.0.5", 2254 | "resolved": "https://registry.npmjs.org/nice-try/-/nice-try-1.0.5.tgz", 2255 | "integrity": "sha512-1nh45deeb5olNY7eX82BkPO7SSxR5SSYJiPTrTdFUVYwAl8CKMA5N9PjTYkHiRjisVcxcQ1HXdLhx2qxxJzLNQ==", 2256 | "dev": true 2257 | }, 2258 | "normalize-package-data": { 2259 | "version": "2.5.0", 2260 | "resolved": "https://registry.npmjs.org/normalize-package-data/-/normalize-package-data-2.5.0.tgz", 2261 | "integrity": "sha512-/5CMN3T0R4XTj4DcGaexo+roZSdSFW/0AOOTROrjxzCG1wrWXEsGbRKevjlIL+ZDE4sZlJr5ED4YW0yqmkK+eA==", 2262 | "dev": true, 2263 | "requires": { 2264 | "hosted-git-info": "^2.1.4", 2265 | "resolve": "^1.10.0", 2266 | "semver": "2 || 3 || 4 || 5", 2267 | "validate-npm-package-license": "^3.0.1" 2268 | } 2269 | }, 2270 | "normalize-path": { 2271 | "version": "3.0.0", 2272 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", 2273 | "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", 2274 | "dev": true 2275 | }, 2276 | "npm-run-all": { 2277 | "version": "4.1.5", 2278 | "resolved": "https://registry.npmjs.org/npm-run-all/-/npm-run-all-4.1.5.tgz", 2279 | "integrity": "sha512-Oo82gJDAVcaMdi3nuoKFavkIHBRVqQ1qvMb+9LHk/cF4P6B2m8aP04hGf7oL6wZ9BuGwX1onlLhpuoofSyoQDQ==", 2280 | "dev": true, 2281 | "requires": { 2282 | "ansi-styles": "^3.2.1", 2283 | "chalk": "^2.4.1", 2284 | "cross-spawn": "^6.0.5", 2285 | "memorystream": "^0.3.1", 2286 | "minimatch": "^3.0.4", 2287 | "pidtree": "^0.3.0", 2288 | "read-pkg": "^3.0.0", 2289 | "shell-quote": "^1.6.1", 2290 | "string.prototype.padend": "^3.0.0" 2291 | } 2292 | }, 2293 | "object-copy": { 2294 | "version": "0.1.0", 2295 | "resolved": "https://registry.npmjs.org/object-copy/-/object-copy-0.1.0.tgz", 2296 | "integrity": "sha1-fn2Fi3gb18mRpBupde04EnVOmYw=", 2297 | "dev": true, 2298 | "requires": { 2299 | "copy-descriptor": "^0.1.0", 2300 | "define-property": "^0.2.5", 2301 | "kind-of": "^3.0.3" 2302 | }, 2303 | "dependencies": { 2304 | "define-property": { 2305 | "version": "0.2.5", 2306 | "resolved": "https://registry.npmjs.org/define-property/-/define-property-0.2.5.tgz", 2307 | "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=", 2308 | "dev": true, 2309 | "requires": { 2310 | "is-descriptor": "^0.1.0" 2311 | } 2312 | }, 2313 | "kind-of": { 2314 | "version": "3.2.2", 2315 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", 2316 | "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", 2317 | "dev": true, 2318 | "requires": { 2319 | "is-buffer": "^1.1.5" 2320 | } 2321 | } 2322 | } 2323 | }, 2324 | "object-keys": { 2325 | "version": "1.1.1", 2326 | "resolved": "https://registry.npmjs.org/object-keys/-/object-keys-1.1.1.tgz", 2327 | "integrity": "sha512-NuAESUOUMrlIXOfHKzD6bpPu3tYt3xvjNdRIQ+FeT0lNb4K8WR70CaDxhuNguS2XG+GjkyMwOzsN5ZktImfhLA==", 2328 | "dev": true 2329 | }, 2330 | "object-visit": { 2331 | "version": "1.0.1", 2332 | "resolved": "https://registry.npmjs.org/object-visit/-/object-visit-1.0.1.tgz", 2333 | "integrity": "sha1-95xEk68MU3e1n+OdOV5BBC3QRbs=", 2334 | "dev": true, 2335 | "requires": { 2336 | "isobject": "^3.0.0" 2337 | } 2338 | }, 2339 | "object.pick": { 2340 | "version": "1.3.0", 2341 | "resolved": "https://registry.npmjs.org/object.pick/-/object.pick-1.3.0.tgz", 2342 | "integrity": "sha1-h6EKxMFpS9Lhy/U1kaZhQftd10c=", 2343 | "dev": true, 2344 | "requires": { 2345 | "isobject": "^3.0.1" 2346 | } 2347 | }, 2348 | "once": { 2349 | "version": "1.4.0", 2350 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 2351 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 2352 | "dev": true, 2353 | "requires": { 2354 | "wrappy": "1" 2355 | } 2356 | }, 2357 | "onetime": { 2358 | "version": "2.0.1", 2359 | "resolved": "https://registry.npmjs.org/onetime/-/onetime-2.0.1.tgz", 2360 | "integrity": "sha1-BnQoIw/WdEOyeUsiu6UotoZ5YtQ=", 2361 | "dev": true, 2362 | "requires": { 2363 | "mimic-fn": "^1.0.0" 2364 | } 2365 | }, 2366 | "optionator": { 2367 | "version": "0.8.2", 2368 | "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.8.2.tgz", 2369 | "integrity": "sha1-NkxeQJ0/TWMB1sC0wFu6UBgK62Q=", 2370 | "dev": true, 2371 | "requires": { 2372 | "deep-is": "~0.1.3", 2373 | "fast-levenshtein": "~2.0.4", 2374 | "levn": "~0.3.0", 2375 | "prelude-ls": "~1.1.2", 2376 | "type-check": "~0.3.2", 2377 | "wordwrap": "~1.0.0" 2378 | } 2379 | }, 2380 | "options": { 2381 | "version": "0.0.6", 2382 | "resolved": "https://registry.npmjs.org/options/-/options-0.0.6.tgz", 2383 | "integrity": "sha1-7CLTEoBrtT5zF3Pnza788cZDEo8=", 2384 | "dev": true 2385 | }, 2386 | "opts": { 2387 | "version": "1.2.6", 2388 | "resolved": "https://registry.npmjs.org/opts/-/opts-1.2.6.tgz", 2389 | "integrity": "sha1-0YXAQlz9652h0YKQi2W1wCOP67M=", 2390 | "dev": true 2391 | }, 2392 | "os-tmpdir": { 2393 | "version": "1.0.2", 2394 | "resolved": "https://registry.npmjs.org/os-tmpdir/-/os-tmpdir-1.0.2.tgz", 2395 | "integrity": "sha1-u+Z0BseaqFxc/sdm/lc0VV36EnQ=", 2396 | "dev": true 2397 | }, 2398 | "parent-module": { 2399 | "version": "1.0.1", 2400 | "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz", 2401 | "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==", 2402 | "dev": true, 2403 | "requires": { 2404 | "callsites": "^3.0.0" 2405 | } 2406 | }, 2407 | "parse-json": { 2408 | "version": "4.0.0", 2409 | "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-4.0.0.tgz", 2410 | "integrity": "sha1-vjX1Qlvh9/bHRxhPmKeIy5lHfuA=", 2411 | "dev": true, 2412 | "requires": { 2413 | "error-ex": "^1.3.1", 2414 | "json-parse-better-errors": "^1.0.1" 2415 | } 2416 | }, 2417 | "pascalcase": { 2418 | "version": "0.1.1", 2419 | "resolved": "https://registry.npmjs.org/pascalcase/-/pascalcase-0.1.1.tgz", 2420 | "integrity": "sha1-s2PlXoAGym/iF4TS2yK9FdeRfxQ=", 2421 | "dev": true 2422 | }, 2423 | "path-dirname": { 2424 | "version": "1.0.2", 2425 | "resolved": "https://registry.npmjs.org/path-dirname/-/path-dirname-1.0.2.tgz", 2426 | "integrity": "sha1-zDPSTVJeCZpTiMAzbG4yuRYGCeA=", 2427 | "dev": true 2428 | }, 2429 | "path-is-absolute": { 2430 | "version": "1.0.1", 2431 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 2432 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=", 2433 | "dev": true 2434 | }, 2435 | "path-key": { 2436 | "version": "2.0.1", 2437 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-2.0.1.tgz", 2438 | "integrity": "sha1-QRyttXTFoUDTpLGRDUDYDMn0C0A=", 2439 | "dev": true 2440 | }, 2441 | "path-parse": { 2442 | "version": "1.0.6", 2443 | "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.6.tgz", 2444 | "integrity": "sha512-GSmOT2EbHrINBf9SR7CDELwlJ8AENk3Qn7OikK4nFYAu3Ote2+JYNVvkpAEQm3/TLNEJFD/xZJjzyxg3KBWOzw==", 2445 | "dev": true 2446 | }, 2447 | "path-type": { 2448 | "version": "3.0.0", 2449 | "resolved": "https://registry.npmjs.org/path-type/-/path-type-3.0.0.tgz", 2450 | "integrity": "sha512-T2ZUsdZFHgA3u4e5PfPbjd7HDDpxPnQb5jN0SrDsjNSuVXHJqtwTnWqG0B1jZrgmJ/7lj1EmVIByWt1gxGkWvg==", 2451 | "dev": true, 2452 | "requires": { 2453 | "pify": "^3.0.0" 2454 | } 2455 | }, 2456 | "pidtree": { 2457 | "version": "0.3.0", 2458 | "resolved": "https://registry.npmjs.org/pidtree/-/pidtree-0.3.0.tgz", 2459 | "integrity": "sha512-9CT4NFlDcosssyg8KVFltgokyKZIFjoBxw8CTGy+5F38Y1eQWrt8tRayiUOXE+zVKQnYu5BR8JjCtvK3BcnBhg==", 2460 | "dev": true 2461 | }, 2462 | "pify": { 2463 | "version": "3.0.0", 2464 | "resolved": "https://registry.npmjs.org/pify/-/pify-3.0.0.tgz", 2465 | "integrity": "sha1-5aSs0sEB/fPZpNB/DbxNtJ3SgXY=", 2466 | "dev": true 2467 | }, 2468 | "posix-character-classes": { 2469 | "version": "0.1.1", 2470 | "resolved": "https://registry.npmjs.org/posix-character-classes/-/posix-character-classes-0.1.1.tgz", 2471 | "integrity": "sha1-AerA/jta9xoqbAL+q7jB/vfgDqs=", 2472 | "dev": true 2473 | }, 2474 | "prelude-ls": { 2475 | "version": "1.1.2", 2476 | "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.1.2.tgz", 2477 | "integrity": "sha1-IZMqVJ9eUv/ZqCf1cOBL5iqX2lQ=", 2478 | "dev": true 2479 | }, 2480 | "prettier": { 2481 | "version": "1.18.2", 2482 | "resolved": "https://registry.npmjs.org/prettier/-/prettier-1.18.2.tgz", 2483 | "integrity": "sha512-OeHeMc0JhFE9idD4ZdtNibzY0+TPHSpSSb9h8FqtP+YnoZZ1sl8Vc9b1sasjfymH3SonAF4QcA2+mzHPhMvIiw==", 2484 | "dev": true 2485 | }, 2486 | "prettier-linter-helpers": { 2487 | "version": "1.0.0", 2488 | "resolved": "https://registry.npmjs.org/prettier-linter-helpers/-/prettier-linter-helpers-1.0.0.tgz", 2489 | "integrity": "sha512-GbK2cP9nraSSUF9N2XwUwqfzlAFlMNYYl+ShE/V+H8a9uNl/oUqB1w2EL54Jh0OlyRSd8RfWYJ3coVS4TROP2w==", 2490 | "dev": true, 2491 | "requires": { 2492 | "fast-diff": "^1.1.2" 2493 | } 2494 | }, 2495 | "process-nextick-args": { 2496 | "version": "2.0.1", 2497 | "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-2.0.1.tgz", 2498 | "integrity": "sha512-3ouUOpQhtgrbOa17J7+uxOTpITYWaGP7/AhoR3+A+/1e9skrzelGi/dXzEYyvbxubEF6Wn2ypscTKiKJFFn1ag==", 2499 | "dev": true 2500 | }, 2501 | "progress": { 2502 | "version": "2.0.3", 2503 | "resolved": "https://registry.npmjs.org/progress/-/progress-2.0.3.tgz", 2504 | "integrity": "sha512-7PiHtLll5LdnKIMw100I+8xJXR5gW2QwWYkT6iJva0bXitZKa/XMrSbdmg3r2Xnaidz9Qumd0VPaMrZlF9V9sA==", 2505 | "dev": true 2506 | }, 2507 | "punycode": { 2508 | "version": "2.1.1", 2509 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.1.1.tgz", 2510 | "integrity": "sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A==", 2511 | "dev": true 2512 | }, 2513 | "read-pkg": { 2514 | "version": "3.0.0", 2515 | "resolved": "https://registry.npmjs.org/read-pkg/-/read-pkg-3.0.0.tgz", 2516 | "integrity": "sha1-nLxoaXj+5l0WwA4rGcI3/Pbjg4k=", 2517 | "dev": true, 2518 | "requires": { 2519 | "load-json-file": "^4.0.0", 2520 | "normalize-package-data": "^2.3.2", 2521 | "path-type": "^3.0.0" 2522 | } 2523 | }, 2524 | "readable-stream": { 2525 | "version": "2.3.6", 2526 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.6.tgz", 2527 | "integrity": "sha512-tQtKA9WIAhBF3+VLAseyMqZeBjW0AHJoxOtYqSUZNJxauErmLbVm2FW1y+J/YA9dUrAC39ITejlZWhVIwawkKw==", 2528 | "dev": true, 2529 | "requires": { 2530 | "core-util-is": "~1.0.0", 2531 | "inherits": "~2.0.3", 2532 | "isarray": "~1.0.0", 2533 | "process-nextick-args": "~2.0.0", 2534 | "safe-buffer": "~5.1.1", 2535 | "string_decoder": "~1.1.1", 2536 | "util-deprecate": "~1.0.1" 2537 | } 2538 | }, 2539 | "readdirp": { 2540 | "version": "2.2.1", 2541 | "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-2.2.1.tgz", 2542 | "integrity": "sha512-1JU/8q+VgFZyxwrJ+SVIOsh+KywWGpds3NTqikiKpDMZWScmAYyKIgqkO+ARvNWJfXeXR1zxz7aHF4u4CyH6vQ==", 2543 | "dev": true, 2544 | "requires": { 2545 | "graceful-fs": "^4.1.11", 2546 | "micromatch": "^3.1.10", 2547 | "readable-stream": "^2.0.2" 2548 | } 2549 | }, 2550 | "regex-not": { 2551 | "version": "1.0.2", 2552 | "resolved": "https://registry.npmjs.org/regex-not/-/regex-not-1.0.2.tgz", 2553 | "integrity": "sha512-J6SDjUgDxQj5NusnOtdFxDwN/+HWykR8GELwctJ7mdqhcyy1xEc4SRFHUXvxTp661YaVKAjfRLZ9cCqS6tn32A==", 2554 | "dev": true, 2555 | "requires": { 2556 | "extend-shallow": "^3.0.2", 2557 | "safe-regex": "^1.1.0" 2558 | } 2559 | }, 2560 | "regexpp": { 2561 | "version": "2.0.1", 2562 | "resolved": "https://registry.npmjs.org/regexpp/-/regexpp-2.0.1.tgz", 2563 | "integrity": "sha512-lv0M6+TkDVniA3aD1Eg0DVpfU/booSu7Eev3TDO/mZKHBfVjgCGTV4t4buppESEYDtkArYFOxTJWv6S5C+iaNw==", 2564 | "dev": true 2565 | }, 2566 | "remove-trailing-separator": { 2567 | "version": "1.1.0", 2568 | "resolved": "https://registry.npmjs.org/remove-trailing-separator/-/remove-trailing-separator-1.1.0.tgz", 2569 | "integrity": "sha1-wkvOKig62tW8P1jg1IJJuSN52O8=", 2570 | "dev": true 2571 | }, 2572 | "repeat-element": { 2573 | "version": "1.1.3", 2574 | "resolved": "https://registry.npmjs.org/repeat-element/-/repeat-element-1.1.3.tgz", 2575 | "integrity": "sha512-ahGq0ZnV5m5XtZLMb+vP76kcAM5nkLqk0lpqAuojSKGgQtn4eRi4ZZGm2olo2zKFH+sMsWaqOCW1dqAnOru72g==", 2576 | "dev": true 2577 | }, 2578 | "repeat-string": { 2579 | "version": "1.6.1", 2580 | "resolved": "https://registry.npmjs.org/repeat-string/-/repeat-string-1.6.1.tgz", 2581 | "integrity": "sha1-jcrkcOHIirwtYA//Sndihtp15jc=", 2582 | "dev": true 2583 | }, 2584 | "require-relative": { 2585 | "version": "0.8.7", 2586 | "resolved": "https://registry.npmjs.org/require-relative/-/require-relative-0.8.7.tgz", 2587 | "integrity": "sha1-eZlTn8ngR6N5KPoZb44VY9q9Nt4=", 2588 | "dev": true 2589 | }, 2590 | "resolve": { 2591 | "version": "1.11.1", 2592 | "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.11.1.tgz", 2593 | "integrity": "sha512-vIpgF6wfuJOZI7KKKSP+HmiKggadPQAdsp5HiC1mvqnfp0gF1vdwgBWZIdrVft9pgqoMFQN+R7BSWZiBxx+BBw==", 2594 | "dev": true, 2595 | "requires": { 2596 | "path-parse": "^1.0.6" 2597 | } 2598 | }, 2599 | "resolve-from": { 2600 | "version": "4.0.0", 2601 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", 2602 | "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==", 2603 | "dev": true 2604 | }, 2605 | "resolve-url": { 2606 | "version": "0.2.1", 2607 | "resolved": "https://registry.npmjs.org/resolve-url/-/resolve-url-0.2.1.tgz", 2608 | "integrity": "sha1-LGN/53yJOv0qZj/iGqkIAGjiBSo=", 2609 | "dev": true 2610 | }, 2611 | "restore-cursor": { 2612 | "version": "2.0.0", 2613 | "resolved": "https://registry.npmjs.org/restore-cursor/-/restore-cursor-2.0.0.tgz", 2614 | "integrity": "sha1-n37ih/gv0ybU/RYpI9YhKe7g368=", 2615 | "dev": true, 2616 | "requires": { 2617 | "onetime": "^2.0.0", 2618 | "signal-exit": "^3.0.2" 2619 | } 2620 | }, 2621 | "ret": { 2622 | "version": "0.1.15", 2623 | "resolved": "https://registry.npmjs.org/ret/-/ret-0.1.15.tgz", 2624 | "integrity": "sha512-TTlYpa+OL+vMMNG24xSlQGEJ3B/RzEfUlLct7b5G/ytav+wPrplCpVMFuwzXbkecJrb6IYo1iFb0S9v37754mg==", 2625 | "dev": true 2626 | }, 2627 | "rimraf": { 2628 | "version": "2.6.3", 2629 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.6.3.tgz", 2630 | "integrity": "sha512-mwqeW5XsA2qAejG46gYdENaxXjx9onRNCfn7L0duuP4hCuTIi/QO7PDK07KJfp1d+izWPrzEJDcSqBa0OZQriA==", 2631 | "dev": true, 2632 | "requires": { 2633 | "glob": "^7.1.3" 2634 | } 2635 | }, 2636 | "rollup": { 2637 | "version": "1.16.2", 2638 | "resolved": "https://registry.npmjs.org/rollup/-/rollup-1.16.2.tgz", 2639 | "integrity": "sha512-UAZxaQvH0klYZdF+90xv9nGb+m4p8jdoaow1VL5/RzDK/gN/4CjvaMmJNcOIv1/+gtzswKhAg/467mzF0sLpAg==", 2640 | "dev": true, 2641 | "requires": { 2642 | "@types/estree": "0.0.39", 2643 | "@types/node": "^12.0.8", 2644 | "acorn": "^6.1.1" 2645 | } 2646 | }, 2647 | "rollup-plugin-commonjs": { 2648 | "version": "9.3.4", 2649 | "resolved": "https://registry.npmjs.org/rollup-plugin-commonjs/-/rollup-plugin-commonjs-9.3.4.tgz", 2650 | "integrity": "sha512-DTZOvRoiVIHHLFBCL4pFxOaJt8pagxsVldEXBOn6wl3/V21wVaj17HFfyzTsQUuou3sZL3lEJZVWKPFblJfI6w==", 2651 | "dev": true, 2652 | "requires": { 2653 | "estree-walker": "^0.6.0", 2654 | "magic-string": "^0.25.2", 2655 | "resolve": "^1.10.0", 2656 | "rollup-pluginutils": "^2.6.0" 2657 | } 2658 | }, 2659 | "rollup-plugin-livereload": { 2660 | "version": "1.0.1", 2661 | "resolved": "https://registry.npmjs.org/rollup-plugin-livereload/-/rollup-plugin-livereload-1.0.1.tgz", 2662 | "integrity": "sha512-gNuUr+L/8+CR/oKF8ftJNvJEww6iGzNc8+3XcCOvgKWgjhzUBETs8sNONIthcCvVYC2c2PIKMWgQwrYbxRRdwg==", 2663 | "dev": true, 2664 | "requires": { 2665 | "livereload": "^0.8.0" 2666 | } 2667 | }, 2668 | "rollup-plugin-node-resolve": { 2669 | "version": "4.2.4", 2670 | "resolved": "https://registry.npmjs.org/rollup-plugin-node-resolve/-/rollup-plugin-node-resolve-4.2.4.tgz", 2671 | "integrity": "sha512-t/64I6l7fZ9BxqD3XlX4ZeO6+5RLKyfpwE2CiPNUKa+GocPlQhf/C208ou8y3AwtNsc6bjSk/8/6y/YAyxCIvw==", 2672 | "dev": true, 2673 | "requires": { 2674 | "@types/resolve": "0.0.8", 2675 | "builtin-modules": "^3.1.0", 2676 | "is-module": "^1.0.0", 2677 | "resolve": "^1.10.0" 2678 | } 2679 | }, 2680 | "rollup-plugin-replace": { 2681 | "version": "2.2.0", 2682 | "resolved": "https://registry.npmjs.org/rollup-plugin-replace/-/rollup-plugin-replace-2.2.0.tgz", 2683 | "integrity": "sha512-/5bxtUPkDHyBJAKketb4NfaeZjL5yLZdeUihSfbF2PQMz+rSTEb8ARKoOl3UBT4m7/X+QOXJo3sLTcq+yMMYTA==", 2684 | "dev": true, 2685 | "requires": { 2686 | "magic-string": "^0.25.2", 2687 | "rollup-pluginutils": "^2.6.0" 2688 | } 2689 | }, 2690 | "rollup-plugin-svelte": { 2691 | "version": "5.1.0", 2692 | "resolved": "https://registry.npmjs.org/rollup-plugin-svelte/-/rollup-plugin-svelte-5.1.0.tgz", 2693 | "integrity": "sha512-4MRZG29dAWDpoxEs5uIHzDnYafQEOLaKIJAuDYUtFIzEm1F1IGSTlFyjd8/qk4wltlHdu6V7YfZY53+CKryhMg==", 2694 | "dev": true, 2695 | "requires": { 2696 | "require-relative": "^0.8.7", 2697 | "rollup-pluginutils": "^2.3.3", 2698 | "sourcemap-codec": "^1.4.4" 2699 | } 2700 | }, 2701 | "rollup-plugin-terser": { 2702 | "version": "4.0.4", 2703 | "resolved": "https://registry.npmjs.org/rollup-plugin-terser/-/rollup-plugin-terser-4.0.4.tgz", 2704 | "integrity": "sha512-wPANT5XKVJJ8RDUN0+wIr7UPd0lIXBo4UdJ59VmlPCtlFsE20AM+14pe+tk7YunCsWEiuzkDBY3QIkSCjtrPXg==", 2705 | "dev": true, 2706 | "requires": { 2707 | "@babel/code-frame": "^7.0.0", 2708 | "jest-worker": "^24.0.0", 2709 | "serialize-javascript": "^1.6.1", 2710 | "terser": "^3.14.1" 2711 | } 2712 | }, 2713 | "rollup-pluginutils": { 2714 | "version": "2.8.1", 2715 | "resolved": "https://registry.npmjs.org/rollup-pluginutils/-/rollup-pluginutils-2.8.1.tgz", 2716 | "integrity": "sha512-J5oAoysWar6GuZo0s+3bZ6sVZAC0pfqKz68De7ZgDi5z63jOVZn1uJL/+z1jeKHNbGII8kAyHF5q8LnxSX5lQg==", 2717 | "dev": true, 2718 | "requires": { 2719 | "estree-walker": "^0.6.1" 2720 | } 2721 | }, 2722 | "run-async": { 2723 | "version": "2.3.0", 2724 | "resolved": "https://registry.npmjs.org/run-async/-/run-async-2.3.0.tgz", 2725 | "integrity": "sha1-A3GrSuC91yDUFm19/aZP96RFpsA=", 2726 | "dev": true, 2727 | "requires": { 2728 | "is-promise": "^2.1.0" 2729 | } 2730 | }, 2731 | "rxjs": { 2732 | "version": "6.5.2", 2733 | "resolved": "https://registry.npmjs.org/rxjs/-/rxjs-6.5.2.tgz", 2734 | "integrity": "sha512-HUb7j3kvb7p7eCUHE3FqjoDsC1xfZQ4AHFWfTKSpZ+sAhhz5X1WX0ZuUqWbzB2QhSLp3DoLUG+hMdEDKqWo2Zg==", 2735 | "dev": true, 2736 | "requires": { 2737 | "tslib": "^1.9.0" 2738 | } 2739 | }, 2740 | "sade": { 2741 | "version": "1.6.0", 2742 | "resolved": "https://registry.npmjs.org/sade/-/sade-1.6.0.tgz", 2743 | "integrity": "sha512-+CwYHyNlf2QvglE8MJLg+DAXruhz1tg9LeztL2qDf1NZx0OR8Ij4CajM5NxgscggwG9ypQXvTQFXcaerBSLQgg==", 2744 | "requires": { 2745 | "mri": "^1.1.0" 2746 | } 2747 | }, 2748 | "safe-buffer": { 2749 | "version": "5.1.2", 2750 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 2751 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==", 2752 | "dev": true 2753 | }, 2754 | "safe-regex": { 2755 | "version": "1.1.0", 2756 | "resolved": "https://registry.npmjs.org/safe-regex/-/safe-regex-1.1.0.tgz", 2757 | "integrity": "sha1-QKNmnzsHfR6UPURinhV91IAjvy4=", 2758 | "dev": true, 2759 | "requires": { 2760 | "ret": "~0.1.10" 2761 | } 2762 | }, 2763 | "safer-buffer": { 2764 | "version": "2.1.2", 2765 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", 2766 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==", 2767 | "dev": true 2768 | }, 2769 | "semver": { 2770 | "version": "5.7.0", 2771 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.0.tgz", 2772 | "integrity": "sha512-Ya52jSX2u7QKghxeoFGpLwCtGlt7j0oY9DYb5apt9nPlJ42ID+ulTXESnt/qAQcoSERyZ5sl3LDIOw0nAn/5DA==", 2773 | "dev": true 2774 | }, 2775 | "serialize-javascript": { 2776 | "version": "1.7.0", 2777 | "resolved": "https://registry.npmjs.org/serialize-javascript/-/serialize-javascript-1.7.0.tgz", 2778 | "integrity": "sha512-ke8UG8ulpFOxO8f8gRYabHQe/ZntKlcig2Mp+8+URDP1D8vJZ0KUt7LYo07q25Z/+JVSgpr/cui9PIp5H6/+nA==", 2779 | "dev": true 2780 | }, 2781 | "set-value": { 2782 | "version": "2.0.1", 2783 | "resolved": "https://registry.npmjs.org/set-value/-/set-value-2.0.1.tgz", 2784 | "integrity": "sha512-JxHc1weCN68wRY0fhCoXpyK55m/XPHafOmK4UWD7m2CI14GMcFypt4w/0+NV5f/ZMby2F6S2wwA7fgynh9gWSw==", 2785 | "dev": true, 2786 | "requires": { 2787 | "extend-shallow": "^2.0.1", 2788 | "is-extendable": "^0.1.1", 2789 | "is-plain-object": "^2.0.3", 2790 | "split-string": "^3.0.1" 2791 | }, 2792 | "dependencies": { 2793 | "extend-shallow": { 2794 | "version": "2.0.1", 2795 | "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", 2796 | "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", 2797 | "dev": true, 2798 | "requires": { 2799 | "is-extendable": "^0.1.0" 2800 | } 2801 | } 2802 | } 2803 | }, 2804 | "shebang-command": { 2805 | "version": "1.2.0", 2806 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-1.2.0.tgz", 2807 | "integrity": "sha1-RKrGW2lbAzmJaMOfNj/uXer98eo=", 2808 | "dev": true, 2809 | "requires": { 2810 | "shebang-regex": "^1.0.0" 2811 | } 2812 | }, 2813 | "shebang-regex": { 2814 | "version": "1.0.0", 2815 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-1.0.0.tgz", 2816 | "integrity": "sha1-2kL0l0DAtC2yypcoVxyxkMmO/qM=", 2817 | "dev": true 2818 | }, 2819 | "shell-quote": { 2820 | "version": "1.6.1", 2821 | "resolved": "https://registry.npmjs.org/shell-quote/-/shell-quote-1.6.1.tgz", 2822 | "integrity": "sha1-9HgZSczkAmlxJ0MOo7PFR29IF2c=", 2823 | "dev": true, 2824 | "requires": { 2825 | "array-filter": "~0.0.0", 2826 | "array-map": "~0.0.0", 2827 | "array-reduce": "~0.0.0", 2828 | "jsonify": "~0.0.0" 2829 | } 2830 | }, 2831 | "signal-exit": { 2832 | "version": "3.0.2", 2833 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.2.tgz", 2834 | "integrity": "sha1-tf3AjxKH6hF4Yo5BXiUTK3NkbG0=", 2835 | "dev": true 2836 | }, 2837 | "sirv": { 2838 | "version": "0.4.2", 2839 | "resolved": "https://registry.npmjs.org/sirv/-/sirv-0.4.2.tgz", 2840 | "integrity": "sha512-dQbZnsMaIiTQPZmbGmktz+c74zt/hyrJEB4tdp2Jj0RNv9J6B/OWR5RyrZEvIn9fyh9Zlg2OlE2XzKz6wMKGAw==", 2841 | "requires": { 2842 | "@polka/url": "^0.5.0", 2843 | "mime": "^2.3.1" 2844 | } 2845 | }, 2846 | "sirv-cli": { 2847 | "version": "0.4.4", 2848 | "resolved": "https://registry.npmjs.org/sirv-cli/-/sirv-cli-0.4.4.tgz", 2849 | "integrity": "sha512-7SsPrYWptRcOvS7/8VIxYDibLDRB4apZaU+y8lfuSnyjYFg0AVVU3J0qcQjWPxT9Ti/DtHnmbivJ+ZTh8L0ykg==", 2850 | "requires": { 2851 | "console-clear": "^1.1.0", 2852 | "get-port": "^3.2.0", 2853 | "kleur": "^3.0.0", 2854 | "local-access": "^1.0.1", 2855 | "sade": "^1.4.0", 2856 | "sirv": "^0.4.2", 2857 | "tinydate": "^1.0.0" 2858 | } 2859 | }, 2860 | "slice-ansi": { 2861 | "version": "2.1.0", 2862 | "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-2.1.0.tgz", 2863 | "integrity": "sha512-Qu+VC3EwYLldKa1fCxuuvULvSJOKEgk9pi8dZeCVK7TqBfUNTH4sFkk4joj8afVSfAYgJoSOetjx9QWOJ5mYoQ==", 2864 | "dev": true, 2865 | "requires": { 2866 | "ansi-styles": "^3.2.0", 2867 | "astral-regex": "^1.0.0", 2868 | "is-fullwidth-code-point": "^2.0.0" 2869 | } 2870 | }, 2871 | "snapdragon": { 2872 | "version": "0.8.2", 2873 | "resolved": "https://registry.npmjs.org/snapdragon/-/snapdragon-0.8.2.tgz", 2874 | "integrity": "sha512-FtyOnWN/wCHTVXOMwvSv26d+ko5vWlIDD6zoUJ7LW8vh+ZBC8QdljveRP+crNrtBwioEUWy/4dMtbBjA4ioNlg==", 2875 | "dev": true, 2876 | "requires": { 2877 | "base": "^0.11.1", 2878 | "debug": "^2.2.0", 2879 | "define-property": "^0.2.5", 2880 | "extend-shallow": "^2.0.1", 2881 | "map-cache": "^0.2.2", 2882 | "source-map": "^0.5.6", 2883 | "source-map-resolve": "^0.5.0", 2884 | "use": "^3.1.0" 2885 | }, 2886 | "dependencies": { 2887 | "define-property": { 2888 | "version": "0.2.5", 2889 | "resolved": "https://registry.npmjs.org/define-property/-/define-property-0.2.5.tgz", 2890 | "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=", 2891 | "dev": true, 2892 | "requires": { 2893 | "is-descriptor": "^0.1.0" 2894 | } 2895 | }, 2896 | "extend-shallow": { 2897 | "version": "2.0.1", 2898 | "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", 2899 | "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", 2900 | "dev": true, 2901 | "requires": { 2902 | "is-extendable": "^0.1.0" 2903 | } 2904 | } 2905 | } 2906 | }, 2907 | "snapdragon-node": { 2908 | "version": "2.1.1", 2909 | "resolved": "https://registry.npmjs.org/snapdragon-node/-/snapdragon-node-2.1.1.tgz", 2910 | "integrity": "sha512-O27l4xaMYt/RSQ5TR3vpWCAB5Kb/czIcqUFOM/C4fYcLnbZUc1PkjTAMjof2pBWaSTwOUd6qUHcFGVGj7aIwnw==", 2911 | "dev": true, 2912 | "requires": { 2913 | "define-property": "^1.0.0", 2914 | "isobject": "^3.0.0", 2915 | "snapdragon-util": "^3.0.1" 2916 | }, 2917 | "dependencies": { 2918 | "define-property": { 2919 | "version": "1.0.0", 2920 | "resolved": "https://registry.npmjs.org/define-property/-/define-property-1.0.0.tgz", 2921 | "integrity": "sha1-dp66rz9KY6rTr56NMEybvnm/sOY=", 2922 | "dev": true, 2923 | "requires": { 2924 | "is-descriptor": "^1.0.0" 2925 | } 2926 | }, 2927 | "is-accessor-descriptor": { 2928 | "version": "1.0.0", 2929 | "resolved": "https://registry.npmjs.org/is-accessor-descriptor/-/is-accessor-descriptor-1.0.0.tgz", 2930 | "integrity": "sha512-m5hnHTkcVsPfqx3AKlyttIPb7J+XykHvJP2B9bZDjlhLIoEq4XoK64Vg7boZlVWYK6LUY94dYPEE7Lh0ZkZKcQ==", 2931 | "dev": true, 2932 | "requires": { 2933 | "kind-of": "^6.0.0" 2934 | } 2935 | }, 2936 | "is-data-descriptor": { 2937 | "version": "1.0.0", 2938 | "resolved": "https://registry.npmjs.org/is-data-descriptor/-/is-data-descriptor-1.0.0.tgz", 2939 | "integrity": "sha512-jbRXy1FmtAoCjQkVmIVYwuuqDFUbaOeDjmed1tOGPrsMhtJA4rD9tkgA0F1qJ3gRFRXcHYVkdeaP50Q5rE/jLQ==", 2940 | "dev": true, 2941 | "requires": { 2942 | "kind-of": "^6.0.0" 2943 | } 2944 | }, 2945 | "is-descriptor": { 2946 | "version": "1.0.2", 2947 | "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-1.0.2.tgz", 2948 | "integrity": "sha512-2eis5WqQGV7peooDyLmNEPUrps9+SXX5c9pL3xEB+4e9HnGuDa7mB7kHxHw4CbqS9k1T2hOH3miL8n8WtiYVtg==", 2949 | "dev": true, 2950 | "requires": { 2951 | "is-accessor-descriptor": "^1.0.0", 2952 | "is-data-descriptor": "^1.0.0", 2953 | "kind-of": "^6.0.2" 2954 | } 2955 | } 2956 | } 2957 | }, 2958 | "snapdragon-util": { 2959 | "version": "3.0.1", 2960 | "resolved": "https://registry.npmjs.org/snapdragon-util/-/snapdragon-util-3.0.1.tgz", 2961 | "integrity": "sha512-mbKkMdQKsjX4BAL4bRYTj21edOf8cN7XHdYUJEe+Zn99hVEYcMvKPct1IqNe7+AZPirn8BCDOQBHQZknqmKlZQ==", 2962 | "dev": true, 2963 | "requires": { 2964 | "kind-of": "^3.2.0" 2965 | }, 2966 | "dependencies": { 2967 | "kind-of": { 2968 | "version": "3.2.2", 2969 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", 2970 | "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", 2971 | "dev": true, 2972 | "requires": { 2973 | "is-buffer": "^1.1.5" 2974 | } 2975 | } 2976 | } 2977 | }, 2978 | "source-map": { 2979 | "version": "0.5.7", 2980 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.5.7.tgz", 2981 | "integrity": "sha1-igOdLRAh0i0eoUyA2OpGi6LvP8w=", 2982 | "dev": true 2983 | }, 2984 | "source-map-resolve": { 2985 | "version": "0.5.2", 2986 | "resolved": "https://registry.npmjs.org/source-map-resolve/-/source-map-resolve-0.5.2.tgz", 2987 | "integrity": "sha512-MjqsvNwyz1s0k81Goz/9vRBe9SZdB09Bdw+/zYyO+3CuPk6fouTaxscHkgtE8jKvf01kVfl8riHzERQ/kefaSA==", 2988 | "dev": true, 2989 | "requires": { 2990 | "atob": "^2.1.1", 2991 | "decode-uri-component": "^0.2.0", 2992 | "resolve-url": "^0.2.1", 2993 | "source-map-url": "^0.4.0", 2994 | "urix": "^0.1.0" 2995 | } 2996 | }, 2997 | "source-map-support": { 2998 | "version": "0.5.12", 2999 | "resolved": "https://registry.npmjs.org/source-map-support/-/source-map-support-0.5.12.tgz", 3000 | "integrity": "sha512-4h2Pbvyy15EE02G+JOZpUCmqWJuqrs+sEkzewTm++BPi7Hvn/HwcqLAcNxYAyI0x13CpPPn+kMjl+hplXMHITQ==", 3001 | "dev": true, 3002 | "requires": { 3003 | "buffer-from": "^1.0.0", 3004 | "source-map": "^0.6.0" 3005 | }, 3006 | "dependencies": { 3007 | "source-map": { 3008 | "version": "0.6.1", 3009 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", 3010 | "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", 3011 | "dev": true 3012 | } 3013 | } 3014 | }, 3015 | "source-map-url": { 3016 | "version": "0.4.0", 3017 | "resolved": "https://registry.npmjs.org/source-map-url/-/source-map-url-0.4.0.tgz", 3018 | "integrity": "sha1-PpNdfd1zYxuXZZlW1VEo6HtQhKM=", 3019 | "dev": true 3020 | }, 3021 | "sourcemap-codec": { 3022 | "version": "1.4.4", 3023 | "resolved": "https://registry.npmjs.org/sourcemap-codec/-/sourcemap-codec-1.4.4.tgz", 3024 | "integrity": "sha512-CYAPYdBu34781kLHkaW3m6b/uUSyMOC2R61gcYMWooeuaGtjof86ZA/8T+qVPPt7np1085CR9hmMGrySwEc8Xg==", 3025 | "dev": true 3026 | }, 3027 | "spdx-correct": { 3028 | "version": "3.1.0", 3029 | "resolved": "https://registry.npmjs.org/spdx-correct/-/spdx-correct-3.1.0.tgz", 3030 | "integrity": "sha512-lr2EZCctC2BNR7j7WzJ2FpDznxky1sjfxvvYEyzxNyb6lZXHODmEoJeFu4JupYlkfha1KZpJyoqiJ7pgA1qq8Q==", 3031 | "dev": true, 3032 | "requires": { 3033 | "spdx-expression-parse": "^3.0.0", 3034 | "spdx-license-ids": "^3.0.0" 3035 | } 3036 | }, 3037 | "spdx-exceptions": { 3038 | "version": "2.2.0", 3039 | "resolved": "https://registry.npmjs.org/spdx-exceptions/-/spdx-exceptions-2.2.0.tgz", 3040 | "integrity": "sha512-2XQACfElKi9SlVb1CYadKDXvoajPgBVPn/gOQLrTvHdElaVhr7ZEbqJaRnJLVNeaI4cMEAgVCeBMKF6MWRDCRA==", 3041 | "dev": true 3042 | }, 3043 | "spdx-expression-parse": { 3044 | "version": "3.0.0", 3045 | "resolved": "https://registry.npmjs.org/spdx-expression-parse/-/spdx-expression-parse-3.0.0.tgz", 3046 | "integrity": "sha512-Yg6D3XpRD4kkOmTpdgbUiEJFKghJH03fiC1OPll5h/0sO6neh2jqRDVHOQ4o/LMea0tgCkbMgea5ip/e+MkWyg==", 3047 | "dev": true, 3048 | "requires": { 3049 | "spdx-exceptions": "^2.1.0", 3050 | "spdx-license-ids": "^3.0.0" 3051 | } 3052 | }, 3053 | "spdx-license-ids": { 3054 | "version": "3.0.4", 3055 | "resolved": "https://registry.npmjs.org/spdx-license-ids/-/spdx-license-ids-3.0.4.tgz", 3056 | "integrity": "sha512-7j8LYJLeY/Yb6ACbQ7F76qy5jHkp0U6jgBfJsk97bwWlVUnUWsAgpyaCvo17h0/RQGnQ036tVDomiwoI4pDkQA==", 3057 | "dev": true 3058 | }, 3059 | "split-string": { 3060 | "version": "3.1.0", 3061 | "resolved": "https://registry.npmjs.org/split-string/-/split-string-3.1.0.tgz", 3062 | "integrity": "sha512-NzNVhJDYpwceVVii8/Hu6DKfD2G+NrQHlS/V/qgv763EYudVwEcMQNxd2lh+0VrUByXN/oJkl5grOhYWvQUYiw==", 3063 | "dev": true, 3064 | "requires": { 3065 | "extend-shallow": "^3.0.0" 3066 | } 3067 | }, 3068 | "sprintf-js": { 3069 | "version": "1.0.3", 3070 | "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz", 3071 | "integrity": "sha1-BOaSb2YolTVPPdAVIDYzuFcpfiw=", 3072 | "dev": true 3073 | }, 3074 | "static-extend": { 3075 | "version": "0.1.2", 3076 | "resolved": "https://registry.npmjs.org/static-extend/-/static-extend-0.1.2.tgz", 3077 | "integrity": "sha1-YICcOcv/VTNyJv1eC1IPNB8ftcY=", 3078 | "dev": true, 3079 | "requires": { 3080 | "define-property": "^0.2.5", 3081 | "object-copy": "^0.1.0" 3082 | }, 3083 | "dependencies": { 3084 | "define-property": { 3085 | "version": "0.2.5", 3086 | "resolved": "https://registry.npmjs.org/define-property/-/define-property-0.2.5.tgz", 3087 | "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=", 3088 | "dev": true, 3089 | "requires": { 3090 | "is-descriptor": "^0.1.0" 3091 | } 3092 | } 3093 | } 3094 | }, 3095 | "string-width": { 3096 | "version": "2.1.1", 3097 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-2.1.1.tgz", 3098 | "integrity": "sha512-nOqH59deCq9SRHlxq1Aw85Jnt4w6KvLKqWVik6oA9ZklXLNIOlqg4F2yrT1MVaTjAqvVwdfeZ7w7aCvJD7ugkw==", 3099 | "dev": true, 3100 | "requires": { 3101 | "is-fullwidth-code-point": "^2.0.0", 3102 | "strip-ansi": "^4.0.0" 3103 | } 3104 | }, 3105 | "string.prototype.padend": { 3106 | "version": "3.0.0", 3107 | "resolved": "https://registry.npmjs.org/string.prototype.padend/-/string.prototype.padend-3.0.0.tgz", 3108 | "integrity": "sha1-86rvfBcZ8XDF6rHDK/eA2W4h8vA=", 3109 | "dev": true, 3110 | "requires": { 3111 | "define-properties": "^1.1.2", 3112 | "es-abstract": "^1.4.3", 3113 | "function-bind": "^1.0.2" 3114 | } 3115 | }, 3116 | "string_decoder": { 3117 | "version": "1.1.1", 3118 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", 3119 | "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", 3120 | "dev": true, 3121 | "requires": { 3122 | "safe-buffer": "~5.1.0" 3123 | } 3124 | }, 3125 | "strip-ansi": { 3126 | "version": "4.0.0", 3127 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-4.0.0.tgz", 3128 | "integrity": "sha1-qEeQIusaw2iocTibY1JixQXuNo8=", 3129 | "dev": true, 3130 | "requires": { 3131 | "ansi-regex": "^3.0.0" 3132 | } 3133 | }, 3134 | "strip-bom": { 3135 | "version": "3.0.0", 3136 | "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-3.0.0.tgz", 3137 | "integrity": "sha1-IzTBjpx1n3vdVv3vfprj1YjmjtM=", 3138 | "dev": true 3139 | }, 3140 | "strip-json-comments": { 3141 | "version": "2.0.1", 3142 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-2.0.1.tgz", 3143 | "integrity": "sha1-PFMZQukIwml8DsNEhYwobHygpgo=", 3144 | "dev": true 3145 | }, 3146 | "supports-color": { 3147 | "version": "5.5.0", 3148 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 3149 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 3150 | "dev": true, 3151 | "requires": { 3152 | "has-flag": "^3.0.0" 3153 | } 3154 | }, 3155 | "svelte": { 3156 | "version": "3.6.1", 3157 | "resolved": "https://registry.npmjs.org/svelte/-/svelte-3.6.1.tgz", 3158 | "integrity": "sha512-4TaCyB0nBgpsdLBZ8T0ovIgbVpNoCmXnPvBkJ0v1P9RYY2gcYd7Yv1FX+O7hW4Ak1v8uVSKh6WU0XBlN2oZXEw==", 3159 | "dev": true 3160 | }, 3161 | "table": { 3162 | "version": "5.4.1", 3163 | "resolved": "https://registry.npmjs.org/table/-/table-5.4.1.tgz", 3164 | "integrity": "sha512-E6CK1/pZe2N75rGZQotFOdmzWQ1AILtgYbMAbAjvms0S1l5IDB47zG3nCnFGB/w+7nB3vKofbLXCH7HPBo864w==", 3165 | "dev": true, 3166 | "requires": { 3167 | "ajv": "^6.9.1", 3168 | "lodash": "^4.17.11", 3169 | "slice-ansi": "^2.1.0", 3170 | "string-width": "^3.0.0" 3171 | }, 3172 | "dependencies": { 3173 | "ansi-regex": { 3174 | "version": "4.1.0", 3175 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.1.0.tgz", 3176 | "integrity": "sha512-1apePfXM1UOSqw0o9IiFAovVz9M5S1Dg+4TrDwfMewQ6p/rmMueb7tWZjQ1rx4Loy1ArBggoqGpfqqdI4rondg==", 3177 | "dev": true 3178 | }, 3179 | "string-width": { 3180 | "version": "3.1.0", 3181 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-3.1.0.tgz", 3182 | "integrity": "sha512-vafcv6KjVZKSgz06oM/H6GDBrAtz8vdhQakGjFIvNrHA6y3HCF1CInLy+QLq8dTJPQ1b+KDUqDFctkdRW44e1w==", 3183 | "dev": true, 3184 | "requires": { 3185 | "emoji-regex": "^7.0.1", 3186 | "is-fullwidth-code-point": "^2.0.0", 3187 | "strip-ansi": "^5.1.0" 3188 | } 3189 | }, 3190 | "strip-ansi": { 3191 | "version": "5.2.0", 3192 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.2.0.tgz", 3193 | "integrity": "sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA==", 3194 | "dev": true, 3195 | "requires": { 3196 | "ansi-regex": "^4.1.0" 3197 | } 3198 | } 3199 | } 3200 | }, 3201 | "terser": { 3202 | "version": "3.17.0", 3203 | "resolved": "https://registry.npmjs.org/terser/-/terser-3.17.0.tgz", 3204 | "integrity": "sha512-/FQzzPJmCpjAH9Xvk2paiWrFq+5M6aVOf+2KRbwhByISDX/EujxsK+BAvrhb6H+2rtrLCHK9N01wO014vrIwVQ==", 3205 | "dev": true, 3206 | "requires": { 3207 | "commander": "^2.19.0", 3208 | "source-map": "~0.6.1", 3209 | "source-map-support": "~0.5.10" 3210 | }, 3211 | "dependencies": { 3212 | "source-map": { 3213 | "version": "0.6.1", 3214 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", 3215 | "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", 3216 | "dev": true 3217 | } 3218 | } 3219 | }, 3220 | "text-table": { 3221 | "version": "0.2.0", 3222 | "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz", 3223 | "integrity": "sha1-f17oI66AUgfACvLfSoTsP8+lcLQ=", 3224 | "dev": true 3225 | }, 3226 | "through": { 3227 | "version": "2.3.8", 3228 | "resolved": "https://registry.npmjs.org/through/-/through-2.3.8.tgz", 3229 | "integrity": "sha1-DdTJ/6q8NXlgsbckEV1+Doai4fU=", 3230 | "dev": true 3231 | }, 3232 | "tinydate": { 3233 | "version": "1.1.0", 3234 | "resolved": "https://registry.npmjs.org/tinydate/-/tinydate-1.1.0.tgz", 3235 | "integrity": "sha512-YF6YTOyBRHX4b3EtEI0W/mROcv82Gt6VccmVuSAkRV3FNORug2457wSGvT2cThbfuctQvVSmC5GobGheScxtIw==" 3236 | }, 3237 | "tmp": { 3238 | "version": "0.0.33", 3239 | "resolved": "https://registry.npmjs.org/tmp/-/tmp-0.0.33.tgz", 3240 | "integrity": "sha512-jRCJlojKnZ3addtTOjdIqoRuPEKBvNXcGYqzO6zWZX8KfKEpnGY5jfggJQ3EjKuu8D4bJRr0y+cYJFmYbImXGw==", 3241 | "dev": true, 3242 | "requires": { 3243 | "os-tmpdir": "~1.0.2" 3244 | } 3245 | }, 3246 | "to-object-path": { 3247 | "version": "0.3.0", 3248 | "resolved": "https://registry.npmjs.org/to-object-path/-/to-object-path-0.3.0.tgz", 3249 | "integrity": "sha1-KXWIt7Dn4KwI4E5nL4XB9JmeF68=", 3250 | "dev": true, 3251 | "requires": { 3252 | "kind-of": "^3.0.2" 3253 | }, 3254 | "dependencies": { 3255 | "kind-of": { 3256 | "version": "3.2.2", 3257 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", 3258 | "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", 3259 | "dev": true, 3260 | "requires": { 3261 | "is-buffer": "^1.1.5" 3262 | } 3263 | } 3264 | } 3265 | }, 3266 | "to-regex": { 3267 | "version": "3.0.2", 3268 | "resolved": "https://registry.npmjs.org/to-regex/-/to-regex-3.0.2.tgz", 3269 | "integrity": "sha512-FWtleNAtZ/Ki2qtqej2CXTOayOH9bHDQF+Q48VpWyDXjbYxA4Yz8iDB31zXOBUlOHHKidDbqGVrTUvQMPmBGBw==", 3270 | "dev": true, 3271 | "requires": { 3272 | "define-property": "^2.0.2", 3273 | "extend-shallow": "^3.0.2", 3274 | "regex-not": "^1.0.2", 3275 | "safe-regex": "^1.1.0" 3276 | } 3277 | }, 3278 | "to-regex-range": { 3279 | "version": "2.1.1", 3280 | "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-2.1.1.tgz", 3281 | "integrity": "sha1-fIDBe53+vlmeJzZ+DU3VWQFB2zg=", 3282 | "dev": true, 3283 | "requires": { 3284 | "is-number": "^3.0.0", 3285 | "repeat-string": "^1.6.1" 3286 | } 3287 | }, 3288 | "tslib": { 3289 | "version": "1.10.0", 3290 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.10.0.tgz", 3291 | "integrity": "sha512-qOebF53frne81cf0S9B41ByenJ3/IuH8yJKngAX35CmiZySA0khhkovshKK+jGCaMnVomla7gVlIcc3EvKPbTQ==", 3292 | "dev": true 3293 | }, 3294 | "type-check": { 3295 | "version": "0.3.2", 3296 | "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.3.2.tgz", 3297 | "integrity": "sha1-WITKtRLPHTVeP7eE8wgEsrUg23I=", 3298 | "dev": true, 3299 | "requires": { 3300 | "prelude-ls": "~1.1.2" 3301 | } 3302 | }, 3303 | "ultron": { 3304 | "version": "1.0.2", 3305 | "resolved": "https://registry.npmjs.org/ultron/-/ultron-1.0.2.tgz", 3306 | "integrity": "sha1-rOEWq1V80Zc4ak6I9GhTeMiy5Po=", 3307 | "dev": true 3308 | }, 3309 | "union-value": { 3310 | "version": "1.0.1", 3311 | "resolved": "https://registry.npmjs.org/union-value/-/union-value-1.0.1.tgz", 3312 | "integrity": "sha512-tJfXmxMeWYnczCVs7XAEvIV7ieppALdyepWMkHkwciRpZraG/xwT+s2JN8+pr1+8jCRf80FFzvr+MpQeeoF4Xg==", 3313 | "dev": true, 3314 | "requires": { 3315 | "arr-union": "^3.1.0", 3316 | "get-value": "^2.0.6", 3317 | "is-extendable": "^0.1.1", 3318 | "set-value": "^2.0.1" 3319 | } 3320 | }, 3321 | "unset-value": { 3322 | "version": "1.0.0", 3323 | "resolved": "https://registry.npmjs.org/unset-value/-/unset-value-1.0.0.tgz", 3324 | "integrity": "sha1-g3aHP30jNRef+x5vw6jtDfyKtVk=", 3325 | "dev": true, 3326 | "requires": { 3327 | "has-value": "^0.3.1", 3328 | "isobject": "^3.0.0" 3329 | }, 3330 | "dependencies": { 3331 | "has-value": { 3332 | "version": "0.3.1", 3333 | "resolved": "https://registry.npmjs.org/has-value/-/has-value-0.3.1.tgz", 3334 | "integrity": "sha1-ex9YutpiyoJ+wKIHgCVlSEWZXh8=", 3335 | "dev": true, 3336 | "requires": { 3337 | "get-value": "^2.0.3", 3338 | "has-values": "^0.1.4", 3339 | "isobject": "^2.0.0" 3340 | }, 3341 | "dependencies": { 3342 | "isobject": { 3343 | "version": "2.1.0", 3344 | "resolved": "https://registry.npmjs.org/isobject/-/isobject-2.1.0.tgz", 3345 | "integrity": "sha1-8GVWEJaj8dou9GJy+BXIQNh+DIk=", 3346 | "dev": true, 3347 | "requires": { 3348 | "isarray": "1.0.0" 3349 | } 3350 | } 3351 | } 3352 | }, 3353 | "has-values": { 3354 | "version": "0.1.4", 3355 | "resolved": "https://registry.npmjs.org/has-values/-/has-values-0.1.4.tgz", 3356 | "integrity": "sha1-bWHeldkd/Km5oCCJrThL/49it3E=", 3357 | "dev": true 3358 | } 3359 | } 3360 | }, 3361 | "upath": { 3362 | "version": "1.1.2", 3363 | "resolved": "https://registry.npmjs.org/upath/-/upath-1.1.2.tgz", 3364 | "integrity": "sha512-kXpym8nmDmlCBr7nKdIx8P2jNBa+pBpIUFRnKJ4dr8htyYGJFokkr2ZvERRtUN+9SY+JqXouNgUPtv6JQva/2Q==", 3365 | "dev": true 3366 | }, 3367 | "uri-js": { 3368 | "version": "4.2.2", 3369 | "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.2.2.tgz", 3370 | "integrity": "sha512-KY9Frmirql91X2Qgjry0Wd4Y+YTdrdZheS8TFwvkbLWf/G5KNJDCh6pKL5OZctEW4+0Baa5idK2ZQuELRwPznQ==", 3371 | "dev": true, 3372 | "requires": { 3373 | "punycode": "^2.1.0" 3374 | } 3375 | }, 3376 | "urix": { 3377 | "version": "0.1.0", 3378 | "resolved": "https://registry.npmjs.org/urix/-/urix-0.1.0.tgz", 3379 | "integrity": "sha1-2pN/emLiH+wf0Y1Js1wpNQZ6bHI=", 3380 | "dev": true 3381 | }, 3382 | "use": { 3383 | "version": "3.1.1", 3384 | "resolved": "https://registry.npmjs.org/use/-/use-3.1.1.tgz", 3385 | "integrity": "sha512-cwESVXlO3url9YWlFW/TA9cshCEhtu7IKJ/p5soJ/gGpj7vbvFrAY/eIioQ6Dw23KjZhYgiIo8HOs1nQ2vr/oQ==", 3386 | "dev": true 3387 | }, 3388 | "util-deprecate": { 3389 | "version": "1.0.2", 3390 | "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", 3391 | "integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8=", 3392 | "dev": true 3393 | }, 3394 | "validate-npm-package-license": { 3395 | "version": "3.0.4", 3396 | "resolved": "https://registry.npmjs.org/validate-npm-package-license/-/validate-npm-package-license-3.0.4.tgz", 3397 | "integrity": "sha512-DpKm2Ui/xN7/HQKCtpZxoRWBhZ9Z0kqtygG8XCgNQ8ZlDnxuQmWhj566j8fN4Cu3/JmbhsDo7fcAJq4s9h27Ew==", 3398 | "dev": true, 3399 | "requires": { 3400 | "spdx-correct": "^3.0.0", 3401 | "spdx-expression-parse": "^3.0.0" 3402 | } 3403 | }, 3404 | "which": { 3405 | "version": "1.3.1", 3406 | "resolved": "https://registry.npmjs.org/which/-/which-1.3.1.tgz", 3407 | "integrity": "sha512-HxJdYWq1MTIQbJ3nw0cqssHoTNU267KlrDuGZ1WYlxDStUtKUhOaJmh112/TZmHxxUfuJqPXSOm7tDyas0OSIQ==", 3408 | "dev": true, 3409 | "requires": { 3410 | "isexe": "^2.0.0" 3411 | } 3412 | }, 3413 | "wordwrap": { 3414 | "version": "1.0.0", 3415 | "resolved": "https://registry.npmjs.org/wordwrap/-/wordwrap-1.0.0.tgz", 3416 | "integrity": "sha1-J1hIEIkUVqQXHI0CJkQa3pDLyus=", 3417 | "dev": true 3418 | }, 3419 | "wrappy": { 3420 | "version": "1.0.2", 3421 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 3422 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=", 3423 | "dev": true 3424 | }, 3425 | "write": { 3426 | "version": "1.0.3", 3427 | "resolved": "https://registry.npmjs.org/write/-/write-1.0.3.tgz", 3428 | "integrity": "sha512-/lg70HAjtkUgWPVZhZcm+T4hkL8Zbtp1nFNOn3lRrxnlv50SRBv7cR7RqR+GMsd3hUXy9hWBo4CHTbFTcOYwig==", 3429 | "dev": true, 3430 | "requires": { 3431 | "mkdirp": "^0.5.1" 3432 | } 3433 | }, 3434 | "ws": { 3435 | "version": "1.1.5", 3436 | "resolved": "https://registry.npmjs.org/ws/-/ws-1.1.5.tgz", 3437 | "integrity": "sha512-o3KqipXNUdS7wpQzBHSe180lBGO60SoK0yVo3CYJgb2MkobuWuBX6dhkYP5ORCLd55y+SaflMOV5fqAB53ux4w==", 3438 | "dev": true, 3439 | "requires": { 3440 | "options": ">=0.0.5", 3441 | "ultron": "1.0.x" 3442 | } 3443 | }, 3444 | "xstate": { 3445 | "version": "4.6.3", 3446 | "resolved": "https://registry.npmjs.org/xstate/-/xstate-4.6.3.tgz", 3447 | "integrity": "sha512-ihJcpZWjqW60psaC+RxFhfZxgFDNRpEmHeSsM4DgtKswsz6HxEzNx7rgesZtg8/LqluOba8puy8lVtB748RG6A==", 3448 | "requires": { 3449 | "@vuepress/plugin-google-analytics": "^1.0.1" 3450 | } 3451 | } 3452 | } 3453 | } 3454 | --------------------------------------------------------------------------------