├── .babelrc ├── .eslintrc ├── .gitignore ├── .npmignore ├── CONTRIBUTING.md ├── LICENSE ├── README.md ├── index.js ├── package-lock.json ├── package.json ├── rollup.config.js ├── src └── component.js └── test ├── README.md ├── basics-test.js ├── conditional-rendering-test.js ├── containment-test.js ├── context-test.js ├── exit-test.js ├── index-test.js ├── key-function-test.js ├── nesting-test.js ├── recursive-component-test.js ├── recursive-exit-test.js └── specificity-test.js /.babelrc: -------------------------------------------------------------------------------- 1 | { 2 | "presets": [ "es2015" ] 3 | } -------------------------------------------------------------------------------- /.eslintrc: -------------------------------------------------------------------------------- 1 | { 2 | "extends": "airbnb-base", 3 | "rules": { 4 | "no-param-reassign": "off", 5 | "no-use-before-define": "off" 6 | } 7 | } 8 | -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | .DS_Store 2 | build/ 3 | node_modules 4 | npm-debug.log 5 | *.swp 6 | -------------------------------------------------------------------------------- /.npmignore: -------------------------------------------------------------------------------- 1 | build/*.zip 2 | test/ 3 | -------------------------------------------------------------------------------- /CONTRIBUTING.md: -------------------------------------------------------------------------------- 1 | # How to contribute 2 | 3 | Any feedback, questions, bug reports, and general discussions are most welcome. 4 | 5 | Please [submit an issue](https://github.com/curran/d3-component/issues/new) to start a discussion. 6 | 7 | If you've created something using d3-component, we'd love to hear about it! Please [submit an issue](https://github.com/curran/d3-component/issues/new) to request adding a link in the README to your example. 8 | 9 | To get started with development, 10 | 11 | * clone the repository, 12 | * run `npm install`, then 13 | * run `npm test`, which passes the source code `src/component.js` through ESLint and runs the tests found under `test`. 14 | -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | Copyright 2017, Curran Kelleher 2 | All rights reserved. 3 | 4 | Redistribution and use in source and binary forms, with or without modification, 5 | are permitted provided that the following conditions are met: 6 | 7 | * Redistributions of source code must retain the above copyright notice, this 8 | list of conditions and the following disclaimer. 9 | 10 | * Redistributions in binary form must reproduce the above copyright notice, 11 | this list of conditions and the following disclaimer in the documentation 12 | and/or other materials provided with the distribution. 13 | 14 | * Neither the name of the author nor the names of contributors may be used to 15 | endorse or promote products derived from this software without specific prior 16 | written permission. 17 | 18 | THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND 19 | ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED 20 | WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE 21 | DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR 22 | ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES 23 | (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; 24 | LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON 25 | ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 26 | (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS 27 | SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 28 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # d3-component 2 | 3 | A lightweight component abstraction for [D3.js](d3js.org). 4 | 5 | **Features:** 6 | 7 | * Encapsulates the [General Update Pattern](https://github.com/d3/d3-selection#selection_merge). 8 | * Composable (even [recursive](https://bl.ocks.org/curran/2aafab81bb2029e1f4f24d258b790ce4)!) stateless functional components. 9 | * Reliable `destroy` hook for cleaning things up. 10 | * Works great with [Redux](http://redux.js.org/). 11 | 12 | **Examples:** 13 | 14 | 15 | 16 | 24 | 25 | 33 | 34 | 42 | 43 | 44 | 45 | 53 | 54 | 60 | 61 | 71 | 72 | 73 | 74 | 80 | 81 | 87 | 88 | 94 | 95 | 96 | 97 | 103 | 104 |
17 |
18 | Posts | ES6 version 19 |
20 | 21 | 22 | 23 |
26 |
27 | Spinner | ES6 version 28 |
29 | 30 | 31 | 32 |
35 |
36 | Stopwatch (Redux) | ES6 version 37 |
38 | 39 | 40 | 41 |
46 |
47 | Counter (Redux) | ES6 version 48 |
49 | 50 | 51 | 52 |
55 | 56 |
Todos
57 | 58 |
59 |
62 |
63 | Scatter Plot with Menus (Redux) 64 |
65 | ES6 version | Radius select variant 66 |
67 | 68 | 69 | 70 |
75 | 76 |
Clock
77 | 78 |
79 |
82 | 83 |
Airport Clocks
84 | 85 |
86 |
89 | 90 |
example-viewer (Redux, ES6)
91 | 92 |
93 |
98 | 99 |
Fractal Pie Chart (ES6)
100 | 101 |
102 |
105 | 106 | Using this component abstraction, you can easily encapsulate data-driven user interface components as conceptual "boxes-within-boxes", cleanly isolating concerns for various levels of your DOM tree. This component abstraction is similar in concept and functionality to [React Stateless Functional Components](https://hackernoon.com/react-stateless-functional-components-nine-wins-you-might-have-overlooked-997b0d933dbc#.dc21r5uj4). Everything a component needs to render itself and interact with application state gets passed down through the component tree at render time. Components don't store any local state; this is the main difference between d3-component and the [Towards Reusable Charts](https://bost.ocks.org/mike/chart/) pattern. No special treatment is given to events or event delegation, because the intended use is within a unidirectional data flow architecture like [Redux](http://redux.js.org/). 107 | 108 | ## Installing 109 | 110 | If you use NPM, `npm install d3-component`. Otherwise, download the [latest release](https://github.com/curran/d3-component/releases/latest). You can also load directly from [unpkg.com](https://unpkg.com) as a [standalone library](https://unpkg.com/d3-component@1). AMD, CommonJS, and vanilla environments are supported. In vanilla, a `d3` global is exported: 111 | 112 | ```html 113 | 114 | 115 | 118 | ``` 119 | 120 | ## API Reference 121 | 122 | **Note:** There was a recent [major version release](https://github.com/curran/d3-component/releases/tag/v3.0.0), and along with it there were substantial [API Changes](https://github.com/curran/d3-component/issues/70). 123 | 124 | In summary, the API looks like this: 125 | 126 | ```js 127 | var myComponent = d3.component("div", "some-class") 128 | .create((selection, d, i) => { ... }) // Invoked for entering component instances. 129 | .render((selection, d, i) => { ... }) // Invoked for entering AND updating component instances. 130 | .destroy((selection, d, i) => { ... }); // Invoked for exiting instances, may return a transition. 131 | 132 | // To invoke the component, 133 | d3.select("body") // create a selection with a single element, 134 | .call(myComponent, "Hello d3-component!"); // then use selection.call(). 135 | ``` 136 | 137 | To see the full API in action, check out this ["Hello d3-component" example](https://bl.ocks.org/curran/c3d9783e641636479fa8e07a480e7233). 138 | 139 | # component(tagName[, className])) 140 | 141 | Creates a new component generator that manages and renders into DOM elements of the specified *tagName*. 142 | 143 | The optional parameter *className* determines the value of the `class` attribute on the DOM elements managed. 144 | 145 | # component.create(function(selection, d, i)) 146 | 147 | Sets the create *function* of this component generator, which will be invoked whenever a new component instance is created, being passed a *selection* containing the current DOM element, the current datum (*d*), and the index of the current datum (*i*). 148 | 149 | # component.render(function(selection, d, i)) 150 | 151 | Sets the render *function* of this component generator. This *function* will be invoked for each component instance during rendering, being passed a *selection* containing the current DOM element, the current datum (*d*), and the index of the current datum (*i*). 152 | 153 | # component.destroy(function(selection, d, i)) 154 | 155 | Sets the destroy *function* of this component generator, which will be invoked whenever a component instance is destroyed, being passed a *selection* containing the current DOM element, the current datum (*d*), and the index of the current datum (*i*). 156 | 157 | When a component instance gets destroyed, the destroy *function* of all its children is also invoked (recursively), so you can be sure that this *function* will be invoked before the compoent instance is removed from the DOM. 158 | 159 | The destroy *function* may optionally return a transition, which will defer DOM element removal until after the transition is finished (but only if the parent component instance is not destroyed). Deeply nested component instances may have their DOM nodes removed before the transition completes, so it's best not to depend on the DOM node existing after the transition completes. 160 | 161 | # component.key(function) 162 | 163 | Sets the key *function* used in the internal [data join](https://github.com/d3/d3-selection#selection_data) when managing DOM elements for component instances. Specifying a key *function* is optional (the array index is used as the key by default), but will make re-rendering more efficient in cases where *data* arrays get reordered or spliced over time. 164 | 165 | # component(selection[,data[,context]]) 166 | 167 | Renders the component to the given *selection*, a D3 selection containing a single DOM element. A raw DOM element may also be passed in as the *selection* argument. Returns a D3 selection containing the merged Enter and Update selections for component instances. 168 | 169 | * If *data* is specified and is an array, one component instance will be rendered for each element of the array, and the *[render function](component_render)* will receive a single element of the *data* array as its *d* argument. 170 | * **Useful case:** If *data* is specified as an empty array `[]`, all previously rendered component instances will be removed. 171 | * If *data* is specified and is not an array, exactly one component instance will be rendered, and the *[render function](component_render)* will receive the *data* value as its *d* argument. 172 | * If *data* is not specified, exactly one component instance will be rendered, and the *[render function](component_render)* will receive `undefined` as its *d* argument. 173 | 174 | In summary, components can be rendered using the following signatures: 175 | 176 | * `selection.call(myComponent, dataObject)` → One instance, render function *d* will be `dataObject`. 177 | * `selection.call(myComponent, dataArray)` → `dataArray.length` instances, render function *d* will be `dataArray[i]` 178 | * `selection.call(myComponent)` → One instance, render function *d* will be `undefined`. 179 | 180 | If a *context* object is specified, each data element in the data array will be shallow merged into a new object whose prototype is the *context* object, and the resulting array will be used in place of the *data* array. This is useful for passing down callback functions through your component tree. To clarify, the following two invocations are equivalent: 181 | 182 | ```js 183 | var context = { 184 | onClick: function (){ console.log("Clicked!"); 185 | }; 186 | selection.call(myComponent, dataArray.map(function (d){ 187 | return Object.assign(Object.create(context), d); 188 | })); 189 | ``` 190 | 191 | ```js 192 | var context = { 193 | onClick: function (){ console.log("Clicked!"); 194 | }; 195 | selection.call(myComponent, dataArray, context); 196 | ``` 197 | -------------------------------------------------------------------------------- /index.js: -------------------------------------------------------------------------------- 1 | export {default as component} from "./src/component"; 2 | -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "d3-component", 3 | "version": "3.1.0", 4 | "lockfileVersion": 1, 5 | "requires": true, 6 | "dependencies": { 7 | "abab": { 8 | "version": "1.0.4", 9 | "resolved": "https://registry.npmjs.org/abab/-/abab-1.0.4.tgz", 10 | "integrity": "sha1-X6rZwsB/YN12dw9xzwJbYqY8/U4=", 11 | "dev": true 12 | }, 13 | "acorn": { 14 | "version": "5.2.1", 15 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-5.2.1.tgz", 16 | "integrity": "sha512-jG0u7c4Ly+3QkkW18V+NRDN+4bWHdln30NL1ZL2AvFZZmQe/BfopYCtghCKKVBUSetZ4QKcyA0pY6/4Gw8Pv8w==", 17 | "dev": true 18 | }, 19 | "acorn-globals": { 20 | "version": "3.1.0", 21 | "resolved": "https://registry.npmjs.org/acorn-globals/-/acorn-globals-3.1.0.tgz", 22 | "integrity": "sha1-/YJw9x+7SZawBPqIDuXUZXOnMb8=", 23 | "dev": true, 24 | "requires": { 25 | "acorn": "4.0.13" 26 | }, 27 | "dependencies": { 28 | "acorn": { 29 | "version": "4.0.13", 30 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-4.0.13.tgz", 31 | "integrity": "sha1-EFSVrlNh1pe9GVyCUZLhrX8lN4c=", 32 | "dev": true 33 | } 34 | } 35 | }, 36 | "acorn-jsx": { 37 | "version": "3.0.1", 38 | "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-3.0.1.tgz", 39 | "integrity": "sha1-r9+UiPsezvyDSPb7IvRk4ypYs2s=", 40 | "dev": true, 41 | "requires": { 42 | "acorn": "3.3.0" 43 | }, 44 | "dependencies": { 45 | "acorn": { 46 | "version": "3.3.0", 47 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-3.3.0.tgz", 48 | "integrity": "sha1-ReN/s56No/JbruP/U2niu18iAXo=", 49 | "dev": true 50 | } 51 | } 52 | }, 53 | "ansi-regex": { 54 | "version": "2.1.1", 55 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-2.1.1.tgz", 56 | "integrity": "sha1-w7M6te42DYbg5ijwRorn7yfWVN8=", 57 | "dev": true 58 | }, 59 | "ansi-styles": { 60 | "version": "2.2.1", 61 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-2.2.1.tgz", 62 | "integrity": "sha1-tDLdM1i2NM914eRmQ2gkBTPB3b4=", 63 | "dev": true 64 | }, 65 | "argparse": { 66 | "version": "1.0.9", 67 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.9.tgz", 68 | "integrity": "sha1-c9g7wmP4bpf4zE9rrhsOkKfSLIY=", 69 | "dev": true, 70 | "requires": { 71 | "sprintf-js": "1.0.3" 72 | } 73 | }, 74 | "array-equal": { 75 | "version": "1.0.0", 76 | "resolved": "https://registry.npmjs.org/array-equal/-/array-equal-1.0.0.tgz", 77 | "integrity": "sha1-jCpe8kcv2ep0KwTHenUJO6J1fJM=", 78 | "dev": true 79 | }, 80 | "array-union": { 81 | "version": "1.0.2", 82 | "resolved": "https://registry.npmjs.org/array-union/-/array-union-1.0.2.tgz", 83 | "integrity": "sha1-mjRBDk9OPaI96jdb5b5w8kd47Dk=", 84 | "dev": true, 85 | "requires": { 86 | "array-uniq": "1.0.3" 87 | } 88 | }, 89 | "array-uniq": { 90 | "version": "1.0.3", 91 | "resolved": "https://registry.npmjs.org/array-uniq/-/array-uniq-1.0.3.tgz", 92 | "integrity": "sha1-r2rId6Jcx/dOBYiUdThY39sk/bY=", 93 | "dev": true 94 | }, 95 | "arrify": { 96 | "version": "1.0.1", 97 | "resolved": "https://registry.npmjs.org/arrify/-/arrify-1.0.1.tgz", 98 | "integrity": "sha1-iYUI2iIm84DfkEcoRWhJwVAaSw0=", 99 | "dev": true 100 | }, 101 | "asn1": { 102 | "version": "0.2.3", 103 | "resolved": "https://registry.npmjs.org/asn1/-/asn1-0.2.3.tgz", 104 | "integrity": "sha1-2sh4dxPJlmhJ/IGAd36+nB3fO4Y=", 105 | "dev": true 106 | }, 107 | "assert-plus": { 108 | "version": "1.0.0", 109 | "resolved": "https://registry.npmjs.org/assert-plus/-/assert-plus-1.0.0.tgz", 110 | "integrity": "sha1-8S4PPF13sLHN2RRpQuTpbB5N1SU=", 111 | "dev": true 112 | }, 113 | "asynckit": { 114 | "version": "0.4.0", 115 | "resolved": "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz", 116 | "integrity": "sha1-x57Zf380y48robyXkLzDZkdLS3k=", 117 | "dev": true 118 | }, 119 | "aws-sign2": { 120 | "version": "0.7.0", 121 | "resolved": "https://registry.npmjs.org/aws-sign2/-/aws-sign2-0.7.0.tgz", 122 | "integrity": "sha1-tG6JCTSpWR8tL2+G1+ap8bP+dqg=", 123 | "dev": true 124 | }, 125 | "aws4": { 126 | "version": "1.6.0", 127 | "resolved": "https://registry.npmjs.org/aws4/-/aws4-1.6.0.tgz", 128 | "integrity": "sha1-g+9cqGCysy5KDe7e6MdxudtXRx4=", 129 | "dev": true 130 | }, 131 | "babel-code-frame": { 132 | "version": "6.26.0", 133 | "resolved": "https://registry.npmjs.org/babel-code-frame/-/babel-code-frame-6.26.0.tgz", 134 | "integrity": "sha1-Y/1D99weO7fONZR9uP42mj9Yx0s=", 135 | "dev": true, 136 | "requires": { 137 | "chalk": "1.1.3", 138 | "esutils": "2.0.2", 139 | "js-tokens": "3.0.2" 140 | } 141 | }, 142 | "babel-core": { 143 | "version": "6.26.0", 144 | "resolved": "https://registry.npmjs.org/babel-core/-/babel-core-6.26.0.tgz", 145 | "integrity": "sha1-rzL3izGm/O8RnIew/Y2XU/A6C7g=", 146 | "dev": true, 147 | "requires": { 148 | "babel-code-frame": "6.26.0", 149 | "babel-generator": "6.26.0", 150 | "babel-helpers": "6.24.1", 151 | "babel-messages": "6.23.0", 152 | "babel-register": "6.26.0", 153 | "babel-runtime": "6.26.0", 154 | "babel-template": "6.26.0", 155 | "babel-traverse": "6.26.0", 156 | "babel-types": "6.26.0", 157 | "babylon": "6.18.0", 158 | "convert-source-map": "1.5.1", 159 | "debug": "2.6.9", 160 | "json5": "0.5.1", 161 | "lodash": "4.17.4", 162 | "minimatch": "3.0.4", 163 | "path-is-absolute": "1.0.1", 164 | "private": "0.1.8", 165 | "slash": "1.0.0", 166 | "source-map": "0.5.7" 167 | } 168 | }, 169 | "babel-generator": { 170 | "version": "6.26.0", 171 | "resolved": "https://registry.npmjs.org/babel-generator/-/babel-generator-6.26.0.tgz", 172 | "integrity": "sha1-rBriAHC3n248odMmlhMFN3TyDcU=", 173 | "dev": true, 174 | "requires": { 175 | "babel-messages": "6.23.0", 176 | "babel-runtime": "6.26.0", 177 | "babel-types": "6.26.0", 178 | "detect-indent": "4.0.0", 179 | "jsesc": "1.3.0", 180 | "lodash": "4.17.4", 181 | "source-map": "0.5.7", 182 | "trim-right": "1.0.1" 183 | }, 184 | "dependencies": { 185 | "jsesc": { 186 | "version": "1.3.0", 187 | "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-1.3.0.tgz", 188 | "integrity": "sha1-RsP+yMGJKxKwgz25vHYiF226s0s=", 189 | "dev": true 190 | } 191 | } 192 | }, 193 | "babel-helper-call-delegate": { 194 | "version": "6.24.1", 195 | "resolved": "https://registry.npmjs.org/babel-helper-call-delegate/-/babel-helper-call-delegate-6.24.1.tgz", 196 | "integrity": "sha1-7Oaqzdx25Bw0YfiL/Fdb0Nqi340=", 197 | "dev": true, 198 | "requires": { 199 | "babel-helper-hoist-variables": "6.24.1", 200 | "babel-runtime": "6.26.0", 201 | "babel-traverse": "6.26.0", 202 | "babel-types": "6.26.0" 203 | } 204 | }, 205 | "babel-helper-define-map": { 206 | "version": "6.26.0", 207 | "resolved": "https://registry.npmjs.org/babel-helper-define-map/-/babel-helper-define-map-6.26.0.tgz", 208 | "integrity": "sha1-pfVtq0GiX5fstJjH66ypgZ+Vvl8=", 209 | "dev": true, 210 | "requires": { 211 | "babel-helper-function-name": "6.24.1", 212 | "babel-runtime": "6.26.0", 213 | "babel-types": "6.26.0", 214 | "lodash": "4.17.4" 215 | } 216 | }, 217 | "babel-helper-function-name": { 218 | "version": "6.24.1", 219 | "resolved": "https://registry.npmjs.org/babel-helper-function-name/-/babel-helper-function-name-6.24.1.tgz", 220 | "integrity": "sha1-00dbjAPtmCQqJbSDUasYOZ01gKk=", 221 | "dev": true, 222 | "requires": { 223 | "babel-helper-get-function-arity": "6.24.1", 224 | "babel-runtime": "6.26.0", 225 | "babel-template": "6.26.0", 226 | "babel-traverse": "6.26.0", 227 | "babel-types": "6.26.0" 228 | } 229 | }, 230 | "babel-helper-get-function-arity": { 231 | "version": "6.24.1", 232 | "resolved": "https://registry.npmjs.org/babel-helper-get-function-arity/-/babel-helper-get-function-arity-6.24.1.tgz", 233 | "integrity": "sha1-j3eCqpNAfEHTqlCQj4mwMbG2hT0=", 234 | "dev": true, 235 | "requires": { 236 | "babel-runtime": "6.26.0", 237 | "babel-types": "6.26.0" 238 | } 239 | }, 240 | "babel-helper-hoist-variables": { 241 | "version": "6.24.1", 242 | "resolved": "https://registry.npmjs.org/babel-helper-hoist-variables/-/babel-helper-hoist-variables-6.24.1.tgz", 243 | "integrity": "sha1-HssnaJydJVE+rbyZFKc/VAi+enY=", 244 | "dev": true, 245 | "requires": { 246 | "babel-runtime": "6.26.0", 247 | "babel-types": "6.26.0" 248 | } 249 | }, 250 | "babel-helper-optimise-call-expression": { 251 | "version": "6.24.1", 252 | "resolved": "https://registry.npmjs.org/babel-helper-optimise-call-expression/-/babel-helper-optimise-call-expression-6.24.1.tgz", 253 | "integrity": "sha1-96E0J7qfc/j0+pk8VKl4gtEkQlc=", 254 | "dev": true, 255 | "requires": { 256 | "babel-runtime": "6.26.0", 257 | "babel-types": "6.26.0" 258 | } 259 | }, 260 | "babel-helper-regex": { 261 | "version": "6.26.0", 262 | "resolved": "https://registry.npmjs.org/babel-helper-regex/-/babel-helper-regex-6.26.0.tgz", 263 | "integrity": "sha1-MlxZ+QL4LyS3T6zu0DY5VPZJXnI=", 264 | "dev": true, 265 | "requires": { 266 | "babel-runtime": "6.26.0", 267 | "babel-types": "6.26.0", 268 | "lodash": "4.17.4" 269 | } 270 | }, 271 | "babel-helper-replace-supers": { 272 | "version": "6.24.1", 273 | "resolved": "https://registry.npmjs.org/babel-helper-replace-supers/-/babel-helper-replace-supers-6.24.1.tgz", 274 | "integrity": "sha1-v22/5Dk40XNpohPKiov3S2qQqxo=", 275 | "dev": true, 276 | "requires": { 277 | "babel-helper-optimise-call-expression": "6.24.1", 278 | "babel-messages": "6.23.0", 279 | "babel-runtime": "6.26.0", 280 | "babel-template": "6.26.0", 281 | "babel-traverse": "6.26.0", 282 | "babel-types": "6.26.0" 283 | } 284 | }, 285 | "babel-helpers": { 286 | "version": "6.24.1", 287 | "resolved": "https://registry.npmjs.org/babel-helpers/-/babel-helpers-6.24.1.tgz", 288 | "integrity": "sha1-NHHenK7DiOXIUOWX5Yom3fN2ArI=", 289 | "dev": true, 290 | "requires": { 291 | "babel-runtime": "6.26.0", 292 | "babel-template": "6.26.0" 293 | } 294 | }, 295 | "babel-messages": { 296 | "version": "6.23.0", 297 | "resolved": "https://registry.npmjs.org/babel-messages/-/babel-messages-6.23.0.tgz", 298 | "integrity": "sha1-8830cDhYA1sqKVHG7F7fbGLyYw4=", 299 | "dev": true, 300 | "requires": { 301 | "babel-runtime": "6.26.0" 302 | } 303 | }, 304 | "babel-plugin-check-es2015-constants": { 305 | "version": "6.22.0", 306 | "resolved": "https://registry.npmjs.org/babel-plugin-check-es2015-constants/-/babel-plugin-check-es2015-constants-6.22.0.tgz", 307 | "integrity": "sha1-NRV7EBQm/S/9PaP3XH0ekYNbv4o=", 308 | "dev": true, 309 | "requires": { 310 | "babel-runtime": "6.26.0" 311 | } 312 | }, 313 | "babel-plugin-external-helpers": { 314 | "version": "6.22.0", 315 | "resolved": "https://registry.npmjs.org/babel-plugin-external-helpers/-/babel-plugin-external-helpers-6.22.0.tgz", 316 | "integrity": "sha1-IoX0iwK9Xe3oUXXK+MYuhq3M76E=", 317 | "dev": true, 318 | "requires": { 319 | "babel-runtime": "6.26.0" 320 | } 321 | }, 322 | "babel-plugin-transform-es2015-arrow-functions": { 323 | "version": "6.22.0", 324 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-arrow-functions/-/babel-plugin-transform-es2015-arrow-functions-6.22.0.tgz", 325 | "integrity": "sha1-RSaSy3EdX3ncf4XkQM5BufJE0iE=", 326 | "dev": true, 327 | "requires": { 328 | "babel-runtime": "6.26.0" 329 | } 330 | }, 331 | "babel-plugin-transform-es2015-block-scoped-functions": { 332 | "version": "6.22.0", 333 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-block-scoped-functions/-/babel-plugin-transform-es2015-block-scoped-functions-6.22.0.tgz", 334 | "integrity": "sha1-u8UbSflk1wy42OC5ToICRs46YUE=", 335 | "dev": true, 336 | "requires": { 337 | "babel-runtime": "6.26.0" 338 | } 339 | }, 340 | "babel-plugin-transform-es2015-block-scoping": { 341 | "version": "6.26.0", 342 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-block-scoping/-/babel-plugin-transform-es2015-block-scoping-6.26.0.tgz", 343 | "integrity": "sha1-1w9SmcEwjQXBL0Y4E7CgnnOxiV8=", 344 | "dev": true, 345 | "requires": { 346 | "babel-runtime": "6.26.0", 347 | "babel-template": "6.26.0", 348 | "babel-traverse": "6.26.0", 349 | "babel-types": "6.26.0", 350 | "lodash": "4.17.4" 351 | } 352 | }, 353 | "babel-plugin-transform-es2015-classes": { 354 | "version": "6.24.1", 355 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-classes/-/babel-plugin-transform-es2015-classes-6.24.1.tgz", 356 | "integrity": "sha1-WkxYpQyclGHlZLSyo7+ryXolhNs=", 357 | "dev": true, 358 | "requires": { 359 | "babel-helper-define-map": "6.26.0", 360 | "babel-helper-function-name": "6.24.1", 361 | "babel-helper-optimise-call-expression": "6.24.1", 362 | "babel-helper-replace-supers": "6.24.1", 363 | "babel-messages": "6.23.0", 364 | "babel-runtime": "6.26.0", 365 | "babel-template": "6.26.0", 366 | "babel-traverse": "6.26.0", 367 | "babel-types": "6.26.0" 368 | } 369 | }, 370 | "babel-plugin-transform-es2015-computed-properties": { 371 | "version": "6.24.1", 372 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-computed-properties/-/babel-plugin-transform-es2015-computed-properties-6.24.1.tgz", 373 | "integrity": "sha1-b+Ko0WiV1WNPTNmZttNICjCBWbM=", 374 | "dev": true, 375 | "requires": { 376 | "babel-runtime": "6.26.0", 377 | "babel-template": "6.26.0" 378 | } 379 | }, 380 | "babel-plugin-transform-es2015-destructuring": { 381 | "version": "6.23.0", 382 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-destructuring/-/babel-plugin-transform-es2015-destructuring-6.23.0.tgz", 383 | "integrity": "sha1-mXux8auWf2gtKwh2/jWNYOdlxW0=", 384 | "dev": true, 385 | "requires": { 386 | "babel-runtime": "6.26.0" 387 | } 388 | }, 389 | "babel-plugin-transform-es2015-duplicate-keys": { 390 | "version": "6.24.1", 391 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-duplicate-keys/-/babel-plugin-transform-es2015-duplicate-keys-6.24.1.tgz", 392 | "integrity": "sha1-c+s9MQypaePvnskcU3QabxV2Qj4=", 393 | "dev": true, 394 | "requires": { 395 | "babel-runtime": "6.26.0", 396 | "babel-types": "6.26.0" 397 | } 398 | }, 399 | "babel-plugin-transform-es2015-for-of": { 400 | "version": "6.23.0", 401 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-for-of/-/babel-plugin-transform-es2015-for-of-6.23.0.tgz", 402 | "integrity": "sha1-9HyVsrYT3x0+zC/bdXNiPHUkhpE=", 403 | "dev": true, 404 | "requires": { 405 | "babel-runtime": "6.26.0" 406 | } 407 | }, 408 | "babel-plugin-transform-es2015-function-name": { 409 | "version": "6.24.1", 410 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-function-name/-/babel-plugin-transform-es2015-function-name-6.24.1.tgz", 411 | "integrity": "sha1-g0yJhTvDaxrw86TF26qU/Y6sqos=", 412 | "dev": true, 413 | "requires": { 414 | "babel-helper-function-name": "6.24.1", 415 | "babel-runtime": "6.26.0", 416 | "babel-types": "6.26.0" 417 | } 418 | }, 419 | "babel-plugin-transform-es2015-literals": { 420 | "version": "6.22.0", 421 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-literals/-/babel-plugin-transform-es2015-literals-6.22.0.tgz", 422 | "integrity": "sha1-T1SgLWzWbPkVKAAZox0xklN3yi4=", 423 | "dev": true, 424 | "requires": { 425 | "babel-runtime": "6.26.0" 426 | } 427 | }, 428 | "babel-plugin-transform-es2015-modules-amd": { 429 | "version": "6.24.1", 430 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-modules-amd/-/babel-plugin-transform-es2015-modules-amd-6.24.1.tgz", 431 | "integrity": "sha1-Oz5UAXI5hC1tGcMBHEvS8AoA0VQ=", 432 | "dev": true, 433 | "requires": { 434 | "babel-plugin-transform-es2015-modules-commonjs": "6.26.0", 435 | "babel-runtime": "6.26.0", 436 | "babel-template": "6.26.0" 437 | } 438 | }, 439 | "babel-plugin-transform-es2015-modules-commonjs": { 440 | "version": "6.26.0", 441 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-modules-commonjs/-/babel-plugin-transform-es2015-modules-commonjs-6.26.0.tgz", 442 | "integrity": "sha1-DYOUApt9xqvhqX7xgeAHWN0uXYo=", 443 | "dev": true, 444 | "requires": { 445 | "babel-plugin-transform-strict-mode": "6.24.1", 446 | "babel-runtime": "6.26.0", 447 | "babel-template": "6.26.0", 448 | "babel-types": "6.26.0" 449 | } 450 | }, 451 | "babel-plugin-transform-es2015-modules-systemjs": { 452 | "version": "6.24.1", 453 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-modules-systemjs/-/babel-plugin-transform-es2015-modules-systemjs-6.24.1.tgz", 454 | "integrity": "sha1-/4mhQrkRmpBhlfXxBuzzBdlAfSM=", 455 | "dev": true, 456 | "requires": { 457 | "babel-helper-hoist-variables": "6.24.1", 458 | "babel-runtime": "6.26.0", 459 | "babel-template": "6.26.0" 460 | } 461 | }, 462 | "babel-plugin-transform-es2015-modules-umd": { 463 | "version": "6.24.1", 464 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-modules-umd/-/babel-plugin-transform-es2015-modules-umd-6.24.1.tgz", 465 | "integrity": "sha1-rJl+YoXNGO1hdq22B9YCNErThGg=", 466 | "dev": true, 467 | "requires": { 468 | "babel-plugin-transform-es2015-modules-amd": "6.24.1", 469 | "babel-runtime": "6.26.0", 470 | "babel-template": "6.26.0" 471 | } 472 | }, 473 | "babel-plugin-transform-es2015-object-super": { 474 | "version": "6.24.1", 475 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-object-super/-/babel-plugin-transform-es2015-object-super-6.24.1.tgz", 476 | "integrity": "sha1-JM72muIcuDp/hgPa0CH1cusnj40=", 477 | "dev": true, 478 | "requires": { 479 | "babel-helper-replace-supers": "6.24.1", 480 | "babel-runtime": "6.26.0" 481 | } 482 | }, 483 | "babel-plugin-transform-es2015-parameters": { 484 | "version": "6.24.1", 485 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-parameters/-/babel-plugin-transform-es2015-parameters-6.24.1.tgz", 486 | "integrity": "sha1-V6w1GrScrxSpfNE7CfZv3wpiXys=", 487 | "dev": true, 488 | "requires": { 489 | "babel-helper-call-delegate": "6.24.1", 490 | "babel-helper-get-function-arity": "6.24.1", 491 | "babel-runtime": "6.26.0", 492 | "babel-template": "6.26.0", 493 | "babel-traverse": "6.26.0", 494 | "babel-types": "6.26.0" 495 | } 496 | }, 497 | "babel-plugin-transform-es2015-shorthand-properties": { 498 | "version": "6.24.1", 499 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-shorthand-properties/-/babel-plugin-transform-es2015-shorthand-properties-6.24.1.tgz", 500 | "integrity": "sha1-JPh11nIch2YbvZmkYi5R8U3jiqA=", 501 | "dev": true, 502 | "requires": { 503 | "babel-runtime": "6.26.0", 504 | "babel-types": "6.26.0" 505 | } 506 | }, 507 | "babel-plugin-transform-es2015-spread": { 508 | "version": "6.22.0", 509 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-spread/-/babel-plugin-transform-es2015-spread-6.22.0.tgz", 510 | "integrity": "sha1-1taKmfia7cRTbIGlQujdnxdG+NE=", 511 | "dev": true, 512 | "requires": { 513 | "babel-runtime": "6.26.0" 514 | } 515 | }, 516 | "babel-plugin-transform-es2015-sticky-regex": { 517 | "version": "6.24.1", 518 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-sticky-regex/-/babel-plugin-transform-es2015-sticky-regex-6.24.1.tgz", 519 | "integrity": "sha1-AMHNsaynERLN8M9hJsLta0V8zbw=", 520 | "dev": true, 521 | "requires": { 522 | "babel-helper-regex": "6.26.0", 523 | "babel-runtime": "6.26.0", 524 | "babel-types": "6.26.0" 525 | } 526 | }, 527 | "babel-plugin-transform-es2015-template-literals": { 528 | "version": "6.22.0", 529 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-template-literals/-/babel-plugin-transform-es2015-template-literals-6.22.0.tgz", 530 | "integrity": "sha1-qEs0UPfp+PH2g51taH2oS7EjbY0=", 531 | "dev": true, 532 | "requires": { 533 | "babel-runtime": "6.26.0" 534 | } 535 | }, 536 | "babel-plugin-transform-es2015-typeof-symbol": { 537 | "version": "6.23.0", 538 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-typeof-symbol/-/babel-plugin-transform-es2015-typeof-symbol-6.23.0.tgz", 539 | "integrity": "sha1-3sCfHN3/lLUqxz1QXITfWdzOs3I=", 540 | "dev": true, 541 | "requires": { 542 | "babel-runtime": "6.26.0" 543 | } 544 | }, 545 | "babel-plugin-transform-es2015-unicode-regex": { 546 | "version": "6.24.1", 547 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-unicode-regex/-/babel-plugin-transform-es2015-unicode-regex-6.24.1.tgz", 548 | "integrity": "sha1-04sS9C6nMj9yk4fxinxa4frrNek=", 549 | "dev": true, 550 | "requires": { 551 | "babel-helper-regex": "6.26.0", 552 | "babel-runtime": "6.26.0", 553 | "regexpu-core": "2.0.0" 554 | } 555 | }, 556 | "babel-plugin-transform-regenerator": { 557 | "version": "6.26.0", 558 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-regenerator/-/babel-plugin-transform-regenerator-6.26.0.tgz", 559 | "integrity": "sha1-4HA2lvveJ/Cj78rPi03KL3s6jy8=", 560 | "dev": true, 561 | "requires": { 562 | "regenerator-transform": "0.10.1" 563 | } 564 | }, 565 | "babel-plugin-transform-strict-mode": { 566 | "version": "6.24.1", 567 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-strict-mode/-/babel-plugin-transform-strict-mode-6.24.1.tgz", 568 | "integrity": "sha1-1fr3qleKZbvlkc9e2uBKDGcCB1g=", 569 | "dev": true, 570 | "requires": { 571 | "babel-runtime": "6.26.0", 572 | "babel-types": "6.26.0" 573 | } 574 | }, 575 | "babel-preset-es2015": { 576 | "version": "6.24.1", 577 | "resolved": "https://registry.npmjs.org/babel-preset-es2015/-/babel-preset-es2015-6.24.1.tgz", 578 | "integrity": "sha1-1EBQ1rwsn+6nAqrzjXJ6AhBTiTk=", 579 | "dev": true, 580 | "requires": { 581 | "babel-plugin-check-es2015-constants": "6.22.0", 582 | "babel-plugin-transform-es2015-arrow-functions": "6.22.0", 583 | "babel-plugin-transform-es2015-block-scoped-functions": "6.22.0", 584 | "babel-plugin-transform-es2015-block-scoping": "6.26.0", 585 | "babel-plugin-transform-es2015-classes": "6.24.1", 586 | "babel-plugin-transform-es2015-computed-properties": "6.24.1", 587 | "babel-plugin-transform-es2015-destructuring": "6.23.0", 588 | "babel-plugin-transform-es2015-duplicate-keys": "6.24.1", 589 | "babel-plugin-transform-es2015-for-of": "6.23.0", 590 | "babel-plugin-transform-es2015-function-name": "6.24.1", 591 | "babel-plugin-transform-es2015-literals": "6.22.0", 592 | "babel-plugin-transform-es2015-modules-amd": "6.24.1", 593 | "babel-plugin-transform-es2015-modules-commonjs": "6.26.0", 594 | "babel-plugin-transform-es2015-modules-systemjs": "6.24.1", 595 | "babel-plugin-transform-es2015-modules-umd": "6.24.1", 596 | "babel-plugin-transform-es2015-object-super": "6.24.1", 597 | "babel-plugin-transform-es2015-parameters": "6.24.1", 598 | "babel-plugin-transform-es2015-shorthand-properties": "6.24.1", 599 | "babel-plugin-transform-es2015-spread": "6.22.0", 600 | "babel-plugin-transform-es2015-sticky-regex": "6.24.1", 601 | "babel-plugin-transform-es2015-template-literals": "6.22.0", 602 | "babel-plugin-transform-es2015-typeof-symbol": "6.23.0", 603 | "babel-plugin-transform-es2015-unicode-regex": "6.24.1", 604 | "babel-plugin-transform-regenerator": "6.26.0" 605 | } 606 | }, 607 | "babel-register": { 608 | "version": "6.26.0", 609 | "resolved": "https://registry.npmjs.org/babel-register/-/babel-register-6.26.0.tgz", 610 | "integrity": "sha1-btAhFz4vy0htestFxgCahW9kcHE=", 611 | "dev": true, 612 | "requires": { 613 | "babel-core": "6.26.0", 614 | "babel-runtime": "6.26.0", 615 | "core-js": "2.5.3", 616 | "home-or-tmp": "2.0.0", 617 | "lodash": "4.17.4", 618 | "mkdirp": "0.5.1", 619 | "source-map-support": "0.4.18" 620 | } 621 | }, 622 | "babel-runtime": { 623 | "version": "6.26.0", 624 | "resolved": "https://registry.npmjs.org/babel-runtime/-/babel-runtime-6.26.0.tgz", 625 | "integrity": "sha1-llxwWGaOgrVde/4E/yM3vItWR/4=", 626 | "dev": true, 627 | "requires": { 628 | "core-js": "2.5.3", 629 | "regenerator-runtime": "0.11.1" 630 | } 631 | }, 632 | "babel-template": { 633 | "version": "6.26.0", 634 | "resolved": "https://registry.npmjs.org/babel-template/-/babel-template-6.26.0.tgz", 635 | "integrity": "sha1-3gPi0WOWsGn0bdn/+FIfsaDjXgI=", 636 | "dev": true, 637 | "requires": { 638 | "babel-runtime": "6.26.0", 639 | "babel-traverse": "6.26.0", 640 | "babel-types": "6.26.0", 641 | "babylon": "6.18.0", 642 | "lodash": "4.17.4" 643 | } 644 | }, 645 | "babel-traverse": { 646 | "version": "6.26.0", 647 | "resolved": "https://registry.npmjs.org/babel-traverse/-/babel-traverse-6.26.0.tgz", 648 | "integrity": "sha1-RqnL1+3MYsjlwGTi0tjQ9ANXZu4=", 649 | "dev": true, 650 | "requires": { 651 | "babel-code-frame": "6.26.0", 652 | "babel-messages": "6.23.0", 653 | "babel-runtime": "6.26.0", 654 | "babel-types": "6.26.0", 655 | "babylon": "6.18.0", 656 | "debug": "2.6.9", 657 | "globals": "9.18.0", 658 | "invariant": "2.2.2", 659 | "lodash": "4.17.4" 660 | } 661 | }, 662 | "babel-types": { 663 | "version": "6.26.0", 664 | "resolved": "https://registry.npmjs.org/babel-types/-/babel-types-6.26.0.tgz", 665 | "integrity": "sha1-o7Bz+Uq0nrb6Vc1lInozQ4BjJJc=", 666 | "dev": true, 667 | "requires": { 668 | "babel-runtime": "6.26.0", 669 | "esutils": "2.0.2", 670 | "lodash": "4.17.4", 671 | "to-fast-properties": "1.0.3" 672 | } 673 | }, 674 | "babelrc-rollup": { 675 | "version": "3.0.0", 676 | "resolved": "https://registry.npmjs.org/babelrc-rollup/-/babelrc-rollup-3.0.0.tgz", 677 | "integrity": "sha1-/Ozb4+tkAM9OdpIzwXhqL6/otWw=", 678 | "dev": true, 679 | "requires": { 680 | "resolve": "1.5.0" 681 | } 682 | }, 683 | "babylon": { 684 | "version": "6.18.0", 685 | "resolved": "https://registry.npmjs.org/babylon/-/babylon-6.18.0.tgz", 686 | "integrity": "sha512-q/UEjfGJ2Cm3oKV71DJz9d25TPnq5rhBVL2Q4fA5wcC3jcrdn7+SssEybFIxwAvvP+YCsCYNKughoF33GxgycQ==", 687 | "dev": true 688 | }, 689 | "balanced-match": { 690 | "version": "1.0.0", 691 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz", 692 | "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=", 693 | "dev": true 694 | }, 695 | "bcrypt-pbkdf": { 696 | "version": "1.0.1", 697 | "resolved": "https://registry.npmjs.org/bcrypt-pbkdf/-/bcrypt-pbkdf-1.0.1.tgz", 698 | "integrity": "sha1-Y7xdy2EzG5K8Bf1SiVPDNGKgb40=", 699 | "dev": true, 700 | "optional": true, 701 | "requires": { 702 | "tweetnacl": "0.14.5" 703 | } 704 | }, 705 | "boom": { 706 | "version": "4.3.1", 707 | "resolved": "https://registry.npmjs.org/boom/-/boom-4.3.1.tgz", 708 | "integrity": "sha1-T4owBctKfjiJ90kDD9JbluAdLjE=", 709 | "dev": true, 710 | "requires": { 711 | "hoek": "4.2.0" 712 | } 713 | }, 714 | "brace-expansion": { 715 | "version": "1.1.8", 716 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.8.tgz", 717 | "integrity": "sha1-wHshHHyVLsH479Uad+8NHTmQopI=", 718 | "dev": true, 719 | "requires": { 720 | "balanced-match": "1.0.0", 721 | "concat-map": "0.0.1" 722 | } 723 | }, 724 | "builtin-modules": { 725 | "version": "1.1.1", 726 | "resolved": "https://registry.npmjs.org/builtin-modules/-/builtin-modules-1.1.1.tgz", 727 | "integrity": "sha1-Jw8HbFpywC9bZaR9+Uxf46J4iS8=", 728 | "dev": true 729 | }, 730 | "caller-path": { 731 | "version": "0.1.0", 732 | "resolved": "https://registry.npmjs.org/caller-path/-/caller-path-0.1.0.tgz", 733 | "integrity": "sha1-lAhe9jWB7NPaqSREqP6U6CV3dR8=", 734 | "dev": true, 735 | "requires": { 736 | "callsites": "0.2.0" 737 | } 738 | }, 739 | "callsites": { 740 | "version": "0.2.0", 741 | "resolved": "https://registry.npmjs.org/callsites/-/callsites-0.2.0.tgz", 742 | "integrity": "sha1-r6uWJikQp/M8GaV3WCXGnzTjUMo=", 743 | "dev": true 744 | }, 745 | "caseless": { 746 | "version": "0.12.0", 747 | "resolved": "https://registry.npmjs.org/caseless/-/caseless-0.12.0.tgz", 748 | "integrity": "sha1-G2gcIf+EAzyCZUMJBolCDRhxUdw=", 749 | "dev": true 750 | }, 751 | "chalk": { 752 | "version": "1.1.3", 753 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-1.1.3.tgz", 754 | "integrity": "sha1-qBFcVeSnAv5NFQq9OHKCKn4J/Jg=", 755 | "dev": true, 756 | "requires": { 757 | "ansi-styles": "2.2.1", 758 | "escape-string-regexp": "1.0.5", 759 | "has-ansi": "2.0.0", 760 | "strip-ansi": "3.0.1", 761 | "supports-color": "2.0.0" 762 | } 763 | }, 764 | "chardet": { 765 | "version": "0.4.2", 766 | "resolved": "https://registry.npmjs.org/chardet/-/chardet-0.4.2.tgz", 767 | "integrity": "sha1-tUc7M9yXxCTl2Y3IfVXU2KKci/I=", 768 | "dev": true 769 | }, 770 | "circular-json": { 771 | "version": "0.3.3", 772 | "resolved": "https://registry.npmjs.org/circular-json/-/circular-json-0.3.3.tgz", 773 | "integrity": "sha512-UZK3NBx2Mca+b5LsG7bY183pHWt5Y1xts4P3Pz7ENTwGVnJOUWbRb3ocjvX7hx9tq/yTAdclXm9sZ38gNuem4A==", 774 | "dev": true 775 | }, 776 | "cli-width": { 777 | "version": "2.2.0", 778 | "resolved": "https://registry.npmjs.org/cli-width/-/cli-width-2.2.0.tgz", 779 | "integrity": "sha1-/xnt6Kml5XkyQUewwR8PvLq+1jk=", 780 | "dev": true 781 | }, 782 | "co": { 783 | "version": "4.6.0", 784 | "resolved": "https://registry.npmjs.org/co/-/co-4.6.0.tgz", 785 | "integrity": "sha1-bqa989hTrlTMuOR7+gvz+QMfsYQ=", 786 | "dev": true 787 | }, 788 | "color-convert": { 789 | "version": "1.9.1", 790 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.1.tgz", 791 | "integrity": "sha512-mjGanIiwQJskCC18rPR6OmrZ6fm2Lc7PeGFYwCmy5J34wC6F1PzdGL6xeMfmgicfYcNLGuVFA3WzXtIDCQSZxQ==", 792 | "dev": true, 793 | "requires": { 794 | "color-name": "1.1.3" 795 | } 796 | }, 797 | "color-name": { 798 | "version": "1.1.3", 799 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 800 | "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=", 801 | "dev": true 802 | }, 803 | "combined-stream": { 804 | "version": "1.0.5", 805 | "resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.5.tgz", 806 | "integrity": "sha1-k4NwpXtKUd6ix3wV1cX9+JUWQAk=", 807 | "dev": true, 808 | "requires": { 809 | "delayed-stream": "1.0.0" 810 | } 811 | }, 812 | "commander": { 813 | "version": "2.12.2", 814 | "resolved": "https://registry.npmjs.org/commander/-/commander-2.12.2.tgz", 815 | "integrity": "sha512-BFnaq5ZOGcDN7FlrtBT4xxkgIToalIIxwjxLWVJ8bGTpe1LroqMiqQXdA7ygc7CRvaYS+9zfPGFnJqFSayx+AA==", 816 | "dev": true 817 | }, 818 | "concat-map": { 819 | "version": "0.0.1", 820 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 821 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=", 822 | "dev": true 823 | }, 824 | "concat-stream": { 825 | "version": "1.6.0", 826 | "resolved": "https://registry.npmjs.org/concat-stream/-/concat-stream-1.6.0.tgz", 827 | "integrity": "sha1-CqxmL9Ur54lk1VMvaUeE5wEQrPc=", 828 | "dev": true, 829 | "requires": { 830 | "inherits": "2.0.3", 831 | "readable-stream": "2.3.3", 832 | "typedarray": "0.0.6" 833 | } 834 | }, 835 | "contains-path": { 836 | "version": "0.1.0", 837 | "resolved": "https://registry.npmjs.org/contains-path/-/contains-path-0.1.0.tgz", 838 | "integrity": "sha1-/ozxhP9mcLa67wGp1IYaXL7EEgo=", 839 | "dev": true 840 | }, 841 | "content-type-parser": { 842 | "version": "1.0.2", 843 | "resolved": "https://registry.npmjs.org/content-type-parser/-/content-type-parser-1.0.2.tgz", 844 | "integrity": "sha512-lM4l4CnMEwOLHAHr/P6MEZwZFPJFtAAKgL6pogbXmVZggIqXhdB6RbBtPOTsw2FcXwYhehRGERJmRrjOiIB8pQ==", 845 | "dev": true 846 | }, 847 | "convert-source-map": { 848 | "version": "1.5.1", 849 | "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-1.5.1.tgz", 850 | "integrity": "sha1-uCeAl7m8IpNl3lxiz1/K7YtVmeU=", 851 | "dev": true 852 | }, 853 | "core-js": { 854 | "version": "2.5.3", 855 | "resolved": "https://registry.npmjs.org/core-js/-/core-js-2.5.3.tgz", 856 | "integrity": "sha1-isw4NFgk8W2DZbfJtCWRaOjtYD4=", 857 | "dev": true 858 | }, 859 | "core-util-is": { 860 | "version": "1.0.2", 861 | "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.2.tgz", 862 | "integrity": "sha1-tf1UIgqivFq1eqtxQMlAdUUDwac=", 863 | "dev": true 864 | }, 865 | "cross-spawn": { 866 | "version": "5.1.0", 867 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-5.1.0.tgz", 868 | "integrity": "sha1-6L0O/uWPz/b4+UUQoKVUu/ojVEk=", 869 | "dev": true, 870 | "requires": { 871 | "lru-cache": "4.1.1", 872 | "shebang-command": "1.2.0", 873 | "which": "1.3.0" 874 | } 875 | }, 876 | "cryptiles": { 877 | "version": "3.1.2", 878 | "resolved": "https://registry.npmjs.org/cryptiles/-/cryptiles-3.1.2.tgz", 879 | "integrity": "sha1-qJ+7Ig9c4l7FboxKqKT9e1sNKf4=", 880 | "dev": true, 881 | "requires": { 882 | "boom": "5.2.0" 883 | }, 884 | "dependencies": { 885 | "boom": { 886 | "version": "5.2.0", 887 | "resolved": "https://registry.npmjs.org/boom/-/boom-5.2.0.tgz", 888 | "integrity": "sha512-Z5BTk6ZRe4tXXQlkqftmsAUANpXmuwlsF5Oov8ThoMbQRzdGTA1ngYRW160GexgOgjsFOKJz0LYhoNi+2AMBUw==", 889 | "dev": true, 890 | "requires": { 891 | "hoek": "4.2.0" 892 | } 893 | } 894 | } 895 | }, 896 | "cssom": { 897 | "version": "0.3.2", 898 | "resolved": "https://registry.npmjs.org/cssom/-/cssom-0.3.2.tgz", 899 | "integrity": "sha1-uANhcMefB6kP8vFuIihAJ6JDhIs=", 900 | "dev": true 901 | }, 902 | "cssstyle": { 903 | "version": "0.2.37", 904 | "resolved": "https://registry.npmjs.org/cssstyle/-/cssstyle-0.2.37.tgz", 905 | "integrity": "sha1-VBCXI0yyUTyDzu06zdwn/yeYfVQ=", 906 | "dev": true, 907 | "requires": { 908 | "cssom": "0.3.2" 909 | } 910 | }, 911 | "d3-color": { 912 | "version": "1.0.3", 913 | "resolved": "https://registry.npmjs.org/d3-color/-/d3-color-1.0.3.tgz", 914 | "integrity": "sha1-vHZD/KjlOoNH4vva/6I2eWtYUJs=", 915 | "dev": true 916 | }, 917 | "d3-dispatch": { 918 | "version": "1.0.3", 919 | "resolved": "https://registry.npmjs.org/d3-dispatch/-/d3-dispatch-1.0.3.tgz", 920 | "integrity": "sha1-RuFJHqqbWMNY/OW+TovtYm54cfg=", 921 | "dev": true 922 | }, 923 | "d3-ease": { 924 | "version": "1.0.3", 925 | "resolved": "https://registry.npmjs.org/d3-ease/-/d3-ease-1.0.3.tgz", 926 | "integrity": "sha1-aL+8NJM4o4DETYrMT7wzBKotjA4=", 927 | "dev": true 928 | }, 929 | "d3-interpolate": { 930 | "version": "1.1.6", 931 | "resolved": "https://registry.npmjs.org/d3-interpolate/-/d3-interpolate-1.1.6.tgz", 932 | "integrity": "sha512-mOnv5a+pZzkNIHtw/V6I+w9Lqm9L5bG3OTXPM5A+QO0yyVMQ4W1uZhR+VOJmazaOZXri2ppbiZ5BUNWT0pFM9A==", 933 | "dev": true, 934 | "requires": { 935 | "d3-color": "1.0.3" 936 | } 937 | }, 938 | "d3-selection": { 939 | "version": "1.2.0", 940 | "resolved": "https://registry.npmjs.org/d3-selection/-/d3-selection-1.2.0.tgz", 941 | "integrity": "sha512-xW2Pfcdzh1gOaoI+LGpPsLR2VpBQxuFoxvrvguK8ZmrJbPIVvfNG6pU6GNfK41D6Qz15sj61sbW/AFYuukwaLQ==" 942 | }, 943 | "d3-timer": { 944 | "version": "1.0.7", 945 | "resolved": "https://registry.npmjs.org/d3-timer/-/d3-timer-1.0.7.tgz", 946 | "integrity": "sha512-vMZXR88XujmG/L5oB96NNKH5lCWwiLM/S2HyyAQLcjWJCloK5shxta4CwOFYLZoY3AWX73v8Lgv4cCAdWtRmOA==", 947 | "dev": true 948 | }, 949 | "d3-transition": { 950 | "version": "1.1.1", 951 | "resolved": "https://registry.npmjs.org/d3-transition/-/d3-transition-1.1.1.tgz", 952 | "integrity": "sha512-xeg8oggyQ+y5eb4J13iDgKIjUcEfIOZs2BqV/eEmXm2twx80wTzJ4tB4vaZ5BKfz7XsI/DFmQL5me6O27/5ykQ==", 953 | "dev": true, 954 | "requires": { 955 | "d3-color": "1.0.3", 956 | "d3-dispatch": "1.0.3", 957 | "d3-ease": "1.0.3", 958 | "d3-interpolate": "1.1.6", 959 | "d3-selection": "1.2.0", 960 | "d3-timer": "1.0.7" 961 | } 962 | }, 963 | "dashdash": { 964 | "version": "1.14.1", 965 | "resolved": "https://registry.npmjs.org/dashdash/-/dashdash-1.14.1.tgz", 966 | "integrity": "sha1-hTz6D3y+L+1d4gMmuN1YEDX24vA=", 967 | "dev": true, 968 | "requires": { 969 | "assert-plus": "1.0.0" 970 | } 971 | }, 972 | "debug": { 973 | "version": "2.6.9", 974 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 975 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 976 | "dev": true, 977 | "requires": { 978 | "ms": "2.0.0" 979 | } 980 | }, 981 | "deep-equal": { 982 | "version": "1.0.1", 983 | "resolved": "https://registry.npmjs.org/deep-equal/-/deep-equal-1.0.1.tgz", 984 | "integrity": "sha1-9dJgKStmDghO/0zbyfCK0yR0SLU=", 985 | "dev": true 986 | }, 987 | "deep-is": { 988 | "version": "0.1.3", 989 | "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.3.tgz", 990 | "integrity": "sha1-s2nW+128E+7PUk+RsHD+7cNXzzQ=", 991 | "dev": true 992 | }, 993 | "define-properties": { 994 | "version": "1.1.2", 995 | "resolved": "https://registry.npmjs.org/define-properties/-/define-properties-1.1.2.tgz", 996 | "integrity": "sha1-g6c/L+pWmJj7c3GTyPhzyvbUXJQ=", 997 | "dev": true, 998 | "requires": { 999 | "foreach": "2.0.5", 1000 | "object-keys": "1.0.11" 1001 | } 1002 | }, 1003 | "defined": { 1004 | "version": "1.0.0", 1005 | "resolved": "https://registry.npmjs.org/defined/-/defined-1.0.0.tgz", 1006 | "integrity": "sha1-yY2bzvdWdBiOEQlpFRGZ45sfppM=", 1007 | "dev": true 1008 | }, 1009 | "del": { 1010 | "version": "2.2.2", 1011 | "resolved": "https://registry.npmjs.org/del/-/del-2.2.2.tgz", 1012 | "integrity": "sha1-wSyYHQZ4RshLyvhiz/kw2Qf/0ag=", 1013 | "dev": true, 1014 | "requires": { 1015 | "globby": "5.0.0", 1016 | "is-path-cwd": "1.0.0", 1017 | "is-path-in-cwd": "1.0.0", 1018 | "object-assign": "4.1.1", 1019 | "pify": "2.3.0", 1020 | "pinkie-promise": "2.0.1", 1021 | "rimraf": "2.6.2" 1022 | } 1023 | }, 1024 | "delayed-stream": { 1025 | "version": "1.0.0", 1026 | "resolved": "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz", 1027 | "integrity": "sha1-3zrhmayt+31ECqrgsp4icrJOxhk=", 1028 | "dev": true 1029 | }, 1030 | "detect-indent": { 1031 | "version": "4.0.0", 1032 | "resolved": "https://registry.npmjs.org/detect-indent/-/detect-indent-4.0.0.tgz", 1033 | "integrity": "sha1-920GQ1LN9Docts5hnE7jqUdd4gg=", 1034 | "dev": true, 1035 | "requires": { 1036 | "repeating": "2.0.1" 1037 | } 1038 | }, 1039 | "doctrine": { 1040 | "version": "2.0.2", 1041 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-2.0.2.tgz", 1042 | "integrity": "sha512-y0tm5Pq6ywp3qSTZ1vPgVdAnbDEoeoc5wlOHXoY1c4Wug/a7JvqHIl7BTvwodaHmejWkK/9dSb3sCYfyo/om8A==", 1043 | "dev": true, 1044 | "requires": { 1045 | "esutils": "2.0.2" 1046 | } 1047 | }, 1048 | "ecc-jsbn": { 1049 | "version": "0.1.1", 1050 | "resolved": "https://registry.npmjs.org/ecc-jsbn/-/ecc-jsbn-0.1.1.tgz", 1051 | "integrity": "sha1-D8c6ntXw1Tw4GTOYUj735UN3dQU=", 1052 | "dev": true, 1053 | "optional": true, 1054 | "requires": { 1055 | "jsbn": "0.1.1" 1056 | } 1057 | }, 1058 | "error-ex": { 1059 | "version": "1.3.1", 1060 | "resolved": "https://registry.npmjs.org/error-ex/-/error-ex-1.3.1.tgz", 1061 | "integrity": "sha1-+FWobOYa3E6GIcPNoh56dhLDqNw=", 1062 | "dev": true, 1063 | "requires": { 1064 | "is-arrayish": "0.2.1" 1065 | } 1066 | }, 1067 | "es-abstract": { 1068 | "version": "1.10.0", 1069 | "resolved": "https://registry.npmjs.org/es-abstract/-/es-abstract-1.10.0.tgz", 1070 | "integrity": "sha512-/uh/DhdqIOSkAWifU+8nG78vlQxdLckUdI/sPgy0VhuXi2qJ7T8czBmqIYtLQVpCIFYafChnsRsB5pyb1JdmCQ==", 1071 | "dev": true, 1072 | "requires": { 1073 | "es-to-primitive": "1.1.1", 1074 | "function-bind": "1.1.1", 1075 | "has": "1.0.1", 1076 | "is-callable": "1.1.3", 1077 | "is-regex": "1.0.4" 1078 | } 1079 | }, 1080 | "es-to-primitive": { 1081 | "version": "1.1.1", 1082 | "resolved": "https://registry.npmjs.org/es-to-primitive/-/es-to-primitive-1.1.1.tgz", 1083 | "integrity": "sha1-RTVSSKiJeQNLZ5Lhm7gfK3l13Q0=", 1084 | "dev": true, 1085 | "requires": { 1086 | "is-callable": "1.1.3", 1087 | "is-date-object": "1.0.1", 1088 | "is-symbol": "1.0.1" 1089 | } 1090 | }, 1091 | "escape-string-regexp": { 1092 | "version": "1.0.5", 1093 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", 1094 | "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=", 1095 | "dev": true 1096 | }, 1097 | "escodegen": { 1098 | "version": "1.9.0", 1099 | "resolved": "https://registry.npmjs.org/escodegen/-/escodegen-1.9.0.tgz", 1100 | "integrity": "sha512-v0MYvNQ32bzwoG2OSFzWAkuahDQHK92JBN0pTAALJ4RIxEZe766QJPDR8Hqy7XNUy5K3fnVL76OqYAdc4TZEIw==", 1101 | "dev": true, 1102 | "requires": { 1103 | "esprima": "3.1.3", 1104 | "estraverse": "4.2.0", 1105 | "esutils": "2.0.2", 1106 | "optionator": "0.8.2", 1107 | "source-map": "0.5.7" 1108 | }, 1109 | "dependencies": { 1110 | "esprima": { 1111 | "version": "3.1.3", 1112 | "resolved": "https://registry.npmjs.org/esprima/-/esprima-3.1.3.tgz", 1113 | "integrity": "sha1-/cpRzuYTOJXjyI1TXOSdv/YqRjM=", 1114 | "dev": true 1115 | } 1116 | } 1117 | }, 1118 | "eslint": { 1119 | "version": "4.13.1", 1120 | "resolved": "https://registry.npmjs.org/eslint/-/eslint-4.13.1.tgz", 1121 | "integrity": "sha512-UCJVV50RtLHYzBp1DZ8CMPtRSg4iVZvjgO9IJHIKyWU/AnJVjtdRikoUPLB29n5pzMB7TnsLQWf0V6VUJfoPfw==", 1122 | "dev": true, 1123 | "requires": { 1124 | "ajv": "5.5.1", 1125 | "babel-code-frame": "6.26.0", 1126 | "chalk": "2.3.0", 1127 | "concat-stream": "1.6.0", 1128 | "cross-spawn": "5.1.0", 1129 | "debug": "3.1.0", 1130 | "doctrine": "2.0.2", 1131 | "eslint-scope": "3.7.1", 1132 | "espree": "3.5.2", 1133 | "esquery": "1.0.0", 1134 | "estraverse": "4.2.0", 1135 | "esutils": "2.0.2", 1136 | "file-entry-cache": "2.0.0", 1137 | "functional-red-black-tree": "1.0.1", 1138 | "glob": "7.1.2", 1139 | "globals": "11.1.0", 1140 | "ignore": "3.3.7", 1141 | "imurmurhash": "0.1.4", 1142 | "inquirer": "3.3.0", 1143 | "is-resolvable": "1.0.1", 1144 | "js-yaml": "3.10.0", 1145 | "json-stable-stringify-without-jsonify": "1.0.1", 1146 | "levn": "0.3.0", 1147 | "lodash": "4.17.4", 1148 | "minimatch": "3.0.4", 1149 | "mkdirp": "0.5.1", 1150 | "natural-compare": "1.4.0", 1151 | "optionator": "0.8.2", 1152 | "path-is-inside": "1.0.2", 1153 | "pluralize": "7.0.0", 1154 | "progress": "2.0.0", 1155 | "require-uncached": "1.0.3", 1156 | "semver": "5.4.1", 1157 | "strip-ansi": "4.0.0", 1158 | "strip-json-comments": "2.0.1", 1159 | "table": "4.0.2", 1160 | "text-table": "0.2.0" 1161 | }, 1162 | "dependencies": { 1163 | "ajv": { 1164 | "version": "5.5.1", 1165 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-5.5.1.tgz", 1166 | "integrity": "sha1-s4u4h22ehr7plJVqBOch6IskjrI=", 1167 | "dev": true, 1168 | "requires": { 1169 | "co": "4.6.0", 1170 | "fast-deep-equal": "1.0.0", 1171 | "fast-json-stable-stringify": "2.0.0", 1172 | "json-schema-traverse": "0.3.1" 1173 | } 1174 | }, 1175 | "ajv-keywords": { 1176 | "version": "2.1.1", 1177 | "resolved": "https://registry.npmjs.org/ajv-keywords/-/ajv-keywords-2.1.1.tgz", 1178 | "integrity": "sha1-YXmX/F9gV2iUxDX5QNgZ4TW4B2I=", 1179 | "dev": true 1180 | }, 1181 | "ansi-escapes": { 1182 | "version": "3.0.0", 1183 | "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-3.0.0.tgz", 1184 | "integrity": "sha512-O/klc27mWNUigtv0F8NJWbLF00OcegQalkqKURWdosW08YZKi4m6CnSUSvIZG1otNJbTWhN01Hhz389DW7mvDQ==", 1185 | "dev": true 1186 | }, 1187 | "ansi-regex": { 1188 | "version": "3.0.0", 1189 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-3.0.0.tgz", 1190 | "integrity": "sha1-7QMXwyIGT3lGbAKWa922Bas32Zg=", 1191 | "dev": true 1192 | }, 1193 | "ansi-styles": { 1194 | "version": "3.2.0", 1195 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.0.tgz", 1196 | "integrity": "sha512-NnSOmMEYtVR2JVMIGTzynRkkaxtiq1xnFBcdQD/DnNCYPoEPsVJhM98BDyaoNOQIi7p4okdi3E27eN7GQbsUug==", 1197 | "dev": true, 1198 | "requires": { 1199 | "color-convert": "1.9.1" 1200 | } 1201 | }, 1202 | "chalk": { 1203 | "version": "2.3.0", 1204 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.3.0.tgz", 1205 | "integrity": "sha512-Az5zJR2CBujap2rqXGaJKaPHyJ0IrUimvYNX+ncCy8PJP4ltOGTrHUIo097ZaL2zMeKYpiCdqDvS6zdrTFok3Q==", 1206 | "dev": true, 1207 | "requires": { 1208 | "ansi-styles": "3.2.0", 1209 | "escape-string-regexp": "1.0.5", 1210 | "supports-color": "4.5.0" 1211 | } 1212 | }, 1213 | "cli-cursor": { 1214 | "version": "2.1.0", 1215 | "resolved": "https://registry.npmjs.org/cli-cursor/-/cli-cursor-2.1.0.tgz", 1216 | "integrity": "sha1-s12sN2R5+sw+lHR9QdDQ9SOP/LU=", 1217 | "dev": true, 1218 | "requires": { 1219 | "restore-cursor": "2.0.0" 1220 | } 1221 | }, 1222 | "debug": { 1223 | "version": "3.1.0", 1224 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.1.0.tgz", 1225 | "integrity": "sha512-OX8XqP7/1a9cqkxYw2yXss15f26NKWBpDXQd0/uK/KPqdQhxbPa994hnzjcE2VqQpDslf55723cKPUOGSmMY3g==", 1226 | "dev": true, 1227 | "requires": { 1228 | "ms": "2.0.0" 1229 | } 1230 | }, 1231 | "figures": { 1232 | "version": "2.0.0", 1233 | "resolved": "https://registry.npmjs.org/figures/-/figures-2.0.0.tgz", 1234 | "integrity": "sha1-OrGi0qYsi/tDGgyUy3l6L84nyWI=", 1235 | "dev": true, 1236 | "requires": { 1237 | "escape-string-regexp": "1.0.5" 1238 | } 1239 | }, 1240 | "globals": { 1241 | "version": "11.1.0", 1242 | "resolved": "https://registry.npmjs.org/globals/-/globals-11.1.0.tgz", 1243 | "integrity": "sha512-uEuWt9mqTlPDwSqi+sHjD4nWU/1N+q0fiWI9T1mZpD2UENqX20CFD5T/ziLZvztPaBKl7ZylUi1q6Qfm7E2CiQ==", 1244 | "dev": true 1245 | }, 1246 | "inquirer": { 1247 | "version": "3.3.0", 1248 | "resolved": "https://registry.npmjs.org/inquirer/-/inquirer-3.3.0.tgz", 1249 | "integrity": "sha512-h+xtnyk4EwKvFWHrUYsWErEVR+igKtLdchu+o0Z1RL7VU/jVMFbYir2bp6bAj8efFNxWqHX0dIss6fJQ+/+qeQ==", 1250 | "dev": true, 1251 | "requires": { 1252 | "ansi-escapes": "3.0.0", 1253 | "chalk": "2.3.0", 1254 | "cli-cursor": "2.1.0", 1255 | "cli-width": "2.2.0", 1256 | "external-editor": "2.1.0", 1257 | "figures": "2.0.0", 1258 | "lodash": "4.17.4", 1259 | "mute-stream": "0.0.7", 1260 | "run-async": "2.3.0", 1261 | "rx-lite": "4.0.8", 1262 | "rx-lite-aggregates": "4.0.8", 1263 | "string-width": "2.1.1", 1264 | "strip-ansi": "4.0.0", 1265 | "through": "2.3.8" 1266 | } 1267 | }, 1268 | "is-fullwidth-code-point": { 1269 | "version": "2.0.0", 1270 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", 1271 | "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=", 1272 | "dev": true 1273 | }, 1274 | "mute-stream": { 1275 | "version": "0.0.7", 1276 | "resolved": "https://registry.npmjs.org/mute-stream/-/mute-stream-0.0.7.tgz", 1277 | "integrity": "sha1-MHXOk7whuPq0PhvE2n6BFe0ee6s=", 1278 | "dev": true 1279 | }, 1280 | "onetime": { 1281 | "version": "2.0.1", 1282 | "resolved": "https://registry.npmjs.org/onetime/-/onetime-2.0.1.tgz", 1283 | "integrity": "sha1-BnQoIw/WdEOyeUsiu6UotoZ5YtQ=", 1284 | "dev": true, 1285 | "requires": { 1286 | "mimic-fn": "1.1.0" 1287 | } 1288 | }, 1289 | "pluralize": { 1290 | "version": "7.0.0", 1291 | "resolved": "https://registry.npmjs.org/pluralize/-/pluralize-7.0.0.tgz", 1292 | "integrity": "sha512-ARhBOdzS3e41FbkW/XWrTEtukqqLoK5+Z/4UeDaLuSW+39JPeFgs4gCGqsrJHVZX0fUrx//4OF0K1CUGwlIFow==", 1293 | "dev": true 1294 | }, 1295 | "progress": { 1296 | "version": "2.0.0", 1297 | "resolved": "https://registry.npmjs.org/progress/-/progress-2.0.0.tgz", 1298 | "integrity": "sha1-ihvjZr+Pwj2yvSPxDG/pILQ4nR8=", 1299 | "dev": true 1300 | }, 1301 | "restore-cursor": { 1302 | "version": "2.0.0", 1303 | "resolved": "https://registry.npmjs.org/restore-cursor/-/restore-cursor-2.0.0.tgz", 1304 | "integrity": "sha1-n37ih/gv0ybU/RYpI9YhKe7g368=", 1305 | "dev": true, 1306 | "requires": { 1307 | "onetime": "2.0.1", 1308 | "signal-exit": "3.0.2" 1309 | } 1310 | }, 1311 | "run-async": { 1312 | "version": "2.3.0", 1313 | "resolved": "https://registry.npmjs.org/run-async/-/run-async-2.3.0.tgz", 1314 | "integrity": "sha1-A3GrSuC91yDUFm19/aZP96RFpsA=", 1315 | "dev": true, 1316 | "requires": { 1317 | "is-promise": "2.1.0" 1318 | } 1319 | }, 1320 | "rx-lite": { 1321 | "version": "4.0.8", 1322 | "resolved": "https://registry.npmjs.org/rx-lite/-/rx-lite-4.0.8.tgz", 1323 | "integrity": "sha1-Cx4Rr4vESDbwSmQH6S2kJGe3lEQ=", 1324 | "dev": true 1325 | }, 1326 | "slice-ansi": { 1327 | "version": "1.0.0", 1328 | "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-1.0.0.tgz", 1329 | "integrity": "sha512-POqxBK6Lb3q6s047D/XsDVNPnF9Dl8JSaqe9h9lURl0OdNqy/ujDrOiIHtsqXMGbWWTIomRzAMaTyawAU//Reg==", 1330 | "dev": true, 1331 | "requires": { 1332 | "is-fullwidth-code-point": "2.0.0" 1333 | } 1334 | }, 1335 | "string-width": { 1336 | "version": "2.1.1", 1337 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-2.1.1.tgz", 1338 | "integrity": "sha512-nOqH59deCq9SRHlxq1Aw85Jnt4w6KvLKqWVik6oA9ZklXLNIOlqg4F2yrT1MVaTjAqvVwdfeZ7w7aCvJD7ugkw==", 1339 | "dev": true, 1340 | "requires": { 1341 | "is-fullwidth-code-point": "2.0.0", 1342 | "strip-ansi": "4.0.0" 1343 | } 1344 | }, 1345 | "strip-ansi": { 1346 | "version": "4.0.0", 1347 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-4.0.0.tgz", 1348 | "integrity": "sha1-qEeQIusaw2iocTibY1JixQXuNo8=", 1349 | "dev": true, 1350 | "requires": { 1351 | "ansi-regex": "3.0.0" 1352 | } 1353 | }, 1354 | "supports-color": { 1355 | "version": "4.5.0", 1356 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-4.5.0.tgz", 1357 | "integrity": "sha1-vnoN5ITexcXN34s9WRJQRJEvY1s=", 1358 | "dev": true, 1359 | "requires": { 1360 | "has-flag": "2.0.0" 1361 | } 1362 | }, 1363 | "table": { 1364 | "version": "4.0.2", 1365 | "resolved": "https://registry.npmjs.org/table/-/table-4.0.2.tgz", 1366 | "integrity": "sha512-UUkEAPdSGxtRpiV9ozJ5cMTtYiqz7Ni1OGqLXRCynrvzdtR1p+cfOWe2RJLwvUG8hNanaSRjecIqwOjqeatDsA==", 1367 | "dev": true, 1368 | "requires": { 1369 | "ajv": "5.5.1", 1370 | "ajv-keywords": "2.1.1", 1371 | "chalk": "2.3.0", 1372 | "lodash": "4.17.4", 1373 | "slice-ansi": "1.0.0", 1374 | "string-width": "2.1.1" 1375 | } 1376 | } 1377 | } 1378 | }, 1379 | "eslint-config-airbnb-base": { 1380 | "version": "12.1.0", 1381 | "resolved": "https://registry.npmjs.org/eslint-config-airbnb-base/-/eslint-config-airbnb-base-12.1.0.tgz", 1382 | "integrity": "sha512-/vjm0Px5ZCpmJqnjIzcFb9TKZrKWz0gnuG/7Gfkt0Db1ELJR51xkZth+t14rYdqWgX836XbuxtArbIHlVhbLBA==", 1383 | "dev": true, 1384 | "requires": { 1385 | "eslint-restricted-globals": "0.1.1" 1386 | } 1387 | }, 1388 | "eslint-import-resolver-node": { 1389 | "version": "0.3.1", 1390 | "resolved": "https://registry.npmjs.org/eslint-import-resolver-node/-/eslint-import-resolver-node-0.3.1.tgz", 1391 | "integrity": "sha512-yUtXS15gIcij68NmXmP9Ni77AQuCN0itXbCc/jWd8C6/yKZaSNXicpC8cgvjnxVdmfsosIXrjpzFq7GcDryb6A==", 1392 | "dev": true, 1393 | "requires": { 1394 | "debug": "2.6.9", 1395 | "resolve": "1.5.0" 1396 | } 1397 | }, 1398 | "eslint-module-utils": { 1399 | "version": "2.1.1", 1400 | "resolved": "https://registry.npmjs.org/eslint-module-utils/-/eslint-module-utils-2.1.1.tgz", 1401 | "integrity": "sha512-jDI/X5l/6D1rRD/3T43q8Qgbls2nq5km5KSqiwlyUbGo5+04fXhMKdCPhjwbqAa6HXWaMxj8Q4hQDIh7IadJQw==", 1402 | "dev": true, 1403 | "requires": { 1404 | "debug": "2.6.9", 1405 | "pkg-dir": "1.0.0" 1406 | } 1407 | }, 1408 | "eslint-plugin-import": { 1409 | "version": "2.8.0", 1410 | "resolved": "https://registry.npmjs.org/eslint-plugin-import/-/eslint-plugin-import-2.8.0.tgz", 1411 | "integrity": "sha512-Rf7dfKJxZ16QuTgVv1OYNxkZcsu/hULFnC+e+w0Gzi6jMC3guQoWQgxYxc54IDRinlb6/0v5z/PxxIKmVctN+g==", 1412 | "dev": true, 1413 | "requires": { 1414 | "builtin-modules": "1.1.1", 1415 | "contains-path": "0.1.0", 1416 | "debug": "2.6.9", 1417 | "doctrine": "1.5.0", 1418 | "eslint-import-resolver-node": "0.3.1", 1419 | "eslint-module-utils": "2.1.1", 1420 | "has": "1.0.1", 1421 | "lodash.cond": "4.5.2", 1422 | "minimatch": "3.0.4", 1423 | "read-pkg-up": "2.0.0" 1424 | }, 1425 | "dependencies": { 1426 | "doctrine": { 1427 | "version": "1.5.0", 1428 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-1.5.0.tgz", 1429 | "integrity": "sha1-N53Ocw9hZvds76TmcHoVmwLFpvo=", 1430 | "dev": true, 1431 | "requires": { 1432 | "esutils": "2.0.2", 1433 | "isarray": "1.0.0" 1434 | } 1435 | } 1436 | } 1437 | }, 1438 | "eslint-restricted-globals": { 1439 | "version": "0.1.1", 1440 | "resolved": "https://registry.npmjs.org/eslint-restricted-globals/-/eslint-restricted-globals-0.1.1.tgz", 1441 | "integrity": "sha1-NfDVy8ZMLj7WLpO0saevBbp+1Nc=", 1442 | "dev": true 1443 | }, 1444 | "eslint-scope": { 1445 | "version": "3.7.1", 1446 | "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-3.7.1.tgz", 1447 | "integrity": "sha1-PWPD7f2gLgbgGkUq2IyqzHzctug=", 1448 | "dev": true, 1449 | "requires": { 1450 | "esrecurse": "4.2.0", 1451 | "estraverse": "4.2.0" 1452 | } 1453 | }, 1454 | "espree": { 1455 | "version": "3.5.2", 1456 | "resolved": "https://registry.npmjs.org/espree/-/espree-3.5.2.tgz", 1457 | "integrity": "sha512-sadKeYwaR/aJ3stC2CdvgXu1T16TdYN+qwCpcWbMnGJ8s0zNWemzrvb2GbD4OhmJ/fwpJjudThAlLobGbWZbCQ==", 1458 | "dev": true, 1459 | "requires": { 1460 | "acorn": "5.2.1", 1461 | "acorn-jsx": "3.0.1" 1462 | } 1463 | }, 1464 | "esprima": { 1465 | "version": "4.0.0", 1466 | "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.0.tgz", 1467 | "integrity": "sha512-oftTcaMu/EGrEIu904mWteKIv8vMuOgGYo7EhVJJN00R/EED9DCua/xxHRdYnKtcECzVg7xOWhflvJMnqcFZjw==", 1468 | "dev": true 1469 | }, 1470 | "esquery": { 1471 | "version": "1.0.0", 1472 | "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.0.0.tgz", 1473 | "integrity": "sha1-z7qLV9f7qT8XKYqKAGoEzaE9gPo=", 1474 | "dev": true, 1475 | "requires": { 1476 | "estraverse": "4.2.0" 1477 | } 1478 | }, 1479 | "esrecurse": { 1480 | "version": "4.2.0", 1481 | "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.2.0.tgz", 1482 | "integrity": "sha1-+pVo2Y04I/mkHZHpAtyrnqblsWM=", 1483 | "dev": true, 1484 | "requires": { 1485 | "estraverse": "4.2.0", 1486 | "object-assign": "4.1.1" 1487 | } 1488 | }, 1489 | "estraverse": { 1490 | "version": "4.2.0", 1491 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-4.2.0.tgz", 1492 | "integrity": "sha1-De4/7TH81GlhjOc0IJn8GvoL2xM=", 1493 | "dev": true 1494 | }, 1495 | "estree-walker": { 1496 | "version": "0.2.1", 1497 | "resolved": "https://registry.npmjs.org/estree-walker/-/estree-walker-0.2.1.tgz", 1498 | "integrity": "sha1-va/oCVOD2EFNXcLs9MkXO225QS4=", 1499 | "dev": true 1500 | }, 1501 | "esutils": { 1502 | "version": "2.0.2", 1503 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.2.tgz", 1504 | "integrity": "sha1-Cr9PHKpbyx96nYrMbepPqqBLrJs=", 1505 | "dev": true 1506 | }, 1507 | "extend": { 1508 | "version": "3.0.1", 1509 | "resolved": "https://registry.npmjs.org/extend/-/extend-3.0.1.tgz", 1510 | "integrity": "sha1-p1Xqe8Gt/MWjHOfnYtuq3F5jZEQ=", 1511 | "dev": true 1512 | }, 1513 | "external-editor": { 1514 | "version": "2.1.0", 1515 | "resolved": "https://registry.npmjs.org/external-editor/-/external-editor-2.1.0.tgz", 1516 | "integrity": "sha512-E44iT5QVOUJBKij4IIV3uvxuNlbKS38Tw1HiupxEIHPv9qtC2PrDYohbXV5U+1jnfIXttny8gUhj+oZvflFlzA==", 1517 | "dev": true, 1518 | "requires": { 1519 | "chardet": "0.4.2", 1520 | "iconv-lite": "0.4.19", 1521 | "tmp": "0.0.33" 1522 | } 1523 | }, 1524 | "extsprintf": { 1525 | "version": "1.3.0", 1526 | "resolved": "https://registry.npmjs.org/extsprintf/-/extsprintf-1.3.0.tgz", 1527 | "integrity": "sha1-lpGEQOMEGnpBT4xS48V06zw+HgU=", 1528 | "dev": true 1529 | }, 1530 | "fast-deep-equal": { 1531 | "version": "1.0.0", 1532 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-1.0.0.tgz", 1533 | "integrity": "sha1-liVqO8l1WV6zbYLpkp0GDYk0Of8=", 1534 | "dev": true 1535 | }, 1536 | "fast-json-stable-stringify": { 1537 | "version": "2.0.0", 1538 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.0.0.tgz", 1539 | "integrity": "sha1-1RQsDK7msRifh9OnYREGT4bIu/I=", 1540 | "dev": true 1541 | }, 1542 | "fast-levenshtein": { 1543 | "version": "2.0.6", 1544 | "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", 1545 | "integrity": "sha1-PYpcZog6FqMMqGQ+hR8Zuqd5eRc=", 1546 | "dev": true 1547 | }, 1548 | "file-entry-cache": { 1549 | "version": "2.0.0", 1550 | "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-2.0.0.tgz", 1551 | "integrity": "sha1-w5KZDD5oR4PYOLjISkXYoEhFg2E=", 1552 | "dev": true, 1553 | "requires": { 1554 | "flat-cache": "1.3.0", 1555 | "object-assign": "4.1.1" 1556 | } 1557 | }, 1558 | "find-up": { 1559 | "version": "1.1.2", 1560 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-1.1.2.tgz", 1561 | "integrity": "sha1-ay6YIrGizgpgq2TWEOzK1TyyTQ8=", 1562 | "dev": true, 1563 | "requires": { 1564 | "path-exists": "2.1.0", 1565 | "pinkie-promise": "2.0.1" 1566 | } 1567 | }, 1568 | "flat-cache": { 1569 | "version": "1.3.0", 1570 | "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-1.3.0.tgz", 1571 | "integrity": "sha1-0wMLMrOBVPTjt+nHCfSQ9++XxIE=", 1572 | "dev": true, 1573 | "requires": { 1574 | "circular-json": "0.3.3", 1575 | "del": "2.2.2", 1576 | "graceful-fs": "4.1.11", 1577 | "write": "0.2.1" 1578 | } 1579 | }, 1580 | "for-each": { 1581 | "version": "0.3.2", 1582 | "resolved": "https://registry.npmjs.org/for-each/-/for-each-0.3.2.tgz", 1583 | "integrity": "sha1-LEBFC5NI6X8oEyJZO6lnBLmr1NQ=", 1584 | "dev": true, 1585 | "requires": { 1586 | "is-function": "1.0.1" 1587 | } 1588 | }, 1589 | "foreach": { 1590 | "version": "2.0.5", 1591 | "resolved": "https://registry.npmjs.org/foreach/-/foreach-2.0.5.tgz", 1592 | "integrity": "sha1-C+4AUBiusmDQo6865ljdATbsG5k=", 1593 | "dev": true 1594 | }, 1595 | "forever-agent": { 1596 | "version": "0.6.1", 1597 | "resolved": "https://registry.npmjs.org/forever-agent/-/forever-agent-0.6.1.tgz", 1598 | "integrity": "sha1-+8cfDEGt6zf5bFd60e1C2P2sypE=", 1599 | "dev": true 1600 | }, 1601 | "form-data": { 1602 | "version": "2.3.1", 1603 | "resolved": "https://registry.npmjs.org/form-data/-/form-data-2.3.1.tgz", 1604 | "integrity": "sha1-b7lPvXGIUwbXPRXMSX/kzE7NRL8=", 1605 | "dev": true, 1606 | "requires": { 1607 | "asynckit": "0.4.0", 1608 | "combined-stream": "1.0.5", 1609 | "mime-types": "2.1.17" 1610 | } 1611 | }, 1612 | "fs.realpath": { 1613 | "version": "1.0.0", 1614 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 1615 | "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=", 1616 | "dev": true 1617 | }, 1618 | "function-bind": { 1619 | "version": "1.1.1", 1620 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", 1621 | "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==", 1622 | "dev": true 1623 | }, 1624 | "functional-red-black-tree": { 1625 | "version": "1.0.1", 1626 | "resolved": "https://registry.npmjs.org/functional-red-black-tree/-/functional-red-black-tree-1.0.1.tgz", 1627 | "integrity": "sha1-GwqzvVU7Kg1jmdKcDj6gslIHgyc=", 1628 | "dev": true 1629 | }, 1630 | "getpass": { 1631 | "version": "0.1.7", 1632 | "resolved": "https://registry.npmjs.org/getpass/-/getpass-0.1.7.tgz", 1633 | "integrity": "sha1-Xv+OPmhNVprkyysSgmBOi6YhSfo=", 1634 | "dev": true, 1635 | "requires": { 1636 | "assert-plus": "1.0.0" 1637 | } 1638 | }, 1639 | "glob": { 1640 | "version": "7.1.2", 1641 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.2.tgz", 1642 | "integrity": "sha512-MJTUg1kjuLeQCJ+ccE4Vpa6kKVXkPYJ2mOCQyUuKLcLQsdrMCpBPUi8qVE6+YuaJkozeA9NusTAw3hLr8Xe5EQ==", 1643 | "dev": true, 1644 | "requires": { 1645 | "fs.realpath": "1.0.0", 1646 | "inflight": "1.0.6", 1647 | "inherits": "2.0.3", 1648 | "minimatch": "3.0.4", 1649 | "once": "1.4.0", 1650 | "path-is-absolute": "1.0.1" 1651 | } 1652 | }, 1653 | "globals": { 1654 | "version": "9.18.0", 1655 | "resolved": "https://registry.npmjs.org/globals/-/globals-9.18.0.tgz", 1656 | "integrity": "sha512-S0nG3CLEQiY/ILxqtztTWH/3iRRdyBLw6KMDxnKMchrtbj2OFmehVh0WUCfW3DUrIgx/qFrJPICrq4Z4sTR9UQ==", 1657 | "dev": true 1658 | }, 1659 | "globby": { 1660 | "version": "5.0.0", 1661 | "resolved": "https://registry.npmjs.org/globby/-/globby-5.0.0.tgz", 1662 | "integrity": "sha1-69hGZ8oNuzMLmbz8aOrCvFQ3Dg0=", 1663 | "dev": true, 1664 | "requires": { 1665 | "array-union": "1.0.2", 1666 | "arrify": "1.0.1", 1667 | "glob": "7.1.2", 1668 | "object-assign": "4.1.1", 1669 | "pify": "2.3.0", 1670 | "pinkie-promise": "2.0.1" 1671 | } 1672 | }, 1673 | "graceful-fs": { 1674 | "version": "4.1.11", 1675 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.1.11.tgz", 1676 | "integrity": "sha1-Dovf5NHduIVNZOBOp8AOKgJuVlg=", 1677 | "dev": true 1678 | }, 1679 | "har-schema": { 1680 | "version": "2.0.0", 1681 | "resolved": "https://registry.npmjs.org/har-schema/-/har-schema-2.0.0.tgz", 1682 | "integrity": "sha1-qUwiJOvKwEeCoNkDVSHyRzW37JI=", 1683 | "dev": true 1684 | }, 1685 | "har-validator": { 1686 | "version": "5.0.3", 1687 | "resolved": "https://registry.npmjs.org/har-validator/-/har-validator-5.0.3.tgz", 1688 | "integrity": "sha1-ukAsJmGU8VlW7xXg/PJCmT9qff0=", 1689 | "dev": true, 1690 | "requires": { 1691 | "ajv": "5.5.1", 1692 | "har-schema": "2.0.0" 1693 | }, 1694 | "dependencies": { 1695 | "ajv": { 1696 | "version": "5.5.1", 1697 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-5.5.1.tgz", 1698 | "integrity": "sha1-s4u4h22ehr7plJVqBOch6IskjrI=", 1699 | "dev": true, 1700 | "requires": { 1701 | "co": "4.6.0", 1702 | "fast-deep-equal": "1.0.0", 1703 | "fast-json-stable-stringify": "2.0.0", 1704 | "json-schema-traverse": "0.3.1" 1705 | } 1706 | } 1707 | } 1708 | }, 1709 | "has": { 1710 | "version": "1.0.1", 1711 | "resolved": "https://registry.npmjs.org/has/-/has-1.0.1.tgz", 1712 | "integrity": "sha1-hGFzP1OLCDfJNh45qauelwTcLyg=", 1713 | "dev": true, 1714 | "requires": { 1715 | "function-bind": "1.1.1" 1716 | } 1717 | }, 1718 | "has-ansi": { 1719 | "version": "2.0.0", 1720 | "resolved": "https://registry.npmjs.org/has-ansi/-/has-ansi-2.0.0.tgz", 1721 | "integrity": "sha1-NPUEnOHs3ysGSa8+8k5F7TVBbZE=", 1722 | "dev": true, 1723 | "requires": { 1724 | "ansi-regex": "2.1.1" 1725 | } 1726 | }, 1727 | "has-flag": { 1728 | "version": "2.0.0", 1729 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-2.0.0.tgz", 1730 | "integrity": "sha1-6CB68cx7MNRGzHC3NLXovhj4jVE=", 1731 | "dev": true 1732 | }, 1733 | "hawk": { 1734 | "version": "6.0.2", 1735 | "resolved": "https://registry.npmjs.org/hawk/-/hawk-6.0.2.tgz", 1736 | "integrity": "sha512-miowhl2+U7Qle4vdLqDdPt9m09K6yZhkLDTWGoUiUzrQCn+mHHSmfJgAyGaLRZbPmTqfFFjRV1QWCW0VWUJBbQ==", 1737 | "dev": true, 1738 | "requires": { 1739 | "boom": "4.3.1", 1740 | "cryptiles": "3.1.2", 1741 | "hoek": "4.2.0", 1742 | "sntp": "2.1.0" 1743 | } 1744 | }, 1745 | "hoek": { 1746 | "version": "4.2.0", 1747 | "resolved": "https://registry.npmjs.org/hoek/-/hoek-4.2.0.tgz", 1748 | "integrity": "sha512-v0XCLxICi9nPfYrS9RL8HbYnXi9obYAeLbSP00BmnZwCK9+Ih9WOjoZ8YoHCoav2csqn4FOz4Orldsy2dmDwmQ==", 1749 | "dev": true 1750 | }, 1751 | "home-or-tmp": { 1752 | "version": "2.0.0", 1753 | "resolved": "https://registry.npmjs.org/home-or-tmp/-/home-or-tmp-2.0.0.tgz", 1754 | "integrity": "sha1-42w/LSyufXRqhX440Y1fMqeILbg=", 1755 | "dev": true, 1756 | "requires": { 1757 | "os-homedir": "1.0.2", 1758 | "os-tmpdir": "1.0.2" 1759 | } 1760 | }, 1761 | "hosted-git-info": { 1762 | "version": "2.5.0", 1763 | "resolved": "https://registry.npmjs.org/hosted-git-info/-/hosted-git-info-2.5.0.tgz", 1764 | "integrity": "sha512-pNgbURSuab90KbTqvRPsseaTxOJCZBD0a7t+haSN33piP9cCM4l0CqdzAif2hUqm716UovKB2ROmiabGAKVXyg==", 1765 | "dev": true 1766 | }, 1767 | "html-encoding-sniffer": { 1768 | "version": "1.0.2", 1769 | "resolved": "https://registry.npmjs.org/html-encoding-sniffer/-/html-encoding-sniffer-1.0.2.tgz", 1770 | "integrity": "sha512-71lZziiDnsuabfdYiUeWdCVyKuqwWi23L8YeIgV9jSSZHCtb6wB1BKWooH7L3tn4/FuZJMVWyNaIDr4RGmaSYw==", 1771 | "dev": true, 1772 | "requires": { 1773 | "whatwg-encoding": "1.0.3" 1774 | } 1775 | }, 1776 | "http-signature": { 1777 | "version": "1.2.0", 1778 | "resolved": "https://registry.npmjs.org/http-signature/-/http-signature-1.2.0.tgz", 1779 | "integrity": "sha1-muzZJRFHcvPZW2WmCruPfBj7rOE=", 1780 | "dev": true, 1781 | "requires": { 1782 | "assert-plus": "1.0.0", 1783 | "jsprim": "1.4.1", 1784 | "sshpk": "1.13.1" 1785 | } 1786 | }, 1787 | "iconv-lite": { 1788 | "version": "0.4.19", 1789 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.19.tgz", 1790 | "integrity": "sha512-oTZqweIP51xaGPI4uPa56/Pri/480R+mo7SeU+YETByQNhDG55ycFyNLIgta9vXhILrxXDmF7ZGhqZIcuN0gJQ==", 1791 | "dev": true 1792 | }, 1793 | "ignore": { 1794 | "version": "3.3.7", 1795 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-3.3.7.tgz", 1796 | "integrity": "sha512-YGG3ejvBNHRqu0559EOxxNFihD0AjpvHlC/pdGKd3X3ofe+CoJkYazwNJYTNebqpPKN+VVQbh4ZFn1DivMNuHA==", 1797 | "dev": true 1798 | }, 1799 | "imurmurhash": { 1800 | "version": "0.1.4", 1801 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 1802 | "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=", 1803 | "dev": true 1804 | }, 1805 | "inflight": { 1806 | "version": "1.0.6", 1807 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 1808 | "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", 1809 | "dev": true, 1810 | "requires": { 1811 | "once": "1.4.0", 1812 | "wrappy": "1.0.2" 1813 | } 1814 | }, 1815 | "inherits": { 1816 | "version": "2.0.3", 1817 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz", 1818 | "integrity": "sha1-Yzwsg+PaQqUC9SRmAiSA9CCCYd4=", 1819 | "dev": true 1820 | }, 1821 | "invariant": { 1822 | "version": "2.2.2", 1823 | "resolved": "https://registry.npmjs.org/invariant/-/invariant-2.2.2.tgz", 1824 | "integrity": "sha1-nh9WrArNtr8wMwbzOL47IErmA2A=", 1825 | "dev": true, 1826 | "requires": { 1827 | "loose-envify": "1.3.1" 1828 | } 1829 | }, 1830 | "is-arrayish": { 1831 | "version": "0.2.1", 1832 | "resolved": "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.2.1.tgz", 1833 | "integrity": "sha1-d8mYQFJ6qOyxqLppe4BkWnqSap0=", 1834 | "dev": true 1835 | }, 1836 | "is-builtin-module": { 1837 | "version": "1.0.0", 1838 | "resolved": "https://registry.npmjs.org/is-builtin-module/-/is-builtin-module-1.0.0.tgz", 1839 | "integrity": "sha1-VAVy0096wxGfj3bDDLwbHgN6/74=", 1840 | "dev": true, 1841 | "requires": { 1842 | "builtin-modules": "1.1.1" 1843 | } 1844 | }, 1845 | "is-callable": { 1846 | "version": "1.1.3", 1847 | "resolved": "https://registry.npmjs.org/is-callable/-/is-callable-1.1.3.tgz", 1848 | "integrity": "sha1-hut1OSgF3cM69xySoO7fdO52BLI=", 1849 | "dev": true 1850 | }, 1851 | "is-date-object": { 1852 | "version": "1.0.1", 1853 | "resolved": "https://registry.npmjs.org/is-date-object/-/is-date-object-1.0.1.tgz", 1854 | "integrity": "sha1-mqIOtq7rv/d/vTPnTKAbM1gdOhY=", 1855 | "dev": true 1856 | }, 1857 | "is-finite": { 1858 | "version": "1.0.2", 1859 | "resolved": "https://registry.npmjs.org/is-finite/-/is-finite-1.0.2.tgz", 1860 | "integrity": "sha1-zGZ3aVYCvlUO8R6LSqYwU0K20Ko=", 1861 | "dev": true, 1862 | "requires": { 1863 | "number-is-nan": "1.0.1" 1864 | } 1865 | }, 1866 | "is-function": { 1867 | "version": "1.0.1", 1868 | "resolved": "https://registry.npmjs.org/is-function/-/is-function-1.0.1.tgz", 1869 | "integrity": "sha1-Es+5i2W1fdPRk6MSH19uL0N2ArU=", 1870 | "dev": true 1871 | }, 1872 | "is-path-cwd": { 1873 | "version": "1.0.0", 1874 | "resolved": "https://registry.npmjs.org/is-path-cwd/-/is-path-cwd-1.0.0.tgz", 1875 | "integrity": "sha1-0iXsIxMuie3Tj9p2dHLmLmXxEG0=", 1876 | "dev": true 1877 | }, 1878 | "is-path-in-cwd": { 1879 | "version": "1.0.0", 1880 | "resolved": "https://registry.npmjs.org/is-path-in-cwd/-/is-path-in-cwd-1.0.0.tgz", 1881 | "integrity": "sha1-ZHdYK4IU1gI0YJRWcAO+ip6sBNw=", 1882 | "dev": true, 1883 | "requires": { 1884 | "is-path-inside": "1.0.1" 1885 | } 1886 | }, 1887 | "is-path-inside": { 1888 | "version": "1.0.1", 1889 | "resolved": "https://registry.npmjs.org/is-path-inside/-/is-path-inside-1.0.1.tgz", 1890 | "integrity": "sha1-jvW33lBDej/cprToZe96pVy0gDY=", 1891 | "dev": true, 1892 | "requires": { 1893 | "path-is-inside": "1.0.2" 1894 | } 1895 | }, 1896 | "is-promise": { 1897 | "version": "2.1.0", 1898 | "resolved": "https://registry.npmjs.org/is-promise/-/is-promise-2.1.0.tgz", 1899 | "integrity": "sha1-eaKp7OfwlugPNtKy87wWwf9L8/o=", 1900 | "dev": true 1901 | }, 1902 | "is-regex": { 1903 | "version": "1.0.4", 1904 | "resolved": "https://registry.npmjs.org/is-regex/-/is-regex-1.0.4.tgz", 1905 | "integrity": "sha1-VRdIm1RwkbCTDglWVM7SXul+lJE=", 1906 | "dev": true, 1907 | "requires": { 1908 | "has": "1.0.1" 1909 | } 1910 | }, 1911 | "is-resolvable": { 1912 | "version": "1.0.1", 1913 | "resolved": "https://registry.npmjs.org/is-resolvable/-/is-resolvable-1.0.1.tgz", 1914 | "integrity": "sha512-y5CXYbzvB3jTnWAZH1Nl7ykUWb6T3BcTs56HUruwBf8MhF56n1HWqhDWnVFo8GHrUPDgvUUNVhrc2U8W7iqz5g==", 1915 | "dev": true 1916 | }, 1917 | "is-symbol": { 1918 | "version": "1.0.1", 1919 | "resolved": "https://registry.npmjs.org/is-symbol/-/is-symbol-1.0.1.tgz", 1920 | "integrity": "sha1-PMWfAAJRlLarLjjbrmaJJWtmBXI=", 1921 | "dev": true 1922 | }, 1923 | "is-typedarray": { 1924 | "version": "1.0.0", 1925 | "resolved": "https://registry.npmjs.org/is-typedarray/-/is-typedarray-1.0.0.tgz", 1926 | "integrity": "sha1-5HnICFjfDBsR3dppQPlgEfzaSpo=", 1927 | "dev": true 1928 | }, 1929 | "isarray": { 1930 | "version": "1.0.0", 1931 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", 1932 | "integrity": "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE=", 1933 | "dev": true 1934 | }, 1935 | "isexe": { 1936 | "version": "2.0.0", 1937 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 1938 | "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=", 1939 | "dev": true 1940 | }, 1941 | "isstream": { 1942 | "version": "0.1.2", 1943 | "resolved": "https://registry.npmjs.org/isstream/-/isstream-0.1.2.tgz", 1944 | "integrity": "sha1-R+Y/evVa+m+S4VAOaQ64uFKcCZo=", 1945 | "dev": true 1946 | }, 1947 | "js-tokens": { 1948 | "version": "3.0.2", 1949 | "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-3.0.2.tgz", 1950 | "integrity": "sha1-mGbfOVECEw449/mWvOtlRDIJwls=", 1951 | "dev": true 1952 | }, 1953 | "js-yaml": { 1954 | "version": "3.10.0", 1955 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.10.0.tgz", 1956 | "integrity": "sha512-O2v52ffjLa9VeM43J4XocZE//WT9N0IiwDa3KSHH7Tu8CtH+1qM8SIZvnsTh6v+4yFy5KUY3BHUVwjpfAWsjIA==", 1957 | "dev": true, 1958 | "requires": { 1959 | "argparse": "1.0.9", 1960 | "esprima": "4.0.0" 1961 | } 1962 | }, 1963 | "jsbn": { 1964 | "version": "0.1.1", 1965 | "resolved": "https://registry.npmjs.org/jsbn/-/jsbn-0.1.1.tgz", 1966 | "integrity": "sha1-peZUwuWi3rXyAdls77yoDA7y9RM=", 1967 | "dev": true, 1968 | "optional": true 1969 | }, 1970 | "jsdom": { 1971 | "version": "9.12.0", 1972 | "resolved": "https://registry.npmjs.org/jsdom/-/jsdom-9.12.0.tgz", 1973 | "integrity": "sha1-6MVG//ywbADUgzyoRBD+1/igl9Q=", 1974 | "dev": true, 1975 | "requires": { 1976 | "abab": "1.0.4", 1977 | "acorn": "4.0.13", 1978 | "acorn-globals": "3.1.0", 1979 | "array-equal": "1.0.0", 1980 | "content-type-parser": "1.0.2", 1981 | "cssom": "0.3.2", 1982 | "cssstyle": "0.2.37", 1983 | "escodegen": "1.9.0", 1984 | "html-encoding-sniffer": "1.0.2", 1985 | "nwmatcher": "1.4.3", 1986 | "parse5": "1.5.1", 1987 | "request": "2.83.0", 1988 | "sax": "1.2.4", 1989 | "symbol-tree": "3.2.2", 1990 | "tough-cookie": "2.3.3", 1991 | "webidl-conversions": "4.0.2", 1992 | "whatwg-encoding": "1.0.3", 1993 | "whatwg-url": "4.8.0", 1994 | "xml-name-validator": "2.0.1" 1995 | }, 1996 | "dependencies": { 1997 | "acorn": { 1998 | "version": "4.0.13", 1999 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-4.0.13.tgz", 2000 | "integrity": "sha1-EFSVrlNh1pe9GVyCUZLhrX8lN4c=", 2001 | "dev": true 2002 | } 2003 | } 2004 | }, 2005 | "jsesc": { 2006 | "version": "0.5.0", 2007 | "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-0.5.0.tgz", 2008 | "integrity": "sha1-597mbjXW/Bb3EP6R1c9p9w8IkR0=", 2009 | "dev": true 2010 | }, 2011 | "json-schema": { 2012 | "version": "0.2.3", 2013 | "resolved": "https://registry.npmjs.org/json-schema/-/json-schema-0.2.3.tgz", 2014 | "integrity": "sha1-tIDIkuWaLwWVTOcnvT8qTogvnhM=", 2015 | "dev": true 2016 | }, 2017 | "json-schema-traverse": { 2018 | "version": "0.3.1", 2019 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.3.1.tgz", 2020 | "integrity": "sha1-NJptRMU6Ud6JtAgFxdXlm0F9M0A=", 2021 | "dev": true 2022 | }, 2023 | "json-stable-stringify-without-jsonify": { 2024 | "version": "1.0.1", 2025 | "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz", 2026 | "integrity": "sha1-nbe1lJatPzz+8wp1FC0tkwrXJlE=", 2027 | "dev": true 2028 | }, 2029 | "json-stringify-safe": { 2030 | "version": "5.0.1", 2031 | "resolved": "https://registry.npmjs.org/json-stringify-safe/-/json-stringify-safe-5.0.1.tgz", 2032 | "integrity": "sha1-Epai1Y/UXxmg9s4B1lcB4sc1tus=", 2033 | "dev": true 2034 | }, 2035 | "json5": { 2036 | "version": "0.5.1", 2037 | "resolved": "https://registry.npmjs.org/json5/-/json5-0.5.1.tgz", 2038 | "integrity": "sha1-Hq3nrMASA0rYTiOWdn6tn6VJWCE=", 2039 | "dev": true 2040 | }, 2041 | "jsprim": { 2042 | "version": "1.4.1", 2043 | "resolved": "https://registry.npmjs.org/jsprim/-/jsprim-1.4.1.tgz", 2044 | "integrity": "sha1-MT5mvB5cwG5Di8G3SZwuXFastqI=", 2045 | "dev": true, 2046 | "requires": { 2047 | "assert-plus": "1.0.0", 2048 | "extsprintf": "1.3.0", 2049 | "json-schema": "0.2.3", 2050 | "verror": "1.10.0" 2051 | } 2052 | }, 2053 | "levn": { 2054 | "version": "0.3.0", 2055 | "resolved": "https://registry.npmjs.org/levn/-/levn-0.3.0.tgz", 2056 | "integrity": "sha1-OwmSTt+fCDwEkP3UwLxEIeBHZO4=", 2057 | "dev": true, 2058 | "requires": { 2059 | "prelude-ls": "1.1.2", 2060 | "type-check": "0.3.2" 2061 | } 2062 | }, 2063 | "load-json-file": { 2064 | "version": "2.0.0", 2065 | "resolved": "https://registry.npmjs.org/load-json-file/-/load-json-file-2.0.0.tgz", 2066 | "integrity": "sha1-eUfkIUmvgNaWy/eXvKq8/h/inKg=", 2067 | "dev": true, 2068 | "requires": { 2069 | "graceful-fs": "4.1.11", 2070 | "parse-json": "2.2.0", 2071 | "pify": "2.3.0", 2072 | "strip-bom": "3.0.0" 2073 | } 2074 | }, 2075 | "locate-path": { 2076 | "version": "2.0.0", 2077 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-2.0.0.tgz", 2078 | "integrity": "sha1-K1aLJl7slExtnA3pw9u7ygNUzY4=", 2079 | "dev": true, 2080 | "requires": { 2081 | "p-locate": "2.0.0", 2082 | "path-exists": "3.0.0" 2083 | }, 2084 | "dependencies": { 2085 | "path-exists": { 2086 | "version": "3.0.0", 2087 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-3.0.0.tgz", 2088 | "integrity": "sha1-zg6+ql94yxiSXqfYENe1mwEP1RU=", 2089 | "dev": true 2090 | } 2091 | } 2092 | }, 2093 | "lodash": { 2094 | "version": "4.17.4", 2095 | "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.4.tgz", 2096 | "integrity": "sha1-eCA6TRwyiuHYbcpkYONptX9AVa4=", 2097 | "dev": true 2098 | }, 2099 | "lodash.cond": { 2100 | "version": "4.5.2", 2101 | "resolved": "https://registry.npmjs.org/lodash.cond/-/lodash.cond-4.5.2.tgz", 2102 | "integrity": "sha1-9HGh2khr5g9quVXRcRVSPdHSVdU=", 2103 | "dev": true 2104 | }, 2105 | "loose-envify": { 2106 | "version": "1.3.1", 2107 | "resolved": "https://registry.npmjs.org/loose-envify/-/loose-envify-1.3.1.tgz", 2108 | "integrity": "sha1-0aitM/qc4OcT1l/dCsi3SNR4yEg=", 2109 | "dev": true, 2110 | "requires": { 2111 | "js-tokens": "3.0.2" 2112 | } 2113 | }, 2114 | "lru-cache": { 2115 | "version": "4.1.1", 2116 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-4.1.1.tgz", 2117 | "integrity": "sha512-q4spe4KTfsAS1SUHLO0wz8Qiyf1+vMIAgpRYioFYDMNqKfHQbg+AVDH3i4fvpl71/P1L0dBl+fQi+P37UYf0ew==", 2118 | "dev": true, 2119 | "requires": { 2120 | "pseudomap": "1.0.2", 2121 | "yallist": "2.1.2" 2122 | } 2123 | }, 2124 | "mime-db": { 2125 | "version": "1.30.0", 2126 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.30.0.tgz", 2127 | "integrity": "sha1-dMZD2i3Z1qRTmZY0ZbJtXKfXHwE=", 2128 | "dev": true 2129 | }, 2130 | "mime-types": { 2131 | "version": "2.1.17", 2132 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.17.tgz", 2133 | "integrity": "sha1-Cdejk/A+mVp5+K+Fe3Cp4KsWVXo=", 2134 | "dev": true, 2135 | "requires": { 2136 | "mime-db": "1.30.0" 2137 | } 2138 | }, 2139 | "mimic-fn": { 2140 | "version": "1.1.0", 2141 | "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-1.1.0.tgz", 2142 | "integrity": "sha1-5md4PZLonb00KBi1IwudYqZyrRg=", 2143 | "dev": true 2144 | }, 2145 | "minimatch": { 2146 | "version": "3.0.4", 2147 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", 2148 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 2149 | "dev": true, 2150 | "requires": { 2151 | "brace-expansion": "1.1.8" 2152 | } 2153 | }, 2154 | "minimist": { 2155 | "version": "0.0.8", 2156 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-0.0.8.tgz", 2157 | "integrity": "sha1-hX/Kv8M5fSYluCKCYuhqp6ARsF0=", 2158 | "dev": true 2159 | }, 2160 | "mkdirp": { 2161 | "version": "0.5.1", 2162 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.1.tgz", 2163 | "integrity": "sha1-MAV0OOrGz3+MR2fzhkjWaX11yQM=", 2164 | "dev": true, 2165 | "requires": { 2166 | "minimist": "0.0.8" 2167 | } 2168 | }, 2169 | "ms": { 2170 | "version": "2.0.0", 2171 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 2172 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=", 2173 | "dev": true 2174 | }, 2175 | "natural-compare": { 2176 | "version": "1.4.0", 2177 | "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", 2178 | "integrity": "sha1-Sr6/7tdUHywnrPspvbvRXI1bpPc=", 2179 | "dev": true 2180 | }, 2181 | "normalize-package-data": { 2182 | "version": "2.4.0", 2183 | "resolved": "https://registry.npmjs.org/normalize-package-data/-/normalize-package-data-2.4.0.tgz", 2184 | "integrity": "sha512-9jjUFbTPfEy3R/ad/2oNbKtW9Hgovl5O1FvFWKkKblNXoN/Oou6+9+KKohPK13Yc3/TyunyWhJp6gvRNR/PPAw==", 2185 | "dev": true, 2186 | "requires": { 2187 | "hosted-git-info": "2.5.0", 2188 | "is-builtin-module": "1.0.0", 2189 | "semver": "5.4.1", 2190 | "validate-npm-package-license": "3.0.1" 2191 | } 2192 | }, 2193 | "number-is-nan": { 2194 | "version": "1.0.1", 2195 | "resolved": "https://registry.npmjs.org/number-is-nan/-/number-is-nan-1.0.1.tgz", 2196 | "integrity": "sha1-CXtgK1NCKlIsGvuHkDGDNpQaAR0=", 2197 | "dev": true 2198 | }, 2199 | "nwmatcher": { 2200 | "version": "1.4.3", 2201 | "resolved": "https://registry.npmjs.org/nwmatcher/-/nwmatcher-1.4.3.tgz", 2202 | "integrity": "sha512-IKdSTiDWCarf2JTS5e9e2+5tPZGdkRJ79XjYV0pzK8Q9BpsFyBq1RGKxzs7Q8UBushGw7m6TzVKz6fcY99iSWw==", 2203 | "dev": true 2204 | }, 2205 | "oauth-sign": { 2206 | "version": "0.8.2", 2207 | "resolved": "https://registry.npmjs.org/oauth-sign/-/oauth-sign-0.8.2.tgz", 2208 | "integrity": "sha1-Rqarfwrq2N6unsBWV4C31O/rnUM=", 2209 | "dev": true 2210 | }, 2211 | "object-assign": { 2212 | "version": "4.1.1", 2213 | "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", 2214 | "integrity": "sha1-IQmtx5ZYh8/AXLvUQsrIv7s2CGM=", 2215 | "dev": true 2216 | }, 2217 | "object-inspect": { 2218 | "version": "1.3.0", 2219 | "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.3.0.tgz", 2220 | "integrity": "sha512-OHHnLgLNXpM++GnJRyyhbr2bwl3pPVm4YvaraHrRvDt/N3r+s/gDVHciA7EJBTkijKXj61ssgSAikq1fb0IBRg==", 2221 | "dev": true 2222 | }, 2223 | "object-keys": { 2224 | "version": "1.0.11", 2225 | "resolved": "https://registry.npmjs.org/object-keys/-/object-keys-1.0.11.tgz", 2226 | "integrity": "sha1-xUYBd4rVYPEULODgG8yotW0TQm0=", 2227 | "dev": true 2228 | }, 2229 | "once": { 2230 | "version": "1.4.0", 2231 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 2232 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 2233 | "dev": true, 2234 | "requires": { 2235 | "wrappy": "1.0.2" 2236 | } 2237 | }, 2238 | "optionator": { 2239 | "version": "0.8.2", 2240 | "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.8.2.tgz", 2241 | "integrity": "sha1-NkxeQJ0/TWMB1sC0wFu6UBgK62Q=", 2242 | "dev": true, 2243 | "requires": { 2244 | "deep-is": "0.1.3", 2245 | "fast-levenshtein": "2.0.6", 2246 | "levn": "0.3.0", 2247 | "prelude-ls": "1.1.2", 2248 | "type-check": "0.3.2", 2249 | "wordwrap": "1.0.0" 2250 | } 2251 | }, 2252 | "os-homedir": { 2253 | "version": "1.0.2", 2254 | "resolved": "https://registry.npmjs.org/os-homedir/-/os-homedir-1.0.2.tgz", 2255 | "integrity": "sha1-/7xJiDNuDoM94MFox+8VISGqf7M=", 2256 | "dev": true 2257 | }, 2258 | "os-tmpdir": { 2259 | "version": "1.0.2", 2260 | "resolved": "https://registry.npmjs.org/os-tmpdir/-/os-tmpdir-1.0.2.tgz", 2261 | "integrity": "sha1-u+Z0BseaqFxc/sdm/lc0VV36EnQ=", 2262 | "dev": true 2263 | }, 2264 | "p-limit": { 2265 | "version": "1.1.0", 2266 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-1.1.0.tgz", 2267 | "integrity": "sha1-sH/y2aXYi+yAYDWJWiurZqJ5iLw=", 2268 | "dev": true 2269 | }, 2270 | "p-locate": { 2271 | "version": "2.0.0", 2272 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-2.0.0.tgz", 2273 | "integrity": "sha1-IKAQOyIqcMj9OcwuWAaA893l7EM=", 2274 | "dev": true, 2275 | "requires": { 2276 | "p-limit": "1.1.0" 2277 | } 2278 | }, 2279 | "parse-json": { 2280 | "version": "2.2.0", 2281 | "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-2.2.0.tgz", 2282 | "integrity": "sha1-9ID0BDTvgHQfhGkJn43qGPVaTck=", 2283 | "dev": true, 2284 | "requires": { 2285 | "error-ex": "1.3.1" 2286 | } 2287 | }, 2288 | "parse5": { 2289 | "version": "1.5.1", 2290 | "resolved": "https://registry.npmjs.org/parse5/-/parse5-1.5.1.tgz", 2291 | "integrity": "sha1-m387DeMr543CQBsXVzzK8Pb1nZQ=", 2292 | "dev": true 2293 | }, 2294 | "path-exists": { 2295 | "version": "2.1.0", 2296 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-2.1.0.tgz", 2297 | "integrity": "sha1-D+tsZPD8UY2adU3V77YscCJ2H0s=", 2298 | "dev": true, 2299 | "requires": { 2300 | "pinkie-promise": "2.0.1" 2301 | } 2302 | }, 2303 | "path-is-absolute": { 2304 | "version": "1.0.1", 2305 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 2306 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=", 2307 | "dev": true 2308 | }, 2309 | "path-is-inside": { 2310 | "version": "1.0.2", 2311 | "resolved": "https://registry.npmjs.org/path-is-inside/-/path-is-inside-1.0.2.tgz", 2312 | "integrity": "sha1-NlQX3t5EQw0cEa9hAn+s8HS9/FM=", 2313 | "dev": true 2314 | }, 2315 | "path-parse": { 2316 | "version": "1.0.5", 2317 | "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.5.tgz", 2318 | "integrity": "sha1-PBrfhx6pzWyUMbbqK9dKD/BVxME=", 2319 | "dev": true 2320 | }, 2321 | "path-type": { 2322 | "version": "2.0.0", 2323 | "resolved": "https://registry.npmjs.org/path-type/-/path-type-2.0.0.tgz", 2324 | "integrity": "sha1-8BLMuEFbcJb8LaoQVMPXI4lZTHM=", 2325 | "dev": true, 2326 | "requires": { 2327 | "pify": "2.3.0" 2328 | } 2329 | }, 2330 | "performance-now": { 2331 | "version": "2.1.0", 2332 | "resolved": "https://registry.npmjs.org/performance-now/-/performance-now-2.1.0.tgz", 2333 | "integrity": "sha1-Ywn04OX6kT7BxpMHrjZLSzd8nns=", 2334 | "dev": true 2335 | }, 2336 | "pify": { 2337 | "version": "2.3.0", 2338 | "resolved": "https://registry.npmjs.org/pify/-/pify-2.3.0.tgz", 2339 | "integrity": "sha1-7RQaasBDqEnqWISY59yosVMw6Qw=", 2340 | "dev": true 2341 | }, 2342 | "pinkie": { 2343 | "version": "2.0.4", 2344 | "resolved": "https://registry.npmjs.org/pinkie/-/pinkie-2.0.4.tgz", 2345 | "integrity": "sha1-clVrgM+g1IqXToDnckjoDtT3+HA=", 2346 | "dev": true 2347 | }, 2348 | "pinkie-promise": { 2349 | "version": "2.0.1", 2350 | "resolved": "https://registry.npmjs.org/pinkie-promise/-/pinkie-promise-2.0.1.tgz", 2351 | "integrity": "sha1-ITXW36ejWMBprJsXh3YogihFD/o=", 2352 | "dev": true, 2353 | "requires": { 2354 | "pinkie": "2.0.4" 2355 | } 2356 | }, 2357 | "pkg-dir": { 2358 | "version": "1.0.0", 2359 | "resolved": "https://registry.npmjs.org/pkg-dir/-/pkg-dir-1.0.0.tgz", 2360 | "integrity": "sha1-ektQio1bstYp1EcFb/TpyTFM89Q=", 2361 | "dev": true, 2362 | "requires": { 2363 | "find-up": "1.1.2" 2364 | } 2365 | }, 2366 | "prelude-ls": { 2367 | "version": "1.1.2", 2368 | "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.1.2.tgz", 2369 | "integrity": "sha1-IZMqVJ9eUv/ZqCf1cOBL5iqX2lQ=", 2370 | "dev": true 2371 | }, 2372 | "private": { 2373 | "version": "0.1.8", 2374 | "resolved": "https://registry.npmjs.org/private/-/private-0.1.8.tgz", 2375 | "integrity": "sha512-VvivMrbvd2nKkiG38qjULzlc+4Vx4wm/whI9pQD35YrARNnhxeiRktSOhSukRLFNlzg6Br/cJPet5J/u19r/mg==", 2376 | "dev": true 2377 | }, 2378 | "process-nextick-args": { 2379 | "version": "1.0.7", 2380 | "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-1.0.7.tgz", 2381 | "integrity": "sha1-FQ4gt1ZZCtP5EJPyWk8q2L/zC6M=", 2382 | "dev": true 2383 | }, 2384 | "pseudomap": { 2385 | "version": "1.0.2", 2386 | "resolved": "https://registry.npmjs.org/pseudomap/-/pseudomap-1.0.2.tgz", 2387 | "integrity": "sha1-8FKijacOYYkX7wqKw0wa5aaChrM=", 2388 | "dev": true 2389 | }, 2390 | "punycode": { 2391 | "version": "1.4.1", 2392 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-1.4.1.tgz", 2393 | "integrity": "sha1-wNWmOycYgArY4esPpSachN1BhF4=", 2394 | "dev": true 2395 | }, 2396 | "qs": { 2397 | "version": "6.5.1", 2398 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.5.1.tgz", 2399 | "integrity": "sha512-eRzhrN1WSINYCDCbrz796z37LOe3m5tmW7RQf6oBntukAG1nmovJvhnwHHRMAfeoItc1m2Hk02WER2aQ/iqs+A==", 2400 | "dev": true 2401 | }, 2402 | "read-pkg": { 2403 | "version": "2.0.0", 2404 | "resolved": "https://registry.npmjs.org/read-pkg/-/read-pkg-2.0.0.tgz", 2405 | "integrity": "sha1-jvHAYjxqbbDcZxPEv6xGMysjaPg=", 2406 | "dev": true, 2407 | "requires": { 2408 | "load-json-file": "2.0.0", 2409 | "normalize-package-data": "2.4.0", 2410 | "path-type": "2.0.0" 2411 | } 2412 | }, 2413 | "read-pkg-up": { 2414 | "version": "2.0.0", 2415 | "resolved": "https://registry.npmjs.org/read-pkg-up/-/read-pkg-up-2.0.0.tgz", 2416 | "integrity": "sha1-a3KoBImE4MQeeVEP1en6mbO1Sb4=", 2417 | "dev": true, 2418 | "requires": { 2419 | "find-up": "2.1.0", 2420 | "read-pkg": "2.0.0" 2421 | }, 2422 | "dependencies": { 2423 | "find-up": { 2424 | "version": "2.1.0", 2425 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-2.1.0.tgz", 2426 | "integrity": "sha1-RdG35QbHF93UgndaK3eSCjwMV6c=", 2427 | "dev": true, 2428 | "requires": { 2429 | "locate-path": "2.0.0" 2430 | } 2431 | } 2432 | } 2433 | }, 2434 | "readable-stream": { 2435 | "version": "2.3.3", 2436 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.3.tgz", 2437 | "integrity": "sha512-m+qzzcn7KUxEmd1gMbchF+Y2eIUbieUaxkWtptyHywrX0rE8QEYqPC07Vuy4Wm32/xE16NcdBctb8S0Xe/5IeQ==", 2438 | "dev": true, 2439 | "requires": { 2440 | "core-util-is": "1.0.2", 2441 | "inherits": "2.0.3", 2442 | "isarray": "1.0.0", 2443 | "process-nextick-args": "1.0.7", 2444 | "safe-buffer": "5.1.1", 2445 | "string_decoder": "1.0.3", 2446 | "util-deprecate": "1.0.2" 2447 | } 2448 | }, 2449 | "regenerate": { 2450 | "version": "1.3.3", 2451 | "resolved": "https://registry.npmjs.org/regenerate/-/regenerate-1.3.3.tgz", 2452 | "integrity": "sha512-jVpo1GadrDAK59t/0jRx5VxYWQEDkkEKi6+HjE3joFVLfDOh9Xrdh0dF1eSq+BI/SwvTQ44gSscJ8N5zYL61sg==", 2453 | "dev": true 2454 | }, 2455 | "regenerator-runtime": { 2456 | "version": "0.11.1", 2457 | "resolved": "https://registry.npmjs.org/regenerator-runtime/-/regenerator-runtime-0.11.1.tgz", 2458 | "integrity": "sha512-MguG95oij0fC3QV3URf4V2SDYGJhJnJGqvIIgdECeODCT98wSWDAJ94SSuVpYQUoTcGUIL6L4yNB7j1DFFHSBg==", 2459 | "dev": true 2460 | }, 2461 | "regenerator-transform": { 2462 | "version": "0.10.1", 2463 | "resolved": "https://registry.npmjs.org/regenerator-transform/-/regenerator-transform-0.10.1.tgz", 2464 | "integrity": "sha512-PJepbvDbuK1xgIgnau7Y90cwaAmO/LCLMI2mPvaXq2heGMR3aWW5/BQvYrhJ8jgmQjXewXvBjzfqKcVOmhjZ6Q==", 2465 | "dev": true, 2466 | "requires": { 2467 | "babel-runtime": "6.26.0", 2468 | "babel-types": "6.26.0", 2469 | "private": "0.1.8" 2470 | } 2471 | }, 2472 | "regexpu-core": { 2473 | "version": "2.0.0", 2474 | "resolved": "https://registry.npmjs.org/regexpu-core/-/regexpu-core-2.0.0.tgz", 2475 | "integrity": "sha1-SdA4g3uNz4v6W5pCE5k45uoq4kA=", 2476 | "dev": true, 2477 | "requires": { 2478 | "regenerate": "1.3.3", 2479 | "regjsgen": "0.2.0", 2480 | "regjsparser": "0.1.5" 2481 | } 2482 | }, 2483 | "regjsgen": { 2484 | "version": "0.2.0", 2485 | "resolved": "https://registry.npmjs.org/regjsgen/-/regjsgen-0.2.0.tgz", 2486 | "integrity": "sha1-bAFq3qxVT3WCP+N6wFuS1aTtsfc=", 2487 | "dev": true 2488 | }, 2489 | "regjsparser": { 2490 | "version": "0.1.5", 2491 | "resolved": "https://registry.npmjs.org/regjsparser/-/regjsparser-0.1.5.tgz", 2492 | "integrity": "sha1-fuj4Tcb6eS0/0K4ijSS9lJ6tIFw=", 2493 | "dev": true, 2494 | "requires": { 2495 | "jsesc": "0.5.0" 2496 | } 2497 | }, 2498 | "repeating": { 2499 | "version": "2.0.1", 2500 | "resolved": "https://registry.npmjs.org/repeating/-/repeating-2.0.1.tgz", 2501 | "integrity": "sha1-UhTFOpJtNVJwdSf7q0FdvAjQbdo=", 2502 | "dev": true, 2503 | "requires": { 2504 | "is-finite": "1.0.2" 2505 | } 2506 | }, 2507 | "request": { 2508 | "version": "2.83.0", 2509 | "resolved": "https://registry.npmjs.org/request/-/request-2.83.0.tgz", 2510 | "integrity": "sha512-lR3gD69osqm6EYLk9wB/G1W/laGWjzH90t1vEa2xuxHD5KUrSzp9pUSfTm+YC5Nxt2T8nMPEvKlhbQayU7bgFw==", 2511 | "dev": true, 2512 | "requires": { 2513 | "aws-sign2": "0.7.0", 2514 | "aws4": "1.6.0", 2515 | "caseless": "0.12.0", 2516 | "combined-stream": "1.0.5", 2517 | "extend": "3.0.1", 2518 | "forever-agent": "0.6.1", 2519 | "form-data": "2.3.1", 2520 | "har-validator": "5.0.3", 2521 | "hawk": "6.0.2", 2522 | "http-signature": "1.2.0", 2523 | "is-typedarray": "1.0.0", 2524 | "isstream": "0.1.2", 2525 | "json-stringify-safe": "5.0.1", 2526 | "mime-types": "2.1.17", 2527 | "oauth-sign": "0.8.2", 2528 | "performance-now": "2.1.0", 2529 | "qs": "6.5.1", 2530 | "safe-buffer": "5.1.1", 2531 | "stringstream": "0.0.5", 2532 | "tough-cookie": "2.3.3", 2533 | "tunnel-agent": "0.6.0", 2534 | "uuid": "3.1.0" 2535 | } 2536 | }, 2537 | "require-uncached": { 2538 | "version": "1.0.3", 2539 | "resolved": "https://registry.npmjs.org/require-uncached/-/require-uncached-1.0.3.tgz", 2540 | "integrity": "sha1-Tg1W1slmL9MeQwEcS5WqSZVUIdM=", 2541 | "dev": true, 2542 | "requires": { 2543 | "caller-path": "0.1.0", 2544 | "resolve-from": "1.0.1" 2545 | } 2546 | }, 2547 | "resolve": { 2548 | "version": "1.5.0", 2549 | "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.5.0.tgz", 2550 | "integrity": "sha512-hgoSGrc3pjzAPHNBg+KnFcK2HwlHTs/YrAGUr6qgTVUZmXv1UEXXl0bZNBKMA9fud6lRYFdPGz0xXxycPzmmiw==", 2551 | "dev": true, 2552 | "requires": { 2553 | "path-parse": "1.0.5" 2554 | } 2555 | }, 2556 | "resolve-from": { 2557 | "version": "1.0.1", 2558 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-1.0.1.tgz", 2559 | "integrity": "sha1-Jsv+k10a7uq7Kbw/5a6wHpPUQiY=", 2560 | "dev": true 2561 | }, 2562 | "resumer": { 2563 | "version": "0.0.0", 2564 | "resolved": "https://registry.npmjs.org/resumer/-/resumer-0.0.0.tgz", 2565 | "integrity": "sha1-8ej0YeQGS6Oegq883CqMiT0HZ1k=", 2566 | "dev": true, 2567 | "requires": { 2568 | "through": "2.3.8" 2569 | } 2570 | }, 2571 | "rimraf": { 2572 | "version": "2.6.2", 2573 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.6.2.tgz", 2574 | "integrity": "sha512-lreewLK/BlghmxtfH36YYVg1i8IAce4TI7oao75I1g245+6BctqTVQiBP3YUJ9C6DQOXJmkYR9X9fCLtCOJc5w==", 2575 | "dev": true, 2576 | "requires": { 2577 | "glob": "7.1.2" 2578 | } 2579 | }, 2580 | "rollup": { 2581 | "version": "0.52.1", 2582 | "resolved": "https://registry.npmjs.org/rollup/-/rollup-0.52.1.tgz", 2583 | "integrity": "sha512-cVOL8rUMivChVcScL7zq1JCl4+4gMiVOllnX9r2l6MlkUzyXRbBK7szGDGaFXyqZl6uruFtX+gFhize9o7iiKg==", 2584 | "dev": true 2585 | }, 2586 | "rollup-plugin-babel": { 2587 | "version": "3.0.2", 2588 | "resolved": "https://registry.npmjs.org/rollup-plugin-babel/-/rollup-plugin-babel-3.0.2.tgz", 2589 | "integrity": "sha512-ALGPBFtwJZcYHsNPM6RGJlEncTzAARPvZOGjNPZgDe5hS5t6sJGjiOWibEFVEz5LQN7S7spvCBILaS4N1Cql2w==", 2590 | "dev": true, 2591 | "requires": { 2592 | "rollup-pluginutils": "1.5.2" 2593 | } 2594 | }, 2595 | "rollup-pluginutils": { 2596 | "version": "1.5.2", 2597 | "resolved": "https://registry.npmjs.org/rollup-pluginutils/-/rollup-pluginutils-1.5.2.tgz", 2598 | "integrity": "sha1-HhVud4+UtyVb+hs9AXi+j1xVJAg=", 2599 | "dev": true, 2600 | "requires": { 2601 | "estree-walker": "0.2.1", 2602 | "minimatch": "3.0.4" 2603 | } 2604 | }, 2605 | "rx-lite": { 2606 | "version": "3.1.2", 2607 | "resolved": "https://registry.npmjs.org/rx-lite/-/rx-lite-3.1.2.tgz", 2608 | "integrity": "sha1-Gc5QLKVyZl87ZHsQk5+X/RYV8QI=", 2609 | "dev": true 2610 | }, 2611 | "rx-lite-aggregates": { 2612 | "version": "4.0.8", 2613 | "resolved": "https://registry.npmjs.org/rx-lite-aggregates/-/rx-lite-aggregates-4.0.8.tgz", 2614 | "integrity": "sha1-dTuHqJoRyVRnxKwWJsTvxOBcZ74=", 2615 | "dev": true, 2616 | "requires": { 2617 | "rx-lite": "3.1.2" 2618 | } 2619 | }, 2620 | "safe-buffer": { 2621 | "version": "5.1.1", 2622 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.1.tgz", 2623 | "integrity": "sha512-kKvNJn6Mm93gAczWVJg7wH+wGYWNrDHdWvpUmHyEsgCtIwwo3bqPtV4tR5tuPaUhTOo/kvhVwd8XwwOllGYkbg==", 2624 | "dev": true 2625 | }, 2626 | "sax": { 2627 | "version": "1.2.4", 2628 | "resolved": "https://registry.npmjs.org/sax/-/sax-1.2.4.tgz", 2629 | "integrity": "sha512-NqVDv9TpANUjFm0N8uM5GxL36UgKi9/atZw+x7YFnQ8ckwFGKrl4xX4yWtrey3UJm5nP1kUbnYgLopqWNSRhWw==", 2630 | "dev": true 2631 | }, 2632 | "semver": { 2633 | "version": "5.4.1", 2634 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.4.1.tgz", 2635 | "integrity": "sha512-WfG/X9+oATh81XtllIo/I8gOiY9EXRdv1cQdyykeXK17YcUW3EXUAi2To4pcH6nZtJPr7ZOpM5OMyWJZm+8Rsg==", 2636 | "dev": true 2637 | }, 2638 | "shebang-command": { 2639 | "version": "1.2.0", 2640 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-1.2.0.tgz", 2641 | "integrity": "sha1-RKrGW2lbAzmJaMOfNj/uXer98eo=", 2642 | "dev": true, 2643 | "requires": { 2644 | "shebang-regex": "1.0.0" 2645 | } 2646 | }, 2647 | "shebang-regex": { 2648 | "version": "1.0.0", 2649 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-1.0.0.tgz", 2650 | "integrity": "sha1-2kL0l0DAtC2yypcoVxyxkMmO/qM=", 2651 | "dev": true 2652 | }, 2653 | "signal-exit": { 2654 | "version": "3.0.2", 2655 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.2.tgz", 2656 | "integrity": "sha1-tf3AjxKH6hF4Yo5BXiUTK3NkbG0=", 2657 | "dev": true 2658 | }, 2659 | "slash": { 2660 | "version": "1.0.0", 2661 | "resolved": "https://registry.npmjs.org/slash/-/slash-1.0.0.tgz", 2662 | "integrity": "sha1-xB8vbDn8FtHNF61LXYlhFK5HDVU=", 2663 | "dev": true 2664 | }, 2665 | "sntp": { 2666 | "version": "2.1.0", 2667 | "resolved": "https://registry.npmjs.org/sntp/-/sntp-2.1.0.tgz", 2668 | "integrity": "sha512-FL1b58BDrqS3A11lJ0zEdnJ3UOKqVxawAkF3k7F0CVN7VQ34aZrV+G8BZ1WC9ZL7NyrwsW0oviwsWDgRuVYtJg==", 2669 | "dev": true, 2670 | "requires": { 2671 | "hoek": "4.2.0" 2672 | } 2673 | }, 2674 | "source-map": { 2675 | "version": "0.5.7", 2676 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.5.7.tgz", 2677 | "integrity": "sha1-igOdLRAh0i0eoUyA2OpGi6LvP8w=", 2678 | "dev": true 2679 | }, 2680 | "source-map-support": { 2681 | "version": "0.4.18", 2682 | "resolved": "https://registry.npmjs.org/source-map-support/-/source-map-support-0.4.18.tgz", 2683 | "integrity": "sha512-try0/JqxPLF9nOjvSta7tVondkP5dwgyLDjVoyMDlmjugT2lRZ1OfsrYTkCd2hkDnJTKRbO/Rl3orm8vlsUzbA==", 2684 | "dev": true, 2685 | "requires": { 2686 | "source-map": "0.5.7" 2687 | } 2688 | }, 2689 | "spdx-correct": { 2690 | "version": "1.0.2", 2691 | "resolved": "https://registry.npmjs.org/spdx-correct/-/spdx-correct-1.0.2.tgz", 2692 | "integrity": "sha1-SzBz2TP/UfORLwOsVRlJikFQ20A=", 2693 | "dev": true, 2694 | "requires": { 2695 | "spdx-license-ids": "1.2.2" 2696 | } 2697 | }, 2698 | "spdx-expression-parse": { 2699 | "version": "1.0.4", 2700 | "resolved": "https://registry.npmjs.org/spdx-expression-parse/-/spdx-expression-parse-1.0.4.tgz", 2701 | "integrity": "sha1-m98vIOH0DtRH++JzJmGR/O1RYmw=", 2702 | "dev": true 2703 | }, 2704 | "spdx-license-ids": { 2705 | "version": "1.2.2", 2706 | "resolved": "https://registry.npmjs.org/spdx-license-ids/-/spdx-license-ids-1.2.2.tgz", 2707 | "integrity": "sha1-yd96NCRZSt5r0RkA1ZZpbcBrrFc=", 2708 | "dev": true 2709 | }, 2710 | "sprintf-js": { 2711 | "version": "1.0.3", 2712 | "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz", 2713 | "integrity": "sha1-BOaSb2YolTVPPdAVIDYzuFcpfiw=", 2714 | "dev": true 2715 | }, 2716 | "sshpk": { 2717 | "version": "1.13.1", 2718 | "resolved": "https://registry.npmjs.org/sshpk/-/sshpk-1.13.1.tgz", 2719 | "integrity": "sha1-US322mKHFEMW3EwY/hzx2UBzm+M=", 2720 | "dev": true, 2721 | "requires": { 2722 | "asn1": "0.2.3", 2723 | "assert-plus": "1.0.0", 2724 | "bcrypt-pbkdf": "1.0.1", 2725 | "dashdash": "1.14.1", 2726 | "ecc-jsbn": "0.1.1", 2727 | "getpass": "0.1.7", 2728 | "jsbn": "0.1.1", 2729 | "tweetnacl": "0.14.5" 2730 | } 2731 | }, 2732 | "string.prototype.trim": { 2733 | "version": "1.1.2", 2734 | "resolved": "https://registry.npmjs.org/string.prototype.trim/-/string.prototype.trim-1.1.2.tgz", 2735 | "integrity": "sha1-0E3iyJ4Tf019IG8Ia17S+ua+jOo=", 2736 | "dev": true, 2737 | "requires": { 2738 | "define-properties": "1.1.2", 2739 | "es-abstract": "1.10.0", 2740 | "function-bind": "1.1.1" 2741 | } 2742 | }, 2743 | "string_decoder": { 2744 | "version": "1.0.3", 2745 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.0.3.tgz", 2746 | "integrity": "sha512-4AH6Z5fzNNBcH+6XDMfA/BTt87skxqJlO0lAh3Dker5zThcAxG6mKz+iGu308UKoPPQ8Dcqx/4JhujzltRa+hQ==", 2747 | "dev": true, 2748 | "requires": { 2749 | "safe-buffer": "5.1.1" 2750 | } 2751 | }, 2752 | "stringstream": { 2753 | "version": "0.0.5", 2754 | "resolved": "https://registry.npmjs.org/stringstream/-/stringstream-0.0.5.tgz", 2755 | "integrity": "sha1-TkhM1N5aC7vuGORjB3EKioFiGHg=", 2756 | "dev": true 2757 | }, 2758 | "strip-ansi": { 2759 | "version": "3.0.1", 2760 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-3.0.1.tgz", 2761 | "integrity": "sha1-ajhfuIU9lS1f8F0Oiq+UJ43GPc8=", 2762 | "dev": true, 2763 | "requires": { 2764 | "ansi-regex": "2.1.1" 2765 | } 2766 | }, 2767 | "strip-bom": { 2768 | "version": "3.0.0", 2769 | "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-3.0.0.tgz", 2770 | "integrity": "sha1-IzTBjpx1n3vdVv3vfprj1YjmjtM=", 2771 | "dev": true 2772 | }, 2773 | "strip-json-comments": { 2774 | "version": "2.0.1", 2775 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-2.0.1.tgz", 2776 | "integrity": "sha1-PFMZQukIwml8DsNEhYwobHygpgo=", 2777 | "dev": true 2778 | }, 2779 | "supports-color": { 2780 | "version": "2.0.0", 2781 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-2.0.0.tgz", 2782 | "integrity": "sha1-U10EXOa2Nj+kARcIRimZXp3zJMc=", 2783 | "dev": true 2784 | }, 2785 | "symbol-tree": { 2786 | "version": "3.2.2", 2787 | "resolved": "https://registry.npmjs.org/symbol-tree/-/symbol-tree-3.2.2.tgz", 2788 | "integrity": "sha1-rifbOPZgp64uHDt9G8KQgZuFGeY=", 2789 | "dev": true 2790 | }, 2791 | "tape": { 2792 | "version": "4.8.0", 2793 | "resolved": "https://registry.npmjs.org/tape/-/tape-4.8.0.tgz", 2794 | "integrity": "sha512-TWILfEnvO7I8mFe35d98F6T5fbLaEtbFTG/lxWvid8qDfFTxt19EBijWmB4j3+Hoh5TfHE2faWs73ua+EphuBA==", 2795 | "dev": true, 2796 | "requires": { 2797 | "deep-equal": "1.0.1", 2798 | "defined": "1.0.0", 2799 | "for-each": "0.3.2", 2800 | "function-bind": "1.1.1", 2801 | "glob": "7.1.2", 2802 | "has": "1.0.1", 2803 | "inherits": "2.0.3", 2804 | "minimist": "1.2.0", 2805 | "object-inspect": "1.3.0", 2806 | "resolve": "1.4.0", 2807 | "resumer": "0.0.0", 2808 | "string.prototype.trim": "1.1.2", 2809 | "through": "2.3.8" 2810 | }, 2811 | "dependencies": { 2812 | "minimist": { 2813 | "version": "1.2.0", 2814 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.0.tgz", 2815 | "integrity": "sha1-o1AIsg9BOD7sH7kU9M1d95omQoQ=", 2816 | "dev": true 2817 | }, 2818 | "resolve": { 2819 | "version": "1.4.0", 2820 | "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.4.0.tgz", 2821 | "integrity": "sha512-aW7sVKPufyHqOmyyLzg/J+8606v5nevBgaliIlV7nUpVMsDnoBGV/cbSLNjZAg9q0Cfd/+easKVKQ8vOu8fn1Q==", 2822 | "dev": true, 2823 | "requires": { 2824 | "path-parse": "1.0.5" 2825 | } 2826 | } 2827 | } 2828 | }, 2829 | "text-table": { 2830 | "version": "0.2.0", 2831 | "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz", 2832 | "integrity": "sha1-f17oI66AUgfACvLfSoTsP8+lcLQ=", 2833 | "dev": true 2834 | }, 2835 | "through": { 2836 | "version": "2.3.8", 2837 | "resolved": "https://registry.npmjs.org/through/-/through-2.3.8.tgz", 2838 | "integrity": "sha1-DdTJ/6q8NXlgsbckEV1+Doai4fU=", 2839 | "dev": true 2840 | }, 2841 | "tmp": { 2842 | "version": "0.0.33", 2843 | "resolved": "https://registry.npmjs.org/tmp/-/tmp-0.0.33.tgz", 2844 | "integrity": "sha512-jRCJlojKnZ3addtTOjdIqoRuPEKBvNXcGYqzO6zWZX8KfKEpnGY5jfggJQ3EjKuu8D4bJRr0y+cYJFmYbImXGw==", 2845 | "dev": true, 2846 | "requires": { 2847 | "os-tmpdir": "1.0.2" 2848 | } 2849 | }, 2850 | "to-fast-properties": { 2851 | "version": "1.0.3", 2852 | "resolved": "https://registry.npmjs.org/to-fast-properties/-/to-fast-properties-1.0.3.tgz", 2853 | "integrity": "sha1-uDVx+k2MJbguIxsG46MFXeTKGkc=", 2854 | "dev": true 2855 | }, 2856 | "tough-cookie": { 2857 | "version": "2.3.3", 2858 | "resolved": "https://registry.npmjs.org/tough-cookie/-/tough-cookie-2.3.3.tgz", 2859 | "integrity": "sha1-C2GKVWW23qkL80JdBNVe3EdadWE=", 2860 | "dev": true, 2861 | "requires": { 2862 | "punycode": "1.4.1" 2863 | } 2864 | }, 2865 | "tr46": { 2866 | "version": "0.0.3", 2867 | "resolved": "https://registry.npmjs.org/tr46/-/tr46-0.0.3.tgz", 2868 | "integrity": "sha1-gYT9NH2snNwYWZLzpmIuFLnZq2o=", 2869 | "dev": true 2870 | }, 2871 | "trim-right": { 2872 | "version": "1.0.1", 2873 | "resolved": "https://registry.npmjs.org/trim-right/-/trim-right-1.0.1.tgz", 2874 | "integrity": "sha1-yy4SAwZ+DI3h9hQJS5/kVwTqYAM=", 2875 | "dev": true 2876 | }, 2877 | "tunnel-agent": { 2878 | "version": "0.6.0", 2879 | "resolved": "https://registry.npmjs.org/tunnel-agent/-/tunnel-agent-0.6.0.tgz", 2880 | "integrity": "sha1-J6XeoGs2sEoKmWZ3SykIaPD8QP0=", 2881 | "dev": true, 2882 | "requires": { 2883 | "safe-buffer": "5.1.1" 2884 | } 2885 | }, 2886 | "tweetnacl": { 2887 | "version": "0.14.5", 2888 | "resolved": "https://registry.npmjs.org/tweetnacl/-/tweetnacl-0.14.5.tgz", 2889 | "integrity": "sha1-WuaBd/GS1EViadEIr6k/+HQ/T2Q=", 2890 | "dev": true, 2891 | "optional": true 2892 | }, 2893 | "type-check": { 2894 | "version": "0.3.2", 2895 | "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.3.2.tgz", 2896 | "integrity": "sha1-WITKtRLPHTVeP7eE8wgEsrUg23I=", 2897 | "dev": true, 2898 | "requires": { 2899 | "prelude-ls": "1.1.2" 2900 | } 2901 | }, 2902 | "typedarray": { 2903 | "version": "0.0.6", 2904 | "resolved": "https://registry.npmjs.org/typedarray/-/typedarray-0.0.6.tgz", 2905 | "integrity": "sha1-hnrHTjhkGHsdPUfZlqeOxciDB3c=", 2906 | "dev": true 2907 | }, 2908 | "uglify-js": { 2909 | "version": "3.2.2", 2910 | "resolved": "https://registry.npmjs.org/uglify-js/-/uglify-js-3.2.2.tgz", 2911 | "integrity": "sha512-++1NO/zZIEdWf6cDIGceSJQPX31SqIpbVAHwFG5+240MtZqPG/NIPoinj8zlXQtAfMBqEt1Jyv2FiLP3n9gVhQ==", 2912 | "dev": true, 2913 | "requires": { 2914 | "commander": "2.12.2", 2915 | "source-map": "0.6.1" 2916 | }, 2917 | "dependencies": { 2918 | "source-map": { 2919 | "version": "0.6.1", 2920 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", 2921 | "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", 2922 | "dev": true 2923 | } 2924 | } 2925 | }, 2926 | "util-deprecate": { 2927 | "version": "1.0.2", 2928 | "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", 2929 | "integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8=", 2930 | "dev": true 2931 | }, 2932 | "uuid": { 2933 | "version": "3.1.0", 2934 | "resolved": "https://registry.npmjs.org/uuid/-/uuid-3.1.0.tgz", 2935 | "integrity": "sha512-DIWtzUkw04M4k3bf1IcpS2tngXEL26YUD2M0tMDUpnUrz2hgzUBlD55a4FjdLGPvfHxS6uluGWvaVEqgBcVa+g==", 2936 | "dev": true 2937 | }, 2938 | "validate-npm-package-license": { 2939 | "version": "3.0.1", 2940 | "resolved": "https://registry.npmjs.org/validate-npm-package-license/-/validate-npm-package-license-3.0.1.tgz", 2941 | "integrity": "sha1-KAS6vnEq0zeUWaz74kdGqywwP7w=", 2942 | "dev": true, 2943 | "requires": { 2944 | "spdx-correct": "1.0.2", 2945 | "spdx-expression-parse": "1.0.4" 2946 | } 2947 | }, 2948 | "verror": { 2949 | "version": "1.10.0", 2950 | "resolved": "https://registry.npmjs.org/verror/-/verror-1.10.0.tgz", 2951 | "integrity": "sha1-OhBcoXBTr1XW4nDB+CiGguGNpAA=", 2952 | "dev": true, 2953 | "requires": { 2954 | "assert-plus": "1.0.0", 2955 | "core-util-is": "1.0.2", 2956 | "extsprintf": "1.3.0" 2957 | } 2958 | }, 2959 | "webidl-conversions": { 2960 | "version": "4.0.2", 2961 | "resolved": "https://registry.npmjs.org/webidl-conversions/-/webidl-conversions-4.0.2.tgz", 2962 | "integrity": "sha512-YQ+BmxuTgd6UXZW3+ICGfyqRyHXVlD5GtQr5+qjiNW7bF0cqrzX500HVXPBOvgXb5YnzDd+h0zqyv61KUD7+Sg==", 2963 | "dev": true 2964 | }, 2965 | "whatwg-encoding": { 2966 | "version": "1.0.3", 2967 | "resolved": "https://registry.npmjs.org/whatwg-encoding/-/whatwg-encoding-1.0.3.tgz", 2968 | "integrity": "sha512-jLBwwKUhi8WtBfsMQlL4bUUcT8sMkAtQinscJAe/M4KHCkHuUJAF6vuB0tueNIw4c8ziO6AkRmgY+jL3a0iiPw==", 2969 | "dev": true, 2970 | "requires": { 2971 | "iconv-lite": "0.4.19" 2972 | } 2973 | }, 2974 | "whatwg-url": { 2975 | "version": "4.8.0", 2976 | "resolved": "https://registry.npmjs.org/whatwg-url/-/whatwg-url-4.8.0.tgz", 2977 | "integrity": "sha1-0pgaqRSMHgCkHFphMRZqtGg7vMA=", 2978 | "dev": true, 2979 | "requires": { 2980 | "tr46": "0.0.3", 2981 | "webidl-conversions": "3.0.1" 2982 | }, 2983 | "dependencies": { 2984 | "webidl-conversions": { 2985 | "version": "3.0.1", 2986 | "resolved": "https://registry.npmjs.org/webidl-conversions/-/webidl-conversions-3.0.1.tgz", 2987 | "integrity": "sha1-JFNCdeKnvGvnvIZhHMFq4KVlSHE=", 2988 | "dev": true 2989 | } 2990 | } 2991 | }, 2992 | "which": { 2993 | "version": "1.3.0", 2994 | "resolved": "https://registry.npmjs.org/which/-/which-1.3.0.tgz", 2995 | "integrity": "sha512-xcJpopdamTuY5duC/KnTTNBraPK54YwpenP4lzxU8H91GudWpFv38u0CKjclE1Wi2EH2EDz5LRcHcKbCIzqGyg==", 2996 | "dev": true, 2997 | "requires": { 2998 | "isexe": "2.0.0" 2999 | } 3000 | }, 3001 | "wordwrap": { 3002 | "version": "1.0.0", 3003 | "resolved": "https://registry.npmjs.org/wordwrap/-/wordwrap-1.0.0.tgz", 3004 | "integrity": "sha1-J1hIEIkUVqQXHI0CJkQa3pDLyus=", 3005 | "dev": true 3006 | }, 3007 | "wrappy": { 3008 | "version": "1.0.2", 3009 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 3010 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=", 3011 | "dev": true 3012 | }, 3013 | "write": { 3014 | "version": "0.2.1", 3015 | "resolved": "https://registry.npmjs.org/write/-/write-0.2.1.tgz", 3016 | "integrity": "sha1-X8A4KOJkzqP+kUVUdvejxWbLB1c=", 3017 | "dev": true, 3018 | "requires": { 3019 | "mkdirp": "0.5.1" 3020 | } 3021 | }, 3022 | "xml-name-validator": { 3023 | "version": "2.0.1", 3024 | "resolved": "https://registry.npmjs.org/xml-name-validator/-/xml-name-validator-2.0.1.tgz", 3025 | "integrity": "sha1-TYuPHszTQZqjYgYb7O9RXh5VljU=", 3026 | "dev": true 3027 | }, 3028 | "yallist": { 3029 | "version": "2.1.2", 3030 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-2.1.2.tgz", 3031 | "integrity": "sha1-HBH5IY8HYImkfdUS+TxmmaaoHVI=", 3032 | "dev": true 3033 | } 3034 | } 3035 | } 3036 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "d3-component", 3 | "version": "3.1.0", 4 | "description": "A D3 component system.", 5 | "keywords": [ 6 | "d3", 7 | "d3-module" 8 | ], 9 | "license": "BSD-3-Clause", 10 | "main": "build/d3-component.js", 11 | "jsnext:main": "index", 12 | "module": "index", 13 | "homepage": "https://github.com/curran/d3-component", 14 | "repository": { 15 | "type": "git", 16 | "url": "https://github.com/curran/d3-component.git" 17 | }, 18 | "scripts": { 19 | "lint": "eslint src", 20 | "lint:fix": "eslint src --fix", 21 | "pretest": "npm run lint && rm -rf build && mkdir build && rollup -c", 22 | "test": "tape 'test/**/*-test.js'", 23 | "prepublish": "npm run test && uglifyjs build/d3-component.js -c -m -o build/d3-component.min.js", 24 | "postpublish": "git push; git push --tags" 25 | }, 26 | "devDependencies": { 27 | "babel-plugin-external-helpers": "^6.22.0", 28 | "babel-preset-es2015": "^6.24.1", 29 | "babel-register": "^6.26.0", 30 | "babelrc-rollup": "^3.0.0", 31 | "d3-transition": "^1.1.1", 32 | "eslint": "^4.13.1", 33 | "eslint-config-airbnb-base": "^12.1.0", 34 | "eslint-plugin-import": "^2.8.0", 35 | "jsdom": "^9.11.0", 36 | "rollup": "0.52", 37 | "rollup-plugin-babel": "^3.0.2", 38 | "tape": "4", 39 | "uglify-js": "3" 40 | }, 41 | "dependencies": { 42 | "d3-selection": "^1.2.0" 43 | } 44 | } 45 | -------------------------------------------------------------------------------- /rollup.config.js: -------------------------------------------------------------------------------- 1 | import babel from 'rollup-plugin-babel'; 2 | import babelrc from 'babelrc-rollup'; 3 | 4 | let pkg = require('./package.json'); 5 | let external = Object.keys(pkg.dependencies); 6 | 7 | export default { 8 | input: 'index.js', 9 | plugins: [ 10 | babel(babelrc()), 11 | ], 12 | external: external, 13 | output: [ 14 | { 15 | file: pkg.main, 16 | format: 'umd', 17 | name: 'd3', 18 | sourcemap: true 19 | } 20 | ], 21 | globals: { 22 | 'd3-selection': 'd3' 23 | } 24 | }; 25 | -------------------------------------------------------------------------------- /src/component.js: -------------------------------------------------------------------------------- 1 | import { select } from 'd3-selection'; 2 | 3 | // The name of the property used to store component instances on DOM nodes. 4 | const instanceProperty = '__instance__'; 5 | 6 | // Sets the component instance property on the given DOM node. 7 | function setInstance(node, value) { 8 | node[instanceProperty] = value; 9 | } 10 | 11 | // Gets the component instance property from the given DOM node. 12 | const getInstance = node => node[instanceProperty]; 13 | 14 | // Computes the data to pass into the data join from component invocation arguments. 15 | function dataArray(data, context) { 16 | data = Array.isArray(data) ? data : [data]; 17 | return context ? data.map(d => Object.assign(Object.create(context), d)) : data; 18 | } 19 | 20 | // Destroys a descendant component instance. 21 | // Does not remove its DOM node, as one if its ancestors will be removed. 22 | function destroyDescendant() { 23 | const instance = getInstance(this); 24 | if (instance) { 25 | const { 26 | selection, datum, destroy, index, 27 | } = instance; 28 | destroy(selection, datum, index); 29 | } 30 | } 31 | 32 | // Destroys the component instance and its descendant component instances. 33 | function destroyInstance() { 34 | const { 35 | selection, datum, destroy, index, 36 | } = getInstance(this); 37 | selection.selectAll('*').each(destroyDescendant); 38 | const transition = destroy(selection, datum, index); 39 | (transition || selection).remove(); 40 | } 41 | 42 | // No operation. 43 | const noop = () => null; 44 | 45 | // The component constructor, exposed as d3.component. 46 | export default function (tagName, className) { 47 | // Values set via setters. 48 | let create = noop; 49 | let render = noop; 50 | let destroy = noop; 51 | let key = null; 52 | 53 | // Checks if the given DOM node is managed by this component. 54 | function belongsToMe(node) { 55 | const instance = getInstance(node); 56 | return instance && instance.component === component; 57 | } 58 | 59 | // Returns DOM children managed by this component. 60 | function mine() { 61 | return Array.from(this.children).filter(belongsToMe); 62 | } 63 | 64 | // Creates a new component instance and stores it on the DOM node. 65 | function createInstance(datum, index) { 66 | const selection = select(this); 67 | setInstance(this, { 68 | component, selection, destroy, datum, index, 69 | }); 70 | create(selection, datum, index); 71 | } 72 | 73 | // Renders the component instance, and stores its datum for later use (in destroy). 74 | function renderInstance(datum, index) { 75 | const instance = getInstance(this); 76 | instance.datum = datum; 77 | render(instance.selection, datum, index); 78 | } 79 | 80 | // The returned component instance. 81 | function component(container, data, context) { 82 | const selection = container.nodeName ? select(container) : container; 83 | const instances = selection 84 | .selectAll(mine) 85 | .data(dataArray(data, context), key); 86 | instances 87 | .exit() 88 | .each(destroyInstance); 89 | return instances 90 | .enter().append(tagName) 91 | .attr('class', className) 92 | .each(createInstance) 93 | .merge(instances) 94 | .each(renderInstance); 95 | } 96 | 97 | // Chainable setters. 98 | component.render = (_) => { render = _; return component; }; 99 | component.create = (_) => { create = _; return component; }; 100 | component.destroy = (_) => { destroy = _; return component; }; 101 | component.key = (_) => { key = _; return component; }; 102 | 103 | return component; 104 | } 105 | -------------------------------------------------------------------------------- /test/README.md: -------------------------------------------------------------------------------- 1 | These tests use [Tape](https://github.com/substack/tape), and are written to match the structure of tests in [other D3 repositories](https://github.com/d3). These tests were originally scaffolded out by following instructions in [Let’s Make a (D3) Plugin](https://bost.ocks.org/mike/d3-plugin/). 2 | 3 | To run these tests, invoke the `test` script defined in `package.json` by running: 4 | 5 | `npm test` 6 | -------------------------------------------------------------------------------- /test/basics-test.js: -------------------------------------------------------------------------------- 1 | var tape = require("tape"), 2 | jsdom = require("jsdom"), 3 | d3_selection = require("d3-selection"), 4 | d3_component = require("../"), 5 | d3 = Object.assign(d3_selection, d3_component); 6 | 7 | 8 | var paragraphDatum, 9 | paragraph = d3.component("p") 10 | .render(function (selection, d){ 11 | paragraphDatum = d; 12 | selection.text(d); 13 | }); 14 | 15 | var createArgs, 16 | renderArgs, 17 | destroyArgs, 18 | argsTester = d3.component("div") 19 | .create(function (selection, d){ 20 | createArgs = arguments; 21 | }) 22 | .render(function (selection, d){ 23 | renderArgs = arguments; 24 | }) 25 | .destroy(function (selection, d){ 26 | destroyArgs = arguments; 27 | }); 28 | 29 | 30 | tape("A component should render a single instance.", function(test) { 31 | var div = d3.select(jsdom.jsdom().body).append("div"); 32 | div.call(paragraph, "Hello Component"); 33 | test.equal(div.html(), "

