├── .eslintrc.yml ├── .gitignore ├── .travis.yml ├── LICENSE ├── README.md ├── lib ├── gen-id.js └── index.js ├── package-lock.json ├── package.json ├── prettier.config.js └── test ├── .eslintrc.yml ├── expects ├── class.js └── object.js ├── fixtures ├── class.js └── object.js ├── jasmine.json └── specs └── index.spec.js /.eslintrc.yml: -------------------------------------------------------------------------------- 1 | --- 2 | extends: eslint-config-ktsn 3 | parserOptions: 4 | ecmaVersion: 8 5 | -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | node_modules/ 2 | -------------------------------------------------------------------------------- /.travis.yml: -------------------------------------------------------------------------------- 1 | language: node_js 2 | node_js: 3 | - "8" 4 | -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | Copyright (c) 2017 katashin 2 | 3 | Permission is hereby granted, free of charge, to any person obtaining a copy 4 | of this software and associated documentation files (the "Software"), to deal 5 | in the Software without restriction, including without limitation the rights 6 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 7 | copies of the Software, and to permit persons to whom the Software is 8 | furnished to do so, subject to the following conditions: 9 | 10 | The above copyright notice and this permission notice shall be included in 11 | all copies or substantial portions of the Software. 12 | 13 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 14 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 15 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 16 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 17 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 18 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN 19 | THE SOFTWARE. 20 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # vue-hot-reload-loader 2 | 3 | Enable hot module replacement (HMR) on your Vue components. 4 | 5 | This loader is for Vue components written in `.js` (or other non single file components format) file. If you are using `.vue` file, you don't need this loader because they already have HMR feature. 6 | 7 | ## Installation 8 | 9 | ```bash 10 | # NPM 11 | $ npm install --save-dev vue-hot-reload-loader 12 | 13 | # Yarn 14 | $ yarn add --dev vue-hot-reload-loader 15 | ``` 16 | 17 | ## Usage 18 | 19 | You need to update your webpack config to let webpack awere `vue-hot-reload-loader`. Note that you should carefuly set webpack's [rule condition](https://webpack.js.org/configuration/module/#rule-conditions) so that `vue-hot-reload-loader` is only used for actual component files. See [a discussion](https://github.com/ktsn/vue-hot-reload-loader/issues/6). 20 | 21 | ```js 22 | module.exports = { 23 | module: { 24 | rules: [ 25 | { 26 | test: /\.js/, 27 | use: ['vue-hot-reload-loader', 'buble-loader'], 28 | // If and only if all your components are in `path/to/components` directory 29 | include: path.resolve(__dirname, 'path/to/components') 30 | } 31 | ] 32 | } 33 | } 34 | ``` 35 | 36 | And you have to export each component as default export. 37 | 38 | ```js 39 | export default { 40 | data () { 41 | return { 42 | message: 'hi' 43 | } 44 | } 45 | } 46 | ``` 47 | 48 | ## License 49 | 50 | MIT 51 | -------------------------------------------------------------------------------- /lib/gen-id.js: -------------------------------------------------------------------------------- 1 | // borrowed from vue-loader 2 | const path = require('path') 3 | const hash = require('hash-sum') 4 | const cache = Object.create(null) 5 | const sepRE = new RegExp(path.sep.replace('\\', '\\\\'), 'g') 6 | 7 | module.exports = function genId(file, context) { 8 | const contextPath = context.split(path.sep) 9 | const rootId = contextPath[contextPath.length - 1] 10 | file = rootId + '/' + path.relative(context, file).replace(sepRE, '/') 11 | return cache[file] || (cache[file] = hash(file)) 12 | } 13 | -------------------------------------------------------------------------------- /lib/index.js: -------------------------------------------------------------------------------- 1 | const acorn = require('acorn') 2 | const estraverse = require('estraverse') 3 | const genCode = require('escodegen') 4 | const genId = require('./gen-id') 5 | 6 | const sourceMap = require('source-map') 7 | const SourceMapConsumer = sourceMap.SourceMapConsumer 8 | 9 | module.exports = async function(contents, sourcemap) { 10 | const id = genId(this.resourcePath, process.cwd()) 11 | let hasComponent = false 12 | 13 | const parseOptions = { sourceType: 'module', ecmaVersion: 9 } 14 | 15 | if (this.sourceMap) { 16 | parseOptions.locations = true 17 | parseOptions.sourceFile = this.resourcePath 18 | } 19 | 20 | const ast = acorn.parse(contents, parseOptions) 21 | 22 | const res = estraverse.replace(ast, { 23 | enter(node, parent) { 24 | if (node.type === 'ExportDefaultDeclaration') { 25 | hasComponent = true 26 | 27 | const component = node.declaration 28 | 29 | const componentId = { 30 | type: 'Identifier', 31 | name: '__component__' 32 | } 33 | 34 | node.declaration = componentId 35 | parent.body.push(node) 36 | 37 | return { 38 | type: 'VariableDeclaration', 39 | declarations: [ 40 | { 41 | type: 'VariableDeclarator', 42 | id: componentId, 43 | init: component 44 | } 45 | ], 46 | kind: 'var' 47 | } 48 | } 49 | } 50 | }) 51 | 52 | if (!hasComponent) { 53 | this.callback(null, contents, sourcemap) 54 | return 55 | } 56 | 57 | if (this.sourceMap) { 58 | const generatedContents = genCode.generate(res, { 59 | sourceMap: this.resourcePath, 60 | sourceMapWithCode: true, 61 | sourceContent: contents 62 | }) 63 | 64 | // apply the original sourcemap to the sourcemap generated by escodegen. 65 | const sourceMapGenerator = generatedContents.map 66 | 67 | if (sourcemap) { 68 | const originalSmc = await new SourceMapConsumer(sourcemap) 69 | sourceMapGenerator.applySourceMap(originalSmc) 70 | originalSmc.destroy() 71 | } 72 | 73 | const outSourcemap = sourceMapGenerator.toJSON() 74 | 75 | this.callback(null, generatedContents.code + genHotReload(id), outSourcemap) 76 | } else { 77 | const generatedContents = genCode.generate(res) 78 | 79 | this.callback(null, generatedContents + genHotReload(id)) 80 | } 81 | } 82 | 83 | function genHotReload(id) { 84 | return ` 85 | if (module.hot) {(function(options) { 86 | if (typeof options === 'function') { 87 | options = __component__.options 88 | } 89 | 90 | var api = require('vue-hot-reload-api') 91 | var Vue = require('vue') 92 | 93 | api.install(Vue) 94 | 95 | if (api.compatible) { 96 | module.hot.accept() 97 | if (!module.hot.data) { 98 | api.createRecord("${id}", options) 99 | } else { 100 | api.reload("${id}", options) 101 | } 102 | }})(__component__) 103 | }` 104 | } 105 | -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "vue-hot-reload-loader", 3 | "version": "0.2.0", 4 | "lockfileVersion": 1, 5 | "requires": true, 6 | "dependencies": { 7 | "@babel/code-frame": { 8 | "version": "7.0.0", 9 | "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.0.0.tgz", 10 | "integrity": "sha512-OfC2uemaknXr87bdLUkWog7nYuliM9Ij5HUcajsVcMCpQrcLmtxRbVFTIqmcSkSeYRBFBRxs2FiUqFJDLdiebA==", 11 | "dev": true, 12 | "requires": { 13 | "@babel/highlight": "^7.0.0" 14 | } 15 | }, 16 | "@babel/highlight": { 17 | "version": "7.0.0", 18 | "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.0.0.tgz", 19 | "integrity": "sha512-UFMC4ZeFC48Tpvj7C8UgLvtkaUuovQX+5xNWrsIoMG8o2z+XFKjKaN9iVmS84dPwVN00W4wPmqvYoZF3EGAsfw==", 20 | "dev": true, 21 | "requires": { 22 | "chalk": "^2.0.0", 23 | "esutils": "^2.0.2", 24 | "js-tokens": "^4.0.0" 25 | } 26 | }, 27 | "acorn": { 28 | "version": "6.0.1", 29 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-6.0.1.tgz", 30 | "integrity": "sha512-SiwgrRuRD2D1R6qjwwoopKcCTkmmIWjy1M15Wv+Nk/7VUsBad4P8GOPft2t6coDZG0TuR5dq9o1v0g8wo7F6+A==" 31 | }, 32 | "acorn-jsx": { 33 | "version": "4.1.1", 34 | "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-4.1.1.tgz", 35 | "integrity": "sha512-JY+iV6r+cO21KtntVvFkD+iqjtdpRUpGqKWgfkCdZq1R+kbreEl8EcdcJR4SmiIgsIQT33s6QzheQ9a275Q8xw==", 36 | "dev": true, 37 | "requires": { 38 | "acorn": "^5.0.3" 39 | }, 40 | "dependencies": { 41 | "acorn": { 42 | "version": "5.7.3", 43 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-5.7.3.tgz", 44 | "integrity": "sha512-T/zvzYRfbVojPWahDsE5evJdHb3oJoQfFbsrKM7w5Zcs++Tr257tia3BmMP8XYVjp1S9RZXQMh7gao96BlqZOw==", 45 | "dev": true 46 | } 47 | } 48 | }, 49 | "ajv": { 50 | "version": "6.5.3", 51 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.5.3.tgz", 52 | "integrity": "sha512-LqZ9wY+fx3UMiiPd741yB2pj3hhil+hQc8taf4o2QGRFpWgZ2V5C8HA165DY9sS3fJwsk7uT7ZlFEyC3Ig3lLg==", 53 | "dev": true, 54 | "requires": { 55 | "fast-deep-equal": "^2.0.1", 56 | "fast-json-stable-stringify": "^2.0.0", 57 | "json-schema-traverse": "^0.4.1", 58 | "uri-js": "^4.2.2" 59 | } 60 | }, 61 | "ajv-keywords": { 62 | "version": "3.2.0", 63 | "resolved": "https://registry.npmjs.org/ajv-keywords/-/ajv-keywords-3.2.0.tgz", 64 | "integrity": "sha1-6GuBnGAs+IIa1jdBNpjx3sAhhHo=", 65 | "dev": true 66 | }, 67 | "ansi-escapes": { 68 | "version": "3.1.0", 69 | "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-3.1.0.tgz", 70 | "integrity": "sha512-UgAb8H9D41AQnu/PbWlCofQVcnV4Gs2bBJi9eZPxfU/hgglFh3SMDMENRIqdr7H6XFnXdoknctFByVsCOotTVw==", 71 | "dev": true 72 | }, 73 | "ansi-regex": { 74 | "version": "3.0.0", 75 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-3.0.0.tgz", 76 | "integrity": "sha1-7QMXwyIGT3lGbAKWa922Bas32Zg=", 77 | "dev": true 78 | }, 79 | "ansi-styles": { 80 | "version": "3.2.1", 81 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 82 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 83 | "dev": true, 84 | "requires": { 85 | "color-convert": "^1.9.0" 86 | } 87 | }, 88 | "argparse": { 89 | "version": "1.0.10", 90 | "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.10.tgz", 91 | "integrity": "sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg==", 92 | "dev": true, 93 | "requires": { 94 | "sprintf-js": "~1.0.2" 95 | } 96 | }, 97 | "array-union": { 98 | "version": "1.0.2", 99 | "resolved": "https://registry.npmjs.org/array-union/-/array-union-1.0.2.tgz", 100 | "integrity": "sha1-mjRBDk9OPaI96jdb5b5w8kd47Dk=", 101 | "dev": true, 102 | "requires": { 103 | "array-uniq": "^1.0.1" 104 | } 105 | }, 106 | "array-uniq": { 107 | "version": "1.0.3", 108 | "resolved": "https://registry.npmjs.org/array-uniq/-/array-uniq-1.0.3.tgz", 109 | "integrity": "sha1-r2rId6Jcx/dOBYiUdThY39sk/bY=", 110 | "dev": true 111 | }, 112 | "arrify": { 113 | "version": "1.0.1", 114 | "resolved": "https://registry.npmjs.org/arrify/-/arrify-1.0.1.tgz", 115 | "integrity": "sha1-iYUI2iIm84DfkEcoRWhJwVAaSw0=", 116 | "dev": true 117 | }, 118 | "balanced-match": { 119 | "version": "1.0.0", 120 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz", 121 | "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=", 122 | "dev": true 123 | }, 124 | "brace-expansion": { 125 | "version": "1.1.11", 126 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 127 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 128 | "dev": true, 129 | "requires": { 130 | "balanced-match": "^1.0.0", 131 | "concat-map": "0.0.1" 132 | } 133 | }, 134 | "builtin-modules": { 135 | "version": "1.1.1", 136 | "resolved": "https://registry.npmjs.org/builtin-modules/-/builtin-modules-1.1.1.tgz", 137 | "integrity": "sha1-Jw8HbFpywC9bZaR9+Uxf46J4iS8=", 138 | "dev": true 139 | }, 140 | "caller-path": { 141 | "version": "0.1.0", 142 | "resolved": "https://registry.npmjs.org/caller-path/-/caller-path-0.1.0.tgz", 143 | "integrity": "sha1-lAhe9jWB7NPaqSREqP6U6CV3dR8=", 144 | "dev": true, 145 | "requires": { 146 | "callsites": "^0.2.0" 147 | } 148 | }, 149 | "callsites": { 150 | "version": "0.2.0", 151 | "resolved": "https://registry.npmjs.org/callsites/-/callsites-0.2.0.tgz", 152 | "integrity": "sha1-r6uWJikQp/M8GaV3WCXGnzTjUMo=", 153 | "dev": true 154 | }, 155 | "chalk": { 156 | "version": "2.4.1", 157 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.1.tgz", 158 | "integrity": "sha512-ObN6h1v2fTJSmUXoS3nMQ92LbDK9be4TV+6G+omQlGJFdcUX5heKi1LZ1YnRMIgwTLEj3E24bT6tYni50rlCfQ==", 159 | "dev": true, 160 | "requires": { 161 | "ansi-styles": "^3.2.1", 162 | "escape-string-regexp": "^1.0.5", 163 | "supports-color": "^5.3.0" 164 | } 165 | }, 166 | "chardet": { 167 | "version": "0.7.0", 168 | "resolved": "https://registry.npmjs.org/chardet/-/chardet-0.7.0.tgz", 169 | "integrity": "sha512-mT8iDcrh03qDGRRmoA2hmBJnxpllMR+0/0qlzjqZES6NdiWDcZkCNAk4rPFZ9Q85r27unkiNNg8ZOiwZXBHwcA==", 170 | "dev": true 171 | }, 172 | "circular-json": { 173 | "version": "0.3.3", 174 | "resolved": "https://registry.npmjs.org/circular-json/-/circular-json-0.3.3.tgz", 175 | "integrity": "sha512-UZK3NBx2Mca+b5LsG7bY183pHWt5Y1xts4P3Pz7ENTwGVnJOUWbRb3ocjvX7hx9tq/yTAdclXm9sZ38gNuem4A==", 176 | "dev": true 177 | }, 178 | "cli-cursor": { 179 | "version": "2.1.0", 180 | "resolved": "https://registry.npmjs.org/cli-cursor/-/cli-cursor-2.1.0.tgz", 181 | "integrity": "sha1-s12sN2R5+sw+lHR9QdDQ9SOP/LU=", 182 | "dev": true, 183 | "requires": { 184 | "restore-cursor": "^2.0.0" 185 | } 186 | }, 187 | "cli-width": { 188 | "version": "2.2.0", 189 | "resolved": "https://registry.npmjs.org/cli-width/-/cli-width-2.2.0.tgz", 190 | "integrity": "sha1-/xnt6Kml5XkyQUewwR8PvLq+1jk=", 191 | "dev": true 192 | }, 193 | "color-convert": { 194 | "version": "1.9.3", 195 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", 196 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", 197 | "dev": true, 198 | "requires": { 199 | "color-name": "1.1.3" 200 | } 201 | }, 202 | "color-name": { 203 | "version": "1.1.3", 204 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 205 | "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=", 206 | "dev": true 207 | }, 208 | "concat-map": { 209 | "version": "0.0.1", 210 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 211 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=", 212 | "dev": true 213 | }, 214 | "contains-path": { 215 | "version": "0.1.0", 216 | "resolved": "https://registry.npmjs.org/contains-path/-/contains-path-0.1.0.tgz", 217 | "integrity": "sha1-/ozxhP9mcLa67wGp1IYaXL7EEgo=", 218 | "dev": true 219 | }, 220 | "cross-spawn": { 221 | "version": "6.0.5", 222 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-6.0.5.tgz", 223 | "integrity": "sha512-eTVLrBSt7fjbDygz805pMnstIs2VTBNkRm0qxZd+M7A5XDdxVRWO5MxGBXZhjY4cqLYLdtrGqRf8mBPmzwSpWQ==", 224 | "dev": true, 225 | "requires": { 226 | "nice-try": "^1.0.4", 227 | "path-key": "^2.0.1", 228 | "semver": "^5.5.0", 229 | "shebang-command": "^1.2.0", 230 | "which": "^1.2.9" 231 | } 232 | }, 233 | "debug": { 234 | "version": "3.2.5", 235 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.5.tgz", 236 | "integrity": "sha512-D61LaDQPQkxJ5AUM2mbSJRbPkNs/TmdmOeLAi1hgDkpDfIfetSrjmWhccwtuResSwMbACjx/xXQofvM9CE/aeg==", 237 | "dev": true, 238 | "requires": { 239 | "ms": "^2.1.1" 240 | } 241 | }, 242 | "deep-is": { 243 | "version": "0.1.3", 244 | "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.3.tgz", 245 | "integrity": "sha1-s2nW+128E+7PUk+RsHD+7cNXzzQ=" 246 | }, 247 | "del": { 248 | "version": "2.2.2", 249 | "resolved": "https://registry.npmjs.org/del/-/del-2.2.2.tgz", 250 | "integrity": "sha1-wSyYHQZ4RshLyvhiz/kw2Qf/0ag=", 251 | "dev": true, 252 | "requires": { 253 | "globby": "^5.0.0", 254 | "is-path-cwd": "^1.0.0", 255 | "is-path-in-cwd": "^1.0.0", 256 | "object-assign": "^4.0.1", 257 | "pify": "^2.0.0", 258 | "pinkie-promise": "^2.0.0", 259 | "rimraf": "^2.2.8" 260 | } 261 | }, 262 | "doctrine": { 263 | "version": "2.1.0", 264 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-2.1.0.tgz", 265 | "integrity": "sha512-35mSku4ZXK0vfCuHEDAwt55dg2jNajHZ1odvF+8SSr82EsZY4QmXfuWso8oEd8zRhVObSN18aM0CjSdoBX7zIw==", 266 | "dev": true, 267 | "requires": { 268 | "esutils": "^2.0.2" 269 | } 270 | }, 271 | "error-ex": { 272 | "version": "1.3.2", 273 | "resolved": "https://registry.npmjs.org/error-ex/-/error-ex-1.3.2.tgz", 274 | "integrity": "sha512-7dFHNmqeFSEt2ZBsCriorKnn3Z2pj+fd9kmI6QoWw4//DL+icEBfc0U7qJCisqrTsKTjw4fNFy2pW9OqStD84g==", 275 | "dev": true, 276 | "requires": { 277 | "is-arrayish": "^0.2.1" 278 | } 279 | }, 280 | "escape-string-regexp": { 281 | "version": "1.0.5", 282 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", 283 | "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=", 284 | "dev": true 285 | }, 286 | "escodegen": { 287 | "version": "1.11.0", 288 | "resolved": "https://registry.npmjs.org/escodegen/-/escodegen-1.11.0.tgz", 289 | "integrity": "sha512-IeMV45ReixHS53K/OmfKAIztN/igDHzTJUhZM3k1jMhIZWjk45SMwAtBsEXiJp3vSPmTcu6CXn7mDvFHRN66fw==", 290 | "requires": { 291 | "esprima": "^3.1.3", 292 | "estraverse": "^4.2.0", 293 | "esutils": "^2.0.2", 294 | "optionator": "^0.8.1", 295 | "source-map": "~0.6.1" 296 | }, 297 | "dependencies": { 298 | "source-map": { 299 | "version": "0.6.1", 300 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", 301 | "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", 302 | "optional": true 303 | } 304 | } 305 | }, 306 | "eslint": { 307 | "version": "5.6.0", 308 | "resolved": "https://registry.npmjs.org/eslint/-/eslint-5.6.0.tgz", 309 | "integrity": "sha512-/eVYs9VVVboX286mBK7bbKnO1yamUy2UCRjiY6MryhQL2PaaXCExsCQ2aO83OeYRhU2eCU/FMFP+tVMoOrzNrA==", 310 | "dev": true, 311 | "requires": { 312 | "@babel/code-frame": "^7.0.0", 313 | "ajv": "^6.5.3", 314 | "chalk": "^2.1.0", 315 | "cross-spawn": "^6.0.5", 316 | "debug": "^3.1.0", 317 | "doctrine": "^2.1.0", 318 | "eslint-scope": "^4.0.0", 319 | "eslint-utils": "^1.3.1", 320 | "eslint-visitor-keys": "^1.0.0", 321 | "espree": "^4.0.0", 322 | "esquery": "^1.0.1", 323 | "esutils": "^2.0.2", 324 | "file-entry-cache": "^2.0.0", 325 | "functional-red-black-tree": "^1.0.1", 326 | "glob": "^7.1.2", 327 | "globals": "^11.7.0", 328 | "ignore": "^4.0.6", 329 | "imurmurhash": "^0.1.4", 330 | "inquirer": "^6.1.0", 331 | "is-resolvable": "^1.1.0", 332 | "js-yaml": "^3.12.0", 333 | "json-stable-stringify-without-jsonify": "^1.0.1", 334 | "levn": "^0.3.0", 335 | "lodash": "^4.17.5", 336 | "minimatch": "^3.0.4", 337 | "mkdirp": "^0.5.1", 338 | "natural-compare": "^1.4.0", 339 | "optionator": "^0.8.2", 340 | "path-is-inside": "^1.0.2", 341 | "pluralize": "^7.0.0", 342 | "progress": "^2.0.0", 343 | "regexpp": "^2.0.0", 344 | "require-uncached": "^1.0.3", 345 | "semver": "^5.5.1", 346 | "strip-ansi": "^4.0.0", 347 | "strip-json-comments": "^2.0.1", 348 | "table": "^4.0.3", 349 | "text-table": "^0.2.0" 350 | } 351 | }, 352 | "eslint-config-ktsn": { 353 | "version": "2.0.1", 354 | "resolved": "https://registry.npmjs.org/eslint-config-ktsn/-/eslint-config-ktsn-2.0.1.tgz", 355 | "integrity": "sha512-D6J4qw2fn2gaQE2cF6qhWkV4VhEJKhsr61apfnUM+GR+MfOE4zHdNDJI12zIy2bxzYpolf9TI3eX0HK3lZUpgw==", 356 | "dev": true, 357 | "requires": { 358 | "eslint-plugin-prettier": "^2.6.2" 359 | } 360 | }, 361 | "eslint-import-resolver-node": { 362 | "version": "0.3.2", 363 | "resolved": "https://registry.npmjs.org/eslint-import-resolver-node/-/eslint-import-resolver-node-0.3.2.tgz", 364 | "integrity": "sha512-sfmTqJfPSizWu4aymbPr4Iidp5yKm8yDkHp+Ir3YiTHiiDfxh69mOUsmiqW6RZ9zRXFaF64GtYmN7e+8GHBv6Q==", 365 | "dev": true, 366 | "requires": { 367 | "debug": "^2.6.9", 368 | "resolve": "^1.5.0" 369 | }, 370 | "dependencies": { 371 | "debug": { 372 | "version": "2.6.9", 373 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 374 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 375 | "dev": true, 376 | "requires": { 377 | "ms": "2.0.0" 378 | } 379 | }, 380 | "ms": { 381 | "version": "2.0.0", 382 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 383 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=", 384 | "dev": true 385 | } 386 | } 387 | }, 388 | "eslint-module-utils": { 389 | "version": "2.2.0", 390 | "resolved": "https://registry.npmjs.org/eslint-module-utils/-/eslint-module-utils-2.2.0.tgz", 391 | "integrity": "sha1-snA2LNiLGkitMIl2zn+lTphBF0Y=", 392 | "dev": true, 393 | "requires": { 394 | "debug": "^2.6.8", 395 | "pkg-dir": "^1.0.0" 396 | }, 397 | "dependencies": { 398 | "debug": { 399 | "version": "2.6.9", 400 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 401 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 402 | "dev": true, 403 | "requires": { 404 | "ms": "2.0.0" 405 | } 406 | }, 407 | "ms": { 408 | "version": "2.0.0", 409 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 410 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=", 411 | "dev": true 412 | } 413 | } 414 | }, 415 | "eslint-plugin-import": { 416 | "version": "2.14.0", 417 | "resolved": "https://registry.npmjs.org/eslint-plugin-import/-/eslint-plugin-import-2.14.0.tgz", 418 | "integrity": "sha512-FpuRtniD/AY6sXByma2Wr0TXvXJ4nA/2/04VPlfpmUDPOpOY264x+ILiwnrk/k4RINgDAyFZByxqPUbSQ5YE7g==", 419 | "dev": true, 420 | "requires": { 421 | "contains-path": "^0.1.0", 422 | "debug": "^2.6.8", 423 | "doctrine": "1.5.0", 424 | "eslint-import-resolver-node": "^0.3.1", 425 | "eslint-module-utils": "^2.2.0", 426 | "has": "^1.0.1", 427 | "lodash": "^4.17.4", 428 | "minimatch": "^3.0.3", 429 | "read-pkg-up": "^2.0.0", 430 | "resolve": "^1.6.0" 431 | }, 432 | "dependencies": { 433 | "debug": { 434 | "version": "2.6.9", 435 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 436 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 437 | "dev": true, 438 | "requires": { 439 | "ms": "2.0.0" 440 | } 441 | }, 442 | "doctrine": { 443 | "version": "1.5.0", 444 | "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-1.5.0.tgz", 445 | "integrity": "sha1-N53Ocw9hZvds76TmcHoVmwLFpvo=", 446 | "dev": true, 447 | "requires": { 448 | "esutils": "^2.0.2", 449 | "isarray": "^1.0.0" 450 | } 451 | }, 452 | "ms": { 453 | "version": "2.0.0", 454 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 455 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=", 456 | "dev": true 457 | } 458 | } 459 | }, 460 | "eslint-plugin-prettier": { 461 | "version": "2.6.2", 462 | "resolved": "https://registry.npmjs.org/eslint-plugin-prettier/-/eslint-plugin-prettier-2.6.2.tgz", 463 | "integrity": "sha512-tGek5clmW5swrAx1mdPYM8oThrBE83ePh7LeseZHBWfHVGrHPhKn7Y5zgRMbU/9D5Td9K4CEmUPjGxA7iw98Og==", 464 | "dev": true, 465 | "requires": { 466 | "fast-diff": "^1.1.1", 467 | "jest-docblock": "^21.0.0" 468 | } 469 | }, 470 | "eslint-scope": { 471 | "version": "4.0.0", 472 | "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-4.0.0.tgz", 473 | "integrity": "sha512-1G6UTDi7Jc1ELFwnR58HV4fK9OQK4S6N985f166xqXxpjU6plxFISJa2Ba9KCQuFa8RCnj/lSFJbHo7UFDBnUA==", 474 | "dev": true, 475 | "requires": { 476 | "esrecurse": "^4.1.0", 477 | "estraverse": "^4.1.1" 478 | } 479 | }, 480 | "eslint-utils": { 481 | "version": "1.3.1", 482 | "resolved": "https://registry.npmjs.org/eslint-utils/-/eslint-utils-1.3.1.tgz", 483 | "integrity": "sha512-Z7YjnIldX+2XMcjr7ZkgEsOj/bREONV60qYeB/bjMAqqqZ4zxKyWX+BOUkdmRmA9riiIPVvo5x86m5elviOk0Q==", 484 | "dev": true 485 | }, 486 | "eslint-visitor-keys": { 487 | "version": "1.0.0", 488 | "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-1.0.0.tgz", 489 | "integrity": "sha512-qzm/XxIbxm/FHyH341ZrbnMUpe+5Bocte9xkmFMzPMjRaZMcXww+MpBptFvtU+79L362nqiLhekCxCxDPaUMBQ==", 490 | "dev": true 491 | }, 492 | "espree": { 493 | "version": "4.0.0", 494 | "resolved": "https://registry.npmjs.org/espree/-/espree-4.0.0.tgz", 495 | "integrity": "sha512-kapdTCt1bjmspxStVKX6huolXVV5ZfyZguY1lcfhVVZstce3bqxH9mcLzNn3/mlgW6wQ732+0fuG9v7h0ZQoKg==", 496 | "dev": true, 497 | "requires": { 498 | "acorn": "^5.6.0", 499 | "acorn-jsx": "^4.1.1" 500 | }, 501 | "dependencies": { 502 | "acorn": { 503 | "version": "5.7.3", 504 | "resolved": "https://registry.npmjs.org/acorn/-/acorn-5.7.3.tgz", 505 | "integrity": "sha512-T/zvzYRfbVojPWahDsE5evJdHb3oJoQfFbsrKM7w5Zcs++Tr257tia3BmMP8XYVjp1S9RZXQMh7gao96BlqZOw==", 506 | "dev": true 507 | } 508 | } 509 | }, 510 | "esprima": { 511 | "version": "3.1.3", 512 | "resolved": "https://registry.npmjs.org/esprima/-/esprima-3.1.3.tgz", 513 | "integrity": "sha1-/cpRzuYTOJXjyI1TXOSdv/YqRjM=" 514 | }, 515 | "esquery": { 516 | "version": "1.0.1", 517 | "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.0.1.tgz", 518 | "integrity": "sha512-SmiyZ5zIWH9VM+SRUReLS5Q8a7GxtRdxEBVZpm98rJM7Sb+A9DVCndXfkeFUd3byderg+EbDkfnevfCwynWaNA==", 519 | "dev": true, 520 | "requires": { 521 | "estraverse": "^4.0.0" 522 | } 523 | }, 524 | "esrecurse": { 525 | "version": "4.2.1", 526 | "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.2.1.tgz", 527 | "integrity": "sha512-64RBB++fIOAXPw3P9cy89qfMlvZEXZkqqJkjqqXIvzP5ezRZjW+lPWjw35UX/3EhUPFYbg5ER4JYgDw4007/DQ==", 528 | "dev": true, 529 | "requires": { 530 | "estraverse": "^4.1.0" 531 | } 532 | }, 533 | "estraverse": { 534 | "version": "4.2.0", 535 | "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-4.2.0.tgz", 536 | "integrity": "sha1-De4/7TH81GlhjOc0IJn8GvoL2xM=" 537 | }, 538 | "esutils": { 539 | "version": "2.0.2", 540 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.2.tgz", 541 | "integrity": "sha1-Cr9PHKpbyx96nYrMbepPqqBLrJs=" 542 | }, 543 | "external-editor": { 544 | "version": "3.0.3", 545 | "resolved": "https://registry.npmjs.org/external-editor/-/external-editor-3.0.3.tgz", 546 | "integrity": "sha512-bn71H9+qWoOQKyZDo25mOMVpSmXROAsTJVVVYzrrtol3d4y+AsKjf4Iwl2Q+IuT0kFSQ1qo166UuIwqYq7mGnA==", 547 | "dev": true, 548 | "requires": { 549 | "chardet": "^0.7.0", 550 | "iconv-lite": "^0.4.24", 551 | "tmp": "^0.0.33" 552 | } 553 | }, 554 | "fast-deep-equal": { 555 | "version": "2.0.1", 556 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-2.0.1.tgz", 557 | "integrity": "sha1-ewUhjd+WZ79/Nwv3/bLLFf3Qqkk=", 558 | "dev": true 559 | }, 560 | "fast-diff": { 561 | "version": "1.1.2", 562 | "resolved": "https://registry.npmjs.org/fast-diff/-/fast-diff-1.1.2.tgz", 563 | "integrity": "sha512-KaJUt+M9t1qaIteSvjc6P3RbMdXsNhK61GRftR6SNxqmhthcd9MGIi4T+o0jD8LUSpSnSKXE20nLtJ3fOHxQig==", 564 | "dev": true 565 | }, 566 | "fast-json-stable-stringify": { 567 | "version": "2.0.0", 568 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.0.0.tgz", 569 | "integrity": "sha1-1RQsDK7msRifh9OnYREGT4bIu/I=", 570 | "dev": true 571 | }, 572 | "fast-levenshtein": { 573 | "version": "2.0.6", 574 | "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", 575 | "integrity": "sha1-PYpcZog6FqMMqGQ+hR8Zuqd5eRc=" 576 | }, 577 | "figures": { 578 | "version": "2.0.0", 579 | "resolved": "https://registry.npmjs.org/figures/-/figures-2.0.0.tgz", 580 | "integrity": "sha1-OrGi0qYsi/tDGgyUy3l6L84nyWI=", 581 | "dev": true, 582 | "requires": { 583 | "escape-string-regexp": "^1.0.5" 584 | } 585 | }, 586 | "file-entry-cache": { 587 | "version": "2.0.0", 588 | "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-2.0.0.tgz", 589 | "integrity": "sha1-w5KZDD5oR4PYOLjISkXYoEhFg2E=", 590 | "dev": true, 591 | "requires": { 592 | "flat-cache": "^1.2.1", 593 | "object-assign": "^4.0.1" 594 | } 595 | }, 596 | "find-up": { 597 | "version": "1.1.2", 598 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-1.1.2.tgz", 599 | "integrity": "sha1-ay6YIrGizgpgq2TWEOzK1TyyTQ8=", 600 | "dev": true, 601 | "requires": { 602 | "path-exists": "^2.0.0", 603 | "pinkie-promise": "^2.0.0" 604 | } 605 | }, 606 | "flat-cache": { 607 | "version": "1.3.0", 608 | "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-1.3.0.tgz", 609 | "integrity": "sha1-0wMLMrOBVPTjt+nHCfSQ9++XxIE=", 610 | "dev": true, 611 | "requires": { 612 | "circular-json": "^0.3.1", 613 | "del": "^2.0.2", 614 | "graceful-fs": "^4.1.2", 615 | "write": "^0.2.1" 616 | } 617 | }, 618 | "fs.realpath": { 619 | "version": "1.0.0", 620 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 621 | "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=", 622 | "dev": true 623 | }, 624 | "function-bind": { 625 | "version": "1.1.1", 626 | "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", 627 | "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==", 628 | "dev": true 629 | }, 630 | "functional-red-black-tree": { 631 | "version": "1.0.1", 632 | "resolved": "https://registry.npmjs.org/functional-red-black-tree/-/functional-red-black-tree-1.0.1.tgz", 633 | "integrity": "sha1-GwqzvVU7Kg1jmdKcDj6gslIHgyc=", 634 | "dev": true 635 | }, 636 | "glob": { 637 | "version": "7.1.3", 638 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.3.tgz", 639 | "integrity": "sha512-vcfuiIxogLV4DlGBHIUOwI0IbrJ8HWPc4MU7HzviGeNho/UJDfi6B5p3sHeWIQ0KGIU0Jpxi5ZHxemQfLkkAwQ==", 640 | "dev": true, 641 | "requires": { 642 | "fs.realpath": "^1.0.0", 643 | "inflight": "^1.0.4", 644 | "inherits": "2", 645 | "minimatch": "^3.0.4", 646 | "once": "^1.3.0", 647 | "path-is-absolute": "^1.0.0" 648 | } 649 | }, 650 | "globals": { 651 | "version": "11.7.0", 652 | "resolved": "https://registry.npmjs.org/globals/-/globals-11.7.0.tgz", 653 | "integrity": "sha512-K8BNSPySfeShBQXsahYB/AbbWruVOTyVpgoIDnl8odPpeSfP2J5QO2oLFFdl2j7GfDCtZj2bMKar2T49itTPCg==", 654 | "dev": true 655 | }, 656 | "globby": { 657 | "version": "5.0.0", 658 | "resolved": "https://registry.npmjs.org/globby/-/globby-5.0.0.tgz", 659 | "integrity": "sha1-69hGZ8oNuzMLmbz8aOrCvFQ3Dg0=", 660 | "dev": true, 661 | "requires": { 662 | "array-union": "^1.0.1", 663 | "arrify": "^1.0.0", 664 | "glob": "^7.0.3", 665 | "object-assign": "^4.0.1", 666 | "pify": "^2.0.0", 667 | "pinkie-promise": "^2.0.0" 668 | } 669 | }, 670 | "graceful-fs": { 671 | "version": "4.1.11", 672 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.1.11.tgz", 673 | "integrity": "sha1-Dovf5NHduIVNZOBOp8AOKgJuVlg=", 674 | "dev": true 675 | }, 676 | "has": { 677 | "version": "1.0.3", 678 | "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", 679 | "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", 680 | "dev": true, 681 | "requires": { 682 | "function-bind": "^1.1.1" 683 | } 684 | }, 685 | "has-flag": { 686 | "version": "3.0.0", 687 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 688 | "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=", 689 | "dev": true 690 | }, 691 | "hash-sum": { 692 | "version": "1.0.2", 693 | "resolved": "https://registry.npmjs.org/hash-sum/-/hash-sum-1.0.2.tgz", 694 | "integrity": "sha1-M7QHd3VMZDJXPBIMw4CLvRDUfwQ=" 695 | }, 696 | "hosted-git-info": { 697 | "version": "2.7.1", 698 | "resolved": "https://registry.npmjs.org/hosted-git-info/-/hosted-git-info-2.7.1.tgz", 699 | "integrity": "sha512-7T/BxH19zbcCTa8XkMlbK5lTo1WtgkFi3GvdWEyNuc4Vex7/9Dqbnpsf4JMydcfj9HCg4zUWFTL3Za6lapg5/w==", 700 | "dev": true 701 | }, 702 | "iconv-lite": { 703 | "version": "0.4.24", 704 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", 705 | "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", 706 | "dev": true, 707 | "requires": { 708 | "safer-buffer": ">= 2.1.2 < 3" 709 | } 710 | }, 711 | "ignore": { 712 | "version": "4.0.6", 713 | "resolved": "https://registry.npmjs.org/ignore/-/ignore-4.0.6.tgz", 714 | "integrity": "sha512-cyFDKrqc/YdcWFniJhzI42+AzS+gNwmUzOSFcRCQYwySuBBBy/KjuxWLZ/FHEH6Moq1NizMOBWyTcv8O4OZIMg==", 715 | "dev": true 716 | }, 717 | "imurmurhash": { 718 | "version": "0.1.4", 719 | "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", 720 | "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=", 721 | "dev": true 722 | }, 723 | "inflight": { 724 | "version": "1.0.6", 725 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 726 | "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", 727 | "dev": true, 728 | "requires": { 729 | "once": "^1.3.0", 730 | "wrappy": "1" 731 | } 732 | }, 733 | "inherits": { 734 | "version": "2.0.3", 735 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz", 736 | "integrity": "sha1-Yzwsg+PaQqUC9SRmAiSA9CCCYd4=", 737 | "dev": true 738 | }, 739 | "inquirer": { 740 | "version": "6.2.0", 741 | "resolved": "https://registry.npmjs.org/inquirer/-/inquirer-6.2.0.tgz", 742 | "integrity": "sha512-QIEQG4YyQ2UYZGDC4srMZ7BjHOmNk1lR2JQj5UknBapklm6WHA+VVH7N+sUdX3A7NeCfGF8o4X1S3Ao7nAcIeg==", 743 | "dev": true, 744 | "requires": { 745 | "ansi-escapes": "^3.0.0", 746 | "chalk": "^2.0.0", 747 | "cli-cursor": "^2.1.0", 748 | "cli-width": "^2.0.0", 749 | "external-editor": "^3.0.0", 750 | "figures": "^2.0.0", 751 | "lodash": "^4.17.10", 752 | "mute-stream": "0.0.7", 753 | "run-async": "^2.2.0", 754 | "rxjs": "^6.1.0", 755 | "string-width": "^2.1.0", 756 | "strip-ansi": "^4.0.0", 757 | "through": "^2.3.6" 758 | } 759 | }, 760 | "is-arrayish": { 761 | "version": "0.2.1", 762 | "resolved": "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.2.1.tgz", 763 | "integrity": "sha1-d8mYQFJ6qOyxqLppe4BkWnqSap0=", 764 | "dev": true 765 | }, 766 | "is-builtin-module": { 767 | "version": "1.0.0", 768 | "resolved": "http://registry.npmjs.org/is-builtin-module/-/is-builtin-module-1.0.0.tgz", 769 | "integrity": "sha1-VAVy0096wxGfj3bDDLwbHgN6/74=", 770 | "dev": true, 771 | "requires": { 772 | "builtin-modules": "^1.0.0" 773 | } 774 | }, 775 | "is-fullwidth-code-point": { 776 | "version": "2.0.0", 777 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", 778 | "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=", 779 | "dev": true 780 | }, 781 | "is-path-cwd": { 782 | "version": "1.0.0", 783 | "resolved": "https://registry.npmjs.org/is-path-cwd/-/is-path-cwd-1.0.0.tgz", 784 | "integrity": "sha1-0iXsIxMuie3Tj9p2dHLmLmXxEG0=", 785 | "dev": true 786 | }, 787 | "is-path-in-cwd": { 788 | "version": "1.0.1", 789 | "resolved": "https://registry.npmjs.org/is-path-in-cwd/-/is-path-in-cwd-1.0.1.tgz", 790 | "integrity": "sha512-FjV1RTW48E7CWM7eE/J2NJvAEEVektecDBVBE5Hh3nM1Jd0kvhHtX68Pr3xsDf857xt3Y4AkwVULK1Vku62aaQ==", 791 | "dev": true, 792 | "requires": { 793 | "is-path-inside": "^1.0.0" 794 | } 795 | }, 796 | "is-path-inside": { 797 | "version": "1.0.1", 798 | "resolved": "https://registry.npmjs.org/is-path-inside/-/is-path-inside-1.0.1.tgz", 799 | "integrity": "sha1-jvW33lBDej/cprToZe96pVy0gDY=", 800 | "dev": true, 801 | "requires": { 802 | "path-is-inside": "^1.0.1" 803 | } 804 | }, 805 | "is-promise": { 806 | "version": "2.1.0", 807 | "resolved": "https://registry.npmjs.org/is-promise/-/is-promise-2.1.0.tgz", 808 | "integrity": "sha1-eaKp7OfwlugPNtKy87wWwf9L8/o=", 809 | "dev": true 810 | }, 811 | "is-resolvable": { 812 | "version": "1.1.0", 813 | "resolved": "https://registry.npmjs.org/is-resolvable/-/is-resolvable-1.1.0.tgz", 814 | "integrity": "sha512-qgDYXFSR5WvEfuS5dMj6oTMEbrrSaM0CrFk2Yiq/gXnBvD9pMa2jGXxyhGLfvhZpuMZe18CJpFxAt3CRs42NMg==", 815 | "dev": true 816 | }, 817 | "isarray": { 818 | "version": "1.0.0", 819 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", 820 | "integrity": "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE=", 821 | "dev": true 822 | }, 823 | "isexe": { 824 | "version": "2.0.0", 825 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 826 | "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=", 827 | "dev": true 828 | }, 829 | "jasmine": { 830 | "version": "3.2.0", 831 | "resolved": "https://registry.npmjs.org/jasmine/-/jasmine-3.2.0.tgz", 832 | "integrity": "sha512-qv6TZ32r+slrQz8fbx2EhGbD9zlJo3NwPrpLK1nE8inILtZO9Fap52pyHk7mNTh4tG50a+1+tOiWVT3jO5I0Sg==", 833 | "dev": true, 834 | "requires": { 835 | "glob": "^7.0.6", 836 | "jasmine-core": "~3.2.0" 837 | } 838 | }, 839 | "jasmine-core": { 840 | "version": "3.2.1", 841 | "resolved": "https://registry.npmjs.org/jasmine-core/-/jasmine-core-3.2.1.tgz", 842 | "integrity": "sha512-pa9tbBWgU0EE4SWgc85T4sa886ufuQdsgruQANhECYjwqgV4z7Vw/499aCaP8ZH79JDS4vhm8doDG9HO4+e4sA==", 843 | "dev": true 844 | }, 845 | "jest-docblock": { 846 | "version": "21.2.0", 847 | "resolved": "https://registry.npmjs.org/jest-docblock/-/jest-docblock-21.2.0.tgz", 848 | "integrity": "sha512-5IZ7sY9dBAYSV+YjQ0Ovb540Ku7AO9Z5o2Cg789xj167iQuZ2cG+z0f3Uct6WeYLbU6aQiM2pCs7sZ+4dotydw==", 849 | "dev": true 850 | }, 851 | "js-tokens": { 852 | "version": "4.0.0", 853 | "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", 854 | "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==", 855 | "dev": true 856 | }, 857 | "js-yaml": { 858 | "version": "3.12.0", 859 | "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.12.0.tgz", 860 | "integrity": "sha512-PIt2cnwmPfL4hKNwqeiuz4bKfnzHTBv6HyVgjahA6mPLwPDzjDWrplJBMjHUFxku/N3FlmrbyPclad+I+4mJ3A==", 861 | "dev": true, 862 | "requires": { 863 | "argparse": "^1.0.7", 864 | "esprima": "^4.0.0" 865 | }, 866 | "dependencies": { 867 | "esprima": { 868 | "version": "4.0.1", 869 | "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz", 870 | "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==", 871 | "dev": true 872 | } 873 | } 874 | }, 875 | "json-schema-traverse": { 876 | "version": "0.4.1", 877 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", 878 | "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", 879 | "dev": true 880 | }, 881 | "json-stable-stringify-without-jsonify": { 882 | "version": "1.0.1", 883 | "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz", 884 | "integrity": "sha1-nbe1lJatPzz+8wp1FC0tkwrXJlE=", 885 | "dev": true 886 | }, 887 | "levn": { 888 | "version": "0.3.0", 889 | "resolved": "https://registry.npmjs.org/levn/-/levn-0.3.0.tgz", 890 | "integrity": "sha1-OwmSTt+fCDwEkP3UwLxEIeBHZO4=", 891 | "requires": { 892 | "prelude-ls": "~1.1.2", 893 | "type-check": "~0.3.2" 894 | } 895 | }, 896 | "load-json-file": { 897 | "version": "2.0.0", 898 | "resolved": "http://registry.npmjs.org/load-json-file/-/load-json-file-2.0.0.tgz", 899 | "integrity": "sha1-eUfkIUmvgNaWy/eXvKq8/h/inKg=", 900 | "dev": true, 901 | "requires": { 902 | "graceful-fs": "^4.1.2", 903 | "parse-json": "^2.2.0", 904 | "pify": "^2.0.0", 905 | "strip-bom": "^3.0.0" 906 | } 907 | }, 908 | "locate-path": { 909 | "version": "2.0.0", 910 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-2.0.0.tgz", 911 | "integrity": "sha1-K1aLJl7slExtnA3pw9u7ygNUzY4=", 912 | "dev": true, 913 | "requires": { 914 | "p-locate": "^2.0.0", 915 | "path-exists": "^3.0.0" 916 | }, 917 | "dependencies": { 918 | "path-exists": { 919 | "version": "3.0.0", 920 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-3.0.0.tgz", 921 | "integrity": "sha1-zg6+ql94yxiSXqfYENe1mwEP1RU=", 922 | "dev": true 923 | } 924 | } 925 | }, 926 | "lodash": { 927 | "version": "4.17.11", 928 | "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.11.tgz", 929 | "integrity": "sha512-cQKh8igo5QUhZ7lg38DYWAxMvjSAKG0A8wGSVimP07SIUEK2UO+arSRKbRZWtelMtN5V0Hkwh5ryOto/SshYIg==", 930 | "dev": true 931 | }, 932 | "mimic-fn": { 933 | "version": "1.2.0", 934 | "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-1.2.0.tgz", 935 | "integrity": "sha512-jf84uxzwiuiIVKiOLpfYk7N46TSy8ubTonmneY9vrpHNAnp0QBt2BxWV9dO3/j+BoVAb+a5G6YDPW3M5HOdMWQ==", 936 | "dev": true 937 | }, 938 | "minimatch": { 939 | "version": "3.0.4", 940 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", 941 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 942 | "dev": true, 943 | "requires": { 944 | "brace-expansion": "^1.1.7" 945 | } 946 | }, 947 | "minimist": { 948 | "version": "0.0.8", 949 | "resolved": "http://registry.npmjs.org/minimist/-/minimist-0.0.8.tgz", 950 | "integrity": "sha1-hX/Kv8M5fSYluCKCYuhqp6ARsF0=", 951 | "dev": true 952 | }, 953 | "mkdirp": { 954 | "version": "0.5.1", 955 | "resolved": "http://registry.npmjs.org/mkdirp/-/mkdirp-0.5.1.tgz", 956 | "integrity": "sha1-MAV0OOrGz3+MR2fzhkjWaX11yQM=", 957 | "dev": true, 958 | "requires": { 959 | "minimist": "0.0.8" 960 | } 961 | }, 962 | "ms": { 963 | "version": "2.1.1", 964 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.1.tgz", 965 | "integrity": "sha512-tgp+dl5cGk28utYktBsrFqA7HKgrhgPsg6Z/EfhWI4gl1Hwq8B/GmY/0oXZ6nF8hDVesS/FpnYaD/kOWhYQvyg==", 966 | "dev": true 967 | }, 968 | "mute-stream": { 969 | "version": "0.0.7", 970 | "resolved": "https://registry.npmjs.org/mute-stream/-/mute-stream-0.0.7.tgz", 971 | "integrity": "sha1-MHXOk7whuPq0PhvE2n6BFe0ee6s=", 972 | "dev": true 973 | }, 974 | "natural-compare": { 975 | "version": "1.4.0", 976 | "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", 977 | "integrity": "sha1-Sr6/7tdUHywnrPspvbvRXI1bpPc=", 978 | "dev": true 979 | }, 980 | "nice-try": { 981 | "version": "1.0.5", 982 | "resolved": "https://registry.npmjs.org/nice-try/-/nice-try-1.0.5.tgz", 983 | "integrity": "sha512-1nh45deeb5olNY7eX82BkPO7SSxR5SSYJiPTrTdFUVYwAl8CKMA5N9PjTYkHiRjisVcxcQ1HXdLhx2qxxJzLNQ==", 984 | "dev": true 985 | }, 986 | "normalize-package-data": { 987 | "version": "2.4.0", 988 | "resolved": "https://registry.npmjs.org/normalize-package-data/-/normalize-package-data-2.4.0.tgz", 989 | "integrity": "sha512-9jjUFbTPfEy3R/ad/2oNbKtW9Hgovl5O1FvFWKkKblNXoN/Oou6+9+KKohPK13Yc3/TyunyWhJp6gvRNR/PPAw==", 990 | "dev": true, 991 | "requires": { 992 | "hosted-git-info": "^2.1.4", 993 | "is-builtin-module": "^1.0.0", 994 | "semver": "2 || 3 || 4 || 5", 995 | "validate-npm-package-license": "^3.0.1" 996 | } 997 | }, 998 | "object-assign": { 999 | "version": "4.1.1", 1000 | "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", 1001 | "integrity": "sha1-IQmtx5ZYh8/AXLvUQsrIv7s2CGM=", 1002 | "dev": true 1003 | }, 1004 | "once": { 1005 | "version": "1.4.0", 1006 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 1007 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 1008 | "dev": true, 1009 | "requires": { 1010 | "wrappy": "1" 1011 | } 1012 | }, 1013 | "onetime": { 1014 | "version": "2.0.1", 1015 | "resolved": "https://registry.npmjs.org/onetime/-/onetime-2.0.1.tgz", 1016 | "integrity": "sha1-BnQoIw/WdEOyeUsiu6UotoZ5YtQ=", 1017 | "dev": true, 1018 | "requires": { 1019 | "mimic-fn": "^1.0.0" 1020 | } 1021 | }, 1022 | "optionator": { 1023 | "version": "0.8.2", 1024 | "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.8.2.tgz", 1025 | "integrity": "sha1-NkxeQJ0/TWMB1sC0wFu6UBgK62Q=", 1026 | "requires": { 1027 | "deep-is": "~0.1.3", 1028 | "fast-levenshtein": "~2.0.4", 1029 | "levn": "~0.3.0", 1030 | "prelude-ls": "~1.1.2", 1031 | "type-check": "~0.3.2", 1032 | "wordwrap": "~1.0.0" 1033 | } 1034 | }, 1035 | "os-tmpdir": { 1036 | "version": "1.0.2", 1037 | "resolved": "https://registry.npmjs.org/os-tmpdir/-/os-tmpdir-1.0.2.tgz", 1038 | "integrity": "sha1-u+Z0BseaqFxc/sdm/lc0VV36EnQ=", 1039 | "dev": true 1040 | }, 1041 | "p-limit": { 1042 | "version": "1.3.0", 1043 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-1.3.0.tgz", 1044 | "integrity": "sha512-vvcXsLAJ9Dr5rQOPk7toZQZJApBl2K4J6dANSsEuh6QI41JYcsS/qhTGa9ErIUUgK3WNQoJYvylxvjqmiqEA9Q==", 1045 | "dev": true, 1046 | "requires": { 1047 | "p-try": "^1.0.0" 1048 | } 1049 | }, 1050 | "p-locate": { 1051 | "version": "2.0.0", 1052 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-2.0.0.tgz", 1053 | "integrity": "sha1-IKAQOyIqcMj9OcwuWAaA893l7EM=", 1054 | "dev": true, 1055 | "requires": { 1056 | "p-limit": "^1.1.0" 1057 | } 1058 | }, 1059 | "p-try": { 1060 | "version": "1.0.0", 1061 | "resolved": "https://registry.npmjs.org/p-try/-/p-try-1.0.0.tgz", 1062 | "integrity": "sha1-y8ec26+P1CKOE/Yh8rGiN8GyB7M=", 1063 | "dev": true 1064 | }, 1065 | "parse-json": { 1066 | "version": "2.2.0", 1067 | "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-2.2.0.tgz", 1068 | "integrity": "sha1-9ID0BDTvgHQfhGkJn43qGPVaTck=", 1069 | "dev": true, 1070 | "requires": { 1071 | "error-ex": "^1.2.0" 1072 | } 1073 | }, 1074 | "path-exists": { 1075 | "version": "2.1.0", 1076 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-2.1.0.tgz", 1077 | "integrity": "sha1-D+tsZPD8UY2adU3V77YscCJ2H0s=", 1078 | "dev": true, 1079 | "requires": { 1080 | "pinkie-promise": "^2.0.0" 1081 | } 1082 | }, 1083 | "path-is-absolute": { 1084 | "version": "1.0.1", 1085 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 1086 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=", 1087 | "dev": true 1088 | }, 1089 | "path-is-inside": { 1090 | "version": "1.0.2", 1091 | "resolved": "https://registry.npmjs.org/path-is-inside/-/path-is-inside-1.0.2.tgz", 1092 | "integrity": "sha1-NlQX3t5EQw0cEa9hAn+s8HS9/FM=", 1093 | "dev": true 1094 | }, 1095 | "path-key": { 1096 | "version": "2.0.1", 1097 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-2.0.1.tgz", 1098 | "integrity": "sha1-QRyttXTFoUDTpLGRDUDYDMn0C0A=", 1099 | "dev": true 1100 | }, 1101 | "path-parse": { 1102 | "version": "1.0.6", 1103 | "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.6.tgz", 1104 | "integrity": "sha512-GSmOT2EbHrINBf9SR7CDELwlJ8AENk3Qn7OikK4nFYAu3Ote2+JYNVvkpAEQm3/TLNEJFD/xZJjzyxg3KBWOzw==", 1105 | "dev": true 1106 | }, 1107 | "path-type": { 1108 | "version": "2.0.0", 1109 | "resolved": "https://registry.npmjs.org/path-type/-/path-type-2.0.0.tgz", 1110 | "integrity": "sha1-8BLMuEFbcJb8LaoQVMPXI4lZTHM=", 1111 | "dev": true, 1112 | "requires": { 1113 | "pify": "^2.0.0" 1114 | } 1115 | }, 1116 | "pify": { 1117 | "version": "2.3.0", 1118 | "resolved": "https://registry.npmjs.org/pify/-/pify-2.3.0.tgz", 1119 | "integrity": "sha1-7RQaasBDqEnqWISY59yosVMw6Qw=", 1120 | "dev": true 1121 | }, 1122 | "pinkie": { 1123 | "version": "2.0.4", 1124 | "resolved": "https://registry.npmjs.org/pinkie/-/pinkie-2.0.4.tgz", 1125 | "integrity": "sha1-clVrgM+g1IqXToDnckjoDtT3+HA=", 1126 | "dev": true 1127 | }, 1128 | "pinkie-promise": { 1129 | "version": "2.0.1", 1130 | "resolved": "https://registry.npmjs.org/pinkie-promise/-/pinkie-promise-2.0.1.tgz", 1131 | "integrity": "sha1-ITXW36ejWMBprJsXh3YogihFD/o=", 1132 | "dev": true, 1133 | "requires": { 1134 | "pinkie": "^2.0.0" 1135 | } 1136 | }, 1137 | "pkg-dir": { 1138 | "version": "1.0.0", 1139 | "resolved": "https://registry.npmjs.org/pkg-dir/-/pkg-dir-1.0.0.tgz", 1140 | "integrity": "sha1-ektQio1bstYp1EcFb/TpyTFM89Q=", 1141 | "dev": true, 1142 | "requires": { 1143 | "find-up": "^1.0.0" 1144 | } 1145 | }, 1146 | "pluralize": { 1147 | "version": "7.0.0", 1148 | "resolved": "https://registry.npmjs.org/pluralize/-/pluralize-7.0.0.tgz", 1149 | "integrity": "sha512-ARhBOdzS3e41FbkW/XWrTEtukqqLoK5+Z/4UeDaLuSW+39JPeFgs4gCGqsrJHVZX0fUrx//4OF0K1CUGwlIFow==", 1150 | "dev": true 1151 | }, 1152 | "prelude-ls": { 1153 | "version": "1.1.2", 1154 | "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.1.2.tgz", 1155 | "integrity": "sha1-IZMqVJ9eUv/ZqCf1cOBL5iqX2lQ=" 1156 | }, 1157 | "prettier": { 1158 | "version": "1.14.3", 1159 | "resolved": "https://registry.npmjs.org/prettier/-/prettier-1.14.3.tgz", 1160 | "integrity": "sha512-qZDVnCrnpsRJJq5nSsiHCE3BYMED2OtsI+cmzIzF1QIfqm5ALf8tEJcO27zV1gKNKRPdhjO0dNWnrzssDQ1tFg==", 1161 | "dev": true 1162 | }, 1163 | "prettier-config-ktsn": { 1164 | "version": "1.0.0", 1165 | "resolved": "https://registry.npmjs.org/prettier-config-ktsn/-/prettier-config-ktsn-1.0.0.tgz", 1166 | "integrity": "sha512-z1W+wHGWnR3f0Tlq4PvD/3KrjXwaYRSJBj6m0QS0o7LazJR4BKPY1V7BsYQrFTrJrSxx2btyDEPO33NTTsFyfA==", 1167 | "dev": true 1168 | }, 1169 | "progress": { 1170 | "version": "2.0.0", 1171 | "resolved": "https://registry.npmjs.org/progress/-/progress-2.0.0.tgz", 1172 | "integrity": "sha1-ihvjZr+Pwj2yvSPxDG/pILQ4nR8=", 1173 | "dev": true 1174 | }, 1175 | "punycode": { 1176 | "version": "2.1.1", 1177 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.1.1.tgz", 1178 | "integrity": "sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A==", 1179 | "dev": true 1180 | }, 1181 | "read-pkg": { 1182 | "version": "2.0.0", 1183 | "resolved": "https://registry.npmjs.org/read-pkg/-/read-pkg-2.0.0.tgz", 1184 | "integrity": "sha1-jvHAYjxqbbDcZxPEv6xGMysjaPg=", 1185 | "dev": true, 1186 | "requires": { 1187 | "load-json-file": "^2.0.0", 1188 | "normalize-package-data": "^2.3.2", 1189 | "path-type": "^2.0.0" 1190 | } 1191 | }, 1192 | "read-pkg-up": { 1193 | "version": "2.0.0", 1194 | "resolved": "https://registry.npmjs.org/read-pkg-up/-/read-pkg-up-2.0.0.tgz", 1195 | "integrity": "sha1-a3KoBImE4MQeeVEP1en6mbO1Sb4=", 1196 | "dev": true, 1197 | "requires": { 1198 | "find-up": "^2.0.0", 1199 | "read-pkg": "^2.0.0" 1200 | }, 1201 | "dependencies": { 1202 | "find-up": { 1203 | "version": "2.1.0", 1204 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-2.1.0.tgz", 1205 | "integrity": "sha1-RdG35QbHF93UgndaK3eSCjwMV6c=", 1206 | "dev": true, 1207 | "requires": { 1208 | "locate-path": "^2.0.0" 1209 | } 1210 | } 1211 | } 1212 | }, 1213 | "regexpp": { 1214 | "version": "2.0.0", 1215 | "resolved": "https://registry.npmjs.org/regexpp/-/regexpp-2.0.0.tgz", 1216 | "integrity": "sha512-g2FAVtR8Uh8GO1Nv5wpxW7VFVwHcCEr4wyA8/MHiRkO8uHoR5ntAA8Uq3P1vvMTX/BeQiRVSpDGLd+Wn5HNOTA==", 1217 | "dev": true 1218 | }, 1219 | "require-uncached": { 1220 | "version": "1.0.3", 1221 | "resolved": "https://registry.npmjs.org/require-uncached/-/require-uncached-1.0.3.tgz", 1222 | "integrity": "sha1-Tg1W1slmL9MeQwEcS5WqSZVUIdM=", 1223 | "dev": true, 1224 | "requires": { 1225 | "caller-path": "^0.1.0", 1226 | "resolve-from": "^1.0.0" 1227 | } 1228 | }, 1229 | "resolve": { 1230 | "version": "1.8.1", 1231 | "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.8.1.tgz", 1232 | "integrity": "sha512-AicPrAC7Qu1JxPCZ9ZgCZlY35QgFnNqc+0LtbRNxnVw4TXvjQ72wnuL9JQcEBgXkI9JM8MsT9kaQoHcpCRJOYA==", 1233 | "dev": true, 1234 | "requires": { 1235 | "path-parse": "^1.0.5" 1236 | } 1237 | }, 1238 | "resolve-from": { 1239 | "version": "1.0.1", 1240 | "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-1.0.1.tgz", 1241 | "integrity": "sha1-Jsv+k10a7uq7Kbw/5a6wHpPUQiY=", 1242 | "dev": true 1243 | }, 1244 | "restore-cursor": { 1245 | "version": "2.0.0", 1246 | "resolved": "https://registry.npmjs.org/restore-cursor/-/restore-cursor-2.0.0.tgz", 1247 | "integrity": "sha1-n37ih/gv0ybU/RYpI9YhKe7g368=", 1248 | "dev": true, 1249 | "requires": { 1250 | "onetime": "^2.0.0", 1251 | "signal-exit": "^3.0.2" 1252 | } 1253 | }, 1254 | "rimraf": { 1255 | "version": "2.6.2", 1256 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.6.2.tgz", 1257 | "integrity": "sha512-lreewLK/BlghmxtfH36YYVg1i8IAce4TI7oao75I1g245+6BctqTVQiBP3YUJ9C6DQOXJmkYR9X9fCLtCOJc5w==", 1258 | "dev": true, 1259 | "requires": { 1260 | "glob": "^7.0.5" 1261 | } 1262 | }, 1263 | "run-async": { 1264 | "version": "2.3.0", 1265 | "resolved": "https://registry.npmjs.org/run-async/-/run-async-2.3.0.tgz", 1266 | "integrity": "sha1-A3GrSuC91yDUFm19/aZP96RFpsA=", 1267 | "dev": true, 1268 | "requires": { 1269 | "is-promise": "^2.1.0" 1270 | } 1271 | }, 1272 | "rxjs": { 1273 | "version": "6.3.2", 1274 | "resolved": "https://registry.npmjs.org/rxjs/-/rxjs-6.3.2.tgz", 1275 | "integrity": "sha512-hV7criqbR0pe7EeL3O66UYVg92IR0XsA97+9y+BWTePK9SKmEI5Qd3Zj6uPnGkNzXsBywBQWTvujPl+1Kn9Zjw==", 1276 | "dev": true, 1277 | "requires": { 1278 | "tslib": "^1.9.0" 1279 | } 1280 | }, 1281 | "safer-buffer": { 1282 | "version": "2.1.2", 1283 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", 1284 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==", 1285 | "dev": true 1286 | }, 1287 | "semver": { 1288 | "version": "5.5.1", 1289 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.5.1.tgz", 1290 | "integrity": "sha512-PqpAxfrEhlSUWge8dwIp4tZnQ25DIOthpiaHNIthsjEFQD6EvqUKUDM7L8O2rShkFccYo1VjJR0coWfNkCubRw==", 1291 | "dev": true 1292 | }, 1293 | "shebang-command": { 1294 | "version": "1.2.0", 1295 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-1.2.0.tgz", 1296 | "integrity": "sha1-RKrGW2lbAzmJaMOfNj/uXer98eo=", 1297 | "dev": true, 1298 | "requires": { 1299 | "shebang-regex": "^1.0.0" 1300 | } 1301 | }, 1302 | "shebang-regex": { 1303 | "version": "1.0.0", 1304 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-1.0.0.tgz", 1305 | "integrity": "sha1-2kL0l0DAtC2yypcoVxyxkMmO/qM=", 1306 | "dev": true 1307 | }, 1308 | "signal-exit": { 1309 | "version": "3.0.2", 1310 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.2.tgz", 1311 | "integrity": "sha1-tf3AjxKH6hF4Yo5BXiUTK3NkbG0=", 1312 | "dev": true 1313 | }, 1314 | "slice-ansi": { 1315 | "version": "1.0.0", 1316 | "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-1.0.0.tgz", 1317 | "integrity": "sha512-POqxBK6Lb3q6s047D/XsDVNPnF9Dl8JSaqe9h9lURl0OdNqy/ujDrOiIHtsqXMGbWWTIomRzAMaTyawAU//Reg==", 1318 | "dev": true, 1319 | "requires": { 1320 | "is-fullwidth-code-point": "^2.0.0" 1321 | } 1322 | }, 1323 | "source-map": { 1324 | "version": "0.7.3", 1325 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.7.3.tgz", 1326 | "integrity": "sha512-CkCj6giN3S+n9qrYiBTX5gystlENnRW5jZeNLHpe6aue+SrHcG5VYwujhW9s4dY31mEGsxBDrHR6oI69fTXsaQ==" 1327 | }, 1328 | "spdx-correct": { 1329 | "version": "3.0.0", 1330 | "resolved": "https://registry.npmjs.org/spdx-correct/-/spdx-correct-3.0.0.tgz", 1331 | "integrity": "sha512-N19o9z5cEyc8yQQPukRCZ9EUmb4HUpnrmaL/fxS2pBo2jbfcFRVuFZ/oFC+vZz0MNNk0h80iMn5/S6qGZOL5+g==", 1332 | "dev": true, 1333 | "requires": { 1334 | "spdx-expression-parse": "^3.0.0", 1335 | "spdx-license-ids": "^3.0.0" 1336 | } 1337 | }, 1338 | "spdx-exceptions": { 1339 | "version": "2.1.0", 1340 | "resolved": "https://registry.npmjs.org/spdx-exceptions/-/spdx-exceptions-2.1.0.tgz", 1341 | "integrity": "sha512-4K1NsmrlCU1JJgUrtgEeTVyfx8VaYea9J9LvARxhbHtVtohPs/gFGG5yy49beySjlIMhhXZ4QqujIZEfS4l6Cg==", 1342 | "dev": true 1343 | }, 1344 | "spdx-expression-parse": { 1345 | "version": "3.0.0", 1346 | "resolved": "https://registry.npmjs.org/spdx-expression-parse/-/spdx-expression-parse-3.0.0.tgz", 1347 | "integrity": "sha512-Yg6D3XpRD4kkOmTpdgbUiEJFKghJH03fiC1OPll5h/0sO6neh2jqRDVHOQ4o/LMea0tgCkbMgea5ip/e+MkWyg==", 1348 | "dev": true, 1349 | "requires": { 1350 | "spdx-exceptions": "^2.1.0", 1351 | "spdx-license-ids": "^3.0.0" 1352 | } 1353 | }, 1354 | "spdx-license-ids": { 1355 | "version": "3.0.1", 1356 | "resolved": "https://registry.npmjs.org/spdx-license-ids/-/spdx-license-ids-3.0.1.tgz", 1357 | "integrity": "sha512-TfOfPcYGBB5sDuPn3deByxPhmfegAhpDYKSOXZQN81Oyrrif8ZCodOLzK3AesELnCx03kikhyDwh0pfvvQvF8w==", 1358 | "dev": true 1359 | }, 1360 | "sprintf-js": { 1361 | "version": "1.0.3", 1362 | "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz", 1363 | "integrity": "sha1-BOaSb2YolTVPPdAVIDYzuFcpfiw=", 1364 | "dev": true 1365 | }, 1366 | "string-width": { 1367 | "version": "2.1.1", 1368 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-2.1.1.tgz", 1369 | "integrity": "sha512-nOqH59deCq9SRHlxq1Aw85Jnt4w6KvLKqWVik6oA9ZklXLNIOlqg4F2yrT1MVaTjAqvVwdfeZ7w7aCvJD7ugkw==", 1370 | "dev": true, 1371 | "requires": { 1372 | "is-fullwidth-code-point": "^2.0.0", 1373 | "strip-ansi": "^4.0.0" 1374 | } 1375 | }, 1376 | "strip-ansi": { 1377 | "version": "4.0.0", 1378 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-4.0.0.tgz", 1379 | "integrity": "sha1-qEeQIusaw2iocTibY1JixQXuNo8=", 1380 | "dev": true, 1381 | "requires": { 1382 | "ansi-regex": "^3.0.0" 1383 | } 1384 | }, 1385 | "strip-bom": { 1386 | "version": "3.0.0", 1387 | "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-3.0.0.tgz", 1388 | "integrity": "sha1-IzTBjpx1n3vdVv3vfprj1YjmjtM=", 1389 | "dev": true 1390 | }, 1391 | "strip-json-comments": { 1392 | "version": "2.0.1", 1393 | "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-2.0.1.tgz", 1394 | "integrity": "sha1-PFMZQukIwml8DsNEhYwobHygpgo=", 1395 | "dev": true 1396 | }, 1397 | "supports-color": { 1398 | "version": "5.5.0", 1399 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 1400 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 1401 | "dev": true, 1402 | "requires": { 1403 | "has-flag": "^3.0.0" 1404 | } 1405 | }, 1406 | "table": { 1407 | "version": "4.0.3", 1408 | "resolved": "http://registry.npmjs.org/table/-/table-4.0.3.tgz", 1409 | "integrity": "sha512-S7rnFITmBH1EnyKcvxBh1LjYeQMmnZtCXSEbHcH6S0NoKit24ZuFO/T1vDcLdYsLQkM188PVVhQmzKIuThNkKg==", 1410 | "dev": true, 1411 | "requires": { 1412 | "ajv": "^6.0.1", 1413 | "ajv-keywords": "^3.0.0", 1414 | "chalk": "^2.1.0", 1415 | "lodash": "^4.17.4", 1416 | "slice-ansi": "1.0.0", 1417 | "string-width": "^2.1.1" 1418 | } 1419 | }, 1420 | "text-table": { 1421 | "version": "0.2.0", 1422 | "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz", 1423 | "integrity": "sha1-f17oI66AUgfACvLfSoTsP8+lcLQ=", 1424 | "dev": true 1425 | }, 1426 | "through": { 1427 | "version": "2.3.8", 1428 | "resolved": "http://registry.npmjs.org/through/-/through-2.3.8.tgz", 1429 | "integrity": "sha1-DdTJ/6q8NXlgsbckEV1+Doai4fU=", 1430 | "dev": true 1431 | }, 1432 | "tmp": { 1433 | "version": "0.0.33", 1434 | "resolved": "https://registry.npmjs.org/tmp/-/tmp-0.0.33.tgz", 1435 | "integrity": "sha512-jRCJlojKnZ3addtTOjdIqoRuPEKBvNXcGYqzO6zWZX8KfKEpnGY5jfggJQ3EjKuu8D4bJRr0y+cYJFmYbImXGw==", 1436 | "dev": true, 1437 | "requires": { 1438 | "os-tmpdir": "~1.0.2" 1439 | } 1440 | }, 1441 | "tslib": { 1442 | "version": "1.9.3", 1443 | "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.9.3.tgz", 1444 | "integrity": "sha512-4krF8scpejhaOgqzBEcGM7yDIEfi0/8+8zDRZhNZZ2kjmHJ4hv3zCbQWxoJGz1iw5U0Jl0nma13xzHXcncMavQ==", 1445 | "dev": true 1446 | }, 1447 | "type-check": { 1448 | "version": "0.3.2", 1449 | "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.3.2.tgz", 1450 | "integrity": "sha1-WITKtRLPHTVeP7eE8wgEsrUg23I=", 1451 | "requires": { 1452 | "prelude-ls": "~1.1.2" 1453 | } 1454 | }, 1455 | "uri-js": { 1456 | "version": "4.2.2", 1457 | "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.2.2.tgz", 1458 | "integrity": "sha512-KY9Frmirql91X2Qgjry0Wd4Y+YTdrdZheS8TFwvkbLWf/G5KNJDCh6pKL5OZctEW4+0Baa5idK2ZQuELRwPznQ==", 1459 | "dev": true, 1460 | "requires": { 1461 | "punycode": "^2.1.0" 1462 | } 1463 | }, 1464 | "validate-npm-package-license": { 1465 | "version": "3.0.4", 1466 | "resolved": "https://registry.npmjs.org/validate-npm-package-license/-/validate-npm-package-license-3.0.4.tgz", 1467 | "integrity": "sha512-DpKm2Ui/xN7/HQKCtpZxoRWBhZ9Z0kqtygG8XCgNQ8ZlDnxuQmWhj566j8fN4Cu3/JmbhsDo7fcAJq4s9h27Ew==", 1468 | "dev": true, 1469 | "requires": { 1470 | "spdx-correct": "^3.0.0", 1471 | "spdx-expression-parse": "^3.0.0" 1472 | } 1473 | }, 1474 | "vue-hot-reload-api": { 1475 | "version": "2.3.1", 1476 | "resolved": "https://registry.npmjs.org/vue-hot-reload-api/-/vue-hot-reload-api-2.3.1.tgz", 1477 | "integrity": "sha512-AA86yKZ5uOKz87/q1UpngEXhbRkaYg1b7HMMVRobNV1IVKqZe8oLIzo6iMocVwZXnYitlGwf2k4ZRLOZlS8oPQ==" 1478 | }, 1479 | "which": { 1480 | "version": "1.3.1", 1481 | "resolved": "https://registry.npmjs.org/which/-/which-1.3.1.tgz", 1482 | "integrity": "sha512-HxJdYWq1MTIQbJ3nw0cqssHoTNU267KlrDuGZ1WYlxDStUtKUhOaJmh112/TZmHxxUfuJqPXSOm7tDyas0OSIQ==", 1483 | "dev": true, 1484 | "requires": { 1485 | "isexe": "^2.0.0" 1486 | } 1487 | }, 1488 | "wordwrap": { 1489 | "version": "1.0.0", 1490 | "resolved": "https://registry.npmjs.org/wordwrap/-/wordwrap-1.0.0.tgz", 1491 | "integrity": "sha1-J1hIEIkUVqQXHI0CJkQa3pDLyus=" 1492 | }, 1493 | "wrappy": { 1494 | "version": "1.0.2", 1495 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 1496 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=", 1497 | "dev": true 1498 | }, 1499 | "write": { 1500 | "version": "0.2.1", 1501 | "resolved": "https://registry.npmjs.org/write/-/write-0.2.1.tgz", 1502 | "integrity": "sha1-X8A4KOJkzqP+kUVUdvejxWbLB1c=", 1503 | "dev": true, 1504 | "requires": { 1505 | "mkdirp": "^0.5.1" 1506 | } 1507 | } 1508 | } 1509 | } 1510 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "vue-hot-reload-loader", 3 | "version": "0.2.0", 4 | "description": "Enable hot module replacement (HMR) on your Vue components", 5 | "main": "lib/index.js", 6 | "files": [ 7 | "lib" 8 | ], 9 | "repository": { 10 | "type": "git", 11 | "url": "git+https://github.com/ktsn/vue-hot-reload-loader.git" 12 | }, 13 | "keywords": [ 14 | "vue", 15 | "hot reload", 16 | "webpack", 17 | "loader" 18 | ], 19 | "author": "katashin", 20 | "license": "MIT", 21 | "engines": { 22 | "node": ">=8.0.0" 23 | }, 24 | "bugs": { 25 | "url": "https://github.com/ktsn/vue-hot-reload-loader/issues" 26 | }, 27 | "homepage": "https://github.com/ktsn/vue-hot-reload-loader#readme", 28 | "scripts": { 29 | "lint": "eslint lib test/specs", 30 | "test": "npm run lint && jasmine JASMINE_CONFIG_PATH=test/jasmine.json", 31 | "prepublishOnly": "npm run test" 32 | }, 33 | "peerDependencies": { 34 | "vue": "^2.0.0" 35 | }, 36 | "devDependencies": { 37 | "eslint": "^5.6.0", 38 | "eslint-config-ktsn": "^2.0.1", 39 | "eslint-plugin-import": "^2.14.0", 40 | "jasmine": "^3.2.0", 41 | "prettier": "1.14.3", 42 | "prettier-config-ktsn": "^1.0.0" 43 | }, 44 | "dependencies": { 45 | "acorn": "^6.0.1", 46 | "escodegen": "^1.11.0", 47 | "estraverse": "^4.2.0", 48 | "hash-sum": "^1.0.2", 49 | "source-map": "^0.7.3", 50 | "vue-hot-reload-api": "^2.3.1" 51 | } 52 | } 53 | -------------------------------------------------------------------------------- /prettier.config.js: -------------------------------------------------------------------------------- 1 | module.exports = require('prettier-config-ktsn') -------------------------------------------------------------------------------- /test/.eslintrc.yml: -------------------------------------------------------------------------------- 1 | --- 2 | env: 3 | jasmine: true 4 | -------------------------------------------------------------------------------- /test/expects/class.js: -------------------------------------------------------------------------------- 1 | var __component__ = class MyComp extends Vue { 2 | getAnswer() { 3 | return 42; 4 | } 5 | }; 6 | export default __component__; 7 | -------------------------------------------------------------------------------- /test/expects/object.js: -------------------------------------------------------------------------------- 1 | var __component__ = { 2 | data() { 3 | return { test: 'hi' }; 4 | } 5 | }; 6 | export default __component__; 7 | -------------------------------------------------------------------------------- /test/fixtures/class.js: -------------------------------------------------------------------------------- 1 | export default class MyComp extends Vue { 2 | getAnswer() { 3 | return 42; 4 | } 5 | } 6 | -------------------------------------------------------------------------------- /test/fixtures/object.js: -------------------------------------------------------------------------------- 1 | export default { 2 | data() { 3 | return { test: 'hi' }; 4 | } 5 | }; 6 | -------------------------------------------------------------------------------- /test/jasmine.json: -------------------------------------------------------------------------------- 1 | { 2 | "spec_dir": "test", 3 | "spec_files": [ 4 | "**/*[sS]pec.js" 5 | ], 6 | "helpers": [ 7 | "../node_modules/babel-register/lib/node.js" 8 | ], 9 | "stopSpecOnExpectationFailure": false, 10 | "random": false 11 | } 12 | -------------------------------------------------------------------------------- /test/specs/index.spec.js: -------------------------------------------------------------------------------- 1 | const path = require('path') 2 | const fs = require('fs') 3 | const loader = require('../../lib/index') 4 | 5 | function loadCode(data) { 6 | let callbackAnswer 7 | 8 | loader.call( 9 | { 10 | resourcePath: '/path/to/test.html', 11 | options: {}, 12 | callback: (err, contents, sourcemap) => { 13 | callbackAnswer = { err, contents, sourcemap } 14 | } 15 | }, 16 | data 17 | ) 18 | 19 | return callbackAnswer 20 | } 21 | 22 | function test(name) { 23 | const src = fs.readFileSync( 24 | path.resolve(__dirname, '../fixtures', name), 25 | 'utf8' 26 | ) 27 | const expected = fs.readFileSync( 28 | path.resolve(__dirname, '../expects', name), 29 | 'utf8' 30 | ) 31 | 32 | it(name, () => { 33 | const callbackAnswer = loadCode(src) 34 | expect( 35 | callbackAnswer.contents.replace(/if \(module\.hot\)[\s\S]*$/, '').trim() 36 | ).toBe(expected.trim()) 37 | }) 38 | } 39 | 40 | describe('vue-hot-reload-loader', () => { 41 | fs.readdirSync(path.resolve(__dirname, '../fixtures')).forEach(file => { 42 | test(path.basename(file)) 43 | }) 44 | }) 45 | --------------------------------------------------------------------------------