├── .editorconfig ├── .eslintrc.json ├── .gitignore ├── LICENCE ├── README.md ├── eslintrc.json ├── images ├── BrowserPreview_tmp.gif ├── effects_900w.gif ├── greygreen_gg_full.png ├── greygreen_gg_full_350w.png ├── greygreen_logo.png ├── greygreen_logo_150w.png └── greygreen_text.png ├── package-lock.json ├── package.json └── src ├── app ├── .gitignore ├── components │ ├── App.jsx │ ├── DetailCards │ │ ├── Actions │ │ │ └── ActionsDisplay.jsx │ │ ├── DetailsNav.jsx │ │ ├── Effects │ │ │ └── EffectsDisplay.jsx │ │ ├── InitialDetailCard │ │ │ └── InitialDisplay.jsx │ │ └── State │ │ │ ├── StateCard.jsx │ │ │ └── StateDisplay.jsx │ ├── EventCards │ │ ├── EventCreator.jsx │ │ ├── EventsDisplay.jsx │ │ ├── EventsNav.jsx │ │ └── FilterBar.jsx │ └── stateDifference.jsx ├── container │ ├── Details.jsx │ ├── Events.jsx │ ├── SplitPane.jsx │ └── TimeSlider.jsx ├── index.html ├── index.js ├── package-lock.json ├── package.json ├── styles │ ├── Details.jsx │ ├── Events.jsx │ ├── FilterBar.jsx │ ├── Nav.jsx │ ├── SplitPane.jsx │ └── TimeSlider.jsx └── webpack.config.js └── browser ├── chrome ├── background.js ├── devtools.html ├── devtools.js ├── extension.js ├── icons │ ├── icon_128.png │ ├── icon_16.png │ ├── icon_32.png │ └── icon_48.png ├── manifest.json ├── page_action.html ├── page_action.js └── scripts │ ├── inject_bundle.js │ ├── inject_script_tags.js │ ├── linked_list.js │ ├── parser.js │ └── time_travel.js └── firefox └── .gitkeep /.editorconfig: -------------------------------------------------------------------------------- 1 | # editorconfig.org 2 | root = true 3 | 4 | [*] 5 | indent_style = space 6 | indent_size = 2 7 | end_of_line = lf 8 | charset = utf-8 9 | insert_final_newline = true 10 | trim_trailing_whitespace = true -------------------------------------------------------------------------------- /.eslintrc.json: -------------------------------------------------------------------------------- 1 | { 2 | "extends": ["airbnb"], 3 | "rules": { 4 | "react/prop-types": 0, 5 | "no-console": 1 6 | }, 7 | "plugins": ["react", "import"], 8 | "parser": "babel-eslint", 9 | "parserOptions": { 10 | "ecmaVersion": 2018, 11 | "sourceType": "module", 12 | "ecmaFeatures": { 13 | "jsx": true 14 | } 15 | }, 16 | "env": { 17 | "es6": true, 18 | "browser": true, 19 | "node": true 20 | } 21 | } 22 | -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | /node_modules 2 | src/browser/chrome/devtools_bundle 3 | .DS_Store 4 | src/.DS_Store/ 5 | 6 | -------------------------------------------------------------------------------- /LICENCE: -------------------------------------------------------------------------------- 1 | MIT License 2 | 3 | Copyright (c) 2019 React Rewind 4 | 5 | Permission is hereby granted, free of charge, to any person obtaining a copy 6 | of this software and associated documentation files (the "Software"), to deal 7 | in the Software without restriction, including without limitation the rights 8 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 9 | copies of the Software, and to permit persons to whom the Software is 10 | furnished to do so, subject to the following conditions: 11 | 12 | The above copyright notice and this permission notice shall be included in all 13 | copies or substantial portions of the Software. 14 | 15 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 16 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 17 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 18 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 19 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 20 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE 21 | SOFTWARE. -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 |

2 | 3 |

4 | 5 | # Rewind: A Time Travel Debugger for React *useReducer* 6 | 7 | [![PRs Welcome](https://img.shields.io/badge/PRs-welcome-brightgreen.svg)](https://github.com/reactrewind/react-rewind/pulls) [![License: MIT](https://img.shields.io/badge/License-MIT-yellow.svg)](https://opensource.org/licenses/MIT) 8 | ![Release Beta](https://img.shields.io/badge/release-beta-blue.svg)

9 | Designed to help engineers fix bugs faster by recording and replaying through different states of their applications. Debug your app more easily by “rewinding” your session instead of having to wait to reproduce the issue once you find the problem.
10 | 11 | 12 | 13 | - Press record and start interacting with your application. 14 | - Each dispatched action will be stored as a unique event in time. 15 | - Rewind through your recorded actions with the back button or by dragging the slider. 16 | - Analyze the state, the effects and the action object of every dispatched event. 17 | - Press play and watch your app change! 18 |

19 | 20 |

21 | 22 | **React Rewind is in active development. Follow this repo for contribution guidelines.** 23 | ## Getting Started 24 | 25 | These instructions will get you a copy of the project up and running on your local machine for development and testing purposes. 26 | 27 | ### Prerequisites 28 | You must use an unminified version of React. Also, your application must be using the hook `useReducer` for actions to be recorded. 29 | 30 | ### Installing 31 | You can install it from the [Chrome Web Store](https://chrome.google.com/webstore/detail/react-rewind/gaombjmfkfdcfaeehpflnkkfdbpmjohl?hl=en). 32 | 33 | To install locally, setup instructions are as follows: 34 | 35 | 1. `git clone --single-branch --branch beta-release https://github.com/reactrewind/react-rewind.git` 36 | 2. Visit the URL `chrome://extensions/` 37 | 3. Click Load Unpacked button and select the folder `react-rewind/chrome` 38 | 4. On your application page, open the Chrome Developer (Ctrl + Shift + J / Mac: Cmd + Option + I) tools and select `React Rewind` from the tool bar 39 | 5. Click Record and begin interacting with your application 40 | 41 | 42 | As you interact with your application, actions will populate the events panel. Click on these actions to view more details about them, such as the action object that was dispatched, the effects or state difference, and the whole state of the application after the dispatch. The time slider panel allows you to rewind, fast forward, and play through all recorded actions. 43 | 44 | ### Application Features 45 |

46 | 47 |