Hello Component

"); 34 | test.end(); 35 | }); 36 | 37 | tape("A component should accept a DOM node in place of a selection.", function(test) { 38 | var div = d3.select(jsdom.jsdom().body).append("div"); 39 | paragraph(div.node(), "Hello Component"); 40 | test.equal(div.html(), "

Hello Component

"); 41 | test.end(); 42 | }); 43 | 44 | tape("A component should render multiple instances.", function(test) { 45 | var div = d3.select(jsdom.jsdom().body).append("div"); 46 | 47 | // Enter 48 | div.call(paragraph, [ "foo", "bar" ]); 49 | test.equal(div.html(), "

foo

bar

"); 50 | 51 | // Update + Enter 52 | div.call(paragraph, [ "fooz", "barz", "baz" ]) 53 | test.equal(div.html(), "

fooz

barz

baz

"); 54 | 55 | // Update + Exit 56 | div.call(paragraph, [ "fooz", "baz" ]) 57 | test.equal(div.html(), "

fooz

baz

"); 58 | 59 | // Exit 60 | div.call(paragraph, []); 61 | test.equal(div.html(), ""); 62 | 63 | test.end(); 64 | }); 65 | 66 | tape("A component should be passed undefined as datum when data not specified.", function(test) { 67 | var div = d3.select(jsdom.jsdom().body).append("div"); 68 | div.call(paragraph); 69 | test.equal(div.html(), '

