├── .babelrc ├── .editorconfig ├── .eslintignore ├── .eslintrc ├── .gitignore ├── .travis.yml ├── LICENSE ├── README.md ├── package-lock.json ├── package.json ├── rollup.config.js └── src ├── components ├── Provider.js ├── createGraphQLHoc.js ├── createWithClientHoc.js ├── createWithOperationsHoc.js ├── graphql.js ├── withClient.js └── withOperations.js ├── index.js └── utils ├── compose.js ├── computeNextState.js ├── convertSubscriptionToQuery.js ├── createDocumentAST.js ├── getOperationName.js ├── getOperationType.js ├── getPropNameOr.js ├── getRequiredFragments.js ├── hasDirectives.js ├── index.js ├── isEmpty.js ├── isFragmentDefinition.js ├── isNil.js ├── isOperationDefinition.js ├── mapObject.js ├── mergeErrors.js ├── mergeOperations.js ├── omit.js ├── operationsMap.js ├── rejectDirectives.js ├── removeEmptyOrNilProps.js ├── shallowEqual.js └── when.js /.babelrc: -------------------------------------------------------------------------------- 1 | { 2 | "plugins": [ 3 | ["transform-class-properties", { "loose": true }], 4 | "transform-object-rest-spread", 5 | "transform-async-generator-functions" 6 | ], 7 | "presets": [ 8 | ["es2015", { "loose": true, "modules": false }], 9 | "react", 10 | "stage-0" 11 | ], 12 | "env": { 13 | "cjs": { 14 | "plugins": [["transform-es2015-modules-commonjs", { "loose": true }]] 15 | }, 16 | "rollup": { 17 | "plugins": ["external-helpers"] 18 | } 19 | } 20 | } 21 | -------------------------------------------------------------------------------- /.editorconfig: -------------------------------------------------------------------------------- 1 | root = true 2 | 3 | [*] 4 | indent_style = space 5 | indent_size = 2 6 | -------------------------------------------------------------------------------- /.eslintignore: -------------------------------------------------------------------------------- 1 | lib 2 | es 3 | dist 4 | -------------------------------------------------------------------------------- /.eslintrc: -------------------------------------------------------------------------------- 1 | { 2 | "parser": "babel-eslint", 3 | "extends": ["standard", "plugin:react/recommended"], 4 | "plugins": [ 5 | "react" 6 | ], 7 | "rules": { 8 | "comma-dangle": ["warn", "always"], 9 | "array-bracket-spacing": ["warn", "always"], 10 | "object-curly-spacing": ["warn", "always"], 11 | "no-sequences": ["off"], 12 | "no-console": ["warn"], 13 | "standard/object-curly-even-spacing": ["off"] 14 | }, 15 | "parserOptions": { 16 | "ecmaVersion": 6, 17 | "sourceType": "module", 18 | "ecmaFeatures": { 19 | "classes": true, 20 | "jsx": true, 21 | "experimentalObjectRestSpread": true 22 | }, 23 | }, 24 | } 25 | -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | .DS_Store 2 | 3 | # Logs 4 | logs 5 | *.log 6 | npm-debug.log* 7 | yarn-debug.log* 8 | yarn-error.log* 9 | 10 | # Runtime data 11 | pids 12 | *.pid 13 | *.seed 14 | *.pid.lock 15 | 16 | # Directory for instrumented libs generated by jscoverage/JSCover 17 | lib-cov 18 | 19 | # Coverage directory used by tools like istanbul 20 | coverage 21 | 22 | # nyc test coverage 23 | .nyc_output 24 | 25 | # Grunt intermediate storage (http://gruntjs.com/creating-plugins#storing-task-files) 26 | .grunt 27 | 28 | # Bower dependency directory (https://bower.io/) 29 | bower_components 30 | 31 | # node-waf configuration 32 | .lock-wscript 33 | 34 | # Dist 35 | dist 36 | es 37 | lib 38 | 39 | # Dependency directories 40 | node_modules/ 41 | jspm_packages/ 42 | 43 | # Typescript v1 declaration files 44 | typings/ 45 | 46 | # Optional npm cache directory 47 | .npm 48 | 49 | # Optional eslint cache 50 | .eslintcache 51 | 52 | # Optional REPL history 53 | .node_repl_history 54 | 55 | # Output of 'npm pack' 56 | *.tgz 57 | 58 | # Yarn Integrity file 59 | .yarn-integrity 60 | 61 | # dotenv environment variables file 62 | .env 63 | -------------------------------------------------------------------------------- /.travis.yml: -------------------------------------------------------------------------------- 1 | language: node_js 2 | node_js: 3 | - "8.9.0" 4 | 5 | deploy: 6 | provider: npm 7 | email: achimvionut@gmail.com 8 | api_key: $NPM_TOKEN 9 | skip_cleanup: true 10 | on: 11 | tags: true 12 | -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | MIT License 2 | 3 | Copyright (c) 2017 Ionut Achim 4 | 5 | Permission is hereby granted, free of charge, to any person obtaining a copy 6 | of this software and associated documentation files (the "Software"), to deal 7 | in the Software without restriction, including without limitation the rights 8 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 9 | copies of the Software, and to permit persons to whom the Software is 10 | furnished to do so, subject to the following conditions: 11 | 12 | The above copyright notice and this permission notice shall be included in all 13 | copies or substantial portions of the Software. 14 | 15 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 16 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 17 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 18 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 19 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 20 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE 21 | SOFTWARE. 22 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # React-Blips 2 | 3 | Official React bindings for [**Blips**](https://github.com/monojack/blips) 4 | 5 | [![build status](https://travis-ci.org/monojack/react-blips.svg?branch=master)](https://travis-ci.org/monojack/react-blips) 6 | [![npm version](https://img.shields.io/npm/v/react-blips.svg)](https://www.npmjs.com/package/react-blips) 7 | [![npm downloads](https://img.shields.io/npm/dm/react-blips.svg)](https://www.npmjs.com/package/react-blips) 8 | 9 | ## Table of contents: 10 | 11 | * [Installation](#installation) 12 | * [Usage](#usage) 13 | * [The **Provider** instance](#the-provider-instance) 14 | * [Connect components with **graphql**](#connect-components-with-graphql) 15 | * [The `config` object](#the-config-object) 16 | * [The `data` prop](#the-data-prop) 17 | * [The `queries` prop](#the-queries-prop) 18 | * [The `mutations` prop](#the-mutations-prop) 19 | * [The `withOperations` HOC](#the-withoperations-hoc) 20 | * [The `withClient` HOC](#the-withclient-hoc) 21 | * [Subscribing to state changes](#subscribing-to-state-changes) 22 | * [Tips](#tips) 23 | * [Examples](https://github.com/monojack/blips/tree/master/examples) 24 | 25 | ## Installation 26 | 27 | ```bash 28 | npm i react-blips 29 | ``` 30 | 31 | This assumes you are using **npm** and have already installed 32 | [**blips**](https://www.npmjs.com/package/blips) and 33 | [**graphql**](https://www.npmjs.com/package/graphql) 34 | 35 | ## Usage 36 | 37 | #### The `Provider` instance 38 | 39 | To get started you'll have to 40 | [create the blips client](https://github.com/monojack/blips#the-client-instance) 41 | and pass it as a prop to the `Provider` component 42 | 43 | ```js 44 | import { BlipsClient } from 'blips' 45 | import { Provider } from 'react-blips' 46 | // ... 47 | 48 | const client = new BlipsClient(...) 49 | 50 | ReactDOM.render( 51 | 52 | 53 | , 54 | document.getElementById('root') 55 | ) 56 | ``` 57 | 58 | #### Connect components with `graphql` 59 | 60 | `graphql` is the function that creates container components which are connected 61 | to the store. 62 | 63 | `graphql(...operations [, config])(BaseComponent)` 64 | 65 | ```js 66 | // ... 67 | import { graphql } from 'react-blips' 68 | 69 | const TodoList = ({ data: { allTodos = [] } }) => ( 70 | 80 | ) 81 | 82 | const allTodosQuery = ` 83 | query allTodosQuery { 84 | allTodos { 85 | id 86 | label 87 | completed 88 | } 89 | } 90 | ` 91 | 92 | export default graphql(allTodosQuery)(TodoList) 93 | ``` 94 | 95 | You can add as many operations as you need, the only requirement is that if you 96 | provide a `config` object, it must be the last argument. 97 | 98 | ```js 99 | // ... 100 | const config = { ... } 101 | 102 | export default graphql(allTodosQuery, allUsersQuery, config)(TodoList) 103 | ``` 104 | 105 | By default, the result of your queries will be added to the component's props 106 | under the `data` key: 107 | 108 | ```js 109 | props: { 110 | data: { 111 | allTodos: [...], 112 | allUsers: [...] 113 | } 114 | } 115 | ``` 116 | 117 | #### The `data` prop 118 | 119 | In addition to the fields you query, the `data` prop may also contain a 120 | `loading` flag and/or an `errors` object 121 | 122 | ##### `loading` 123 | 124 | Indicates whether or not the operations are still executing. 125 | 126 | ```js 127 | props: { 128 | data: { 129 | loading: true 130 | } 131 | } 132 | ``` 133 | 134 | While loading, the fields you've queried may not be part of the `data`. Make 135 | sure to add some default values or display a loader until the operations finish 136 | executing. 137 | 138 | ```js 139 | // default values: 140 | 141 | const TodoList = ({ data: { allTodos = [] } }) => ( 142 | 143 | ) 144 | 145 | // displaying loader while operations is executing 146 | 147 | const TodoList = ({ data: { loading, allTodos } }) => { 148 | return loading ? ( 149 | 150 | ) : ( 151 | 152 | ) 153 | } 154 | ``` 155 | 156 | ##### `error` 157 | 158 | Contains all the errors that might have resulted from any of the operations. 159 | 160 | ```js 161 | props: { 162 | data: { 163 | loading: false, 164 | allTodos: [...], 165 | errors: { 166 | allUsers: { ... } 167 | } 168 | } 169 | } 170 | ``` 171 | 172 | You should always have some sort of error-handling in place, this is generally a 173 | good practice, not only when using **Blips**. 174 | 175 | #### The `config` object 176 | 177 | `graphql` accepts an optional argument which represents the configuration 178 | object. This argument should always be provided last, after all operations. 179 | 180 | ```js 181 | graphql(...operations, config)(BaseComponent) 182 | ``` 183 | 184 | ##### config.name 185 | 186 | This property allows you to change the name of the `data` prop that gets passed 187 | down to your component. 188 | 189 | ```js 190 | graphql(...operations, { name: 'state' })(BaseComponent) 191 | 192 | // props :{ 193 | // ... 194 | // state: { 195 | // loading: false, 196 | // allTodos: [...], 197 | // allUsers: [...] 198 | // } 199 | // } 200 | ``` 201 | 202 | You can also define `config.name` as a plain object if you wish to provide 203 | custom names for the other props ([queries](#the-queries-prop), 204 | [mutations](#the-mutations-prop)) that `graphql` adds to the container component 205 | 206 | ```js 207 | graphql(...operations, { 208 | name: { 209 | data: 'state', 210 | queries: 'geters', 211 | mutations: 'setters', 212 | }, 213 | })(BaseComponent) 214 | 215 | // props :{ 216 | // ... 217 | // state: { ... }, 218 | // getters: { ... }, 219 | // setters: { ... } 220 | // } 221 | ``` 222 | 223 | ##### config.options 224 | 225 | This property is an object or function that allows you to provide the variables 226 | needed for your operations or to extend the context of the resolvers they will 227 | call. 228 | 229 | ```js 230 | // resolvers.js 231 | const resolvers = { 232 | // ... 233 | Query: { 234 | // returns only todos of the logged user 235 | allTodosQuery: (obj, { first }, { store, user }) => { 236 | store.get('todos', { user_id: user.id }).slice(0, first) 237 | }, 238 | }, 239 | } 240 | 241 | // TodoList.js 242 | const TodoList = ({ data: { allTodos = [] } }) => ( 243 | 244 | ) 245 | 246 | const allTodosQuery = ` 247 | query allTodosQuery($first: Int) { 248 | allTodos(first: $first) { 249 | id 250 | label 251 | completed 252 | } 253 | } 254 | ` 255 | 256 | export default graphql(allTodosQuery, { 257 | options: { 258 | variables: { first: 10 }, 259 | context: { user: localStorage.getItem('currentUser') }, 260 | }, 261 | }) 262 | ``` 263 | 264 | You can define `config.options` as a plain object, or as a function that takes 265 | the component’s props as an argument and returns the object. 266 | 267 | ```js 268 | export default graphql(allTodosQuery, { 269 | options: props => ({ 270 | variables: { first: props.count }, 271 | context: { user: props.user }, 272 | }), 273 | }) 274 | ``` 275 | 276 | #### The `queries` prop 277 | 278 | In addition to `data`, the connected component will also receive a `queries` 279 | prop which contains all the query operations specified, as methods that you can 280 | call manually. 281 | 282 | ```js 283 | // ... 284 | 285 | onUserSelect = async id => { 286 | const { queries: { allTodosQuery, user }, count, user } = this.props 287 | const newUser = await user({ variables: { id } }) 288 | const data = await allTodosQuery({ variables: { first: count }, context: { user: newUser } }) 289 | 290 | this.setState({ 291 | todos: data.allTodos, 292 | }) 293 | } 294 | 295 | // ... 296 | 297 | render() { 298 | return ( 299 |
300 | 304 | 305 |
306 | ) 307 | } 308 | ``` 309 | 310 | This is great for the above type of behaviour, but you can also use these 311 | queries to poll the state at a specific interval and update the component's 312 | state. The problem with this approach is that you'd have to add the props you 313 | want to poll for to the state so that your component updates correctly. If this 314 | is what you want, you're better off using 315 | [`subscription`](#subscribing-to-state-changes) instead of `query` 316 | 317 | #### The `mutations` prop 318 | 319 | Another prop passed down to the container component is `mutations`. This prop 320 | contains all the mutations you provide to `graphql()` 321 | 322 | ```js 323 | class Todos extends Component { 324 | // ... 325 | 326 | onKeyUp = e => { 327 | const { 328 | mutations: { createTodoMutation = () => {} }, 329 | data: { allTodos = [] }, 330 | } = this.props 331 | 332 | createTodoMutation({ variables: { label: e.target.value } }) 333 | // adds the new todo to the store and our subscription will handle the component update 334 | } 335 | 336 | // ... 337 | 338 | render() { 339 | const { data: { allTodos = [] } } = this.props 340 | 341 | return ( 342 |
343 | 344 | 345 |
346 | ) 347 | } 348 | } 349 | 350 | const createTodoMutation = ` 351 | mutation createTodoMutation(id: String, label: String!, completed: Boolean) { 352 | createTodo { 353 | id 354 | label 355 | completed 356 | } 357 | } 358 | ` 359 | 360 | export default graphql(allTodosSubscription, createTodoMutation, { 361 | options: { 362 | context: { user: localStorage.getItem('currentUser') }, 363 | }, 364 | }) 365 | ``` 366 | 367 | #### Subscribing to state changes 368 | 369 | If you provide subscription operations to `graphql()`, the connected component 370 | will also subscribe to state changes and will update correctly. It will also 371 | clean up after itself when unmounting. There's no magic happening behind the 372 | scenes, you'll still have to write the resolvers yourself. Read the 373 | [**Blips** documentation](https://github.com/monojack/blips#subscriptions) about 374 | writing resolvers for subscriptions 375 | 376 | ```js 377 | const allTodosSubscription = ` 378 | subscription allTodosSubscription { 379 | allTodos { 380 | id 381 | label 382 | completed 383 | } 384 | } 385 | ` 386 | 387 | export default graphql(allTodosSubscription)(TodoList) 388 | ``` 389 | 390 | #### The `withOperations` HOC 391 | 392 | The `withOperations` higher-order component creates components that have the 393 | ability to execute queries and mutations manually. The signature of 394 | `withOperations` is the same as that of `graphql`. It will not provide a `data` 395 | prop since it won't execute operations for you, but it will provide the 396 | `queries` and `mutations` props. It's useful for creating components that don't 397 | need to be connected to the store but may still execute mutations or read from 398 | it on demand, like when you have a component a few levels deep from a container 399 | and you don't want to pass callbacks all the way down. 400 | 401 | #### The `withClient` HOC 402 | 403 | Components created by the `withClient` higher-order component have access to the 404 | entire `client` instance. `withClient` accepts a single argument, the base 405 | component and it will provide a `client` prop. Messing with the client instance 406 | directly is risky, so this is not a recommended approach, but it's available if 407 | you consider that you need it. Event then, `withOperations` may still be enough. 408 | 409 | ## Tips 410 | 411 | See [**Blips** documentation](https://github.com/monojack/blips#the-tips) to 412 | read about tips 413 | -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "react-blips", 3 | "version": "0.14.1", 4 | "lockfileVersion": 1, 5 | "requires": true, 6 | "dependencies": { 7 | "acorn": { 8 | "version": "5.2.1", 9 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-5.2.1.tgz", 10 | "integrity": "sha512-jG0u7c4Ly+3QkkW18V+NRDN+4bWHdln30NL1ZL2AvFZZmQe/BfopYCtghCKKVBUSetZ4QKcyA0pY6/4Gw8Pv8w==", 11 | "dev": true 12 | }, 13 | "acorn-jsx": { 14 | "version": "3.0.1", 15 | "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-3.0.1.tgz", 16 | "integrity": "sha1-r9+UiPsezvyDSPb7IvRk4ypYs2s=", 17 | "dev": true, 18 | "requires": { 19 | "acorn": "3.3.0" 20 | }, 21 | "dependencies": { 22 | "acorn": { 23 | "version": "3.3.0", 24 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-3.3.0.tgz", 25 | "integrity": "sha1-ReN/s56No/JbruP/U2niu18iAXo=", 26 | "dev": true 27 | } 28 | } 29 | }, 30 | "ajv": { 31 | "version": "5.3.0", 32 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-5.3.0.tgz", 33 | "integrity": "sha1-RBT/dKUIecII7l/cgm4ywwNUnto=", 34 | "dev": true, 35 | "requires": { 36 | "co": "4.6.0", 37 | "fast-deep-equal": "1.0.0", 38 | "fast-json-stable-stringify": "2.0.0", 39 | "json-schema-traverse": "0.3.1" 40 | } 41 | }, 42 | "ajv-keywords": { 43 | "version": "2.1.1", 44 | "resolved": "https://registry.npmjs.org/ajv-keywords/-/ajv-keywords-2.1.1.tgz", 45 | "integrity": "sha1-YXmX/F9gV2iUxDX5QNgZ4TW4B2I=", 46 | "dev": true 47 | }, 48 | "ansi-escapes": { 49 | "version": "3.0.0", 50 | "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-3.0.0.tgz", 51 | "integrity": "sha512-O/klc27mWNUigtv0F8NJWbLF00OcegQalkqKURWdosW08YZKi4m6CnSUSvIZG1otNJbTWhN01Hhz389DW7mvDQ==", 52 | "dev": true 53 | }, 54 | "ansi-regex": { 55 | "version": "2.1.1", 56 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-2.1.1.tgz", 57 | "integrity": "sha1-w7M6te42DYbg5ijwRorn7yfWVN8=", 58 | "dev": true 59 | }, 60 | "ansi-styles": { 61 | "version": "2.2.1", 62 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-2.2.1.tgz", 63 | "integrity": "sha1-tDLdM1i2NM914eRmQ2gkBTPB3b4=", 64 | "dev": true 65 | }, 66 | "anymatch": { 67 | "version": "1.3.2", 68 | "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-1.3.2.tgz", 69 | "integrity": "sha512-0XNayC8lTHQ2OI8aljNCN3sSx6hsr/1+rlcDAotXJR7C1oZZHCNsfpbKwMjRA3Uqb5tF1Rae2oloTr4xpq+WjA==", 70 | "dev": true, 71 | "optional": true, 72 | "requires": { 73 | "micromatch": "2.3.11", 74 | "normalize-path": "2.1.1" 75 | } 76 | }, 77 | "apollo-fetch": { 78 | "version": "0.7.0", 79 | "resolved": "https://registry.npmjs.org/apollo-fetch/-/apollo-fetch-0.7.0.tgz", 80 | "integrity": "sha512-0oHsDW3Zxx+Of1wuqcOXruNj4Kv55WN69tkIjwkCQDEIrgCpgA2scjChFsgflSVMy/1mkTKCY1Mc0TYJhNRzmw==", 81 | "dev": true, 82 | "requires": { 83 | "cross-fetch": "1.1.1" 84 | } 85 | }, 86 | "apollo-utilities": { 87 | "version": "1.0.3", 88 | "resolved": "https://registry.npmjs.org/apollo-utilities/-/apollo-utilities-1.0.3.tgz", 89 | "integrity": "sha512-wNKf0GAXfvnmZFYVl1YIzZ6LDSUe+zo4SKd2kbzi7YquNZUuSwJnG1FfEphvfwRRTI2dnpcGZEq26I7uUBrWNw==", 90 | "dev": true 91 | }, 92 | "argparse": { 93 | "version": "1.0.9", 94 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.9.tgz", 95 | "integrity": "sha1-c9g7wmP4bpf4zE9rrhsOkKfSLIY=", 96 | "dev": true, 97 | "requires": { 98 | "sprintf-js": "1.0.3" 99 | } 100 | }, 101 | "arr-diff": { 102 | "version": "2.0.0", 103 | "resolved": "https://registry.npmjs.org/arr-diff/-/arr-diff-2.0.0.tgz", 104 | "integrity": "sha1-jzuCf5Vai9ZpaX5KQlasPOrjVs8=", 105 | "dev": true, 106 | "requires": { 107 | "arr-flatten": "1.1.0" 108 | } 109 | }, 110 | "arr-flatten": { 111 | "version": "1.1.0", 112 | "resolved": "https://registry.npmjs.org/arr-flatten/-/arr-flatten-1.1.0.tgz", 113 | "integrity": "sha512-L3hKV5R/p5o81R7O02IGnwpDmkp6E982XhtbuwSe3O4qOtMMMtodicASA1Cny2U+aCXcNpml+m4dPsvsJ3jatg==", 114 | "dev": true 115 | }, 116 | "array-includes": { 117 | "version": "3.0.3", 118 | "resolved": "https://registry.npmjs.org/array-includes/-/array-includes-3.0.3.tgz", 119 | "integrity": "sha1-GEtI9i2S10UrsxsyMWXH+L0CJm0=", 120 | "dev": true, 121 | "requires": { 122 | "define-properties": "1.1.2", 123 | "es-abstract": "1.10.0" 124 | } 125 | }, 126 | "array-union": { 127 | "version": "1.0.2", 128 | "resolved": "https://registry.npmjs.org/array-union/-/array-union-1.0.2.tgz", 129 | "integrity": "sha1-mjRBDk9OPaI96jdb5b5w8kd47Dk=", 130 | "dev": true, 131 | "requires": { 132 | "array-uniq": "1.0.3" 133 | } 134 | }, 135 | "array-uniq": { 136 | "version": "1.0.3", 137 | "resolved": "https://registry.npmjs.org/array-uniq/-/array-uniq-1.0.3.tgz", 138 | "integrity": "sha1-r2rId6Jcx/dOBYiUdThY39sk/bY=", 139 | "dev": true 140 | }, 141 | "array-unique": { 142 | "version": "0.2.1", 143 | "resolved": "https://registry.npmjs.org/array-unique/-/array-unique-0.2.1.tgz", 144 | "integrity": "sha1-odl8yvy8JiXMcPrc6zalDFiwGlM=", 145 | "dev": true 146 | }, 147 | "arrify": { 148 | "version": "1.0.1", 149 | "resolved": "https://registry.npmjs.org/arrify/-/arrify-1.0.1.tgz", 150 | "integrity": "sha1-iYUI2iIm84DfkEcoRWhJwVAaSw0=", 151 | "dev": true 152 | }, 153 | "asap": { 154 | "version": "2.0.6", 155 | "resolved": "https://registry.npmjs.org/asap/-/asap-2.0.6.tgz", 156 | "integrity": "sha1-5QNHYR1+aQlDIIu9r+vLwvuGbUY=" 157 | }, 158 | "async-each": { 159 | "version": "1.0.1", 160 | "resolved": "https://registry.npmjs.org/async-each/-/async-each-1.0.1.tgz", 161 | "integrity": "sha1-GdOGodntxufByF04iu28xW0zYC0=", 162 | "dev": true, 163 | "optional": true 164 | }, 165 | "babel-cli": { 166 | "version": "6.26.0", 167 | "resolved": "https://registry.npmjs.org/babel-cli/-/babel-cli-6.26.0.tgz", 168 | "integrity": "sha1-UCq1SHTX24itALiHoGODzgPQAvE=", 169 | "dev": true, 170 | "requires": { 171 | "babel-core": "6.26.0", 172 | "babel-polyfill": "6.26.0", 173 | "babel-register": "6.26.0", 174 | "babel-runtime": "6.26.0", 175 | "chokidar": "1.7.0", 176 | "commander": "2.11.0", 177 | "convert-source-map": "1.5.0", 178 | "fs-readdir-recursive": "1.0.0", 179 | "glob": "7.1.2", 180 | "lodash": "4.17.4", 181 | "output-file-sync": "1.1.2", 182 | "path-is-absolute": "1.0.1", 183 | "slash": "1.0.0", 184 | "source-map": "0.5.7", 185 | "v8flags": "2.1.1" 186 | } 187 | }, 188 | "babel-code-frame": { 189 | "version": "6.26.0", 190 | "resolved": "https://registry.npmjs.org/babel-code-frame/-/babel-code-frame-6.26.0.tgz", 191 | "integrity": "sha1-Y/1D99weO7fONZR9uP42mj9Yx0s=", 192 | "dev": true, 193 | "requires": { 194 | "chalk": "1.1.3", 195 | "esutils": "2.0.2", 196 | "js-tokens": "3.0.2" 197 | } 198 | }, 199 | "babel-core": { 200 | "version": "6.26.0", 201 | "resolved": "https://registry.npmjs.org/babel-core/-/babel-core-6.26.0.tgz", 202 | "integrity": "sha1-rzL3izGm/O8RnIew/Y2XU/A6C7g=", 203 | "dev": true, 204 | "requires": { 205 | "babel-code-frame": "6.26.0", 206 | "babel-generator": "6.26.0", 207 | "babel-helpers": "6.24.1", 208 | "babel-messages": "6.23.0", 209 | "babel-register": "6.26.0", 210 | "babel-runtime": "6.26.0", 211 | "babel-template": "6.26.0", 212 | "babel-traverse": "6.26.0", 213 | "babel-types": "6.26.0", 214 | "babylon": "6.18.0", 215 | "convert-source-map": "1.5.0", 216 | "debug": "2.6.9", 217 | "json5": "0.5.1", 218 | "lodash": "4.17.4", 219 | "minimatch": "3.0.4", 220 | "path-is-absolute": "1.0.1", 221 | "private": "0.1.8", 222 | "slash": "1.0.0", 223 | "source-map": "0.5.7" 224 | } 225 | }, 226 | "babel-eslint": { 227 | "version": "8.0.1", 228 | "resolved": "https://registry.npmjs.org/babel-eslint/-/babel-eslint-8.0.1.tgz", 229 | "integrity": "sha512-h3moF6PCTQE06UjMMG+ydZSBvZ4Q7rqPE/5WAUOvUyHYUTqxm8JVhjZRiG1avI/tGVOK4BnZLDQapyLzh8DeKg==", 230 | "dev": true, 231 | "requires": { 232 | "babel-code-frame": "7.0.0-beta.0", 233 | "babel-traverse": "7.0.0-beta.0", 234 | "babel-types": "7.0.0-beta.0", 235 | "babylon": "7.0.0-beta.22" 236 | }, 237 | "dependencies": { 238 | "ansi-styles": { 239 | "version": "3.2.0", 240 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.0.tgz", 241 | "integrity": "sha512-NnSOmMEYtVR2JVMIGTzynRkkaxtiq1xnFBcdQD/DnNCYPoEPsVJhM98BDyaoNOQIi7p4okdi3E27eN7GQbsUug==", 242 | "dev": true, 243 | "requires": { 244 | "color-convert": "1.9.0" 245 | } 246 | }, 247 | "babel-code-frame": { 248 | "version": "7.0.0-beta.0", 249 | "resolved": "https://registry.npmjs.org/babel-code-frame/-/babel-code-frame-7.0.0-beta.0.tgz", 250 | "integrity": "sha512-/xr1ADm5bnTjjN+xwoXb7lF4v2rnxMzNZzFU7h8SxB+qB6+IqSTOOqVcpaPTUC2Non/MbQxS3OIZnJpQ2X21aQ==", 251 | "dev": true, 252 | "requires": { 253 | "chalk": "2.3.0", 254 | "esutils": "2.0.2", 255 | "js-tokens": "3.0.2" 256 | } 257 | }, 258 | "babel-messages": { 259 | "version": "7.0.0-beta.0", 260 | "resolved": "https://registry.npmjs.org/babel-messages/-/babel-messages-7.0.0-beta.0.tgz", 261 | "integrity": "sha512-eXdShsm9ZTh9AQhlIaAn6HR3xWpxCnK9ZwIDA9QyjnwTgMctGxHHflw4b4RJ3/ZjTL0Vrmvm0tQXPkp49mTAUw==", 262 | "dev": true 263 | }, 264 | "babel-traverse": { 265 | "version": "7.0.0-beta.0", 266 | "resolved": "https://registry.npmjs.org/babel-traverse/-/babel-traverse-7.0.0-beta.0.tgz", 267 | "integrity": "sha512-IKzuTqUcQtMRZ0Vv5RjIrGGj33eBKmNTNeRexWSyjPPuAciyNkva1rt7WXPfHfkb+dX7coRAIUhzeTUEzhnwdA==", 268 | "dev": true, 269 | "requires": { 270 | "babel-code-frame": "7.0.0-beta.0", 271 | "babel-helper-function-name": "7.0.0-beta.0", 272 | "babel-messages": "7.0.0-beta.0", 273 | "babel-types": "7.0.0-beta.0", 274 | "babylon": "7.0.0-beta.22", 275 | "debug": "3.1.0", 276 | "globals": "10.3.0", 277 | "invariant": "2.2.2", 278 | "lodash": "4.17.4" 279 | } 280 | }, 281 | "babel-types": { 282 | "version": "7.0.0-beta.0", 283 | "resolved": "https://registry.npmjs.org/babel-types/-/babel-types-7.0.0-beta.0.tgz", 284 | "integrity": "sha512-rJc2kV9iPJGLlqIY71AM3nPcdkoeLRCDuR07GFgfd3lFl4TsBQq76TxYQQIZ2MONg1HpsqmuoCXr9aZ1Oa4wYw==", 285 | "dev": true, 286 | "requires": { 287 | "esutils": "2.0.2", 288 | "lodash": "4.17.4", 289 | "to-fast-properties": "2.0.0" 290 | } 291 | }, 292 | "babylon": { 293 | "version": "7.0.0-beta.22", 294 | "resolved": "https://registry.npmjs.org/babylon/-/babylon-7.0.0-beta.22.tgz", 295 | "integrity": "sha512-Yl7iT8QGrS8OfR7p6R12AJexQm+brKwrryai4VWZ7NHUbPoZ5al3+klhvl/14shXZiLa7uK//OIFuZ1/RKHgoA==", 296 | "dev": true 297 | }, 298 | "chalk": { 299 | "version": "2.3.0", 300 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.3.0.tgz", 301 | "integrity": "sha512-Az5zJR2CBujap2rqXGaJKaPHyJ0IrUimvYNX+ncCy8PJP4ltOGTrHUIo097ZaL2zMeKYpiCdqDvS6zdrTFok3Q==", 302 | "dev": true, 303 | "requires": { 304 | "ansi-styles": "3.2.0", 305 | "escape-string-regexp": "1.0.5", 306 | "supports-color": "4.5.0" 307 | } 308 | }, 309 | "debug": { 310 | "version": "3.1.0", 311 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.1.0.tgz", 312 | "integrity": "sha512-OX8XqP7/1a9cqkxYw2yXss15f26NKWBpDXQd0/uK/KPqdQhxbPa994hnzjcE2VqQpDslf55723cKPUOGSmMY3g==", 313 | "dev": true, 314 | "requires": { 315 | "ms": "2.0.0" 316 | } 317 | }, 318 | "globals": { 319 | "version": "10.3.0", 320 | "resolved": "https://registry.npmjs.org/globals/-/globals-10.3.0.tgz", 321 | "integrity": "sha512-1g6qO5vMbiPHbRTDtR9JVjRkAhkgH4nSANYGyx1eOfqgxcMnYMMD+7MjmjfzXjwFpVUE/7/NzF+jQxYE7P4r7A==", 322 | "dev": true 323 | }, 324 | "supports-color": { 325 | "version": "4.5.0", 326 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-4.5.0.tgz", 327 | "integrity": "sha1-vnoN5ITexcXN34s9WRJQRJEvY1s=", 328 | "dev": true, 329 | "requires": { 330 | "has-flag": "2.0.0" 331 | } 332 | }, 333 | "to-fast-properties": { 334 | "version": "2.0.0", 335 | "resolved": "https://registry.npmjs.org/to-fast-properties/-/to-fast-properties-2.0.0.tgz", 336 | "integrity": "sha1-3F5pjL0HkmW8c+A3doGk5Og/YW4=", 337 | "dev": true 338 | } 339 | } 340 | }, 341 | "babel-generator": { 342 | "version": "6.26.0", 343 | "resolved": "https://registry.npmjs.org/babel-generator/-/babel-generator-6.26.0.tgz", 344 | "integrity": "sha1-rBriAHC3n248odMmlhMFN3TyDcU=", 345 | "dev": true, 346 | "requires": { 347 | "babel-messages": "6.23.0", 348 | "babel-runtime": "6.26.0", 349 | "babel-types": "6.26.0", 350 | "detect-indent": "4.0.0", 351 | "jsesc": "1.3.0", 352 | "lodash": "4.17.4", 353 | "source-map": "0.5.7", 354 | "trim-right": "1.0.1" 355 | } 356 | }, 357 | "babel-helper-bindify-decorators": { 358 | "version": "6.24.1", 359 | "resolved": "https://registry.npmjs.org/babel-helper-bindify-decorators/-/babel-helper-bindify-decorators-6.24.1.tgz", 360 | "integrity": "sha1-FMGeXxQte0fxmlJDHlKxzLxAozA=", 361 | "dev": true, 362 | "requires": { 363 | "babel-runtime": "6.26.0", 364 | "babel-traverse": "6.26.0", 365 | "babel-types": "6.26.0" 366 | } 367 | }, 368 | "babel-helper-builder-binary-assignment-operator-visitor": { 369 | "version": "6.24.1", 370 | "resolved": "https://registry.npmjs.org/babel-helper-builder-binary-assignment-operator-visitor/-/babel-helper-builder-binary-assignment-operator-visitor-6.24.1.tgz", 371 | "integrity": "sha1-zORReto1b0IgvK6KAsKzRvmlZmQ=", 372 | "dev": true, 373 | "requires": { 374 | "babel-helper-explode-assignable-expression": "6.24.1", 375 | "babel-runtime": "6.26.0", 376 | "babel-types": "6.26.0" 377 | } 378 | }, 379 | "babel-helper-builder-react-jsx": { 380 | "version": "6.26.0", 381 | "resolved": "https://registry.npmjs.org/babel-helper-builder-react-jsx/-/babel-helper-builder-react-jsx-6.26.0.tgz", 382 | "integrity": "sha1-Of+DE7dci2Xc7/HzHTg+D/KkCKA=", 383 | "dev": true, 384 | "requires": { 385 | "babel-runtime": "6.26.0", 386 | "babel-types": "6.26.0", 387 | "esutils": "2.0.2" 388 | } 389 | }, 390 | "babel-helper-call-delegate": { 391 | "version": "6.24.1", 392 | "resolved": "https://registry.npmjs.org/babel-helper-call-delegate/-/babel-helper-call-delegate-6.24.1.tgz", 393 | "integrity": "sha1-7Oaqzdx25Bw0YfiL/Fdb0Nqi340=", 394 | "dev": true, 395 | "requires": { 396 | "babel-helper-hoist-variables": "6.24.1", 397 | "babel-runtime": "6.26.0", 398 | "babel-traverse": "6.26.0", 399 | "babel-types": "6.26.0" 400 | } 401 | }, 402 | "babel-helper-define-map": { 403 | "version": "6.26.0", 404 | "resolved": "https://registry.npmjs.org/babel-helper-define-map/-/babel-helper-define-map-6.26.0.tgz", 405 | "integrity": "sha1-pfVtq0GiX5fstJjH66ypgZ+Vvl8=", 406 | "dev": true, 407 | "requires": { 408 | "babel-helper-function-name": "6.24.1", 409 | "babel-runtime": "6.26.0", 410 | "babel-types": "6.26.0", 411 | "lodash": "4.17.4" 412 | }, 413 | "dependencies": { 414 | "babel-helper-function-name": { 415 | "version": "6.24.1", 416 | "resolved": "https://registry.npmjs.org/babel-helper-function-name/-/babel-helper-function-name-6.24.1.tgz", 417 | "integrity": "sha1-00dbjAPtmCQqJbSDUasYOZ01gKk=", 418 | "dev": true, 419 | "requires": { 420 | "babel-helper-get-function-arity": "6.24.1", 421 | "babel-runtime": "6.26.0", 422 | "babel-template": "6.26.0", 423 | "babel-traverse": "6.26.0", 424 | "babel-types": "6.26.0" 425 | } 426 | }, 427 | "babel-helper-get-function-arity": { 428 | "version": "6.24.1", 429 | "resolved": "https://registry.npmjs.org/babel-helper-get-function-arity/-/babel-helper-get-function-arity-6.24.1.tgz", 430 | "integrity": "sha1-j3eCqpNAfEHTqlCQj4mwMbG2hT0=", 431 | "dev": true, 432 | "requires": { 433 | "babel-runtime": "6.26.0", 434 | "babel-types": "6.26.0" 435 | } 436 | } 437 | } 438 | }, 439 | "babel-helper-explode-assignable-expression": { 440 | "version": "6.24.1", 441 | "resolved": "https://registry.npmjs.org/babel-helper-explode-assignable-expression/-/babel-helper-explode-assignable-expression-6.24.1.tgz", 442 | "integrity": "sha1-8luCz33BBDPFX3BZLVdGQArCLKo=", 443 | "dev": true, 444 | "requires": { 445 | "babel-runtime": "6.26.0", 446 | "babel-traverse": "6.26.0", 447 | "babel-types": "6.26.0" 448 | } 449 | }, 450 | "babel-helper-explode-class": { 451 | "version": "6.24.1", 452 | "resolved": "https://registry.npmjs.org/babel-helper-explode-class/-/babel-helper-explode-class-6.24.1.tgz", 453 | "integrity": "sha1-fcKjkQ3uAHBW4eMdZAztPVTqqes=", 454 | "dev": true, 455 | "requires": { 456 | "babel-helper-bindify-decorators": "6.24.1", 457 | "babel-runtime": "6.26.0", 458 | "babel-traverse": "6.26.0", 459 | "babel-types": "6.26.0" 460 | } 461 | }, 462 | "babel-helper-function-name": { 463 | "version": "7.0.0-beta.0", 464 | "resolved": "https://registry.npmjs.org/babel-helper-function-name/-/babel-helper-function-name-7.0.0-beta.0.tgz", 465 | "integrity": "sha512-DaQccFBBWBEzMdqbKmNXamY0m1yLHJGOdbbEsNoGdJrrU7wAF3wwowtDDPzF0ZT3SqJXPgZW/P2kgBX9moMuAA==", 466 | "dev": true, 467 | "requires": { 468 | "babel-helper-get-function-arity": "7.0.0-beta.0", 469 | "babel-template": "7.0.0-beta.0", 470 | "babel-traverse": "7.0.0-beta.0", 471 | "babel-types": "7.0.0-beta.0" 472 | }, 473 | "dependencies": { 474 | "ansi-styles": { 475 | "version": "3.2.0", 476 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.0.tgz", 477 | "integrity": "sha512-NnSOmMEYtVR2JVMIGTzynRkkaxtiq1xnFBcdQD/DnNCYPoEPsVJhM98BDyaoNOQIi7p4okdi3E27eN7GQbsUug==", 478 | "dev": true, 479 | "requires": { 480 | "color-convert": "1.9.0" 481 | } 482 | }, 483 | "babel-code-frame": { 484 | "version": "7.0.0-beta.0", 485 | "resolved": "https://registry.npmjs.org/babel-code-frame/-/babel-code-frame-7.0.0-beta.0.tgz", 486 | "integrity": "sha512-/xr1ADm5bnTjjN+xwoXb7lF4v2rnxMzNZzFU7h8SxB+qB6+IqSTOOqVcpaPTUC2Non/MbQxS3OIZnJpQ2X21aQ==", 487 | "dev": true, 488 | "requires": { 489 | "chalk": "2.3.0", 490 | "esutils": "2.0.2", 491 | "js-tokens": "3.0.2" 492 | } 493 | }, 494 | "babel-messages": { 495 | "version": "7.0.0-beta.0", 496 | "resolved": "https://registry.npmjs.org/babel-messages/-/babel-messages-7.0.0-beta.0.tgz", 497 | "integrity": "sha512-eXdShsm9ZTh9AQhlIaAn6HR3xWpxCnK9ZwIDA9QyjnwTgMctGxHHflw4b4RJ3/ZjTL0Vrmvm0tQXPkp49mTAUw==", 498 | "dev": true 499 | }, 500 | "babel-template": { 501 | "version": "7.0.0-beta.0", 502 | "resolved": "https://registry.npmjs.org/babel-template/-/babel-template-7.0.0-beta.0.tgz", 503 | "integrity": "sha512-tmdH+MmmU0F6Ur8humpevSmFzYKbrN3Oru0g5Qyg4R6+sxjnzZmnvzUbsP0aKMr7tB0Ua6xhEb9arKTOsEMkyA==", 504 | "dev": true, 505 | "requires": { 506 | "babel-traverse": "7.0.0-beta.0", 507 | "babel-types": "7.0.0-beta.0", 508 | "babylon": "7.0.0-beta.22", 509 | "lodash": "4.17.4" 510 | } 511 | }, 512 | "babel-traverse": { 513 | "version": "7.0.0-beta.0", 514 | "resolved": "https://registry.npmjs.org/babel-traverse/-/babel-traverse-7.0.0-beta.0.tgz", 515 | "integrity": "sha512-IKzuTqUcQtMRZ0Vv5RjIrGGj33eBKmNTNeRexWSyjPPuAciyNkva1rt7WXPfHfkb+dX7coRAIUhzeTUEzhnwdA==", 516 | "dev": true, 517 | "requires": { 518 | "babel-code-frame": "7.0.0-beta.0", 519 | "babel-helper-function-name": "7.0.0-beta.0", 520 | "babel-messages": "7.0.0-beta.0", 521 | "babel-types": "7.0.0-beta.0", 522 | "babylon": "7.0.0-beta.22", 523 | "debug": "3.1.0", 524 | "globals": "10.3.0", 525 | "invariant": "2.2.2", 526 | "lodash": "4.17.4" 527 | } 528 | }, 529 | "babel-types": { 530 | "version": "7.0.0-beta.0", 531 | "resolved": "https://registry.npmjs.org/babel-types/-/babel-types-7.0.0-beta.0.tgz", 532 | "integrity": "sha512-rJc2kV9iPJGLlqIY71AM3nPcdkoeLRCDuR07GFgfd3lFl4TsBQq76TxYQQIZ2MONg1HpsqmuoCXr9aZ1Oa4wYw==", 533 | "dev": true, 534 | "requires": { 535 | "esutils": "2.0.2", 536 | "lodash": "4.17.4", 537 | "to-fast-properties": "2.0.0" 538 | } 539 | }, 540 | "babylon": { 541 | "version": "7.0.0-beta.22", 542 | "resolved": "https://registry.npmjs.org/babylon/-/babylon-7.0.0-beta.22.tgz", 543 | "integrity": "sha512-Yl7iT8QGrS8OfR7p6R12AJexQm+brKwrryai4VWZ7NHUbPoZ5al3+klhvl/14shXZiLa7uK//OIFuZ1/RKHgoA==", 544 | "dev": true 545 | }, 546 | "chalk": { 547 | "version": "2.3.0", 548 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.3.0.tgz", 549 | "integrity": "sha512-Az5zJR2CBujap2rqXGaJKaPHyJ0IrUimvYNX+ncCy8PJP4ltOGTrHUIo097ZaL2zMeKYpiCdqDvS6zdrTFok3Q==", 550 | "dev": true, 551 | "requires": { 552 | "ansi-styles": "3.2.0", 553 | "escape-string-regexp": "1.0.5", 554 | "supports-color": "4.5.0" 555 | } 556 | }, 557 | "debug": { 558 | "version": "3.1.0", 559 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.1.0.tgz", 560 | "integrity": "sha512-OX8XqP7/1a9cqkxYw2yXss15f26NKWBpDXQd0/uK/KPqdQhxbPa994hnzjcE2VqQpDslf55723cKPUOGSmMY3g==", 561 | "dev": true, 562 | "requires": { 563 | "ms": "2.0.0" 564 | } 565 | }, 566 | "globals": { 567 | "version": "10.3.0", 568 | "resolved": "https://registry.npmjs.org/globals/-/globals-10.3.0.tgz", 569 | "integrity": "sha512-1g6qO5vMbiPHbRTDtR9JVjRkAhkgH4nSANYGyx1eOfqgxcMnYMMD+7MjmjfzXjwFpVUE/7/NzF+jQxYE7P4r7A==", 570 | "dev": true 571 | }, 572 | "supports-color": { 573 | "version": "4.5.0", 574 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-4.5.0.tgz", 575 | "integrity": "sha1-vnoN5ITexcXN34s9WRJQRJEvY1s=", 576 | "dev": true, 577 | "requires": { 578 | "has-flag": "2.0.0" 579 | } 580 | }, 581 | "to-fast-properties": { 582 | "version": "2.0.0", 583 | "resolved": "https://registry.npmjs.org/to-fast-properties/-/to-fast-properties-2.0.0.tgz", 584 | "integrity": "sha1-3F5pjL0HkmW8c+A3doGk5Og/YW4=", 585 | "dev": true 586 | } 587 | } 588 | }, 589 | "babel-helper-get-function-arity": { 590 | "version": "7.0.0-beta.0", 591 | "resolved": "https://registry.npmjs.org/babel-helper-get-function-arity/-/babel-helper-get-function-arity-7.0.0-beta.0.tgz", 592 | "integrity": "sha512-csqAic15/2Vm1951nJxkkL9K8E6ojyNF/eAOjk7pqJlO8kvgrccGNFCV9eDwcGHDPe5AjvJGwVSAcQ5fit9wuA==", 593 | "dev": true, 594 | "requires": { 595 | "babel-types": "7.0.0-beta.0" 596 | }, 597 | "dependencies": { 598 | "babel-types": { 599 | "version": "7.0.0-beta.0", 600 | "resolved": "https://registry.npmjs.org/babel-types/-/babel-types-7.0.0-beta.0.tgz", 601 | "integrity": "sha512-rJc2kV9iPJGLlqIY71AM3nPcdkoeLRCDuR07GFgfd3lFl4TsBQq76TxYQQIZ2MONg1HpsqmuoCXr9aZ1Oa4wYw==", 602 | "dev": true, 603 | "requires": { 604 | "esutils": "2.0.2", 605 | "lodash": "4.17.4", 606 | "to-fast-properties": "2.0.0" 607 | } 608 | }, 609 | "to-fast-properties": { 610 | "version": "2.0.0", 611 | "resolved": "https://registry.npmjs.org/to-fast-properties/-/to-fast-properties-2.0.0.tgz", 612 | "integrity": "sha1-3F5pjL0HkmW8c+A3doGk5Og/YW4=", 613 | "dev": true 614 | } 615 | } 616 | }, 617 | "babel-helper-hoist-variables": { 618 | "version": "6.24.1", 619 | "resolved": "https://registry.npmjs.org/babel-helper-hoist-variables/-/babel-helper-hoist-variables-6.24.1.tgz", 620 | "integrity": "sha1-HssnaJydJVE+rbyZFKc/VAi+enY=", 621 | "dev": true, 622 | "requires": { 623 | "babel-runtime": "6.26.0", 624 | "babel-types": "6.26.0" 625 | } 626 | }, 627 | "babel-helper-optimise-call-expression": { 628 | "version": "6.24.1", 629 | "resolved": "https://registry.npmjs.org/babel-helper-optimise-call-expression/-/babel-helper-optimise-call-expression-6.24.1.tgz", 630 | "integrity": "sha1-96E0J7qfc/j0+pk8VKl4gtEkQlc=", 631 | "dev": true, 632 | "requires": { 633 | "babel-runtime": "6.26.0", 634 | "babel-types": "6.26.0" 635 | } 636 | }, 637 | "babel-helper-regex": { 638 | "version": "6.26.0", 639 | "resolved": "https://registry.npmjs.org/babel-helper-regex/-/babel-helper-regex-6.26.0.tgz", 640 | "integrity": "sha1-MlxZ+QL4LyS3T6zu0DY5VPZJXnI=", 641 | "dev": true, 642 | "requires": { 643 | "babel-runtime": "6.26.0", 644 | "babel-types": "6.26.0", 645 | "lodash": "4.17.4" 646 | } 647 | }, 648 | "babel-helper-remap-async-to-generator": { 649 | "version": "6.24.1", 650 | "resolved": "https://registry.npmjs.org/babel-helper-remap-async-to-generator/-/babel-helper-remap-async-to-generator-6.24.1.tgz", 651 | "integrity": "sha1-XsWBgnrXI/7N04HxySg5BnbkVRs=", 652 | "dev": true, 653 | "requires": { 654 | "babel-helper-function-name": "6.24.1", 655 | "babel-runtime": "6.26.0", 656 | "babel-template": "6.26.0", 657 | "babel-traverse": "6.26.0", 658 | "babel-types": "6.26.0" 659 | }, 660 | "dependencies": { 661 | "babel-helper-function-name": { 662 | "version": "6.24.1", 663 | "resolved": "https://registry.npmjs.org/babel-helper-function-name/-/babel-helper-function-name-6.24.1.tgz", 664 | "integrity": "sha1-00dbjAPtmCQqJbSDUasYOZ01gKk=", 665 | "dev": true, 666 | "requires": { 667 | "babel-helper-get-function-arity": "6.24.1", 668 | "babel-runtime": "6.26.0", 669 | "babel-template": "6.26.0", 670 | "babel-traverse": "6.26.0", 671 | "babel-types": "6.26.0" 672 | } 673 | }, 674 | "babel-helper-get-function-arity": { 675 | "version": "6.24.1", 676 | "resolved": "https://registry.npmjs.org/babel-helper-get-function-arity/-/babel-helper-get-function-arity-6.24.1.tgz", 677 | "integrity": "sha1-j3eCqpNAfEHTqlCQj4mwMbG2hT0=", 678 | "dev": true, 679 | "requires": { 680 | "babel-runtime": "6.26.0", 681 | "babel-types": "6.26.0" 682 | } 683 | } 684 | } 685 | }, 686 | "babel-helper-replace-supers": { 687 | "version": "6.24.1", 688 | "resolved": "https://registry.npmjs.org/babel-helper-replace-supers/-/babel-helper-replace-supers-6.24.1.tgz", 689 | "integrity": "sha1-v22/5Dk40XNpohPKiov3S2qQqxo=", 690 | "dev": true, 691 | "requires": { 692 | "babel-helper-optimise-call-expression": "6.24.1", 693 | "babel-messages": "6.23.0", 694 | "babel-runtime": "6.26.0", 695 | "babel-template": "6.26.0", 696 | "babel-traverse": "6.26.0", 697 | "babel-types": "6.26.0" 698 | } 699 | }, 700 | "babel-helpers": { 701 | "version": "6.24.1", 702 | "resolved": "https://registry.npmjs.org/babel-helpers/-/babel-helpers-6.24.1.tgz", 703 | "integrity": "sha1-NHHenK7DiOXIUOWX5Yom3fN2ArI=", 704 | "dev": true, 705 | "requires": { 706 | "babel-runtime": "6.26.0", 707 | "babel-template": "6.26.0" 708 | } 709 | }, 710 | "babel-messages": { 711 | "version": "6.23.0", 712 | "resolved": "https://registry.npmjs.org/babel-messages/-/babel-messages-6.23.0.tgz", 713 | "integrity": "sha1-8830cDhYA1sqKVHG7F7fbGLyYw4=", 714 | "dev": true, 715 | "requires": { 716 | "babel-runtime": "6.26.0" 717 | } 718 | }, 719 | "babel-plugin-check-es2015-constants": { 720 | "version": "6.22.0", 721 | "resolved": "https://registry.npmjs.org/babel-plugin-check-es2015-constants/-/babel-plugin-check-es2015-constants-6.22.0.tgz", 722 | "integrity": "sha1-NRV7EBQm/S/9PaP3XH0ekYNbv4o=", 723 | "dev": true, 724 | "requires": { 725 | "babel-runtime": "6.26.0" 726 | } 727 | }, 728 | "babel-plugin-external-helpers": { 729 | "version": "6.22.0", 730 | "resolved": "https://registry.npmjs.org/babel-plugin-external-helpers/-/babel-plugin-external-helpers-6.22.0.tgz", 731 | "integrity": "sha1-IoX0iwK9Xe3oUXXK+MYuhq3M76E=", 732 | "dev": true, 733 | "requires": { 734 | "babel-runtime": "6.26.0" 735 | } 736 | }, 737 | "babel-plugin-syntax-async-functions": { 738 | "version": "6.13.0", 739 | "resolved": "https://registry.npmjs.org/babel-plugin-syntax-async-functions/-/babel-plugin-syntax-async-functions-6.13.0.tgz", 740 | "integrity": "sha1-ytnK0RkbWtY0vzCuCHI5HgZHvpU=", 741 | "dev": true 742 | }, 743 | "babel-plugin-syntax-async-generators": { 744 | "version": "6.13.0", 745 | "resolved": "https://registry.npmjs.org/babel-plugin-syntax-async-generators/-/babel-plugin-syntax-async-generators-6.13.0.tgz", 746 | "integrity": "sha1-a8lj67FuzLrmuStZbrfzXDQqi5o=", 747 | "dev": true 748 | }, 749 | "babel-plugin-syntax-class-constructor-call": { 750 | "version": "6.18.0", 751 | "resolved": "https://registry.npmjs.org/babel-plugin-syntax-class-constructor-call/-/babel-plugin-syntax-class-constructor-call-6.18.0.tgz", 752 | "integrity": "sha1-nLnTn+Q8hgC+yBRkVt3L1OGnZBY=", 753 | "dev": true 754 | }, 755 | "babel-plugin-syntax-class-properties": { 756 | "version": "6.13.0", 757 | "resolved": "https://registry.npmjs.org/babel-plugin-syntax-class-properties/-/babel-plugin-syntax-class-properties-6.13.0.tgz", 758 | "integrity": "sha1-1+sjt5oxf4VDlixQW4J8fWysJ94=", 759 | "dev": true 760 | }, 761 | "babel-plugin-syntax-decorators": { 762 | "version": "6.13.0", 763 | "resolved": "https://registry.npmjs.org/babel-plugin-syntax-decorators/-/babel-plugin-syntax-decorators-6.13.0.tgz", 764 | "integrity": "sha1-MSVjtNvePMgGzuPkFszurd0RrAs=", 765 | "dev": true 766 | }, 767 | "babel-plugin-syntax-do-expressions": { 768 | "version": "6.13.0", 769 | "resolved": "https://registry.npmjs.org/babel-plugin-syntax-do-expressions/-/babel-plugin-syntax-do-expressions-6.13.0.tgz", 770 | "integrity": "sha1-V0d1YTmqJtOQ0JQQsDdEugfkeW0=", 771 | "dev": true 772 | }, 773 | "babel-plugin-syntax-dynamic-import": { 774 | "version": "6.18.0", 775 | "resolved": "https://registry.npmjs.org/babel-plugin-syntax-dynamic-import/-/babel-plugin-syntax-dynamic-import-6.18.0.tgz", 776 | "integrity": "sha1-jWomIpyDdFqZgqRBBRVyyqF5sdo=", 777 | "dev": true 778 | }, 779 | "babel-plugin-syntax-exponentiation-operator": { 780 | "version": "6.13.0", 781 | "resolved": "https://registry.npmjs.org/babel-plugin-syntax-exponentiation-operator/-/babel-plugin-syntax-exponentiation-operator-6.13.0.tgz", 782 | "integrity": "sha1-nufoM3KQ2pUoggGmpX9BcDF4MN4=", 783 | "dev": true 784 | }, 785 | "babel-plugin-syntax-export-extensions": { 786 | "version": "6.13.0", 787 | "resolved": "https://registry.npmjs.org/babel-plugin-syntax-export-extensions/-/babel-plugin-syntax-export-extensions-6.13.0.tgz", 788 | "integrity": "sha1-cKFITw+QiaToStRLrDU8lbmxJyE=", 789 | "dev": true 790 | }, 791 | "babel-plugin-syntax-flow": { 792 | "version": "6.18.0", 793 | "resolved": "https://registry.npmjs.org/babel-plugin-syntax-flow/-/babel-plugin-syntax-flow-6.18.0.tgz", 794 | "integrity": "sha1-TDqyCiryaqIM0lmVw5jE63AxDI0=", 795 | "dev": true 796 | }, 797 | "babel-plugin-syntax-function-bind": { 798 | "version": "6.13.0", 799 | "resolved": "https://registry.npmjs.org/babel-plugin-syntax-function-bind/-/babel-plugin-syntax-function-bind-6.13.0.tgz", 800 | "integrity": "sha1-SMSV8Xe98xqYHnMvVa3AvdJgH0Y=", 801 | "dev": true 802 | }, 803 | "babel-plugin-syntax-jsx": { 804 | "version": "6.18.0", 805 | "resolved": "https://registry.npmjs.org/babel-plugin-syntax-jsx/-/babel-plugin-syntax-jsx-6.18.0.tgz", 806 | "integrity": "sha1-CvMqmm4Tyno/1QaeYtew9Y0NiUY=", 807 | "dev": true 808 | }, 809 | "babel-plugin-syntax-object-rest-spread": { 810 | "version": "6.13.0", 811 | "resolved": "https://registry.npmjs.org/babel-plugin-syntax-object-rest-spread/-/babel-plugin-syntax-object-rest-spread-6.13.0.tgz", 812 | "integrity": "sha1-/WU28rzhODb/o6VFjEkDpZe7O/U=", 813 | "dev": true 814 | }, 815 | "babel-plugin-syntax-trailing-function-commas": { 816 | "version": "6.22.0", 817 | "resolved": "https://registry.npmjs.org/babel-plugin-syntax-trailing-function-commas/-/babel-plugin-syntax-trailing-function-commas-6.22.0.tgz", 818 | "integrity": "sha1-ugNgk3+NBuQBgKQ/4NVhb/9TLPM=", 819 | "dev": true 820 | }, 821 | "babel-plugin-transform-async-generator-functions": { 822 | "version": "6.24.1", 823 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-async-generator-functions/-/babel-plugin-transform-async-generator-functions-6.24.1.tgz", 824 | "integrity": "sha1-8FiQAUX9PpkHpt3yjaWfIVJYpds=", 825 | "dev": true, 826 | "requires": { 827 | "babel-helper-remap-async-to-generator": "6.24.1", 828 | "babel-plugin-syntax-async-generators": "6.13.0", 829 | "babel-runtime": "6.26.0" 830 | } 831 | }, 832 | "babel-plugin-transform-async-to-generator": { 833 | "version": "6.24.1", 834 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-async-to-generator/-/babel-plugin-transform-async-to-generator-6.24.1.tgz", 835 | "integrity": "sha1-ZTbjeK/2yx1VF6wOQOs+n8jQh2E=", 836 | "dev": true, 837 | "requires": { 838 | "babel-helper-remap-async-to-generator": "6.24.1", 839 | "babel-plugin-syntax-async-functions": "6.13.0", 840 | "babel-runtime": "6.26.0" 841 | } 842 | }, 843 | "babel-plugin-transform-class-constructor-call": { 844 | "version": "6.24.1", 845 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-class-constructor-call/-/babel-plugin-transform-class-constructor-call-6.24.1.tgz", 846 | "integrity": "sha1-gNwoVQWsBn3LjWxl4vbxGrd2Xvk=", 847 | "dev": true, 848 | "requires": { 849 | "babel-plugin-syntax-class-constructor-call": "6.18.0", 850 | "babel-runtime": "6.26.0", 851 | "babel-template": "6.26.0" 852 | } 853 | }, 854 | "babel-plugin-transform-class-properties": { 855 | "version": "6.24.1", 856 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-class-properties/-/babel-plugin-transform-class-properties-6.24.1.tgz", 857 | "integrity": "sha1-anl2PqYdM9NvN7YRqp3vgagbRqw=", 858 | "dev": true, 859 | "requires": { 860 | "babel-helper-function-name": "6.24.1", 861 | "babel-plugin-syntax-class-properties": "6.13.0", 862 | "babel-runtime": "6.26.0", 863 | "babel-template": "6.26.0" 864 | }, 865 | "dependencies": { 866 | "babel-helper-function-name": { 867 | "version": "6.24.1", 868 | "resolved": "https://registry.npmjs.org/babel-helper-function-name/-/babel-helper-function-name-6.24.1.tgz", 869 | "integrity": "sha1-00dbjAPtmCQqJbSDUasYOZ01gKk=", 870 | "dev": true, 871 | "requires": { 872 | "babel-helper-get-function-arity": "6.24.1", 873 | "babel-runtime": "6.26.0", 874 | "babel-template": "6.26.0", 875 | "babel-traverse": "6.26.0", 876 | "babel-types": "6.26.0" 877 | } 878 | }, 879 | "babel-helper-get-function-arity": { 880 | "version": "6.24.1", 881 | "resolved": "https://registry.npmjs.org/babel-helper-get-function-arity/-/babel-helper-get-function-arity-6.24.1.tgz", 882 | "integrity": "sha1-j3eCqpNAfEHTqlCQj4mwMbG2hT0=", 883 | "dev": true, 884 | "requires": { 885 | "babel-runtime": "6.26.0", 886 | "babel-types": "6.26.0" 887 | } 888 | } 889 | } 890 | }, 891 | "babel-plugin-transform-decorators": { 892 | "version": "6.24.1", 893 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-decorators/-/babel-plugin-transform-decorators-6.24.1.tgz", 894 | "integrity": "sha1-eIAT2PjGtSIr33s0Q5Df13Vp4k0=", 895 | "dev": true, 896 | "requires": { 897 | "babel-helper-explode-class": "6.24.1", 898 | "babel-plugin-syntax-decorators": "6.13.0", 899 | "babel-runtime": "6.26.0", 900 | "babel-template": "6.26.0", 901 | "babel-types": "6.26.0" 902 | } 903 | }, 904 | "babel-plugin-transform-do-expressions": { 905 | "version": "6.22.0", 906 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-do-expressions/-/babel-plugin-transform-do-expressions-6.22.0.tgz", 907 | "integrity": "sha1-KMyvkoEtlJws0SgfaQyP3EaK6bs=", 908 | "dev": true, 909 | "requires": { 910 | "babel-plugin-syntax-do-expressions": "6.13.0", 911 | "babel-runtime": "6.26.0" 912 | } 913 | }, 914 | "babel-plugin-transform-es2015-arrow-functions": { 915 | "version": "6.22.0", 916 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-arrow-functions/-/babel-plugin-transform-es2015-arrow-functions-6.22.0.tgz", 917 | "integrity": "sha1-RSaSy3EdX3ncf4XkQM5BufJE0iE=", 918 | "dev": true, 919 | "requires": { 920 | "babel-runtime": "6.26.0" 921 | } 922 | }, 923 | "babel-plugin-transform-es2015-block-scoped-functions": { 924 | "version": "6.22.0", 925 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-block-scoped-functions/-/babel-plugin-transform-es2015-block-scoped-functions-6.22.0.tgz", 926 | "integrity": "sha1-u8UbSflk1wy42OC5ToICRs46YUE=", 927 | "dev": true, 928 | "requires": { 929 | "babel-runtime": "6.26.0" 930 | } 931 | }, 932 | "babel-plugin-transform-es2015-block-scoping": { 933 | "version": "6.26.0", 934 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-block-scoping/-/babel-plugin-transform-es2015-block-scoping-6.26.0.tgz", 935 | "integrity": "sha1-1w9SmcEwjQXBL0Y4E7CgnnOxiV8=", 936 | "dev": true, 937 | "requires": { 938 | "babel-runtime": "6.26.0", 939 | "babel-template": "6.26.0", 940 | "babel-traverse": "6.26.0", 941 | "babel-types": "6.26.0", 942 | "lodash": "4.17.4" 943 | } 944 | }, 945 | "babel-plugin-transform-es2015-classes": { 946 | "version": "6.24.1", 947 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-classes/-/babel-plugin-transform-es2015-classes-6.24.1.tgz", 948 | "integrity": "sha1-WkxYpQyclGHlZLSyo7+ryXolhNs=", 949 | "dev": true, 950 | "requires": { 951 | "babel-helper-define-map": "6.26.0", 952 | "babel-helper-function-name": "6.24.1", 953 | "babel-helper-optimise-call-expression": "6.24.1", 954 | "babel-helper-replace-supers": "6.24.1", 955 | "babel-messages": "6.23.0", 956 | "babel-runtime": "6.26.0", 957 | "babel-template": "6.26.0", 958 | "babel-traverse": "6.26.0", 959 | "babel-types": "6.26.0" 960 | }, 961 | "dependencies": { 962 | "babel-helper-function-name": { 963 | "version": "6.24.1", 964 | "resolved": "https://registry.npmjs.org/babel-helper-function-name/-/babel-helper-function-name-6.24.1.tgz", 965 | "integrity": "sha1-00dbjAPtmCQqJbSDUasYOZ01gKk=", 966 | "dev": true, 967 | "requires": { 968 | "babel-helper-get-function-arity": "6.24.1", 969 | "babel-runtime": "6.26.0", 970 | "babel-template": "6.26.0", 971 | "babel-traverse": "6.26.0", 972 | "babel-types": "6.26.0" 973 | } 974 | }, 975 | "babel-helper-get-function-arity": { 976 | "version": "6.24.1", 977 | "resolved": "https://registry.npmjs.org/babel-helper-get-function-arity/-/babel-helper-get-function-arity-6.24.1.tgz", 978 | "integrity": "sha1-j3eCqpNAfEHTqlCQj4mwMbG2hT0=", 979 | "dev": true, 980 | "requires": { 981 | "babel-runtime": "6.26.0", 982 | "babel-types": "6.26.0" 983 | } 984 | } 985 | } 986 | }, 987 | "babel-plugin-transform-es2015-computed-properties": { 988 | "version": "6.24.1", 989 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-computed-properties/-/babel-plugin-transform-es2015-computed-properties-6.24.1.tgz", 990 | "integrity": "sha1-b+Ko0WiV1WNPTNmZttNICjCBWbM=", 991 | "dev": true, 992 | "requires": { 993 | "babel-runtime": "6.26.0", 994 | "babel-template": "6.26.0" 995 | } 996 | }, 997 | "babel-plugin-transform-es2015-destructuring": { 998 | "version": "6.23.0", 999 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-destructuring/-/babel-plugin-transform-es2015-destructuring-6.23.0.tgz", 1000 | "integrity": "sha1-mXux8auWf2gtKwh2/jWNYOdlxW0=", 1001 | "dev": true, 1002 | "requires": { 1003 | "babel-runtime": "6.26.0" 1004 | } 1005 | }, 1006 | "babel-plugin-transform-es2015-duplicate-keys": { 1007 | "version": "6.24.1", 1008 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-duplicate-keys/-/babel-plugin-transform-es2015-duplicate-keys-6.24.1.tgz", 1009 | "integrity": "sha1-c+s9MQypaePvnskcU3QabxV2Qj4=", 1010 | "dev": true, 1011 | "requires": { 1012 | "babel-runtime": "6.26.0", 1013 | "babel-types": "6.26.0" 1014 | } 1015 | }, 1016 | "babel-plugin-transform-es2015-for-of": { 1017 | "version": "6.23.0", 1018 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-for-of/-/babel-plugin-transform-es2015-for-of-6.23.0.tgz", 1019 | "integrity": "sha1-9HyVsrYT3x0+zC/bdXNiPHUkhpE=", 1020 | "dev": true, 1021 | "requires": { 1022 | "babel-runtime": "6.26.0" 1023 | } 1024 | }, 1025 | "babel-plugin-transform-es2015-function-name": { 1026 | "version": "6.24.1", 1027 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-function-name/-/babel-plugin-transform-es2015-function-name-6.24.1.tgz", 1028 | "integrity": "sha1-g0yJhTvDaxrw86TF26qU/Y6sqos=", 1029 | "dev": true, 1030 | "requires": { 1031 | "babel-helper-function-name": "6.24.1", 1032 | "babel-runtime": "6.26.0", 1033 | "babel-types": "6.26.0" 1034 | }, 1035 | "dependencies": { 1036 | "babel-helper-function-name": { 1037 | "version": "6.24.1", 1038 | "resolved": "https://registry.npmjs.org/babel-helper-function-name/-/babel-helper-function-name-6.24.1.tgz", 1039 | "integrity": "sha1-00dbjAPtmCQqJbSDUasYOZ01gKk=", 1040 | "dev": true, 1041 | "requires": { 1042 | "babel-helper-get-function-arity": "6.24.1", 1043 | "babel-runtime": "6.26.0", 1044 | "babel-template": "6.26.0", 1045 | "babel-traverse": "6.26.0", 1046 | "babel-types": "6.26.0" 1047 | } 1048 | }, 1049 | "babel-helper-get-function-arity": { 1050 | "version": "6.24.1", 1051 | "resolved": "https://registry.npmjs.org/babel-helper-get-function-arity/-/babel-helper-get-function-arity-6.24.1.tgz", 1052 | "integrity": "sha1-j3eCqpNAfEHTqlCQj4mwMbG2hT0=", 1053 | "dev": true, 1054 | "requires": { 1055 | "babel-runtime": "6.26.0", 1056 | "babel-types": "6.26.0" 1057 | } 1058 | } 1059 | } 1060 | }, 1061 | "babel-plugin-transform-es2015-literals": { 1062 | "version": "6.22.0", 1063 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-literals/-/babel-plugin-transform-es2015-literals-6.22.0.tgz", 1064 | "integrity": "sha1-T1SgLWzWbPkVKAAZox0xklN3yi4=", 1065 | "dev": true, 1066 | "requires": { 1067 | "babel-runtime": "6.26.0" 1068 | } 1069 | }, 1070 | "babel-plugin-transform-es2015-modules-amd": { 1071 | "version": "6.24.1", 1072 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-modules-amd/-/babel-plugin-transform-es2015-modules-amd-6.24.1.tgz", 1073 | "integrity": "sha1-Oz5UAXI5hC1tGcMBHEvS8AoA0VQ=", 1074 | "dev": true, 1075 | "requires": { 1076 | "babel-plugin-transform-es2015-modules-commonjs": "6.26.0", 1077 | "babel-runtime": "6.26.0", 1078 | "babel-template": "6.26.0" 1079 | } 1080 | }, 1081 | "babel-plugin-transform-es2015-modules-commonjs": { 1082 | "version": "6.26.0", 1083 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-modules-commonjs/-/babel-plugin-transform-es2015-modules-commonjs-6.26.0.tgz", 1084 | "integrity": "sha1-DYOUApt9xqvhqX7xgeAHWN0uXYo=", 1085 | "dev": true, 1086 | "requires": { 1087 | "babel-plugin-transform-strict-mode": "6.24.1", 1088 | "babel-runtime": "6.26.0", 1089 | "babel-template": "6.26.0", 1090 | "babel-types": "6.26.0" 1091 | } 1092 | }, 1093 | "babel-plugin-transform-es2015-modules-systemjs": { 1094 | "version": "6.24.1", 1095 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-modules-systemjs/-/babel-plugin-transform-es2015-modules-systemjs-6.24.1.tgz", 1096 | "integrity": "sha1-/4mhQrkRmpBhlfXxBuzzBdlAfSM=", 1097 | "dev": true, 1098 | "requires": { 1099 | "babel-helper-hoist-variables": "6.24.1", 1100 | "babel-runtime": "6.26.0", 1101 | "babel-template": "6.26.0" 1102 | } 1103 | }, 1104 | "babel-plugin-transform-es2015-modules-umd": { 1105 | "version": "6.24.1", 1106 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-modules-umd/-/babel-plugin-transform-es2015-modules-umd-6.24.1.tgz", 1107 | "integrity": "sha1-rJl+YoXNGO1hdq22B9YCNErThGg=", 1108 | "dev": true, 1109 | "requires": { 1110 | "babel-plugin-transform-es2015-modules-amd": "6.24.1", 1111 | "babel-runtime": "6.26.0", 1112 | "babel-template": "6.26.0" 1113 | } 1114 | }, 1115 | "babel-plugin-transform-es2015-object-super": { 1116 | "version": "6.24.1", 1117 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-object-super/-/babel-plugin-transform-es2015-object-super-6.24.1.tgz", 1118 | "integrity": "sha1-JM72muIcuDp/hgPa0CH1cusnj40=", 1119 | "dev": true, 1120 | "requires": { 1121 | "babel-helper-replace-supers": "6.24.1", 1122 | "babel-runtime": "6.26.0" 1123 | } 1124 | }, 1125 | "babel-plugin-transform-es2015-parameters": { 1126 | "version": "6.24.1", 1127 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-parameters/-/babel-plugin-transform-es2015-parameters-6.24.1.tgz", 1128 | "integrity": "sha1-V6w1GrScrxSpfNE7CfZv3wpiXys=", 1129 | "dev": true, 1130 | "requires": { 1131 | "babel-helper-call-delegate": "6.24.1", 1132 | "babel-helper-get-function-arity": "6.24.1", 1133 | "babel-runtime": "6.26.0", 1134 | "babel-template": "6.26.0", 1135 | "babel-traverse": "6.26.0", 1136 | "babel-types": "6.26.0" 1137 | }, 1138 | "dependencies": { 1139 | "babel-helper-get-function-arity": { 1140 | "version": "6.24.1", 1141 | "resolved": "https://registry.npmjs.org/babel-helper-get-function-arity/-/babel-helper-get-function-arity-6.24.1.tgz", 1142 | "integrity": "sha1-j3eCqpNAfEHTqlCQj4mwMbG2hT0=", 1143 | "dev": true, 1144 | "requires": { 1145 | "babel-runtime": "6.26.0", 1146 | "babel-types": "6.26.0" 1147 | } 1148 | } 1149 | } 1150 | }, 1151 | "babel-plugin-transform-es2015-shorthand-properties": { 1152 | "version": "6.24.1", 1153 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-shorthand-properties/-/babel-plugin-transform-es2015-shorthand-properties-6.24.1.tgz", 1154 | "integrity": "sha1-JPh11nIch2YbvZmkYi5R8U3jiqA=", 1155 | "dev": true, 1156 | "requires": { 1157 | "babel-runtime": "6.26.0", 1158 | "babel-types": "6.26.0" 1159 | } 1160 | }, 1161 | "babel-plugin-transform-es2015-spread": { 1162 | "version": "6.22.0", 1163 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-spread/-/babel-plugin-transform-es2015-spread-6.22.0.tgz", 1164 | "integrity": "sha1-1taKmfia7cRTbIGlQujdnxdG+NE=", 1165 | "dev": true, 1166 | "requires": { 1167 | "babel-runtime": "6.26.0" 1168 | } 1169 | }, 1170 | "babel-plugin-transform-es2015-sticky-regex": { 1171 | "version": "6.24.1", 1172 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-sticky-regex/-/babel-plugin-transform-es2015-sticky-regex-6.24.1.tgz", 1173 | "integrity": "sha1-AMHNsaynERLN8M9hJsLta0V8zbw=", 1174 | "dev": true, 1175 | "requires": { 1176 | "babel-helper-regex": "6.26.0", 1177 | "babel-runtime": "6.26.0", 1178 | "babel-types": "6.26.0" 1179 | } 1180 | }, 1181 | "babel-plugin-transform-es2015-template-literals": { 1182 | "version": "6.22.0", 1183 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-template-literals/-/babel-plugin-transform-es2015-template-literals-6.22.0.tgz", 1184 | "integrity": "sha1-qEs0UPfp+PH2g51taH2oS7EjbY0=", 1185 | "dev": true, 1186 | "requires": { 1187 | "babel-runtime": "6.26.0" 1188 | } 1189 | }, 1190 | "babel-plugin-transform-es2015-typeof-symbol": { 1191 | "version": "6.23.0", 1192 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-typeof-symbol/-/babel-plugin-transform-es2015-typeof-symbol-6.23.0.tgz", 1193 | "integrity": "sha1-3sCfHN3/lLUqxz1QXITfWdzOs3I=", 1194 | "dev": true, 1195 | "requires": { 1196 | "babel-runtime": "6.26.0" 1197 | } 1198 | }, 1199 | "babel-plugin-transform-es2015-unicode-regex": { 1200 | "version": "6.24.1", 1201 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-unicode-regex/-/babel-plugin-transform-es2015-unicode-regex-6.24.1.tgz", 1202 | "integrity": "sha1-04sS9C6nMj9yk4fxinxa4frrNek=", 1203 | "dev": true, 1204 | "requires": { 1205 | "babel-helper-regex": "6.26.0", 1206 | "babel-runtime": "6.26.0", 1207 | "regexpu-core": "2.0.0" 1208 | } 1209 | }, 1210 | "babel-plugin-transform-exponentiation-operator": { 1211 | "version": "6.24.1", 1212 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-exponentiation-operator/-/babel-plugin-transform-exponentiation-operator-6.24.1.tgz", 1213 | "integrity": "sha1-KrDJx/MJj6SJB3cruBP+QejeOg4=", 1214 | "dev": true, 1215 | "requires": { 1216 | "babel-helper-builder-binary-assignment-operator-visitor": "6.24.1", 1217 | "babel-plugin-syntax-exponentiation-operator": "6.13.0", 1218 | "babel-runtime": "6.26.0" 1219 | } 1220 | }, 1221 | "babel-plugin-transform-export-extensions": { 1222 | "version": "6.22.0", 1223 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-export-extensions/-/babel-plugin-transform-export-extensions-6.22.0.tgz", 1224 | "integrity": "sha1-U3OLR+deghhYnuqUbLvTkQm75lM=", 1225 | "dev": true, 1226 | "requires": { 1227 | "babel-plugin-syntax-export-extensions": "6.13.0", 1228 | "babel-runtime": "6.26.0" 1229 | } 1230 | }, 1231 | "babel-plugin-transform-flow-strip-types": { 1232 | "version": "6.22.0", 1233 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-flow-strip-types/-/babel-plugin-transform-flow-strip-types-6.22.0.tgz", 1234 | "integrity": "sha1-hMtnKTXUNxT9wyvOhFaNh0Qc988=", 1235 | "dev": true, 1236 | "requires": { 1237 | "babel-plugin-syntax-flow": "6.18.0", 1238 | "babel-runtime": "6.26.0" 1239 | } 1240 | }, 1241 | "babel-plugin-transform-function-bind": { 1242 | "version": "6.22.0", 1243 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-function-bind/-/babel-plugin-transform-function-bind-6.22.0.tgz", 1244 | "integrity": "sha1-xvuOlqwpajELjPjqQBRiQH3fapc=", 1245 | "dev": true, 1246 | "requires": { 1247 | "babel-plugin-syntax-function-bind": "6.13.0", 1248 | "babel-runtime": "6.26.0" 1249 | } 1250 | }, 1251 | "babel-plugin-transform-object-rest-spread": { 1252 | "version": "6.26.0", 1253 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-object-rest-spread/-/babel-plugin-transform-object-rest-spread-6.26.0.tgz", 1254 | "integrity": "sha1-DzZpLVD+9rfi1LOsFHgTepY7ewY=", 1255 | "dev": true, 1256 | "requires": { 1257 | "babel-plugin-syntax-object-rest-spread": "6.13.0", 1258 | "babel-runtime": "6.26.0" 1259 | } 1260 | }, 1261 | "babel-plugin-transform-react-display-name": { 1262 | "version": "6.25.0", 1263 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-react-display-name/-/babel-plugin-transform-react-display-name-6.25.0.tgz", 1264 | "integrity": "sha1-Z+K/Hx6ck6sI25Z5LgU5K/LMKNE=", 1265 | "dev": true, 1266 | "requires": { 1267 | "babel-runtime": "6.26.0" 1268 | } 1269 | }, 1270 | "babel-plugin-transform-react-jsx": { 1271 | "version": "6.24.1", 1272 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-react-jsx/-/babel-plugin-transform-react-jsx-6.24.1.tgz", 1273 | "integrity": "sha1-hAoCjn30YN/DotKfDA2R9jduZqM=", 1274 | "dev": true, 1275 | "requires": { 1276 | "babel-helper-builder-react-jsx": "6.26.0", 1277 | "babel-plugin-syntax-jsx": "6.18.0", 1278 | "babel-runtime": "6.26.0" 1279 | } 1280 | }, 1281 | "babel-plugin-transform-react-jsx-self": { 1282 | "version": "6.22.0", 1283 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-react-jsx-self/-/babel-plugin-transform-react-jsx-self-6.22.0.tgz", 1284 | "integrity": "sha1-322AqdomEqEh5t3XVYvL7PBuY24=", 1285 | "dev": true, 1286 | "requires": { 1287 | "babel-plugin-syntax-jsx": "6.18.0", 1288 | "babel-runtime": "6.26.0" 1289 | } 1290 | }, 1291 | "babel-plugin-transform-react-jsx-source": { 1292 | "version": "6.22.0", 1293 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-react-jsx-source/-/babel-plugin-transform-react-jsx-source-6.22.0.tgz", 1294 | "integrity": "sha1-ZqwSFT9c0tF7PBkmj0vwGX9E7NY=", 1295 | "dev": true, 1296 | "requires": { 1297 | "babel-plugin-syntax-jsx": "6.18.0", 1298 | "babel-runtime": "6.26.0" 1299 | } 1300 | }, 1301 | "babel-plugin-transform-regenerator": { 1302 | "version": "6.26.0", 1303 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-regenerator/-/babel-plugin-transform-regenerator-6.26.0.tgz", 1304 | "integrity": "sha1-4HA2lvveJ/Cj78rPi03KL3s6jy8=", 1305 | "dev": true, 1306 | "requires": { 1307 | "regenerator-transform": "0.10.1" 1308 | } 1309 | }, 1310 | "babel-plugin-transform-strict-mode": { 1311 | "version": "6.24.1", 1312 | "resolved": "https://registry.npmjs.org/babel-plugin-transform-strict-mode/-/babel-plugin-transform-strict-mode-6.24.1.tgz", 1313 | "integrity": "sha1-1fr3qleKZbvlkc9e2uBKDGcCB1g=", 1314 | "dev": true, 1315 | "requires": { 1316 | "babel-runtime": "6.26.0", 1317 | "babel-types": "6.26.0" 1318 | } 1319 | }, 1320 | "babel-polyfill": { 1321 | "version": "6.26.0", 1322 | "resolved": "https://registry.npmjs.org/babel-polyfill/-/babel-polyfill-6.26.0.tgz", 1323 | "integrity": "sha1-N5k3q8Z9eJWXCtxiHyhM2WbPIVM=", 1324 | "dev": true, 1325 | "requires": { 1326 | "babel-runtime": "6.26.0", 1327 | "core-js": "2.5.1", 1328 | "regenerator-runtime": "0.10.5" 1329 | }, 1330 | "dependencies": { 1331 | "core-js": { 1332 | "version": "2.5.1", 1333 | "resolved": "https://registry.npmjs.org/core-js/-/core-js-2.5.1.tgz", 1334 | "integrity": "sha1-rmh03GaTd4m4B1T/VCjfZoGcpQs=", 1335 | "dev": true 1336 | }, 1337 | "regenerator-runtime": { 1338 | "version": "0.10.5", 1339 | "resolved": "https://registry.npmjs.org/regenerator-runtime/-/regenerator-runtime-0.10.5.tgz", 1340 | "integrity": "sha1-M2w+/BIgrc7dosn6tntaeVWjNlg=", 1341 | "dev": true 1342 | } 1343 | } 1344 | }, 1345 | "babel-preset-env": { 1346 | "version": "1.6.1", 1347 | "resolved": "https://registry.npmjs.org/babel-preset-env/-/babel-preset-env-1.6.1.tgz", 1348 | "integrity": "sha512-W6VIyA6Ch9ePMI7VptNn2wBM6dbG0eSz25HEiL40nQXCsXGTGZSTZu1Iap+cj3Q0S5a7T9+529l/5Bkvd+afNA==", 1349 | "dev": true, 1350 | "requires": { 1351 | "babel-plugin-check-es2015-constants": "6.22.0", 1352 | "babel-plugin-syntax-trailing-function-commas": "6.22.0", 1353 | "babel-plugin-transform-async-to-generator": "6.24.1", 1354 | "babel-plugin-transform-es2015-arrow-functions": "6.22.0", 1355 | "babel-plugin-transform-es2015-block-scoped-functions": "6.22.0", 1356 | "babel-plugin-transform-es2015-block-scoping": "6.26.0", 1357 | "babel-plugin-transform-es2015-classes": "6.24.1", 1358 | "babel-plugin-transform-es2015-computed-properties": "6.24.1", 1359 | "babel-plugin-transform-es2015-destructuring": "6.23.0", 1360 | "babel-plugin-transform-es2015-duplicate-keys": "6.24.1", 1361 | "babel-plugin-transform-es2015-for-of": "6.23.0", 1362 | "babel-plugin-transform-es2015-function-name": "6.24.1", 1363 | "babel-plugin-transform-es2015-literals": "6.22.0", 1364 | "babel-plugin-transform-es2015-modules-amd": "6.24.1", 1365 | "babel-plugin-transform-es2015-modules-commonjs": "6.26.0", 1366 | "babel-plugin-transform-es2015-modules-systemjs": "6.24.1", 1367 | "babel-plugin-transform-es2015-modules-umd": "6.24.1", 1368 | "babel-plugin-transform-es2015-object-super": "6.24.1", 1369 | "babel-plugin-transform-es2015-parameters": "6.24.1", 1370 | "babel-plugin-transform-es2015-shorthand-properties": "6.24.1", 1371 | "babel-plugin-transform-es2015-spread": "6.22.0", 1372 | "babel-plugin-transform-es2015-sticky-regex": "6.24.1", 1373 | "babel-plugin-transform-es2015-template-literals": "6.22.0", 1374 | "babel-plugin-transform-es2015-typeof-symbol": "6.23.0", 1375 | "babel-plugin-transform-es2015-unicode-regex": "6.24.1", 1376 | "babel-plugin-transform-exponentiation-operator": "6.24.1", 1377 | "babel-plugin-transform-regenerator": "6.26.0", 1378 | "browserslist": "2.7.0", 1379 | "invariant": "2.2.2", 1380 | "semver": "5.4.1" 1381 | } 1382 | }, 1383 | "babel-preset-es2015": { 1384 | "version": "6.24.1", 1385 | "resolved": "https://registry.npmjs.org/babel-preset-es2015/-/babel-preset-es2015-6.24.1.tgz", 1386 | "integrity": "sha1-1EBQ1rwsn+6nAqrzjXJ6AhBTiTk=", 1387 | "dev": true, 1388 | "requires": { 1389 | "babel-plugin-check-es2015-constants": "6.22.0", 1390 | "babel-plugin-transform-es2015-arrow-functions": "6.22.0", 1391 | "babel-plugin-transform-es2015-block-scoped-functions": "6.22.0", 1392 | "babel-plugin-transform-es2015-block-scoping": "6.26.0", 1393 | "babel-plugin-transform-es2015-classes": "6.24.1", 1394 | "babel-plugin-transform-es2015-computed-properties": "6.24.1", 1395 | "babel-plugin-transform-es2015-destructuring": "6.23.0", 1396 | "babel-plugin-transform-es2015-duplicate-keys": "6.24.1", 1397 | "babel-plugin-transform-es2015-for-of": "6.23.0", 1398 | "babel-plugin-transform-es2015-function-name": "6.24.1", 1399 | "babel-plugin-transform-es2015-literals": "6.22.0", 1400 | "babel-plugin-transform-es2015-modules-amd": "6.24.1", 1401 | "babel-plugin-transform-es2015-modules-commonjs": "6.26.0", 1402 | "babel-plugin-transform-es2015-modules-systemjs": "6.24.1", 1403 | "babel-plugin-transform-es2015-modules-umd": "6.24.1", 1404 | "babel-plugin-transform-es2015-object-super": "6.24.1", 1405 | "babel-plugin-transform-es2015-parameters": "6.24.1", 1406 | "babel-plugin-transform-es2015-shorthand-properties": "6.24.1", 1407 | "babel-plugin-transform-es2015-spread": "6.22.0", 1408 | "babel-plugin-transform-es2015-sticky-regex": "6.24.1", 1409 | "babel-plugin-transform-es2015-template-literals": "6.22.0", 1410 | "babel-plugin-transform-es2015-typeof-symbol": "6.23.0", 1411 | "babel-plugin-transform-es2015-unicode-regex": "6.24.1", 1412 | "babel-plugin-transform-regenerator": "6.26.0" 1413 | } 1414 | }, 1415 | "babel-preset-flow": { 1416 | "version": "6.23.0", 1417 | "resolved": "https://registry.npmjs.org/babel-preset-flow/-/babel-preset-flow-6.23.0.tgz", 1418 | "integrity": "sha1-5xIYiHCFrpoktb5Baa/7WZgWxJ0=", 1419 | "dev": true, 1420 | "requires": { 1421 | "babel-plugin-transform-flow-strip-types": "6.22.0" 1422 | } 1423 | }, 1424 | "babel-preset-react": { 1425 | "version": "6.24.1", 1426 | "resolved": "https://registry.npmjs.org/babel-preset-react/-/babel-preset-react-6.24.1.tgz", 1427 | "integrity": "sha1-umnfrqRfw+xjm2pOzqbhdwLJE4A=", 1428 | "dev": true, 1429 | "requires": { 1430 | "babel-plugin-syntax-jsx": "6.18.0", 1431 | "babel-plugin-transform-react-display-name": "6.25.0", 1432 | "babel-plugin-transform-react-jsx": "6.24.1", 1433 | "babel-plugin-transform-react-jsx-self": "6.22.0", 1434 | "babel-plugin-transform-react-jsx-source": "6.22.0", 1435 | "babel-preset-flow": "6.23.0" 1436 | } 1437 | }, 1438 | "babel-preset-stage-0": { 1439 | "version": "6.24.1", 1440 | "resolved": "https://registry.npmjs.org/babel-preset-stage-0/-/babel-preset-stage-0-6.24.1.tgz", 1441 | "integrity": "sha1-VkLRUEL5E4TX5a+LyIsduVsDnmo=", 1442 | "dev": true, 1443 | "requires": { 1444 | "babel-plugin-transform-do-expressions": "6.22.0", 1445 | "babel-plugin-transform-function-bind": "6.22.0", 1446 | "babel-preset-stage-1": "6.24.1" 1447 | } 1448 | }, 1449 | "babel-preset-stage-1": { 1450 | "version": "6.24.1", 1451 | "resolved": "https://registry.npmjs.org/babel-preset-stage-1/-/babel-preset-stage-1-6.24.1.tgz", 1452 | "integrity": "sha1-dpLNfc1oSZB+auSgqFWJz7niv7A=", 1453 | "dev": true, 1454 | "requires": { 1455 | "babel-plugin-transform-class-constructor-call": "6.24.1", 1456 | "babel-plugin-transform-export-extensions": "6.22.0", 1457 | "babel-preset-stage-2": "6.24.1" 1458 | } 1459 | }, 1460 | "babel-preset-stage-2": { 1461 | "version": "6.24.1", 1462 | "resolved": "https://registry.npmjs.org/babel-preset-stage-2/-/babel-preset-stage-2-6.24.1.tgz", 1463 | "integrity": "sha1-2eKWD7PXEYfw5k7sYrwHdnIZvcE=", 1464 | "dev": true, 1465 | "requires": { 1466 | "babel-plugin-syntax-dynamic-import": "6.18.0", 1467 | "babel-plugin-transform-class-properties": "6.24.1", 1468 | "babel-plugin-transform-decorators": "6.24.1", 1469 | "babel-preset-stage-3": "6.24.1" 1470 | } 1471 | }, 1472 | "babel-preset-stage-3": { 1473 | "version": "6.24.1", 1474 | "resolved": "https://registry.npmjs.org/babel-preset-stage-3/-/babel-preset-stage-3-6.24.1.tgz", 1475 | "integrity": "sha1-g2raCp56f6N8sTj7kyb4eTSkg5U=", 1476 | "dev": true, 1477 | "requires": { 1478 | "babel-plugin-syntax-trailing-function-commas": "6.22.0", 1479 | "babel-plugin-transform-async-generator-functions": "6.24.1", 1480 | "babel-plugin-transform-async-to-generator": "6.24.1", 1481 | "babel-plugin-transform-exponentiation-operator": "6.24.1", 1482 | "babel-plugin-transform-object-rest-spread": "6.26.0" 1483 | } 1484 | }, 1485 | "babel-register": { 1486 | "version": "6.26.0", 1487 | "resolved": "https://registry.npmjs.org/babel-register/-/babel-register-6.26.0.tgz", 1488 | "integrity": "sha1-btAhFz4vy0htestFxgCahW9kcHE=", 1489 | "dev": true, 1490 | "requires": { 1491 | "babel-core": "6.26.0", 1492 | "babel-runtime": "6.26.0", 1493 | "core-js": "2.5.1", 1494 | "home-or-tmp": "2.0.0", 1495 | "lodash": "4.17.4", 1496 | "mkdirp": "0.5.1", 1497 | "source-map-support": "0.4.18" 1498 | }, 1499 | "dependencies": { 1500 | "core-js": { 1501 | "version": "2.5.1", 1502 | "resolved": "https://registry.npmjs.org/core-js/-/core-js-2.5.1.tgz", 1503 | "integrity": "sha1-rmh03GaTd4m4B1T/VCjfZoGcpQs=", 1504 | "dev": true 1505 | } 1506 | } 1507 | }, 1508 | "babel-runtime": { 1509 | "version": "6.26.0", 1510 | "resolved": "https://registry.npmjs.org/babel-runtime/-/babel-runtime-6.26.0.tgz", 1511 | "integrity": "sha1-llxwWGaOgrVde/4E/yM3vItWR/4=", 1512 | "dev": true, 1513 | "requires": { 1514 | "core-js": "2.5.1", 1515 | "regenerator-runtime": "0.11.0" 1516 | }, 1517 | "dependencies": { 1518 | "core-js": { 1519 | "version": "2.5.1", 1520 | "resolved": "https://registry.npmjs.org/core-js/-/core-js-2.5.1.tgz", 1521 | "integrity": "sha1-rmh03GaTd4m4B1T/VCjfZoGcpQs=", 1522 | "dev": true 1523 | } 1524 | } 1525 | }, 1526 | "babel-template": { 1527 | "version": "6.26.0", 1528 | "resolved": "https://registry.npmjs.org/babel-template/-/babel-template-6.26.0.tgz", 1529 | "integrity": "sha1-3gPi0WOWsGn0bdn/+FIfsaDjXgI=", 1530 | "dev": true, 1531 | "requires": { 1532 | "babel-runtime": "6.26.0", 1533 | "babel-traverse": "6.26.0", 1534 | "babel-types": "6.26.0", 1535 | "babylon": "6.18.0", 1536 | "lodash": "4.17.4" 1537 | } 1538 | }, 1539 | "babel-traverse": { 1540 | "version": "6.26.0", 1541 | "resolved": "https://registry.npmjs.org/babel-traverse/-/babel-traverse-6.26.0.tgz", 1542 | "integrity": "sha1-RqnL1+3MYsjlwGTi0tjQ9ANXZu4=", 1543 | "dev": true, 1544 | "requires": { 1545 | "babel-code-frame": "6.26.0", 1546 | "babel-messages": "6.23.0", 1547 | "babel-runtime": "6.26.0", 1548 | "babel-types": "6.26.0", 1549 | "babylon": "6.18.0", 1550 | "debug": "2.6.9", 1551 | "globals": "9.18.0", 1552 | "invariant": "2.2.2", 1553 | "lodash": "4.17.4" 1554 | } 1555 | }, 1556 | "babel-types": { 1557 | "version": "6.26.0", 1558 | "resolved": "https://registry.npmjs.org/babel-types/-/babel-types-6.26.0.tgz", 1559 | "integrity": "sha1-o7Bz+Uq0nrb6Vc1lInozQ4BjJJc=", 1560 | "dev": true, 1561 | "requires": { 1562 | "babel-runtime": "6.26.0", 1563 | "esutils": "2.0.2", 1564 | "lodash": "4.17.4", 1565 | "to-fast-properties": "1.0.3" 1566 | } 1567 | }, 1568 | "babylon": { 1569 | "version": "6.18.0", 1570 | "resolved": "https://registry.npmjs.org/babylon/-/babylon-6.18.0.tgz", 1571 | "integrity": "sha512-q/UEjfGJ2Cm3oKV71DJz9d25TPnq5rhBVL2Q4fA5wcC3jcrdn7+SssEybFIxwAvvP+YCsCYNKughoF33GxgycQ==", 1572 | "dev": true 1573 | }, 1574 | "balanced-match": { 1575 | "version": "1.0.0", 1576 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz", 1577 | "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=", 1578 | "dev": true 1579 | }, 1580 | "binary-extensions": { 1581 | "version": "1.10.0", 1582 | "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-1.10.0.tgz", 1583 | "integrity": "sha1-muuabF6IY4qtFx4Wf1kAq+JINdA=", 1584 | "dev": true, 1585 | "optional": true 1586 | }, 1587 | "blips": { 1588 | "version": "1.0.0-rc4", 1589 | "resolved": "https://registry.npmjs.org/blips/-/blips-1.0.0-rc4.tgz", 1590 | "integrity": "sha512-lI14bH7T6+fJnmXVnjrusef5FCBDl79iMHr6OBIPOyp3d4N3wJCvCawhDSGtMeYXSx8KUTNdzp1NAxBKk+IysA==", 1591 | "dev": true, 1592 | "requires": { 1593 | "apollo-fetch": "0.7.0", 1594 | "graphql-subscriptions": "0.5.5", 1595 | "graphql-tools": "2.12.0", 1596 | "loose-envify": "1.3.1", 1597 | "state-clerk": "1.3.0", 1598 | "zen-observable": "0.6.0" 1599 | } 1600 | }, 1601 | "brace-expansion": { 1602 | "version": "1.1.8", 1603 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.8.tgz", 1604 | "integrity": "sha1-wHshHHyVLsH479Uad+8NHTmQopI=", 1605 | "dev": true, 1606 | "requires": { 1607 | "balanced-match": "1.0.0", 1608 | "concat-map": "0.0.1" 1609 | } 1610 | }, 1611 | "braces": { 1612 | "version": "1.8.5", 1613 | "resolved": "https://registry.npmjs.org/braces/-/braces-1.8.5.tgz", 1614 | "integrity": "sha1-uneWLhLf+WnWt2cR6RS3N4V79qc=", 1615 | "dev": true, 1616 | "requires": { 1617 | "expand-range": "1.8.2", 1618 | "preserve": "0.2.0", 1619 | "repeat-element": "1.1.2" 1620 | } 1621 | }, 1622 | "browser-resolve": { 1623 | "version": "1.11.2", 1624 | "resolved": "https://registry.npmjs.org/browser-resolve/-/browser-resolve-1.11.2.tgz", 1625 | "integrity": "sha1-j/CbCixCFxihBRwmCzLkj0QpOM4=", 1626 | "dev": true, 1627 | "requires": { 1628 | "resolve": "1.1.7" 1629 | }, 1630 | "dependencies": { 1631 | "resolve": { 1632 | "version": "1.1.7", 1633 | "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.1.7.tgz", 1634 | "integrity": "sha1-IDEU2CrSxe2ejgQRs5ModeiJ6Xs=", 1635 | "dev": true 1636 | } 1637 | } 1638 | }, 1639 | "browserslist": { 1640 | "version": "2.7.0", 1641 | "resolved": "https://registry.npmjs.org/browserslist/-/browserslist-2.7.0.tgz", 1642 | "integrity": "sha512-s34mrlczJsfbJu//mz/m9zlOy/S6tiP6El1u8iC1gTfEnzKXvxo8RAoCxS/MmojB7rd7bnfYzvKQNHykWaUWWw==", 1643 | "dev": true, 1644 | "requires": { 1645 | "caniuse-lite": "1.0.30000758", 1646 | "electron-to-chromium": "1.3.27" 1647 | } 1648 | }, 1649 | "builtin-modules": { 1650 | "version": "1.1.1", 1651 | "resolved": "https://registry.npmjs.org/builtin-modules/-/builtin-modules-1.1.1.tgz", 1652 | "integrity": "sha1-Jw8HbFpywC9bZaR9+Uxf46J4iS8=", 1653 | "dev": true 1654 | }, 1655 | "caller-path": { 1656 | "version": "0.1.0", 1657 | "resolved": "https://registry.npmjs.org/caller-path/-/caller-path-0.1.0.tgz", 1658 | "integrity": "sha1-lAhe9jWB7NPaqSREqP6U6CV3dR8=", 1659 | "dev": true, 1660 | "requires": { 1661 | "callsites": "0.2.0" 1662 | } 1663 | }, 1664 | "callsites": { 1665 | "version": "0.2.0", 1666 | "resolved": "https://registry.npmjs.org/callsites/-/callsites-0.2.0.tgz", 1667 | "integrity": "sha1-r6uWJikQp/M8GaV3WCXGnzTjUMo=", 1668 | "dev": true 1669 | }, 1670 | "caniuse-lite": { 1671 | "version": "1.0.30000758", 1672 | "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30000758.tgz", 1673 | "integrity": "sha1-4mEUAHZlEEnPaJHtS8ZJtcjCbGk=", 1674 | "dev": true 1675 | }, 1676 | "chalk": { 1677 | "version": "1.1.3", 1678 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-1.1.3.tgz", 1679 | "integrity": "sha1-qBFcVeSnAv5NFQq9OHKCKn4J/Jg=", 1680 | "dev": true, 1681 | "requires": { 1682 | "ansi-styles": "2.2.1", 1683 | "escape-string-regexp": "1.0.5", 1684 | "has-ansi": "2.0.0", 1685 | "strip-ansi": "3.0.1", 1686 | "supports-color": "2.0.0" 1687 | } 1688 | }, 1689 | "chokidar": { 1690 | "version": "1.7.0", 1691 | "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-1.7.0.tgz", 1692 | "integrity": "sha1-eY5ol3gVHIB2tLNg5e3SjNortGg=", 1693 | "dev": true, 1694 | "optional": true, 1695 | "requires": { 1696 | "anymatch": "1.3.2", 1697 | "async-each": "1.0.1", 1698 | "glob-parent": "2.0.0", 1699 | "inherits": "2.0.3", 1700 | "is-binary-path": "1.0.1", 1701 | "is-glob": "2.0.1", 1702 | "path-is-absolute": "1.0.1", 1703 | "readdirp": "2.1.0" 1704 | } 1705 | }, 1706 | "circular-json": { 1707 | "version": "0.3.3", 1708 | "resolved": "https://registry.npmjs.org/circular-json/-/circular-json-0.3.3.tgz", 1709 | "integrity": "sha512-UZK3NBx2Mca+b5LsG7bY183pHWt5Y1xts4P3Pz7ENTwGVnJOUWbRb3ocjvX7hx9tq/yTAdclXm9sZ38gNuem4A==", 1710 | "dev": true 1711 | }, 1712 | "cli-cursor": { 1713 | "version": "2.1.0", 1714 | "resolved": "https://registry.npmjs.org/cli-cursor/-/cli-cursor-2.1.0.tgz", 1715 | "integrity": "sha1-s12sN2R5+sw+lHR9QdDQ9SOP/LU=", 1716 | "dev": true, 1717 | "requires": { 1718 | "restore-cursor": "2.0.0" 1719 | } 1720 | }, 1721 | "cli-width": { 1722 | "version": "2.2.0", 1723 | "resolved": "https://registry.npmjs.org/cli-width/-/cli-width-2.2.0.tgz", 1724 | "integrity": "sha1-/xnt6Kml5XkyQUewwR8PvLq+1jk=", 1725 | "dev": true 1726 | }, 1727 | "co": { 1728 | "version": "4.6.0", 1729 | "resolved": "https://registry.npmjs.org/co/-/co-4.6.0.tgz", 1730 | "integrity": "sha1-bqa989hTrlTMuOR7+gvz+QMfsYQ=", 1731 | "dev": true 1732 | }, 1733 | "color-convert": { 1734 | "version": "1.9.0", 1735 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.0.tgz", 1736 | "integrity": "sha1-Gsz5fdc5uYO/mU1W/sj5WFNkG3o=", 1737 | "dev": true, 1738 | "requires": { 1739 | "color-name": "1.1.3" 1740 | } 1741 | }, 1742 | "color-name": { 1743 | "version": "1.1.3", 1744 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 1745 | "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=", 1746 | "dev": true 1747 | }, 1748 | "commander": { 1749 | "version": "2.11.0", 1750 | "resolved": "https://registry.npmjs.org/commander/-/commander-2.11.0.tgz", 1751 | "integrity": "sha512-b0553uYA5YAEGgyYIGYROzKQ7X5RAqedkfjiZxwi0kL1g3bOaBNNZfYkzt/CL0umgD5wc9Jec2FbB98CjkMRvQ==", 1752 | "dev": true 1753 | }, 1754 | "concat-map": { 1755 | "version": "0.0.1", 1756 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 1757 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=", 1758 | "dev": true 1759 | }, 1760 | "concat-stream": { 1761 | "version": "1.6.0", 1762 | "resolved": "https://registry.npmjs.org/concat-stream/-/concat-stream-1.6.0.tgz", 1763 | "integrity": "sha1-CqxmL9Ur54lk1VMvaUeE5wEQrPc=", 1764 | "dev": true, 1765 | "requires": { 1766 | "inherits": "2.0.3", 1767 | "readable-stream": "2.3.3", 1768 | "typedarray": "0.0.6" 1769 | } 1770 | }, 1771 | "contains-path": { 1772 | "version": "0.1.0", 1773 | "resolved": "https://registry.npmjs.org/contains-path/-/contains-path-0.1.0.tgz", 1774 | "integrity": "sha1-/ozxhP9mcLa67wGp1IYaXL7EEgo=", 1775 | "dev": true 1776 | }, 1777 | "convert-source-map": { 1778 | "version": "1.5.0", 1779 | "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-1.5.0.tgz", 1780 | "integrity": "sha1-ms1whRxtXf3ZPZKC5e35SgP/RrU=", 1781 | "dev": true 1782 | }, 1783 | "core-js": { 1784 | "version": "1.2.7", 1785 | "resolved": "https://registry.npmjs.org/core-js/-/core-js-1.2.7.tgz", 1786 | "integrity": "sha1-ZSKUwUZR2yj6k70tX/KYOk8IxjY=" 1787 | }, 1788 | "core-util-is": { 1789 | "version": "1.0.2", 1790 | "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.2.tgz", 1791 | "integrity": "sha1-tf1UIgqivFq1eqtxQMlAdUUDwac=", 1792 | "dev": true 1793 | }, 1794 | "cross-env": { 1795 | "version": "5.1.0", 1796 | "resolved": "https://registry.npmjs.org/cross-env/-/cross-env-5.1.0.tgz", 1797 | "integrity": "sha512-R+0paw9UZQc7odHjIxElqyYotgyMlhcUMTfRxiv4I22grgvS5WOSSfCpyfAZUDhP/c9ShSRv+Hzfxs6fY4JA7g==", 1798 | "dev": true, 1799 | "requires": { 1800 | "cross-spawn": "5.1.0", 1801 | "is-windows": "1.0.1" 1802 | } 1803 | }, 1804 | "cross-fetch": { 1805 | "version": "1.1.1", 1806 | "resolved": "https://registry.npmjs.org/cross-fetch/-/cross-fetch-1.1.1.tgz", 1807 | "integrity": "sha512-+VJE04+UfxxmBfcnmAu/lKor53RUCx/1ilOti4p+JgrnLQ4AZZIRoe2OEd76VaHyWQmQxqKnV+TaqjHC4r0HWw==", 1808 | "dev": true, 1809 | "requires": { 1810 | "node-fetch": "1.7.3", 1811 | "whatwg-fetch": "2.0.3" 1812 | } 1813 | }, 1814 | "cross-spawn": { 1815 | "version": "5.1.0", 1816 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-5.1.0.tgz", 1817 | "integrity": "sha1-6L0O/uWPz/b4+UUQoKVUu/ojVEk=", 1818 | "dev": true, 1819 | "requires": { 1820 | "lru-cache": "4.1.1", 1821 | "shebang-command": "1.2.0", 1822 | "which": "1.3.0" 1823 | } 1824 | }, 1825 | "debug": { 1826 | "version": "2.6.9", 1827 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 1828 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 1829 | "dev": true, 1830 | "requires": { 1831 | "ms": "2.0.0" 1832 | } 1833 | }, 1834 | "deep-is": { 1835 | "version": "0.1.3", 1836 | "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.3.tgz", 1837 | "integrity": "sha1-s2nW+128E+7PUk+RsHD+7cNXzzQ=", 1838 | "dev": true 1839 | }, 1840 | "define-properties": { 1841 | "version": "1.1.2", 1842 | "resolved": "https://registry.npmjs.org/define-properties/-/define-properties-1.1.2.tgz", 1843 | "integrity": "sha1-g6c/L+pWmJj7c3GTyPhzyvbUXJQ=", 1844 | "dev": true, 1845 | "requires": { 1846 | "foreach": "2.0.5", 1847 | "object-keys": "1.0.11" 1848 | } 1849 | }, 1850 | "del": { 1851 | "version": "2.2.2", 1852 | "resolved": "https://registry.npmjs.org/del/-/del-2.2.2.tgz", 1853 | "integrity": "sha1-wSyYHQZ4RshLyvhiz/kw2Qf/0ag=", 1854 | "dev": true, 1855 | "requires": { 1856 | "globby": "5.0.0", 1857 | "is-path-cwd": "1.0.0", 1858 | "is-path-in-cwd": "1.0.0", 1859 | "object-assign": "4.1.1", 1860 | "pify": "2.3.0", 1861 | "pinkie-promise": "2.0.1", 1862 | "rimraf": "2.6.2" 1863 | } 1864 | }, 1865 | "deprecated-decorator": { 1866 | "version": "0.1.6", 1867 | "resolved": "https://registry.npmjs.org/deprecated-decorator/-/deprecated-decorator-0.1.6.tgz", 1868 | "integrity": "sha1-AJZjF7ehL+kvPMgx91g68ym4bDc=", 1869 | "dev": true 1870 | }, 1871 | "detect-indent": { 1872 | "version": "4.0.0", 1873 | "resolved": "https://registry.npmjs.org/detect-indent/-/detect-indent-4.0.0.tgz", 1874 | "integrity": "sha1-920GQ1LN9Docts5hnE7jqUdd4gg=", 1875 | "dev": true, 1876 | "requires": { 1877 | "repeating": "2.0.1" 1878 | } 1879 | }, 1880 | "doctrine": { 1881 | "version": "2.0.0", 1882 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-2.0.0.tgz", 1883 | "integrity": "sha1-xz2NKQnSIpHhoAejlYBNqLZl/mM=", 1884 | "dev": true, 1885 | "requires": { 1886 | "esutils": "2.0.2", 1887 | "isarray": "1.0.0" 1888 | } 1889 | }, 1890 | "electron-to-chromium": { 1891 | "version": "1.3.27", 1892 | "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.3.27.tgz", 1893 | "integrity": "sha1-eOy4o5kGYYe7N07t412ccFZagD0=", 1894 | "dev": true 1895 | }, 1896 | "encoding": { 1897 | "version": "0.1.12", 1898 | "resolved": "https://registry.npmjs.org/encoding/-/encoding-0.1.12.tgz", 1899 | "integrity": "sha1-U4tm8+5izRq1HsMjgp0flIDHS+s=", 1900 | "requires": { 1901 | "iconv-lite": "0.4.19" 1902 | } 1903 | }, 1904 | "error-ex": { 1905 | "version": "1.3.1", 1906 | "resolved": "https://registry.npmjs.org/error-ex/-/error-ex-1.3.1.tgz", 1907 | "integrity": "sha1-+FWobOYa3E6GIcPNoh56dhLDqNw=", 1908 | "dev": true, 1909 | "requires": { 1910 | "is-arrayish": "0.2.1" 1911 | } 1912 | }, 1913 | "es-abstract": { 1914 | "version": "1.10.0", 1915 | "resolved": "https://registry.npmjs.org/es-abstract/-/es-abstract-1.10.0.tgz", 1916 | "integrity": "sha512-/uh/DhdqIOSkAWifU+8nG78vlQxdLckUdI/sPgy0VhuXi2qJ7T8czBmqIYtLQVpCIFYafChnsRsB5pyb1JdmCQ==", 1917 | "dev": true, 1918 | "requires": { 1919 | "es-to-primitive": "1.1.1", 1920 | "function-bind": "1.1.1", 1921 | "has": "1.0.1", 1922 | "is-callable": "1.1.3", 1923 | "is-regex": "1.0.4" 1924 | } 1925 | }, 1926 | "es-to-primitive": { 1927 | "version": "1.1.1", 1928 | "resolved": "https://registry.npmjs.org/es-to-primitive/-/es-to-primitive-1.1.1.tgz", 1929 | "integrity": "sha1-RTVSSKiJeQNLZ5Lhm7gfK3l13Q0=", 1930 | "dev": true, 1931 | "requires": { 1932 | "is-callable": "1.1.3", 1933 | "is-date-object": "1.0.1", 1934 | "is-symbol": "1.0.1" 1935 | } 1936 | }, 1937 | "es6-promise": { 1938 | "version": "4.1.1", 1939 | "resolved": "https://registry.npmjs.org/es6-promise/-/es6-promise-4.1.1.tgz", 1940 | "integrity": "sha512-OaU1hHjgJf+b0NzsxCg7NdIYERD6Hy/PEmFLTjw+b65scuisG3Kt4QoTvJ66BBkPZ581gr0kpoVzKnxniM8nng==", 1941 | "dev": true 1942 | }, 1943 | "escape-string-regexp": { 1944 | "version": "1.0.5", 1945 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", 1946 | "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=", 1947 | "dev": true 1948 | }, 1949 | "eslint": { 1950 | "version": "4.9.0", 1951 | "resolved": "https://registry.npmjs.org/eslint/-/eslint-4.9.0.tgz", 1952 | "integrity": "sha1-doedJ0BoJhsZH+Dy9Wx0wvQgjos=", 1953 | "dev": true, 1954 | "requires": { 1955 | "ajv": "5.3.0", 1956 | "babel-code-frame": "6.26.0", 1957 | "chalk": "2.3.0", 1958 | "concat-stream": "1.6.0", 1959 | "cross-spawn": "5.1.0", 1960 | "debug": "3.1.0", 1961 | "doctrine": "2.0.0", 1962 | "eslint-scope": "3.7.1", 1963 | "espree": "3.5.1", 1964 | "esquery": "1.0.0", 1965 | "estraverse": "4.2.0", 1966 | "esutils": "2.0.2", 1967 | "file-entry-cache": "2.0.0", 1968 | "functional-red-black-tree": "1.0.1", 1969 | "glob": "7.1.2", 1970 | "globals": "9.18.0", 1971 | "ignore": "3.3.7", 1972 | "imurmurhash": "0.1.4", 1973 | "inquirer": "3.3.0", 1974 | "is-resolvable": "1.0.0", 1975 | "js-yaml": "3.10.0", 1976 | "json-stable-stringify": "1.0.1", 1977 | "levn": "0.3.0", 1978 | "lodash": "4.17.4", 1979 | "minimatch": "3.0.4", 1980 | "mkdirp": "0.5.1", 1981 | "natural-compare": "1.4.0", 1982 | "optionator": "0.8.2", 1983 | "path-is-inside": "1.0.2", 1984 | "pluralize": "7.0.0", 1985 | "progress": "2.0.0", 1986 | "require-uncached": "1.0.3", 1987 | "semver": "5.4.1", 1988 | "strip-ansi": "4.0.0", 1989 | "strip-json-comments": "2.0.1", 1990 | "table": "4.0.2", 1991 | "text-table": "0.2.0" 1992 | }, 1993 | "dependencies": { 1994 | "ansi-regex": { 1995 | "version": "3.0.0", 1996 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-3.0.0.tgz", 1997 | "integrity": "sha1-7QMXwyIGT3lGbAKWa922Bas32Zg=", 1998 | "dev": true 1999 | }, 2000 | "ansi-styles": { 2001 | "version": "3.2.0", 2002 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.0.tgz", 2003 | "integrity": "sha512-NnSOmMEYtVR2JVMIGTzynRkkaxtiq1xnFBcdQD/DnNCYPoEPsVJhM98BDyaoNOQIi7p4okdi3E27eN7GQbsUug==", 2004 | "dev": true, 2005 | "requires": { 2006 | "color-convert": "1.9.0" 2007 | } 2008 | }, 2009 | "chalk": { 2010 | "version": "2.3.0", 2011 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.3.0.tgz", 2012 | "integrity": "sha512-Az5zJR2CBujap2rqXGaJKaPHyJ0IrUimvYNX+ncCy8PJP4ltOGTrHUIo097ZaL2zMeKYpiCdqDvS6zdrTFok3Q==", 2013 | "dev": true, 2014 | "requires": { 2015 | "ansi-styles": "3.2.0", 2016 | "escape-string-regexp": "1.0.5", 2017 | "supports-color": "4.5.0" 2018 | } 2019 | }, 2020 | "debug": { 2021 | "version": "3.1.0", 2022 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.1.0.tgz", 2023 | "integrity": "sha512-OX8XqP7/1a9cqkxYw2yXss15f26NKWBpDXQd0/uK/KPqdQhxbPa994hnzjcE2VqQpDslf55723cKPUOGSmMY3g==", 2024 | "dev": true, 2025 | "requires": { 2026 | "ms": "2.0.0" 2027 | } 2028 | }, 2029 | "strip-ansi": { 2030 | "version": "4.0.0", 2031 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-4.0.0.tgz", 2032 | "integrity": "sha1-qEeQIusaw2iocTibY1JixQXuNo8=", 2033 | "dev": true, 2034 | "requires": { 2035 | "ansi-regex": "3.0.0" 2036 | } 2037 | }, 2038 | "supports-color": { 2039 | "version": "4.5.0", 2040 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-4.5.0.tgz", 2041 | "integrity": "sha1-vnoN5ITexcXN34s9WRJQRJEvY1s=", 2042 | "dev": true, 2043 | "requires": { 2044 | "has-flag": "2.0.0" 2045 | } 2046 | } 2047 | } 2048 | }, 2049 | "eslint-config-standard": { 2050 | "version": "10.2.1", 2051 | "resolved": "https://registry.npmjs.org/eslint-config-standard/-/eslint-config-standard-10.2.1.tgz", 2052 | "integrity": "sha1-wGHk0GbzedwXzVYsZOgZtN1FRZE=", 2053 | "dev": true 2054 | }, 2055 | "eslint-import-resolver-node": { 2056 | "version": "0.3.1", 2057 | "resolved": "https://registry.npmjs.org/eslint-import-resolver-node/-/eslint-import-resolver-node-0.3.1.tgz", 2058 | "integrity": "sha512-yUtXS15gIcij68NmXmP9Ni77AQuCN0itXbCc/jWd8C6/yKZaSNXicpC8cgvjnxVdmfsosIXrjpzFq7GcDryb6A==", 2059 | "dev": true, 2060 | "requires": { 2061 | "debug": "2.6.9", 2062 | "resolve": "1.5.0" 2063 | } 2064 | }, 2065 | "eslint-module-utils": { 2066 | "version": "2.1.1", 2067 | "resolved": "https://registry.npmjs.org/eslint-module-utils/-/eslint-module-utils-2.1.1.tgz", 2068 | "integrity": "sha512-jDI/X5l/6D1rRD/3T43q8Qgbls2nq5km5KSqiwlyUbGo5+04fXhMKdCPhjwbqAa6HXWaMxj8Q4hQDIh7IadJQw==", 2069 | "dev": true, 2070 | "requires": { 2071 | "debug": "2.6.9", 2072 | "pkg-dir": "1.0.0" 2073 | } 2074 | }, 2075 | "eslint-plugin-import": { 2076 | "version": "2.8.0", 2077 | "resolved": "https://registry.npmjs.org/eslint-plugin-import/-/eslint-plugin-import-2.8.0.tgz", 2078 | "integrity": "sha512-Rf7dfKJxZ16QuTgVv1OYNxkZcsu/hULFnC+e+w0Gzi6jMC3guQoWQgxYxc54IDRinlb6/0v5z/PxxIKmVctN+g==", 2079 | "dev": true, 2080 | "requires": { 2081 | "builtin-modules": "1.1.1", 2082 | "contains-path": "0.1.0", 2083 | "debug": "2.6.9", 2084 | "doctrine": "1.5.0", 2085 | "eslint-import-resolver-node": "0.3.1", 2086 | "eslint-module-utils": "2.1.1", 2087 | "has": "1.0.1", 2088 | "lodash.cond": "4.5.2", 2089 | "minimatch": "3.0.4", 2090 | "read-pkg-up": "2.0.0" 2091 | }, 2092 | "dependencies": { 2093 | "doctrine": { 2094 | "version": "1.5.0", 2095 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-1.5.0.tgz", 2096 | "integrity": "sha1-N53Ocw9hZvds76TmcHoVmwLFpvo=", 2097 | "dev": true, 2098 | "requires": { 2099 | "esutils": "2.0.2", 2100 | "isarray": "1.0.0" 2101 | } 2102 | } 2103 | } 2104 | }, 2105 | "eslint-plugin-node": { 2106 | "version": "5.2.0", 2107 | "resolved": "https://registry.npmjs.org/eslint-plugin-node/-/eslint-plugin-node-5.2.0.tgz", 2108 | "integrity": "sha512-N9FLFwknT5LhRhjz1lmHguNss/MCwkrLCS4CjqqTZZTJaUhLRfDNK3zxSHL/Il3Aa0Mw+xY3T1gtsJrUNoJy8Q==", 2109 | "dev": true, 2110 | "requires": { 2111 | "ignore": "3.3.7", 2112 | "minimatch": "3.0.4", 2113 | "resolve": "1.5.0", 2114 | "semver": "5.3.0" 2115 | }, 2116 | "dependencies": { 2117 | "semver": { 2118 | "version": "5.3.0", 2119 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.3.0.tgz", 2120 | "integrity": "sha1-myzl094C0XxgEq0yaqa00M9U+U8=", 2121 | "dev": true 2122 | } 2123 | } 2124 | }, 2125 | "eslint-plugin-promise": { 2126 | "version": "3.6.0", 2127 | "resolved": "https://registry.npmjs.org/eslint-plugin-promise/-/eslint-plugin-promise-3.6.0.tgz", 2128 | "integrity": "sha512-YQzM6TLTlApAr7Li8vWKR+K3WghjwKcYzY0d2roWap4SLK+kzuagJX/leTetIDWsFcTFnKNJXWupDCD6aZkP2Q==", 2129 | "dev": true 2130 | }, 2131 | "eslint-plugin-react": { 2132 | "version": "7.5.1", 2133 | "resolved": "https://registry.npmjs.org/eslint-plugin-react/-/eslint-plugin-react-7.5.1.tgz", 2134 | "integrity": "sha512-YGSjB9Qu6QbVTroUZi66pYky3DfoIPLdHQ/wmrBGyBRnwxQsBXAov9j2rpXt/55i8nyMv6IRWJv2s4d4YnduzQ==", 2135 | "dev": true, 2136 | "requires": { 2137 | "doctrine": "2.0.0", 2138 | "has": "1.0.1", 2139 | "jsx-ast-utils": "2.0.1", 2140 | "prop-types": "15.6.0" 2141 | } 2142 | }, 2143 | "eslint-plugin-standard": { 2144 | "version": "3.0.1", 2145 | "resolved": "https://registry.npmjs.org/eslint-plugin-standard/-/eslint-plugin-standard-3.0.1.tgz", 2146 | "integrity": "sha1-NNDJFbRe3G8BA5PH7vOCOwhWXPI=", 2147 | "dev": true 2148 | }, 2149 | "eslint-scope": { 2150 | "version": "3.7.1", 2151 | "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-3.7.1.tgz", 2152 | "integrity": "sha1-PWPD7f2gLgbgGkUq2IyqzHzctug=", 2153 | "dev": true, 2154 | "requires": { 2155 | "esrecurse": "4.2.0", 2156 | "estraverse": "4.2.0" 2157 | } 2158 | }, 2159 | "espree": { 2160 | "version": "3.5.1", 2161 | "resolved": "https://registry.npmjs.org/espree/-/espree-3.5.1.tgz", 2162 | "integrity": "sha1-DJiLirRttTEAoZVK5LqZXd0n2H4=", 2163 | "dev": true, 2164 | "requires": { 2165 | "acorn": "5.2.1", 2166 | "acorn-jsx": "3.0.1" 2167 | } 2168 | }, 2169 | "esprima": { 2170 | "version": "4.0.0", 2171 | "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.0.tgz", 2172 | "integrity": "sha512-oftTcaMu/EGrEIu904mWteKIv8vMuOgGYo7EhVJJN00R/EED9DCua/xxHRdYnKtcECzVg7xOWhflvJMnqcFZjw==", 2173 | "dev": true 2174 | }, 2175 | "esquery": { 2176 | "version": "1.0.0", 2177 | "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.0.0.tgz", 2178 | "integrity": "sha1-z7qLV9f7qT8XKYqKAGoEzaE9gPo=", 2179 | "dev": true, 2180 | "requires": { 2181 | "estraverse": "4.2.0" 2182 | } 2183 | }, 2184 | "esrecurse": { 2185 | "version": "4.2.0", 2186 | "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.2.0.tgz", 2187 | "integrity": "sha1-+pVo2Y04I/mkHZHpAtyrnqblsWM=", 2188 | "dev": true, 2189 | "requires": { 2190 | "estraverse": "4.2.0", 2191 | "object-assign": "4.1.1" 2192 | } 2193 | }, 2194 | "estraverse": { 2195 | "version": "4.2.0", 2196 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-4.2.0.tgz", 2197 | "integrity": "sha1-De4/7TH81GlhjOc0IJn8GvoL2xM=", 2198 | "dev": true 2199 | }, 2200 | "estree-walker": { 2201 | "version": "0.2.1", 2202 | "resolved": "https://registry.npmjs.org/estree-walker/-/estree-walker-0.2.1.tgz", 2203 | "integrity": "sha1-va/oCVOD2EFNXcLs9MkXO225QS4=", 2204 | "dev": true 2205 | }, 2206 | "esutils": { 2207 | "version": "2.0.2", 2208 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.2.tgz", 2209 | "integrity": "sha1-Cr9PHKpbyx96nYrMbepPqqBLrJs=", 2210 | "dev": true 2211 | }, 2212 | "expand-brackets": { 2213 | "version": "0.1.5", 2214 | "resolved": "https://registry.npmjs.org/expand-brackets/-/expand-brackets-0.1.5.tgz", 2215 | "integrity": "sha1-3wcoTjQqgHzXM6xa9yQR5YHRF3s=", 2216 | "dev": true, 2217 | "requires": { 2218 | "is-posix-bracket": "0.1.1" 2219 | } 2220 | }, 2221 | "expand-range": { 2222 | "version": "1.8.2", 2223 | "resolved": "https://registry.npmjs.org/expand-range/-/expand-range-1.8.2.tgz", 2224 | "integrity": "sha1-opnv/TNf4nIeuujiV+x5ZE/IUzc=", 2225 | "dev": true, 2226 | "requires": { 2227 | "fill-range": "2.2.3" 2228 | } 2229 | }, 2230 | "external-editor": { 2231 | "version": "2.0.5", 2232 | "resolved": "https://registry.npmjs.org/external-editor/-/external-editor-2.0.5.tgz", 2233 | "integrity": "sha512-Msjo64WT5W+NhOpQXh0nOHm+n0RfU1QUwDnKYvJ8dEJ8zlwLrqXNTv5mSUTJpepf41PDJGyhueTw2vNZW+Fr/w==", 2234 | "dev": true, 2235 | "requires": { 2236 | "iconv-lite": "0.4.19", 2237 | "jschardet": "1.6.0", 2238 | "tmp": "0.0.33" 2239 | } 2240 | }, 2241 | "extglob": { 2242 | "version": "0.3.2", 2243 | "resolved": "https://registry.npmjs.org/extglob/-/extglob-0.3.2.tgz", 2244 | "integrity": "sha1-Lhj/PS9JqydlzskCPwEdqo2DSaE=", 2245 | "dev": true, 2246 | "requires": { 2247 | "is-extglob": "1.0.0" 2248 | } 2249 | }, 2250 | "fast-deep-equal": { 2251 | "version": "1.0.0", 2252 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-1.0.0.tgz", 2253 | "integrity": "sha1-liVqO8l1WV6zbYLpkp0GDYk0Of8=", 2254 | "dev": true 2255 | }, 2256 | "fast-json-stable-stringify": { 2257 | "version": "2.0.0", 2258 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.0.0.tgz", 2259 | "integrity": "sha1-1RQsDK7msRifh9OnYREGT4bIu/I=", 2260 | "dev": true 2261 | }, 2262 | "fast-levenshtein": { 2263 | "version": "2.0.6", 2264 | "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", 2265 | "integrity": "sha1-PYpcZog6FqMMqGQ+hR8Zuqd5eRc=", 2266 | "dev": true 2267 | }, 2268 | "fbjs": { 2269 | "version": "0.8.16", 2270 | "resolved": "https://registry.npmjs.org/fbjs/-/fbjs-0.8.16.tgz", 2271 | "integrity": "sha1-XmdDL1UNxBtXK/VYR7ispk5TN9s=", 2272 | "requires": { 2273 | "core-js": "1.2.7", 2274 | "isomorphic-fetch": "2.2.1", 2275 | "loose-envify": "1.3.1", 2276 | "object-assign": "4.1.1", 2277 | "promise": "7.3.1", 2278 | "setimmediate": "1.0.5", 2279 | "ua-parser-js": "0.7.17" 2280 | } 2281 | }, 2282 | "figures": { 2283 | "version": "2.0.0", 2284 | "resolved": "https://registry.npmjs.org/figures/-/figures-2.0.0.tgz", 2285 | "integrity": "sha1-OrGi0qYsi/tDGgyUy3l6L84nyWI=", 2286 | "dev": true, 2287 | "requires": { 2288 | "escape-string-regexp": "1.0.5" 2289 | } 2290 | }, 2291 | "file-entry-cache": { 2292 | "version": "2.0.0", 2293 | "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-2.0.0.tgz", 2294 | "integrity": "sha1-w5KZDD5oR4PYOLjISkXYoEhFg2E=", 2295 | "dev": true, 2296 | "requires": { 2297 | "flat-cache": "1.3.0", 2298 | "object-assign": "4.1.1" 2299 | } 2300 | }, 2301 | "filename-regex": { 2302 | "version": "2.0.1", 2303 | "resolved": "https://registry.npmjs.org/filename-regex/-/filename-regex-2.0.1.tgz", 2304 | "integrity": "sha1-wcS5vuPglyXdsQa3XB4wH+LxiyY=", 2305 | "dev": true 2306 | }, 2307 | "fill-range": { 2308 | "version": "2.2.3", 2309 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-2.2.3.tgz", 2310 | "integrity": "sha1-ULd9/X5Gm8dJJHCWNpn+eoSFpyM=", 2311 | "dev": true, 2312 | "requires": { 2313 | "is-number": "2.1.0", 2314 | "isobject": "2.1.0", 2315 | "randomatic": "1.1.7", 2316 | "repeat-element": "1.1.2", 2317 | "repeat-string": "1.6.1" 2318 | } 2319 | }, 2320 | "find-up": { 2321 | "version": "1.1.2", 2322 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-1.1.2.tgz", 2323 | "integrity": "sha1-ay6YIrGizgpgq2TWEOzK1TyyTQ8=", 2324 | "dev": true, 2325 | "requires": { 2326 | "path-exists": "2.1.0", 2327 | "pinkie-promise": "2.0.1" 2328 | } 2329 | }, 2330 | "flat-cache": { 2331 | "version": "1.3.0", 2332 | "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-1.3.0.tgz", 2333 | "integrity": "sha1-0wMLMrOBVPTjt+nHCfSQ9++XxIE=", 2334 | "dev": true, 2335 | "requires": { 2336 | "circular-json": "0.3.3", 2337 | "del": "2.2.2", 2338 | "graceful-fs": "4.1.11", 2339 | "write": "0.2.1" 2340 | } 2341 | }, 2342 | "for-in": { 2343 | "version": "1.0.2", 2344 | "resolved": "https://registry.npmjs.org/for-in/-/for-in-1.0.2.tgz", 2345 | "integrity": "sha1-gQaNKVqBQuwKxybG4iAMMPttXoA=", 2346 | "dev": true 2347 | }, 2348 | "for-own": { 2349 | "version": "0.1.5", 2350 | "resolved": "https://registry.npmjs.org/for-own/-/for-own-0.1.5.tgz", 2351 | "integrity": "sha1-UmXGgaTylNq78XyVCbZ2OqhFEM4=", 2352 | "dev": true, 2353 | "requires": { 2354 | "for-in": "1.0.2" 2355 | } 2356 | }, 2357 | "foreach": { 2358 | "version": "2.0.5", 2359 | "resolved": "https://registry.npmjs.org/foreach/-/foreach-2.0.5.tgz", 2360 | "integrity": "sha1-C+4AUBiusmDQo6865ljdATbsG5k=", 2361 | "dev": true 2362 | }, 2363 | "fs-readdir-recursive": { 2364 | "version": "1.0.0", 2365 | "resolved": "https://registry.npmjs.org/fs-readdir-recursive/-/fs-readdir-recursive-1.0.0.tgz", 2366 | "integrity": "sha1-jNF0XItPiinIyuw5JHaSG6GV9WA=", 2367 | "dev": true 2368 | }, 2369 | "fs.realpath": { 2370 | "version": "1.0.0", 2371 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 2372 | "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=", 2373 | "dev": true 2374 | }, 2375 | "function-bind": { 2376 | "version": "1.1.1", 2377 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", 2378 | "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==", 2379 | "dev": true 2380 | }, 2381 | "functional-red-black-tree": { 2382 | "version": "1.0.1", 2383 | "resolved": "https://registry.npmjs.org/functional-red-black-tree/-/functional-red-black-tree-1.0.1.tgz", 2384 | "integrity": "sha1-GwqzvVU7Kg1jmdKcDj6gslIHgyc=", 2385 | "dev": true 2386 | }, 2387 | "glob": { 2388 | "version": "7.1.2", 2389 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.2.tgz", 2390 | "integrity": "sha512-MJTUg1kjuLeQCJ+ccE4Vpa6kKVXkPYJ2mOCQyUuKLcLQsdrMCpBPUi8qVE6+YuaJkozeA9NusTAw3hLr8Xe5EQ==", 2391 | "dev": true, 2392 | "requires": { 2393 | "fs.realpath": "1.0.0", 2394 | "inflight": "1.0.6", 2395 | "inherits": "2.0.3", 2396 | "minimatch": "3.0.4", 2397 | "once": "1.4.0", 2398 | "path-is-absolute": "1.0.1" 2399 | } 2400 | }, 2401 | "glob-base": { 2402 | "version": "0.3.0", 2403 | "resolved": "https://registry.npmjs.org/glob-base/-/glob-base-0.3.0.tgz", 2404 | "integrity": "sha1-27Fk9iIbHAscz4Kuoyi0l98Oo8Q=", 2405 | "dev": true, 2406 | "requires": { 2407 | "glob-parent": "2.0.0", 2408 | "is-glob": "2.0.1" 2409 | } 2410 | }, 2411 | "glob-parent": { 2412 | "version": "2.0.0", 2413 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-2.0.0.tgz", 2414 | "integrity": "sha1-gTg9ctsFT8zPUzbaqQLxgvbtuyg=", 2415 | "dev": true, 2416 | "requires": { 2417 | "is-glob": "2.0.1" 2418 | } 2419 | }, 2420 | "globals": { 2421 | "version": "9.18.0", 2422 | "resolved": "https://registry.npmjs.org/globals/-/globals-9.18.0.tgz", 2423 | "integrity": "sha512-S0nG3CLEQiY/ILxqtztTWH/3iRRdyBLw6KMDxnKMchrtbj2OFmehVh0WUCfW3DUrIgx/qFrJPICrq4Z4sTR9UQ==", 2424 | "dev": true 2425 | }, 2426 | "globby": { 2427 | "version": "5.0.0", 2428 | "resolved": "https://registry.npmjs.org/globby/-/globby-5.0.0.tgz", 2429 | "integrity": "sha1-69hGZ8oNuzMLmbz8aOrCvFQ3Dg0=", 2430 | "dev": true, 2431 | "requires": { 2432 | "array-union": "1.0.2", 2433 | "arrify": "1.0.1", 2434 | "glob": "7.1.2", 2435 | "object-assign": "4.1.1", 2436 | "pify": "2.3.0", 2437 | "pinkie-promise": "2.0.1" 2438 | } 2439 | }, 2440 | "graceful-fs": { 2441 | "version": "4.1.11", 2442 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.1.11.tgz", 2443 | "integrity": "sha1-Dovf5NHduIVNZOBOp8AOKgJuVlg=", 2444 | "dev": true 2445 | }, 2446 | "graphql": { 2447 | "version": "0.11.7", 2448 | "resolved": "https://registry.npmjs.org/graphql/-/graphql-0.11.7.tgz", 2449 | "integrity": "sha512-x7uDjyz8Jx+QPbpCFCMQ8lltnQa4p4vSYHx6ADe8rVYRTdsyhCJbvSty5DAsLVmU6cGakl+r8HQYolKHxk/tiw==", 2450 | "dev": true, 2451 | "requires": { 2452 | "iterall": "1.1.3" 2453 | } 2454 | }, 2455 | "graphql-subscriptions": { 2456 | "version": "0.5.5", 2457 | "resolved": "https://registry.npmjs.org/graphql-subscriptions/-/graphql-subscriptions-0.5.5.tgz", 2458 | "integrity": "sha512-NlJh7lfBPs9Xp8tt4WkCdxUblg+ZMZ0aj2AxJ5bXI2N/7jhiLupL7e+hK6AZoQGtOnIyY66UHxYNeEnLDmL4oQ==", 2459 | "dev": true, 2460 | "requires": { 2461 | "es6-promise": "4.1.1", 2462 | "iterall": "1.1.3" 2463 | } 2464 | }, 2465 | "graphql-tools": { 2466 | "version": "2.12.0", 2467 | "resolved": "https://registry.npmjs.org/graphql-tools/-/graphql-tools-2.12.0.tgz", 2468 | "integrity": "sha512-o19yEiugSP6IisH39RVdBnwllYz77JTuplLDa1/RdQg8fTpFS2XI08ptWqs0v7kM2ZqHtc1qQIiyGnAFU9Mgug==", 2469 | "dev": true, 2470 | "requires": { 2471 | "apollo-utilities": "1.0.3", 2472 | "deprecated-decorator": "0.1.6", 2473 | "uuid": "3.1.0" 2474 | } 2475 | }, 2476 | "has": { 2477 | "version": "1.0.1", 2478 | "resolved": "https://registry.npmjs.org/has/-/has-1.0.1.tgz", 2479 | "integrity": "sha1-hGFzP1OLCDfJNh45qauelwTcLyg=", 2480 | "dev": true, 2481 | "requires": { 2482 | "function-bind": "1.1.1" 2483 | } 2484 | }, 2485 | "has-ansi": { 2486 | "version": "2.0.0", 2487 | "resolved": "https://registry.npmjs.org/has-ansi/-/has-ansi-2.0.0.tgz", 2488 | "integrity": "sha1-NPUEnOHs3ysGSa8+8k5F7TVBbZE=", 2489 | "dev": true, 2490 | "requires": { 2491 | "ansi-regex": "2.1.1" 2492 | } 2493 | }, 2494 | "has-flag": { 2495 | "version": "2.0.0", 2496 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-2.0.0.tgz", 2497 | "integrity": "sha1-6CB68cx7MNRGzHC3NLXovhj4jVE=", 2498 | "dev": true 2499 | }, 2500 | "hoist-non-react-statics": { 2501 | "version": "2.3.1", 2502 | "resolved": "https://registry.npmjs.org/hoist-non-react-statics/-/hoist-non-react-statics-2.3.1.tgz", 2503 | "integrity": "sha1-ND24TGAYxlB3iJgkATWhQg7iLOA=" 2504 | }, 2505 | "home-or-tmp": { 2506 | "version": "2.0.0", 2507 | "resolved": "https://registry.npmjs.org/home-or-tmp/-/home-or-tmp-2.0.0.tgz", 2508 | "integrity": "sha1-42w/LSyufXRqhX440Y1fMqeILbg=", 2509 | "dev": true, 2510 | "requires": { 2511 | "os-homedir": "1.0.2", 2512 | "os-tmpdir": "1.0.2" 2513 | } 2514 | }, 2515 | "hosted-git-info": { 2516 | "version": "2.5.0", 2517 | "resolved": "https://registry.npmjs.org/hosted-git-info/-/hosted-git-info-2.5.0.tgz", 2518 | "integrity": "sha512-pNgbURSuab90KbTqvRPsseaTxOJCZBD0a7t+haSN33piP9cCM4l0CqdzAif2hUqm716UovKB2ROmiabGAKVXyg==", 2519 | "dev": true 2520 | }, 2521 | "iconv-lite": { 2522 | "version": "0.4.19", 2523 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.19.tgz", 2524 | "integrity": "sha512-oTZqweIP51xaGPI4uPa56/Pri/480R+mo7SeU+YETByQNhDG55ycFyNLIgta9vXhILrxXDmF7ZGhqZIcuN0gJQ==" 2525 | }, 2526 | "ignore": { 2527 | "version": "3.3.7", 2528 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-3.3.7.tgz", 2529 | "integrity": "sha512-YGG3ejvBNHRqu0559EOxxNFihD0AjpvHlC/pdGKd3X3ofe+CoJkYazwNJYTNebqpPKN+VVQbh4ZFn1DivMNuHA==", 2530 | "dev": true 2531 | }, 2532 | "imurmurhash": { 2533 | "version": "0.1.4", 2534 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 2535 | "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=", 2536 | "dev": true 2537 | }, 2538 | "inflight": { 2539 | "version": "1.0.6", 2540 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 2541 | "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", 2542 | "dev": true, 2543 | "requires": { 2544 | "once": "1.4.0", 2545 | "wrappy": "1.0.2" 2546 | } 2547 | }, 2548 | "inherits": { 2549 | "version": "2.0.3", 2550 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz", 2551 | "integrity": "sha1-Yzwsg+PaQqUC9SRmAiSA9CCCYd4=", 2552 | "dev": true 2553 | }, 2554 | "inquirer": { 2555 | "version": "3.3.0", 2556 | "resolved": "https://registry.npmjs.org/inquirer/-/inquirer-3.3.0.tgz", 2557 | "integrity": "sha512-h+xtnyk4EwKvFWHrUYsWErEVR+igKtLdchu+o0Z1RL7VU/jVMFbYir2bp6bAj8efFNxWqHX0dIss6fJQ+/+qeQ==", 2558 | "dev": true, 2559 | "requires": { 2560 | "ansi-escapes": "3.0.0", 2561 | "chalk": "2.3.0", 2562 | "cli-cursor": "2.1.0", 2563 | "cli-width": "2.2.0", 2564 | "external-editor": "2.0.5", 2565 | "figures": "2.0.0", 2566 | "lodash": "4.17.4", 2567 | "mute-stream": "0.0.7", 2568 | "run-async": "2.3.0", 2569 | "rx-lite": "4.0.8", 2570 | "rx-lite-aggregates": "4.0.8", 2571 | "string-width": "2.1.1", 2572 | "strip-ansi": "4.0.0", 2573 | "through": "2.3.8" 2574 | }, 2575 | "dependencies": { 2576 | "ansi-regex": { 2577 | "version": "3.0.0", 2578 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-3.0.0.tgz", 2579 | "integrity": "sha1-7QMXwyIGT3lGbAKWa922Bas32Zg=", 2580 | "dev": true 2581 | }, 2582 | "ansi-styles": { 2583 | "version": "3.2.0", 2584 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.0.tgz", 2585 | "integrity": "sha512-NnSOmMEYtVR2JVMIGTzynRkkaxtiq1xnFBcdQD/DnNCYPoEPsVJhM98BDyaoNOQIi7p4okdi3E27eN7GQbsUug==", 2586 | "dev": true, 2587 | "requires": { 2588 | "color-convert": "1.9.0" 2589 | } 2590 | }, 2591 | "chalk": { 2592 | "version": "2.3.0", 2593 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.3.0.tgz", 2594 | "integrity": "sha512-Az5zJR2CBujap2rqXGaJKaPHyJ0IrUimvYNX+ncCy8PJP4ltOGTrHUIo097ZaL2zMeKYpiCdqDvS6zdrTFok3Q==", 2595 | "dev": true, 2596 | "requires": { 2597 | "ansi-styles": "3.2.0", 2598 | "escape-string-regexp": "1.0.5", 2599 | "supports-color": "4.5.0" 2600 | } 2601 | }, 2602 | "strip-ansi": { 2603 | "version": "4.0.0", 2604 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-4.0.0.tgz", 2605 | "integrity": "sha1-qEeQIusaw2iocTibY1JixQXuNo8=", 2606 | "dev": true, 2607 | "requires": { 2608 | "ansi-regex": "3.0.0" 2609 | } 2610 | }, 2611 | "supports-color": { 2612 | "version": "4.5.0", 2613 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-4.5.0.tgz", 2614 | "integrity": "sha1-vnoN5ITexcXN34s9WRJQRJEvY1s=", 2615 | "dev": true, 2616 | "requires": { 2617 | "has-flag": "2.0.0" 2618 | } 2619 | } 2620 | } 2621 | }, 2622 | "invariant": { 2623 | "version": "2.2.2", 2624 | "resolved": "https://registry.npmjs.org/invariant/-/invariant-2.2.2.tgz", 2625 | "integrity": "sha1-nh9WrArNtr8wMwbzOL47IErmA2A=", 2626 | "requires": { 2627 | "loose-envify": "1.3.1" 2628 | } 2629 | }, 2630 | "is-arrayish": { 2631 | "version": "0.2.1", 2632 | "resolved": "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.2.1.tgz", 2633 | "integrity": "sha1-d8mYQFJ6qOyxqLppe4BkWnqSap0=", 2634 | "dev": true 2635 | }, 2636 | "is-binary-path": { 2637 | "version": "1.0.1", 2638 | "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-1.0.1.tgz", 2639 | "integrity": "sha1-dfFmQrSA8YenEcgUFh/TpKdlWJg=", 2640 | "dev": true, 2641 | "optional": true, 2642 | "requires": { 2643 | "binary-extensions": "1.10.0" 2644 | } 2645 | }, 2646 | "is-buffer": { 2647 | "version": "1.1.6", 2648 | "resolved": "https://registry.npmjs.org/is-buffer/-/is-buffer-1.1.6.tgz", 2649 | "integrity": "sha512-NcdALwpXkTm5Zvvbk7owOUSvVvBKDgKP5/ewfXEznmQFfs4ZRmanOeKBTjRVjka3QFoN6XJ+9F3USqfHqTaU5w==", 2650 | "dev": true 2651 | }, 2652 | "is-builtin-module": { 2653 | "version": "1.0.0", 2654 | "resolved": "https://registry.npmjs.org/is-builtin-module/-/is-builtin-module-1.0.0.tgz", 2655 | "integrity": "sha1-VAVy0096wxGfj3bDDLwbHgN6/74=", 2656 | "dev": true, 2657 | "requires": { 2658 | "builtin-modules": "1.1.1" 2659 | } 2660 | }, 2661 | "is-callable": { 2662 | "version": "1.1.3", 2663 | "resolved": "https://registry.npmjs.org/is-callable/-/is-callable-1.1.3.tgz", 2664 | "integrity": "sha1-hut1OSgF3cM69xySoO7fdO52BLI=", 2665 | "dev": true 2666 | }, 2667 | "is-date-object": { 2668 | "version": "1.0.1", 2669 | "resolved": "https://registry.npmjs.org/is-date-object/-/is-date-object-1.0.1.tgz", 2670 | "integrity": "sha1-mqIOtq7rv/d/vTPnTKAbM1gdOhY=", 2671 | "dev": true 2672 | }, 2673 | "is-dotfile": { 2674 | "version": "1.0.3", 2675 | "resolved": "https://registry.npmjs.org/is-dotfile/-/is-dotfile-1.0.3.tgz", 2676 | "integrity": "sha1-pqLzL/0t+wT1yiXs0Pa4PPeYoeE=", 2677 | "dev": true 2678 | }, 2679 | "is-equal-shallow": { 2680 | "version": "0.1.3", 2681 | "resolved": "https://registry.npmjs.org/is-equal-shallow/-/is-equal-shallow-0.1.3.tgz", 2682 | "integrity": "sha1-IjgJj8Ih3gvPpdnqxMRdY4qhxTQ=", 2683 | "dev": true, 2684 | "requires": { 2685 | "is-primitive": "2.0.0" 2686 | } 2687 | }, 2688 | "is-extendable": { 2689 | "version": "0.1.1", 2690 | "resolved": "https://registry.npmjs.org/is-extendable/-/is-extendable-0.1.1.tgz", 2691 | "integrity": "sha1-YrEQ4omkcUGOPsNqYX1HLjAd/Ik=", 2692 | "dev": true 2693 | }, 2694 | "is-extglob": { 2695 | "version": "1.0.0", 2696 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-1.0.0.tgz", 2697 | "integrity": "sha1-rEaBd8SUNAWgkvyPKXYMb/xiBsA=", 2698 | "dev": true 2699 | }, 2700 | "is-finite": { 2701 | "version": "1.0.2", 2702 | "resolved": "https://registry.npmjs.org/is-finite/-/is-finite-1.0.2.tgz", 2703 | "integrity": "sha1-zGZ3aVYCvlUO8R6LSqYwU0K20Ko=", 2704 | "dev": true, 2705 | "requires": { 2706 | "number-is-nan": "1.0.1" 2707 | } 2708 | }, 2709 | "is-fullwidth-code-point": { 2710 | "version": "2.0.0", 2711 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", 2712 | "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=", 2713 | "dev": true 2714 | }, 2715 | "is-glob": { 2716 | "version": "2.0.1", 2717 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-2.0.1.tgz", 2718 | "integrity": "sha1-0Jb5JqPe1WAPP9/ZEZjLCIjC2GM=", 2719 | "dev": true, 2720 | "requires": { 2721 | "is-extglob": "1.0.0" 2722 | } 2723 | }, 2724 | "is-module": { 2725 | "version": "1.0.0", 2726 | "resolved": "https://registry.npmjs.org/is-module/-/is-module-1.0.0.tgz", 2727 | "integrity": "sha1-Mlj7afeMFNW4FdZkM2tM/7ZEFZE=", 2728 | "dev": true 2729 | }, 2730 | "is-number": { 2731 | "version": "2.1.0", 2732 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-2.1.0.tgz", 2733 | "integrity": "sha1-Afy7s5NGOlSPL0ZszhbezknbkI8=", 2734 | "dev": true, 2735 | "requires": { 2736 | "kind-of": "3.2.2" 2737 | } 2738 | }, 2739 | "is-path-cwd": { 2740 | "version": "1.0.0", 2741 | "resolved": "https://registry.npmjs.org/is-path-cwd/-/is-path-cwd-1.0.0.tgz", 2742 | "integrity": "sha1-0iXsIxMuie3Tj9p2dHLmLmXxEG0=", 2743 | "dev": true 2744 | }, 2745 | "is-path-in-cwd": { 2746 | "version": "1.0.0", 2747 | "resolved": "https://registry.npmjs.org/is-path-in-cwd/-/is-path-in-cwd-1.0.0.tgz", 2748 | "integrity": "sha1-ZHdYK4IU1gI0YJRWcAO+ip6sBNw=", 2749 | "dev": true, 2750 | "requires": { 2751 | "is-path-inside": "1.0.0" 2752 | } 2753 | }, 2754 | "is-path-inside": { 2755 | "version": "1.0.0", 2756 | "resolved": "https://registry.npmjs.org/is-path-inside/-/is-path-inside-1.0.0.tgz", 2757 | "integrity": "sha1-/AbloWg/vaE95mev9xe7wQpI838=", 2758 | "dev": true, 2759 | "requires": { 2760 | "path-is-inside": "1.0.2" 2761 | } 2762 | }, 2763 | "is-posix-bracket": { 2764 | "version": "0.1.1", 2765 | "resolved": "https://registry.npmjs.org/is-posix-bracket/-/is-posix-bracket-0.1.1.tgz", 2766 | "integrity": "sha1-MzTceXdDaOkvAW5vvAqI9c1ua8Q=", 2767 | "dev": true 2768 | }, 2769 | "is-primitive": { 2770 | "version": "2.0.0", 2771 | "resolved": "https://registry.npmjs.org/is-primitive/-/is-primitive-2.0.0.tgz", 2772 | "integrity": "sha1-IHurkWOEmcB7Kt8kCkGochADRXU=", 2773 | "dev": true 2774 | }, 2775 | "is-promise": { 2776 | "version": "2.1.0", 2777 | "resolved": "https://registry.npmjs.org/is-promise/-/is-promise-2.1.0.tgz", 2778 | "integrity": "sha1-eaKp7OfwlugPNtKy87wWwf9L8/o=", 2779 | "dev": true 2780 | }, 2781 | "is-regex": { 2782 | "version": "1.0.4", 2783 | "resolved": "https://registry.npmjs.org/is-regex/-/is-regex-1.0.4.tgz", 2784 | "integrity": "sha1-VRdIm1RwkbCTDglWVM7SXul+lJE=", 2785 | "dev": true, 2786 | "requires": { 2787 | "has": "1.0.1" 2788 | } 2789 | }, 2790 | "is-resolvable": { 2791 | "version": "1.0.0", 2792 | "resolved": "https://registry.npmjs.org/is-resolvable/-/is-resolvable-1.0.0.tgz", 2793 | "integrity": "sha1-jfV8YeouPFAUCNEA+wE8+NbgzGI=", 2794 | "dev": true, 2795 | "requires": { 2796 | "tryit": "1.0.3" 2797 | } 2798 | }, 2799 | "is-stream": { 2800 | "version": "1.1.0", 2801 | "resolved": "https://registry.npmjs.org/is-stream/-/is-stream-1.1.0.tgz", 2802 | "integrity": "sha1-EtSj3U5o4Lec6428hBc66A2RykQ=" 2803 | }, 2804 | "is-symbol": { 2805 | "version": "1.0.1", 2806 | "resolved": "https://registry.npmjs.org/is-symbol/-/is-symbol-1.0.1.tgz", 2807 | "integrity": "sha1-PMWfAAJRlLarLjjbrmaJJWtmBXI=", 2808 | "dev": true 2809 | }, 2810 | "is-windows": { 2811 | "version": "1.0.1", 2812 | "resolved": "https://registry.npmjs.org/is-windows/-/is-windows-1.0.1.tgz", 2813 | "integrity": "sha1-MQ23D3QtJZoWo2kgK1GvhCMzENk=", 2814 | "dev": true 2815 | }, 2816 | "isarray": { 2817 | "version": "1.0.0", 2818 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", 2819 | "integrity": "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE=", 2820 | "dev": true 2821 | }, 2822 | "isexe": { 2823 | "version": "2.0.0", 2824 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 2825 | "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=", 2826 | "dev": true 2827 | }, 2828 | "isobject": { 2829 | "version": "2.1.0", 2830 | "resolved": "https://registry.npmjs.org/isobject/-/isobject-2.1.0.tgz", 2831 | "integrity": "sha1-8GVWEJaj8dou9GJy+BXIQNh+DIk=", 2832 | "dev": true, 2833 | "requires": { 2834 | "isarray": "1.0.0" 2835 | } 2836 | }, 2837 | "isomorphic-fetch": { 2838 | "version": "2.2.1", 2839 | "resolved": "https://registry.npmjs.org/isomorphic-fetch/-/isomorphic-fetch-2.2.1.tgz", 2840 | "integrity": "sha1-YRrhrPFPXoH3KVB0coGf6XM1WKk=", 2841 | "requires": { 2842 | "node-fetch": "1.7.3", 2843 | "whatwg-fetch": "2.0.3" 2844 | } 2845 | }, 2846 | "iterall": { 2847 | "version": "1.1.3", 2848 | "resolved": "https://registry.npmjs.org/iterall/-/iterall-1.1.3.tgz", 2849 | "integrity": "sha512-Cu/kb+4HiNSejAPhSaN1VukdNTTi/r4/e+yykqjlG/IW+1gZH5b4+Bq3whDX4tvbYugta3r8KTMUiqT3fIGxuQ==", 2850 | "dev": true 2851 | }, 2852 | "js-tokens": { 2853 | "version": "3.0.2", 2854 | "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-3.0.2.tgz", 2855 | "integrity": "sha1-mGbfOVECEw449/mWvOtlRDIJwls=" 2856 | }, 2857 | "js-yaml": { 2858 | "version": "3.10.0", 2859 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.10.0.tgz", 2860 | "integrity": "sha512-O2v52ffjLa9VeM43J4XocZE//WT9N0IiwDa3KSHH7Tu8CtH+1qM8SIZvnsTh6v+4yFy5KUY3BHUVwjpfAWsjIA==", 2861 | "dev": true, 2862 | "requires": { 2863 | "argparse": "1.0.9", 2864 | "esprima": "4.0.0" 2865 | } 2866 | }, 2867 | "jschardet": { 2868 | "version": "1.6.0", 2869 | "resolved": "https://registry.npmjs.org/jschardet/-/jschardet-1.6.0.tgz", 2870 | "integrity": "sha512-xYuhvQ7I9PDJIGBWev9xm0+SMSed3ZDBAmvVjbFR1ZRLAF+vlXcQu6cRI9uAlj81rzikElRVteehwV7DuX2ZmQ==", 2871 | "dev": true 2872 | }, 2873 | "jsesc": { 2874 | "version": "1.3.0", 2875 | "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-1.3.0.tgz", 2876 | "integrity": "sha1-RsP+yMGJKxKwgz25vHYiF226s0s=", 2877 | "dev": true 2878 | }, 2879 | "json-schema-traverse": { 2880 | "version": "0.3.1", 2881 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.3.1.tgz", 2882 | "integrity": "sha1-NJptRMU6Ud6JtAgFxdXlm0F9M0A=", 2883 | "dev": true 2884 | }, 2885 | "json-stable-stringify": { 2886 | "version": "1.0.1", 2887 | "resolved": "https://registry.npmjs.org/json-stable-stringify/-/json-stable-stringify-1.0.1.tgz", 2888 | "integrity": "sha1-mnWdOcXy/1A/1TAGRu1EX4jE+a8=", 2889 | "dev": true, 2890 | "requires": { 2891 | "jsonify": "0.0.0" 2892 | } 2893 | }, 2894 | "json5": { 2895 | "version": "0.5.1", 2896 | "resolved": "https://registry.npmjs.org/json5/-/json5-0.5.1.tgz", 2897 | "integrity": "sha1-Hq3nrMASA0rYTiOWdn6tn6VJWCE=", 2898 | "dev": true 2899 | }, 2900 | "jsonify": { 2901 | "version": "0.0.0", 2902 | "resolved": "https://registry.npmjs.org/jsonify/-/jsonify-0.0.0.tgz", 2903 | "integrity": "sha1-LHS27kHZPKUbe1qu6PUDYx0lKnM=", 2904 | "dev": true 2905 | }, 2906 | "jsx-ast-utils": { 2907 | "version": "2.0.1", 2908 | "resolved": "https://registry.npmjs.org/jsx-ast-utils/-/jsx-ast-utils-2.0.1.tgz", 2909 | "integrity": "sha1-6AGxs5mF4g//yHtA43SAgOLcrH8=", 2910 | "dev": true, 2911 | "requires": { 2912 | "array-includes": "3.0.3" 2913 | } 2914 | }, 2915 | "kind-of": { 2916 | "version": "3.2.2", 2917 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", 2918 | "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", 2919 | "dev": true, 2920 | "requires": { 2921 | "is-buffer": "1.1.6" 2922 | } 2923 | }, 2924 | "levn": { 2925 | "version": "0.3.0", 2926 | "resolved": "https://registry.npmjs.org/levn/-/levn-0.3.0.tgz", 2927 | "integrity": "sha1-OwmSTt+fCDwEkP3UwLxEIeBHZO4=", 2928 | "dev": true, 2929 | "requires": { 2930 | "prelude-ls": "1.1.2", 2931 | "type-check": "0.3.2" 2932 | } 2933 | }, 2934 | "load-json-file": { 2935 | "version": "2.0.0", 2936 | "resolved": "https://registry.npmjs.org/load-json-file/-/load-json-file-2.0.0.tgz", 2937 | "integrity": "sha1-eUfkIUmvgNaWy/eXvKq8/h/inKg=", 2938 | "dev": true, 2939 | "requires": { 2940 | "graceful-fs": "4.1.11", 2941 | "parse-json": "2.2.0", 2942 | "pify": "2.3.0", 2943 | "strip-bom": "3.0.0" 2944 | } 2945 | }, 2946 | "locate-path": { 2947 | "version": "2.0.0", 2948 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-2.0.0.tgz", 2949 | "integrity": "sha1-K1aLJl7slExtnA3pw9u7ygNUzY4=", 2950 | "dev": true, 2951 | "requires": { 2952 | "p-locate": "2.0.0", 2953 | "path-exists": "3.0.0" 2954 | }, 2955 | "dependencies": { 2956 | "path-exists": { 2957 | "version": "3.0.0", 2958 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-3.0.0.tgz", 2959 | "integrity": "sha1-zg6+ql94yxiSXqfYENe1mwEP1RU=", 2960 | "dev": true 2961 | } 2962 | } 2963 | }, 2964 | "lodash": { 2965 | "version": "4.17.4", 2966 | "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.4.tgz", 2967 | "integrity": "sha1-eCA6TRwyiuHYbcpkYONptX9AVa4=", 2968 | "dev": true 2969 | }, 2970 | "lodash.cond": { 2971 | "version": "4.5.2", 2972 | "resolved": "https://registry.npmjs.org/lodash.cond/-/lodash.cond-4.5.2.tgz", 2973 | "integrity": "sha1-9HGh2khr5g9quVXRcRVSPdHSVdU=", 2974 | "dev": true 2975 | }, 2976 | "loose-envify": { 2977 | "version": "1.3.1", 2978 | "resolved": "https://registry.npmjs.org/loose-envify/-/loose-envify-1.3.1.tgz", 2979 | "integrity": "sha1-0aitM/qc4OcT1l/dCsi3SNR4yEg=", 2980 | "requires": { 2981 | "js-tokens": "3.0.2" 2982 | } 2983 | }, 2984 | "lru-cache": { 2985 | "version": "4.1.1", 2986 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-4.1.1.tgz", 2987 | "integrity": "sha512-q4spe4KTfsAS1SUHLO0wz8Qiyf1+vMIAgpRYioFYDMNqKfHQbg+AVDH3i4fvpl71/P1L0dBl+fQi+P37UYf0ew==", 2988 | "dev": true, 2989 | "requires": { 2990 | "pseudomap": "1.0.2", 2991 | "yallist": "2.1.2" 2992 | } 2993 | }, 2994 | "magic-string": { 2995 | "version": "0.22.4", 2996 | "resolved": "https://registry.npmjs.org/magic-string/-/magic-string-0.22.4.tgz", 2997 | "integrity": "sha512-kxBL06p6iO2qPBHsqGK2b3cRwiRGpnmSuVWNhwHcMX7qJOUr1HvricYP1LZOCdkQBUp0jiWg2d6WJwR3vYgByw==", 2998 | "dev": true, 2999 | "requires": { 3000 | "vlq": "0.2.3" 3001 | } 3002 | }, 3003 | "micromatch": { 3004 | "version": "2.3.11", 3005 | "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-2.3.11.tgz", 3006 | "integrity": "sha1-hmd8l9FyCzY0MdBNDRUpO9OMFWU=", 3007 | "dev": true, 3008 | "requires": { 3009 | "arr-diff": "2.0.0", 3010 | "array-unique": "0.2.1", 3011 | "braces": "1.8.5", 3012 | "expand-brackets": "0.1.5", 3013 | "extglob": "0.3.2", 3014 | "filename-regex": "2.0.1", 3015 | "is-extglob": "1.0.0", 3016 | "is-glob": "2.0.1", 3017 | "kind-of": "3.2.2", 3018 | "normalize-path": "2.1.1", 3019 | "object.omit": "2.0.1", 3020 | "parse-glob": "3.0.4", 3021 | "regex-cache": "0.4.4" 3022 | } 3023 | }, 3024 | "mimic-fn": { 3025 | "version": "1.1.0", 3026 | "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-1.1.0.tgz", 3027 | "integrity": "sha1-5md4PZLonb00KBi1IwudYqZyrRg=", 3028 | "dev": true 3029 | }, 3030 | "minimatch": { 3031 | "version": "3.0.4", 3032 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", 3033 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 3034 | "dev": true, 3035 | "requires": { 3036 | "brace-expansion": "1.1.8" 3037 | } 3038 | }, 3039 | "minimist": { 3040 | "version": "0.0.8", 3041 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-0.0.8.tgz", 3042 | "integrity": "sha1-hX/Kv8M5fSYluCKCYuhqp6ARsF0=", 3043 | "dev": true 3044 | }, 3045 | "mkdirp": { 3046 | "version": "0.5.1", 3047 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.1.tgz", 3048 | "integrity": "sha1-MAV0OOrGz3+MR2fzhkjWaX11yQM=", 3049 | "dev": true, 3050 | "requires": { 3051 | "minimist": "0.0.8" 3052 | } 3053 | }, 3054 | "ms": { 3055 | "version": "2.0.0", 3056 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 3057 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=", 3058 | "dev": true 3059 | }, 3060 | "mute-stream": { 3061 | "version": "0.0.7", 3062 | "resolved": "https://registry.npmjs.org/mute-stream/-/mute-stream-0.0.7.tgz", 3063 | "integrity": "sha1-MHXOk7whuPq0PhvE2n6BFe0ee6s=", 3064 | "dev": true 3065 | }, 3066 | "natural-compare": { 3067 | "version": "1.4.0", 3068 | "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", 3069 | "integrity": "sha1-Sr6/7tdUHywnrPspvbvRXI1bpPc=", 3070 | "dev": true 3071 | }, 3072 | "node-fetch": { 3073 | "version": "1.7.3", 3074 | "resolved": "https://registry.npmjs.org/node-fetch/-/node-fetch-1.7.3.tgz", 3075 | "integrity": "sha512-NhZ4CsKx7cYm2vSrBAr2PvFOe6sWDf0UYLRqA6svUYg7+/TSfVAu49jYC4BvQ4Sms9SZgdqGBgroqfDhJdTyKQ==", 3076 | "requires": { 3077 | "encoding": "0.1.12", 3078 | "is-stream": "1.1.0" 3079 | } 3080 | }, 3081 | "normalize-package-data": { 3082 | "version": "2.4.0", 3083 | "resolved": "https://registry.npmjs.org/normalize-package-data/-/normalize-package-data-2.4.0.tgz", 3084 | "integrity": "sha512-9jjUFbTPfEy3R/ad/2oNbKtW9Hgovl5O1FvFWKkKblNXoN/Oou6+9+KKohPK13Yc3/TyunyWhJp6gvRNR/PPAw==", 3085 | "dev": true, 3086 | "requires": { 3087 | "hosted-git-info": "2.5.0", 3088 | "is-builtin-module": "1.0.0", 3089 | "semver": "5.4.1", 3090 | "validate-npm-package-license": "3.0.1" 3091 | } 3092 | }, 3093 | "normalize-path": { 3094 | "version": "2.1.1", 3095 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-2.1.1.tgz", 3096 | "integrity": "sha1-GrKLVW4Zg2Oowab35vogE3/mrtk=", 3097 | "dev": true, 3098 | "requires": { 3099 | "remove-trailing-separator": "1.1.0" 3100 | } 3101 | }, 3102 | "number-is-nan": { 3103 | "version": "1.0.1", 3104 | "resolved": "https://registry.npmjs.org/number-is-nan/-/number-is-nan-1.0.1.tgz", 3105 | "integrity": "sha1-CXtgK1NCKlIsGvuHkDGDNpQaAR0=", 3106 | "dev": true 3107 | }, 3108 | "object-assign": { 3109 | "version": "4.1.1", 3110 | "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", 3111 | "integrity": "sha1-IQmtx5ZYh8/AXLvUQsrIv7s2CGM=" 3112 | }, 3113 | "object-keys": { 3114 | "version": "1.0.11", 3115 | "resolved": "https://registry.npmjs.org/object-keys/-/object-keys-1.0.11.tgz", 3116 | "integrity": "sha1-xUYBd4rVYPEULODgG8yotW0TQm0=", 3117 | "dev": true 3118 | }, 3119 | "object.omit": { 3120 | "version": "2.0.1", 3121 | "resolved": "https://registry.npmjs.org/object.omit/-/object.omit-2.0.1.tgz", 3122 | "integrity": "sha1-Gpx0SCnznbuFjHbKNXmuKlTr0fo=", 3123 | "dev": true, 3124 | "requires": { 3125 | "for-own": "0.1.5", 3126 | "is-extendable": "0.1.1" 3127 | } 3128 | }, 3129 | "once": { 3130 | "version": "1.4.0", 3131 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 3132 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 3133 | "dev": true, 3134 | "requires": { 3135 | "wrappy": "1.0.2" 3136 | } 3137 | }, 3138 | "onetime": { 3139 | "version": "2.0.1", 3140 | "resolved": "https://registry.npmjs.org/onetime/-/onetime-2.0.1.tgz", 3141 | "integrity": "sha1-BnQoIw/WdEOyeUsiu6UotoZ5YtQ=", 3142 | "dev": true, 3143 | "requires": { 3144 | "mimic-fn": "1.1.0" 3145 | } 3146 | }, 3147 | "optionator": { 3148 | "version": "0.8.2", 3149 | "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.8.2.tgz", 3150 | "integrity": "sha1-NkxeQJ0/TWMB1sC0wFu6UBgK62Q=", 3151 | "dev": true, 3152 | "requires": { 3153 | "deep-is": "0.1.3", 3154 | "fast-levenshtein": "2.0.6", 3155 | "levn": "0.3.0", 3156 | "prelude-ls": "1.1.2", 3157 | "type-check": "0.3.2", 3158 | "wordwrap": "1.0.0" 3159 | } 3160 | }, 3161 | "os-homedir": { 3162 | "version": "1.0.2", 3163 | "resolved": "https://registry.npmjs.org/os-homedir/-/os-homedir-1.0.2.tgz", 3164 | "integrity": "sha1-/7xJiDNuDoM94MFox+8VISGqf7M=", 3165 | "dev": true 3166 | }, 3167 | "os-tmpdir": { 3168 | "version": "1.0.2", 3169 | "resolved": "https://registry.npmjs.org/os-tmpdir/-/os-tmpdir-1.0.2.tgz", 3170 | "integrity": "sha1-u+Z0BseaqFxc/sdm/lc0VV36EnQ=", 3171 | "dev": true 3172 | }, 3173 | "output-file-sync": { 3174 | "version": "1.1.2", 3175 | "resolved": "https://registry.npmjs.org/output-file-sync/-/output-file-sync-1.1.2.tgz", 3176 | "integrity": "sha1-0KM+7+YaIF+suQCS6CZZjVJFznY=", 3177 | "dev": true, 3178 | "requires": { 3179 | "graceful-fs": "4.1.11", 3180 | "mkdirp": "0.5.1", 3181 | "object-assign": "4.1.1" 3182 | } 3183 | }, 3184 | "p-limit": { 3185 | "version": "1.1.0", 3186 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-1.1.0.tgz", 3187 | "integrity": "sha1-sH/y2aXYi+yAYDWJWiurZqJ5iLw=", 3188 | "dev": true 3189 | }, 3190 | "p-locate": { 3191 | "version": "2.0.0", 3192 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-2.0.0.tgz", 3193 | "integrity": "sha1-IKAQOyIqcMj9OcwuWAaA893l7EM=", 3194 | "dev": true, 3195 | "requires": { 3196 | "p-limit": "1.1.0" 3197 | } 3198 | }, 3199 | "parse-glob": { 3200 | "version": "3.0.4", 3201 | "resolved": "https://registry.npmjs.org/parse-glob/-/parse-glob-3.0.4.tgz", 3202 | "integrity": "sha1-ssN2z7EfNVE7rdFz7wu246OIORw=", 3203 | "dev": true, 3204 | "requires": { 3205 | "glob-base": "0.3.0", 3206 | "is-dotfile": "1.0.3", 3207 | "is-extglob": "1.0.0", 3208 | "is-glob": "2.0.1" 3209 | } 3210 | }, 3211 | "parse-json": { 3212 | "version": "2.2.0", 3213 | "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-2.2.0.tgz", 3214 | "integrity": "sha1-9ID0BDTvgHQfhGkJn43qGPVaTck=", 3215 | "dev": true, 3216 | "requires": { 3217 | "error-ex": "1.3.1" 3218 | } 3219 | }, 3220 | "path-exists": { 3221 | "version": "2.1.0", 3222 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-2.1.0.tgz", 3223 | "integrity": "sha1-D+tsZPD8UY2adU3V77YscCJ2H0s=", 3224 | "dev": true, 3225 | "requires": { 3226 | "pinkie-promise": "2.0.1" 3227 | } 3228 | }, 3229 | "path-is-absolute": { 3230 | "version": "1.0.1", 3231 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 3232 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=", 3233 | "dev": true 3234 | }, 3235 | "path-is-inside": { 3236 | "version": "1.0.2", 3237 | "resolved": "https://registry.npmjs.org/path-is-inside/-/path-is-inside-1.0.2.tgz", 3238 | "integrity": "sha1-NlQX3t5EQw0cEa9hAn+s8HS9/FM=", 3239 | "dev": true 3240 | }, 3241 | "path-parse": { 3242 | "version": "1.0.5", 3243 | "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.5.tgz", 3244 | "integrity": "sha1-PBrfhx6pzWyUMbbqK9dKD/BVxME=", 3245 | "dev": true 3246 | }, 3247 | "path-type": { 3248 | "version": "2.0.0", 3249 | "resolved": "https://registry.npmjs.org/path-type/-/path-type-2.0.0.tgz", 3250 | "integrity": "sha1-8BLMuEFbcJb8LaoQVMPXI4lZTHM=", 3251 | "dev": true, 3252 | "requires": { 3253 | "pify": "2.3.0" 3254 | } 3255 | }, 3256 | "pify": { 3257 | "version": "2.3.0", 3258 | "resolved": "https://registry.npmjs.org/pify/-/pify-2.3.0.tgz", 3259 | "integrity": "sha1-7RQaasBDqEnqWISY59yosVMw6Qw=", 3260 | "dev": true 3261 | }, 3262 | "pinkie": { 3263 | "version": "2.0.4", 3264 | "resolved": "https://registry.npmjs.org/pinkie/-/pinkie-2.0.4.tgz", 3265 | "integrity": "sha1-clVrgM+g1IqXToDnckjoDtT3+HA=", 3266 | "dev": true 3267 | }, 3268 | "pinkie-promise": { 3269 | "version": "2.0.1", 3270 | "resolved": "https://registry.npmjs.org/pinkie-promise/-/pinkie-promise-2.0.1.tgz", 3271 | "integrity": "sha1-ITXW36ejWMBprJsXh3YogihFD/o=", 3272 | "dev": true, 3273 | "requires": { 3274 | "pinkie": "2.0.4" 3275 | } 3276 | }, 3277 | "pkg-dir": { 3278 | "version": "1.0.0", 3279 | "resolved": "https://registry.npmjs.org/pkg-dir/-/pkg-dir-1.0.0.tgz", 3280 | "integrity": "sha1-ektQio1bstYp1EcFb/TpyTFM89Q=", 3281 | "dev": true, 3282 | "requires": { 3283 | "find-up": "1.1.2" 3284 | } 3285 | }, 3286 | "pluralize": { 3287 | "version": "7.0.0", 3288 | "resolved": "https://registry.npmjs.org/pluralize/-/pluralize-7.0.0.tgz", 3289 | "integrity": "sha512-ARhBOdzS3e41FbkW/XWrTEtukqqLoK5+Z/4UeDaLuSW+39JPeFgs4gCGqsrJHVZX0fUrx//4OF0K1CUGwlIFow==", 3290 | "dev": true 3291 | }, 3292 | "prelude-ls": { 3293 | "version": "1.1.2", 3294 | "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.1.2.tgz", 3295 | "integrity": "sha1-IZMqVJ9eUv/ZqCf1cOBL5iqX2lQ=", 3296 | "dev": true 3297 | }, 3298 | "preserve": { 3299 | "version": "0.2.0", 3300 | "resolved": "https://registry.npmjs.org/preserve/-/preserve-0.2.0.tgz", 3301 | "integrity": "sha1-gV7R9uvGWSb4ZbMQwHE7yzMVzks=", 3302 | "dev": true 3303 | }, 3304 | "private": { 3305 | "version": "0.1.8", 3306 | "resolved": "https://registry.npmjs.org/private/-/private-0.1.8.tgz", 3307 | "integrity": "sha512-VvivMrbvd2nKkiG38qjULzlc+4Vx4wm/whI9pQD35YrARNnhxeiRktSOhSukRLFNlzg6Br/cJPet5J/u19r/mg==", 3308 | "dev": true 3309 | }, 3310 | "process-nextick-args": { 3311 | "version": "1.0.7", 3312 | "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-1.0.7.tgz", 3313 | "integrity": "sha1-FQ4gt1ZZCtP5EJPyWk8q2L/zC6M=", 3314 | "dev": true 3315 | }, 3316 | "progress": { 3317 | "version": "2.0.0", 3318 | "resolved": "https://registry.npmjs.org/progress/-/progress-2.0.0.tgz", 3319 | "integrity": "sha1-ihvjZr+Pwj2yvSPxDG/pILQ4nR8=", 3320 | "dev": true 3321 | }, 3322 | "promise": { 3323 | "version": "7.3.1", 3324 | "resolved": "https://registry.npmjs.org/promise/-/promise-7.3.1.tgz", 3325 | "integrity": "sha512-nolQXZ/4L+bP/UGlkfaIujX9BKxGwmQ9OT4mOt5yvy8iK1h3wqTEJCijzGANTCCl9nWjY41juyAn2K3Q1hLLTg==", 3326 | "requires": { 3327 | "asap": "2.0.6" 3328 | } 3329 | }, 3330 | "prop-types": { 3331 | "version": "15.6.0", 3332 | "resolved": "https://registry.npmjs.org/prop-types/-/prop-types-15.6.0.tgz", 3333 | "integrity": "sha1-zq8IMCL8RrSjX2nhPvda7Q1jmFY=", 3334 | "requires": { 3335 | "fbjs": "0.8.16", 3336 | "loose-envify": "1.3.1", 3337 | "object-assign": "4.1.1" 3338 | } 3339 | }, 3340 | "pseudomap": { 3341 | "version": "1.0.2", 3342 | "resolved": "https://registry.npmjs.org/pseudomap/-/pseudomap-1.0.2.tgz", 3343 | "integrity": "sha1-8FKijacOYYkX7wqKw0wa5aaChrM=", 3344 | "dev": true 3345 | }, 3346 | "ramda": { 3347 | "version": "0.25.0", 3348 | "resolved": "https://registry.npmjs.org/ramda/-/ramda-0.25.0.tgz", 3349 | "integrity": "sha512-GXpfrYVPwx3K7RQ6aYT8KPS8XViSXUVJT1ONhoKPE9VAleW42YE+U+8VEyGWt41EnEQW7gwecYJriTI0pKoecQ==", 3350 | "dev": true 3351 | }, 3352 | "randomatic": { 3353 | "version": "1.1.7", 3354 | "resolved": "https://registry.npmjs.org/randomatic/-/randomatic-1.1.7.tgz", 3355 | "integrity": "sha512-D5JUjPyJbaJDkuAazpVnSfVkLlpeO3wDlPROTMLGKG1zMFNFRgrciKo1ltz/AzNTkqE0HzDx655QOL51N06how==", 3356 | "dev": true, 3357 | "requires": { 3358 | "is-number": "3.0.0", 3359 | "kind-of": "4.0.0" 3360 | }, 3361 | "dependencies": { 3362 | "is-number": { 3363 | "version": "3.0.0", 3364 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-3.0.0.tgz", 3365 | "integrity": "sha1-JP1iAaR4LPUFYcgQJ2r8fRLXEZU=", 3366 | "dev": true, 3367 | "requires": { 3368 | "kind-of": "3.2.2" 3369 | }, 3370 | "dependencies": { 3371 | "kind-of": { 3372 | "version": "3.2.2", 3373 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", 3374 | "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", 3375 | "dev": true, 3376 | "requires": { 3377 | "is-buffer": "1.1.6" 3378 | } 3379 | } 3380 | } 3381 | }, 3382 | "kind-of": { 3383 | "version": "4.0.0", 3384 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-4.0.0.tgz", 3385 | "integrity": "sha1-IIE989cSkosgc3hpGkUGb65y3Vc=", 3386 | "dev": true, 3387 | "requires": { 3388 | "is-buffer": "1.1.6" 3389 | } 3390 | } 3391 | } 3392 | }, 3393 | "react": { 3394 | "version": "16.0.0", 3395 | "resolved": "https://registry.npmjs.org/react/-/react-16.0.0.tgz", 3396 | "integrity": "sha1-zn348ZQbA28Cssyp29DLHw6FXi0=", 3397 | "dev": true, 3398 | "requires": { 3399 | "fbjs": "0.8.16", 3400 | "loose-envify": "1.3.1", 3401 | "object-assign": "4.1.1", 3402 | "prop-types": "15.6.0" 3403 | } 3404 | }, 3405 | "read-pkg": { 3406 | "version": "2.0.0", 3407 | "resolved": "https://registry.npmjs.org/read-pkg/-/read-pkg-2.0.0.tgz", 3408 | "integrity": "sha1-jvHAYjxqbbDcZxPEv6xGMysjaPg=", 3409 | "dev": true, 3410 | "requires": { 3411 | "load-json-file": "2.0.0", 3412 | "normalize-package-data": "2.4.0", 3413 | "path-type": "2.0.0" 3414 | } 3415 | }, 3416 | "read-pkg-up": { 3417 | "version": "2.0.0", 3418 | "resolved": "https://registry.npmjs.org/read-pkg-up/-/read-pkg-up-2.0.0.tgz", 3419 | "integrity": "sha1-a3KoBImE4MQeeVEP1en6mbO1Sb4=", 3420 | "dev": true, 3421 | "requires": { 3422 | "find-up": "2.1.0", 3423 | "read-pkg": "2.0.0" 3424 | }, 3425 | "dependencies": { 3426 | "find-up": { 3427 | "version": "2.1.0", 3428 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-2.1.0.tgz", 3429 | "integrity": "sha1-RdG35QbHF93UgndaK3eSCjwMV6c=", 3430 | "dev": true, 3431 | "requires": { 3432 | "locate-path": "2.0.0" 3433 | } 3434 | } 3435 | } 3436 | }, 3437 | "readable-stream": { 3438 | "version": "2.3.3", 3439 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.3.tgz", 3440 | "integrity": "sha512-m+qzzcn7KUxEmd1gMbchF+Y2eIUbieUaxkWtptyHywrX0rE8QEYqPC07Vuy4Wm32/xE16NcdBctb8S0Xe/5IeQ==", 3441 | "dev": true, 3442 | "requires": { 3443 | "core-util-is": "1.0.2", 3444 | "inherits": "2.0.3", 3445 | "isarray": "1.0.0", 3446 | "process-nextick-args": "1.0.7", 3447 | "safe-buffer": "5.1.1", 3448 | "string_decoder": "1.0.3", 3449 | "util-deprecate": "1.0.2" 3450 | } 3451 | }, 3452 | "readdirp": { 3453 | "version": "2.1.0", 3454 | "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-2.1.0.tgz", 3455 | "integrity": "sha1-TtCtBg3zBzMAxIRANz9y0cxkLXg=", 3456 | "dev": true, 3457 | "optional": true, 3458 | "requires": { 3459 | "graceful-fs": "4.1.11", 3460 | "minimatch": "3.0.4", 3461 | "readable-stream": "2.3.3", 3462 | "set-immediate-shim": "1.0.1" 3463 | } 3464 | }, 3465 | "regenerate": { 3466 | "version": "1.3.3", 3467 | "resolved": "https://registry.npmjs.org/regenerate/-/regenerate-1.3.3.tgz", 3468 | "integrity": "sha512-jVpo1GadrDAK59t/0jRx5VxYWQEDkkEKi6+HjE3joFVLfDOh9Xrdh0dF1eSq+BI/SwvTQ44gSscJ8N5zYL61sg==", 3469 | "dev": true 3470 | }, 3471 | "regenerator-runtime": { 3472 | "version": "0.11.0", 3473 | "resolved": "https://registry.npmjs.org/regenerator-runtime/-/regenerator-runtime-0.11.0.tgz", 3474 | "integrity": "sha512-/aA0kLeRb5N9K0d4fw7ooEbI+xDe+DKD499EQqygGqeS8N3xto15p09uY2xj7ixP81sNPXvRLnAQIqdVStgb1A==", 3475 | "dev": true 3476 | }, 3477 | "regenerator-transform": { 3478 | "version": "0.10.1", 3479 | "resolved": "https://registry.npmjs.org/regenerator-transform/-/regenerator-transform-0.10.1.tgz", 3480 | "integrity": "sha512-PJepbvDbuK1xgIgnau7Y90cwaAmO/LCLMI2mPvaXq2heGMR3aWW5/BQvYrhJ8jgmQjXewXvBjzfqKcVOmhjZ6Q==", 3481 | "dev": true, 3482 | "requires": { 3483 | "babel-runtime": "6.26.0", 3484 | "babel-types": "6.26.0", 3485 | "private": "0.1.8" 3486 | } 3487 | }, 3488 | "regex-cache": { 3489 | "version": "0.4.4", 3490 | "resolved": "https://registry.npmjs.org/regex-cache/-/regex-cache-0.4.4.tgz", 3491 | "integrity": "sha512-nVIZwtCjkC9YgvWkpM55B5rBhBYRZhAaJbgcFYXXsHnbZ9UZI9nnVWYZpBlCqv9ho2eZryPnWrZGsOdPwVWXWQ==", 3492 | "dev": true, 3493 | "requires": { 3494 | "is-equal-shallow": "0.1.3" 3495 | } 3496 | }, 3497 | "regexpu-core": { 3498 | "version": "2.0.0", 3499 | "resolved": "https://registry.npmjs.org/regexpu-core/-/regexpu-core-2.0.0.tgz", 3500 | "integrity": "sha1-SdA4g3uNz4v6W5pCE5k45uoq4kA=", 3501 | "dev": true, 3502 | "requires": { 3503 | "regenerate": "1.3.3", 3504 | "regjsgen": "0.2.0", 3505 | "regjsparser": "0.1.5" 3506 | } 3507 | }, 3508 | "regjsgen": { 3509 | "version": "0.2.0", 3510 | "resolved": "https://registry.npmjs.org/regjsgen/-/regjsgen-0.2.0.tgz", 3511 | "integrity": "sha1-bAFq3qxVT3WCP+N6wFuS1aTtsfc=", 3512 | "dev": true 3513 | }, 3514 | "regjsparser": { 3515 | "version": "0.1.5", 3516 | "resolved": "https://registry.npmjs.org/regjsparser/-/regjsparser-0.1.5.tgz", 3517 | "integrity": "sha1-fuj4Tcb6eS0/0K4ijSS9lJ6tIFw=", 3518 | "dev": true, 3519 | "requires": { 3520 | "jsesc": "0.5.0" 3521 | }, 3522 | "dependencies": { 3523 | "jsesc": { 3524 | "version": "0.5.0", 3525 | "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-0.5.0.tgz", 3526 | "integrity": "sha1-597mbjXW/Bb3EP6R1c9p9w8IkR0=", 3527 | "dev": true 3528 | } 3529 | } 3530 | }, 3531 | "remove-trailing-separator": { 3532 | "version": "1.1.0", 3533 | "resolved": "https://registry.npmjs.org/remove-trailing-separator/-/remove-trailing-separator-1.1.0.tgz", 3534 | "integrity": "sha1-wkvOKig62tW8P1jg1IJJuSN52O8=", 3535 | "dev": true 3536 | }, 3537 | "repeat-element": { 3538 | "version": "1.1.2", 3539 | "resolved": "https://registry.npmjs.org/repeat-element/-/repeat-element-1.1.2.tgz", 3540 | "integrity": "sha1-7wiaF40Ug7quTZPrmLT55OEdmQo=", 3541 | "dev": true 3542 | }, 3543 | "repeat-string": { 3544 | "version": "1.6.1", 3545 | "resolved": "https://registry.npmjs.org/repeat-string/-/repeat-string-1.6.1.tgz", 3546 | "integrity": "sha1-jcrkcOHIirwtYA//Sndihtp15jc=", 3547 | "dev": true 3548 | }, 3549 | "repeating": { 3550 | "version": "2.0.1", 3551 | "resolved": "https://registry.npmjs.org/repeating/-/repeating-2.0.1.tgz", 3552 | "integrity": "sha1-UhTFOpJtNVJwdSf7q0FdvAjQbdo=", 3553 | "dev": true, 3554 | "requires": { 3555 | "is-finite": "1.0.2" 3556 | } 3557 | }, 3558 | "require-uncached": { 3559 | "version": "1.0.3", 3560 | "resolved": "https://registry.npmjs.org/require-uncached/-/require-uncached-1.0.3.tgz", 3561 | "integrity": "sha1-Tg1W1slmL9MeQwEcS5WqSZVUIdM=", 3562 | "dev": true, 3563 | "requires": { 3564 | "caller-path": "0.1.0", 3565 | "resolve-from": "1.0.1" 3566 | } 3567 | }, 3568 | "resolve": { 3569 | "version": "1.5.0", 3570 | "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.5.0.tgz", 3571 | "integrity": "sha512-hgoSGrc3pjzAPHNBg+KnFcK2HwlHTs/YrAGUr6qgTVUZmXv1UEXXl0bZNBKMA9fud6lRYFdPGz0xXxycPzmmiw==", 3572 | "dev": true, 3573 | "requires": { 3574 | "path-parse": "1.0.5" 3575 | } 3576 | }, 3577 | "resolve-from": { 3578 | "version": "1.0.1", 3579 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-1.0.1.tgz", 3580 | "integrity": "sha1-Jsv+k10a7uq7Kbw/5a6wHpPUQiY=", 3581 | "dev": true 3582 | }, 3583 | "restore-cursor": { 3584 | "version": "2.0.0", 3585 | "resolved": "https://registry.npmjs.org/restore-cursor/-/restore-cursor-2.0.0.tgz", 3586 | "integrity": "sha1-n37ih/gv0ybU/RYpI9YhKe7g368=", 3587 | "dev": true, 3588 | "requires": { 3589 | "onetime": "2.0.1", 3590 | "signal-exit": "3.0.2" 3591 | } 3592 | }, 3593 | "rimraf": { 3594 | "version": "2.6.2", 3595 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.6.2.tgz", 3596 | "integrity": "sha512-lreewLK/BlghmxtfH36YYVg1i8IAce4TI7oao75I1g245+6BctqTVQiBP3YUJ9C6DQOXJmkYR9X9fCLtCOJc5w==", 3597 | "dev": true, 3598 | "requires": { 3599 | "glob": "7.1.2" 3600 | } 3601 | }, 3602 | "rollup": { 3603 | "version": "0.50.0", 3604 | "resolved": "https://registry.npmjs.org/rollup/-/rollup-0.50.0.tgz", 3605 | "integrity": "sha512-7RqCBQ9iwsOBPkjYgoIaeUij606mSkDMExP0NT7QDI3bqkHYQHrQ83uoNIXwPcQm/vP2VbsUz3kiyZZ1qPlLTQ==", 3606 | "dev": true 3607 | }, 3608 | "rollup-analyzer": { 3609 | "version": "1.1.0", 3610 | "resolved": "https://registry.npmjs.org/rollup-analyzer/-/rollup-analyzer-1.1.0.tgz", 3611 | "integrity": "sha512-QTUudbQdw0o+Z0Y838WEag5AqkRwc5hOj0K774eB5jXG733v72fQX0u6jCqV1i3OU+kEqVCasi3UEbt/ep1R/A==", 3612 | "dev": true 3613 | }, 3614 | "rollup-analyzer-plugin": { 3615 | "version": "1.1.1", 3616 | "resolved": "https://registry.npmjs.org/rollup-analyzer-plugin/-/rollup-analyzer-plugin-1.1.1.tgz", 3617 | "integrity": "sha512-Z8HSQEGqB60ntOpcYZZ1LSTG9zFTwpGhTEz2c4d6+crw7+2lOuO5T5K7pOqWhSESq+HcApMzrqTAwLEKDbstSA==", 3618 | "dev": true, 3619 | "requires": { 3620 | "rollup-analyzer": "1.1.0" 3621 | } 3622 | }, 3623 | "rollup-plugin-babel": { 3624 | "version": "3.0.2", 3625 | "resolved": "https://registry.npmjs.org/rollup-plugin-babel/-/rollup-plugin-babel-3.0.2.tgz", 3626 | "integrity": "sha512-ALGPBFtwJZcYHsNPM6RGJlEncTzAARPvZOGjNPZgDe5hS5t6sJGjiOWibEFVEz5LQN7S7spvCBILaS4N1Cql2w==", 3627 | "dev": true, 3628 | "requires": { 3629 | "rollup-pluginutils": "1.5.2" 3630 | } 3631 | }, 3632 | "rollup-plugin-commonjs": { 3633 | "version": "8.2.3", 3634 | "resolved": "https://registry.npmjs.org/rollup-plugin-commonjs/-/rollup-plugin-commonjs-8.2.3.tgz", 3635 | "integrity": "sha512-WFkITnsa3sNsWtBfBMnjXVUN/6tWKVOUTq/2VhQhDjytPhpZ/y+oTa2tyBdu9caC9Rp29ZtnH+qo4zYO7n8/Ww==", 3636 | "dev": true, 3637 | "requires": { 3638 | "acorn": "5.2.1", 3639 | "estree-walker": "0.5.0", 3640 | "magic-string": "0.22.4", 3641 | "resolve": "1.5.0", 3642 | "rollup-pluginutils": "2.0.1" 3643 | }, 3644 | "dependencies": { 3645 | "estree-walker": { 3646 | "version": "0.5.0", 3647 | "resolved": "https://registry.npmjs.org/estree-walker/-/estree-walker-0.5.0.tgz", 3648 | "integrity": "sha512-/bEAy+yKAZQrEWUhGmS3H9XpGqSDBtRzX0I2PgMw9kA2n1jN22uV5B5p7MFdZdvWdXCRJztXAfx6ZeRfgkEETg==", 3649 | "dev": true 3650 | }, 3651 | "rollup-pluginutils": { 3652 | "version": "2.0.1", 3653 | "resolved": "https://registry.npmjs.org/rollup-pluginutils/-/rollup-pluginutils-2.0.1.tgz", 3654 | "integrity": "sha1-fslbNXP2VDpGpkYb2afFRFJdD8A=", 3655 | "dev": true, 3656 | "requires": { 3657 | "estree-walker": "0.3.1", 3658 | "micromatch": "2.3.11" 3659 | }, 3660 | "dependencies": { 3661 | "estree-walker": { 3662 | "version": "0.3.1", 3663 | "resolved": "https://registry.npmjs.org/estree-walker/-/estree-walker-0.3.1.tgz", 3664 | "integrity": "sha1-5rGlHPcpJSTnI3wxLl/mZgwc4ao=", 3665 | "dev": true 3666 | } 3667 | } 3668 | } 3669 | } 3670 | }, 3671 | "rollup-plugin-node-resolve": { 3672 | "version": "3.0.0", 3673 | "resolved": "https://registry.npmjs.org/rollup-plugin-node-resolve/-/rollup-plugin-node-resolve-3.0.0.tgz", 3674 | "integrity": "sha1-i4l8TDAw1QASd7BRSyXSygloPuA=", 3675 | "dev": true, 3676 | "requires": { 3677 | "browser-resolve": "1.11.2", 3678 | "builtin-modules": "1.1.1", 3679 | "is-module": "1.0.0", 3680 | "resolve": "1.5.0" 3681 | } 3682 | }, 3683 | "rollup-plugin-replace": { 3684 | "version": "2.0.0", 3685 | "resolved": "https://registry.npmjs.org/rollup-plugin-replace/-/rollup-plugin-replace-2.0.0.tgz", 3686 | "integrity": "sha512-pK9mTd/FNrhtBxcTBXoh0YOwRIShV0gGhv9qvUtNcXHxIMRZMXqfiZKVBmCRGp8/2DJRy62z2JUE7/5tP6WxOQ==", 3687 | "dev": true, 3688 | "requires": { 3689 | "magic-string": "0.22.4", 3690 | "minimatch": "3.0.4", 3691 | "rollup-pluginutils": "2.0.1" 3692 | }, 3693 | "dependencies": { 3694 | "estree-walker": { 3695 | "version": "0.3.1", 3696 | "resolved": "https://registry.npmjs.org/estree-walker/-/estree-walker-0.3.1.tgz", 3697 | "integrity": "sha1-5rGlHPcpJSTnI3wxLl/mZgwc4ao=", 3698 | "dev": true 3699 | }, 3700 | "rollup-pluginutils": { 3701 | "version": "2.0.1", 3702 | "resolved": "https://registry.npmjs.org/rollup-pluginutils/-/rollup-pluginutils-2.0.1.tgz", 3703 | "integrity": "sha1-fslbNXP2VDpGpkYb2afFRFJdD8A=", 3704 | "dev": true, 3705 | "requires": { 3706 | "estree-walker": "0.3.1", 3707 | "micromatch": "2.3.11" 3708 | } 3709 | } 3710 | } 3711 | }, 3712 | "rollup-plugin-uglify": { 3713 | "version": "2.0.1", 3714 | "resolved": "https://registry.npmjs.org/rollup-plugin-uglify/-/rollup-plugin-uglify-2.0.1.tgz", 3715 | "integrity": "sha1-Z7N60e/a+9g69MNrQMGJ7khmyWk=", 3716 | "dev": true, 3717 | "requires": { 3718 | "uglify-js": "3.1.6" 3719 | } 3720 | }, 3721 | "rollup-pluginutils": { 3722 | "version": "1.5.2", 3723 | "resolved": "https://registry.npmjs.org/rollup-pluginutils/-/rollup-pluginutils-1.5.2.tgz", 3724 | "integrity": "sha1-HhVud4+UtyVb+hs9AXi+j1xVJAg=", 3725 | "dev": true, 3726 | "requires": { 3727 | "estree-walker": "0.2.1", 3728 | "minimatch": "3.0.4" 3729 | } 3730 | }, 3731 | "run-async": { 3732 | "version": "2.3.0", 3733 | "resolved": "https://registry.npmjs.org/run-async/-/run-async-2.3.0.tgz", 3734 | "integrity": "sha1-A3GrSuC91yDUFm19/aZP96RFpsA=", 3735 | "dev": true, 3736 | "requires": { 3737 | "is-promise": "2.1.0" 3738 | } 3739 | }, 3740 | "rx-lite": { 3741 | "version": "4.0.8", 3742 | "resolved": "https://registry.npmjs.org/rx-lite/-/rx-lite-4.0.8.tgz", 3743 | "integrity": "sha1-Cx4Rr4vESDbwSmQH6S2kJGe3lEQ=", 3744 | "dev": true 3745 | }, 3746 | "rx-lite-aggregates": { 3747 | "version": "4.0.8", 3748 | "resolved": "https://registry.npmjs.org/rx-lite-aggregates/-/rx-lite-aggregates-4.0.8.tgz", 3749 | "integrity": "sha1-dTuHqJoRyVRnxKwWJsTvxOBcZ74=", 3750 | "dev": true, 3751 | "requires": { 3752 | "rx-lite": "4.0.8" 3753 | } 3754 | }, 3755 | "safe-buffer": { 3756 | "version": "5.1.1", 3757 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.1.tgz", 3758 | "integrity": "sha512-kKvNJn6Mm93gAczWVJg7wH+wGYWNrDHdWvpUmHyEsgCtIwwo3bqPtV4tR5tuPaUhTOo/kvhVwd8XwwOllGYkbg==", 3759 | "dev": true 3760 | }, 3761 | "semver": { 3762 | "version": "5.4.1", 3763 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.4.1.tgz", 3764 | "integrity": "sha512-WfG/X9+oATh81XtllIo/I8gOiY9EXRdv1cQdyykeXK17YcUW3EXUAi2To4pcH6nZtJPr7ZOpM5OMyWJZm+8Rsg==", 3765 | "dev": true 3766 | }, 3767 | "set-immediate-shim": { 3768 | "version": "1.0.1", 3769 | "resolved": "https://registry.npmjs.org/set-immediate-shim/-/set-immediate-shim-1.0.1.tgz", 3770 | "integrity": "sha1-SysbJ+uAip+NzEgaWOXlb1mfP2E=", 3771 | "dev": true, 3772 | "optional": true 3773 | }, 3774 | "setimmediate": { 3775 | "version": "1.0.5", 3776 | "resolved": "https://registry.npmjs.org/setimmediate/-/setimmediate-1.0.5.tgz", 3777 | "integrity": "sha1-KQy7Iy4waULX1+qbg3Mqt4VvgoU=" 3778 | }, 3779 | "shebang-command": { 3780 | "version": "1.2.0", 3781 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-1.2.0.tgz", 3782 | "integrity": "sha1-RKrGW2lbAzmJaMOfNj/uXer98eo=", 3783 | "dev": true, 3784 | "requires": { 3785 | "shebang-regex": "1.0.0" 3786 | } 3787 | }, 3788 | "shebang-regex": { 3789 | "version": "1.0.0", 3790 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-1.0.0.tgz", 3791 | "integrity": "sha1-2kL0l0DAtC2yypcoVxyxkMmO/qM=", 3792 | "dev": true 3793 | }, 3794 | "signal-exit": { 3795 | "version": "3.0.2", 3796 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.2.tgz", 3797 | "integrity": "sha1-tf3AjxKH6hF4Yo5BXiUTK3NkbG0=", 3798 | "dev": true 3799 | }, 3800 | "slash": { 3801 | "version": "1.0.0", 3802 | "resolved": "https://registry.npmjs.org/slash/-/slash-1.0.0.tgz", 3803 | "integrity": "sha1-xB8vbDn8FtHNF61LXYlhFK5HDVU=", 3804 | "dev": true 3805 | }, 3806 | "slice-ansi": { 3807 | "version": "1.0.0", 3808 | "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-1.0.0.tgz", 3809 | "integrity": "sha512-POqxBK6Lb3q6s047D/XsDVNPnF9Dl8JSaqe9h9lURl0OdNqy/ujDrOiIHtsqXMGbWWTIomRzAMaTyawAU//Reg==", 3810 | "dev": true, 3811 | "requires": { 3812 | "is-fullwidth-code-point": "2.0.0" 3813 | } 3814 | }, 3815 | "source-map": { 3816 | "version": "0.5.7", 3817 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.5.7.tgz", 3818 | "integrity": "sha1-igOdLRAh0i0eoUyA2OpGi6LvP8w=", 3819 | "dev": true 3820 | }, 3821 | "source-map-support": { 3822 | "version": "0.4.18", 3823 | "resolved": "https://registry.npmjs.org/source-map-support/-/source-map-support-0.4.18.tgz", 3824 | "integrity": "sha512-try0/JqxPLF9nOjvSta7tVondkP5dwgyLDjVoyMDlmjugT2lRZ1OfsrYTkCd2hkDnJTKRbO/Rl3orm8vlsUzbA==", 3825 | "dev": true, 3826 | "requires": { 3827 | "source-map": "0.5.7" 3828 | } 3829 | }, 3830 | "spdx-correct": { 3831 | "version": "1.0.2", 3832 | "resolved": "https://registry.npmjs.org/spdx-correct/-/spdx-correct-1.0.2.tgz", 3833 | "integrity": "sha1-SzBz2TP/UfORLwOsVRlJikFQ20A=", 3834 | "dev": true, 3835 | "requires": { 3836 | "spdx-license-ids": "1.2.2" 3837 | } 3838 | }, 3839 | "spdx-expression-parse": { 3840 | "version": "1.0.4", 3841 | "resolved": "https://registry.npmjs.org/spdx-expression-parse/-/spdx-expression-parse-1.0.4.tgz", 3842 | "integrity": "sha1-m98vIOH0DtRH++JzJmGR/O1RYmw=", 3843 | "dev": true 3844 | }, 3845 | "spdx-license-ids": { 3846 | "version": "1.2.2", 3847 | "resolved": "https://registry.npmjs.org/spdx-license-ids/-/spdx-license-ids-1.2.2.tgz", 3848 | "integrity": "sha1-yd96NCRZSt5r0RkA1ZZpbcBrrFc=", 3849 | "dev": true 3850 | }, 3851 | "sprintf-js": { 3852 | "version": "1.0.3", 3853 | "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz", 3854 | "integrity": "sha1-BOaSb2YolTVPPdAVIDYzuFcpfiw=", 3855 | "dev": true 3856 | }, 3857 | "state-clerk": { 3858 | "version": "1.3.0", 3859 | "resolved": "https://registry.npmjs.org/state-clerk/-/state-clerk-1.3.0.tgz", 3860 | "integrity": "sha1-Y+DtJxVOcevJNJCmFYp/VLGoWo4=", 3861 | "dev": true, 3862 | "requires": { 3863 | "invariant": "2.2.2", 3864 | "loose-envify": "1.3.1", 3865 | "ramda": "0.25.0" 3866 | } 3867 | }, 3868 | "string-width": { 3869 | "version": "2.1.1", 3870 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-2.1.1.tgz", 3871 | "integrity": "sha512-nOqH59deCq9SRHlxq1Aw85Jnt4w6KvLKqWVik6oA9ZklXLNIOlqg4F2yrT1MVaTjAqvVwdfeZ7w7aCvJD7ugkw==", 3872 | "dev": true, 3873 | "requires": { 3874 | "is-fullwidth-code-point": "2.0.0", 3875 | "strip-ansi": "4.0.0" 3876 | }, 3877 | "dependencies": { 3878 | "ansi-regex": { 3879 | "version": "3.0.0", 3880 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-3.0.0.tgz", 3881 | "integrity": "sha1-7QMXwyIGT3lGbAKWa922Bas32Zg=", 3882 | "dev": true 3883 | }, 3884 | "strip-ansi": { 3885 | "version": "4.0.0", 3886 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-4.0.0.tgz", 3887 | "integrity": "sha1-qEeQIusaw2iocTibY1JixQXuNo8=", 3888 | "dev": true, 3889 | "requires": { 3890 | "ansi-regex": "3.0.0" 3891 | } 3892 | } 3893 | } 3894 | }, 3895 | "string_decoder": { 3896 | "version": "1.0.3", 3897 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.0.3.tgz", 3898 | "integrity": "sha512-4AH6Z5fzNNBcH+6XDMfA/BTt87skxqJlO0lAh3Dker5zThcAxG6mKz+iGu308UKoPPQ8Dcqx/4JhujzltRa+hQ==", 3899 | "dev": true, 3900 | "requires": { 3901 | "safe-buffer": "5.1.1" 3902 | } 3903 | }, 3904 | "strip-ansi": { 3905 | "version": "3.0.1", 3906 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-3.0.1.tgz", 3907 | "integrity": "sha1-ajhfuIU9lS1f8F0Oiq+UJ43GPc8=", 3908 | "dev": true, 3909 | "requires": { 3910 | "ansi-regex": "2.1.1" 3911 | } 3912 | }, 3913 | "strip-bom": { 3914 | "version": "3.0.0", 3915 | "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-3.0.0.tgz", 3916 | "integrity": "sha1-IzTBjpx1n3vdVv3vfprj1YjmjtM=", 3917 | "dev": true 3918 | }, 3919 | "strip-json-comments": { 3920 | "version": "2.0.1", 3921 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-2.0.1.tgz", 3922 | "integrity": "sha1-PFMZQukIwml8DsNEhYwobHygpgo=", 3923 | "dev": true 3924 | }, 3925 | "supports-color": { 3926 | "version": "2.0.0", 3927 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-2.0.0.tgz", 3928 | "integrity": "sha1-U10EXOa2Nj+kARcIRimZXp3zJMc=", 3929 | "dev": true 3930 | }, 3931 | "table": { 3932 | "version": "4.0.2", 3933 | "resolved": "https://registry.npmjs.org/table/-/table-4.0.2.tgz", 3934 | "integrity": "sha512-UUkEAPdSGxtRpiV9ozJ5cMTtYiqz7Ni1OGqLXRCynrvzdtR1p+cfOWe2RJLwvUG8hNanaSRjecIqwOjqeatDsA==", 3935 | "dev": true, 3936 | "requires": { 3937 | "ajv": "5.3.0", 3938 | "ajv-keywords": "2.1.1", 3939 | "chalk": "2.3.0", 3940 | "lodash": "4.17.4", 3941 | "slice-ansi": "1.0.0", 3942 | "string-width": "2.1.1" 3943 | }, 3944 | "dependencies": { 3945 | "ansi-styles": { 3946 | "version": "3.2.0", 3947 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.0.tgz", 3948 | "integrity": "sha512-NnSOmMEYtVR2JVMIGTzynRkkaxtiq1xnFBcdQD/DnNCYPoEPsVJhM98BDyaoNOQIi7p4okdi3E27eN7GQbsUug==", 3949 | "dev": true, 3950 | "requires": { 3951 | "color-convert": "1.9.0" 3952 | } 3953 | }, 3954 | "chalk": { 3955 | "version": "2.3.0", 3956 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.3.0.tgz", 3957 | "integrity": "sha512-Az5zJR2CBujap2rqXGaJKaPHyJ0IrUimvYNX+ncCy8PJP4ltOGTrHUIo097ZaL2zMeKYpiCdqDvS6zdrTFok3Q==", 3958 | "dev": true, 3959 | "requires": { 3960 | "ansi-styles": "3.2.0", 3961 | "escape-string-regexp": "1.0.5", 3962 | "supports-color": "4.5.0" 3963 | } 3964 | }, 3965 | "supports-color": { 3966 | "version": "4.5.0", 3967 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-4.5.0.tgz", 3968 | "integrity": "sha1-vnoN5ITexcXN34s9WRJQRJEvY1s=", 3969 | "dev": true, 3970 | "requires": { 3971 | "has-flag": "2.0.0" 3972 | } 3973 | } 3974 | } 3975 | }, 3976 | "text-table": { 3977 | "version": "0.2.0", 3978 | "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz", 3979 | "integrity": "sha1-f17oI66AUgfACvLfSoTsP8+lcLQ=", 3980 | "dev": true 3981 | }, 3982 | "through": { 3983 | "version": "2.3.8", 3984 | "resolved": "https://registry.npmjs.org/through/-/through-2.3.8.tgz", 3985 | "integrity": "sha1-DdTJ/6q8NXlgsbckEV1+Doai4fU=", 3986 | "dev": true 3987 | }, 3988 | "tmp": { 3989 | "version": "0.0.33", 3990 | "resolved": "https://registry.npmjs.org/tmp/-/tmp-0.0.33.tgz", 3991 | "integrity": "sha512-jRCJlojKnZ3addtTOjdIqoRuPEKBvNXcGYqzO6zWZX8KfKEpnGY5jfggJQ3EjKuu8D4bJRr0y+cYJFmYbImXGw==", 3992 | "dev": true, 3993 | "requires": { 3994 | "os-tmpdir": "1.0.2" 3995 | } 3996 | }, 3997 | "to-fast-properties": { 3998 | "version": "1.0.3", 3999 | "resolved": "https://registry.npmjs.org/to-fast-properties/-/to-fast-properties-1.0.3.tgz", 4000 | "integrity": "sha1-uDVx+k2MJbguIxsG46MFXeTKGkc=", 4001 | "dev": true 4002 | }, 4003 | "trim-right": { 4004 | "version": "1.0.1", 4005 | "resolved": "https://registry.npmjs.org/trim-right/-/trim-right-1.0.1.tgz", 4006 | "integrity": "sha1-yy4SAwZ+DI3h9hQJS5/kVwTqYAM=", 4007 | "dev": true 4008 | }, 4009 | "tryit": { 4010 | "version": "1.0.3", 4011 | "resolved": "https://registry.npmjs.org/tryit/-/tryit-1.0.3.tgz", 4012 | "integrity": "sha1-OTvnMKlEb9Hq1tpZoBQwjzbCics=", 4013 | "dev": true 4014 | }, 4015 | "type-check": { 4016 | "version": "0.3.2", 4017 | "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.3.2.tgz", 4018 | "integrity": "sha1-WITKtRLPHTVeP7eE8wgEsrUg23I=", 4019 | "dev": true, 4020 | "requires": { 4021 | "prelude-ls": "1.1.2" 4022 | } 4023 | }, 4024 | "typedarray": { 4025 | "version": "0.0.6", 4026 | "resolved": "https://registry.npmjs.org/typedarray/-/typedarray-0.0.6.tgz", 4027 | "integrity": "sha1-hnrHTjhkGHsdPUfZlqeOxciDB3c=", 4028 | "dev": true 4029 | }, 4030 | "ua-parser-js": { 4031 | "version": "0.7.17", 4032 | "resolved": "https://registry.npmjs.org/ua-parser-js/-/ua-parser-js-0.7.17.tgz", 4033 | "integrity": "sha512-uRdSdu1oA1rncCQL7sCj8vSyZkgtL7faaw9Tc9rZ3mGgraQ7+Pdx7w5mnOSF3gw9ZNG6oc+KXfkon3bKuROm0g==" 4034 | }, 4035 | "uglify-js": { 4036 | "version": "3.1.6", 4037 | "resolved": "https://registry.npmjs.org/uglify-js/-/uglify-js-3.1.6.tgz", 4038 | "integrity": "sha512-/rseyxEKEVMBo8279lqpoJgD6C/i/CIi+9TJDvWmb+Xo6mqMKwjA8Io3IMHlcXQzj99feR6zrN8m3wqqvm/nYA==", 4039 | "dev": true, 4040 | "requires": { 4041 | "commander": "2.11.0", 4042 | "source-map": "0.6.1" 4043 | }, 4044 | "dependencies": { 4045 | "source-map": { 4046 | "version": "0.6.1", 4047 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", 4048 | "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", 4049 | "dev": true 4050 | } 4051 | } 4052 | }, 4053 | "user-home": { 4054 | "version": "1.1.1", 4055 | "resolved": "https://registry.npmjs.org/user-home/-/user-home-1.1.1.tgz", 4056 | "integrity": "sha1-K1viOjK2Onyd640PKNSFcko98ZA=", 4057 | "dev": true 4058 | }, 4059 | "util-deprecate": { 4060 | "version": "1.0.2", 4061 | "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", 4062 | "integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8=", 4063 | "dev": true 4064 | }, 4065 | "uuid": { 4066 | "version": "3.1.0", 4067 | "resolved": "https://registry.npmjs.org/uuid/-/uuid-3.1.0.tgz", 4068 | "integrity": "sha512-DIWtzUkw04M4k3bf1IcpS2tngXEL26YUD2M0tMDUpnUrz2hgzUBlD55a4FjdLGPvfHxS6uluGWvaVEqgBcVa+g==", 4069 | "dev": true 4070 | }, 4071 | "v8flags": { 4072 | "version": "2.1.1", 4073 | "resolved": "https://registry.npmjs.org/v8flags/-/v8flags-2.1.1.tgz", 4074 | "integrity": "sha1-qrGh+jDUX4jdMhFIh1rALAtV5bQ=", 4075 | "dev": true, 4076 | "requires": { 4077 | "user-home": "1.1.1" 4078 | } 4079 | }, 4080 | "validate-npm-package-license": { 4081 | "version": "3.0.1", 4082 | "resolved": "https://registry.npmjs.org/validate-npm-package-license/-/validate-npm-package-license-3.0.1.tgz", 4083 | "integrity": "sha1-KAS6vnEq0zeUWaz74kdGqywwP7w=", 4084 | "dev": true, 4085 | "requires": { 4086 | "spdx-correct": "1.0.2", 4087 | "spdx-expression-parse": "1.0.4" 4088 | } 4089 | }, 4090 | "vlq": { 4091 | "version": "0.2.3", 4092 | "resolved": "https://registry.npmjs.org/vlq/-/vlq-0.2.3.tgz", 4093 | "integrity": "sha512-DRibZL6DsNhIgYQ+wNdWDL2SL3bKPlVrRiBqV5yuMm++op8W4kGFtaQfCs4KEJn0wBZcHVHJ3eoywX8983k1ow==", 4094 | "dev": true 4095 | }, 4096 | "whatwg-fetch": { 4097 | "version": "2.0.3", 4098 | "resolved": "https://registry.npmjs.org/whatwg-fetch/-/whatwg-fetch-2.0.3.tgz", 4099 | "integrity": "sha1-nITsLc9oGH/wC8ZOEnS0QhduHIQ=" 4100 | }, 4101 | "which": { 4102 | "version": "1.3.0", 4103 | "resolved": "https://registry.npmjs.org/which/-/which-1.3.0.tgz", 4104 | "integrity": "sha512-xcJpopdamTuY5duC/KnTTNBraPK54YwpenP4lzxU8H91GudWpFv38u0CKjclE1Wi2EH2EDz5LRcHcKbCIzqGyg==", 4105 | "dev": true, 4106 | "requires": { 4107 | "isexe": "2.0.0" 4108 | } 4109 | }, 4110 | "wordwrap": { 4111 | "version": "1.0.0", 4112 | "resolved": "https://registry.npmjs.org/wordwrap/-/wordwrap-1.0.0.tgz", 4113 | "integrity": "sha1-J1hIEIkUVqQXHI0CJkQa3pDLyus=", 4114 | "dev": true 4115 | }, 4116 | "wrappy": { 4117 | "version": "1.0.2", 4118 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 4119 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=", 4120 | "dev": true 4121 | }, 4122 | "write": { 4123 | "version": "0.2.1", 4124 | "resolved": "https://registry.npmjs.org/write/-/write-0.2.1.tgz", 4125 | "integrity": "sha1-X8A4KOJkzqP+kUVUdvejxWbLB1c=", 4126 | "dev": true, 4127 | "requires": { 4128 | "mkdirp": "0.5.1" 4129 | } 4130 | }, 4131 | "yallist": { 4132 | "version": "2.1.2", 4133 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-2.1.2.tgz", 4134 | "integrity": "sha1-HBH5IY8HYImkfdUS+TxmmaaoHVI=", 4135 | "dev": true 4136 | }, 4137 | "zen-observable": { 4138 | "version": "0.6.0", 4139 | "resolved": "https://registry.npmjs.org/zen-observable/-/zen-observable-0.6.0.tgz", 4140 | "integrity": "sha512-G5v4eFZ1+qJC9U3iyldcc7OLsYfFf6/+/vywU3acbq0qq1PdFXsyfqtOUaQSTwhdbejO7AQWil3GzHxYlMchIg==", 4141 | "dev": true 4142 | } 4143 | } 4144 | } 4145 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "react-blips", 3 | "version": "0.14.1", 4 | "description": "Official React bindings for Blips", 5 | "repository": { 6 | "type": "git", 7 | "url": "git+https://github.com/monojack/react-blips.git" 8 | }, 9 | "keywords": [ 10 | "react", 11 | "reactjs", 12 | "blips", 13 | "graphql", 14 | "local", 15 | "store", 16 | "state", 17 | "immutable" 18 | ], 19 | "author": "Ionut Achim ", 20 | "main": "./lib/index.js", 21 | "module": "es/index.js", 22 | "jsnext:main": "es/index.js", 23 | "dependencies": { 24 | "hoist-non-react-statics": "2.3.1", 25 | "invariant": "2.2.2", 26 | "loose-envify": "1.3.1", 27 | "prop-types": "15.6.0" 28 | }, 29 | "devDependencies": { 30 | "babel-cli": "6.26.0", 31 | "babel-eslint": "8.0.1", 32 | "babel-plugin-external-helpers": "6.22.0", 33 | "babel-plugin-transform-async-generator-functions": "6.24.1", 34 | "babel-plugin-transform-class-properties": "6.24.1", 35 | "babel-plugin-transform-es2015-modules-commonjs": "6.26.0", 36 | "babel-plugin-transform-object-rest-spread": "6.26.0", 37 | "babel-preset-env": "1.6.1", 38 | "babel-preset-es2015": "6.24.1", 39 | "babel-preset-react": "6.24.1", 40 | "babel-preset-stage-0": "6.24.1", 41 | "blips": "1.0.0-rc4", 42 | "cross-env": "5.1.0", 43 | "eslint": "4.9.0", 44 | "eslint-config-standard": "10.2.1", 45 | "eslint-plugin-import": "2.8.0", 46 | "eslint-plugin-node": "5.2.0", 47 | "eslint-plugin-promise": "3.6.0", 48 | "eslint-plugin-react": "^7.4.0", 49 | "eslint-plugin-standard": "3.0.1", 50 | "graphql": "0.11.7", 51 | "react": "16.0.0", 52 | "rimraf": "2.6.2", 53 | "rollup": "0.50.0", 54 | "rollup-analyzer-plugin": "1.1.1", 55 | "rollup-plugin-babel": "3.0.2", 56 | "rollup-plugin-commonjs": "8.2.3", 57 | "rollup-plugin-node-resolve": "3.0.0", 58 | "rollup-plugin-replace": "2.0.0", 59 | "rollup-plugin-uglify": "2.0.1" 60 | }, 61 | "license": "MIT", 62 | "bugs": { 63 | "url": "https://github.com/monojack/react-blips/issues" 64 | }, 65 | "homepage": "https://github.com/monojack/react-blips", 66 | "peerDependencies": { 67 | "react": "^15.4.0 || ^16.0.0-0", 68 | "graphql": "^0.11.7", 69 | "blips": "^0.11.0 || ^1.0.0* || ^1.0.0 " 70 | }, 71 | "scripts": { 72 | "build:cjs": "cross-env BABEL_ENV=cjs babel src --out-dir lib", 73 | "build:es": "cross-env BABEL_ENV=es babel src --out-dir es", 74 | "build:umd": "cross-env BABEL_ENV=rollup NODE_ENV=development rollup -c -o dist/react-blips.js", 75 | "build:umd:min": "cross-env BABEL_ENV=rollup NODE_ENV=production rollup -c -o dist/react-blips.min.js", 76 | "build": "npm run build:cjs && npm run build:es && npm run build:umd && npm run build:umd:min", 77 | "prepare": "npm run clean && npm run build", 78 | "lint": "eslint src", 79 | "clean": "rimraf lib dist es", 80 | "dev": "npm run build:es -- -w" 81 | }, 82 | "browserify": { 83 | "transform": [ 84 | "loose-envify" 85 | ] 86 | }, 87 | "files": [ 88 | "dist", 89 | "lib", 90 | "es", 91 | "src" 92 | ] 93 | } 94 | -------------------------------------------------------------------------------- /rollup.config.js: -------------------------------------------------------------------------------- 1 | import resolve from 'rollup-plugin-node-resolve' 2 | import commonjs from 'rollup-plugin-commonjs' 3 | import babel from 'rollup-plugin-babel' 4 | import replace from 'rollup-plugin-replace' 5 | import uglify from 'rollup-plugin-uglify' 6 | import analyze from 'rollup-analyzer-plugin' 7 | 8 | const opts = { limit: 5, filter: [], root: __dirname, } 9 | 10 | const env = process.env.NODE_ENV 11 | 12 | const config = { 13 | input: 'src/index.js', 14 | external: [ 'react', 'blips', 'graphql', ], 15 | globals: { 16 | react: 'React', 17 | blips: 'blips', 18 | graphql: 'graphql', 19 | }, 20 | output: { 21 | format: 'umd', 22 | }, 23 | name: 'blips', 24 | sourcemap: true, 25 | plugins: [ 26 | resolve(), 27 | babel({ 28 | exclude: '**/node_modules/**', 29 | }), 30 | replace({ 31 | 'process.env.NODE_ENV': JSON.stringify(env), 32 | }), 33 | commonjs(), 34 | analyze(opts), 35 | ], 36 | } 37 | 38 | if (env === 'production') { 39 | config.plugins.push( 40 | uglify({ 41 | compress: { 42 | pure_getters: true, 43 | unsafe: true, 44 | unsafe_comps: true, 45 | warnings: false, 46 | }, 47 | }) 48 | ) 49 | } 50 | 51 | export default config 52 | -------------------------------------------------------------------------------- /src/components/Provider.js: -------------------------------------------------------------------------------- 1 | import { Component, Children, } from 'react' 2 | import { GraphQLDirective, DirectiveLocation, } from 'graphql' 3 | import PropTypes from 'prop-types' 4 | 5 | export default class Provider extends Component { 6 | static propTypes = { 7 | client: PropTypes.shape({ 8 | state: PropTypes.object.isRequired, 9 | schema: PropTypes.object.isRequired, 10 | query: PropTypes.func.isRequired, 11 | mutate: PropTypes.func.isRequired, 12 | subscribe: PropTypes.func.isRequired, 13 | fetch: PropTypes.func.isRequired, 14 | }).isRequired, 15 | children: PropTypes.element.isRequired, 16 | } 17 | 18 | static childContextTypes = { 19 | client: PropTypes.object.isRequired, 20 | } 21 | 22 | getChildContext () { 23 | return { client: this.client, } 24 | } 25 | 26 | constructor (props, context) { 27 | super(props, context) 28 | this.client = props.client 29 | 30 | const apiDirective = new GraphQLDirective({ 31 | name: 'api', 32 | description: 33 | 'Sends this operation to a real GraphQL server for execution', 34 | locations: [ 35 | DirectiveLocation.QUERY, 36 | DirectiveLocation.MUTATION, 37 | DirectiveLocation.SUBSCRIPTION, 38 | ], 39 | }) 40 | 41 | this.client.schema._directives.push(apiDirective) 42 | } 43 | 44 | render () { 45 | return Children.only(this.props.children) 46 | } 47 | } 48 | -------------------------------------------------------------------------------- /src/components/createGraphQLHoc.js: -------------------------------------------------------------------------------- 1 | import React, { Component, } from 'react' 2 | import PropTypes from 'prop-types' 3 | import { parse, } from 'graphql' 4 | 5 | import hoistNonReactStatics from 'hoist-non-react-statics' 6 | import invariant from 'invariant' 7 | 8 | import { 9 | shallowEqual, 10 | getPropNameOr, 11 | computeNextState, 12 | mapObject, 13 | operationsMap, 14 | mergeOperations, 15 | convertSubscriptionToQuery, 16 | } from '../utils' 17 | 18 | export function createGraphQLHoc (sources, config) { 19 | const dataKey = getPropNameOr('data')(config) 20 | const mutationsKey = getPropNameOr('mutations')(config) 21 | const queriesKey = getPropNameOr('queries')(config) 22 | 23 | const promiseRegistry = [] 24 | const registerPromise = promiseRegistry.push.bind(promiseRegistry) 25 | const clearPromiseRegistry = () => (promiseRegistry.length = 0) 26 | 27 | const subscriptionRegistry = [] 28 | const registerSubscription = subscriptionRegistry.push.bind( 29 | subscriptionRegistry 30 | ) 31 | const clearSubscriptionRegistry = () => (subscriptionRegistry.length = 0) 32 | const cancelSubscriptions = () => { 33 | for (const subscription of subscriptionRegistry) { 34 | subscription.unsubscribe() 35 | } 36 | } 37 | 38 | const updateBatch = [] 39 | 40 | const computeOptions = props => 41 | config.options && typeof config.options === 'function' 42 | ? config.options(props) 43 | : config.options || {} 44 | 45 | return function createGraphQLHoc (BaseComponent) { 46 | invariant( 47 | typeof BaseComponent === 'function', 48 | `You must pass a component to the function returned by graphql. Instead received ${JSON.stringify( 49 | BaseComponent 50 | )}` 51 | ) 52 | 53 | class Blips extends Component { 54 | static displayName = `Blips(${BaseComponent.displayName || 55 | BaseComponent.name || 56 | 'Component'})` 57 | 58 | static WrappedComponent = BaseComponent 59 | 60 | static contextTypes = { 61 | client: PropTypes.object.isRequired, 62 | } 63 | 64 | constructor (props, context) { 65 | super(props, context) 66 | 67 | this.client = context.client 68 | this.options = computeOptions(props) 69 | this.parsedData = this.parse(sources) 70 | } 71 | 72 | state = { 73 | [dataKey]: { 74 | loading: true, 75 | }, 76 | } 77 | 78 | componentWillMount () { 79 | this.resolve() 80 | } 81 | 82 | componentWillReceiveProps (nextProps) { 83 | const nextOptions = computeOptions(nextProps) 84 | 85 | if (shallowEqual(this.options, nextOptions)) return 86 | 87 | this.options = { ...nextOptions, } 88 | 89 | cancelSubscriptions() 90 | clearSubscriptionRegistry() 91 | clearPromiseRegistry() 92 | 93 | this.cancelResolve() 94 | this.resolve() 95 | } 96 | 97 | cancelResolve = () => {} 98 | 99 | batchUpdateState = (list = updateBatch, state = this.state, force) => { 100 | if (list.length === 0 && !force) return 101 | this.setState( 102 | computeNextState( 103 | list, 104 | { 105 | dataKey, 106 | queriesKey, 107 | mutationsKey, 108 | }, 109 | state 110 | ) 111 | ) 112 | updateBatch.length = 0 113 | } 114 | 115 | parse = sources => { 116 | const documents = sources.map(parse) 117 | const operations = documents 118 | .map(operationsMap) 119 | .reduce(mergeOperations, {}) 120 | 121 | return { 122 | sources, 123 | documents, 124 | operations, 125 | } 126 | } 127 | 128 | resolve = () => { 129 | let cancel = false 130 | const { 131 | operations: { 132 | query: queries = {}, 133 | mutation: mutations = {}, 134 | subscription: subscriptions = {}, 135 | fetch: fetches = {}, 136 | }, 137 | } = this.parsedData 138 | 139 | for (const subscription of Object.values(subscriptions)) { 140 | this.subscribe(subscription)(this.options) 141 | registerPromise( 142 | this.query(convertSubscriptionToQuery(subscription))(this.options) 143 | ) 144 | } 145 | 146 | for (const query of Object.values(queries)) { 147 | registerPromise(this.query(query)(this.options)) 148 | } 149 | 150 | for (const fetch of Object.values(fetches)) { 151 | registerPromise(this.fetch(fetch)(this.options)) 152 | } 153 | 154 | registerPromise( 155 | Promise.resolve({ 156 | [queriesKey]: { 157 | ...mapObject(this.query)(queries), 158 | ...mapObject(this.fetch)(fetches), 159 | }, 160 | [mutationsKey]: mapObject(this.mutate)(mutations), 161 | }) 162 | ) 163 | 164 | Promise.all(promiseRegistry).then(res => { 165 | !cancel && 166 | this.batchUpdateState(res, { [dataKey]: { loading: false, }, }, true) 167 | }) 168 | 169 | this.cancelResolve = () => (cancel = true) 170 | } 171 | 172 | query = document => (options = this.options) => { 173 | return this.client.query(document, options) 174 | } 175 | 176 | mutate = document => (options = this.options) => { 177 | return this.client.mutate(document, options) 178 | } 179 | 180 | fetch = document => (options = this.options) => { 181 | return this.client.fetch(document, options) 182 | } 183 | 184 | subscribe = document => async (options = this.options) => { 185 | const observable = await this.client.subscribe(document, options) 186 | 187 | registerSubscription( 188 | observable.subscribe(res => { 189 | updateBatch.push(res) 190 | process.nextTick(this.batchUpdateState) 191 | }) 192 | ) 193 | } 194 | 195 | render () { 196 | const props = Object.entries(this.state).reduce( 197 | (acc, [ key, value, ]) => ({ 198 | ...acc, 199 | [key]: { 200 | ...(acc[key] || {}), 201 | ...value, 202 | }, 203 | }), 204 | this.props 205 | ) 206 | 207 | return 208 | } 209 | } 210 | 211 | return hoistNonReactStatics(Blips, BaseComponent, {}) 212 | } 213 | } 214 | -------------------------------------------------------------------------------- /src/components/createWithClientHoc.js: -------------------------------------------------------------------------------- 1 | import React, { Component, } from 'react' 2 | import PropTypes from 'prop-types' 3 | 4 | import hoistNonReactStatics from 'hoist-non-react-statics' 5 | import invariant from 'invariant' 6 | 7 | export function createWithClientHoc (BaseComponent) { 8 | invariant( 9 | typeof BaseComponent === 'function', 10 | `You must pass a component to the function returned by graphql. Instead received ${JSON.stringify( 11 | BaseComponent 12 | )}` 13 | ) 14 | 15 | class WithClient extends Component { 16 | static displayName = `withClient(${BaseComponent.displayName || 17 | BaseComponent.name || 18 | 'Component'})` 19 | 20 | static WrappedComponent = BaseComponent 21 | 22 | static propTypes = { 23 | client: PropTypes.object, 24 | } 25 | 26 | static contextTypes = { 27 | client: PropTypes.object.isRequired, 28 | } 29 | 30 | constructor (props, context) { 31 | super(props, context) 32 | 33 | this.client = props.client || context.client 34 | } 35 | 36 | componentWillReceiveProps (nextProps) { 37 | if (nextProps.client && nextProps.client !== this.client) { 38 | this.client = nextProps.client 39 | } 40 | } 41 | 42 | render () { 43 | return 44 | } 45 | } 46 | 47 | return hoistNonReactStatics(WithClient, BaseComponent, {}) 48 | } 49 | -------------------------------------------------------------------------------- /src/components/createWithOperationsHoc.js: -------------------------------------------------------------------------------- 1 | import React, { Component, } from 'react' 2 | import PropTypes from 'prop-types' 3 | import { parse, } from 'graphql' 4 | 5 | import hoistNonReactStatics from 'hoist-non-react-statics' 6 | import invariant from 'invariant' 7 | 8 | import { 9 | shallowEqual, 10 | getPropNameOr, 11 | operationsMap, 12 | mapObject, 13 | mergeOperations, 14 | isEmpty, 15 | isNil, 16 | } from '../utils' 17 | 18 | export function createWithOperationsHoc (sources, config) { 19 | const mutationsKey = getPropNameOr('mutations')(config) 20 | const queriesKey = getPropNameOr('queries')(config) 21 | 22 | const computeOptions = props => 23 | config.options && typeof config.options === 'function' 24 | ? config.options(props) 25 | : config.options || {} 26 | 27 | return function withOperations (BaseComponent) { 28 | invariant( 29 | typeof BaseComponent === 'function', 30 | `You must pass a component to the function returned by blips. Instead received ${JSON.stringify( 31 | BaseComponent 32 | )}` 33 | ) 34 | 35 | class WithOperations extends Component { 36 | static displayName = `withOperations(${BaseComponent.displayName || 37 | BaseComponent.name || 38 | 'Component'})` 39 | 40 | static WrappedComponent = BaseComponent 41 | 42 | static contextTypes = { 43 | client: PropTypes.object.isRequired, 44 | } 45 | 46 | constructor (props, context) { 47 | super(props, context) 48 | 49 | this.client = context.client 50 | this.options = computeOptions(props) 51 | this.parsedData = this.parse(sources) 52 | } 53 | 54 | componentWillMount () { 55 | this.resolve() 56 | } 57 | 58 | componentWillReceiveProps (nextProps) { 59 | const nextOptions = computeOptions(nextProps) 60 | 61 | if (shallowEqual(this.options, nextOptions)) return 62 | 63 | this.options = { ...nextOptions, } 64 | 65 | this.resolve() 66 | } 67 | 68 | parse = sources => { 69 | const documents = sources.map(parse) 70 | const operations = documents 71 | .map(operationsMap) 72 | .reduce(mergeOperations, {}) 73 | 74 | return { 75 | sources, 76 | documents, 77 | operations, 78 | } 79 | } 80 | 81 | resolve = () => { 82 | const { 83 | operations: { 84 | query: queries = {}, 85 | mutation: mutations = {}, 86 | fetch: fetches = {}, 87 | }, 88 | } = this.parsedData 89 | this.operations = { 90 | [queriesKey]: { 91 | ...mapObject(this.query)(queries), 92 | ...mapObject(this.fetch)(fetches), 93 | }, 94 | [mutationsKey]: mapObject(this.mutate)(mutations), 95 | } 96 | } 97 | 98 | query = document => (options = this.options) => { 99 | return this.client.query(document, options) 100 | } 101 | 102 | mutate = document => (options = this.options) => { 103 | return this.client.mutate(document, options) 104 | } 105 | 106 | fetch = document => (options = this.options) => { 107 | return this.client.fetch(document, options) 108 | } 109 | 110 | render () { 111 | const props = Object.entries(this.operations).reduce( 112 | (acc, [ key, value, ]) => { 113 | if (isEmpty(value) || isNil(value)) return acc 114 | return { 115 | ...acc, 116 | [key]: { 117 | ...(acc[key] || {}), 118 | ...value, 119 | }, 120 | } 121 | }, 122 | this.props 123 | ) 124 | 125 | return 126 | } 127 | } 128 | 129 | return hoistNonReactStatics(WithOperations, BaseComponent, {}) 130 | } 131 | } 132 | -------------------------------------------------------------------------------- /src/components/graphql.js: -------------------------------------------------------------------------------- 1 | import { createGraphQLHoc, } from './createGraphQLHoc' 2 | 3 | export default (...args) => { 4 | let config = {} 5 | 6 | if (typeof args[args.length - 1] === 'object') { 7 | config = args.pop() 8 | } 9 | const sources = [ ...args, ] 10 | 11 | return createGraphQLHoc(sources, config) 12 | } 13 | -------------------------------------------------------------------------------- /src/components/withClient.js: -------------------------------------------------------------------------------- 1 | import { createWithClientHoc, } from './createWithClientHoc' 2 | 3 | export default createWithClientHoc 4 | -------------------------------------------------------------------------------- /src/components/withOperations.js: -------------------------------------------------------------------------------- 1 | import { createWithOperationsHoc, } from './createWithOperationsHoc' 2 | 3 | export default (...args) => { 4 | let config = {} 5 | 6 | if (typeof args[args.length - 1] === 'object') { 7 | config = args.pop() 8 | } 9 | const sources = [ ...args, ] 10 | 11 | return createWithOperationsHoc(sources, config) 12 | } 13 | -------------------------------------------------------------------------------- /src/index.js: -------------------------------------------------------------------------------- 1 | export { default as graphql, } from './components/graphql' 2 | export { default as withClient, } from './components/withClient' 3 | export { default as withOperations, } from './components/withOperations' 4 | export { default as Provider, } from './components/Provider' 5 | export { compose, } from './utils/compose' 6 | -------------------------------------------------------------------------------- /src/utils/compose.js: -------------------------------------------------------------------------------- 1 | // https://github.com/acdlite/recompose/tree/master/src/packages/recompose 2 | 3 | export function compose (...funcs) { 4 | if (funcs.length === 0) { 5 | return arg => arg 6 | } 7 | 8 | if (funcs.length === 1) { 9 | return funcs[0] 10 | } 11 | 12 | return funcs.reduce((a, b) => (...args) => a(b(...args))) 13 | } 14 | -------------------------------------------------------------------------------- /src/utils/computeNextState.js: -------------------------------------------------------------------------------- 1 | import { isNil, } from './isNil' 2 | import { when, } from './when' 3 | import { isEmpty, } from './isEmpty' 4 | import { omit, } from './omit' 5 | import { removeEmptyOrNilProps, } from './removeEmptyOrNilProps' 6 | 7 | import { mergeErrors, } from './mergeErrors' 8 | 9 | export function computeNextState ( 10 | list, 11 | { dataKey, queriesKey, mutationsKey, }, 12 | base = {} 13 | ) { 14 | let errorsObject = {} 15 | 16 | let update = list.reduce((acc, { errors, data, ...res }) => { 17 | errors && (errorsObject = mergeErrors(errors)(errorsObject)) 18 | return { 19 | ...acc, 20 | [dataKey]: { 21 | ...(acc[dataKey] || {}), 22 | ...when(isNil, {}, data), 23 | }, 24 | [mutationsKey]: { 25 | ...(acc[mutationsKey] || {}), 26 | ...when(isNil, {}, res[mutationsKey]), 27 | }, 28 | [queriesKey]: { 29 | ...(acc[queriesKey] || {}), 30 | ...when(isNil, {}, res[queriesKey]), 31 | }, 32 | } 33 | }, base) 34 | 35 | if (!isEmpty(errorsObject)) { 36 | update[dataKey] = omit(Object.keys(errorsObject), update[dataKey]) 37 | update[dataKey]['errors'] = errorsObject 38 | } 39 | 40 | return removeEmptyOrNilProps(update) 41 | } 42 | -------------------------------------------------------------------------------- /src/utils/convertSubscriptionToQuery.js: -------------------------------------------------------------------------------- 1 | import { visit, } from 'graphql' 2 | 3 | export function convertSubscriptionToQuery (ast) { 4 | return visit(ast, { 5 | leave (node, key, parent, path, ancestors) { 6 | return node.kind === 'OperationDefinition' && 7 | node.operation === 'subscription' 8 | ? { 9 | ...node, 10 | operation: 'query', 11 | name: { 12 | ...node.name, 13 | value: (node.name.value || '').replace('Subscription', 'Query'), 14 | }, 15 | } 16 | : node 17 | }, 18 | }) 19 | } 20 | -------------------------------------------------------------------------------- /src/utils/createDocumentAST.js: -------------------------------------------------------------------------------- 1 | import { Kind, } from 'graphql' 2 | 3 | export function createDocumentAST (ast) { 4 | if (!ast || ast.kind === Kind.DOCUMENT) { 5 | return ast 6 | } 7 | 8 | return { 9 | kind: 'Document', 10 | definitions: [ ast, ], 11 | } 12 | } 13 | -------------------------------------------------------------------------------- /src/utils/getOperationName.js: -------------------------------------------------------------------------------- 1 | export function getOperationName ({ name: { value, }, } = {}) { 2 | return value 3 | } 4 | -------------------------------------------------------------------------------- /src/utils/getOperationType.js: -------------------------------------------------------------------------------- 1 | export function getOperationType ({ operation, } = {}) { 2 | return operation 3 | } 4 | -------------------------------------------------------------------------------- /src/utils/getPropNameOr.js: -------------------------------------------------------------------------------- 1 | import { isNil, } from './isNil' 2 | 3 | export function getPropNameOr (key) { 4 | return config => { 5 | let name = key 6 | 7 | if (!isNil(config.name)) { 8 | if (typeof config.name === 'object') { 9 | name = config.name[key] || key 10 | } else if (typeof config.name === 'string') { 11 | name = key === 'data' ? config.name : key 12 | } 13 | } 14 | 15 | return name 16 | } 17 | } 18 | -------------------------------------------------------------------------------- /src/utils/getRequiredFragments.js: -------------------------------------------------------------------------------- 1 | import { visit, Kind, } from 'graphql' 2 | 3 | export function getRequiredFragments (ast) { 4 | const fragments = [] 5 | 6 | visit(ast, { 7 | leave ({ kind, name: { value, } = {}, }) { 8 | kind === Kind.FRAGMENT_SPREAD && fragments.push(value) 9 | }, 10 | }) 11 | 12 | return fragments 13 | } 14 | -------------------------------------------------------------------------------- /src/utils/hasDirectives.js: -------------------------------------------------------------------------------- 1 | export function hasDirectives (names, node) { 2 | return node.directives.some(({ name: { value, }, }) => names.includes(value)) 3 | } 4 | -------------------------------------------------------------------------------- /src/utils/index.js: -------------------------------------------------------------------------------- 1 | export { shallowEqual, } from './shallowEqual' 2 | export { getPropNameOr, } from './getPropNameOr' 3 | export { mapObject, } from './mapObject' 4 | export { mergeErrors, } from './mergeErrors' 5 | export { convertSubscriptionToQuery, } from './convertSubscriptionToQuery' 6 | export { computeNextState, } from './computeNextState' 7 | export { createDocumentAST, } from './createDocumentAST' 8 | export { hasDirectives, } from './hasDirectives' 9 | export { rejectDirectives, } from './rejectDirectives' 10 | export { isOperationDefinition, } from './isOperationDefinition' 11 | export { isFragmentDefinition, } from './isFragmentDefinition' 12 | export { getOperationName, } from './getOperationName' 13 | export { getOperationType, } from './getOperationType' 14 | export { getRequiredFragments, } from './getRequiredFragments' 15 | export { operationsMap, } from './operationsMap' 16 | export { mergeOperations, } from './mergeOperations' 17 | export { isEmpty, } from './isEmpty' 18 | export { isNil, } from './isNil' 19 | -------------------------------------------------------------------------------- /src/utils/isEmpty.js: -------------------------------------------------------------------------------- 1 | export function isEmpty (value) { 2 | if (typeof value === 'string') { 3 | return value === '' 4 | } else if (typeof value === 'object') { 5 | if (value.hasOwnProperty('length')) { 6 | return !value.length 7 | } else if (value.hasOwnProperty('size')) { 8 | return !value.size 9 | } else { 10 | return !Object.keys(value).length 11 | } 12 | } else { 13 | return false 14 | } 15 | } 16 | -------------------------------------------------------------------------------- /src/utils/isFragmentDefinition.js: -------------------------------------------------------------------------------- 1 | import { Kind, } from 'graphql' 2 | 3 | export function isFragmentDefinition (definition) { 4 | return Boolean(definition.kind === Kind.FRAGMENT_DEFINITION) 5 | } 6 | -------------------------------------------------------------------------------- /src/utils/isNil.js: -------------------------------------------------------------------------------- 1 | export function isNil (value) { 2 | return value == null 3 | } 4 | -------------------------------------------------------------------------------- /src/utils/isOperationDefinition.js: -------------------------------------------------------------------------------- 1 | import { Kind, } from 'graphql' 2 | 3 | export function isOperationDefinition (definition) { 4 | return Boolean(definition.kind === Kind.OPERATION_DEFINITION) 5 | } 6 | -------------------------------------------------------------------------------- /src/utils/mapObject.js: -------------------------------------------------------------------------------- 1 | export function mapObject (transform) { 2 | return function (obj) { 3 | return Object.entries(obj).reduce( 4 | (acc, [ key, value, ]) => ({ 5 | ...acc, 6 | [key]: transform(value), 7 | }), 8 | {} 9 | ) 10 | } 11 | } 12 | -------------------------------------------------------------------------------- /src/utils/mergeErrors.js: -------------------------------------------------------------------------------- 1 | export function mergeErrors (errors) { 2 | return (object = {}) => { 3 | return Object.entries(errors).reduce((obj, [ type, err, ]) => { 4 | return { 5 | ...obj, 6 | [type]: [ ...(obj[type] || []), ...err, ], 7 | } 8 | }, object) 9 | } 10 | } 11 | -------------------------------------------------------------------------------- /src/utils/mergeOperations.js: -------------------------------------------------------------------------------- 1 | import { when, } from './when' 2 | import { isEmpty, } from './isEmpty' 3 | 4 | function mergeType (type) { 5 | return function (acc, curr) { 6 | const obj = { 7 | [type]: { 8 | ...(acc[type] || {}), 9 | ...(curr[type] || {}), 10 | }, 11 | } 12 | return when(isEmpty(obj[type]), {}, obj) 13 | } 14 | } 15 | 16 | export function mergeOperations (acc, curr) { 17 | const query = mergeType('query')(acc, curr) 18 | const mutation = mergeType('mutation')(acc, curr) 19 | const subscription = mergeType('subscription')(acc, curr) 20 | const fetch = mergeType('fetch')(acc, curr) 21 | return { 22 | ...acc, 23 | ...query, 24 | ...mutation, 25 | ...subscription, 26 | ...fetch, 27 | } 28 | } 29 | -------------------------------------------------------------------------------- /src/utils/omit.js: -------------------------------------------------------------------------------- 1 | // https://github.com/ramda/ramda/blob/master/source/omit.js 2 | export function omit (keys, obj) { 3 | const result = {} 4 | const index = {} 5 | const len = keys.length 6 | let idx = 0 7 | 8 | while (idx < len) { 9 | index[keys[idx]] = 1 10 | idx += 1 11 | } 12 | 13 | for (const prop in obj) { 14 | if (!index.hasOwnProperty(prop)) { 15 | result[prop] = obj[prop] 16 | } 17 | } 18 | return result 19 | } 20 | -------------------------------------------------------------------------------- /src/utils/operationsMap.js: -------------------------------------------------------------------------------- 1 | import { concatAST, } from 'graphql' 2 | import { createDocumentAST, } from './createDocumentAST' 3 | import { isOperationDefinition, } from './isOperationDefinition' 4 | import { isFragmentDefinition, } from './isFragmentDefinition' 5 | import { getOperationName, } from './getOperationName' 6 | import { getOperationType, } from './getOperationType' 7 | import { getRequiredFragments, } from './getRequiredFragments' 8 | import { mapObject, } from './mapObject' 9 | import { isNil, } from './isNil' 10 | import { hasDirectives, } from './hasDirectives' 11 | import { rejectDirectives, } from './rejectDirectives' 12 | 13 | const operationsCache = new Map() 14 | 15 | function getExecutableOperation (fragments) { 16 | return function (def) { 17 | return concatAST([ 18 | createDocumentAST(def), 19 | ...getRequiredFragments(def).map(f => createDocumentAST(fragments[f])), 20 | ]) 21 | } 22 | } 23 | 24 | export function operationsMap (document) { 25 | let operations = operationsCache.get(document) 26 | if (!operations) { 27 | const { fragment, ...definitionsObject } = document.definitions.reduce( 28 | (acc, node) => { 29 | let sanitizedNode 30 | const [ key, name, ] = isOperationDefinition(node) 31 | ? hasDirectives([ 'fetch', ], node) 32 | ? ((sanitizedNode = { 33 | ...node, 34 | directives: rejectDirectives([ 'fetch', ], node), 35 | }), 36 | [ 'fetch', getOperationName(node), ]) 37 | : [ getOperationType(node), getOperationName(node), ] 38 | : isFragmentDefinition(node) 39 | ? [ 'fragment', getOperationName(node), ] 40 | : [ null, null, ] 41 | 42 | if (isNil(key) || isNil(name)) return acc 43 | 44 | return { 45 | ...acc, 46 | [key]: { 47 | ...(acc[key] || {}), 48 | [name]: sanitizedNode || node, 49 | }, 50 | } 51 | }, 52 | {} 53 | ) 54 | 55 | operations = mapObject(mapObject(getExecutableOperation(fragment)))( 56 | definitionsObject 57 | ) 58 | 59 | operationsCache.set(document, operations) 60 | } 61 | 62 | return operations 63 | } 64 | -------------------------------------------------------------------------------- /src/utils/rejectDirectives.js: -------------------------------------------------------------------------------- 1 | export function rejectDirectives (names, node) { 2 | return node.directives.filter(({ name: { value, }, }) => !names.includes(value)) 3 | } 4 | -------------------------------------------------------------------------------- /src/utils/removeEmptyOrNilProps.js: -------------------------------------------------------------------------------- 1 | import { isNil, } from './isNil' 2 | import { isEmpty, } from './isEmpty' 3 | 4 | export function removeEmptyOrNilProps (obj) { 5 | return Object.entries(obj).reduce((acc, [ key, value, ]) => { 6 | if (isEmpty(value) || isNil(value)) return acc 7 | return { 8 | ...acc, 9 | [key]: value, 10 | } 11 | }, {}) 12 | } 13 | -------------------------------------------------------------------------------- /src/utils/shallowEqual.js: -------------------------------------------------------------------------------- 1 | export function shallowEqual (objA, objB) { 2 | if (objA === objB) return true 3 | 4 | if ( 5 | typeof objA !== 'object' || 6 | objA === null || 7 | typeof objB !== 'object' || 8 | objB === null 9 | ) { return false } 10 | 11 | const keysA = Object.keys(objA) 12 | const keysB = Object.keys(objB) 13 | 14 | if (keysA.length !== keysB.length) return false 15 | 16 | for (let idx = 0; idx < keysA.length; idx++) { 17 | const key = keysA[idx] 18 | if (!objB.hasOwnProperty(key) || objA[key] !== objB[key]) return false 19 | } 20 | 21 | return true 22 | } 23 | -------------------------------------------------------------------------------- /src/utils/when.js: -------------------------------------------------------------------------------- 1 | export function when (condition, transform, data) { 2 | let bool = Boolean(condition) 3 | 4 | if (typeof condition === 'function') { 5 | bool = Boolean(condition(data)) 6 | } 7 | 8 | return bool 9 | ? typeof transform === 'function' ? transform(data) : transform 10 | : data 11 | } 12 | --------------------------------------------------------------------------------