48 | 49 | | Field | Description | 50 | | ------------- | ------------- | 51 | | events | action types and time since last dispatch | 52 | | actions | the action object that was dispatched | 53 | | effects | difference between the states before and after the action was dispatched | 54 | | state | the state object after the action was dispatched | 55 | 56 | ## Contributing 57 | 58 | Please fork this repo. We welcome pull requests. For suggestions or to report bugs please log an issue. 59 | 60 | ## Versioning 61 | 62 | We use [SemVer](http://semver.org/) for versioning. For the versions available, see the [tags on this repository](https://github.com/reactrewind/react-rewind/tags). 63 | 64 | ## Authors 65 | 66 | [Brandon Murphy](https://github.com/murphybrandon) | [Victor Varaschin](https://github.com/victorvrv) | [Kia Colbert](https://github.com/kiacolbert) | [Gaber Mowiena](https://github.com/GaberMowiena) 67 | 68 | ## License 69 | 70 | This project is licensed under the MIT License - see the [LICENCE.md](./LICENCE) file for details 71 | 72 | -------------------------------------------------------------------------------- /eslintrc.json: -------------------------------------------------------------------------------- 1 | { 2 | "extends": [ 3 | "eslint:recommended", 4 | "plugin:import/errors", 5 | "plugin:react/recommended" 6 | ], 7 | "rules": { 8 | "react/prop-types": 0, 9 | "no-console": 1 10 | }, 11 | "plugins": ["react", "import"], 12 | "parser": "babel-eslint", 13 | "parserOptions": { 14 | "ecmaVersion": 2018, 15 | "sourceType": "module", 16 | "ecmaFeatures": { 17 | "jsx": true 18 | } 19 | }, 20 | "env": { 21 | "es6": true, 22 | "browser": true, 23 | "node": true 24 | } 25 | } 26 | -------------------------------------------------------------------------------- /images/BrowserPreview_tmp.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/reactrewind/react-rewind/784cd0174ff62b4bfcc82b67110019673e75d376/images/BrowserPreview_tmp.gif -------------------------------------------------------------------------------- /images/effects_900w.gif: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/reactrewind/react-rewind/784cd0174ff62b4bfcc82b67110019673e75d376/images/effects_900w.gif -------------------------------------------------------------------------------- /images/greygreen_gg_full.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/reactrewind/react-rewind/784cd0174ff62b4bfcc82b67110019673e75d376/images/greygreen_gg_full.png -------------------------------------------------------------------------------- /images/greygreen_gg_full_350w.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/reactrewind/react-rewind/784cd0174ff62b4bfcc82b67110019673e75d376/images/greygreen_gg_full_350w.png -------------------------------------------------------------------------------- /images/greygreen_logo.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/reactrewind/react-rewind/784cd0174ff62b4bfcc82b67110019673e75d376/images/greygreen_logo.png -------------------------------------------------------------------------------- /images/greygreen_logo_150w.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/reactrewind/react-rewind/784cd0174ff62b4bfcc82b67110019673e75d376/images/greygreen_logo_150w.png -------------------------------------------------------------------------------- /images/greygreen_text.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/reactrewind/react-rewind/784cd0174ff62b4bfcc82b67110019673e75d376/images/greygreen_text.png -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "react-rewind", 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/generator": { 17 | "version": "7.3.4", 18 | "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.3.4.tgz", 19 | "integrity": "sha512-8EXhHRFqlVVWXPezBW5keTiQi/rJMQTg/Y9uVCEZ0CAF3PKtCCaVRnp64Ii1ujhkoDhhF1fVsImoN4yJ2uz4Wg==", 20 | "dev": true, 21 | "requires": { 22 | "@babel/types": "^7.3.4", 23 | "jsesc": "^2.5.1", 24 | "lodash": "^4.17.11", 25 | "source-map": "^0.5.0", 26 | "trim-right": "^1.0.1" 27 | } 28 | }, 29 | "@babel/helper-function-name": { 30 | "version": "7.1.0", 31 | "resolved": "https://registry.npmjs.org/@babel/helper-function-name/-/helper-function-name-7.1.0.tgz", 32 | "integrity": "sha512-A95XEoCpb3TO+KZzJ4S/5uW5fNe26DjBGqf1o9ucyLyCmi1dXq/B3c8iaWTfBk3VvetUxl16e8tIrd5teOCfGw==", 33 | "dev": true, 34 | "requires": { 35 | "@babel/helper-get-function-arity": "^7.0.0", 36 | "@babel/template": "^7.1.0", 37 | "@babel/types": "^7.0.0" 38 | } 39 | }, 40 | "@babel/helper-get-function-arity": { 41 | "version": "7.0.0", 42 | "resolved": "https://registry.npmjs.org/@babel/helper-get-function-arity/-/helper-get-function-arity-7.0.0.tgz", 43 | "integrity": "sha512-r2DbJeg4svYvt3HOS74U4eWKsUAMRH01Z1ds1zx8KNTPtpTL5JAsdFv8BNyOpVqdFhHkkRDIg5B4AsxmkjAlmQ==", 44 | "dev": true, 45 | "requires": { 46 | "@babel/types": "^7.0.0" 47 | } 48 | }, 49 | "@babel/helper-split-export-declaration": { 50 | "version": "7.0.0", 51 | "resolved": "https://registry.npmjs.org/@babel/helper-split-export-declaration/-/helper-split-export-declaration-7.0.0.tgz", 52 | "integrity": "sha512-MXkOJqva62dfC0w85mEf/LucPPS/1+04nmmRMPEBUB++hiiThQ2zPtX/mEWQ3mtzCEjIJvPY8nuwxXtQeQwUag==", 53 | "dev": true, 54 | "requires": { 55 | "@babel/types": "^7.0.0" 56 | } 57 | }, 58 | "@babel/highlight": { 59 | "version": "7.0.0", 60 | "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.0.0.tgz", 61 | "integrity": "sha512-UFMC4ZeFC48Tpvj7C8UgLvtkaUuovQX+5xNWrsIoMG8o2z+XFKjKaN9iVmS84dPwVN00W4wPmqvYoZF3EGAsfw==", 62 | "dev": true, 63 | "requires": { 64 | "chalk": "^2.0.0", 65 | "esutils": "^2.0.2", 66 | "js-tokens": "^4.0.0" 67 | } 68 | }, 69 | "@babel/parser": { 70 | "version": "7.3.4", 71 | "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.3.4.tgz", 72 | "integrity": "sha512-tXZCqWtlOOP4wgCp6RjRvLmfuhnqTLy9VHwRochJBCP2nDm27JnnuFEnXFASVyQNHk36jD1tAammsCEEqgscIQ==", 73 | "dev": true 74 | }, 75 | "@babel/template": { 76 | "version": "7.2.2", 77 | "resolved": "https://registry.npmjs.org/@babel/template/-/template-7.2.2.tgz", 78 | "integrity": "sha512-zRL0IMM02AUDwghf5LMSSDEz7sBCO2YnNmpg3uWTZj/v1rcG2BmQUvaGU8GhU8BvfMh1k2KIAYZ7Ji9KXPUg7g==", 79 | "dev": true, 80 | "requires": { 81 | "@babel/code-frame": "^7.0.0", 82 | "@babel/parser": "^7.2.2", 83 | "@babel/types": "^7.2.2" 84 | } 85 | }, 86 | "@babel/traverse": { 87 | "version": "7.3.4", 88 | "resolved": "https://registry.npmjs.org/@babel/traverse/-/traverse-7.3.4.tgz", 89 | "integrity": "sha512-TvTHKp6471OYEcE/91uWmhR6PrrYywQntCHSaZ8CM8Vmp+pjAusal4nGB2WCCQd0rvI7nOMKn9GnbcvTUz3/ZQ==", 90 | "dev": true, 91 | "requires": { 92 | "@babel/code-frame": "^7.0.0", 93 | "@babel/generator": "^7.3.4", 94 | "@babel/helper-function-name": "^7.1.0", 95 | "@babel/helper-split-export-declaration": "^7.0.0", 96 | "@babel/parser": "^7.3.4", 97 | "@babel/types": "^7.3.4", 98 | "debug": "^4.1.0", 99 | "globals": "^11.1.0", 100 | "lodash": "^4.17.11" 101 | } 102 | }, 103 | "@babel/types": { 104 | "version": "7.3.4", 105 | "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.3.4.tgz", 106 | "integrity": "sha512-WEkp8MsLftM7O/ty580wAmZzN1nDmCACc5+jFzUt+GUFNNIi3LdRlueYz0YIlmJhlZx1QYDMZL5vdWCL0fNjFQ==", 107 | "dev": true, 108 | "requires": { 109 | "esutils": "^2.0.2", 110 | "lodash": "^4.17.11", 111 | "to-fast-properties": "^2.0.0" 112 | } 113 | }, 114 | "JSONStream": { 115 | "version": "1.3.5", 116 | "resolved": "https://registry.npmjs.org/JSONStream/-/JSONStream-1.3.5.tgz", 117 | "integrity": "sha512-E+iruNOY8VV9s4JEbe1aNEm6MiszPRr/UfcHMz0TQh1BXSxHK+ASV1R6W4HpjBhSeS+54PIsAMCBmwD06LLsqQ==", 118 | "dev": true, 119 | "requires": { 120 | "jsonparse": "^1.2.0", 121 | "through": ">=2.2.7 <3" 122 | } 123 | }, 124 | "acorn": { 125 | "version": "6.1.1", 126 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-6.1.1.tgz", 127 | "integrity": "sha512-jPTiwtOxaHNaAPg/dmrJ/beuzLRnXtB0kQPQ8JpotKJgTB6rX6c8mlf315941pyjBSaPg8NHXS9fhP4u17DpGA==", 128 | "dev": true 129 | }, 130 | "acorn-dynamic-import": { 131 | "version": "4.0.0", 132 | "resolved": "https://registry.npmjs.org/acorn-dynamic-import/-/acorn-dynamic-import-4.0.0.tgz", 133 | "integrity": "sha512-d3OEjQV4ROpoflsnUA8HozoIR504TFxNivYEUi6uwz0IYhBkTDXGuWlNdMtybRt3nqVx/L6XqMt0FxkXuWKZhw==", 134 | "dev": true 135 | }, 136 | "acorn-jsx": { 137 | "version": "5.0.1", 138 | "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.0.1.tgz", 139 | "integrity": "sha512-HJ7CfNHrfJLlNTzIEUTj43LNWGkqpRLxm3YjAlcD0ACydk9XynzYsCBHxut+iqt+1aBXkx9UP/w/ZqMr13XIzg==", 140 | "dev": true 141 | }, 142 | "acorn-node": { 143 | "version": "1.6.2", 144 | "resolved": "https://registry.npmjs.org/acorn-node/-/acorn-node-1.6.2.tgz", 145 | "integrity": "sha512-rIhNEZuNI8ibQcL7ANm/mGyPukIaZsRNX9psFNQURyJW0nu6k8wjSDld20z6v2mDBWqX13pIEnk9gGZJHIlEXg==", 146 | "dev": true, 147 | "requires": { 148 | "acorn": "^6.0.2", 149 | "acorn-dynamic-import": "^4.0.0", 150 | "acorn-walk": "^6.1.0", 151 | "xtend": "^4.0.1" 152 | } 153 | }, 154 | "acorn-walk": { 155 | "version": "6.1.1", 156 | "resolved": "https://registry.npmjs.org/acorn-walk/-/acorn-walk-6.1.1.tgz", 157 | "integrity": "sha512-OtUw6JUTgxA2QoqqmrmQ7F2NYqiBPi/L2jqHyFtllhOUvXYQXf0Z1CYUinIfyT4bTCGmrA7gX9FvHA81uzCoVw==", 158 | "dev": true 159 | }, 160 | "ajv": { 161 | "version": "6.9.2", 162 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.9.2.tgz", 163 | "integrity": "sha512-4UFy0/LgDo7Oa/+wOAlj44tp9K78u38E5/359eSrqEp1Z5PdVfimCcs7SluXMP755RUQu6d2b4AvF0R1C9RZjg==", 164 | "dev": true, 165 | "requires": { 166 | "fast-deep-equal": "^2.0.1", 167 | "fast-json-stable-stringify": "^2.0.0", 168 | "json-schema-traverse": "^0.4.1", 169 | "uri-js": "^4.2.2" 170 | } 171 | }, 172 | "ansi-escapes": { 173 | "version": "3.2.0", 174 | "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-3.2.0.tgz", 175 | "integrity": "sha512-cBhpre4ma+U0T1oM5fXg7Dy1Jw7zzwv7lt/GoCpr+hDQJoYnKVPLL4dCvSEFMmQurOQvSrwT7SL/DAlhBI97RQ==", 176 | "dev": true 177 | }, 178 | "ansi-regex": { 179 | "version": "3.0.0", 180 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-3.0.0.tgz", 181 | "integrity": "sha1-7QMXwyIGT3lGbAKWa922Bas32Zg=", 182 | "dev": true 183 | }, 184 | "ansi-styles": { 185 | "version": "3.2.1", 186 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 187 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 188 | "dev": true, 189 | "requires": { 190 | "color-convert": "^1.9.0" 191 | } 192 | }, 193 | "argparse": { 194 | "version": "1.0.10", 195 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.10.tgz", 196 | "integrity": "sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg==", 197 | "dev": true, 198 | "requires": { 199 | "sprintf-js": "~1.0.2" 200 | } 201 | }, 202 | "aria-query": { 203 | "version": "3.0.0", 204 | "resolved": "https://registry.npmjs.org/aria-query/-/aria-query-3.0.0.tgz", 205 | "integrity": "sha1-ZbP8wcoRVajJrmTW7uKX8V1RM8w=", 206 | "requires": { 207 | "ast-types-flow": "0.0.7", 208 | "commander": "^2.11.0" 209 | } 210 | }, 211 | "array-filter": { 212 | "version": "0.0.1", 213 | "resolved": "https://registry.npmjs.org/array-filter/-/array-filter-0.0.1.tgz", 214 | "integrity": "sha1-fajPLiZijtcygDWB/SH2fKzS7uw=", 215 | "dev": true 216 | }, 217 | "array-includes": { 218 | "version": "3.0.3", 219 | "resolved": "https://registry.npmjs.org/array-includes/-/array-includes-3.0.3.tgz", 220 | "integrity": "sha1-GEtI9i2S10UrsxsyMWXH+L0CJm0=", 221 | "requires": { 222 | "define-properties": "^1.1.2", 223 | "es-abstract": "^1.7.0" 224 | } 225 | }, 226 | "array-map": { 227 | "version": "0.0.0", 228 | "resolved": "https://registry.npmjs.org/array-map/-/array-map-0.0.0.tgz", 229 | "integrity": "sha1-iKK6tz0c97zVwbEYoAP2b2ZfpmI=", 230 | "dev": true 231 | }, 232 | "array-reduce": { 233 | "version": "0.0.0", 234 | "resolved": "https://registry.npmjs.org/array-reduce/-/array-reduce-0.0.0.tgz", 235 | "integrity": "sha1-FziZ0//Rx9k4PkR5Ul2+J4yrXys=", 236 | "dev": true 237 | }, 238 | "asn1.js": { 239 | "version": "4.10.1", 240 | "resolved": "https://registry.npmjs.org/asn1.js/-/asn1.js-4.10.1.tgz", 241 | "integrity": "sha512-p32cOF5q0Zqs9uBiONKYLm6BClCoBCM5O9JfeUSlnQLBTxYdTK+pW+nXflm8UkKd2UYlEbYz5qEi0JuZR9ckSw==", 242 | "dev": true, 243 | "requires": { 244 | "bn.js": "^4.0.0", 245 | "inherits": "^2.0.1", 246 | "minimalistic-assert": "^1.0.0" 247 | } 248 | }, 249 | "assert": { 250 | "version": "1.4.1", 251 | "resolved": "https://registry.npmjs.org/assert/-/assert-1.4.1.tgz", 252 | "integrity": "sha1-mZEtWRg2tab1s0XA8H7vwI/GXZE=", 253 | "dev": true, 254 | "requires": { 255 | "util": "0.10.3" 256 | }, 257 | "dependencies": { 258 | "inherits": { 259 | "version": "2.0.1", 260 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.1.tgz", 261 | "integrity": "sha1-sX0I0ya0Qj5Wjv9xn5GwscvfafE=", 262 | "dev": true 263 | }, 264 | "util": { 265 | "version": "0.10.3", 266 | "resolved": "https://registry.npmjs.org/util/-/util-0.10.3.tgz", 267 | "integrity": "sha1-evsa/lCAUkZInj23/g7TeTNqwPk=", 268 | "dev": true, 269 | "requires": { 270 | "inherits": "2.0.1" 271 | } 272 | } 273 | } 274 | }, 275 | "ast-types-flow": { 276 | "version": "0.0.7", 277 | "resolved": "https://registry.npmjs.org/ast-types-flow/-/ast-types-flow-0.0.7.tgz", 278 | "integrity": "sha1-9wtzXGvKGlycItmCw+Oef+ujva0=" 279 | }, 280 | "astral-regex": { 281 | "version": "1.0.0", 282 | "resolved": "https://registry.npmjs.org/astral-regex/-/astral-regex-1.0.0.tgz", 283 | "integrity": "sha512-+Ryf6g3BKoRc7jfp7ad8tM4TtMiaWvbF/1/sQcZPkkS7ag3D5nMBCe2UfOTONtAkaG0tO0ij3C5Lwmf1EiyjHg==", 284 | "dev": true 285 | }, 286 | "axobject-query": { 287 | "version": "2.0.2", 288 | "resolved": "https://registry.npmjs.org/axobject-query/-/axobject-query-2.0.2.tgz", 289 | "integrity": "sha512-MCeek8ZH7hKyO1rWUbKNQBbl4l2eY0ntk7OGi+q0RlafrCnfPxC06WZA+uebCfmYp4mNU9jRBP1AhGyf8+W3ww==", 290 | "requires": { 291 | "ast-types-flow": "0.0.7" 292 | } 293 | }, 294 | "babel-eslint": { 295 | "version": "10.0.1", 296 | "resolved": "https://registry.npmjs.org/babel-eslint/-/babel-eslint-10.0.1.tgz", 297 | "integrity": "sha512-z7OT1iNV+TjOwHNLLyJk+HN+YVWX+CLE6fPD2SymJZOZQBs+QIexFjhm4keGTm8MW9xr4EC9Q0PbaLB24V5GoQ==", 298 | "dev": true, 299 | "requires": { 300 | "@babel/code-frame": "^7.0.0", 301 | "@babel/parser": "^7.0.0", 302 | "@babel/traverse": "^7.0.0", 303 | "@babel/types": "^7.0.0", 304 | "eslint-scope": "3.7.1", 305 | "eslint-visitor-keys": "^1.0.0" 306 | } 307 | }, 308 | "balanced-match": { 309 | "version": "1.0.0", 310 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz", 311 | "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=", 312 | "dev": true 313 | }, 314 | "base64-js": { 315 | "version": "1.3.0", 316 | "resolved": "https://registry.npmjs.org/base64-js/-/base64-js-1.3.0.tgz", 317 | "integrity": "sha512-ccav/yGvoa80BQDljCxsmmQ3Xvx60/UpBIij5QN21W3wBi/hhIC9OoO+KLpu9IJTS9j4DRVJ3aDDF9cMSoa2lw==", 318 | "dev": true 319 | }, 320 | "bn.js": { 321 | "version": "4.11.8", 322 | "resolved": "https://registry.npmjs.org/bn.js/-/bn.js-4.11.8.tgz", 323 | "integrity": "sha512-ItfYfPLkWHUjckQCk8xC+LwxgK8NYcXywGigJgSwOP8Y2iyWT4f2vsZnoOXTTbo+o5yXmIUJ4gn5538SO5S3gA==", 324 | "dev": true 325 | }, 326 | "brace-expansion": { 327 | "version": "1.1.11", 328 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 329 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 330 | "dev": true, 331 | "requires": { 332 | "balanced-match": "^1.0.0", 333 | "concat-map": "0.0.1" 334 | } 335 | }, 336 | "brorand": { 337 | "version": "1.1.0", 338 | "resolved": "https://registry.npmjs.org/brorand/-/brorand-1.1.0.tgz", 339 | "integrity": "sha1-EsJe/kCkXjwyPrhnWgoM5XsiNx8=", 340 | "dev": true 341 | }, 342 | "browser-pack": { 343 | "version": "6.1.0", 344 | "resolved": "https://registry.npmjs.org/browser-pack/-/browser-pack-6.1.0.tgz", 345 | "integrity": "sha512-erYug8XoqzU3IfcU8fUgyHqyOXqIE4tUTTQ+7mqUjQlvnXkOO6OlT9c/ZoJVHYoAaqGxr09CN53G7XIsO4KtWA==", 346 | "dev": true, 347 | "requires": { 348 | "JSONStream": "^1.0.3", 349 | "combine-source-map": "~0.8.0", 350 | "defined": "^1.0.0", 351 | "safe-buffer": "^5.1.1", 352 | "through2": "^2.0.0", 353 | "umd": "^3.0.0" 354 | } 355 | }, 356 | "browser-resolve": { 357 | "version": "1.11.3", 358 | "resolved": "https://registry.npmjs.org/browser-resolve/-/browser-resolve-1.11.3.tgz", 359 | "integrity": "sha512-exDi1BYWB/6raKHmDTCicQfTkqwN5fioMFV4j8BsfMU4R2DK/QfZfK7kOVkmWCNANf0snkBzqGqAJBao9gZMdQ==", 360 | "dev": true, 361 | "requires": { 362 | "resolve": "1.1.7" 363 | }, 364 | "dependencies": { 365 | "resolve": { 366 | "version": "1.1.7", 367 | "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.1.7.tgz", 368 | "integrity": "sha1-IDEU2CrSxe2ejgQRs5ModeiJ6Xs=", 369 | "dev": true 370 | } 371 | } 372 | }, 373 | "browserify": { 374 | "version": "16.2.3", 375 | "resolved": "https://registry.npmjs.org/browserify/-/browserify-16.2.3.tgz", 376 | "integrity": "sha512-zQt/Gd1+W+IY+h/xX2NYMW4orQWhqSwyV+xsblycTtpOuB27h1fZhhNQuipJ4t79ohw4P4mMem0jp/ZkISQtjQ==", 377 | "dev": true, 378 | "requires": { 379 | "JSONStream": "^1.0.3", 380 | "assert": "^1.4.0", 381 | "browser-pack": "^6.0.1", 382 | "browser-resolve": "^1.11.0", 383 | "browserify-zlib": "~0.2.0", 384 | "buffer": "^5.0.2", 385 | "cached-path-relative": "^1.0.0", 386 | "concat-stream": "^1.6.0", 387 | "console-browserify": "^1.1.0", 388 | "constants-browserify": "~1.0.0", 389 | "crypto-browserify": "^3.0.0", 390 | "defined": "^1.0.0", 391 | "deps-sort": "^2.0.0", 392 | "domain-browser": "^1.2.0", 393 | "duplexer2": "~0.1.2", 394 | "events": "^2.0.0", 395 | "glob": "^7.1.0", 396 | "has": "^1.0.0", 397 | "htmlescape": "^1.1.0", 398 | "https-browserify": "^1.0.0", 399 | "inherits": "~2.0.1", 400 | "insert-module-globals": "^7.0.0", 401 | "labeled-stream-splicer": "^2.0.0", 402 | "mkdirp": "^0.5.0", 403 | "module-deps": "^6.0.0", 404 | "os-browserify": "~0.3.0", 405 | "parents": "^1.0.1", 406 | "path-browserify": "~0.0.0", 407 | "process": "~0.11.0", 408 | "punycode": "^1.3.2", 409 | "querystring-es3": "~0.2.0", 410 | "read-only-stream": "^2.0.0", 411 | "readable-stream": "^2.0.2", 412 | "resolve": "^1.1.4", 413 | "shasum": "^1.0.0", 414 | "shell-quote": "^1.6.1", 415 | "stream-browserify": "^2.0.0", 416 | "stream-http": "^2.0.0", 417 | "string_decoder": "^1.1.1", 418 | "subarg": "^1.0.0", 419 | "syntax-error": "^1.1.1", 420 | "through2": "^2.0.0", 421 | "timers-browserify": "^1.0.1", 422 | "tty-browserify": "0.0.1", 423 | "url": "~0.11.0", 424 | "util": "~0.10.1", 425 | "vm-browserify": "^1.0.0", 426 | "xtend": "^4.0.0" 427 | }, 428 | "dependencies": { 429 | "punycode": { 430 | "version": "1.4.1", 431 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-1.4.1.tgz", 432 | "integrity": "sha1-wNWmOycYgArY4esPpSachN1BhF4=", 433 | "dev": true 434 | } 435 | } 436 | }, 437 | "browserify-aes": { 438 | "version": "1.2.0", 439 | "resolved": "https://registry.npmjs.org/browserify-aes/-/browserify-aes-1.2.0.tgz", 440 | "integrity": "sha512-+7CHXqGuspUn/Sl5aO7Ea0xWGAtETPXNSAjHo48JfLdPWcMng33Xe4znFvQweqc/uzk5zSOI3H52CYnjCfb5hA==", 441 | "dev": true, 442 | "requires": { 443 | "buffer-xor": "^1.0.3", 444 | "cipher-base": "^1.0.0", 445 | "create-hash": "^1.1.0", 446 | "evp_bytestokey": "^1.0.3", 447 | "inherits": "^2.0.1", 448 | "safe-buffer": "^5.0.1" 449 | } 450 | }, 451 | "browserify-cipher": { 452 | "version": "1.0.1", 453 | "resolved": "https://registry.npmjs.org/browserify-cipher/-/browserify-cipher-1.0.1.tgz", 454 | "integrity": "sha512-sPhkz0ARKbf4rRQt2hTpAHqn47X3llLkUGn+xEJzLjwY8LRs2p0v7ljvI5EyoRO/mexrNunNECisZs+gw2zz1w==", 455 | "dev": true, 456 | "requires": { 457 | "browserify-aes": "^1.0.4", 458 | "browserify-des": "^1.0.0", 459 | "evp_bytestokey": "^1.0.0" 460 | } 461 | }, 462 | "browserify-des": { 463 | "version": "1.0.2", 464 | "resolved": "https://registry.npmjs.org/browserify-des/-/browserify-des-1.0.2.tgz", 465 | "integrity": "sha512-BioO1xf3hFwz4kc6iBhI3ieDFompMhrMlnDFC4/0/vd5MokpuAc3R+LYbwTA9A5Yc9pq9UYPqffKpW2ObuwX5A==", 466 | "dev": true, 467 | "requires": { 468 | "cipher-base": "^1.0.1", 469 | "des.js": "^1.0.0", 470 | "inherits": "^2.0.1", 471 | "safe-buffer": "^5.1.2" 472 | } 473 | }, 474 | "browserify-rsa": { 475 | "version": "4.0.1", 476 | "resolved": "https://registry.npmjs.org/browserify-rsa/-/browserify-rsa-4.0.1.tgz", 477 | "integrity": "sha1-IeCr+vbyApzy+vsTNWenAdQTVSQ=", 478 | "dev": true, 479 | "requires": { 480 | "bn.js": "^4.1.0", 481 | "randombytes": "^2.0.1" 482 | } 483 | }, 484 | "browserify-sign": { 485 | "version": "4.0.4", 486 | "resolved": "https://registry.npmjs.org/browserify-sign/-/browserify-sign-4.0.4.tgz", 487 | "integrity": "sha1-qk62jl17ZYuqa/alfmMMvXqT0pg=", 488 | "dev": true, 489 | "requires": { 490 | "bn.js": "^4.1.1", 491 | "browserify-rsa": "^4.0.0", 492 | "create-hash": "^1.1.0", 493 | "create-hmac": "^1.1.2", 494 | "elliptic": "^6.0.0", 495 | "inherits": "^2.0.1", 496 | "parse-asn1": "^5.0.0" 497 | } 498 | }, 499 | "browserify-zlib": { 500 | "version": "0.2.0", 501 | "resolved": "https://registry.npmjs.org/browserify-zlib/-/browserify-zlib-0.2.0.tgz", 502 | "integrity": "sha512-Z942RysHXmJrhqk88FmKBVq/v5tqmSkDz7p54G/MGyjMnCFFnC79XWNbg+Vta8W6Wb2qtSZTSxIGkJrRpCFEiA==", 503 | "dev": true, 504 | "requires": { 505 | "pako": "~1.0.5" 506 | } 507 | }, 508 | "buffer": { 509 | "version": "5.2.1", 510 | "resolved": "https://registry.npmjs.org/buffer/-/buffer-5.2.1.tgz", 511 | "integrity": "sha512-c+Ko0loDaFfuPWiL02ls9Xd3GO3cPVmUobQ6t3rXNUk304u6hGq+8N/kFi+QEIKhzK3uwolVhLzszmfLmMLnqg==", 512 | "dev": true, 513 | "requires": { 514 | "base64-js": "^1.0.2", 515 | "ieee754": "^1.1.4" 516 | } 517 | }, 518 | "buffer-from": { 519 | "version": "1.1.1", 520 | "resolved": "https://registry.npmjs.org/buffer-from/-/buffer-from-1.1.1.tgz", 521 | "integrity": "sha512-MQcXEUbCKtEo7bhqEs6560Hyd4XaovZlO/k9V3hjVUF/zwW7KBVdSK4gIt/bzwS9MbR5qob+F5jusZsb0YQK2A==", 522 | "dev": true 523 | }, 524 | "buffer-xor": { 525 | "version": "1.0.3", 526 | "resolved": "https://registry.npmjs.org/buffer-xor/-/buffer-xor-1.0.3.tgz", 527 | "integrity": "sha1-JuYe0UIvtw3ULm42cp7VHYVf6Nk=", 528 | "dev": true 529 | }, 530 | "builtin-status-codes": { 531 | "version": "3.0.0", 532 | "resolved": "https://registry.npmjs.org/builtin-status-codes/-/builtin-status-codes-3.0.0.tgz", 533 | "integrity": "sha1-hZgoeOIbmOHGZCXgPQF0eI9Wnug=", 534 | "dev": true 535 | }, 536 | "cached-path-relative": { 537 | "version": "1.0.2", 538 | "resolved": "https://registry.npmjs.org/cached-path-relative/-/cached-path-relative-1.0.2.tgz", 539 | "integrity": "sha512-5r2GqsoEb4qMTTN9J+WzXfjov+hjxT+j3u5K+kIVNIwAd99DLCJE9pBIMP1qVeybV6JiijL385Oz0DcYxfbOIg==", 540 | "dev": true 541 | }, 542 | "callsites": { 543 | "version": "3.0.0", 544 | "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.0.0.tgz", 545 | "integrity": "sha512-tWnkwu9YEq2uzlBDI4RcLn8jrFvF9AOi8PxDNU3hZZjJcjkcRAq3vCI+vZcg1SuxISDYe86k9VZFwAxDiJGoAw==", 546 | "dev": true 547 | }, 548 | "chalk": { 549 | "version": "2.4.2", 550 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", 551 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", 552 | "dev": true, 553 | "requires": { 554 | "ansi-styles": "^3.2.1", 555 | "escape-string-regexp": "^1.0.5", 556 | "supports-color": "^5.3.0" 557 | } 558 | }, 559 | "chardet": { 560 | "version": "0.7.0", 561 | "resolved": "https://registry.npmjs.org/chardet/-/chardet-0.7.0.tgz", 562 | "integrity": "sha512-mT8iDcrh03qDGRRmoA2hmBJnxpllMR+0/0qlzjqZES6NdiWDcZkCNAk4rPFZ9Q85r27unkiNNg8ZOiwZXBHwcA==", 563 | "dev": true 564 | }, 565 | "cipher-base": { 566 | "version": "1.0.4", 567 | "resolved": "https://registry.npmjs.org/cipher-base/-/cipher-base-1.0.4.tgz", 568 | "integrity": "sha512-Kkht5ye6ZGmwv40uUDZztayT2ThLQGfnj/T71N/XzeZeo3nf8foyW7zGTsPYkEya3m5f3cAypH+qe7YOrM1U2Q==", 569 | "dev": true, 570 | "requires": { 571 | "inherits": "^2.0.1", 572 | "safe-buffer": "^5.0.1" 573 | } 574 | }, 575 | "cli-cursor": { 576 | "version": "2.1.0", 577 | "resolved": "https://registry.npmjs.org/cli-cursor/-/cli-cursor-2.1.0.tgz", 578 | "integrity": "sha1-s12sN2R5+sw+lHR9QdDQ9SOP/LU=", 579 | "dev": true, 580 | "requires": { 581 | "restore-cursor": "^2.0.0" 582 | } 583 | }, 584 | "cli-width": { 585 | "version": "2.2.0", 586 | "resolved": "https://registry.npmjs.org/cli-width/-/cli-width-2.2.0.tgz", 587 | "integrity": "sha1-/xnt6Kml5XkyQUewwR8PvLq+1jk=", 588 | "dev": true 589 | }, 590 | "color-convert": { 591 | "version": "1.9.3", 592 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", 593 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", 594 | "dev": true, 595 | "requires": { 596 | "color-name": "1.1.3" 597 | } 598 | }, 599 | "color-name": { 600 | "version": "1.1.3", 601 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 602 | "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=", 603 | "dev": true 604 | }, 605 | "combine-source-map": { 606 | "version": "0.8.0", 607 | "resolved": "https://registry.npmjs.org/combine-source-map/-/combine-source-map-0.8.0.tgz", 608 | "integrity": "sha1-pY0N8ELBhvz4IqjoAV9UUNLXmos=", 609 | "dev": true, 610 | "requires": { 611 | "convert-source-map": "~1.1.0", 612 | "inline-source-map": "~0.6.0", 613 | "lodash.memoize": "~3.0.3", 614 | "source-map": "~0.5.3" 615 | } 616 | }, 617 | "commander": { 618 | "version": "2.19.0", 619 | "resolved": "https://registry.npmjs.org/commander/-/commander-2.19.0.tgz", 620 | "integrity": "sha512-6tvAOO+D6OENvRAh524Dh9jcfKTYDQAqvqezbCW82xj5X0pSrcpxtvRKHLG0yBY6SD7PSDrJaj+0AiOcKVd1Xg==" 621 | }, 622 | "concat-map": { 623 | "version": "0.0.1", 624 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 625 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=", 626 | "dev": true 627 | }, 628 | "concat-stream": { 629 | "version": "1.6.2", 630 | "resolved": "https://registry.npmjs.org/concat-stream/-/concat-stream-1.6.2.tgz", 631 | "integrity": "sha512-27HBghJxjiZtIk3Ycvn/4kbJk/1uZuJFfuPEns6LaEvpvG1f0hTea8lilrouyo9mVc2GWdcEZ8OLoGmSADlrCw==", 632 | "dev": true, 633 | "requires": { 634 | "buffer-from": "^1.0.0", 635 | "inherits": "^2.0.3", 636 | "readable-stream": "^2.2.2", 637 | "typedarray": "^0.0.6" 638 | } 639 | }, 640 | "console-browserify": { 641 | "version": "1.1.0", 642 | "resolved": "https://registry.npmjs.org/console-browserify/-/console-browserify-1.1.0.tgz", 643 | "integrity": "sha1-8CQcRXMKn8YyOyBtvzjtx0HQuxA=", 644 | "dev": true, 645 | "requires": { 646 | "date-now": "^0.1.4" 647 | } 648 | }, 649 | "constants-browserify": { 650 | "version": "1.0.0", 651 | "resolved": "https://registry.npmjs.org/constants-browserify/-/constants-browserify-1.0.0.tgz", 652 | "integrity": "sha1-wguW2MYXdIqvHBYCF2DNJ/y4y3U=", 653 | "dev": true 654 | }, 655 | "contains-path": { 656 | "version": "0.1.0", 657 | "resolved": "https://registry.npmjs.org/contains-path/-/contains-path-0.1.0.tgz", 658 | "integrity": "sha1-/ozxhP9mcLa67wGp1IYaXL7EEgo=", 659 | "dev": true 660 | }, 661 | "convert-source-map": { 662 | "version": "1.1.3", 663 | "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-1.1.3.tgz", 664 | "integrity": "sha1-SCnId+n+SbMWHzvzZziI4gRpmGA=", 665 | "dev": true 666 | }, 667 | "core-util-is": { 668 | "version": "1.0.2", 669 | "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.2.tgz", 670 | "integrity": "sha1-tf1UIgqivFq1eqtxQMlAdUUDwac=", 671 | "dev": true 672 | }, 673 | "create-ecdh": { 674 | "version": "4.0.3", 675 | "resolved": "https://registry.npmjs.org/create-ecdh/-/create-ecdh-4.0.3.tgz", 676 | "integrity": "sha512-GbEHQPMOswGpKXM9kCWVrremUcBmjteUaQ01T9rkKCPDXfUHX0IoP9LpHYo2NPFampa4e+/pFDc3jQdxrxQLaw==", 677 | "dev": true, 678 | "requires": { 679 | "bn.js": "^4.1.0", 680 | "elliptic": "^6.0.0" 681 | } 682 | }, 683 | "create-hash": { 684 | "version": "1.2.0", 685 | "resolved": "https://registry.npmjs.org/create-hash/-/create-hash-1.2.0.tgz", 686 | "integrity": "sha512-z00bCGNHDG8mHAkP7CtT1qVu+bFQUPjYq/4Iv3C3kWjTFV10zIjfSoeqXo9Asws8gwSHDGj/hl2u4OGIjapeCg==", 687 | "dev": true, 688 | "requires": { 689 | "cipher-base": "^1.0.1", 690 | "inherits": "^2.0.1", 691 | "md5.js": "^1.3.4", 692 | "ripemd160": "^2.0.1", 693 | "sha.js": "^2.4.0" 694 | } 695 | }, 696 | "create-hmac": { 697 | "version": "1.1.7", 698 | "resolved": "https://registry.npmjs.org/create-hmac/-/create-hmac-1.1.7.tgz", 699 | "integrity": "sha512-MJG9liiZ+ogc4TzUwuvbER1JRdgvUFSB5+VR/g5h82fGaIRWMWddtKBHi7/sVhfjQZ6SehlyhvQYrcYkaUIpLg==", 700 | "dev": true, 701 | "requires": { 702 | "cipher-base": "^1.0.3", 703 | "create-hash": "^1.1.0", 704 | "inherits": "^2.0.1", 705 | "ripemd160": "^2.0.0", 706 | "safe-buffer": "^5.0.1", 707 | "sha.js": "^2.4.8" 708 | } 709 | }, 710 | "cross-spawn": { 711 | "version": "6.0.5", 712 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-6.0.5.tgz", 713 | "integrity": "sha512-eTVLrBSt7fjbDygz805pMnstIs2VTBNkRm0qxZd+M7A5XDdxVRWO5MxGBXZhjY4cqLYLdtrGqRf8mBPmzwSpWQ==", 714 | "dev": true, 715 | "requires": { 716 | "nice-try": "^1.0.4", 717 | "path-key": "^2.0.1", 718 | "semver": "^5.5.0", 719 | "shebang-command": "^1.2.0", 720 | "which": "^1.2.9" 721 | } 722 | }, 723 | "crypto-browserify": { 724 | "version": "3.12.0", 725 | "resolved": "https://registry.npmjs.org/crypto-browserify/-/crypto-browserify-3.12.0.tgz", 726 | "integrity": "sha512-fz4spIh+znjO2VjL+IdhEpRJ3YN6sMzITSBijk6FK2UvTqruSQW+/cCZTSNsMiZNvUeq0CqurF+dAbyiGOY6Wg==", 727 | "dev": true, 728 | "requires": { 729 | "browserify-cipher": "^1.0.0", 730 | "browserify-sign": "^4.0.0", 731 | "create-ecdh": "^4.0.0", 732 | "create-hash": "^1.1.0", 733 | "create-hmac": "^1.1.0", 734 | "diffie-hellman": "^5.0.0", 735 | "inherits": "^2.0.1", 736 | "pbkdf2": "^3.0.3", 737 | "public-encrypt": "^4.0.0", 738 | "randombytes": "^2.0.0", 739 | "randomfill": "^1.0.3" 740 | } 741 | }, 742 | "damerau-levenshtein": { 743 | "version": "1.0.4", 744 | "resolved": "https://registry.npmjs.org/damerau-levenshtein/-/damerau-levenshtein-1.0.4.tgz", 745 | "integrity": "sha1-AxkcQyy27qFou3fzpV/9zLiXhRQ=" 746 | }, 747 | "dash-ast": { 748 | "version": "1.0.0", 749 | "resolved": "https://registry.npmjs.org/dash-ast/-/dash-ast-1.0.0.tgz", 750 | "integrity": "sha512-Vy4dx7gquTeMcQR/hDkYLGUnwVil6vk4FOOct+djUnHOUWt+zJPJAaRIXaAFkPXtJjvlY7o3rfRu0/3hpnwoUA==", 751 | "dev": true 752 | }, 753 | "date-now": { 754 | "version": "0.1.4", 755 | "resolved": "https://registry.npmjs.org/date-now/-/date-now-0.1.4.tgz", 756 | "integrity": "sha1-6vQ5/U1ISK105cx9vvIAZyueNFs=", 757 | "dev": true 758 | }, 759 | "debug": { 760 | "version": "4.1.1", 761 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.1.1.tgz", 762 | "integrity": "sha512-pYAIzeRo8J6KPEaJ0VWOh5Pzkbw/RetuzehGM7QRRX5he4fPHx2rdKMB256ehJCkX+XRQm16eZLqLNS8RSZXZw==", 763 | "dev": true, 764 | "requires": { 765 | "ms": "^2.1.1" 766 | } 767 | }, 768 | "deep-is": { 769 | "version": "0.1.3", 770 | "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.3.tgz", 771 | "integrity": "sha1-s2nW+128E+7PUk+RsHD+7cNXzzQ=" 772 | }, 773 | "define-properties": { 774 | "version": "1.1.3", 775 | "resolved": "https://registry.npmjs.org/define-properties/-/define-properties-1.1.3.tgz", 776 | "integrity": "sha512-3MqfYKj2lLzdMSf8ZIZE/V+Zuy+BgD6f164e8K2w7dgnpKArBDerGYpM46IYYcjnkdPNMjPk9A6VFB8+3SKlXQ==", 777 | "requires": { 778 | "object-keys": "^1.0.12" 779 | } 780 | }, 781 | "defined": { 782 | "version": "1.0.0", 783 | "resolved": "https://registry.npmjs.org/defined/-/defined-1.0.0.tgz", 784 | "integrity": "sha1-yY2bzvdWdBiOEQlpFRGZ45sfppM=", 785 | "dev": true 786 | }, 787 | "deps-sort": { 788 | "version": "2.0.0", 789 | "resolved": "https://registry.npmjs.org/deps-sort/-/deps-sort-2.0.0.tgz", 790 | "integrity": "sha1-CRckkC6EZYJg65EHSMzNGvbiH7U=", 791 | "dev": true, 792 | "requires": { 793 | "JSONStream": "^1.0.3", 794 | "shasum": "^1.0.0", 795 | "subarg": "^1.0.0", 796 | "through2": "^2.0.0" 797 | } 798 | }, 799 | "des.js": { 800 | "version": "1.0.0", 801 | "resolved": "https://registry.npmjs.org/des.js/-/des.js-1.0.0.tgz", 802 | "integrity": "sha1-wHTS4qpqipoH29YfmhXCzYPsjsw=", 803 | "dev": true, 804 | "requires": { 805 | "inherits": "^2.0.1", 806 | "minimalistic-assert": "^1.0.0" 807 | } 808 | }, 809 | "detective": { 810 | "version": "5.2.0", 811 | "resolved": "https://registry.npmjs.org/detective/-/detective-5.2.0.tgz", 812 | "integrity": "sha512-6SsIx+nUUbuK0EthKjv0zrdnajCCXVYGmbYYiYjFVpzcjwEs/JMDZ8tPRG29J/HhN56t3GJp2cGSWDRjjot8Pg==", 813 | "dev": true, 814 | "requires": { 815 | "acorn-node": "^1.6.1", 816 | "defined": "^1.0.0", 817 | "minimist": "^1.1.1" 818 | }, 819 | "dependencies": { 820 | "minimist": { 821 | "version": "1.2.0", 822 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.0.tgz", 823 | "integrity": "sha1-o1AIsg9BOD7sH7kU9M1d95omQoQ=", 824 | "dev": true 825 | } 826 | } 827 | }, 828 | "diffie-hellman": { 829 | "version": "5.0.3", 830 | "resolved": "https://registry.npmjs.org/diffie-hellman/-/diffie-hellman-5.0.3.tgz", 831 | "integrity": "sha512-kqag/Nl+f3GwyK25fhUMYj81BUOrZ9IuJsjIcDE5icNM9FJHAVm3VcUDxdLPoQtTuUylWm6ZIknYJwwaPxsUzg==", 832 | "dev": true, 833 | "requires": { 834 | "bn.js": "^4.1.0", 835 | "miller-rabin": "^4.0.0", 836 | "randombytes": "^2.0.0" 837 | } 838 | }, 839 | "doctrine": { 840 | "version": "3.0.0", 841 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-3.0.0.tgz", 842 | "integrity": "sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w==", 843 | "dev": true, 844 | "requires": { 845 | "esutils": "^2.0.2" 846 | } 847 | }, 848 | "domain-browser": { 849 | "version": "1.2.0", 850 | "resolved": "https://registry.npmjs.org/domain-browser/-/domain-browser-1.2.0.tgz", 851 | "integrity": "sha512-jnjyiM6eRyZl2H+W8Q/zLMA481hzi0eszAaBUzIVnmYVDBbnLxVNnfu1HgEBvCbL+71FrxMl3E6lpKH7Ge3OXA==", 852 | "dev": true 853 | }, 854 | "duplexer2": { 855 | "version": "0.1.4", 856 | "resolved": "https://registry.npmjs.org/duplexer2/-/duplexer2-0.1.4.tgz", 857 | "integrity": "sha1-ixLauHjA1p4+eJEFFmKjL8a93ME=", 858 | "dev": true, 859 | "requires": { 860 | "readable-stream": "^2.0.2" 861 | } 862 | }, 863 | "elliptic": { 864 | "version": "6.4.1", 865 | "resolved": "https://registry.npmjs.org/elliptic/-/elliptic-6.4.1.tgz", 866 | "integrity": "sha512-BsXLz5sqX8OHcsh7CqBMztyXARmGQ3LWPtGjJi6DiJHq5C/qvi9P3OqgswKSDftbu8+IoI/QDTAm2fFnQ9SZSQ==", 867 | "dev": true, 868 | "requires": { 869 | "bn.js": "^4.4.0", 870 | "brorand": "^1.0.1", 871 | "hash.js": "^1.0.0", 872 | "hmac-drbg": "^1.0.0", 873 | "inherits": "^2.0.1", 874 | "minimalistic-assert": "^1.0.0", 875 | "minimalistic-crypto-utils": "^1.0.0" 876 | } 877 | }, 878 | "emoji-regex": { 879 | "version": "7.0.3", 880 | "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-7.0.3.tgz", 881 | "integrity": "sha512-CwBLREIQ7LvYFB0WyRvwhq5N5qPhc6PMjD6bYggFlI5YyDgl+0vxq5VHbMOFqLg7hfWzmu8T5Z1QofhmTIhItA==" 882 | }, 883 | "error-ex": { 884 | "version": "1.3.2", 885 | "resolved": "https://registry.npmjs.org/error-ex/-/error-ex-1.3.2.tgz", 886 | "integrity": "sha512-7dFHNmqeFSEt2ZBsCriorKnn3Z2pj+fd9kmI6QoWw4//DL+icEBfc0U7qJCisqrTsKTjw4fNFy2pW9OqStD84g==", 887 | "dev": true, 888 | "requires": { 889 | "is-arrayish": "^0.2.1" 890 | } 891 | }, 892 | "es-abstract": { 893 | "version": "1.13.0", 894 | "resolved": "https://registry.npmjs.org/es-abstract/-/es-abstract-1.13.0.tgz", 895 | "integrity": "sha512-vDZfg/ykNxQVwup/8E1BZhVzFfBxs9NqMzGcvIJrqg5k2/5Za2bWo40dK2J1pgLngZ7c+Shh8lwYtLGyrwPutg==", 896 | "requires": { 897 | "es-to-primitive": "^1.2.0", 898 | "function-bind": "^1.1.1", 899 | "has": "^1.0.3", 900 | "is-callable": "^1.1.4", 901 | "is-regex": "^1.0.4", 902 | "object-keys": "^1.0.12" 903 | } 904 | }, 905 | "es-to-primitive": { 906 | "version": "1.2.0", 907 | "resolved": "https://registry.npmjs.org/es-to-primitive/-/es-to-primitive-1.2.0.tgz", 908 | "integrity": "sha512-qZryBOJjV//LaxLTV6UC//WewneB3LcXOL9NP++ozKVXsIIIpm/2c13UDiD9Jp2eThsecw9m3jPqDwTyobcdbg==", 909 | "requires": { 910 | "is-callable": "^1.1.4", 911 | "is-date-object": "^1.0.1", 912 | "is-symbol": "^1.0.2" 913 | } 914 | }, 915 | "escape-string-regexp": { 916 | "version": "1.0.5", 917 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", 918 | "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=", 919 | "dev": true 920 | }, 921 | "escodegen": { 922 | "version": "1.11.1", 923 | "resolved": "https://registry.npmjs.org/escodegen/-/escodegen-1.11.1.tgz", 924 | "integrity": "sha512-JwiqFD9KdGVVpeuRa68yU3zZnBEOcPs0nKW7wZzXky8Z7tffdYUHbe11bPCV5jYlK6DVdKLWLm0f5I/QlL0Kmw==", 925 | "requires": { 926 | "esprima": "^3.1.3", 927 | "estraverse": "^4.2.0", 928 | "esutils": "^2.0.2", 929 | "optionator": "^0.8.1", 930 | "source-map": "~0.6.1" 931 | }, 932 | "dependencies": { 933 | "esprima": { 934 | "version": "3.1.3", 935 | "resolved": "https://registry.npmjs.org/esprima/-/esprima-3.1.3.tgz", 936 | "integrity": "sha1-/cpRzuYTOJXjyI1TXOSdv/YqRjM=" 937 | }, 938 | "source-map": { 939 | "version": "0.6.1", 940 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", 941 | "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", 942 | "optional": true 943 | } 944 | } 945 | }, 946 | "eslint": { 947 | "version": "5.14.1", 948 | "resolved": "https://registry.npmjs.org/eslint/-/eslint-5.14.1.tgz", 949 | "integrity": "sha512-CyUMbmsjxedx8B0mr79mNOqetvkbij/zrXnFeK2zc3pGRn3/tibjiNAv/3UxFEyfMDjh+ZqTrJrEGBFiGfD5Og==", 950 | "dev": true, 951 | "requires": { 952 | "@babel/code-frame": "^7.0.0", 953 | "ajv": "^6.9.1", 954 | "chalk": "^2.1.0", 955 | "cross-spawn": "^6.0.5", 956 | "debug": "^4.0.1", 957 | "doctrine": "^3.0.0", 958 | "eslint-scope": "^4.0.0", 959 | "eslint-utils": "^1.3.1", 960 | "eslint-visitor-keys": "^1.0.0", 961 | "espree": "^5.0.1", 962 | "esquery": "^1.0.1", 963 | "esutils": "^2.0.2", 964 | "file-entry-cache": "^5.0.1", 965 | "functional-red-black-tree": "^1.0.1", 966 | "glob": "^7.1.2", 967 | "globals": "^11.7.0", 968 | "ignore": "^4.0.6", 969 | "import-fresh": "^3.0.0", 970 | "imurmurhash": "^0.1.4", 971 | "inquirer": "^6.2.2", 972 | "js-yaml": "^3.12.0", 973 | "json-stable-stringify-without-jsonify": "^1.0.1", 974 | "levn": "^0.3.0", 975 | "lodash": "^4.17.11", 976 | "minimatch": "^3.0.4", 977 | "mkdirp": "^0.5.1", 978 | "natural-compare": "^1.4.0", 979 | "optionator": "^0.8.2", 980 | "path-is-inside": "^1.0.2", 981 | "progress": "^2.0.0", 982 | "regexpp": "^2.0.1", 983 | "semver": "^5.5.1", 984 | "strip-ansi": "^4.0.0", 985 | "strip-json-comments": "^2.0.1", 986 | "table": "^5.2.3", 987 | "text-table": "^0.2.0" 988 | }, 989 | "dependencies": { 990 | "eslint-scope": { 991 | "version": "4.0.0", 992 | "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-4.0.0.tgz", 993 | "integrity": "sha512-1G6UTDi7Jc1ELFwnR58HV4fK9OQK4S6N985f166xqXxpjU6plxFISJa2Ba9KCQuFa8RCnj/lSFJbHo7UFDBnUA==", 994 | "dev": true, 995 | "requires": { 996 | "esrecurse": "^4.1.0", 997 | "estraverse": "^4.1.1" 998 | } 999 | } 1000 | } 1001 | }, 1002 | "eslint-config-airbnb": { 1003 | "version": "17.1.0", 1004 | "resolved": "https://registry.npmjs.org/eslint-config-airbnb/-/eslint-config-airbnb-17.1.0.tgz", 1005 | "integrity": "sha512-R9jw28hFfEQnpPau01NO5K/JWMGLi6aymiF6RsnMURjTk+MqZKllCqGK/0tOvHkPi/NWSSOU2Ced/GX++YxLnw==", 1006 | "requires": { 1007 | "eslint-config-airbnb-base": "^13.1.0", 1008 | "object.assign": "^4.1.0", 1009 | "object.entries": "^1.0.4" 1010 | } 1011 | }, 1012 | "eslint-config-airbnb-base": { 1013 | "version": "13.1.0", 1014 | "resolved": "https://registry.npmjs.org/eslint-config-airbnb-base/-/eslint-config-airbnb-base-13.1.0.tgz", 1015 | "integrity": "sha512-XWwQtf3U3zIoKO1BbHh6aUhJZQweOwSt4c2JrPDg9FP3Ltv3+YfEv7jIDB8275tVnO/qOHbfuYg3kzw6Je7uWw==", 1016 | "requires": { 1017 | "eslint-restricted-globals": "^0.1.1", 1018 | "object.assign": "^4.1.0", 1019 | "object.entries": "^1.0.4" 1020 | } 1021 | }, 1022 | "eslint-import-resolver-node": { 1023 | "version": "0.3.2", 1024 | "resolved": "https://registry.npmjs.org/eslint-import-resolver-node/-/eslint-import-resolver-node-0.3.2.tgz", 1025 | "integrity": "sha512-sfmTqJfPSizWu4aymbPr4Iidp5yKm8yDkHp+Ir3YiTHiiDfxh69mOUsmiqW6RZ9zRXFaF64GtYmN7e+8GHBv6Q==", 1026 | "dev": true, 1027 | "requires": { 1028 | "debug": "^2.6.9", 1029 | "resolve": "^1.5.0" 1030 | }, 1031 | "dependencies": { 1032 | "debug": { 1033 | "version": "2.6.9", 1034 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 1035 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 1036 | "dev": true, 1037 | "requires": { 1038 | "ms": "2.0.0" 1039 | } 1040 | }, 1041 | "ms": { 1042 | "version": "2.0.0", 1043 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 1044 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=", 1045 | "dev": true 1046 | } 1047 | } 1048 | }, 1049 | "eslint-module-utils": { 1050 | "version": "2.3.0", 1051 | "resolved": "https://registry.npmjs.org/eslint-module-utils/-/eslint-module-utils-2.3.0.tgz", 1052 | "integrity": "sha512-lmDJgeOOjk8hObTysjqH7wyMi+nsHwwvfBykwfhjR1LNdd7C2uFJBvx4OpWYpXOw4df1yE1cDEVd1yLHitk34w==", 1053 | "dev": true, 1054 | "requires": { 1055 | "debug": "^2.6.8", 1056 | "pkg-dir": "^2.0.0" 1057 | }, 1058 | "dependencies": { 1059 | "debug": { 1060 | "version": "2.6.9", 1061 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 1062 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 1063 | "dev": true, 1064 | "requires": { 1065 | "ms": "2.0.0" 1066 | } 1067 | }, 1068 | "ms": { 1069 | "version": "2.0.0", 1070 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 1071 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=", 1072 | "dev": true 1073 | } 1074 | } 1075 | }, 1076 | "eslint-plugin-import": { 1077 | "version": "2.16.0", 1078 | "resolved": "https://registry.npmjs.org/eslint-plugin-import/-/eslint-plugin-import-2.16.0.tgz", 1079 | "integrity": "sha512-z6oqWlf1x5GkHIFgrSvtmudnqM6Q60KM4KvpWi5ubonMjycLjndvd5+8VAZIsTlHC03djdgJuyKG6XO577px6A==", 1080 | "dev": true, 1081 | "requires": { 1082 | "contains-path": "^0.1.0", 1083 | "debug": "^2.6.9", 1084 | "doctrine": "1.5.0", 1085 | "eslint-import-resolver-node": "^0.3.2", 1086 | "eslint-module-utils": "^2.3.0", 1087 | "has": "^1.0.3", 1088 | "lodash": "^4.17.11", 1089 | "minimatch": "^3.0.4", 1090 | "read-pkg-up": "^2.0.0", 1091 | "resolve": "^1.9.0" 1092 | }, 1093 | "dependencies": { 1094 | "debug": { 1095 | "version": "2.6.9", 1096 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 1097 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 1098 | "dev": true, 1099 | "requires": { 1100 | "ms": "2.0.0" 1101 | } 1102 | }, 1103 | "doctrine": { 1104 | "version": "1.5.0", 1105 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-1.5.0.tgz", 1106 | "integrity": "sha1-N53Ocw9hZvds76TmcHoVmwLFpvo=", 1107 | "dev": true, 1108 | "requires": { 1109 | "esutils": "^2.0.2", 1110 | "isarray": "^1.0.0" 1111 | } 1112 | }, 1113 | "ms": { 1114 | "version": "2.0.0", 1115 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 1116 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=", 1117 | "dev": true 1118 | } 1119 | } 1120 | }, 1121 | "eslint-plugin-jsx-a11y": { 1122 | "version": "6.2.1", 1123 | "resolved": "https://registry.npmjs.org/eslint-plugin-jsx-a11y/-/eslint-plugin-jsx-a11y-6.2.1.tgz", 1124 | "integrity": "sha512-cjN2ObWrRz0TTw7vEcGQrx+YltMvZoOEx4hWU8eEERDnBIU00OTq7Vr+jA7DFKxiwLNv4tTh5Pq2GUNEa8b6+w==", 1125 | "requires": { 1126 | "aria-query": "^3.0.0", 1127 | "array-includes": "^3.0.3", 1128 | "ast-types-flow": "^0.0.7", 1129 | "axobject-query": "^2.0.2", 1130 | "damerau-levenshtein": "^1.0.4", 1131 | "emoji-regex": "^7.0.2", 1132 | "has": "^1.0.3", 1133 | "jsx-ast-utils": "^2.0.1" 1134 | } 1135 | }, 1136 | "eslint-plugin-react": { 1137 | "version": "7.12.4", 1138 | "resolved": "https://registry.npmjs.org/eslint-plugin-react/-/eslint-plugin-react-7.12.4.tgz", 1139 | "integrity": "sha512-1puHJkXJY+oS1t467MjbqjvX53uQ05HXwjqDgdbGBqf5j9eeydI54G3KwiJmWciQ0HTBacIKw2jgwSBSH3yfgQ==", 1140 | "dev": true, 1141 | "requires": { 1142 | "array-includes": "^3.0.3", 1143 | "doctrine": "^2.1.0", 1144 | "has": "^1.0.3", 1145 | "jsx-ast-utils": "^2.0.1", 1146 | "object.fromentries": "^2.0.0", 1147 | "prop-types": "^15.6.2", 1148 | "resolve": "^1.9.0" 1149 | }, 1150 | "dependencies": { 1151 | "doctrine": { 1152 | "version": "2.1.0", 1153 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-2.1.0.tgz", 1154 | "integrity": "sha512-35mSku4ZXK0vfCuHEDAwt55dg2jNajHZ1odvF+8SSr82EsZY4QmXfuWso8oEd8zRhVObSN18aM0CjSdoBX7zIw==", 1155 | "dev": true, 1156 | "requires": { 1157 | "esutils": "^2.0.2" 1158 | } 1159 | } 1160 | } 1161 | }, 1162 | "eslint-restricted-globals": { 1163 | "version": "0.1.1", 1164 | "resolved": "https://registry.npmjs.org/eslint-restricted-globals/-/eslint-restricted-globals-0.1.1.tgz", 1165 | "integrity": "sha1-NfDVy8ZMLj7WLpO0saevBbp+1Nc=" 1166 | }, 1167 | "eslint-scope": { 1168 | "version": "3.7.1", 1169 | "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-3.7.1.tgz", 1170 | "integrity": "sha1-PWPD7f2gLgbgGkUq2IyqzHzctug=", 1171 | "dev": true, 1172 | "requires": { 1173 | "esrecurse": "^4.1.0", 1174 | "estraverse": "^4.1.1" 1175 | } 1176 | }, 1177 | "eslint-utils": { 1178 | "version": "1.3.1", 1179 | "resolved": "https://registry.npmjs.org/eslint-utils/-/eslint-utils-1.3.1.tgz", 1180 | "integrity": "sha512-Z7YjnIldX+2XMcjr7ZkgEsOj/bREONV60qYeB/bjMAqqqZ4zxKyWX+BOUkdmRmA9riiIPVvo5x86m5elviOk0Q==", 1181 | "dev": true 1182 | }, 1183 | "eslint-visitor-keys": { 1184 | "version": "1.0.0", 1185 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-1.0.0.tgz", 1186 | "integrity": "sha512-qzm/XxIbxm/FHyH341ZrbnMUpe+5Bocte9xkmFMzPMjRaZMcXww+MpBptFvtU+79L362nqiLhekCxCxDPaUMBQ==", 1187 | "dev": true 1188 | }, 1189 | "espree": { 1190 | "version": "5.0.1", 1191 | "resolved": "https://registry.npmjs.org/espree/-/espree-5.0.1.tgz", 1192 | "integrity": "sha512-qWAZcWh4XE/RwzLJejfcofscgMc9CamR6Tn1+XRXNzrvUSSbiAjGOI/fggztjIi7y9VLPqnICMIPiGyr8JaZ0A==", 1193 | "dev": true, 1194 | "requires": { 1195 | "acorn": "^6.0.7", 1196 | "acorn-jsx": "^5.0.0", 1197 | "eslint-visitor-keys": "^1.0.0" 1198 | } 1199 | }, 1200 | "esprima": { 1201 | "version": "4.0.1", 1202 | "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz", 1203 | "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==" 1204 | }, 1205 | "esquery": { 1206 | "version": "1.0.1", 1207 | "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.0.1.tgz", 1208 | "integrity": "sha512-SmiyZ5zIWH9VM+SRUReLS5Q8a7GxtRdxEBVZpm98rJM7Sb+A9DVCndXfkeFUd3byderg+EbDkfnevfCwynWaNA==", 1209 | "dev": true, 1210 | "requires": { 1211 | "estraverse": "^4.0.0" 1212 | } 1213 | }, 1214 | "esrecurse": { 1215 | "version": "4.2.1", 1216 | "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.2.1.tgz", 1217 | "integrity": "sha512-64RBB++fIOAXPw3P9cy89qfMlvZEXZkqqJkjqqXIvzP5ezRZjW+lPWjw35UX/3EhUPFYbg5ER4JYgDw4007/DQ==", 1218 | "dev": true, 1219 | "requires": { 1220 | "estraverse": "^4.1.0" 1221 | } 1222 | }, 1223 | "estraverse": { 1224 | "version": "4.2.0", 1225 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-4.2.0.tgz", 1226 | "integrity": "sha1-De4/7TH81GlhjOc0IJn8GvoL2xM=" 1227 | }, 1228 | "esutils": { 1229 | "version": "2.0.2", 1230 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.2.tgz", 1231 | "integrity": "sha1-Cr9PHKpbyx96nYrMbepPqqBLrJs=" 1232 | }, 1233 | "events": { 1234 | "version": "2.1.0", 1235 | "resolved": "https://registry.npmjs.org/events/-/events-2.1.0.tgz", 1236 | "integrity": "sha512-3Zmiobend8P9DjmKAty0Era4jV8oJ0yGYe2nJJAxgymF9+N8F2m0hhZiMoWtcfepExzNKZumFU3ksdQbInGWCg==", 1237 | "dev": true 1238 | }, 1239 | "evp_bytestokey": { 1240 | "version": "1.0.3", 1241 | "resolved": "https://registry.npmjs.org/evp_bytestokey/-/evp_bytestokey-1.0.3.tgz", 1242 | "integrity": "sha512-/f2Go4TognH/KvCISP7OUsHn85hT9nUkxxA9BEWxFn+Oj9o8ZNLm/40hdlgSLyuOimsrTKLUMEorQexp/aPQeA==", 1243 | "dev": true, 1244 | "requires": { 1245 | "md5.js": "^1.3.4", 1246 | "safe-buffer": "^5.1.1" 1247 | } 1248 | }, 1249 | "external-editor": { 1250 | "version": "3.0.3", 1251 | "resolved": "https://registry.npmjs.org/external-editor/-/external-editor-3.0.3.tgz", 1252 | "integrity": "sha512-bn71H9+qWoOQKyZDo25mOMVpSmXROAsTJVVVYzrrtol3d4y+AsKjf4Iwl2Q+IuT0kFSQ1qo166UuIwqYq7mGnA==", 1253 | "dev": true, 1254 | "requires": { 1255 | "chardet": "^0.7.0", 1256 | "iconv-lite": "^0.4.24", 1257 | "tmp": "^0.0.33" 1258 | } 1259 | }, 1260 | "fast-deep-equal": { 1261 | "version": "2.0.1", 1262 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-2.0.1.tgz", 1263 | "integrity": "sha1-ewUhjd+WZ79/Nwv3/bLLFf3Qqkk=", 1264 | "dev": true 1265 | }, 1266 | "fast-json-stable-stringify": { 1267 | "version": "2.0.0", 1268 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.0.0.tgz", 1269 | "integrity": "sha1-1RQsDK7msRifh9OnYREGT4bIu/I=", 1270 | "dev": true 1271 | }, 1272 | "fast-levenshtein": { 1273 | "version": "2.0.6", 1274 | "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", 1275 | "integrity": "sha1-PYpcZog6FqMMqGQ+hR8Zuqd5eRc=" 1276 | }, 1277 | "figures": { 1278 | "version": "2.0.0", 1279 | "resolved": "https://registry.npmjs.org/figures/-/figures-2.0.0.tgz", 1280 | "integrity": "sha1-OrGi0qYsi/tDGgyUy3l6L84nyWI=", 1281 | "dev": true, 1282 | "requires": { 1283 | "escape-string-regexp": "^1.0.5" 1284 | } 1285 | }, 1286 | "file-entry-cache": { 1287 | "version": "5.0.1", 1288 | "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-5.0.1.tgz", 1289 | "integrity": "sha512-bCg29ictuBaKUwwArK4ouCaqDgLZcysCFLmM/Yn/FDoqndh/9vNuQfXRDvTuXKLxfD/JtZQGKFT8MGcJBK644g==", 1290 | "dev": true, 1291 | "requires": { 1292 | "flat-cache": "^2.0.1" 1293 | } 1294 | }, 1295 | "find-up": { 1296 | "version": "2.1.0", 1297 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-2.1.0.tgz", 1298 | "integrity": "sha1-RdG35QbHF93UgndaK3eSCjwMV6c=", 1299 | "dev": true, 1300 | "requires": { 1301 | "locate-path": "^2.0.0" 1302 | } 1303 | }, 1304 | "flat-cache": { 1305 | "version": "2.0.1", 1306 | "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-2.0.1.tgz", 1307 | "integrity": "sha512-LoQe6yDuUMDzQAEH8sgmh4Md6oZnc/7PjtwjNFSzveXqSHt6ka9fPBuso7IGf9Rz4uqnSnWiFH2B/zj24a5ReA==", 1308 | "dev": true, 1309 | "requires": { 1310 | "flatted": "^2.0.0", 1311 | "rimraf": "2.6.3", 1312 | "write": "1.0.3" 1313 | } 1314 | }, 1315 | "flatted": { 1316 | "version": "2.0.0", 1317 | "resolved": "https://registry.npmjs.org/flatted/-/flatted-2.0.0.tgz", 1318 | "integrity": "sha512-R+H8IZclI8AAkSBRQJLVOsxwAoHd6WC40b4QTNWIjzAa6BXOBfQcM587MXDTVPeYaopFNWHUFLx7eNmHDSxMWg==", 1319 | "dev": true 1320 | }, 1321 | "fs.realpath": { 1322 | "version": "1.0.0", 1323 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 1324 | "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=", 1325 | "dev": true 1326 | }, 1327 | "function-bind": { 1328 | "version": "1.1.1", 1329 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", 1330 | "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==" 1331 | }, 1332 | "functional-red-black-tree": { 1333 | "version": "1.0.1", 1334 | "resolved": "https://registry.npmjs.org/functional-red-black-tree/-/functional-red-black-tree-1.0.1.tgz", 1335 | "integrity": "sha1-GwqzvVU7Kg1jmdKcDj6gslIHgyc=", 1336 | "dev": true 1337 | }, 1338 | "get-assigned-identifiers": { 1339 | "version": "1.2.0", 1340 | "resolved": "https://registry.npmjs.org/get-assigned-identifiers/-/get-assigned-identifiers-1.2.0.tgz", 1341 | "integrity": "sha512-mBBwmeGTrxEMO4pMaaf/uUEFHnYtwr8FTe8Y/mer4rcV/bye0qGm6pw1bGZFGStxC5O76c5ZAVBGnqHmOaJpdQ==", 1342 | "dev": true 1343 | }, 1344 | "glob": { 1345 | "version": "7.1.3", 1346 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.3.tgz", 1347 | "integrity": "sha512-vcfuiIxogLV4DlGBHIUOwI0IbrJ8HWPc4MU7HzviGeNho/UJDfi6B5p3sHeWIQ0KGIU0Jpxi5ZHxemQfLkkAwQ==", 1348 | "dev": true, 1349 | "requires": { 1350 | "fs.realpath": "^1.0.0", 1351 | "inflight": "^1.0.4", 1352 | "inherits": "2", 1353 | "minimatch": "^3.0.4", 1354 | "once": "^1.3.0", 1355 | "path-is-absolute": "^1.0.0" 1356 | } 1357 | }, 1358 | "globals": { 1359 | "version": "11.11.0", 1360 | "resolved": "https://registry.npmjs.org/globals/-/globals-11.11.0.tgz", 1361 | "integrity": "sha512-WHq43gS+6ufNOEqlrDBxVEbb8ntfXrfAUU2ZOpCxrBdGKW3gyv8mCxAfIBD0DroPKGrJ2eSsXsLtY9MPntsyTw==", 1362 | "dev": true 1363 | }, 1364 | "graceful-fs": { 1365 | "version": "4.1.15", 1366 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.1.15.tgz", 1367 | "integrity": "sha512-6uHUhOPEBgQ24HM+r6b/QwWfZq+yiFcipKFrOFiBEnWdy5sdzYoi+pJeQaPI5qOLRFqWmAXUPQNsielzdLoecA==", 1368 | "dev": true 1369 | }, 1370 | "has": { 1371 | "version": "1.0.3", 1372 | "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", 1373 | "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", 1374 | "requires": { 1375 | "function-bind": "^1.1.1" 1376 | } 1377 | }, 1378 | "has-flag": { 1379 | "version": "3.0.0", 1380 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 1381 | "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=", 1382 | "dev": true 1383 | }, 1384 | "has-symbols": { 1385 | "version": "1.0.0", 1386 | "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.0.tgz", 1387 | "integrity": "sha1-uhqPGvKg/DllD1yFA2dwQSIGO0Q=" 1388 | }, 1389 | "hash-base": { 1390 | "version": "3.0.4", 1391 | "resolved": "https://registry.npmjs.org/hash-base/-/hash-base-3.0.4.tgz", 1392 | "integrity": "sha1-X8hoaEfs1zSZQDMZprCj8/auSRg=", 1393 | "dev": true, 1394 | "requires": { 1395 | "inherits": "^2.0.1", 1396 | "safe-buffer": "^5.0.1" 1397 | } 1398 | }, 1399 | "hash.js": { 1400 | "version": "1.1.7", 1401 | "resolved": "https://registry.npmjs.org/hash.js/-/hash.js-1.1.7.tgz", 1402 | "integrity": "sha512-taOaskGt4z4SOANNseOviYDvjEJinIkRgmp7LbKP2YTTmVxWBl87s/uzK9r+44BclBSp2X7K1hqeNfz9JbBeXA==", 1403 | "dev": true, 1404 | "requires": { 1405 | "inherits": "^2.0.3", 1406 | "minimalistic-assert": "^1.0.1" 1407 | } 1408 | }, 1409 | "hmac-drbg": { 1410 | "version": "1.0.1", 1411 | "resolved": "https://registry.npmjs.org/hmac-drbg/-/hmac-drbg-1.0.1.tgz", 1412 | "integrity": "sha1-0nRXAQJabHdabFRXk+1QL8DGSaE=", 1413 | "dev": true, 1414 | "requires": { 1415 | "hash.js": "^1.0.3", 1416 | "minimalistic-assert": "^1.0.0", 1417 | "minimalistic-crypto-utils": "^1.0.1" 1418 | } 1419 | }, 1420 | "hosted-git-info": { 1421 | "version": "2.7.1", 1422 | "resolved": "https://registry.npmjs.org/hosted-git-info/-/hosted-git-info-2.7.1.tgz", 1423 | "integrity": "sha512-7T/BxH19zbcCTa8XkMlbK5lTo1WtgkFi3GvdWEyNuc4Vex7/9Dqbnpsf4JMydcfj9HCg4zUWFTL3Za6lapg5/w==", 1424 | "dev": true 1425 | }, 1426 | "htmlescape": { 1427 | "version": "1.1.1", 1428 | "resolved": "https://registry.npmjs.org/htmlescape/-/htmlescape-1.1.1.tgz", 1429 | "integrity": "sha1-OgPtwiFLyjtmQko+eVk0lQnLA1E=", 1430 | "dev": true 1431 | }, 1432 | "https-browserify": { 1433 | "version": "1.0.0", 1434 | "resolved": "https://registry.npmjs.org/https-browserify/-/https-browserify-1.0.0.tgz", 1435 | "integrity": "sha1-7AbBDgo0wPL68Zn3/X/Hj//QPHM=", 1436 | "dev": true 1437 | }, 1438 | "iconv-lite": { 1439 | "version": "0.4.24", 1440 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", 1441 | "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", 1442 | "dev": true, 1443 | "requires": { 1444 | "safer-buffer": ">= 2.1.2 < 3" 1445 | } 1446 | }, 1447 | "ieee754": { 1448 | "version": "1.1.12", 1449 | "resolved": "https://registry.npmjs.org/ieee754/-/ieee754-1.1.12.tgz", 1450 | "integrity": "sha512-GguP+DRY+pJ3soyIiGPTvdiVXjZ+DbXOxGpXn3eMvNW4x4irjqXm4wHKscC+TfxSJ0yw/S1F24tqdMNsMZTiLA==", 1451 | "dev": true 1452 | }, 1453 | "ignore": { 1454 | "version": "4.0.6", 1455 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-4.0.6.tgz", 1456 | "integrity": "sha512-cyFDKrqc/YdcWFniJhzI42+AzS+gNwmUzOSFcRCQYwySuBBBy/KjuxWLZ/FHEH6Moq1NizMOBWyTcv8O4OZIMg==", 1457 | "dev": true 1458 | }, 1459 | "import-fresh": { 1460 | "version": "3.0.0", 1461 | "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.0.0.tgz", 1462 | "integrity": "sha512-pOnA9tfM3Uwics+SaBLCNyZZZbK+4PTu0OPZtLlMIrv17EdBoC15S9Kn8ckJ9TZTyKb3ywNE5y1yeDxxGA7nTQ==", 1463 | "dev": true, 1464 | "requires": { 1465 | "parent-module": "^1.0.0", 1466 | "resolve-from": "^4.0.0" 1467 | } 1468 | }, 1469 | "imurmurhash": { 1470 | "version": "0.1.4", 1471 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 1472 | "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=", 1473 | "dev": true 1474 | }, 1475 | "inflight": { 1476 | "version": "1.0.6", 1477 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 1478 | "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", 1479 | "dev": true, 1480 | "requires": { 1481 | "once": "^1.3.0", 1482 | "wrappy": "1" 1483 | } 1484 | }, 1485 | "inherits": { 1486 | "version": "2.0.3", 1487 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz", 1488 | "integrity": "sha1-Yzwsg+PaQqUC9SRmAiSA9CCCYd4=", 1489 | "dev": true 1490 | }, 1491 | "inline-source-map": { 1492 | "version": "0.6.2", 1493 | "resolved": "https://registry.npmjs.org/inline-source-map/-/inline-source-map-0.6.2.tgz", 1494 | "integrity": "sha1-+Tk0ccGKedFyT4Y/o4tYY3Ct4qU=", 1495 | "dev": true, 1496 | "requires": { 1497 | "source-map": "~0.5.3" 1498 | } 1499 | }, 1500 | "inquirer": { 1501 | "version": "6.2.2", 1502 | "resolved": "https://registry.npmjs.org/inquirer/-/inquirer-6.2.2.tgz", 1503 | "integrity": "sha512-Z2rREiXA6cHRR9KBOarR3WuLlFzlIfAEIiB45ll5SSadMg7WqOh1MKEjjndfuH5ewXdixWCxqnVfGOQzPeiztA==", 1504 | "dev": true, 1505 | "requires": { 1506 | "ansi-escapes": "^3.2.0", 1507 | "chalk": "^2.4.2", 1508 | "cli-cursor": "^2.1.0", 1509 | "cli-width": "^2.0.0", 1510 | "external-editor": "^3.0.3", 1511 | "figures": "^2.0.0", 1512 | "lodash": "^4.17.11", 1513 | "mute-stream": "0.0.7", 1514 | "run-async": "^2.2.0", 1515 | "rxjs": "^6.4.0", 1516 | "string-width": "^2.1.0", 1517 | "strip-ansi": "^5.0.0", 1518 | "through": "^2.3.6" 1519 | }, 1520 | "dependencies": { 1521 | "ansi-regex": { 1522 | "version": "4.0.0", 1523 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.0.0.tgz", 1524 | "integrity": "sha512-iB5Dda8t/UqpPI/IjsejXu5jOGDrzn41wJyljwPH65VCIbk6+1BzFIMJGFwTNrYXT1CrD+B4l19U7awiQ8rk7w==", 1525 | "dev": true 1526 | }, 1527 | "strip-ansi": { 1528 | "version": "5.0.0", 1529 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.0.0.tgz", 1530 | "integrity": "sha512-Uu7gQyZI7J7gn5qLn1Np3G9vcYGTVqB+lFTytnDJv83dd8T22aGH451P3jueT2/QemInJDfxHB5Tde5OzgG1Ow==", 1531 | "dev": true, 1532 | "requires": { 1533 | "ansi-regex": "^4.0.0" 1534 | } 1535 | } 1536 | } 1537 | }, 1538 | "insert-module-globals": { 1539 | "version": "7.2.0", 1540 | "resolved": "https://registry.npmjs.org/insert-module-globals/-/insert-module-globals-7.2.0.tgz", 1541 | "integrity": "sha512-VE6NlW+WGn2/AeOMd496AHFYmE7eLKkUY6Ty31k4og5vmA3Fjuwe9v6ifH6Xx/Hz27QvdoMoviw1/pqWRB09Sw==", 1542 | "dev": true, 1543 | "requires": { 1544 | "JSONStream": "^1.0.3", 1545 | "acorn-node": "^1.5.2", 1546 | "combine-source-map": "^0.8.0", 1547 | "concat-stream": "^1.6.1", 1548 | "is-buffer": "^1.1.0", 1549 | "path-is-absolute": "^1.0.1", 1550 | "process": "~0.11.0", 1551 | "through2": "^2.0.0", 1552 | "undeclared-identifiers": "^1.1.2", 1553 | "xtend": "^4.0.0" 1554 | } 1555 | }, 1556 | "is-arrayish": { 1557 | "version": "0.2.1", 1558 | "resolved": "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.2.1.tgz", 1559 | "integrity": "sha1-d8mYQFJ6qOyxqLppe4BkWnqSap0=", 1560 | "dev": true 1561 | }, 1562 | "is-buffer": { 1563 | "version": "1.1.6", 1564 | "resolved": "https://registry.npmjs.org/is-buffer/-/is-buffer-1.1.6.tgz", 1565 | "integrity": "sha512-NcdALwpXkTm5Zvvbk7owOUSvVvBKDgKP5/ewfXEznmQFfs4ZRmanOeKBTjRVjka3QFoN6XJ+9F3USqfHqTaU5w==", 1566 | "dev": true 1567 | }, 1568 | "is-callable": { 1569 | "version": "1.1.4", 1570 | "resolved": "https://registry.npmjs.org/is-callable/-/is-callable-1.1.4.tgz", 1571 | "integrity": "sha512-r5p9sxJjYnArLjObpjA4xu5EKI3CuKHkJXMhT7kwbpUyIFD1n5PMAsoPvWnvtZiNz7LjkYDRZhd7FlI0eMijEA==" 1572 | }, 1573 | "is-date-object": { 1574 | "version": "1.0.1", 1575 | "resolved": "https://registry.npmjs.org/is-date-object/-/is-date-object-1.0.1.tgz", 1576 | "integrity": "sha1-mqIOtq7rv/d/vTPnTKAbM1gdOhY=" 1577 | }, 1578 | "is-fullwidth-code-point": { 1579 | "version": "2.0.0", 1580 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", 1581 | "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=", 1582 | "dev": true 1583 | }, 1584 | "is-promise": { 1585 | "version": "2.1.0", 1586 | "resolved": "https://registry.npmjs.org/is-promise/-/is-promise-2.1.0.tgz", 1587 | "integrity": "sha1-eaKp7OfwlugPNtKy87wWwf9L8/o=", 1588 | "dev": true 1589 | }, 1590 | "is-regex": { 1591 | "version": "1.0.4", 1592 | "resolved": "https://registry.npmjs.org/is-regex/-/is-regex-1.0.4.tgz", 1593 | "integrity": "sha1-VRdIm1RwkbCTDglWVM7SXul+lJE=", 1594 | "requires": { 1595 | "has": "^1.0.1" 1596 | } 1597 | }, 1598 | "is-symbol": { 1599 | "version": "1.0.2", 1600 | "resolved": "https://registry.npmjs.org/is-symbol/-/is-symbol-1.0.2.tgz", 1601 | "integrity": "sha512-HS8bZ9ox60yCJLH9snBpIwv9pYUAkcuLhSA1oero1UB5y9aiQpRA8y2ex945AOtCZL1lJDeIk3G5LthswI46Lw==", 1602 | "requires": { 1603 | "has-symbols": "^1.0.0" 1604 | } 1605 | }, 1606 | "isarray": { 1607 | "version": "1.0.0", 1608 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", 1609 | "integrity": "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE=", 1610 | "dev": true 1611 | }, 1612 | "isexe": { 1613 | "version": "2.0.0", 1614 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 1615 | "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=", 1616 | "dev": true 1617 | }, 1618 | "js-tokens": { 1619 | "version": "4.0.0", 1620 | "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", 1621 | "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==", 1622 | "dev": true 1623 | }, 1624 | "js-yaml": { 1625 | "version": "3.13.1", 1626 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.13.1.tgz", 1627 | "integrity": "sha512-YfbcO7jXDdyj0DGxYVSlSeQNHbD7XPWvrVWeVUujrQEoZzWJIRrCPoyk6kL6IAjAG2IolMK4T0hNUe0HOUs5Jw==", 1628 | "dev": true, 1629 | "requires": { 1630 | "argparse": "^1.0.7", 1631 | "esprima": "^4.0.0" 1632 | } 1633 | }, 1634 | "jsesc": { 1635 | "version": "2.5.2", 1636 | "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-2.5.2.tgz", 1637 | "integrity": "sha512-OYu7XEzjkCQ3C5Ps3QIZsQfNpqoJyZZA99wd9aWd05NCtC5pWOkShK2mkL6HXQR6/Cy2lbNdPlZBpuQHXE63gA==", 1638 | "dev": true 1639 | }, 1640 | "json-schema-traverse": { 1641 | "version": "0.4.1", 1642 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", 1643 | "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", 1644 | "dev": true 1645 | }, 1646 | "json-stable-stringify": { 1647 | "version": "0.0.1", 1648 | "resolved": "https://registry.npmjs.org/json-stable-stringify/-/json-stable-stringify-0.0.1.tgz", 1649 | "integrity": "sha1-YRwj6BTbN1Un34URk9tZ3Sryf0U=", 1650 | "dev": true, 1651 | "requires": { 1652 | "jsonify": "~0.0.0" 1653 | } 1654 | }, 1655 | "json-stable-stringify-without-jsonify": { 1656 | "version": "1.0.1", 1657 | "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz", 1658 | "integrity": "sha1-nbe1lJatPzz+8wp1FC0tkwrXJlE=", 1659 | "dev": true 1660 | }, 1661 | "jsonify": { 1662 | "version": "0.0.0", 1663 | "resolved": "https://registry.npmjs.org/jsonify/-/jsonify-0.0.0.tgz", 1664 | "integrity": "sha1-LHS27kHZPKUbe1qu6PUDYx0lKnM=", 1665 | "dev": true 1666 | }, 1667 | "jsonparse": { 1668 | "version": "1.3.1", 1669 | "resolved": "https://registry.npmjs.org/jsonparse/-/jsonparse-1.3.1.tgz", 1670 | "integrity": "sha1-P02uSpH6wxX3EGL4UhzCOfE2YoA=", 1671 | "dev": true 1672 | }, 1673 | "jsx-ast-utils": { 1674 | "version": "2.0.1", 1675 | "resolved": "https://registry.npmjs.org/jsx-ast-utils/-/jsx-ast-utils-2.0.1.tgz", 1676 | "integrity": "sha1-6AGxs5mF4g//yHtA43SAgOLcrH8=", 1677 | "requires": { 1678 | "array-includes": "^3.0.3" 1679 | } 1680 | }, 1681 | "labeled-stream-splicer": { 1682 | "version": "2.0.1", 1683 | "resolved": "https://registry.npmjs.org/labeled-stream-splicer/-/labeled-stream-splicer-2.0.1.tgz", 1684 | "integrity": "sha512-MC94mHZRvJ3LfykJlTUipBqenZz1pacOZEMhhQ8dMGcDHs0SBE5GbsavUXV7YtP3icBW17W0Zy1I0lfASmo9Pg==", 1685 | "dev": true, 1686 | "requires": { 1687 | "inherits": "^2.0.1", 1688 | "isarray": "^2.0.4", 1689 | "stream-splicer": "^2.0.0" 1690 | }, 1691 | "dependencies": { 1692 | "isarray": { 1693 | "version": "2.0.4", 1694 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-2.0.4.tgz", 1695 | "integrity": "sha512-GMxXOiUirWg1xTKRipM0Ek07rX+ubx4nNVElTJdNLYmNO/2YrDkgJGw9CljXn+r4EWiDQg/8lsRdHyg2PJuUaA==", 1696 | "dev": true 1697 | } 1698 | } 1699 | }, 1700 | "levn": { 1701 | "version": "0.3.0", 1702 | "resolved": "https://registry.npmjs.org/levn/-/levn-0.3.0.tgz", 1703 | "integrity": "sha1-OwmSTt+fCDwEkP3UwLxEIeBHZO4=", 1704 | "requires": { 1705 | "prelude-ls": "~1.1.2", 1706 | "type-check": "~0.3.2" 1707 | } 1708 | }, 1709 | "load-json-file": { 1710 | "version": "2.0.0", 1711 | "resolved": "https://registry.npmjs.org/load-json-file/-/load-json-file-2.0.0.tgz", 1712 | "integrity": "sha1-eUfkIUmvgNaWy/eXvKq8/h/inKg=", 1713 | "dev": true, 1714 | "requires": { 1715 | "graceful-fs": "^4.1.2", 1716 | "parse-json": "^2.2.0", 1717 | "pify": "^2.0.0", 1718 | "strip-bom": "^3.0.0" 1719 | } 1720 | }, 1721 | "locate-path": { 1722 | "version": "2.0.0", 1723 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-2.0.0.tgz", 1724 | "integrity": "sha1-K1aLJl7slExtnA3pw9u7ygNUzY4=", 1725 | "dev": true, 1726 | "requires": { 1727 | "p-locate": "^2.0.0", 1728 | "path-exists": "^3.0.0" 1729 | } 1730 | }, 1731 | "lodash": { 1732 | "version": "4.17.11", 1733 | "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.11.tgz", 1734 | "integrity": "sha512-cQKh8igo5QUhZ7lg38DYWAxMvjSAKG0A8wGSVimP07SIUEK2UO+arSRKbRZWtelMtN5V0Hkwh5ryOto/SshYIg==", 1735 | "dev": true 1736 | }, 1737 | "lodash.memoize": { 1738 | "version": "3.0.4", 1739 | "resolved": "https://registry.npmjs.org/lodash.memoize/-/lodash.memoize-3.0.4.tgz", 1740 | "integrity": "sha1-LcvSwofLwKVcxCMovQxzYVDVPj8=", 1741 | "dev": true 1742 | }, 1743 | "loose-envify": { 1744 | "version": "1.4.0", 1745 | "resolved": "https://registry.npmjs.org/loose-envify/-/loose-envify-1.4.0.tgz", 1746 | "integrity": "sha512-lyuxPGr/Wfhrlem2CL/UcnUc1zcqKAImBDzukY7Y5F/yQiNdko6+fRLevlw1HgMySw7f611UIY408EtxRSoK3Q==", 1747 | "dev": true, 1748 | "requires": { 1749 | "js-tokens": "^3.0.0 || ^4.0.0" 1750 | } 1751 | }, 1752 | "md5.js": { 1753 | "version": "1.3.5", 1754 | "resolved": "https://registry.npmjs.org/md5.js/-/md5.js-1.3.5.tgz", 1755 | "integrity": "sha512-xitP+WxNPcTTOgnTJcrhM0xvdPepipPSf3I8EIpGKeFLjt3PlJLIDG3u8EX53ZIubkb+5U2+3rELYpEhHhzdkg==", 1756 | "dev": true, 1757 | "requires": { 1758 | "hash-base": "^3.0.0", 1759 | "inherits": "^2.0.1", 1760 | "safe-buffer": "^5.1.2" 1761 | } 1762 | }, 1763 | "miller-rabin": { 1764 | "version": "4.0.1", 1765 | "resolved": "https://registry.npmjs.org/miller-rabin/-/miller-rabin-4.0.1.tgz", 1766 | "integrity": "sha512-115fLhvZVqWwHPbClyntxEVfVDfl9DLLTuJvq3g2O/Oxi8AiNouAHvDSzHS0viUJc+V5vm3eq91Xwqn9dp4jRA==", 1767 | "dev": true, 1768 | "requires": { 1769 | "bn.js": "^4.0.0", 1770 | "brorand": "^1.0.1" 1771 | } 1772 | }, 1773 | "mimic-fn": { 1774 | "version": "1.2.0", 1775 | "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-1.2.0.tgz", 1776 | "integrity": "sha512-jf84uxzwiuiIVKiOLpfYk7N46TSy8ubTonmneY9vrpHNAnp0QBt2BxWV9dO3/j+BoVAb+a5G6YDPW3M5HOdMWQ==", 1777 | "dev": true 1778 | }, 1779 | "minimalistic-assert": { 1780 | "version": "1.0.1", 1781 | "resolved": "https://registry.npmjs.org/minimalistic-assert/-/minimalistic-assert-1.0.1.tgz", 1782 | "integrity": "sha512-UtJcAD4yEaGtjPezWuO9wC4nwUnVH/8/Im3yEHQP4b67cXlD/Qr9hdITCU1xDbSEXg2XKNaP8jsReV7vQd00/A==", 1783 | "dev": true 1784 | }, 1785 | "minimalistic-crypto-utils": { 1786 | "version": "1.0.1", 1787 | "resolved": "https://registry.npmjs.org/minimalistic-crypto-utils/-/minimalistic-crypto-utils-1.0.1.tgz", 1788 | "integrity": "sha1-9sAMHAsIIkblxNmd+4x8CDsrWCo=", 1789 | "dev": true 1790 | }, 1791 | "minimatch": { 1792 | "version": "3.0.4", 1793 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", 1794 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 1795 | "dev": true, 1796 | "requires": { 1797 | "brace-expansion": "^1.1.7" 1798 | } 1799 | }, 1800 | "minimist": { 1801 | "version": "0.0.8", 1802 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-0.0.8.tgz", 1803 | "integrity": "sha1-hX/Kv8M5fSYluCKCYuhqp6ARsF0=", 1804 | "dev": true 1805 | }, 1806 | "mkdirp": { 1807 | "version": "0.5.1", 1808 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.1.tgz", 1809 | "integrity": "sha1-MAV0OOrGz3+MR2fzhkjWaX11yQM=", 1810 | "dev": true, 1811 | "requires": { 1812 | "minimist": "0.0.8" 1813 | } 1814 | }, 1815 | "module-deps": { 1816 | "version": "6.2.0", 1817 | "resolved": "https://registry.npmjs.org/module-deps/-/module-deps-6.2.0.tgz", 1818 | "integrity": "sha512-hKPmO06so6bL/ZvqVNVqdTVO8UAYsi3tQWlCa+z9KuWhoN4KDQtb5hcqQQv58qYiDE21wIvnttZEPiDgEbpwbA==", 1819 | "dev": true, 1820 | "requires": { 1821 | "JSONStream": "^1.0.3", 1822 | "browser-resolve": "^1.7.0", 1823 | "cached-path-relative": "^1.0.0", 1824 | "concat-stream": "~1.6.0", 1825 | "defined": "^1.0.0", 1826 | "detective": "^5.0.2", 1827 | "duplexer2": "^0.1.2", 1828 | "inherits": "^2.0.1", 1829 | "parents": "^1.0.0", 1830 | "readable-stream": "^2.0.2", 1831 | "resolve": "^1.4.0", 1832 | "stream-combiner2": "^1.1.1", 1833 | "subarg": "^1.0.0", 1834 | "through2": "^2.0.0", 1835 | "xtend": "^4.0.0" 1836 | } 1837 | }, 1838 | "ms": { 1839 | "version": "2.1.1", 1840 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.1.tgz", 1841 | "integrity": "sha512-tgp+dl5cGk28utYktBsrFqA7HKgrhgPsg6Z/EfhWI4gl1Hwq8B/GmY/0oXZ6nF8hDVesS/FpnYaD/kOWhYQvyg==", 1842 | "dev": true 1843 | }, 1844 | "mute-stream": { 1845 | "version": "0.0.7", 1846 | "resolved": "https://registry.npmjs.org/mute-stream/-/mute-stream-0.0.7.tgz", 1847 | "integrity": "sha1-MHXOk7whuPq0PhvE2n6BFe0ee6s=", 1848 | "dev": true 1849 | }, 1850 | "natural-compare": { 1851 | "version": "1.4.0", 1852 | "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", 1853 | "integrity": "sha1-Sr6/7tdUHywnrPspvbvRXI1bpPc=", 1854 | "dev": true 1855 | }, 1856 | "nice-try": { 1857 | "version": "1.0.5", 1858 | "resolved": "https://registry.npmjs.org/nice-try/-/nice-try-1.0.5.tgz", 1859 | "integrity": "sha512-1nh45deeb5olNY7eX82BkPO7SSxR5SSYJiPTrTdFUVYwAl8CKMA5N9PjTYkHiRjisVcxcQ1HXdLhx2qxxJzLNQ==", 1860 | "dev": true 1861 | }, 1862 | "normalize-package-data": { 1863 | "version": "2.5.0", 1864 | "resolved": "https://registry.npmjs.org/normalize-package-data/-/normalize-package-data-2.5.0.tgz", 1865 | "integrity": "sha512-/5CMN3T0R4XTj4DcGaexo+roZSdSFW/0AOOTROrjxzCG1wrWXEsGbRKevjlIL+ZDE4sZlJr5ED4YW0yqmkK+eA==", 1866 | "dev": true, 1867 | "requires": { 1868 | "hosted-git-info": "^2.1.4", 1869 | "resolve": "^1.10.0", 1870 | "semver": "2 || 3 || 4 || 5", 1871 | "validate-npm-package-license": "^3.0.1" 1872 | } 1873 | }, 1874 | "object-assign": { 1875 | "version": "4.1.1", 1876 | "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", 1877 | "integrity": "sha1-IQmtx5ZYh8/AXLvUQsrIv7s2CGM=", 1878 | "dev": true 1879 | }, 1880 | "object-keys": { 1881 | "version": "1.1.0", 1882 | "resolved": "https://registry.npmjs.org/object-keys/-/object-keys-1.1.0.tgz", 1883 | "integrity": "sha512-6OO5X1+2tYkNyNEx6TsCxEqFfRWaqx6EtMiSbGrw8Ob8v9Ne+Hl8rBAgLBZn5wjEz3s/s6U1WXFUFOcxxAwUpg==" 1884 | }, 1885 | "object.assign": { 1886 | "version": "4.1.0", 1887 | "resolved": "https://registry.npmjs.org/object.assign/-/object.assign-4.1.0.tgz", 1888 | "integrity": "sha512-exHJeq6kBKj58mqGyTQ9DFvrZC/eR6OwxzoM9YRoGBqrXYonaFyGiFMuc9VZrXf7DarreEwMpurG3dd+CNyW5w==", 1889 | "requires": { 1890 | "define-properties": "^1.1.2", 1891 | "function-bind": "^1.1.1", 1892 | "has-symbols": "^1.0.0", 1893 | "object-keys": "^1.0.11" 1894 | } 1895 | }, 1896 | "object.entries": { 1897 | "version": "1.1.0", 1898 | "resolved": "https://registry.npmjs.org/object.entries/-/object.entries-1.1.0.tgz", 1899 | "integrity": "sha512-l+H6EQ8qzGRxbkHOd5I/aHRhHDKoQXQ8g0BYt4uSweQU1/J6dZUOyWh9a2Vky35YCKjzmgxOzta2hH6kf9HuXA==", 1900 | "requires": { 1901 | "define-properties": "^1.1.3", 1902 | "es-abstract": "^1.12.0", 1903 | "function-bind": "^1.1.1", 1904 | "has": "^1.0.3" 1905 | } 1906 | }, 1907 | "object.fromentries": { 1908 | "version": "2.0.0", 1909 | "resolved": "https://registry.npmjs.org/object.fromentries/-/object.fromentries-2.0.0.tgz", 1910 | "integrity": "sha512-9iLiI6H083uiqUuvzyY6qrlmc/Gz8hLQFOcb/Ri/0xXFkSNS3ctV+CbE6yM2+AnkYfOB3dGjdzC0wrMLIhQICA==", 1911 | "dev": true, 1912 | "requires": { 1913 | "define-properties": "^1.1.2", 1914 | "es-abstract": "^1.11.0", 1915 | "function-bind": "^1.1.1", 1916 | "has": "^1.0.1" 1917 | } 1918 | }, 1919 | "once": { 1920 | "version": "1.4.0", 1921 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 1922 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 1923 | "dev": true, 1924 | "requires": { 1925 | "wrappy": "1" 1926 | } 1927 | }, 1928 | "onetime": { 1929 | "version": "2.0.1", 1930 | "resolved": "https://registry.npmjs.org/onetime/-/onetime-2.0.1.tgz", 1931 | "integrity": "sha1-BnQoIw/WdEOyeUsiu6UotoZ5YtQ=", 1932 | "dev": true, 1933 | "requires": { 1934 | "mimic-fn": "^1.0.0" 1935 | } 1936 | }, 1937 | "optionator": { 1938 | "version": "0.8.2", 1939 | "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.8.2.tgz", 1940 | "integrity": "sha1-NkxeQJ0/TWMB1sC0wFu6UBgK62Q=", 1941 | "requires": { 1942 | "deep-is": "~0.1.3", 1943 | "fast-levenshtein": "~2.0.4", 1944 | "levn": "~0.3.0", 1945 | "prelude-ls": "~1.1.2", 1946 | "type-check": "~0.3.2", 1947 | "wordwrap": "~1.0.0" 1948 | } 1949 | }, 1950 | "os-browserify": { 1951 | "version": "0.3.0", 1952 | "resolved": "https://registry.npmjs.org/os-browserify/-/os-browserify-0.3.0.tgz", 1953 | "integrity": "sha1-hUNzx/XCMVkU/Jv8a9gjj92h7Cc=", 1954 | "dev": true 1955 | }, 1956 | "os-tmpdir": { 1957 | "version": "1.0.2", 1958 | "resolved": "https://registry.npmjs.org/os-tmpdir/-/os-tmpdir-1.0.2.tgz", 1959 | "integrity": "sha1-u+Z0BseaqFxc/sdm/lc0VV36EnQ=", 1960 | "dev": true 1961 | }, 1962 | "p-limit": { 1963 | "version": "1.3.0", 1964 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-1.3.0.tgz", 1965 | "integrity": "sha512-vvcXsLAJ9Dr5rQOPk7toZQZJApBl2K4J6dANSsEuh6QI41JYcsS/qhTGa9ErIUUgK3WNQoJYvylxvjqmiqEA9Q==", 1966 | "dev": true, 1967 | "requires": { 1968 | "p-try": "^1.0.0" 1969 | } 1970 | }, 1971 | "p-locate": { 1972 | "version": "2.0.0", 1973 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-2.0.0.tgz", 1974 | "integrity": "sha1-IKAQOyIqcMj9OcwuWAaA893l7EM=", 1975 | "dev": true, 1976 | "requires": { 1977 | "p-limit": "^1.1.0" 1978 | } 1979 | }, 1980 | "p-try": { 1981 | "version": "1.0.0", 1982 | "resolved": "https://registry.npmjs.org/p-try/-/p-try-1.0.0.tgz", 1983 | "integrity": "sha1-y8ec26+P1CKOE/Yh8rGiN8GyB7M=", 1984 | "dev": true 1985 | }, 1986 | "pako": { 1987 | "version": "1.0.10", 1988 | "resolved": "https://registry.npmjs.org/pako/-/pako-1.0.10.tgz", 1989 | "integrity": "sha512-0DTvPVU3ed8+HNXOu5Bs+o//Mbdj9VNQMUOe9oKCwh8l0GNwpTDMKCWbRjgtD291AWnkAgkqA/LOnQS8AmS1tw==", 1990 | "dev": true 1991 | }, 1992 | "parent-module": { 1993 | "version": "1.0.0", 1994 | "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.0.tgz", 1995 | "integrity": "sha512-8Mf5juOMmiE4FcmzYc4IaiS9L3+9paz2KOiXzkRviCP6aDmN49Hz6EMWz0lGNp9pX80GvvAuLADtyGfW/Em3TA==", 1996 | "dev": true, 1997 | "requires": { 1998 | "callsites": "^3.0.0" 1999 | } 2000 | }, 2001 | "parents": { 2002 | "version": "1.0.1", 2003 | "resolved": "https://registry.npmjs.org/parents/-/parents-1.0.1.tgz", 2004 | "integrity": "sha1-/t1NK/GTp3dF/nHjcdc8MwfZx1E=", 2005 | "dev": true, 2006 | "requires": { 2007 | "path-platform": "~0.11.15" 2008 | } 2009 | }, 2010 | "parse-asn1": { 2011 | "version": "5.1.4", 2012 | "resolved": "https://registry.npmjs.org/parse-asn1/-/parse-asn1-5.1.4.tgz", 2013 | "integrity": "sha512-Qs5duJcuvNExRfFZ99HDD3z4mAi3r9Wl/FOjEOijlxwCZs7E7mW2vjTpgQ4J8LpTF8x5v+1Vn5UQFejmWT11aw==", 2014 | "dev": true, 2015 | "requires": { 2016 | "asn1.js": "^4.0.0", 2017 | "browserify-aes": "^1.0.0", 2018 | "create-hash": "^1.1.0", 2019 | "evp_bytestokey": "^1.0.0", 2020 | "pbkdf2": "^3.0.3", 2021 | "safe-buffer": "^5.1.1" 2022 | } 2023 | }, 2024 | "parse-json": { 2025 | "version": "2.2.0", 2026 | "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-2.2.0.tgz", 2027 | "integrity": "sha1-9ID0BDTvgHQfhGkJn43qGPVaTck=", 2028 | "dev": true, 2029 | "requires": { 2030 | "error-ex": "^1.2.0" 2031 | } 2032 | }, 2033 | "path-browserify": { 2034 | "version": "0.0.1", 2035 | "resolved": "https://registry.npmjs.org/path-browserify/-/path-browserify-0.0.1.tgz", 2036 | "integrity": "sha512-BapA40NHICOS+USX9SN4tyhq+A2RrN/Ws5F0Z5aMHDp98Fl86lX8Oti8B7uN93L4Ifv4fHOEA+pQw87gmMO/lQ==", 2037 | "dev": true 2038 | }, 2039 | "path-exists": { 2040 | "version": "3.0.0", 2041 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-3.0.0.tgz", 2042 | "integrity": "sha1-zg6+ql94yxiSXqfYENe1mwEP1RU=", 2043 | "dev": true 2044 | }, 2045 | "path-is-absolute": { 2046 | "version": "1.0.1", 2047 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 2048 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=", 2049 | "dev": true 2050 | }, 2051 | "path-is-inside": { 2052 | "version": "1.0.2", 2053 | "resolved": "https://registry.npmjs.org/path-is-inside/-/path-is-inside-1.0.2.tgz", 2054 | "integrity": "sha1-NlQX3t5EQw0cEa9hAn+s8HS9/FM=", 2055 | "dev": true 2056 | }, 2057 | "path-key": { 2058 | "version": "2.0.1", 2059 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-2.0.1.tgz", 2060 | "integrity": "sha1-QRyttXTFoUDTpLGRDUDYDMn0C0A=", 2061 | "dev": true 2062 | }, 2063 | "path-parse": { 2064 | "version": "1.0.6", 2065 | "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.6.tgz", 2066 | "integrity": "sha512-GSmOT2EbHrINBf9SR7CDELwlJ8AENk3Qn7OikK4nFYAu3Ote2+JYNVvkpAEQm3/TLNEJFD/xZJjzyxg3KBWOzw==", 2067 | "dev": true 2068 | }, 2069 | "path-platform": { 2070 | "version": "0.11.15", 2071 | "resolved": "https://registry.npmjs.org/path-platform/-/path-platform-0.11.15.tgz", 2072 | "integrity": "sha1-6GQhf3TDaFDwhSt43Hv31KVyG/I=", 2073 | "dev": true 2074 | }, 2075 | "path-type": { 2076 | "version": "2.0.0", 2077 | "resolved": "https://registry.npmjs.org/path-type/-/path-type-2.0.0.tgz", 2078 | "integrity": "sha1-8BLMuEFbcJb8LaoQVMPXI4lZTHM=", 2079 | "dev": true, 2080 | "requires": { 2081 | "pify": "^2.0.0" 2082 | } 2083 | }, 2084 | "pbkdf2": { 2085 | "version": "3.0.17", 2086 | "resolved": "https://registry.npmjs.org/pbkdf2/-/pbkdf2-3.0.17.tgz", 2087 | "integrity": "sha512-U/il5MsrZp7mGg3mSQfn742na2T+1/vHDCG5/iTI3X9MKUuYUZVLQhyRsg06mCgDBTd57TxzgZt7P+fYfjRLtA==", 2088 | "dev": true, 2089 | "requires": { 2090 | "create-hash": "^1.1.2", 2091 | "create-hmac": "^1.1.4", 2092 | "ripemd160": "^2.0.1", 2093 | "safe-buffer": "^5.0.1", 2094 | "sha.js": "^2.4.8" 2095 | } 2096 | }, 2097 | "pify": { 2098 | "version": "2.3.0", 2099 | "resolved": "https://registry.npmjs.org/pify/-/pify-2.3.0.tgz", 2100 | "integrity": "sha1-7RQaasBDqEnqWISY59yosVMw6Qw=", 2101 | "dev": true 2102 | }, 2103 | "pkg-dir": { 2104 | "version": "2.0.0", 2105 | "resolved": "https://registry.npmjs.org/pkg-dir/-/pkg-dir-2.0.0.tgz", 2106 | "integrity": "sha1-9tXREJ4Z1j7fQo4L1X4Sd3YVM0s=", 2107 | "dev": true, 2108 | "requires": { 2109 | "find-up": "^2.1.0" 2110 | } 2111 | }, 2112 | "prelude-ls": { 2113 | "version": "1.1.2", 2114 | "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.1.2.tgz", 2115 | "integrity": "sha1-IZMqVJ9eUv/ZqCf1cOBL5iqX2lQ=" 2116 | }, 2117 | "process": { 2118 | "version": "0.11.10", 2119 | "resolved": "https://registry.npmjs.org/process/-/process-0.11.10.tgz", 2120 | "integrity": "sha1-czIwDoQBYb2j5podHZGn1LwW8YI=", 2121 | "dev": true 2122 | }, 2123 | "process-nextick-args": { 2124 | "version": "2.0.0", 2125 | "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-2.0.0.tgz", 2126 | "integrity": "sha512-MtEC1TqN0EU5nephaJ4rAtThHtC86dNN9qCuEhtshvpVBkAW5ZO7BASN9REnF9eoXGcRub+pFuKEpOHE+HbEMw==", 2127 | "dev": true 2128 | }, 2129 | "progress": { 2130 | "version": "2.0.3", 2131 | "resolved": "https://registry.npmjs.org/progress/-/progress-2.0.3.tgz", 2132 | "integrity": "sha512-7PiHtLll5LdnKIMw100I+8xJXR5gW2QwWYkT6iJva0bXitZKa/XMrSbdmg3r2Xnaidz9Qumd0VPaMrZlF9V9sA==", 2133 | "dev": true 2134 | }, 2135 | "prop-types": { 2136 | "version": "15.7.2", 2137 | "resolved": "https://registry.npmjs.org/prop-types/-/prop-types-15.7.2.tgz", 2138 | "integrity": "sha512-8QQikdH7//R2vurIJSutZ1smHYTcLpRWEOlHnzcWHmBYrOGUysKwSsrC89BCiFj3CbrfJ/nXFdJepOVrY1GCHQ==", 2139 | "dev": true, 2140 | "requires": { 2141 | "loose-envify": "^1.4.0", 2142 | "object-assign": "^4.1.1", 2143 | "react-is": "^16.8.1" 2144 | } 2145 | }, 2146 | "public-encrypt": { 2147 | "version": "4.0.3", 2148 | "resolved": "https://registry.npmjs.org/public-encrypt/-/public-encrypt-4.0.3.tgz", 2149 | "integrity": "sha512-zVpa8oKZSz5bTMTFClc1fQOnyyEzpl5ozpi1B5YcvBrdohMjH2rfsBtyXcuNuwjsDIXmBYlF2N5FlJYhR29t8Q==", 2150 | "dev": true, 2151 | "requires": { 2152 | "bn.js": "^4.1.0", 2153 | "browserify-rsa": "^4.0.0", 2154 | "create-hash": "^1.1.0", 2155 | "parse-asn1": "^5.0.0", 2156 | "randombytes": "^2.0.1", 2157 | "safe-buffer": "^5.1.2" 2158 | } 2159 | }, 2160 | "punycode": { 2161 | "version": "2.1.1", 2162 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.1.1.tgz", 2163 | "integrity": "sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A==", 2164 | "dev": true 2165 | }, 2166 | "querystring": { 2167 | "version": "0.2.0", 2168 | "resolved": "https://registry.npmjs.org/querystring/-/querystring-0.2.0.tgz", 2169 | "integrity": "sha1-sgmEkgO7Jd+CDadW50cAWHhSFiA=", 2170 | "dev": true 2171 | }, 2172 | "querystring-es3": { 2173 | "version": "0.2.1", 2174 | "resolved": "https://registry.npmjs.org/querystring-es3/-/querystring-es3-0.2.1.tgz", 2175 | "integrity": "sha1-nsYfeQSYdXB9aUFFlv2Qek1xHnM=", 2176 | "dev": true 2177 | }, 2178 | "randombytes": { 2179 | "version": "2.1.0", 2180 | "resolved": "https://registry.npmjs.org/randombytes/-/randombytes-2.1.0.tgz", 2181 | "integrity": "sha512-vYl3iOX+4CKUWuxGi9Ukhie6fsqXqS9FE2Zaic4tNFD2N2QQaXOMFbuKK4QmDHC0JO6B1Zp41J0LpT0oR68amQ==", 2182 | "dev": true, 2183 | "requires": { 2184 | "safe-buffer": "^5.1.0" 2185 | } 2186 | }, 2187 | "randomfill": { 2188 | "version": "1.0.4", 2189 | "resolved": "https://registry.npmjs.org/randomfill/-/randomfill-1.0.4.tgz", 2190 | "integrity": "sha512-87lcbR8+MhcWcUiQ+9e+Rwx8MyR2P7qnt15ynUlbm3TU/fjbgz4GsvfSUDTemtCCtVCqb4ZcEFlyPNTh9bBTLw==", 2191 | "dev": true, 2192 | "requires": { 2193 | "randombytes": "^2.0.5", 2194 | "safe-buffer": "^5.1.0" 2195 | } 2196 | }, 2197 | "react-is": { 2198 | "version": "16.8.3", 2199 | "resolved": "https://registry.npmjs.org/react-is/-/react-is-16.8.3.tgz", 2200 | "integrity": "sha512-Y4rC1ZJmsxxkkPuMLwvKvlL1Zfpbcu+Bf4ZigkHup3v9EfdYhAlWAaVyA19olXq2o2mGn0w+dFKvk3pVVlYcIA==", 2201 | "dev": true 2202 | }, 2203 | "read-only-stream": { 2204 | "version": "2.0.0", 2205 | "resolved": "https://registry.npmjs.org/read-only-stream/-/read-only-stream-2.0.0.tgz", 2206 | "integrity": "sha1-JyT9aoET1zdkrCiNQ4YnDB2/F/A=", 2207 | "dev": true, 2208 | "requires": { 2209 | "readable-stream": "^2.0.2" 2210 | } 2211 | }, 2212 | "read-pkg": { 2213 | "version": "2.0.0", 2214 | "resolved": "https://registry.npmjs.org/read-pkg/-/read-pkg-2.0.0.tgz", 2215 | "integrity": "sha1-jvHAYjxqbbDcZxPEv6xGMysjaPg=", 2216 | "dev": true, 2217 | "requires": { 2218 | "load-json-file": "^2.0.0", 2219 | "normalize-package-data": "^2.3.2", 2220 | "path-type": "^2.0.0" 2221 | } 2222 | }, 2223 | "read-pkg-up": { 2224 | "version": "2.0.0", 2225 | "resolved": "https://registry.npmjs.org/read-pkg-up/-/read-pkg-up-2.0.0.tgz", 2226 | "integrity": "sha1-a3KoBImE4MQeeVEP1en6mbO1Sb4=", 2227 | "dev": true, 2228 | "requires": { 2229 | "find-up": "^2.0.0", 2230 | "read-pkg": "^2.0.0" 2231 | } 2232 | }, 2233 | "readable-stream": { 2234 | "version": "2.3.6", 2235 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.6.tgz", 2236 | "integrity": "sha512-tQtKA9WIAhBF3+VLAseyMqZeBjW0AHJoxOtYqSUZNJxauErmLbVm2FW1y+J/YA9dUrAC39ITejlZWhVIwawkKw==", 2237 | "dev": true, 2238 | "requires": { 2239 | "core-util-is": "~1.0.0", 2240 | "inherits": "~2.0.3", 2241 | "isarray": "~1.0.0", 2242 | "process-nextick-args": "~2.0.0", 2243 | "safe-buffer": "~5.1.1", 2244 | "string_decoder": "~1.1.1", 2245 | "util-deprecate": "~1.0.1" 2246 | }, 2247 | "dependencies": { 2248 | "string_decoder": { 2249 | "version": "1.1.1", 2250 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", 2251 | "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", 2252 | "dev": true, 2253 | "requires": { 2254 | "safe-buffer": "~5.1.0" 2255 | } 2256 | } 2257 | } 2258 | }, 2259 | "regexpp": { 2260 | "version": "2.0.1", 2261 | "resolved": "https://registry.npmjs.org/regexpp/-/regexpp-2.0.1.tgz", 2262 | "integrity": "sha512-lv0M6+TkDVniA3aD1Eg0DVpfU/booSu7Eev3TDO/mZKHBfVjgCGTV4t4buppESEYDtkArYFOxTJWv6S5C+iaNw==", 2263 | "dev": true 2264 | }, 2265 | "resolve": { 2266 | "version": "1.10.0", 2267 | "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.10.0.tgz", 2268 | "integrity": "sha512-3sUr9aq5OfSg2S9pNtPA9hL1FVEAjvfOC4leW0SNf/mpnaakz2a9femSd6LqAww2RaFctwyf1lCqnTHuF1rxDg==", 2269 | "dev": true, 2270 | "requires": { 2271 | "path-parse": "^1.0.6" 2272 | } 2273 | }, 2274 | "resolve-from": { 2275 | "version": "4.0.0", 2276 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", 2277 | "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==", 2278 | "dev": true 2279 | }, 2280 | "restore-cursor": { 2281 | "version": "2.0.0", 2282 | "resolved": "https://registry.npmjs.org/restore-cursor/-/restore-cursor-2.0.0.tgz", 2283 | "integrity": "sha1-n37ih/gv0ybU/RYpI9YhKe7g368=", 2284 | "dev": true, 2285 | "requires": { 2286 | "onetime": "^2.0.0", 2287 | "signal-exit": "^3.0.2" 2288 | } 2289 | }, 2290 | "rimraf": { 2291 | "version": "2.6.3", 2292 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.6.3.tgz", 2293 | "integrity": "sha512-mwqeW5XsA2qAejG46gYdENaxXjx9onRNCfn7L0duuP4hCuTIi/QO7PDK07KJfp1d+izWPrzEJDcSqBa0OZQriA==", 2294 | "dev": true, 2295 | "requires": { 2296 | "glob": "^7.1.3" 2297 | } 2298 | }, 2299 | "ripemd160": { 2300 | "version": "2.0.2", 2301 | "resolved": "https://registry.npmjs.org/ripemd160/-/ripemd160-2.0.2.tgz", 2302 | "integrity": "sha512-ii4iagi25WusVoiC4B4lq7pbXfAp3D9v5CwfkY33vffw2+pkDjY1D8GaN7spsxvCSx8dkPqOZCEZyfxcmJG2IA==", 2303 | "dev": true, 2304 | "requires": { 2305 | "hash-base": "^3.0.0", 2306 | "inherits": "^2.0.1" 2307 | } 2308 | }, 2309 | "run-async": { 2310 | "version": "2.3.0", 2311 | "resolved": "https://registry.npmjs.org/run-async/-/run-async-2.3.0.tgz", 2312 | "integrity": "sha1-A3GrSuC91yDUFm19/aZP96RFpsA=", 2313 | "dev": true, 2314 | "requires": { 2315 | "is-promise": "^2.1.0" 2316 | } 2317 | }, 2318 | "rxjs": { 2319 | "version": "6.4.0", 2320 | "resolved": "https://registry.npmjs.org/rxjs/-/rxjs-6.4.0.tgz", 2321 | "integrity": "sha512-Z9Yfa11F6B9Sg/BK9MnqnQ+aQYicPLtilXBp2yUtDt2JRCE0h26d33EnfO3ZxoNxG0T92OUucP3Ct7cpfkdFfw==", 2322 | "dev": true, 2323 | "requires": { 2324 | "tslib": "^1.9.0" 2325 | } 2326 | }, 2327 | "safe-buffer": { 2328 | "version": "5.1.2", 2329 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 2330 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==", 2331 | "dev": true 2332 | }, 2333 | "safer-buffer": { 2334 | "version": "2.1.2", 2335 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", 2336 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==", 2337 | "dev": true 2338 | }, 2339 | "semver": { 2340 | "version": "5.6.0", 2341 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.6.0.tgz", 2342 | "integrity": "sha512-RS9R6R35NYgQn++fkDWaOmqGoj4Ek9gGs+DPxNUZKuwE183xjJroKvyo1IzVFeXvUrvmALy6FWD5xrdJT25gMg==", 2343 | "dev": true 2344 | }, 2345 | "sha.js": { 2346 | "version": "2.4.11", 2347 | "resolved": "https://registry.npmjs.org/sha.js/-/sha.js-2.4.11.tgz", 2348 | "integrity": "sha512-QMEp5B7cftE7APOjk5Y6xgrbWu+WkLVQwk8JNjZ8nKRciZaByEW6MubieAiToS7+dwvrjGhH8jRXz3MVd0AYqQ==", 2349 | "dev": true, 2350 | "requires": { 2351 | "inherits": "^2.0.1", 2352 | "safe-buffer": "^5.0.1" 2353 | } 2354 | }, 2355 | "shasum": { 2356 | "version": "1.0.2", 2357 | "resolved": "https://registry.npmjs.org/shasum/-/shasum-1.0.2.tgz", 2358 | "integrity": "sha1-5wEjENj0F/TetXEhUOVni4euVl8=", 2359 | "dev": true, 2360 | "requires": { 2361 | "json-stable-stringify": "~0.0.0", 2362 | "sha.js": "~2.4.4" 2363 | } 2364 | }, 2365 | "shebang-command": { 2366 | "version": "1.2.0", 2367 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-1.2.0.tgz", 2368 | "integrity": "sha1-RKrGW2lbAzmJaMOfNj/uXer98eo=", 2369 | "dev": true, 2370 | "requires": { 2371 | "shebang-regex": "^1.0.0" 2372 | } 2373 | }, 2374 | "shebang-regex": { 2375 | "version": "1.0.0", 2376 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-1.0.0.tgz", 2377 | "integrity": "sha1-2kL0l0DAtC2yypcoVxyxkMmO/qM=", 2378 | "dev": true 2379 | }, 2380 | "shell-quote": { 2381 | "version": "1.6.1", 2382 | "resolved": "https://registry.npmjs.org/shell-quote/-/shell-quote-1.6.1.tgz", 2383 | "integrity": "sha1-9HgZSczkAmlxJ0MOo7PFR29IF2c=", 2384 | "dev": true, 2385 | "requires": { 2386 | "array-filter": "~0.0.0", 2387 | "array-map": "~0.0.0", 2388 | "array-reduce": "~0.0.0", 2389 | "jsonify": "~0.0.0" 2390 | } 2391 | }, 2392 | "signal-exit": { 2393 | "version": "3.0.2", 2394 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.2.tgz", 2395 | "integrity": "sha1-tf3AjxKH6hF4Yo5BXiUTK3NkbG0=", 2396 | "dev": true 2397 | }, 2398 | "simple-concat": { 2399 | "version": "1.0.0", 2400 | "resolved": "https://registry.npmjs.org/simple-concat/-/simple-concat-1.0.0.tgz", 2401 | "integrity": "sha1-c0TLuLbib7J9ZrL8hvn21Zl1IcY=", 2402 | "dev": true 2403 | }, 2404 | "slice-ansi": { 2405 | "version": "2.1.0", 2406 | "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-2.1.0.tgz", 2407 | "integrity": "sha512-Qu+VC3EwYLldKa1fCxuuvULvSJOKEgk9pi8dZeCVK7TqBfUNTH4sFkk4joj8afVSfAYgJoSOetjx9QWOJ5mYoQ==", 2408 | "dev": true, 2409 | "requires": { 2410 | "ansi-styles": "^3.2.0", 2411 | "astral-regex": "^1.0.0", 2412 | "is-fullwidth-code-point": "^2.0.0" 2413 | } 2414 | }, 2415 | "source-map": { 2416 | "version": "0.5.7", 2417 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.5.7.tgz", 2418 | "integrity": "sha1-igOdLRAh0i0eoUyA2OpGi6LvP8w=", 2419 | "dev": true 2420 | }, 2421 | "spdx-correct": { 2422 | "version": "3.1.0", 2423 | "resolved": "https://registry.npmjs.org/spdx-correct/-/spdx-correct-3.1.0.tgz", 2424 | "integrity": "sha512-lr2EZCctC2BNR7j7WzJ2FpDznxky1sjfxvvYEyzxNyb6lZXHODmEoJeFu4JupYlkfha1KZpJyoqiJ7pgA1qq8Q==", 2425 | "dev": true, 2426 | "requires": { 2427 | "spdx-expression-parse": "^3.0.0", 2428 | "spdx-license-ids": "^3.0.0" 2429 | } 2430 | }, 2431 | "spdx-exceptions": { 2432 | "version": "2.2.0", 2433 | "resolved": "https://registry.npmjs.org/spdx-exceptions/-/spdx-exceptions-2.2.0.tgz", 2434 | "integrity": "sha512-2XQACfElKi9SlVb1CYadKDXvoajPgBVPn/gOQLrTvHdElaVhr7ZEbqJaRnJLVNeaI4cMEAgVCeBMKF6MWRDCRA==", 2435 | "dev": true 2436 | }, 2437 | "spdx-expression-parse": { 2438 | "version": "3.0.0", 2439 | "resolved": "https://registry.npmjs.org/spdx-expression-parse/-/spdx-expression-parse-3.0.0.tgz", 2440 | "integrity": "sha512-Yg6D3XpRD4kkOmTpdgbUiEJFKghJH03fiC1OPll5h/0sO6neh2jqRDVHOQ4o/LMea0tgCkbMgea5ip/e+MkWyg==", 2441 | "dev": true, 2442 | "requires": { 2443 | "spdx-exceptions": "^2.1.0", 2444 | "spdx-license-ids": "^3.0.0" 2445 | } 2446 | }, 2447 | "spdx-license-ids": { 2448 | "version": "3.0.3", 2449 | "resolved": "https://registry.npmjs.org/spdx-license-ids/-/spdx-license-ids-3.0.3.tgz", 2450 | "integrity": "sha512-uBIcIl3Ih6Phe3XHK1NqboJLdGfwr1UN3k6wSD1dZpmPsIkb8AGNbZYJ1fOBk834+Gxy8rpfDxrS6XLEMZMY2g==", 2451 | "dev": true 2452 | }, 2453 | "sprintf-js": { 2454 | "version": "1.0.3", 2455 | "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz", 2456 | "integrity": "sha1-BOaSb2YolTVPPdAVIDYzuFcpfiw=", 2457 | "dev": true 2458 | }, 2459 | "stream-browserify": { 2460 | "version": "2.0.2", 2461 | "resolved": "https://registry.npmjs.org/stream-browserify/-/stream-browserify-2.0.2.tgz", 2462 | "integrity": "sha512-nX6hmklHs/gr2FuxYDltq8fJA1GDlxKQCz8O/IM4atRqBH8OORmBNgfvW5gG10GT/qQ9u0CzIvr2X5Pkt6ntqg==", 2463 | "dev": true, 2464 | "requires": { 2465 | "inherits": "~2.0.1", 2466 | "readable-stream": "^2.0.2" 2467 | } 2468 | }, 2469 | "stream-combiner2": { 2470 | "version": "1.1.1", 2471 | "resolved": "https://registry.npmjs.org/stream-combiner2/-/stream-combiner2-1.1.1.tgz", 2472 | "integrity": "sha1-+02KFCDqNidk4hrUeAOXvry0HL4=", 2473 | "dev": true, 2474 | "requires": { 2475 | "duplexer2": "~0.1.0", 2476 | "readable-stream": "^2.0.2" 2477 | } 2478 | }, 2479 | "stream-http": { 2480 | "version": "2.8.3", 2481 | "resolved": "https://registry.npmjs.org/stream-http/-/stream-http-2.8.3.tgz", 2482 | "integrity": "sha512-+TSkfINHDo4J+ZobQLWiMouQYB+UVYFttRA94FpEzzJ7ZdqcL4uUUQ7WkdkI4DSozGmgBUE/a47L+38PenXhUw==", 2483 | "dev": true, 2484 | "requires": { 2485 | "builtin-status-codes": "^3.0.0", 2486 | "inherits": "^2.0.1", 2487 | "readable-stream": "^2.3.6", 2488 | "to-arraybuffer": "^1.0.0", 2489 | "xtend": "^4.0.0" 2490 | } 2491 | }, 2492 | "stream-splicer": { 2493 | "version": "2.0.0", 2494 | "resolved": "https://registry.npmjs.org/stream-splicer/-/stream-splicer-2.0.0.tgz", 2495 | "integrity": "sha1-G2O+Q4oTPktnHMGTUZdgAXWRDYM=", 2496 | "dev": true, 2497 | "requires": { 2498 | "inherits": "^2.0.1", 2499 | "readable-stream": "^2.0.2" 2500 | } 2501 | }, 2502 | "string-width": { 2503 | "version": "2.1.1", 2504 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-2.1.1.tgz", 2505 | "integrity": "sha512-nOqH59deCq9SRHlxq1Aw85Jnt4w6KvLKqWVik6oA9ZklXLNIOlqg4F2yrT1MVaTjAqvVwdfeZ7w7aCvJD7ugkw==", 2506 | "dev": true, 2507 | "requires": { 2508 | "is-fullwidth-code-point": "^2.0.0", 2509 | "strip-ansi": "^4.0.0" 2510 | } 2511 | }, 2512 | "string_decoder": { 2513 | "version": "1.2.0", 2514 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.2.0.tgz", 2515 | "integrity": "sha512-6YqyX6ZWEYguAxgZzHGL7SsCeGx3V2TtOTqZz1xSTSWnqsbWwbptafNyvf/ACquZUXV3DANr5BDIwNYe1mN42w==", 2516 | "dev": true, 2517 | "requires": { 2518 | "safe-buffer": "~5.1.0" 2519 | } 2520 | }, 2521 | "strip-ansi": { 2522 | "version": "4.0.0", 2523 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-4.0.0.tgz", 2524 | "integrity": "sha1-qEeQIusaw2iocTibY1JixQXuNo8=", 2525 | "dev": true, 2526 | "requires": { 2527 | "ansi-regex": "^3.0.0" 2528 | } 2529 | }, 2530 | "strip-bom": { 2531 | "version": "3.0.0", 2532 | "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-3.0.0.tgz", 2533 | "integrity": "sha1-IzTBjpx1n3vdVv3vfprj1YjmjtM=", 2534 | "dev": true 2535 | }, 2536 | "strip-json-comments": { 2537 | "version": "2.0.1", 2538 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-2.0.1.tgz", 2539 | "integrity": "sha1-PFMZQukIwml8DsNEhYwobHygpgo=", 2540 | "dev": true 2541 | }, 2542 | "subarg": { 2543 | "version": "1.0.0", 2544 | "resolved": "https://registry.npmjs.org/subarg/-/subarg-1.0.0.tgz", 2545 | "integrity": "sha1-9izxdYHplrSPyWVpn1TAauJouNI=", 2546 | "dev": true, 2547 | "requires": { 2548 | "minimist": "^1.1.0" 2549 | }, 2550 | "dependencies": { 2551 | "minimist": { 2552 | "version": "1.2.0", 2553 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.0.tgz", 2554 | "integrity": "sha1-o1AIsg9BOD7sH7kU9M1d95omQoQ=", 2555 | "dev": true 2556 | } 2557 | } 2558 | }, 2559 | "supports-color": { 2560 | "version": "5.5.0", 2561 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 2562 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 2563 | "dev": true, 2564 | "requires": { 2565 | "has-flag": "^3.0.0" 2566 | } 2567 | }, 2568 | "syntax-error": { 2569 | "version": "1.4.0", 2570 | "resolved": "https://registry.npmjs.org/syntax-error/-/syntax-error-1.4.0.tgz", 2571 | "integrity": "sha512-YPPlu67mdnHGTup2A8ff7BC2Pjq0e0Yp/IyTFN03zWO0RcK07uLcbi7C2KpGR2FvWbaB0+bfE27a+sBKebSo7w==", 2572 | "dev": true, 2573 | "requires": { 2574 | "acorn-node": "^1.2.0" 2575 | } 2576 | }, 2577 | "table": { 2578 | "version": "5.2.3", 2579 | "resolved": "https://registry.npmjs.org/table/-/table-5.2.3.tgz", 2580 | "integrity": "sha512-N2RsDAMvDLvYwFcwbPyF3VmVSSkuF+G1e+8inhBLtHpvwXGw4QRPEZhihQNeEN0i1up6/f6ObCJXNdlRG3YVyQ==", 2581 | "dev": true, 2582 | "requires": { 2583 | "ajv": "^6.9.1", 2584 | "lodash": "^4.17.11", 2585 | "slice-ansi": "^2.1.0", 2586 | "string-width": "^3.0.0" 2587 | }, 2588 | "dependencies": { 2589 | "ansi-regex": { 2590 | "version": "4.0.0", 2591 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.0.0.tgz", 2592 | "integrity": "sha512-iB5Dda8t/UqpPI/IjsejXu5jOGDrzn41wJyljwPH65VCIbk6+1BzFIMJGFwTNrYXT1CrD+B4l19U7awiQ8rk7w==", 2593 | "dev": true 2594 | }, 2595 | "string-width": { 2596 | "version": "3.0.0", 2597 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-3.0.0.tgz", 2598 | "integrity": "sha512-rr8CUxBbvOZDUvc5lNIJ+OC1nPVpz+Siw9VBtUjB9b6jZehZLFt0JMCZzShFHIsI8cbhm0EsNIfWJMFV3cu3Ew==", 2599 | "dev": true, 2600 | "requires": { 2601 | "emoji-regex": "^7.0.1", 2602 | "is-fullwidth-code-point": "^2.0.0", 2603 | "strip-ansi": "^5.0.0" 2604 | } 2605 | }, 2606 | "strip-ansi": { 2607 | "version": "5.0.0", 2608 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.0.0.tgz", 2609 | "integrity": "sha512-Uu7gQyZI7J7gn5qLn1Np3G9vcYGTVqB+lFTytnDJv83dd8T22aGH451P3jueT2/QemInJDfxHB5Tde5OzgG1Ow==", 2610 | "dev": true, 2611 | "requires": { 2612 | "ansi-regex": "^4.0.0" 2613 | } 2614 | } 2615 | } 2616 | }, 2617 | "text-table": { 2618 | "version": "0.2.0", 2619 | "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz", 2620 | "integrity": "sha1-f17oI66AUgfACvLfSoTsP8+lcLQ=", 2621 | "dev": true 2622 | }, 2623 | "through": { 2624 | "version": "2.3.8", 2625 | "resolved": "https://registry.npmjs.org/through/-/through-2.3.8.tgz", 2626 | "integrity": "sha1-DdTJ/6q8NXlgsbckEV1+Doai4fU=", 2627 | "dev": true 2628 | }, 2629 | "through2": { 2630 | "version": "2.0.5", 2631 | "resolved": "https://registry.npmjs.org/through2/-/through2-2.0.5.tgz", 2632 | "integrity": "sha512-/mrRod8xqpA+IHSLyGCQ2s8SPHiCDEeQJSep1jqLYeEUClOFG2Qsh+4FU6G9VeqpZnGW/Su8LQGc4YKni5rYSQ==", 2633 | "dev": true, 2634 | "requires": { 2635 | "readable-stream": "~2.3.6", 2636 | "xtend": "~4.0.1" 2637 | } 2638 | }, 2639 | "timers-browserify": { 2640 | "version": "1.4.2", 2641 | "resolved": "https://registry.npmjs.org/timers-browserify/-/timers-browserify-1.4.2.tgz", 2642 | "integrity": "sha1-ycWLV1voQHN1y14kYtrO50NZ9B0=", 2643 | "dev": true, 2644 | "requires": { 2645 | "process": "~0.11.0" 2646 | } 2647 | }, 2648 | "tmp": { 2649 | "version": "0.0.33", 2650 | "resolved": "https://registry.npmjs.org/tmp/-/tmp-0.0.33.tgz", 2651 | "integrity": "sha512-jRCJlojKnZ3addtTOjdIqoRuPEKBvNXcGYqzO6zWZX8KfKEpnGY5jfggJQ3EjKuu8D4bJRr0y+cYJFmYbImXGw==", 2652 | "dev": true, 2653 | "requires": { 2654 | "os-tmpdir": "~1.0.2" 2655 | } 2656 | }, 2657 | "to-arraybuffer": { 2658 | "version": "1.0.1", 2659 | "resolved": "https://registry.npmjs.org/to-arraybuffer/-/to-arraybuffer-1.0.1.tgz", 2660 | "integrity": "sha1-fSKbH8xjfkZsoIEYCDanqr/4P0M=", 2661 | "dev": true 2662 | }, 2663 | "to-fast-properties": { 2664 | "version": "2.0.0", 2665 | "resolved": "https://registry.npmjs.org/to-fast-properties/-/to-fast-properties-2.0.0.tgz", 2666 | "integrity": "sha1-3F5pjL0HkmW8c+A3doGk5Og/YW4=", 2667 | "dev": true 2668 | }, 2669 | "trim-right": { 2670 | "version": "1.0.1", 2671 | "resolved": "https://registry.npmjs.org/trim-right/-/trim-right-1.0.1.tgz", 2672 | "integrity": "sha1-yy4SAwZ+DI3h9hQJS5/kVwTqYAM=", 2673 | "dev": true 2674 | }, 2675 | "tslib": { 2676 | "version": "1.9.3", 2677 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.9.3.tgz", 2678 | "integrity": "sha512-4krF8scpejhaOgqzBEcGM7yDIEfi0/8+8zDRZhNZZ2kjmHJ4hv3zCbQWxoJGz1iw5U0Jl0nma13xzHXcncMavQ==", 2679 | "dev": true 2680 | }, 2681 | "tty-browserify": { 2682 | "version": "0.0.1", 2683 | "resolved": "https://registry.npmjs.org/tty-browserify/-/tty-browserify-0.0.1.tgz", 2684 | "integrity": "sha512-C3TaO7K81YvjCgQH9Q1S3R3P3BtN3RIM8n+OvX4il1K1zgE8ZhI0op7kClgkxtutIE8hQrcrHBXvIheqKUUCxw==", 2685 | "dev": true 2686 | }, 2687 | "type-check": { 2688 | "version": "0.3.2", 2689 | "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.3.2.tgz", 2690 | "integrity": "sha1-WITKtRLPHTVeP7eE8wgEsrUg23I=", 2691 | "requires": { 2692 | "prelude-ls": "~1.1.2" 2693 | } 2694 | }, 2695 | "typedarray": { 2696 | "version": "0.0.6", 2697 | "resolved": "https://registry.npmjs.org/typedarray/-/typedarray-0.0.6.tgz", 2698 | "integrity": "sha1-hnrHTjhkGHsdPUfZlqeOxciDB3c=", 2699 | "dev": true 2700 | }, 2701 | "umd": { 2702 | "version": "3.0.3", 2703 | "resolved": "https://registry.npmjs.org/umd/-/umd-3.0.3.tgz", 2704 | "integrity": "sha512-4IcGSufhFshvLNcMCV80UnQVlZ5pMOC8mvNPForqwA4+lzYQuetTESLDQkeLmihq8bRcnpbQa48Wb8Lh16/xow==", 2705 | "dev": true 2706 | }, 2707 | "undeclared-identifiers": { 2708 | "version": "1.1.3", 2709 | "resolved": "https://registry.npmjs.org/undeclared-identifiers/-/undeclared-identifiers-1.1.3.tgz", 2710 | "integrity": "sha512-pJOW4nxjlmfwKApE4zvxLScM/njmwj/DiUBv7EabwE4O8kRUy+HIwxQtZLBPll/jx1LJyBcqNfB3/cpv9EZwOw==", 2711 | "dev": true, 2712 | "requires": { 2713 | "acorn-node": "^1.3.0", 2714 | "dash-ast": "^1.0.0", 2715 | "get-assigned-identifiers": "^1.2.0", 2716 | "simple-concat": "^1.0.0", 2717 | "xtend": "^4.0.1" 2718 | } 2719 | }, 2720 | "uri-js": { 2721 | "version": "4.2.2", 2722 | "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.2.2.tgz", 2723 | "integrity": "sha512-KY9Frmirql91X2Qgjry0Wd4Y+YTdrdZheS8TFwvkbLWf/G5KNJDCh6pKL5OZctEW4+0Baa5idK2ZQuELRwPznQ==", 2724 | "dev": true, 2725 | "requires": { 2726 | "punycode": "^2.1.0" 2727 | } 2728 | }, 2729 | "url": { 2730 | "version": "0.11.0", 2731 | "resolved": "https://registry.npmjs.org/url/-/url-0.11.0.tgz", 2732 | "integrity": "sha1-ODjpfPxgUh63PFJajlW/3Z4uKPE=", 2733 | "dev": true, 2734 | "requires": { 2735 | "punycode": "1.3.2", 2736 | "querystring": "0.2.0" 2737 | }, 2738 | "dependencies": { 2739 | "punycode": { 2740 | "version": "1.3.2", 2741 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-1.3.2.tgz", 2742 | "integrity": "sha1-llOgNvt8HuQjQvIyXM7v6jkmxI0=", 2743 | "dev": true 2744 | } 2745 | } 2746 | }, 2747 | "util": { 2748 | "version": "0.10.4", 2749 | "resolved": "https://registry.npmjs.org/util/-/util-0.10.4.tgz", 2750 | "integrity": "sha512-0Pm9hTQ3se5ll1XihRic3FDIku70C+iHUdT/W926rSgHV5QgXsYbKZN8MSC3tJtSkhuROzvsQjAaFENRXr+19A==", 2751 | "dev": true, 2752 | "requires": { 2753 | "inherits": "2.0.3" 2754 | } 2755 | }, 2756 | "util-deprecate": { 2757 | "version": "1.0.2", 2758 | "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", 2759 | "integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8=", 2760 | "dev": true 2761 | }, 2762 | "validate-npm-package-license": { 2763 | "version": "3.0.4", 2764 | "resolved": "https://registry.npmjs.org/validate-npm-package-license/-/validate-npm-package-license-3.0.4.tgz", 2765 | "integrity": "sha512-DpKm2Ui/xN7/HQKCtpZxoRWBhZ9Z0kqtygG8XCgNQ8ZlDnxuQmWhj566j8fN4Cu3/JmbhsDo7fcAJq4s9h27Ew==", 2766 | "dev": true, 2767 | "requires": { 2768 | "spdx-correct": "^3.0.0", 2769 | "spdx-expression-parse": "^3.0.0" 2770 | } 2771 | }, 2772 | "vm-browserify": { 2773 | "version": "1.1.0", 2774 | "resolved": "https://registry.npmjs.org/vm-browserify/-/vm-browserify-1.1.0.tgz", 2775 | "integrity": "sha512-iq+S7vZJE60yejDYM0ek6zg308+UZsdtPExWP9VZoCFCz1zkJoXFnAX7aZfd/ZwrkidzdUZL0C/ryW+JwAiIGw==", 2776 | "dev": true 2777 | }, 2778 | "which": { 2779 | "version": "1.3.1", 2780 | "resolved": "https://registry.npmjs.org/which/-/which-1.3.1.tgz", 2781 | "integrity": "sha512-HxJdYWq1MTIQbJ3nw0cqssHoTNU267KlrDuGZ1WYlxDStUtKUhOaJmh112/TZmHxxUfuJqPXSOm7tDyas0OSIQ==", 2782 | "dev": true, 2783 | "requires": { 2784 | "isexe": "^2.0.0" 2785 | } 2786 | }, 2787 | "wordwrap": { 2788 | "version": "1.0.0", 2789 | "resolved": "https://registry.npmjs.org/wordwrap/-/wordwrap-1.0.0.tgz", 2790 | "integrity": "sha1-J1hIEIkUVqQXHI0CJkQa3pDLyus=" 2791 | }, 2792 | "wrappy": { 2793 | "version": "1.0.2", 2794 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 2795 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=", 2796 | "dev": true 2797 | }, 2798 | "write": { 2799 | "version": "1.0.3", 2800 | "resolved": "https://registry.npmjs.org/write/-/write-1.0.3.tgz", 2801 | "integrity": "sha512-/lg70HAjtkUgWPVZhZcm+T4hkL8Zbtp1nFNOn3lRrxnlv50SRBv7cR7RqR+GMsd3hUXy9hWBo4CHTbFTcOYwig==", 2802 | "dev": true, 2803 | "requires": { 2804 | "mkdirp": "^0.5.1" 2805 | } 2806 | }, 2807 | "xtend": { 2808 | "version": "4.0.1", 2809 | "resolved": "https://registry.npmjs.org/xtend/-/xtend-4.0.1.tgz", 2810 | "integrity": "sha1-pcbVMr5lbiPbgg77lDofBJmNY68=", 2811 | "dev": true 2812 | } 2813 | } 2814 | } 2815 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "react-rewind", 3 | "version": "1.0.0", 4 | "description": "Time-travel debugger for React useReducer", 5 | "main": "index.js", 6 | "scripts": { 7 | "lint": "eslint \"*/**/*.{js,jsx}\"", 8 | "test": "echo \"Error: no test specified\" && exit 1", 9 | "bundle_bg": "browserify src/browser/chrome/background.js -o src/browser/chrome/devtools_bundle/bg_bundle.js", 10 | "build": "npm run bundle_bg & npm run webpack --prefix ./src/app", 11 | "install_dep": "npm install & npm install --prefix ./src/app" 12 | }, 13 | "repository": { 14 | "type": "git", 15 | "url": "https://github.com/reactrewind" 16 | }, 17 | "author": "React Rewind", 18 | "license": "MIT", 19 | "devDependencies": { 20 | "babel-eslint": "^10.0.1", 21 | "browserify": "^16.2.3", 22 | "eslint": "^5.14.1", 23 | "eslint-plugin-import": "^2.16.0", 24 | "eslint-plugin-react": "^7.12.4" 25 | }, 26 | "dependencies": { 27 | "escodegen": "^1.11.1", 28 | "eslint-config-airbnb": "^17.1.0", 29 | "eslint-plugin-jsx-a11y": "^6.2.1", 30 | "esprima": "^4.0.1", 31 | "estraverse": "^4.2.0" 32 | } 33 | } 34 | -------------------------------------------------------------------------------- /src/app/.gitignore: -------------------------------------------------------------------------------- 1 | node_modules 2 | dist 3 | .DS_Store 4 | src/.DS_Store/ -------------------------------------------------------------------------------- /src/app/components/App.jsx: -------------------------------------------------------------------------------- 1 | import React, { Component } from 'react'; 2 | import { createGlobalStyle } from 'styled-components'; 3 | 4 | // containers 5 | import SplitPane from '../container/SplitPane.jsx'; 6 | import TimeSlider from '../container/TimeSlider.jsx'; 7 | 8 | // left pane = events, right pane = details 9 | import Events from '../container/Events.jsx'; 10 | import Details from '../container/Details.jsx'; 11 | 12 | // styled components 13 | import { Wrapper } from '../styles/SplitPane.jsx'; 14 | 15 | // import from styled components to create global styles 16 | const GlobalStyle = createGlobalStyle` 17 | html { 18 | box-sizing: border-box; 19 | font-size: 10px; 20 | height: 100%; 21 | width: 100%; 22 | } 23 | * *:before, *:after { 24 | box-sizing: inherit; 25 | } 26 | body { 27 | padding: 0; 28 | margin: 0; 29 | font-size: 1.5rem; 30 | line-height: 2; 31 | height: 100%; 32 | width: 100%; 33 | background-color: #2A2E3A; 34 | } 35 | `; 36 | 37 | class App extends Component { 38 | constructor(props) { 39 | super(props); 40 | 41 | this.state = { 42 | data: [], 43 | searchField: '', 44 | filteredData: [], 45 | isPlaying: false, 46 | isRecording: false, 47 | isPlayingIndex: 0, 48 | id: 0, 49 | action: {}, 50 | state: {}, 51 | prevState: {}, 52 | eventTimes: [], 53 | }; 54 | 55 | this.portToExtension = null; 56 | this.justStartedRecording = false; 57 | this.hasInjectedScript = false; 58 | 59 | this.addActionToView = this.addActionToView.bind(this); 60 | this.toTheFuture = this.toTheFuture.bind(this); 61 | this.toThePast = this.toThePast.bind(this); 62 | this.setIsPlaying = this.setIsPlaying.bind(this); 63 | this.setIsRecording = this.setIsRecording.bind(this); 64 | this.actionInPlay = this.actionInPlay.bind(this); 65 | this.handleBarChange = this.handleBarChange.bind(this); 66 | this.searchChange = this.searchChange.bind(this); 67 | this.resetApp = this.resetApp.bind(this); 68 | } 69 | 70 | componentDidMount() { 71 | // adds listener to the effects that are gonna be sent from 72 | // our edited useReducer from the 'react' library. 73 | chrome.runtime.onConnect.addListener((port) => { 74 | // if our port is already open with the extension script, 75 | // we don't want to change this.portToExtension no more. We want 76 | // to keep every instance of the App associated with the specific 77 | // extension script that can communicated with the injected timeTravel. 78 | if (port.name !== 'injected-app' || this.portToExtension) return; 79 | 80 | this.portToExtension = port; 81 | 82 | port.onMessage.addListener((msg) => { 83 | // If the user paused the recording session, we return 84 | const { isRecording } = this.state; 85 | if (!isRecording) return; 86 | 87 | const newData = { 88 | action: msg.action, 89 | state: msg.state, 90 | prevState: msg.prevState, 91 | id: this.state.data.length, 92 | }; 93 | 94 | // search field 95 | const { searchField } = this.state; 96 | const newDataActionType = newData.action.type.toLowerCase(); 97 | 98 | const eventTime = Date.now(); 99 | 100 | // get the date everytime an action fires and add it to state 101 | if (newDataActionType.includes(searchField.toLowerCase())) { 102 | this.setState(state => ({ 103 | data: [...state.data, newData], 104 | isPlayingIndex: state.data.length, 105 | filteredData: [...state.filteredData, newData], 106 | eventTimes: [...state.eventTimes, eventTime], 107 | ...newData, 108 | })); 109 | } else { 110 | this.setState(state => ({ 111 | data: [...state.data, newData], 112 | isPlayingIndex: state.data.length, 113 | ...newData, 114 | })); 115 | } 116 | }); 117 | }); 118 | 119 | // We listen to the message from devtools.js (sent originally from 120 | // background) to refresh our App whenever the user refreshes the webpage. 121 | // The msg from background will come with the ID of the current tab. 122 | // We only want to refresh our App instance of that specific tab. 123 | window.addEventListener('message', (msg) => { 124 | const { action, tabId } = msg.data; 125 | if (action !== 'refresh_devtool') return; 126 | const devtoolsId = chrome.devtools.inspectedWindow.tabId; 127 | if (tabId === devtoolsId) this.resetApp(); 128 | }); 129 | } 130 | 131 | // functionality to change 'play' button to 'stop' 132 | setIsPlaying() { 133 | const { isPlayingIndex, data } = this.state; 134 | if (isPlayingIndex >= data.length - 1) { 135 | return; 136 | } 137 | 138 | let { isPlaying } = this.state; 139 | isPlaying = !isPlaying; 140 | this.setState({ isPlaying }); 141 | 142 | if (isPlaying) { 143 | this.actionInPlay(); 144 | } 145 | } 146 | 147 | setIsRecording() { 148 | const { isRecording } = this.state; 149 | this.setState(state => ({ 150 | isRecording: !state.isRecording, 151 | })); 152 | 153 | // if we are hitting the pause or re-starting the record session 154 | if (isRecording || this.hasInjectedScript) return; 155 | 156 | // We set our port to null so that when the page refreshes, we can 157 | // reupdate it to the new value. 158 | this.portToExtension = null; 159 | 160 | // This variable will prevent the app from refreshing when we refresh 161 | // the userpage after starting to record. 162 | this.justStartedRecording = true; 163 | this.hasInjectedScript = true; 164 | 165 | // we query the active window so we can send it to the background script 166 | // so it knows on which URL to run our devtool. 167 | chrome.tabs.query({ active: true, currentWindow: true }, (tabs) => { 168 | const { url } = tabs[0]; 169 | 170 | // backgroundPort is a variable made avaiable by the devtools.js 171 | backgroundPort.postMessage({ 172 | turnOnDevtool: true, 173 | url, 174 | }); 175 | }); 176 | } 177 | 178 | actionInPlay() { 179 | const { data, isPlayingIndex } = this.state; 180 | 181 | setTimeout(() => { 182 | this.toTheFuture(); 183 | // We CANT deconstruct isPlaying because we want it to be the value 184 | // when this function gets executed - 1000s later. 185 | if (this.state.isPlaying && isPlayingIndex + 1 < data.length - 1) { 186 | this.actionInPlay(); 187 | } else { 188 | this.setState({ isPlaying: false }); 189 | } 190 | }, 1000); 191 | } 192 | 193 | // function to select an event from the data 194 | // and set state with all required info 195 | addActionToView(e) { 196 | const { data } = this.state; 197 | const actionToView = data.filter(action => e.target.id === String(action.id)); 198 | const { 199 | action, id, state, prevState, 200 | } = actionToView[0]; 201 | this.setState({ 202 | action, id, state, prevState, 203 | }); 204 | } 205 | 206 | // filter search bar results 207 | searchChange(e) { 208 | const { data } = this.state; 209 | 210 | // grab user entry from filter bar 211 | const compareSearchValue = e.target.value; 212 | 213 | // set state with compare value 214 | this.setState({ searchField: compareSearchValue }); 215 | 216 | // match results from our filter entry to data 217 | const actions = data.filter(function(item) { 218 | const type = item.action.type.toLowerCase(); 219 | return type.includes(compareSearchValue.toLowerCase()); 220 | }); 221 | this.setState({ filteredData: actions }); 222 | } 223 | 224 | // time travel bar change 225 | handleBarChange(e) { 226 | const { data, isPlayingIndex } = this.state; 227 | const { id, action, state, prevState } = data[e.target.value]; 228 | // forward or past 229 | const currentIsPlayingIndex = e.target.value; 230 | const forward = currentIsPlayingIndex > isPlayingIndex; 231 | this.setState({ 232 | id, 233 | action, 234 | state, 235 | prevState, 236 | isPlayingIndex: parseInt(currentIsPlayingIndex), 237 | }); 238 | // Displays to screen 239 | if (forward) { 240 | this.toTheFuture(); 241 | } else { 242 | this.toThePast(); 243 | } 244 | } 245 | 246 | // function to travel to the FUTURE 247 | toTheFuture() { 248 | const { data, isPlayingIndex } = this.state; 249 | if (isPlayingIndex === data.length - 1) return; 250 | 251 | if (!this.portToExtension) return console.error('No connection on stored port.'); 252 | this.portToExtension.postMessage({ 253 | type: 'TIMETRAVEL', 254 | direction: 'forward', 255 | }); 256 | 257 | const { id, action, state, prevState } = data[isPlayingIndex + 1]; 258 | this.setState(prev => ({ 259 | ...prev, 260 | id, 261 | action, 262 | state, 263 | prevState, 264 | isPlayingIndex: isPlayingIndex + 1, 265 | })); 266 | } 267 | 268 | // function to travel to the PAST 269 | toThePast() { 270 | const { data, isPlayingIndex } = this.state; 271 | if (isPlayingIndex === 0) return; 272 | 273 | if (!this.portToExtension) return console.error('No connection on stored port.'); 274 | 275 | this.portToExtension.postMessage({ 276 | type: 'TIMETRAVEL', 277 | direction: 'backwards', 278 | }); 279 | 280 | const { id, action, state, prevState } = data[isPlayingIndex - 1]; 281 | this.setState(prev => ({ 282 | ...prev, 283 | id, 284 | action, 285 | state, 286 | prevState, 287 | isPlayingIndex: isPlayingIndex - 1, 288 | })); 289 | } 290 | 291 | resetApp() { 292 | if (this.justStartedRecording) { 293 | // hacky: some pages will fire update twice on the background script 294 | setTimeout(() => this.justStartedRecording = false, 50); 295 | return; 296 | } 297 | 298 | this.justStartedRecording = false; 299 | this.hasInjectedScript = false; 300 | 301 | this.setState({ 302 | data: [], 303 | searchField: '', 304 | filteredData: [], 305 | isPlaying: false, 306 | isRecording: false, 307 | isPlayingIndex: 0, 308 | id: 0, 309 | action: {}, 310 | state: {}, 311 | prevState: {}, 312 | eventTimes: [], 313 | }); 314 | } 315 | 316 | render() { 317 | const { 318 | action, 319 | id, 320 | state, 321 | data, 322 | isPlaying, 323 | isRecording, 324 | filteredData, 325 | searchField, 326 | isPlayingIndex, 327 | prevState, 328 | eventTimes, 329 | } = this.state; 330 | 331 | return ( 332 | <> 333 | 334 | 335 | 347 | )} 348 | right={ 349 | ( 350 |
356 | )} 357 | /> 358 | 369 | 370 | 371 | ); 372 | } 373 | } 374 | 375 | export default App; 376 | -------------------------------------------------------------------------------- /src/app/components/DetailCards/Actions/ActionsDisplay.jsx: -------------------------------------------------------------------------------- 1 | import React from 'react'; 2 | import ReactJson from 'react-json-view'; 3 | 4 | // styled components 5 | import { DetailsWrapper } from '../../../styles/Details.jsx'; 6 | 7 | export default function Actions({ action, setIsClicked }) { 8 | // renders action information 9 | setIsClicked(true); 10 | return ( 11 | 12 | { || 'select an event'} 18 | 19 | ); 20 | } 21 | -------------------------------------------------------------------------------- /src/app/components/DetailCards/DetailsNav.jsx: -------------------------------------------------------------------------------- 1 | import React from 'react'; 2 | // styled component imports 3 | import { Buttons, Button, DetailsNavWrapper } from '../../styles/Nav.jsx'; 4 | 5 | const { NavLink } = require('react-router-dom'); 6 | 7 | export default function RightNav(props) { 8 | return ( 9 | <> 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | ); 25 | } 26 | -------------------------------------------------------------------------------- /src/app/components/DetailCards/Effects/EffectsDisplay.jsx: -------------------------------------------------------------------------------- 1 | import React from 'react'; 2 | import ReactJson from 'react-json-view'; 3 | import { DetailsWrapper } from '../../../styles/Details.jsx'; 4 | 5 | // gets difference from previous state to new state 6 | import stateDifference from '../../stateDifference.jsx'; 7 | 8 | 9 | export default function Effects(props) { 10 | const { prevState, actionState, setIsClicked } = props; 11 | const differenceOfPrevAndNextState = stateDifference(prevState, actionState); 12 | setIsClicked(true); 13 | return ( 14 | 15 | 21 | 22 | ); 23 | } 24 | -------------------------------------------------------------------------------- /src/app/components/DetailCards/InitialDetailCard/InitialDisplay.jsx: -------------------------------------------------------------------------------- 1 | import React from 'react'; 2 | import ReactJson from 'react-json-view'; 3 | 4 | // styled components 5 | import { DetailsWrapper } from '../../../styles/Details.jsx'; 6 | 7 | export default function InitialDisplay({ action }) { 8 | // renders action information 9 | return ( 10 | 11 | { || 'select an event'} 17 | 18 | ); 19 | } 20 | -------------------------------------------------------------------------------- /src/app/components/DetailCards/State/StateCard.jsx: -------------------------------------------------------------------------------- 1 | import React from 'react'; 2 | import ReactJson from 'react-json-view'; 3 | 4 | export default function EffectCard(props) { 5 | // renders the data to show 6 | const { actionState } = props; 7 | 8 | return ( 9 |
10 | 16 |
17 | ); 18 | } 19 | -------------------------------------------------------------------------------- /src/app/components/DetailCards/State/StateDisplay.jsx: -------------------------------------------------------------------------------- 1 | import React from 'react'; 2 | import StateCard from './StateCard.jsx'; 3 | 4 | // styled component 5 | import { DetailsWrapper } from '../../../styles/Details.jsx'; 6 | 7 | export default function State({ actionState, setIsClicked }) { 8 | // stringifying data to pass down to StateCard to display 9 | setIsClicked(true); 10 | return ( 11 | 12 | {} 13 | 14 | ); 15 | } 16 | -------------------------------------------------------------------------------- /src/app/components/EventCards/EventCreator.jsx: -------------------------------------------------------------------------------- 1 | import React from 'react'; 2 | 3 | import { EventCard, EventTimeDiv } from '../../styles/Events.jsx'; 4 | 5 | export default function EventCreator(props) { 6 | // renders individual action 7 | const { 8 | action, id, addAction, selectedEvent, eventTimes, 9 | } = props; 10 | 11 | let displayTime; 12 | let timeDifference; 13 | 14 | if (id === 0) { 15 | displayTime = '00: 00: 00'; 16 | } else { 17 | timeDifference = eventTimes[id] - eventTimes[id - 1]; 18 | timeDifference = new Date(timeDifference); 19 | 20 | let minute = timeDifference.getMinutes(); 21 | minute = minute < 10 ? '0'.concat(minute) : minute; 22 | 23 | let second = timeDifference.getSeconds(); 24 | second = second < 10 ? '0'.concat(second) : second; 25 | 26 | let millisecond = Math.floor(timeDifference.getMilliseconds() / 10); 27 | millisecond = millisecond < 10 ? '0'.concat(millisecond) : millisecond; 28 | 29 | displayTime = `${minute} : ${second} : ${millisecond}`; 30 | } 31 | 32 | return ( 33 | 34 | ☰ 35 | {action} 36 | {displayTime} 37 | 38 | 39 | ); 40 | } 41 | -------------------------------------------------------------------------------- /src/app/components/EventCards/EventsDisplay.jsx: -------------------------------------------------------------------------------- 1 | import React, { useContext, useState } from 'react'; 2 | 3 | // components import 4 | import EventCreator from './EventCreator.jsx'; 5 | 6 | // styled components import 7 | import { EventsWrapper } from '../../styles/Events.jsx'; 8 | 9 | export default function Events(props) { 10 | const { 11 | activeEventId, 12 | filteredData, 13 | eventTimes, 14 | } = props; 15 | 16 | return ( 17 | 18 | {filteredData.map((e, i) => ( 19 | 28 | ))} 29 | 30 | ); 31 | } 32 | -------------------------------------------------------------------------------- /src/app/components/EventCards/EventsNav.jsx: -------------------------------------------------------------------------------- 1 | import React from 'react'; 2 | 3 | // styled components 4 | import { EventsNavWrapper } from '../../styles/Nav.jsx'; 5 | 6 | 7 | // events nav bar is created below and styled 8 | export default function LeftNav() { 9 | return ( 10 | <> 11 | events 12 | 13 | ); 14 | } 15 | -------------------------------------------------------------------------------- /src/app/components/EventCards/FilterBar.jsx: -------------------------------------------------------------------------------- 1 | import React from 'react'; 2 | 3 | 4 | // styled components 5 | import { FilterWrapper } from '../../styles/FilterBar.jsx'; 6 | 7 | export default function FilterBar(props) { 8 | const { 9 | searchChange, 10 | searchField, 11 | } = props; 12 | 13 | return ( 14 | <> 15 | 16 | 22 | 23 | 24 | ); 25 | } 26 | -------------------------------------------------------------------------------- /src/app/components/stateDifference.jsx: -------------------------------------------------------------------------------- 1 | function stateDifference(old, curr) { 2 | if (typeof old !== typeof curr) return curr; 3 | 4 | if (typeof old === typeof curr && !Array.isArray(old) && typeof old !== 'object') { 5 | if (old === curr) return undefined; 6 | return curr; 7 | } 8 | 9 | if (Array.isArray(old) && Array.isArray(curr)) { 10 | const newArr = []; 11 | for (let i = 0; i < curr.length; i++) { 12 | if (!old.includes(curr[i])) { 13 | const result = stateDifference(old[i], curr[i]); 14 | if (result !== undefined) { 15 | newArr.push(result); 16 | } 17 | } 18 | } 19 | 20 | return newArr.length > 0 ? newArr : undefined; 21 | } 22 | 23 | const newObj = {}; 24 | for (let prop in curr) { 25 | const result = stateDifference(old[prop], curr[prop]) 26 | if (result !== undefined) { 27 | newObj[prop] = result; 28 | } 29 | } 30 | 31 | return Object.keys(newObj).length === 0 ? undefined : newObj; 32 | } 33 | 34 | export default stateDifference; 35 | -------------------------------------------------------------------------------- /src/app/container/Details.jsx: -------------------------------------------------------------------------------- 1 | import React, { useState } from 'react'; 2 | 3 | // details nav component import 4 | import DetailsNav from '../components/DetailCards/DetailsNav.jsx'; 5 | 6 | // component imports for react router 7 | import ActionsDisplay from '../components/DetailCards/Actions/ActionsDisplay.jsx'; 8 | import EffectsDisplay from '../components/DetailCards/Effects/EffectsDisplay.jsx'; 9 | import StateDisplay from '../components/DetailCards/State/StateDisplay.jsx'; 10 | import InitalDisplay from '../components/DetailCards/InitialDetailCard/InitialDisplay.jsx'; 11 | 12 | const ReactRouter = require('react-router-dom'); 13 | 14 | const Router = ReactRouter.BrowserRouter; 15 | const { Route } = ReactRouter; 16 | 17 | export default function Details(props) { 18 | // destructuring required info that's being passed down from App.jsx 19 | // passing these props onto children 20 | const { 21 | action, prevState, actionState, 22 | } = props; 23 | 24 | const [isClicked, setIsClicked] = useState(false); 25 | return ( 26 | 27 | <> 28 | 29 | {isClicked === false ? : null } 30 | {/* routing components and rendering them with props */} 31 | ( 35 | 40 | )} 41 | /> 42 | ( 45 | 51 | )} 52 | /> 53 | ( 56 | 61 | )} 62 | /> 63 | 64 | 65 | ); 66 | } 67 | -------------------------------------------------------------------------------- /src/app/container/Events.jsx: -------------------------------------------------------------------------------- 1 | import React, { Component } from 'react'; 2 | 3 | // components 4 | import EventsNav from '../components/EventCards/EventsNav.jsx'; 5 | import EventsDisplay from '../components/EventCards/EventsDisplay.jsx' 6 | import FilterBar from '../components/EventCards/FilterBar.jsx'; 7 | 8 | class Events extends Component { 9 | constructor(props) { 10 | super(props); 11 | this.state = {}; 12 | } 13 | 14 | render() { 15 | const { 16 | activeEventId, 17 | addAction, 18 | data, 19 | searchChange, 20 | filteredData, 21 | searchField, 22 | eventTimes, 23 | } = this.props; 24 | return ( 25 | <> 26 | 27 | 28 | 35 | 36 | ); 37 | } 38 | } 39 | 40 | export default Events; 41 | -------------------------------------------------------------------------------- /src/app/container/SplitPane.jsx: -------------------------------------------------------------------------------- 1 | import React from 'react'; 2 | 3 | // styled components 4 | import { PaneWrapper, LeftPane, RightPane } from '../styles/SplitPane.jsx'; 5 | 6 | export default function SplitPane(props) { 7 | const { left, right } = props; 8 | return ( 9 | 10 | {left} 11 | {right} 12 | 13 | ); 14 | } 15 | -------------------------------------------------------------------------------- /src/app/container/TimeSlider.jsx: -------------------------------------------------------------------------------- 1 | import React from 'react'; 2 | 3 | // styled component 4 | import { SliderWrapper, Button } from '../styles/TimeSlider.jsx'; 5 | 6 | const TimeSlider = (props) => { 7 | const { 8 | toTheFuture, 9 | toThePast, 10 | setIsRecording, 11 | isRecording, 12 | setIsPlaying, 13 | isPlaying, 14 | isPlayingIndex, 15 | data, 16 | handleBarChange, 17 | } = props; 18 | 19 | return ( 20 | 21 | 22 | 23 | 24 | 25 | 32 | 33 | ); 34 | }; 35 | 36 | export default TimeSlider; -------------------------------------------------------------------------------- /src/app/index.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | React Rewind 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | -------------------------------------------------------------------------------- /src/app/index.js: -------------------------------------------------------------------------------- 1 | import React from "react"; 2 | import ReactDOM from "react-dom"; 3 | import App from "./components/App.jsx"; 4 | 5 | ReactDOM.render( 6 | , document.getElementById('root'), 7 | ); -------------------------------------------------------------------------------- /src/app/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "react-rewind", 3 | "version": "1.0.0", 4 | "description": "Time-travel debugger for React useReducer", 5 | "main": "index.js", 6 | "scripts": { 7 | "start": "nodemon server/server.js", 8 | "start:dev": "webpack-dev-server --mode development --open --hot", 9 | "build": "webpack --watch", 10 | "webpack": "webpack" 11 | }, 12 | "babel": { 13 | "presets": [ 14 | "@babel/preset-env", 15 | "@babel/preset-react" 16 | ] 17 | }, 18 | "repository": { 19 | "type": "git", 20 | "url": "https://github.com/reactrewind" 21 | }, 22 | "author": "React Rewind", 23 | "license": "MIT", 24 | "dependencies": { 25 | "@babel/core": "^7.0.0", 26 | "@babel/preset-env": "^7.0.0", 27 | "@babel/preset-react": "^7.0.0", 28 | "@babel/register": "^7.0.0", 29 | "babel-loader": "^8.0.5", 30 | "css-loader": "^2.1.0", 31 | "react": "^16.8.3", 32 | "react-dom": "^16.8.3", 33 | "react-json-view": "^1.19.1", 34 | "react-router-dom": "^4.3.1", 35 | "style-loader": "^0.23.1", 36 | "styled-components": "^4.1.3" 37 | }, 38 | "devDependencies": { 39 | "webpack": "^4.29.6", 40 | "webpack-cli": "^3.3.0" 41 | } 42 | } 43 | -------------------------------------------------------------------------------- /src/app/styles/Details.jsx: -------------------------------------------------------------------------------- 1 | import styled from 'styled-components'; 2 | 3 | export const DetailsWrapper = styled.div` 4 | padding-left: 10px; 5 | padding-top: 10px; 6 | /* background-color: red; */ 7 | overflow: auto; 8 | height: calc(100% - 45px) 9 | `; -------------------------------------------------------------------------------- /src/app/styles/Events.jsx: -------------------------------------------------------------------------------- 1 | import styled from 'styled-components'; 2 | 3 | // the entire events display wrapper 4 | export const EventsWrapper = styled.div` 5 | height: -webkit-fill-available; 6 | overflow: auto; 7 | `; 8 | 9 | // single event card 10 | export const EventCard = styled.div` 11 | background-color: ${props => props.selectedEvent === 'false' ? 'none' : "#4F5A65"}; 12 | display: flex; 13 | justify-content: space-between; 14 | align-items: center; 15 | height: 50px; 16 | color: white; 17 | padding-left: 5%; 18 | padding-right: 5%; 19 | border-bottom: 1px solid #484C54; 20 | cursor: pointer; 21 | 22 | &:hover { 23 | color: ${props => props.selectedEvent === 'false' ? '#4F5A65' : "white"}; 24 | border-bottom: 1px solid #4F5A65; 25 | } 26 | `; 27 | 28 | // time card on event card 29 | export const EventTimeDiv = styled.div` 30 | width: 25%; 31 | text-align: center; 32 | background-color: ${props => props.selectedEvent === 'false' ? '#484C54' : "#3C444F"}; 33 | color: ${props => props.selectedEvent === 'false' ? 'white' : "white"}; 34 | border-radius: 5px; 35 | `; 36 | -------------------------------------------------------------------------------- /src/app/styles/FilterBar.jsx: -------------------------------------------------------------------------------- 1 | import styled from 'styled-components'; 2 | 3 | export const FilterWrapper = styled.div` 4 | color: white; 5 | border-bottom: 1px solid #484C54 ; 6 | input[type=text]{ 7 | font-size: 12px; 8 | width: 95%; 9 | margin-left: 5%; 10 | color: white; 11 | background-color: transparent; 12 | border: 0px solid #484C54; 13 | height: 30px; 14 | } 15 | 16 | *:focus { 17 | outline: none; 18 | } 19 | `; 20 | -------------------------------------------------------------------------------- /src/app/styles/Nav.jsx: -------------------------------------------------------------------------------- 1 | import styled from "styled-components"; 2 | 3 | // events nav wrapper 4 | export const EventsNavWrapper = styled.div` 5 | background-color: #3C444F; 6 | display: flex; 7 | align-items: center; 8 | justify-content: center; 9 | width: 100%; 10 | min-height: 33px; 11 | height: 35px; 12 | border-bottom: 1px solid #484C54; 13 | color: white; 14 | `; 15 | 16 | 17 | // details nav wrapper 18 | export const DetailsNavWrapper = styled.div` 19 | background-color: #3C444F; 20 | width: 100%; 21 | height: 33px; 22 | border-bottom: 1px solid #484C54; 23 | color: white; 24 | `; 25 | 26 | 27 | // details buttons container (actions effects state) 28 | export const Buttons = styled.div` 29 | width: 100%; 30 | height: 100%; 31 | display: inline-grid; 32 | grid-template-columns: 1fr 1fr 1fr; 33 | align-items: center; 34 | justify-content: center; 35 | 36 | a { 37 | height: 100%; 38 | width: 100%; 39 | text-decoration: none; 40 | color: white; 41 | 42 | &.active { 43 | color: white; 44 | background-color: #4F5A65; 45 | /* border-bottom: 3px solid hotpink; */ 46 | } 47 | } 48 | 49 | `; 50 | 51 | // individal button styling (actions, effects, state) 52 | export const Button = styled.div` 53 | /* border-right: 1px solid black; */ 54 | /* color: ${props => props.selected ? "black" : "black"} */ 55 | /* background: ${props => props.selected ? "lavender" : "null"}; */ 56 | width: 100%; 57 | height: 100%; 58 | display: flex; 59 | align-items: center; 60 | justify-content: center; 61 | 62 | a { 63 | color: black; 64 | } 65 | 66 | :hover { 67 | background: #4F5A65; 68 | color: white; 69 | /* border-bottom: 3px solid black; */ 70 | } 71 | 72 | `; 73 | -------------------------------------------------------------------------------- /src/app/styles/SplitPane.jsx: -------------------------------------------------------------------------------- 1 | import styled from 'styled-components'; 2 | 3 | // from grid 4 | export const Wrapper = styled.div` 5 | display: grid; 6 | height: 100vh; 7 | grid-template-rows: 1fr auto; 8 | `; 9 | 10 | // wrapper for total split pane views 11 | export const PaneWrapper = styled.div` 12 | font-family: "arial"; 13 | font-size: .80em; 14 | color: #E8E8F4; 15 | background-color: #2A2E3A; 16 | height: calc(100vh - 46px); 17 | display: flex; 18 | justify-content: space-around; 19 | `; 20 | 21 | // wrapper for events (left hand side) 22 | export const LeftPane = styled.div` 23 | background-color: #2A2E3A; 24 | border-right: 3px double #484C54; 25 | width: 43%; 26 | display: flex; 27 | flex-direction: column; 28 | `; 29 | 30 | // wrapper for details (right hand side) 31 | // UPDATED 32 | export const RightPane = styled.div` 33 | color: white; 34 | background-color: #2A2E3A; 35 | width: 57%; 36 | `; 37 | -------------------------------------------------------------------------------- /src/app/styles/TimeSlider.jsx: -------------------------------------------------------------------------------- 1 | import styled from 'styled-components'; 2 | 3 | export const SliderWrapper = styled.div` 4 | display: flex; 5 | height: 45px; 6 | justify-content: space-evenly; 7 | align-items: center; 8 | border-top: 1px solid #191c23; 9 | width: 100%; 10 | background-color: #3C444F; 11 | align-self: flex-end; 12 | 13 | input[type=range] { 14 | height: 25px; 15 | -webkit-appearance: none; 16 | margin: 10px 0; 17 | width: 60%; 18 | border-radius: 50px; 19 | background-color: transparent; 20 | } 21 | input[type=range]:focus { 22 | outline: none; 23 | } 24 | /* bar */ 25 | input[type=range]::-webkit-slider-runnable-track { 26 | width: 100%; 27 | height: 10px; 28 | cursor: pointer; 29 | animate: 0.2s; 30 | box-shadow: 0px 0px 0px #000000; 31 | background: white; 32 | border-radius: 10px; 33 | border: 0px solid #000000; 34 | } 35 | input[type=range]::-webkit-slider-thumb { 36 | box-shadow: 0px 0px 0px #000000; 37 | border: 0px solid rgb(123, 123, 123); 38 | height: 28px; 39 | width: 28px; 40 | border-radius: 25px; 41 | background: rgb(230, 230, 230); 42 | cursor: pointer; 43 | -webkit-appearance: none; 44 | margin-top: -10px; 45 | } 46 | input[type=range]:focus::-webkit-slider-runnable-track { 47 | background: rgb(255, 255, 255); 48 | } 49 | `; 50 | 51 | export const Button = styled.div` 52 | display: flex; 53 | align-content: center; 54 | justify-content: center; 55 | font-size: 20px; 56 | width: 40px; 57 | color: white; 58 | cursor: pointer; 59 | font-family: 'arial'; 60 | 61 | `; 62 | -------------------------------------------------------------------------------- /src/app/webpack.config.js: -------------------------------------------------------------------------------- 1 | const path = require('path'); 2 | 3 | module.exports = { 4 | mode: 'development', 5 | entry: './index.js', 6 | output: { 7 | path: path.resolve(__dirname, '../browser/chrome/devtools_bundle'), 8 | filename: 'devtools_bundle.js', 9 | }, 10 | devtool: 'source-map', 11 | module: { 12 | rules: [ 13 | { test: /\.(js|jsx)$/, use: 'babel-loader' }, 14 | { test: /\.css$/, use: ['style-loader', 'css-loader'] }, 15 | ], 16 | }, 17 | }; 18 | -------------------------------------------------------------------------------- /src/browser/chrome/background.js: -------------------------------------------------------------------------------- 1 | const parseAndGenerate = require('./scripts/parser'); 2 | const injectBundleStr = require('./scripts/inject_bundle'); 3 | 4 | let ports = []; 5 | let reqIndex = 0; 6 | const interceptedURLs = {}; 7 | 8 | chrome.tabs.onUpdated.addListener((id, info, tab) => { 9 | if (tab.status !== 'complete' || tab.url.startsWith('chrome')) return; 10 | 11 | // active page action button and inject extension.js 12 | chrome.pageAction.show(tab.id); 13 | chrome.tabs.executeScript(null, { 14 | file: 'extension.js', 15 | runAt: 'document_end', 16 | }); 17 | 18 | if (interceptedURLs.hasOwnProperty(tab.url)) { 19 | delete interceptedURLs[tab.url]; 20 | reqIndex = 0; 21 | } 22 | 23 | notifyPorts( 24 | { action: 'refresh_devtool', tabId: tab.id }, 25 | 'devtools', 26 | ); 27 | }); 28 | 29 | function handleRequest(request) { 30 | // TODO: filter the request from the webRequest call. 31 | // We check wether or not the URL should have its requests intercepted 32 | let shouldInterceptUrl = false; 33 | Object.keys(interceptedURLs).forEach((url) => { 34 | if (url.startsWith(request.initiator)) shouldInterceptUrl = true; 35 | }); 36 | if (!shouldInterceptUrl) return { cancel: false }; 37 | 38 | if (request.type === 'script' && !request.url.startsWith('chrome') 39 | && request.frameId === 0 && ((request.url.slice(-3) === '.js') 40 | || (request.url.slice(-4) === '.jsx'))) { 41 | // If we just started intercepting requests, we want to add our injected 42 | // bundle into the page. 43 | if (reqIndex === 0) sendMessageToContent(injectBundleStr); 44 | 45 | // To guarantee that the scripts are gonna be executed in order, we are 46 | // gonna intercept EVERY request that is made. Then we have to download the 47 | // script SYNC'ly since the webRequest API doesn't handle async. Last we 48 | // send it to our content script to inject it back into the page. Either 49 | // the React library with the extended functionality or the untouched script. 50 | const syncRequest = new XMLHttpRequest(); 51 | syncRequest.open('GET', request.url, false); 52 | syncRequest.send(null); 53 | 54 | sendMessageToContent(parseAndGenerate(syncRequest.responseText)); 55 | 56 | return { redirectUrl: 'data:application/json; charset=utf-8,' }; 57 | } 58 | } 59 | 60 | // The App on the devtools panel start a connection so that it can 61 | // tell us when to start intercepting the script requests. 62 | chrome.runtime.onConnect.addListener((port) => { 63 | if (ports) ports.push(port); 64 | 65 | port.onMessage.addListener((msg) => { 66 | if (!msg.turnOnDevtool) return; 67 | 68 | interceptedURLs[msg.url] = true; 69 | addScriptInterception(); 70 | 71 | // after activating our interception script, we refresh the active tab 72 | chrome.tabs.query({ active: true, currentWindow: true }, (tabs) => { 73 | chrome.tabs.update(tabs[0].id, { url: tabs[0].url }); 74 | }); 75 | }); 76 | }); 77 | 78 | function addScriptInterception() { 79 | chrome.webRequest.onBeforeRequest.removeListener(handleRequest); 80 | chrome.webRequest.onBeforeRequest.addListener( 81 | handleRequest, 82 | { urls: [''] }, 83 | ['blocking'], 84 | ); 85 | } 86 | 87 | function sendMessageToContent(codeString) { 88 | const index = reqIndex++; 89 | chrome.tabs.query({ active: true, currentWindow: true }, (tabs) => { 90 | chrome.tabs.sendMessage(tabs[0].id, { codeString, index }); 91 | }); 92 | } 93 | 94 | function notifyPorts(msg, portName) { 95 | let index = 0; 96 | while (index < ports.length) { 97 | if (portName && (ports[index].name !== portName)) index++; 98 | else { 99 | try { 100 | ports[index].postMessage(msg); 101 | index++; 102 | } catch { 103 | // remove closed port from array 104 | ports = [...ports.slice(0, index), ...ports.slice(index + 1)]; 105 | } 106 | } 107 | } 108 | } 109 | -------------------------------------------------------------------------------- /src/browser/chrome/devtools.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 7 | React Rewind 8 | 9 | 10 |
11 | 12 | 13 | 14 | -------------------------------------------------------------------------------- /src/browser/chrome/devtools.js: -------------------------------------------------------------------------------- 1 | chrome.devtools.panels.create('React Rewind', 2 | null, 3 | 'devtools.html', 4 | (devtoolsPanel) => { 5 | const backgroundPageConnection = chrome.runtime.connect({ 6 | name: 'devtools', 7 | }); 8 | 9 | devtoolsPanel.onShown.addListener(function tmp(panelWindow) { 10 | // Run once only 11 | devtoolsPanel.onShown.removeListener(tmp); 12 | 13 | const windowP = panelWindow; 14 | windowP.backgroundPort = backgroundPageConnection; 15 | 16 | backgroundPageConnection.onMessage.addListener((message) => { 17 | // When we get a msg from background telling us that we need 18 | // to refresh the App, we send it to App via window.PostMessage() 19 | if (message.action === 'refresh_devtool') windowP.postMessage(message); 20 | }); 21 | }); 22 | }); 23 | -------------------------------------------------------------------------------- /src/browser/chrome/extension.js: -------------------------------------------------------------------------------- 1 | (function openConnectionToApp() { 2 | const port = chrome.runtime.connect({ 3 | name: 'injected-app', 4 | }); 5 | 6 | port.onMessage.addListener((msg) => { 7 | // This is where we get messages from the App component. 8 | // We get an object { type: 'TIMETRAVEL', direction: 'forward' } 9 | window.postMessage(msg); 10 | }); 11 | 12 | window.addEventListener('message', (msg) => { 13 | // When our injected scripts post messages (from useReducer in 'react'), 14 | // we receive it here and send it to our app loaded on the DevTool. 15 | if (msg.data.type === 'DISPATCH') port.postMessage(msg.data.data); 16 | }); 17 | }()); 18 | -------------------------------------------------------------------------------- /src/browser/chrome/icons/icon_128.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/reactrewind/react-rewind/784cd0174ff62b4bfcc82b67110019673e75d376/src/browser/chrome/icons/icon_128.png -------------------------------------------------------------------------------- /src/browser/chrome/icons/icon_16.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/reactrewind/react-rewind/784cd0174ff62b4bfcc82b67110019673e75d376/src/browser/chrome/icons/icon_16.png -------------------------------------------------------------------------------- /src/browser/chrome/icons/icon_32.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/reactrewind/react-rewind/784cd0174ff62b4bfcc82b67110019673e75d376/src/browser/chrome/icons/icon_32.png -------------------------------------------------------------------------------- /src/browser/chrome/icons/icon_48.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/reactrewind/react-rewind/784cd0174ff62b4bfcc82b67110019673e75d376/src/browser/chrome/icons/icon_48.png -------------------------------------------------------------------------------- /src/browser/chrome/manifest.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "React Rewind", 3 | "short_name": "React Rewind", 4 | "version": "0.0.0.1", 5 | "description": "Time travel debugger for useReducer hook", 6 | "manifest_version": 2, 7 | "page_action": { 8 | "default_icon": { 9 | "16": "icons/icon_16.png", 10 | "32": "icons/icon_32.png", 11 | "48": "icons/icon_48.png", 12 | "128": "icons/icon_128.png" 13 | }, 14 | "default_popup": "page_action.html" 15 | }, 16 | "icons": { 17 | "16": "icons/icon_16.png", 18 | "32": "icons/icon_32.png", 19 | "48": "icons/icon_48.png", 20 | "128": "icons/icon_128.png" 21 | }, 22 | "background": { 23 | "scripts": ["devtools_bundle/bg_bundle.js"] 24 | }, 25 | "content_scripts": [ 26 | { 27 | "matches": [""], 28 | "js": ["scripts/inject_script_tags.js"], 29 | "run_at":"document_start" 30 | } 31 | ], 32 | "permissions": [ 33 | "", 34 | "tabs", 35 | "storage", 36 | "webRequest", 37 | "webRequestBlocking" 38 | ], 39 | "web_accessible_resources": [ 40 | "scripts/deepclone_bundle.js" 41 | ], 42 | "devtools_page": "devtools.html" 43 | } -------------------------------------------------------------------------------- /src/browser/chrome/page_action.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 7 | Page Action 8 | 9 | 31 | 32 | 33 |

React Rewind

34 |

Open Chrome developer tools, React Rewind tab is on the right.

35 | rewindjs.io 36 | Github 37 | 38 | 39 | -------------------------------------------------------------------------------- /src/browser/chrome/page_action.js: -------------------------------------------------------------------------------- 1 | document.addEventListener('DOMContentLoaded', () => { 2 | const links = document.getElementsByTagName('a'); 3 | const createTab = url => () => chrome.tabs.create({ active: true, url }); 4 | 5 | for (let i = 0; i < links.length; i++) { 6 | const ln = links[i]; 7 | const location = ln.href; 8 | ln.onclick = createTab(location); 9 | } 10 | }); 11 | -------------------------------------------------------------------------------- /src/browser/chrome/scripts/inject_bundle.js: -------------------------------------------------------------------------------- 1 | /* 2 | * We export a string that is gonna get injected into a