'); 70 | test.equal(typeof paragraphDatum, "undefined"); 71 | test.end(); 72 | }); 73 | 74 | tape("Livecycle arguments should be only (selection, d).", function(test) { 75 | var div = d3.select(jsdom.jsdom().body).append("div"); 76 | div.call(argsTester, ["a", "b"]); 77 | div.call(argsTester, ["a"]); 78 | test.equal(createArgs.length, 3) 79 | test.equal(renderArgs.length, 3) 80 | test.equal(destroyArgs.length, 3); 81 | test.end(); 82 | }); 83 | 84 | tape("A component should return its merged Enter + Update selection.", function(test) { 85 | var div = d3.select(jsdom.jsdom().body).append("div"); 86 | test.equal(paragraph(div, "Text").text(), "Text"); // Enter 87 | test.equal(paragraph(div, "Text").text(), "Text"); // Update 88 | test.end(); 89 | }); 90 | -------------------------------------------------------------------------------- /test/conditional-rendering-test.js: -------------------------------------------------------------------------------- 1 | var tape = require("tape"), 2 | jsdom = require("jsdom"), 3 | d3_selection = require("d3-selection"), 4 | d3_component = require("../"), 5 | d3 = Object.assign(d3_selection, d3_component), 6 | post = require("./nesting-test").post; 7 | 8 | 9 | var apple = d3.component("span", "apple"), 10 | orange = d3.component("span", "orange"), 11 | 12 | // One of the limitations of this library 13 | // is that you can't have apples and oranges mixed as peers 14 | // with a data-driven ordering, so you need to introduce 15 | // an intermediate "switcher" component, like this fruit component here. 16 | fruit = d3.component("div") 17 | .render(function (selection, d){ 18 | selection 19 | .call(apple, d === "apple" || []) // If type matches, pass true as datum, else pass []. 20 | .call(orange, d === "orange" || []) 21 | }); 22 | 23 | 24 | tape("Conditional rendering.", function(test) { 25 | var div = d3.select(jsdom.jsdom().body).append("div"); 26 | 27 | // Enter 28 | div.call(fruit, [ "apple", "orange", "apple", "apple", "orange" ]); 29 | test.equal(div.html(), [ 30 | '
', 31 | '
', 32 | '
', 33 | '
', 34 | '
' 35 | ].join("")); 36 | 37 | // Update + Exit 38 | div.call(fruit, [ "orange", "apple", "apple" ]); 39 | test.equal(div.html(), [ 40 | '
', 41 | '
', 42 | '
' 43 | ].join("")); 44 | 45 | // Exit 46 | div.call(fruit, []); 47 | test.equal(div.html(), ""); 48 | 49 | test.end(); 50 | }); 51 | -------------------------------------------------------------------------------- /test/containment-test.js: -------------------------------------------------------------------------------- 1 | var tape = require("tape"), 2 | jsdom = require("jsdom"), 3 | d3_selection = require("d3-selection"), 4 | d3_component = require("../"), 5 | d3 = Object.assign(d3_selection, d3_component), 6 | post = require("./nesting-test").post; 7 | 8 | 9 | var card = d3.component("div", "card") 10 | .create(function (selection){ 11 | selection 12 | .append("div") 13 | .attr("class", "card-block") 14 | .append("div") 15 | .attr("class", "card-text"); 16 | }) 17 | .render(function (selection, d){ 18 | selection 19 | .select(".card-text") 20 | .call(d.childComponent, d.childProps); 21 | }); 22 | 23 | 24 | tape("Containment.", function(test) { 25 | var div = d3.select(jsdom.jsdom().body).append("div"); 26 | div.call(card, { 27 | childComponent: post, 28 | childProps: [ 29 | { title: "A Title", content: "a content" }, 30 | { title: "B Title", content: "b content" }, 31 | ] 32 | }); 33 | test.equal(div.html(), [ 34 | '
', 35 | '
', 36 | '
', 37 | '

A Title

a content

', 38 | '

B Title

b content

', 39 | "
", 40 | "
", 41 | "
" 42 | ].join("")); 43 | 44 | test.end(); 45 | }); 46 | -------------------------------------------------------------------------------- /test/context-test.js: -------------------------------------------------------------------------------- 1 | var tape = require("tape"), 2 | jsdom = require("jsdom"), 3 | d3_selection = require("d3-selection"), 4 | d3_component = require("../"), 5 | d3 = Object.assign(d3_selection, d3_component); 6 | 7 | var paragraph = d3.component("p") 8 | .render(function (selection, d){ 9 | selection.text(d.text); 10 | d.callback(); 11 | }); 12 | 13 | tape("A component should accept a context.", function(test) { 14 | var div = d3.select(jsdom.jsdom().body).append("div"); 15 | 16 | var data = [ 17 | { text: "foo" }, 18 | { text: "bar" } 19 | ]; 20 | 21 | var count = 0; 22 | var context = { 23 | callback: function (){ 24 | count++; 25 | } 26 | }; 27 | 28 | // Multiple instances 29 | div.call(paragraph, data, context); 30 | test.equal(div.html(), "

foo

bar

"); 31 | test.equal(count, 2); 32 | 33 | // Single instance 34 | div.call(paragraph, data[0], context); 35 | test.equal(div.html(), "

foo

"); 36 | test.equal(count, 3); 37 | 38 | // Data properties override context properties. 39 | context.text = "pwn"; 40 | div.call(paragraph, data[0], context); 41 | test.equal(div.html(), "

foo

"); 42 | test.equal(count, 4); 43 | 44 | test.end(); 45 | 46 | }); 47 | 48 | -------------------------------------------------------------------------------- /test/exit-test.js: -------------------------------------------------------------------------------- 1 | var tape = require("tape"), 2 | jsdom = require("jsdom"), 3 | d3_transition = require("d3-transition"), 4 | d3_selection = require("d3-selection"), 5 | d3_component = require("../"), 6 | d3 = Object.assign(d3_selection, d3_component); 7 | 8 | var datum, 9 | customExit = d3.component("p") 10 | .destroy(function (selection, d){ 11 | datum = d; 12 | return selection.transition().duration(10); 13 | }); 14 | 15 | tape("A component should be able to specify custom destroy transitions.", function(test) { 16 | var div = d3.select(jsdom.jsdom().body).append("div"); 17 | 18 | div.call(customExit); 19 | test.equal(div.html(), "

"); 20 | 21 | div.call(customExit, []); 22 | 23 | // The transition is happening, so DOM element not removed yet. 24 | test.equal(div.html(), "

"); 25 | 26 | // DOM element removed after transition ends. 27 | setTimeout(function (){ 28 | test.equal(div.html(), ""); 29 | test.end(); 30 | }, 30); // The transition lasts 10 ms, so it should be done after 30. 31 | }); 32 | 33 | tape("Datum passed to destroy should be most recent.", function(test) { 34 | var div = d3.select(jsdom.jsdom().body).append("div"); 35 | 36 | div.call(customExit, "a"); 37 | div.call(customExit, []); 38 | test.equal(datum, "a"); 39 | 40 | div.call(customExit, "a"); 41 | div.call(customExit, "b"); 42 | div.call(customExit, []); 43 | test.equal(datum, "b"); // Fails here, uses "a" 44 | 45 | test.end(); 46 | }); 47 | -------------------------------------------------------------------------------- /test/index-test.js: -------------------------------------------------------------------------------- 1 | var tape = require("tape"), 2 | jsdom = require("jsdom"), 3 | d3_selection = require("d3-selection"), 4 | d3_component = require("../"), 5 | d3 = Object.assign(d3_selection, d3_component); 6 | 7 | var createArgs = [], 8 | renderArgs = [], 9 | destroyArgs = [], 10 | argsTester = d3.component("div") 11 | .create(function () { 12 | createArgs.push(arguments); 13 | }) 14 | .render(function () { 15 | renderArgs.push(arguments); 16 | }) 17 | .destroy(function (selection, datum, index) { 18 | destroyArgs.push(arguments); 19 | }); 20 | 21 | tape("Multiple instances should have correct indices.", function(test) { 22 | createArgs = []; 23 | renderArgs = []; 24 | destroyArgs = []; 25 | 26 | var div = d3.select(jsdom.jsdom().body).append("div"); 27 | div.call(argsTester, ["one", "two", "three"]); 28 | 29 | test.equal(createArgs.length, 3); 30 | test.equal(createArgs[0][2], 0); 31 | test.equal(createArgs[1][2], 1); 32 | test.equal(createArgs[2][2], 2); 33 | 34 | test.equal(renderArgs.length, 3); 35 | test.equal(renderArgs[0][2], 0); 36 | test.equal(renderArgs[1][2], 1); 37 | test.equal(renderArgs[2][2], 2); 38 | 39 | div.call(argsTester, []); 40 | test.equal(destroyArgs.length, 3); 41 | test.equal(destroyArgs[0][2], 0); 42 | test.equal(destroyArgs[1][2], 1); 43 | test.equal(destroyArgs[2][2], 2); 44 | 45 | test.end(); 46 | }); 47 | 48 | tape("Single instances should have index 0.", function(test) { 49 | createArgs = []; 50 | renderArgs = []; 51 | destroyArgs = []; 52 | 53 | var div = d3.select(jsdom.jsdom().body).append("div"); 54 | div.call(argsTester, "one"); 55 | 56 | test.equal(createArgs.length, 1); 57 | test.equal(createArgs[0][2], 0); 58 | 59 | test.equal(renderArgs.length, 1); 60 | test.equal(renderArgs[0][2], 0); 61 | 62 | div.call(argsTester, []); 63 | test.equal(destroyArgs.length, 1); 64 | 65 | test.end(); 66 | }); 67 | -------------------------------------------------------------------------------- /test/key-function-test.js: -------------------------------------------------------------------------------- 1 | var tape = require("tape"), 2 | jsdom = require("jsdom"), 3 | d3_selection = require("d3-selection"), 4 | d3_component = require("../"), 5 | d3 = Object.assign(d3_selection, d3_component); 6 | 7 | 8 | var created, 9 | destroyed, 10 | apple = d3.component("span", "apple") 11 | .create(function (){ created++; }) 12 | .destroy(function(){ destroyed++; }), 13 | orange = d3.component("span", "orange") 14 | .create(function (){ created++; }) 15 | .destroy(function(){ destroyed++; }), 16 | renderFruit = function (selection, d){ 17 | selection 18 | .call(apple, d.type === "apple" ? true : []) 19 | .call(orange, d.type === "orange" ? true : []); 20 | }, 21 | fruitNotKeyed = d3.component("div", "fruit") 22 | .render(renderFruit), 23 | fruitKeyed = d3.component("div", "fruit") 24 | .render(renderFruit) 25 | .key(function (d){ return d.id; }); 26 | 27 | tape("Use index as key if key function not specified.", function(test) { 28 | var div = d3.select(jsdom.jsdom().body).append("div"); 29 | 30 | // Enter. 31 | created = destroyed = 0; 32 | div.call(fruitNotKeyed, [ 33 | { id: "a", type: "apple"}, 34 | { id: "b", type: "orange"} 35 | ]); 36 | test.equal(created, 2); 37 | test.equal(destroyed, 0); 38 | 39 | // Update with swap (unnecessary creation and destruction). 40 | created = destroyed = 0; 41 | div.call(fruitNotKeyed, [ 42 | { id: "b", type: "orange"}, 43 | { id: "a", type: "apple"} 44 | ]); 45 | test.equal(created, 2); 46 | test.equal(destroyed, 2); 47 | 48 | // Exit (tests recursive destruction). 49 | created = destroyed = 0; 50 | div.call(fruitNotKeyed, []); 51 | test.equal(created, 0); 52 | test.equal(destroyed, 2); 53 | 54 | test.end(); 55 | }); 56 | 57 | tape("Use key function if specified.", function(test) { 58 | var div = d3.select(jsdom.jsdom().body).append("div"); 59 | 60 | // Enter. 61 | created = destroyed = 0; 62 | div.call(fruitKeyed, [ 63 | { id: "a", type: "apple"}, 64 | { id: "b", type: "orange"} 65 | ]); 66 | test.equal(created, 2); 67 | test.equal(destroyed, 0); 68 | 69 | // Update with swap (no unnecessary creation and destruction). 70 | created = destroyed = 0; 71 | div.call(fruitKeyed, [ 72 | { id: "b", type: "orange"}, 73 | { id: "a", type: "apple"} 74 | ]); 75 | test.equal(created, 0); 76 | test.equal(destroyed, 0); 77 | 78 | // Exit (tests recursive destruction). 79 | created = destroyed = 0; 80 | div.call(fruitKeyed, []); 81 | test.equal(created, 0); 82 | test.equal(destroyed, 2); 83 | 84 | test.end(); 85 | }); 86 | -------------------------------------------------------------------------------- /test/nesting-test.js: -------------------------------------------------------------------------------- 1 | var tape = require("tape"), 2 | jsdom = require("jsdom"), 3 | d3_selection = require("d3-selection"), 4 | d3_component = require("../"), 5 | d3 = Object.assign(d3_selection, d3_component); 6 | 7 | 8 | var heading = d3.component("h1") 9 | .render(function (selection, d){ 10 | selection.text(d); 11 | }), 12 | paragraph = d3.component("p") 13 | .render(function (selection, d){ 14 | selection.text(d); 15 | }), 16 | post = d3.component("div", "post") 17 | .render(function (selection, d){ 18 | selection 19 | .call(heading, d.title) 20 | .call(paragraph, d.content); 21 | }); 22 | 23 | 24 | tape("Nesting single instance.", function(test) { 25 | var div = d3.select(jsdom.jsdom().body).append("div"); 26 | 27 | div.call(post, { 28 | title: "Title", 29 | content: "Content here." 30 | }); 31 | 32 | test.equal(div.html(), [ 33 | '
', 34 | '

Title

', 35 | '

Content here.

', 36 | '
' 37 | ].join("")); 38 | 39 | test.end(); 40 | }); 41 | 42 | tape("Nesting multiple instances.", function(test) { 43 | var div = d3.select(jsdom.jsdom().body).append("div"); 44 | 45 | // Enter 46 | div.call(post, [ 47 | { title: "A", content: "a" }, 48 | { title: "B", content: "b" }, 49 | ]); 50 | test.equal(div.html(), [ 51 | '

A

a

', 52 | '

B

b

' 53 | ].join("")); 54 | 55 | // Enter + Update 56 | div.call(post, [ 57 | { title: "D", content: "d" }, 58 | { title: "E", content: "e" }, 59 | { title: "F", content: "f" }, 60 | ]); 61 | test.equal(div.html(), [ 62 | '

D

d

', 63 | '

E

e

', 64 | '

F

f

' 65 | ].join("")); 66 | 67 | // Exit 68 | div.call(post, []); 69 | test.equal(div.html(), ""); 70 | 71 | test.end(); 72 | }); 73 | 74 | 75 | module.exports = { 76 | post: post 77 | }; 78 | -------------------------------------------------------------------------------- /test/recursive-component-test.js: -------------------------------------------------------------------------------- 1 | var tape = require("tape"), 2 | jsdom = require("jsdom"), 3 | d3 = Object.assign(require("../"), require("d3-selection")); 4 | 5 | 6 | var recursiveComponent = d3.component("div") 7 | .render(function (selection, d){ 8 | selection 9 | .attr("class", d.class) 10 | .call(recursiveComponent, d.children || []); 11 | }); 12 | 13 | 14 | tape("Recursive component.", function(test) { 15 | var div = d3.select(jsdom.jsdom().body).append("div"); 16 | 17 | div.call(recursiveComponent, { class: "a" }); 18 | test.equal(div.html(), '
'); 19 | 20 | div.call(recursiveComponent, { 21 | class: "a", 22 | children: [{ class: "b" }] 23 | }); 24 | test.equal(div.html(), '
'); 25 | 26 | div.call(recursiveComponent, { 27 | class: "a", 28 | children: [ 29 | { 30 | class: "b", 31 | children: [ 32 | { class: "c" } 33 | ] 34 | }, 35 | { class: "d" } 36 | ] 37 | }); 38 | test.equal(div.html(), [ 39 | '
', 40 | '
', 41 | '
', 42 | '
', 43 | '
' 44 | ].join("")); 45 | 46 | test.end(); 47 | }); 48 | -------------------------------------------------------------------------------- /test/recursive-exit-test.js: -------------------------------------------------------------------------------- 1 | var tape = require("tape"), 2 | jsdom = require("jsdom"), 3 | d3_selection = require("d3-selection"), 4 | d3_component = require("../"), 5 | d3 = Object.assign(d3_selection, d3_component); 6 | 7 | 8 | var leafDestroyed = 0, 9 | leaf = d3.component("div", "leaf") 10 | .destroy(function (){ 11 | leafDestroyed ++; 12 | }) 13 | twig = d3.component("div", "twig") 14 | .render(function (selection){ 15 | selection.call(leaf); 16 | }); 17 | branch = d3.component("div", "branch") 18 | .render(function (selection){ 19 | selection.call(twig, [1, 2]); 20 | }), 21 | treeDestroyed = 0, 22 | tree = d3.component("div", "tree") 23 | .create(function (selection){ 24 | selection 25 | .append("div") 26 | .attr("class", "trunk"); 27 | }) 28 | .render(function (selection){ 29 | selection 30 | .select(".trunk") 31 | .call(branch, [1, 2, 3]); 32 | }) 33 | .destroy(function (){ 34 | treeDestroyed++; 35 | }); 36 | 37 | 38 | tape("Recursive destroy.", function(test) { 39 | var div = d3.select(jsdom.jsdom().body).append("div"); 40 | 41 | div.call(tree); 42 | test.equal(div.html(), [ 43 | '
', 44 | '
', 45 | '
', 46 | '
', 47 | '
', 48 | '
', 49 | '
', 50 | '
', 51 | '
', 52 | '
', 53 | '
', 54 | '
', 55 | '
', 56 | '
', 57 | '
', 58 | '
', 59 | '
', 60 | '
', 61 | '
', 62 | '
', 63 | '
', 64 | '
', 65 | '
', 66 | '
', 67 | '
', 68 | '
', 69 | '
', 70 | '
', 71 | ].join("")); 72 | test.equal(leafDestroyed, 0); 73 | 74 | div.call(tree, []); 75 | test.equal(leafDestroyed, 6); 76 | test.equal(treeDestroyed, 1); 77 | 78 | test.end(); 79 | }); 80 | -------------------------------------------------------------------------------- /test/specificity-test.js: -------------------------------------------------------------------------------- 1 | var tape = require("tape"), 2 | jsdom = require("jsdom"), 3 | d3_selection = require("d3-selection"), 4 | d3_component = require("../"), 5 | d3 = Object.assign(d3_selection, d3_component); 6 | 7 | 8 | var paragraphA = d3.component("p", "some-class") 9 | .render(function (selection){ 10 | selection.text("A"); 11 | }), 12 | paragraphB = d3.component("p", "some-class") 13 | .render(function (selection){ 14 | selection.text("B"); 15 | }); 16 | 17 | 18 | tape("Components with the same tag and class should be able to coexist as DOM siblings.", function(test) { 19 | var div = d3.select(jsdom.jsdom().body).append("div") 20 | .call(paragraphA) 21 | .call(paragraphB); 22 | test.equal(div.html(), '

A

B

'); 23 | test.end(); 24 | }); 25 | 26 | tape("Components should coexist with non-component DOM siblings with the same tag and class.", function(test) { 27 | var div = d3.select(jsdom.jsdom().body).append("div"); 28 | div.append("p").attr("class", "some-class").text("Non-component node"); 29 | div.call(paragraphA); 30 | test.equal(div.html(), '

Non-component node

A

'); 31 | test.end(); 32 | }); 33 | --------------------------------------------------------------------------------