├── .gitignore ├── README.md ├── headless-browser ├── README.md ├── hydrate.ts ├── lib │ ├── hydrate.js │ └── serialize.js ├── package-lock.json ├── package.json ├── prerender.ts ├── public │ ├── components │ │ ├── color-text.js │ │ ├── my-hello.js │ │ └── real-counter.js │ └── pages │ │ ├── index.html │ │ └── index.ssr.html ├── render.ts ├── serialize.ts ├── server.ts └── tsconfig.json ├── package-lock.json ├── package.json ├── skate-ssr ├── README.md ├── package-lock.json ├── package.json ├── prerender.ts ├── public │ ├── components │ │ ├── color-text.js │ │ ├── color-text_comp.js │ │ ├── my-hello.js │ │ ├── my-hello_comp.js │ │ ├── real-counter.js │ │ └── real-counter_comp.js │ └── pages │ │ ├── index.html │ │ └── index.ssr.html ├── render.ts ├── server.ts ├── tsconfig.json └── utils.ts ├── stringify.ts └── test.ts /.gitignore: -------------------------------------------------------------------------------- 1 | node_modules 2 | .idea 3 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # wc-prerender 2 | My master thesis project regarding pre-rendering of Web Components 3 | 4 | ## Abstract 5 | Web Components are getting more popular and the community came across some disadvantages like first load performance. Server-side rendering (SSR) could improve this. The idea of server-side rendering is nothing new but it has been said that Web Components can not be rendered on the server due to the lack of a declarative shadow root representation. 6 | This project evaluates a solution to pre-render Web Components and compares its performance to other possible implementations. 7 | 8 | ## Goal 9 | 10 | The key intention, which might be obsolete these days, is that functionality should be usable without JavaScript. As of today, about 95% of all websites use JavaScript which makes the fallback for non-JavaScript websites less important. Nonetheless, this means that Web Components should work without JavaScript to some extent. Although, the definition of "work" here should be narrowed down to the content representation only which is hidden when a Web Component is used while JavaScript is disabled. Another aspect is to minimize the time until the First Contentful Paint(FCP) happens in the browser. This means reducing the workload a browser has to do upfront. Which includes interpreting and displaying a component. The time needed to show a custom component will always be greater compared to a vanilla HTML element, due to their nature and how they are being parsed by the browser. 11 | 12 | Therefore, the goal is to pre-render Web Components to provide a vanilla HTML alternative until the actual component is ready to display and exchange it afterwards. 13 | 14 | 15 | ## Installation 16 | The code was developed using Node.js v10.15.3 and npm v6.9.0. 17 | To install and test the source code, clone the repository and execute `npm install` in each directory to make sure all dependencies are being installed correctly. 18 | 19 | ## Running 20 | 21 | The command `npm run render` triggers a single rendering which takes an example HTML file and creates a new, serialized version of it in the "public/pages" directory. 22 | A server can be started using `npm start`. This will serve a local server at http://localhost:3001/ssr for the headless browser or http://localhost:3002/ssr for the DOM API. The route `/avg` keeps track and displays the current average measurement. 23 | 24 | ### Appendix 25 | Stencil Approach 26 | https://github.com/ionic-team/stencil/blob/143e07ea58a67c9bc16209c1c2a5d32a13f50b60/src/mock-doc/serialize-node.ts 27 | -------------------------------------------------------------------------------- /headless-browser/README.md: -------------------------------------------------------------------------------- 1 | # Headless Browser 2 | This utilizes a headless browser(puppeteer) to pre-render the web component. 3 | 4 | [Article](https://medium.com/@treshugart/%C3%A5server-side-rendering-web-components-e5df705f3f48) 5 | 6 | ## Run 7 | Enter `npm run render` in your terminal. 8 | 9 | ## Serve 10 | Enter `npm start` in your terminal to startup a server. 11 | -------------------------------------------------------------------------------- /headless-browser/hydrate.ts: -------------------------------------------------------------------------------- 1 | function hydrate() { 2 | // @ts-ignore 3 | const elements = [...document.querySelectorAll('[data-ssr="serialized"]')]; 4 | 5 | for (const el of elements) { 6 | const lightDom = el.querySelector('[type="ssr-light-dom"]'); 7 | const dataElement = el.querySelector('[type="ssr-data"]'); 8 | const dataContent = dataElement && dataElement.innerText; 9 | const data = dataContent && JSON.parse(dataContent); 10 | 11 | // replace the whole light DOM 12 | el.innerHTML = lightDom.innerHTML; 13 | 14 | //re-apply attributes 15 | data && Object.keys(data).forEach(key => { 16 | el[key] = data[key]; 17 | }); 18 | 19 | el.setAttribute('data-ssr', 'hydrated'); 20 | } 21 | } 22 | 23 | export const rehydrate = ``; 24 | -------------------------------------------------------------------------------- /headless-browser/lib/hydrate.js: -------------------------------------------------------------------------------- 1 | function hydrate() { 2 | [...document.querySelectorAll('[data-ssr="serialized"]')] 3 | .forEach(el => { 4 | const lightDom = el.querySelector('[type="ssr-light-dom"]') 5 | const lightDomContent = lightDom && lightDom.content 6 | const dataElement = el.querySelector('[type="ssr-data"]') 7 | const dataContent = dataElement && dataElement.innerText 8 | const data = dataContent && JSON.parse(dataContent) 9 | 10 | el.childNodes.forEach(node => { 11 | if (node !== lightDom) { 12 | node.parentElement.removeChild(node) 13 | } 14 | }) 15 | 16 | lightDomContent && lightDomContent.childNodes.forEach(node => el.appendChild(node)) 17 | lightDom && lightDom.parentElement.removeChild(lightDom) 18 | dataElement && dataElement.parentElement && dataElement.parentElement.removeChild(dataElement) 19 | data && Object.keys(data).forEach(key => { 20 | el[key] = data[key] 21 | }) 22 | 23 | el.setAttribute('data-ssr', 'hydrated') 24 | } 25 | ) 26 | } 27 | 28 | module.exports = `` -------------------------------------------------------------------------------- /headless-browser/lib/serialize.js: -------------------------------------------------------------------------------- 1 | module.exports = function serialize (rootNode) { 2 | function serializeNode (node) { 3 | try { 4 | const lightDomNodes = node.childNodes 5 | const lightDomHtml = node.innerHTML 6 | const templateDom = document.createElement('template') 7 | const scriptData = document.createElement('script') 8 | const slot = node.shadowRoot.querySelector('slot') 9 | const attributesProperties = node.getAttributeNames() 10 | .filter(name => name !== 'data-ssr') 11 | .reduce((obj, name) => { 12 | return {...obj, [name]: node[name] } 13 | }, {}) 14 | 15 | templateDom.setAttribute('type', 'ssr-light-dom') 16 | 17 | templateDom.innerHTML = lightDomHtml 18 | 19 | scriptData.setAttribute('type', 'ssr-data') 20 | 21 | scriptData.innerHTML = JSON.stringify(attributesProperties) 22 | 23 | // move light nodes into shadowDom 24 | lightDomNodes.forEach(lightNode => slot.parentNode.insertBefore(lightNode, slot)) 25 | 26 | // move shadowDom into root node 27 | node.shadowRoot.childNodes.forEach(shadowNode => node.appendChild(shadowNode)) 28 | 29 | // remove slot element 30 | if (slot) { 31 | slot.parentNode.removeChild(slot) 32 | } 33 | 34 | // serialize custom element child nodes 35 | serialize(node) 36 | 37 | // add original lightDom as template 38 | if (templateDom.innerHTML !== '') { 39 | node.appendChild(templateDom) 40 | } 41 | 42 | if (scriptData.innerHTML !== '{}') { 43 | node.appendChild(scriptData) 44 | } 45 | 46 | node.setAttribute('data-ssr', 'serialized') 47 | } catch (err) { 48 | console.log('error:', err) 49 | } 50 | } 51 | 52 | [...rootNode.querySelectorAll('*')] 53 | .filter(element => /-/.test(element.nodeName)) 54 | .forEach(serializeNode) 55 | } 56 | -------------------------------------------------------------------------------- /headless-browser/package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "wc-prerender", 3 | "version": "1.0.0", 4 | "lockfileVersion": 1, 5 | "requires": true, 6 | "dependencies": { 7 | "@types/node": { 8 | "version": "12.12.7", 9 | "resolved": "https://registry.npmjs.org/@types/node/-/node-12.12.7.tgz", 10 | "integrity": "sha512-E6Zn0rffhgd130zbCbAr/JdXfXkoOUFAKNs/rF8qnafSJ8KYaA/j3oz7dcwal+lYjLA7xvdd5J4wdYpCTlP8+w==" 11 | }, 12 | "@types/puppeteer": { 13 | "version": "2.0.0", 14 | "resolved": "https://registry.npmjs.org/@types/puppeteer/-/puppeteer-2.0.0.tgz", 15 | "integrity": "sha512-QPHXIcaPcijMbvizoM7PRL97Rm+aM8J2DmgTz2tt79b15PqbyeaCppYonvPLHQ/Q5ea92BUHDpv4bsqtiTy8kQ==", 16 | "requires": { 17 | "@types/node": "*" 18 | } 19 | }, 20 | "accepts": { 21 | "version": "1.3.7", 22 | "resolved": "https://registry.npmjs.org/accepts/-/accepts-1.3.7.tgz", 23 | "integrity": "sha512-Il80Qs2WjYlJIBNzNkK6KYqlVMTbZLXgHx2oT0pU/fjRHyEp+PEfEPY0R3WCwAGVOtauxh1hOxNgIf5bv7dQpA==", 24 | "dev": true, 25 | "requires": { 26 | "mime-types": "~2.1.24", 27 | "negotiator": "0.6.2" 28 | } 29 | }, 30 | "agent-base": { 31 | "version": "4.3.0", 32 | "resolved": "https://registry.npmjs.org/agent-base/-/agent-base-4.3.0.tgz", 33 | "integrity": "sha512-salcGninV0nPrwpGNn4VTXBb1SOuXQBiqbrNXoeizJsHrsL6ERFM2Ne3JUSBWRE6aeNJI2ROP/WEEIDUiDe3cg==", 34 | "dev": true, 35 | "requires": { 36 | "es6-promisify": "^5.0.0" 37 | } 38 | }, 39 | "array-flatten": { 40 | "version": "1.1.1", 41 | "resolved": "https://registry.npmjs.org/array-flatten/-/array-flatten-1.1.1.tgz", 42 | "integrity": "sha1-ml9pkFGx5wczKPKgCJaLZOopVdI=", 43 | "dev": true 44 | }, 45 | "async-limiter": { 46 | "version": "1.0.1", 47 | "resolved": "https://registry.npmjs.org/async-limiter/-/async-limiter-1.0.1.tgz", 48 | "integrity": "sha512-csOlWGAcRFJaI6m+F2WKdnMKr4HhdhFVBk0H/QbJFMCr+uO2kwohwXQPxw/9OCxp05r5ghVBFSyioixx3gfkNQ==", 49 | "dev": true 50 | }, 51 | "balanced-match": { 52 | "version": "1.0.0", 53 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz", 54 | "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=", 55 | "dev": true 56 | }, 57 | "body-parser": { 58 | "version": "1.19.0", 59 | "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-1.19.0.tgz", 60 | "integrity": "sha512-dhEPs72UPbDnAQJ9ZKMNTP6ptJaionhP5cBb541nXPlW60Jepo9RV/a4fX4XWW9CuFNK22krhrj1+rgzifNCsw==", 61 | "dev": true, 62 | "requires": { 63 | "bytes": "3.1.0", 64 | "content-type": "~1.0.4", 65 | "debug": "2.6.9", 66 | "depd": "~1.1.2", 67 | "http-errors": "1.7.2", 68 | "iconv-lite": "0.4.24", 69 | "on-finished": "~2.3.0", 70 | "qs": "6.7.0", 71 | "raw-body": "2.4.0", 72 | "type-is": "~1.6.17" 73 | } 74 | }, 75 | "brace-expansion": { 76 | "version": "1.1.11", 77 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 78 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 79 | "dev": true, 80 | "requires": { 81 | "balanced-match": "^1.0.0", 82 | "concat-map": "0.0.1" 83 | } 84 | }, 85 | "buffer-from": { 86 | "version": "1.1.1", 87 | "resolved": "https://registry.npmjs.org/buffer-from/-/buffer-from-1.1.1.tgz", 88 | "integrity": "sha512-MQcXEUbCKtEo7bhqEs6560Hyd4XaovZlO/k9V3hjVUF/zwW7KBVdSK4gIt/bzwS9MbR5qob+F5jusZsb0YQK2A==", 89 | "dev": true 90 | }, 91 | "bytes": { 92 | "version": "3.1.0", 93 | "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.1.0.tgz", 94 | "integrity": "sha512-zauLjrfCG+xvoyaqLoV8bLVXXNGC4JqlxFCutSDWA6fJrTo2ZuvLYTqZ7aHBLZSMOopbzwv8f+wZcVzfVTI2Dg==", 95 | "dev": true 96 | }, 97 | "concat-map": { 98 | "version": "0.0.1", 99 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 100 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=", 101 | "dev": true 102 | }, 103 | "concat-stream": { 104 | "version": "1.6.2", 105 | "resolved": "https://registry.npmjs.org/concat-stream/-/concat-stream-1.6.2.tgz", 106 | "integrity": "sha512-27HBghJxjiZtIk3Ycvn/4kbJk/1uZuJFfuPEns6LaEvpvG1f0hTea8lilrouyo9mVc2GWdcEZ8OLoGmSADlrCw==", 107 | "dev": true, 108 | "requires": { 109 | "buffer-from": "^1.0.0", 110 | "inherits": "^2.0.3", 111 | "readable-stream": "^2.2.2", 112 | "typedarray": "^0.0.6" 113 | } 114 | }, 115 | "content-disposition": { 116 | "version": "0.5.3", 117 | "resolved": "https://registry.npmjs.org/content-disposition/-/content-disposition-0.5.3.tgz", 118 | "integrity": "sha512-ExO0774ikEObIAEV9kDo50o+79VCUdEB6n6lzKgGwupcVeRlhrj3qGAfwq8G6uBJjkqLrhT0qEYFcWng8z1z0g==", 119 | "dev": true, 120 | "requires": { 121 | "safe-buffer": "5.1.2" 122 | } 123 | }, 124 | "content-type": { 125 | "version": "1.0.4", 126 | "resolved": "https://registry.npmjs.org/content-type/-/content-type-1.0.4.tgz", 127 | "integrity": "sha512-hIP3EEPs8tB9AT1L+NUqtwOAps4mk2Zob89MWXMHjHWg9milF/j4osnnQLXBCBFBk/tvIG/tUc9mOUJiPBhPXA==", 128 | "dev": true 129 | }, 130 | "cookie": { 131 | "version": "0.4.0", 132 | "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.4.0.tgz", 133 | "integrity": "sha512-+Hp8fLp57wnUSt0tY0tHEXh4voZRDnoIrZPqlo3DPiI4y9lwg/jqx+1Om94/W6ZaPDOUbnjOt/99w66zk+l1Xg==", 134 | "dev": true 135 | }, 136 | "cookie-signature": { 137 | "version": "1.0.6", 138 | "resolved": "https://registry.npmjs.org/cookie-signature/-/cookie-signature-1.0.6.tgz", 139 | "integrity": "sha1-4wOogrNCzD7oylE6eZmXNNqzriw=", 140 | "dev": true 141 | }, 142 | "core-util-is": { 143 | "version": "1.0.2", 144 | "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.2.tgz", 145 | "integrity": "sha1-tf1UIgqivFq1eqtxQMlAdUUDwac=", 146 | "dev": true 147 | }, 148 | "debug": { 149 | "version": "2.6.9", 150 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 151 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 152 | "dev": true, 153 | "requires": { 154 | "ms": "2.0.0" 155 | } 156 | }, 157 | "depd": { 158 | "version": "1.1.2", 159 | "resolved": "https://registry.npmjs.org/depd/-/depd-1.1.2.tgz", 160 | "integrity": "sha1-m81S4UwJd2PnSbJ0xDRu0uVgtak=", 161 | "dev": true 162 | }, 163 | "destroy": { 164 | "version": "1.0.4", 165 | "resolved": "https://registry.npmjs.org/destroy/-/destroy-1.0.4.tgz", 166 | "integrity": "sha1-l4hXRCxEdJ5CBmE+N5RiBYJqvYA=", 167 | "dev": true 168 | }, 169 | "ee-first": { 170 | "version": "1.1.1", 171 | "resolved": "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz", 172 | "integrity": "sha1-WQxhFWsK4vTwJVcyoViyZrxWsh0=", 173 | "dev": true 174 | }, 175 | "encodeurl": { 176 | "version": "1.0.2", 177 | "resolved": "https://registry.npmjs.org/encodeurl/-/encodeurl-1.0.2.tgz", 178 | "integrity": "sha1-rT/0yG7C0CkyL1oCw6mmBslbP1k=", 179 | "dev": true 180 | }, 181 | "es6-promise": { 182 | "version": "4.2.8", 183 | "resolved": "https://registry.npmjs.org/es6-promise/-/es6-promise-4.2.8.tgz", 184 | "integrity": "sha512-HJDGx5daxeIvxdBxvG2cb9g4tEvwIk3i8+nhX0yGrYmZUzbkdg8QbDevheDB8gd0//uPj4c1EQua8Q+MViT0/w==", 185 | "dev": true 186 | }, 187 | "es6-promisify": { 188 | "version": "5.0.0", 189 | "resolved": "https://registry.npmjs.org/es6-promisify/-/es6-promisify-5.0.0.tgz", 190 | "integrity": "sha1-UQnWLz5W6pZ8S2NQWu8IKRyKUgM=", 191 | "dev": true, 192 | "requires": { 193 | "es6-promise": "^4.0.3" 194 | } 195 | }, 196 | "escape-html": { 197 | "version": "1.0.3", 198 | "resolved": "https://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz", 199 | "integrity": "sha1-Aljq5NPQwJdN4cFpGI7wBR0dGYg=", 200 | "dev": true 201 | }, 202 | "etag": { 203 | "version": "1.8.1", 204 | "resolved": "https://registry.npmjs.org/etag/-/etag-1.8.1.tgz", 205 | "integrity": "sha1-Qa4u62XvpiJorr/qg6x9eSmbCIc=", 206 | "dev": true 207 | }, 208 | "express": { 209 | "version": "4.17.1", 210 | "resolved": "https://registry.npmjs.org/express/-/express-4.17.1.tgz", 211 | "integrity": "sha512-mHJ9O79RqluphRrcw2X/GTh3k9tVv8YcoyY4Kkh4WDMUYKRZUq0h1o0w2rrrxBqM7VoeUVqgb27xlEMXTnYt4g==", 212 | "dev": true, 213 | "requires": { 214 | "accepts": "~1.3.7", 215 | "array-flatten": "1.1.1", 216 | "body-parser": "1.19.0", 217 | "content-disposition": "0.5.3", 218 | "content-type": "~1.0.4", 219 | "cookie": "0.4.0", 220 | "cookie-signature": "1.0.6", 221 | "debug": "2.6.9", 222 | "depd": "~1.1.2", 223 | "encodeurl": "~1.0.2", 224 | "escape-html": "~1.0.3", 225 | "etag": "~1.8.1", 226 | "finalhandler": "~1.1.2", 227 | "fresh": "0.5.2", 228 | "merge-descriptors": "1.0.1", 229 | "methods": "~1.1.2", 230 | "on-finished": "~2.3.0", 231 | "parseurl": "~1.3.3", 232 | "path-to-regexp": "0.1.7", 233 | "proxy-addr": "~2.0.5", 234 | "qs": "6.7.0", 235 | "range-parser": "~1.2.1", 236 | "safe-buffer": "5.1.2", 237 | "send": "0.17.1", 238 | "serve-static": "1.14.1", 239 | "setprototypeof": "1.1.1", 240 | "statuses": "~1.5.0", 241 | "type-is": "~1.6.18", 242 | "utils-merge": "1.0.1", 243 | "vary": "~1.1.2" 244 | } 245 | }, 246 | "extract-zip": { 247 | "version": "1.6.7", 248 | "resolved": "https://registry.npmjs.org/extract-zip/-/extract-zip-1.6.7.tgz", 249 | "integrity": "sha1-qEC0uK9kAyZMjbV/Txp0Mz74H+k=", 250 | "dev": true, 251 | "requires": { 252 | "concat-stream": "1.6.2", 253 | "debug": "2.6.9", 254 | "mkdirp": "0.5.1", 255 | "yauzl": "2.4.1" 256 | } 257 | }, 258 | "fd-slicer": { 259 | "version": "1.0.1", 260 | "resolved": "https://registry.npmjs.org/fd-slicer/-/fd-slicer-1.0.1.tgz", 261 | "integrity": "sha1-i1vL2ewyfFBBv5qwI/1nUPEXfmU=", 262 | "dev": true, 263 | "requires": { 264 | "pend": "~1.2.0" 265 | } 266 | }, 267 | "finalhandler": { 268 | "version": "1.1.2", 269 | "resolved": "https://registry.npmjs.org/finalhandler/-/finalhandler-1.1.2.tgz", 270 | "integrity": "sha512-aAWcW57uxVNrQZqFXjITpW3sIUQmHGG3qSb9mUah9MgMC4NeWhNOlNjXEYq3HjRAvL6arUviZGGJsBg6z0zsWA==", 271 | "dev": true, 272 | "requires": { 273 | "debug": "2.6.9", 274 | "encodeurl": "~1.0.2", 275 | "escape-html": "~1.0.3", 276 | "on-finished": "~2.3.0", 277 | "parseurl": "~1.3.3", 278 | "statuses": "~1.5.0", 279 | "unpipe": "~1.0.0" 280 | } 281 | }, 282 | "forwarded": { 283 | "version": "0.1.2", 284 | "resolved": "https://registry.npmjs.org/forwarded/-/forwarded-0.1.2.tgz", 285 | "integrity": "sha1-mMI9qxF1ZXuMBXPozszZGw/xjIQ=", 286 | "dev": true 287 | }, 288 | "fresh": { 289 | "version": "0.5.2", 290 | "resolved": "https://registry.npmjs.org/fresh/-/fresh-0.5.2.tgz", 291 | "integrity": "sha1-PYyt2Q2XZWn6g1qx+OSyOhBWBac=", 292 | "dev": true 293 | }, 294 | "fs.realpath": { 295 | "version": "1.0.0", 296 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 297 | "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=", 298 | "dev": true 299 | }, 300 | "glob": { 301 | "version": "7.1.6", 302 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.6.tgz", 303 | "integrity": "sha512-LwaxwyZ72Lk7vZINtNNrywX0ZuLyStrdDtabefZKAY5ZGJhVtgdznluResxNmPitE0SAO+O26sWTHeKSI2wMBA==", 304 | "dev": true, 305 | "requires": { 306 | "fs.realpath": "^1.0.0", 307 | "inflight": "^1.0.4", 308 | "inherits": "2", 309 | "minimatch": "^3.0.4", 310 | "once": "^1.3.0", 311 | "path-is-absolute": "^1.0.0" 312 | } 313 | }, 314 | "http-errors": { 315 | "version": "1.7.2", 316 | "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-1.7.2.tgz", 317 | "integrity": "sha512-uUQBt3H/cSIVfch6i1EuPNy/YsRSOUBXTVfZ+yR7Zjez3qjBz6i9+i4zjNaoqcoFVI4lQJ5plg63TvGfRSDCRg==", 318 | "dev": true, 319 | "requires": { 320 | "depd": "~1.1.2", 321 | "inherits": "2.0.3", 322 | "setprototypeof": "1.1.1", 323 | "statuses": ">= 1.5.0 < 2", 324 | "toidentifier": "1.0.0" 325 | } 326 | }, 327 | "https-proxy-agent": { 328 | "version": "3.0.1", 329 | "resolved": "https://registry.npmjs.org/https-proxy-agent/-/https-proxy-agent-3.0.1.tgz", 330 | "integrity": "sha512-+ML2Rbh6DAuee7d07tYGEKOEi2voWPUGan+ExdPbPW6Z3svq+JCqr0v8WmKPOkz1vOVykPCBSuobe7G8GJUtVg==", 331 | "dev": true, 332 | "requires": { 333 | "agent-base": "^4.3.0", 334 | "debug": "^3.1.0" 335 | }, 336 | "dependencies": { 337 | "debug": { 338 | "version": "3.2.6", 339 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.6.tgz", 340 | "integrity": "sha512-mel+jf7nrtEl5Pn1Qx46zARXKDpBbvzezse7p7LqINmdoIk8PYP5SySaxEmYv6TZ0JyEKA1hsCId6DIhgITtWQ==", 341 | "dev": true, 342 | "requires": { 343 | "ms": "^2.1.1" 344 | } 345 | }, 346 | "ms": { 347 | "version": "2.1.2", 348 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 349 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 350 | "dev": true 351 | } 352 | } 353 | }, 354 | "iconv-lite": { 355 | "version": "0.4.24", 356 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", 357 | "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", 358 | "dev": true, 359 | "requires": { 360 | "safer-buffer": ">= 2.1.2 < 3" 361 | } 362 | }, 363 | "inflight": { 364 | "version": "1.0.6", 365 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 366 | "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", 367 | "dev": true, 368 | "requires": { 369 | "once": "^1.3.0", 370 | "wrappy": "1" 371 | } 372 | }, 373 | "inherits": { 374 | "version": "2.0.3", 375 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz", 376 | "integrity": "sha1-Yzwsg+PaQqUC9SRmAiSA9CCCYd4=", 377 | "dev": true 378 | }, 379 | "ipaddr.js": { 380 | "version": "1.9.0", 381 | "resolved": "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-1.9.0.tgz", 382 | "integrity": "sha512-M4Sjn6N/+O6/IXSJseKqHoFc+5FdGJ22sXqnjTpdZweHK64MzEPAyQZyEU3R/KRv2GLoa7nNtg/C2Ev6m7z+eA==", 383 | "dev": true 384 | }, 385 | "isarray": { 386 | "version": "1.0.0", 387 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", 388 | "integrity": "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE=", 389 | "dev": true 390 | }, 391 | "media-typer": { 392 | "version": "0.3.0", 393 | "resolved": "https://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz", 394 | "integrity": "sha1-hxDXrwqmJvj/+hzgAWhUUmMlV0g=", 395 | "dev": true 396 | }, 397 | "merge-descriptors": { 398 | "version": "1.0.1", 399 | "resolved": "https://registry.npmjs.org/merge-descriptors/-/merge-descriptors-1.0.1.tgz", 400 | "integrity": "sha1-sAqqVW3YtEVoFQ7J0blT8/kMu2E=", 401 | "dev": true 402 | }, 403 | "methods": { 404 | "version": "1.1.2", 405 | "resolved": "https://registry.npmjs.org/methods/-/methods-1.1.2.tgz", 406 | "integrity": "sha1-VSmk1nZUE07cxSZmVoNbD4Ua/O4=", 407 | "dev": true 408 | }, 409 | "mime": { 410 | "version": "1.6.0", 411 | "resolved": "https://registry.npmjs.org/mime/-/mime-1.6.0.tgz", 412 | "integrity": "sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg==", 413 | "dev": true 414 | }, 415 | "mime-db": { 416 | "version": "1.40.0", 417 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.40.0.tgz", 418 | "integrity": "sha512-jYdeOMPy9vnxEqFRRo6ZvTZ8d9oPb+k18PKoYNYUe2stVEBPPwsln/qWzdbmaIvnhZ9v2P+CuecK+fpUfsV2mA==", 419 | "dev": true 420 | }, 421 | "mime-types": { 422 | "version": "2.1.24", 423 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.24.tgz", 424 | "integrity": "sha512-WaFHS3MCl5fapm3oLxU4eYDw77IQM2ACcxQ9RIxfaC3ooc6PFuBMGZZsYpvoXS5D5QTWPieo1jjLdAm3TBP3cQ==", 425 | "dev": true, 426 | "requires": { 427 | "mime-db": "1.40.0" 428 | } 429 | }, 430 | "minimatch": { 431 | "version": "3.0.4", 432 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", 433 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 434 | "dev": true, 435 | "requires": { 436 | "brace-expansion": "^1.1.7" 437 | } 438 | }, 439 | "minimist": { 440 | "version": "0.0.8", 441 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-0.0.8.tgz", 442 | "integrity": "sha1-hX/Kv8M5fSYluCKCYuhqp6ARsF0=", 443 | "dev": true 444 | }, 445 | "mkdirp": { 446 | "version": "0.5.1", 447 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.1.tgz", 448 | "integrity": "sha1-MAV0OOrGz3+MR2fzhkjWaX11yQM=", 449 | "dev": true, 450 | "requires": { 451 | "minimist": "0.0.8" 452 | } 453 | }, 454 | "ms": { 455 | "version": "2.0.0", 456 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 457 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=", 458 | "dev": true 459 | }, 460 | "negotiator": { 461 | "version": "0.6.2", 462 | "resolved": "https://registry.npmjs.org/negotiator/-/negotiator-0.6.2.tgz", 463 | "integrity": "sha512-hZXc7K2e+PgeI1eDBe/10Ard4ekbfrrqG8Ep+8Jmf4JID2bNg7NvCPOZN+kfF574pFQI7mum2AUqDidoKqcTOw==", 464 | "dev": true 465 | }, 466 | "on-finished": { 467 | "version": "2.3.0", 468 | "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.3.0.tgz", 469 | "integrity": "sha1-IPEzZIGwg811M3mSoWlxqi2QaUc=", 470 | "dev": true, 471 | "requires": { 472 | "ee-first": "1.1.1" 473 | } 474 | }, 475 | "once": { 476 | "version": "1.4.0", 477 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 478 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 479 | "dev": true, 480 | "requires": { 481 | "wrappy": "1" 482 | } 483 | }, 484 | "parseurl": { 485 | "version": "1.3.3", 486 | "resolved": "https://registry.npmjs.org/parseurl/-/parseurl-1.3.3.tgz", 487 | "integrity": "sha512-CiyeOxFT/JZyN5m0z9PfXw4SCBJ6Sygz1Dpl0wqjlhDEGGBP1GnsUVEL0p63hoG1fcj3fHynXi9NYO4nWOL+qQ==", 488 | "dev": true 489 | }, 490 | "path-is-absolute": { 491 | "version": "1.0.1", 492 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 493 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=", 494 | "dev": true 495 | }, 496 | "path-to-regexp": { 497 | "version": "0.1.7", 498 | "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-0.1.7.tgz", 499 | "integrity": "sha1-32BBeABfUi8V60SQ5yR6G/qmf4w=", 500 | "dev": true 501 | }, 502 | "pend": { 503 | "version": "1.2.0", 504 | "resolved": "https://registry.npmjs.org/pend/-/pend-1.2.0.tgz", 505 | "integrity": "sha1-elfrVQpng/kRUzH89GY9XI4AelA=", 506 | "dev": true 507 | }, 508 | "process-nextick-args": { 509 | "version": "2.0.1", 510 | "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-2.0.1.tgz", 511 | "integrity": "sha512-3ouUOpQhtgrbOa17J7+uxOTpITYWaGP7/AhoR3+A+/1e9skrzelGi/dXzEYyvbxubEF6Wn2ypscTKiKJFFn1ag==", 512 | "dev": true 513 | }, 514 | "progress": { 515 | "version": "2.0.3", 516 | "resolved": "https://registry.npmjs.org/progress/-/progress-2.0.3.tgz", 517 | "integrity": "sha512-7PiHtLll5LdnKIMw100I+8xJXR5gW2QwWYkT6iJva0bXitZKa/XMrSbdmg3r2Xnaidz9Qumd0VPaMrZlF9V9sA==", 518 | "dev": true 519 | }, 520 | "proxy-addr": { 521 | "version": "2.0.5", 522 | "resolved": "https://registry.npmjs.org/proxy-addr/-/proxy-addr-2.0.5.tgz", 523 | "integrity": "sha512-t/7RxHXPH6cJtP0pRG6smSr9QJidhB+3kXu0KgXnbGYMgzEnUxRQ4/LDdfOwZEMyIh3/xHb8PX3t+lfL9z+YVQ==", 524 | "dev": true, 525 | "requires": { 526 | "forwarded": "~0.1.2", 527 | "ipaddr.js": "1.9.0" 528 | } 529 | }, 530 | "proxy-from-env": { 531 | "version": "1.0.0", 532 | "resolved": "https://registry.npmjs.org/proxy-from-env/-/proxy-from-env-1.0.0.tgz", 533 | "integrity": "sha1-M8UDmPcOp+uW0h97gXYwpVeRx+4=", 534 | "dev": true 535 | }, 536 | "puppeteer": { 537 | "version": "2.0.0", 538 | "resolved": "https://registry.npmjs.org/puppeteer/-/puppeteer-2.0.0.tgz", 539 | "integrity": "sha512-t3MmTWzQxPRP71teU6l0jX47PHXlc4Z52sQv4LJQSZLq1ttkKS2yGM3gaI57uQwZkNaoGd0+HPPMELZkcyhlqA==", 540 | "dev": true, 541 | "requires": { 542 | "debug": "^4.1.0", 543 | "extract-zip": "^1.6.6", 544 | "https-proxy-agent": "^3.0.0", 545 | "mime": "^2.0.3", 546 | "progress": "^2.0.1", 547 | "proxy-from-env": "^1.0.0", 548 | "rimraf": "^2.6.1", 549 | "ws": "^6.1.0" 550 | }, 551 | "dependencies": { 552 | "debug": { 553 | "version": "4.1.1", 554 | "resolved": "https://registry.npmjs.org/debug/-/debug-4.1.1.tgz", 555 | "integrity": "sha512-pYAIzeRo8J6KPEaJ0VWOh5Pzkbw/RetuzehGM7QRRX5he4fPHx2rdKMB256ehJCkX+XRQm16eZLqLNS8RSZXZw==", 556 | "dev": true, 557 | "requires": { 558 | "ms": "^2.1.1" 559 | } 560 | }, 561 | "mime": { 562 | "version": "2.4.4", 563 | "resolved": "https://registry.npmjs.org/mime/-/mime-2.4.4.tgz", 564 | "integrity": "sha512-LRxmNwziLPT828z+4YkNzloCFC2YM4wrB99k+AV5ZbEyfGNWfG8SO1FUXLmLDBSo89NrJZ4DIWeLjy1CHGhMGA==", 565 | "dev": true 566 | }, 567 | "ms": { 568 | "version": "2.1.2", 569 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 570 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 571 | "dev": true 572 | } 573 | } 574 | }, 575 | "qs": { 576 | "version": "6.7.0", 577 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.7.0.tgz", 578 | "integrity": "sha512-VCdBRNFTX1fyE7Nb6FYoURo/SPe62QCaAyzJvUjwRaIsc+NePBEniHlvxFmmX56+HZphIGtV0XeCirBtpDrTyQ==", 579 | "dev": true 580 | }, 581 | "range-parser": { 582 | "version": "1.2.1", 583 | "resolved": "https://registry.npmjs.org/range-parser/-/range-parser-1.2.1.tgz", 584 | "integrity": "sha512-Hrgsx+orqoygnmhFbKaHE6c296J+HTAQXoxEF6gNupROmmGJRoyzfG3ccAveqCBrwr/2yxQ5BVd/GTl5agOwSg==", 585 | "dev": true 586 | }, 587 | "raw-body": { 588 | "version": "2.4.0", 589 | "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-2.4.0.tgz", 590 | "integrity": "sha512-4Oz8DUIwdvoa5qMJelxipzi/iJIi40O5cGV1wNYp5hvZP8ZN0T+jiNkL0QepXs+EsQ9XJ8ipEDoiH70ySUJP3Q==", 591 | "dev": true, 592 | "requires": { 593 | "bytes": "3.1.0", 594 | "http-errors": "1.7.2", 595 | "iconv-lite": "0.4.24", 596 | "unpipe": "1.0.0" 597 | } 598 | }, 599 | "readable-stream": { 600 | "version": "2.3.6", 601 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.6.tgz", 602 | "integrity": "sha512-tQtKA9WIAhBF3+VLAseyMqZeBjW0AHJoxOtYqSUZNJxauErmLbVm2FW1y+J/YA9dUrAC39ITejlZWhVIwawkKw==", 603 | "dev": true, 604 | "requires": { 605 | "core-util-is": "~1.0.0", 606 | "inherits": "~2.0.3", 607 | "isarray": "~1.0.0", 608 | "process-nextick-args": "~2.0.0", 609 | "safe-buffer": "~5.1.1", 610 | "string_decoder": "~1.1.1", 611 | "util-deprecate": "~1.0.1" 612 | } 613 | }, 614 | "rimraf": { 615 | "version": "2.7.1", 616 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.7.1.tgz", 617 | "integrity": "sha512-uWjbaKIK3T1OSVptzX7Nl6PvQ3qAGtKEtVRjRuazjfL3Bx5eI409VZSqgND+4UNnmzLVdPj9FqFJNPqBZFve4w==", 618 | "dev": true, 619 | "requires": { 620 | "glob": "^7.1.3" 621 | } 622 | }, 623 | "safe-buffer": { 624 | "version": "5.1.2", 625 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 626 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==", 627 | "dev": true 628 | }, 629 | "safer-buffer": { 630 | "version": "2.1.2", 631 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", 632 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==", 633 | "dev": true 634 | }, 635 | "send": { 636 | "version": "0.17.1", 637 | "resolved": "https://registry.npmjs.org/send/-/send-0.17.1.tgz", 638 | "integrity": "sha512-BsVKsiGcQMFwT8UxypobUKyv7irCNRHk1T0G680vk88yf6LBByGcZJOTJCrTP2xVN6yI+XjPJcNuE3V4fT9sAg==", 639 | "dev": true, 640 | "requires": { 641 | "debug": "2.6.9", 642 | "depd": "~1.1.2", 643 | "destroy": "~1.0.4", 644 | "encodeurl": "~1.0.2", 645 | "escape-html": "~1.0.3", 646 | "etag": "~1.8.1", 647 | "fresh": "0.5.2", 648 | "http-errors": "~1.7.2", 649 | "mime": "1.6.0", 650 | "ms": "2.1.1", 651 | "on-finished": "~2.3.0", 652 | "range-parser": "~1.2.1", 653 | "statuses": "~1.5.0" 654 | }, 655 | "dependencies": { 656 | "ms": { 657 | "version": "2.1.1", 658 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.1.tgz", 659 | "integrity": "sha512-tgp+dl5cGk28utYktBsrFqA7HKgrhgPsg6Z/EfhWI4gl1Hwq8B/GmY/0oXZ6nF8hDVesS/FpnYaD/kOWhYQvyg==", 660 | "dev": true 661 | } 662 | } 663 | }, 664 | "serve-static": { 665 | "version": "1.14.1", 666 | "resolved": "https://registry.npmjs.org/serve-static/-/serve-static-1.14.1.tgz", 667 | "integrity": "sha512-JMrvUwE54emCYWlTI+hGrGv5I8dEwmco/00EvkzIIsR7MqrHonbD9pO2MOfFnpFntl7ecpZs+3mW+XbQZu9QCg==", 668 | "dev": true, 669 | "requires": { 670 | "encodeurl": "~1.0.2", 671 | "escape-html": "~1.0.3", 672 | "parseurl": "~1.3.3", 673 | "send": "0.17.1" 674 | } 675 | }, 676 | "setprototypeof": { 677 | "version": "1.1.1", 678 | "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.1.1.tgz", 679 | "integrity": "sha512-JvdAWfbXeIGaZ9cILp38HntZSFSo3mWg6xGcJJsd+d4aRMOqauag1C63dJfDw7OaMYwEbHMOxEZ1lqVRYP2OAw==", 680 | "dev": true 681 | }, 682 | "statuses": { 683 | "version": "1.5.0", 684 | "resolved": "https://registry.npmjs.org/statuses/-/statuses-1.5.0.tgz", 685 | "integrity": "sha1-Fhx9rBd2Wf2YEfQ3cfqZOBR4Yow=", 686 | "dev": true 687 | }, 688 | "string_decoder": { 689 | "version": "1.1.1", 690 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", 691 | "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", 692 | "dev": true, 693 | "requires": { 694 | "safe-buffer": "~5.1.0" 695 | } 696 | }, 697 | "toidentifier": { 698 | "version": "1.0.0", 699 | "resolved": "https://registry.npmjs.org/toidentifier/-/toidentifier-1.0.0.tgz", 700 | "integrity": "sha512-yaOH/Pk/VEhBWWTlhI+qXxDFXlejDGcQipMlyxda9nthulaxLZUNcUqFxokp0vcYnvteJln5FNQDRrxj3YcbVw==", 701 | "dev": true 702 | }, 703 | "type-is": { 704 | "version": "1.6.18", 705 | "resolved": "https://registry.npmjs.org/type-is/-/type-is-1.6.18.tgz", 706 | "integrity": "sha512-TkRKr9sUTxEH8MdfuCSP7VizJyzRNMjj2J2do2Jr3Kym598JVdEksuzPQCnlFPW4ky9Q+iA+ma9BGm06XQBy8g==", 707 | "dev": true, 708 | "requires": { 709 | "media-typer": "0.3.0", 710 | "mime-types": "~2.1.24" 711 | } 712 | }, 713 | "typedarray": { 714 | "version": "0.0.6", 715 | "resolved": "https://registry.npmjs.org/typedarray/-/typedarray-0.0.6.tgz", 716 | "integrity": "sha1-hnrHTjhkGHsdPUfZlqeOxciDB3c=", 717 | "dev": true 718 | }, 719 | "unpipe": { 720 | "version": "1.0.0", 721 | "resolved": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz", 722 | "integrity": "sha1-sr9O6FFKrmFltIF4KdIbLvSZBOw=", 723 | "dev": true 724 | }, 725 | "util-deprecate": { 726 | "version": "1.0.2", 727 | "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", 728 | "integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8=", 729 | "dev": true 730 | }, 731 | "utils-merge": { 732 | "version": "1.0.1", 733 | "resolved": "https://registry.npmjs.org/utils-merge/-/utils-merge-1.0.1.tgz", 734 | "integrity": "sha1-n5VxD1CiZ5R7LMwSR0HBAoQn5xM=", 735 | "dev": true 736 | }, 737 | "vary": { 738 | "version": "1.1.2", 739 | "resolved": "https://registry.npmjs.org/vary/-/vary-1.1.2.tgz", 740 | "integrity": "sha1-IpnwLG3tMNSllhsLn3RSShj2NPw=", 741 | "dev": true 742 | }, 743 | "wrappy": { 744 | "version": "1.0.2", 745 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 746 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=", 747 | "dev": true 748 | }, 749 | "ws": { 750 | "version": "6.2.1", 751 | "resolved": "https://registry.npmjs.org/ws/-/ws-6.2.1.tgz", 752 | "integrity": "sha512-GIyAXC2cB7LjvpgMt9EKS2ldqr0MTrORaleiOno6TweZ6r3TKtoFQWay/2PceJ3RuBasOHzXNn5Lrw1X0bEjqA==", 753 | "dev": true, 754 | "requires": { 755 | "async-limiter": "~1.0.0" 756 | } 757 | }, 758 | "yauzl": { 759 | "version": "2.4.1", 760 | "resolved": "https://registry.npmjs.org/yauzl/-/yauzl-2.4.1.tgz", 761 | "integrity": "sha1-lSj0QtqxsihOWLQ3m7GU4i4MQAU=", 762 | "dev": true, 763 | "requires": { 764 | "fd-slicer": "~1.0.1" 765 | } 766 | } 767 | } 768 | } 769 | -------------------------------------------------------------------------------- /headless-browser/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "wc-prerender", 3 | "version": "1.0.0", 4 | "description": "My master thesis project regarding pre-rendering of Web Components", 5 | "author": "Andreas Hahn", 6 | "license": "MIT", 7 | "scripts": { 8 | "start": "ts-node server.ts", 9 | "render": "ts-node prerender.ts" 10 | }, 11 | "dependencies": { 12 | "@types/puppeteer": "^2.0.0" 13 | }, 14 | "devDependencies": { 15 | "express": "^4.17.1", 16 | "puppeteer": "^2.0.0", 17 | "ts-node": "^8.6.2" 18 | }, 19 | "repository": { 20 | "type": "git", 21 | "url": "git+https://github.com/drdreo/wc-prerender.git" 22 | }, 23 | "keywords": [ 24 | "webcomponents", 25 | "prerendering" 26 | ] 27 | } 28 | -------------------------------------------------------------------------------- /headless-browser/prerender.ts: -------------------------------------------------------------------------------- 1 | const path = require('path'); 2 | const fs = require('fs'); 3 | 4 | import { render, launched, stopBrowser } from './render'; 5 | import { rehydrate } from './hydrate'; 6 | 7 | const file = '/public/pages/index.html'; 8 | 9 | // need to wait for the browser to launch 10 | launched 11 | .then(() => { 12 | render(file) 13 | .then((pageContent: string) => { 14 | console.log('[Headless Browser] Pre-rendering finished!'); 15 | fs.writeFile( 16 | path.join(__dirname, file.replace('.html', '.ssr.html')), 17 | // add re-hydration script to the end of 18 | pageContent.replace('', `${rehydrate}`), 19 | { encoding: 'utf8' }, 20 | async (err) => { 21 | if (err) console.log(err); 22 | }, 23 | ); 24 | 25 | stopBrowser(); 26 | }); 27 | }); 28 | -------------------------------------------------------------------------------- /headless-browser/public/components/color-text.js: -------------------------------------------------------------------------------- 1 | class ColorText extends HTMLElement { 2 | connectedCallback() { 3 | this.attachShadow({mode: "open"}); 4 | this.shadowRoot.innerHTML = ` 5 | `; 6 | } 7 | } 8 | 9 | window.customElements.define("color-text", ColorText); 10 | -------------------------------------------------------------------------------- /headless-browser/public/components/my-hello.js: -------------------------------------------------------------------------------- 1 | class Hello extends HTMLElement { 2 | connectedCallback() { 3 | this.attachShadow({mode: "open"}); 4 | this.shadowRoot.innerHTML = ` 5 | ${this.getAttribute("greeting")}, 6 | ! 7 | `; 8 | } 9 | 10 | get greeting() { 11 | return this.getAttribute("greeting"); 12 | } 13 | 14 | set greeting(value) { 15 | this.shadowRoot.querySelector("[data-greeting]").innerHTML = value; 16 | this.setAttribute("greeting", value); 17 | } 18 | } 19 | 20 | window.customElements.define("my-hello", Hello); 21 | -------------------------------------------------------------------------------- /headless-browser/public/components/real-counter.js: -------------------------------------------------------------------------------- 1 | class RealCounter extends HTMLElement { 2 | 3 | counterValue = 0; 4 | 5 | constructor() { 6 | super(); 7 | 8 | setInterval(() => { 9 | this.counter++; 10 | }, 500); 11 | } 12 | 13 | connectedCallback() { 14 | this.attachShadow({mode: "open"}); 15 | this.render(); 16 | } 17 | 18 | set counter(time) { 19 | this.counterValue = time; 20 | this.render(); 21 | } 22 | 23 | get counter() { 24 | return this.counterValue; 25 | } 26 | 27 | render() { 28 | this.shadowRoot.innerHTML = `${this.counter}!`; 29 | } 30 | } 31 | 32 | window.customElements.define("real-counter", RealCounter); 33 | -------------------------------------------------------------------------------- /headless-browser/public/pages/index.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | Headless Browser | WC Pre-Render 6 | 7 | 8 | 9 | 10 | 11 | 12 |

Index.HTML

13 | Felix 14 | 15 | ignored 16 | 17 | 18 | 19 | -------------------------------------------------------------------------------- /headless-browser/public/pages/index.ssr.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | Headless Browser | WC Pre-Render 4 | 5 | 6 | 7 | 8 | 9 | 10 |

Index.HTML

11 | 12 | Sias, 13 | Felix! 14 | 15 | 16 | 0 17 | 18 | 19 | 20 | -------------------------------------------------------------------------------- /headless-browser/render.ts: -------------------------------------------------------------------------------- 1 | const path = require('path'); 2 | const puppeteer = require('puppeteer'); 3 | 4 | import { serialize } from './serialize'; 5 | 6 | let browser = null; 7 | let page = null; 8 | 9 | export const launched = puppeteer.launch().then(b => { 10 | return new Promise(resolve => { 11 | 12 | browser = b; 13 | 14 | browser.newPage().then(p => { 15 | page = p; 16 | // puppeteer console.log handler 17 | page.on('console', async msg => { 18 | const args = await msg.args(); 19 | for (const arg of args) { 20 | const val = await arg.jsonValue(); 21 | // value is serializable 22 | if (JSON.stringify(val) !== JSON.stringify({})) console.log(val); 23 | // value is unserializable (or an empty oject) 24 | else { 25 | const { type, subtype, description } = arg._remoteObject; 26 | console.log(`type: ${type}, subtype: ${subtype}, description:\n ${description}`); 27 | } 28 | } 29 | }); 30 | 31 | resolve(); 32 | }); 33 | }); 34 | }); 35 | 36 | export function stopBrowser() { 37 | browser.close(); 38 | } 39 | 40 | export async function render(fileName: string): Promise { 41 | return new Promise(async (resolve, reject) => { 42 | page.removeAllListeners('load'); 43 | // when the page was loaded, serialize the body content and write it to a file 44 | page.on('load', async (...args) => { 45 | await page.$eval('body', serialize); 46 | let content = await page.content(); 47 | resolve(content); 48 | }); 49 | await page.goto('file://' + path.join(__dirname, fileName)); 50 | 51 | }); 52 | } 53 | -------------------------------------------------------------------------------- /headless-browser/serialize.ts: -------------------------------------------------------------------------------- 1 | export function serialize(rootNode) { 2 | function serializeNode(node) { 3 | 4 | try { 5 | // check if the node is a web-component 6 | if (node.shadowRoot) { 7 | const lightDomNodes = node.childNodes; 8 | const lightDomHtml = node.innerHTML; 9 | const templateDom = document.createElement('template'); 10 | templateDom.setAttribute('type', 'ssr-light-dom'); 11 | templateDom.innerHTML = lightDomHtml; 12 | const scriptData = document.createElement('script'); 13 | const attributesProperties = node.getAttributeNames() 14 | .filter(name => name !== 'data-ssr') 15 | .reduce((obj, name) => ({...obj, [name]: node.getAttribute(name)}), {}); 16 | 17 | scriptData.setAttribute('type', 'ssr-data'); 18 | scriptData.innerHTML = JSON.stringify(attributesProperties); 19 | 20 | const slot = node.shadowRoot.querySelector('slot'); 21 | 22 | // only move light nodes into shadow if there is a 23 | if (slot) { 24 | // insert the light DOM right before the 25 | lightDomNodes.forEach(lightNode => slot.parentNode.insertBefore(lightNode, slot)); 26 | slot.parentNode.removeChild(slot); 27 | } 28 | 29 | // move shadowDom into root node 30 | node.shadowRoot.childNodes.forEach(shadowNode => node.appendChild(shadowNode)); 31 | 32 | // serialize custom element child nodes 33 | serialize(node); 34 | 35 | // add original lightDom as template 36 | if (templateDom.innerHTML !== '') { 37 | node.appendChild(templateDom); 38 | } 39 | 40 | if (scriptData.innerHTML !== '{}') { 41 | node.appendChild(scriptData); 42 | } 43 | 44 | node.setAttribute('data-ssr', 'serialized'); 45 | } else { 46 | console.error('<' + node.nodeName + '> missing shadowRoot!'); 47 | } 48 | } catch (err) { 49 | console.log('error:', err); 50 | } 51 | } 52 | 53 | [...rootNode.querySelectorAll('*')] 54 | .filter(element => /-/.test(element.nodeName)) 55 | .forEach(serializeNode); 56 | } 57 | -------------------------------------------------------------------------------- /headless-browser/server.ts: -------------------------------------------------------------------------------- 1 | import { join } from 'path'; 2 | import express from 'express'; 3 | import { render } from './render'; 4 | import { rehydrate } from './hydrate'; 5 | 6 | const server = express(); 7 | const PORT = 3001; 8 | 9 | server.use(express.static('public')); 10 | 11 | server.get('/', (req, res) => { 12 | res.redirect('/index.ssr.html'); 13 | }); 14 | 15 | const timings = []; 16 | server.get('/ssr', async (req, res) => { 17 | const file = '/public/pages/index.html'; 18 | 19 | const startTime = process.hrtime() 20 | const pageContent = await render(file); 21 | const endTime = process.hrtime(startTime)[1] / 1000000; 22 | timings.push(endTime); 23 | console.info('time: %dms', endTime); 24 | res.send(pageContent.replace('', `${rehydrate}`)); 25 | }); 26 | 27 | server.get('/avg', async (req, res) => { 28 | res.json({data: timings, total: timings.length -1, avg: timings.reduce((a,b) => a + b, 0) / timings.length}); 29 | }); 30 | 31 | server.get('*', (req, res, next) => { 32 | console.log('Serving: ', req.url); 33 | let htmlFile = req.url; 34 | res.sendFile(join(__dirname + '/public/pages/' + htmlFile)); 35 | }); 36 | 37 | server.listen(PORT, () => { 38 | console.log(`Server listening at http://localhost:${PORT}`); 39 | }); 40 | -------------------------------------------------------------------------------- /headless-browser/tsconfig.json: -------------------------------------------------------------------------------- 1 | { 2 | "compilerOptions": { 3 | "target": "es6", 4 | "module": "commonjs", 5 | "outDir": "dist", 6 | "sourceMap": true, 7 | "resolveJsonModule": true, 8 | "lib": ["es6", "dom"], 9 | "esModuleInterop": true 10 | }, 11 | "include": [ 12 | "**/*.ts" 13 | ], 14 | "exclude": [ 15 | "node_modules" 16 | ] 17 | } 18 | -------------------------------------------------------------------------------- /package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "wc-prerender", 3 | "version": "1.0.0", 4 | "lockfileVersion": 1, 5 | "requires": true, 6 | "dependencies": { 7 | "@types/body-parser": { 8 | "version": "1.17.1", 9 | "resolved": "https://registry.npmjs.org/@types/body-parser/-/body-parser-1.17.1.tgz", 10 | "integrity": "sha512-RoX2EZjMiFMjZh9lmYrwgoP9RTpAjSHiJxdp4oidAQVO02T7HER3xj9UKue5534ULWeqVEkujhWcyvUce+d68w==", 11 | "dev": true, 12 | "requires": { 13 | "@types/connect": "*", 14 | "@types/node": "*" 15 | } 16 | }, 17 | "@types/connect": { 18 | "version": "3.4.32", 19 | "resolved": "https://registry.npmjs.org/@types/connect/-/connect-3.4.32.tgz", 20 | "integrity": "sha512-4r8qa0quOvh7lGD0pre62CAb1oni1OO6ecJLGCezTmhQ8Fz50Arx9RUszryR8KlgK6avuSXvviL6yWyViQABOg==", 21 | "dev": true, 22 | "requires": { 23 | "@types/node": "*" 24 | } 25 | }, 26 | "@types/express": { 27 | "version": "4.17.2", 28 | "resolved": "https://registry.npmjs.org/@types/express/-/express-4.17.2.tgz", 29 | "integrity": "sha512-5mHFNyavtLoJmnusB8OKJ5bshSzw+qkMIBAobLrIM48HJvunFva9mOa6aBwh64lBFyNwBbs0xiEFuj4eU/NjCA==", 30 | "dev": true, 31 | "requires": { 32 | "@types/body-parser": "*", 33 | "@types/express-serve-static-core": "*", 34 | "@types/serve-static": "*" 35 | } 36 | }, 37 | "@types/express-serve-static-core": { 38 | "version": "4.17.0", 39 | "resolved": "https://registry.npmjs.org/@types/express-serve-static-core/-/express-serve-static-core-4.17.0.tgz", 40 | "integrity": "sha512-Xnub7w57uvcBqFdIGoRg1KhNOeEj0vB6ykUM7uFWyxvbdE89GFyqgmUcanAriMr4YOxNFZBAWkfcWIb4WBPt3g==", 41 | "dev": true, 42 | "requires": { 43 | "@types/node": "*", 44 | "@types/range-parser": "*" 45 | } 46 | }, 47 | "@types/mime": { 48 | "version": "2.0.1", 49 | "resolved": "https://registry.npmjs.org/@types/mime/-/mime-2.0.1.tgz", 50 | "integrity": "sha512-FwI9gX75FgVBJ7ywgnq/P7tw+/o1GUbtP0KzbtusLigAOgIgNISRK0ZPl4qertvXSIE8YbsVJueQ90cDt9YYyw==", 51 | "dev": true 52 | }, 53 | "@types/node": { 54 | "version": "12.12.7", 55 | "resolved": "https://registry.npmjs.org/@types/node/-/node-12.12.7.tgz", 56 | "integrity": "sha512-E6Zn0rffhgd130zbCbAr/JdXfXkoOUFAKNs/rF8qnafSJ8KYaA/j3oz7dcwal+lYjLA7xvdd5J4wdYpCTlP8+w==" 57 | }, 58 | "@types/range-parser": { 59 | "version": "1.2.3", 60 | "resolved": "https://registry.npmjs.org/@types/range-parser/-/range-parser-1.2.3.tgz", 61 | "integrity": "sha512-ewFXqrQHlFsgc09MK5jP5iR7vumV/BYayNC6PgJO2LPe8vrnNFyjQjSppfEngITi0qvfKtzFvgKymGheFM9UOA==", 62 | "dev": true 63 | }, 64 | "@types/serve-static": { 65 | "version": "1.13.3", 66 | "resolved": "https://registry.npmjs.org/@types/serve-static/-/serve-static-1.13.3.tgz", 67 | "integrity": "sha512-oprSwp094zOglVrXdlo/4bAHtKTAxX6VT8FOZlBKrmyLbNvE1zxZyJ6yikMVtHIvwP45+ZQGJn+FdXGKTozq0g==", 68 | "dev": true, 69 | "requires": { 70 | "@types/express-serve-static-core": "*", 71 | "@types/mime": "*" 72 | } 73 | }, 74 | "arg": { 75 | "version": "4.1.1", 76 | "resolved": "https://registry.npmjs.org/arg/-/arg-4.1.1.tgz", 77 | "integrity": "sha512-SlmP3fEA88MBv0PypnXZ8ZfJhwmDeIE3SP71j37AiXQBXYosPV0x6uISAaHYSlSVhmHOVkomen0tbGk6Anlebw==" 78 | }, 79 | "buffer-from": { 80 | "version": "1.1.1", 81 | "resolved": "https://registry.npmjs.org/buffer-from/-/buffer-from-1.1.1.tgz", 82 | "integrity": "sha512-MQcXEUbCKtEo7bhqEs6560Hyd4XaovZlO/k9V3hjVUF/zwW7KBVdSK4gIt/bzwS9MbR5qob+F5jusZsb0YQK2A==" 83 | }, 84 | "diff": { 85 | "version": "4.0.1", 86 | "resolved": "https://registry.npmjs.org/diff/-/diff-4.0.1.tgz", 87 | "integrity": "sha512-s2+XdvhPCOF01LRQBC8hf4vhbVmI2CGS5aZnxLJlT5FtdhPCDFq80q++zK2KlrVorVDdL5BOGZ/VfLrVtYNF+Q==" 88 | }, 89 | "make-error": { 90 | "version": "1.3.5", 91 | "resolved": "https://registry.npmjs.org/make-error/-/make-error-1.3.5.tgz", 92 | "integrity": "sha512-c3sIjNUow0+8swNwVpqoH4YCShKNFkMaw6oH1mNS2haDZQqkeZFlHS3dhoeEbKKmJB4vXpJucU6oH75aDYeE9g==" 93 | }, 94 | "source-map": { 95 | "version": "0.6.1", 96 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", 97 | "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==" 98 | }, 99 | "source-map-support": { 100 | "version": "0.5.16", 101 | "resolved": "https://registry.npmjs.org/source-map-support/-/source-map-support-0.5.16.tgz", 102 | "integrity": "sha512-efyLRJDr68D9hBBNIPWFjhpFzURh+KJykQwvMyW5UiZzYwoF6l4YMMDIJJEyFWxWCqfyxLzz6tSfUFR+kXXsVQ==", 103 | "requires": { 104 | "buffer-from": "^1.0.0", 105 | "source-map": "^0.6.0" 106 | } 107 | }, 108 | "ts-node": { 109 | "version": "8.4.1", 110 | "resolved": "https://registry.npmjs.org/ts-node/-/ts-node-8.4.1.tgz", 111 | "integrity": "sha512-5LpRN+mTiCs7lI5EtbXmF/HfMeCjzt7DH9CZwtkr6SywStrNQC723wG+aOWFiLNn7zT3kD/RnFqi3ZUfr4l5Qw==", 112 | "requires": { 113 | "arg": "^4.1.0", 114 | "diff": "^4.0.1", 115 | "make-error": "^1.1.1", 116 | "source-map-support": "^0.5.6", 117 | "yn": "^3.0.0" 118 | } 119 | }, 120 | "typescript": { 121 | "version": "3.7.2", 122 | "resolved": "https://registry.npmjs.org/typescript/-/typescript-3.7.2.tgz", 123 | "integrity": "sha512-ml7V7JfiN2Xwvcer+XAf2csGO1bPBdRbFCkYBczNZggrBZ9c7G3riSUeJmqEU5uOtXNPMhE3n+R4FA/3YOAWOQ==" 124 | }, 125 | "yn": { 126 | "version": "3.1.1", 127 | "resolved": "https://registry.npmjs.org/yn/-/yn-3.1.1.tgz", 128 | "integrity": "sha512-Ux4ygGWsu2c7isFWe8Yu1YluJmqVhxqK2cLXNQA5AcC3QfbGNpM7fu0Y8b/z16pXLnFxZYvWhd3fhBY9DLmC6Q==" 129 | } 130 | } 131 | } 132 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "wc-prerender", 3 | "version": "1.0.0", 4 | "description": "My master thesis project regarding pre-rendering of Web Components", 5 | "author": "Andreas Hahn", 6 | "license": "MIT", 7 | "dependencies": { 8 | "ts-node": "^8.4.1", 9 | "typescript": "^3.6.4" 10 | }, 11 | "devDependencies": { 12 | "@types/express": "^4.17.2", 13 | "@types/node": "^12.12.3" 14 | }, 15 | "repository": { 16 | "type": "git", 17 | "url": "git+https://github.com/drdreo/wc-prerender.git" 18 | }, 19 | "keywords": [ 20 | "webcomponents", 21 | "prerendering" 22 | ] 23 | } 24 | -------------------------------------------------------------------------------- /skate-ssr/README.md: -------------------------------------------------------------------------------- 1 | # skatejs/ssr 2 | The way how skate.js renders web components. 3 | 4 | [Article](https://medium.com/@treshugart/%C3%A5server-side-rendering-web-components-e5df705f3f48) 5 | 6 | ## Run 7 | Enter `npm run render` in your terminal. 8 | Enter `npm start` in your terminal. 9 | 10 | ## TODO 11 | * fix `module.exports` in component for browser support 12 | -------------------------------------------------------------------------------- /skate-ssr/package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "wc-prerender", 3 | "version": "1.0.0", 4 | "lockfileVersion": 1, 5 | "requires": true, 6 | "dependencies": { 7 | "@babel/code-frame": { 8 | "version": "7.5.5", 9 | "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.5.5.tgz", 10 | "integrity": "sha512-27d4lZoomVyo51VegxI20xZPuSHusqbQag/ztrBC7wegWoQ1nLREPVSKSW8byhTlzTKyNE4ifaTA6lCp7JjpFw==", 11 | "requires": { 12 | "@babel/highlight": "^7.0.0" 13 | } 14 | }, 15 | "@babel/highlight": { 16 | "version": "7.5.0", 17 | "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.5.0.tgz", 18 | "integrity": "sha512-7dV4eu9gBxoM0dAnj/BCFDW9LFU0zvTrkq0ugM7pnHEgguOEeOz1so2ZghEdzviYzQEED0r4EAgpsBChKy1TRQ==", 19 | "requires": { 20 | "chalk": "^2.0.0", 21 | "esutils": "^2.0.2", 22 | "js-tokens": "^4.0.0" 23 | }, 24 | "dependencies": { 25 | "ansi-styles": { 26 | "version": "3.2.1", 27 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 28 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 29 | "requires": { 30 | "color-convert": "^1.9.0" 31 | } 32 | }, 33 | "chalk": { 34 | "version": "2.4.2", 35 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", 36 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", 37 | "requires": { 38 | "ansi-styles": "^3.2.1", 39 | "escape-string-regexp": "^1.0.5", 40 | "supports-color": "^5.3.0" 41 | } 42 | }, 43 | "js-tokens": { 44 | "version": "4.0.0", 45 | "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", 46 | "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==" 47 | }, 48 | "supports-color": { 49 | "version": "5.5.0", 50 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 51 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 52 | "requires": { 53 | "has-flag": "^3.0.0" 54 | } 55 | } 56 | } 57 | }, 58 | "@skatejs/ssr": { 59 | "version": "0.19.11", 60 | "resolved": "https://registry.npmjs.org/@skatejs/ssr/-/ssr-0.19.11.tgz", 61 | "integrity": "sha512-Mdp7e+zTlIG8/b5X1rie5YXVNb2Rb0izIliGl2PX4NWGjQfLX2NsLyvfN5WD6Y524xadPOa1DkEnEJ3kfY9now==", 62 | "requires": { 63 | "babel-register": "^6.26.0", 64 | "glob": "^7.1.2", 65 | "jest-environment-node": "^23.4.0", 66 | "js-beautify": "^1.7.5", 67 | "mkdirp": "^0.5.1", 68 | "outdent": "^0.5.0", 69 | "parse5": "^4.0.0", 70 | "preact": "^8.2.7", 71 | "uglify-es": "^3.3.10", 72 | "undom": "^0.3.3", 73 | "yargs": "^11.0.0" 74 | } 75 | }, 76 | "abbrev": { 77 | "version": "1.1.1", 78 | "resolved": "https://registry.npmjs.org/abbrev/-/abbrev-1.1.1.tgz", 79 | "integrity": "sha512-nne9/IiQ/hzIhY6pdDnbBtz7DjPTKrY00P/zvPSm5pOFkl6xuGrGnXn/VtTNNfNtAfZ9/1RtehkszU9qcTii0Q==" 80 | }, 81 | "accepts": { 82 | "version": "1.3.7", 83 | "resolved": "https://registry.npmjs.org/accepts/-/accepts-1.3.7.tgz", 84 | "integrity": "sha512-Il80Qs2WjYlJIBNzNkK6KYqlVMTbZLXgHx2oT0pU/fjRHyEp+PEfEPY0R3WCwAGVOtauxh1hOxNgIf5bv7dQpA==", 85 | "dev": true, 86 | "requires": { 87 | "mime-types": "~2.1.24", 88 | "negotiator": "0.6.2" 89 | } 90 | }, 91 | "ansi-regex": { 92 | "version": "2.1.1", 93 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-2.1.1.tgz", 94 | "integrity": "sha1-w7M6te42DYbg5ijwRorn7yfWVN8=" 95 | }, 96 | "ansi-styles": { 97 | "version": "2.2.1", 98 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-2.2.1.tgz", 99 | "integrity": "sha1-tDLdM1i2NM914eRmQ2gkBTPB3b4=" 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 | "requires": { 106 | "arr-flatten": "^1.0.1" 107 | } 108 | }, 109 | "arr-flatten": { 110 | "version": "1.1.0", 111 | "resolved": "https://registry.npmjs.org/arr-flatten/-/arr-flatten-1.1.0.tgz", 112 | "integrity": "sha512-L3hKV5R/p5o81R7O02IGnwpDmkp6E982XhtbuwSe3O4qOtMMMtodicASA1Cny2U+aCXcNpml+m4dPsvsJ3jatg==" 113 | }, 114 | "array-flatten": { 115 | "version": "1.1.1", 116 | "resolved": "https://registry.npmjs.org/array-flatten/-/array-flatten-1.1.1.tgz", 117 | "integrity": "sha1-ml9pkFGx5wczKPKgCJaLZOopVdI=", 118 | "dev": true 119 | }, 120 | "array-unique": { 121 | "version": "0.2.1", 122 | "resolved": "https://registry.npmjs.org/array-unique/-/array-unique-0.2.1.tgz", 123 | "integrity": "sha1-odl8yvy8JiXMcPrc6zalDFiwGlM=" 124 | }, 125 | "babel-code-frame": { 126 | "version": "6.26.0", 127 | "resolved": "https://registry.npmjs.org/babel-code-frame/-/babel-code-frame-6.26.0.tgz", 128 | "integrity": "sha1-Y/1D99weO7fONZR9uP42mj9Yx0s=", 129 | "requires": { 130 | "chalk": "^1.1.3", 131 | "esutils": "^2.0.2", 132 | "js-tokens": "^3.0.2" 133 | } 134 | }, 135 | "babel-core": { 136 | "version": "6.26.3", 137 | "resolved": "https://registry.npmjs.org/babel-core/-/babel-core-6.26.3.tgz", 138 | "integrity": "sha512-6jyFLuDmeidKmUEb3NM+/yawG0M2bDZ9Z1qbZP59cyHLz8kYGKYwpJP0UwUKKUiTRNvxfLesJnTedqczP7cTDA==", 139 | "requires": { 140 | "babel-code-frame": "^6.26.0", 141 | "babel-generator": "^6.26.0", 142 | "babel-helpers": "^6.24.1", 143 | "babel-messages": "^6.23.0", 144 | "babel-register": "^6.26.0", 145 | "babel-runtime": "^6.26.0", 146 | "babel-template": "^6.26.0", 147 | "babel-traverse": "^6.26.0", 148 | "babel-types": "^6.26.0", 149 | "babylon": "^6.18.0", 150 | "convert-source-map": "^1.5.1", 151 | "debug": "^2.6.9", 152 | "json5": "^0.5.1", 153 | "lodash": "^4.17.4", 154 | "minimatch": "^3.0.4", 155 | "path-is-absolute": "^1.0.1", 156 | "private": "^0.1.8", 157 | "slash": "^1.0.0", 158 | "source-map": "^0.5.7" 159 | } 160 | }, 161 | "babel-generator": { 162 | "version": "6.26.1", 163 | "resolved": "https://registry.npmjs.org/babel-generator/-/babel-generator-6.26.1.tgz", 164 | "integrity": "sha512-HyfwY6ApZj7BYTcJURpM5tznulaBvyio7/0d4zFOeMPUmfxkCjHocCuoLa2SAGzBI8AREcH3eP3758F672DppA==", 165 | "requires": { 166 | "babel-messages": "^6.23.0", 167 | "babel-runtime": "^6.26.0", 168 | "babel-types": "^6.26.0", 169 | "detect-indent": "^4.0.0", 170 | "jsesc": "^1.3.0", 171 | "lodash": "^4.17.4", 172 | "source-map": "^0.5.7", 173 | "trim-right": "^1.0.1" 174 | } 175 | }, 176 | "babel-helpers": { 177 | "version": "6.24.1", 178 | "resolved": "https://registry.npmjs.org/babel-helpers/-/babel-helpers-6.24.1.tgz", 179 | "integrity": "sha1-NHHenK7DiOXIUOWX5Yom3fN2ArI=", 180 | "requires": { 181 | "babel-runtime": "^6.22.0", 182 | "babel-template": "^6.24.1" 183 | } 184 | }, 185 | "babel-messages": { 186 | "version": "6.23.0", 187 | "resolved": "https://registry.npmjs.org/babel-messages/-/babel-messages-6.23.0.tgz", 188 | "integrity": "sha1-8830cDhYA1sqKVHG7F7fbGLyYw4=", 189 | "requires": { 190 | "babel-runtime": "^6.22.0" 191 | } 192 | }, 193 | "babel-register": { 194 | "version": "6.26.0", 195 | "resolved": "https://registry.npmjs.org/babel-register/-/babel-register-6.26.0.tgz", 196 | "integrity": "sha1-btAhFz4vy0htestFxgCahW9kcHE=", 197 | "requires": { 198 | "babel-core": "^6.26.0", 199 | "babel-runtime": "^6.26.0", 200 | "core-js": "^2.5.0", 201 | "home-or-tmp": "^2.0.0", 202 | "lodash": "^4.17.4", 203 | "mkdirp": "^0.5.1", 204 | "source-map-support": "^0.4.15" 205 | } 206 | }, 207 | "babel-runtime": { 208 | "version": "6.26.0", 209 | "resolved": "https://registry.npmjs.org/babel-runtime/-/babel-runtime-6.26.0.tgz", 210 | "integrity": "sha1-llxwWGaOgrVde/4E/yM3vItWR/4=", 211 | "requires": { 212 | "core-js": "^2.4.0", 213 | "regenerator-runtime": "^0.11.0" 214 | } 215 | }, 216 | "babel-template": { 217 | "version": "6.26.0", 218 | "resolved": "https://registry.npmjs.org/babel-template/-/babel-template-6.26.0.tgz", 219 | "integrity": "sha1-3gPi0WOWsGn0bdn/+FIfsaDjXgI=", 220 | "requires": { 221 | "babel-runtime": "^6.26.0", 222 | "babel-traverse": "^6.26.0", 223 | "babel-types": "^6.26.0", 224 | "babylon": "^6.18.0", 225 | "lodash": "^4.17.4" 226 | } 227 | }, 228 | "babel-traverse": { 229 | "version": "6.26.0", 230 | "resolved": "https://registry.npmjs.org/babel-traverse/-/babel-traverse-6.26.0.tgz", 231 | "integrity": "sha1-RqnL1+3MYsjlwGTi0tjQ9ANXZu4=", 232 | "requires": { 233 | "babel-code-frame": "^6.26.0", 234 | "babel-messages": "^6.23.0", 235 | "babel-runtime": "^6.26.0", 236 | "babel-types": "^6.26.0", 237 | "babylon": "^6.18.0", 238 | "debug": "^2.6.8", 239 | "globals": "^9.18.0", 240 | "invariant": "^2.2.2", 241 | "lodash": "^4.17.4" 242 | } 243 | }, 244 | "babel-types": { 245 | "version": "6.26.0", 246 | "resolved": "https://registry.npmjs.org/babel-types/-/babel-types-6.26.0.tgz", 247 | "integrity": "sha1-o7Bz+Uq0nrb6Vc1lInozQ4BjJJc=", 248 | "requires": { 249 | "babel-runtime": "^6.26.0", 250 | "esutils": "^2.0.2", 251 | "lodash": "^4.17.4", 252 | "to-fast-properties": "^1.0.3" 253 | } 254 | }, 255 | "babylon": { 256 | "version": "6.18.0", 257 | "resolved": "https://registry.npmjs.org/babylon/-/babylon-6.18.0.tgz", 258 | "integrity": "sha512-q/UEjfGJ2Cm3oKV71DJz9d25TPnq5rhBVL2Q4fA5wcC3jcrdn7+SssEybFIxwAvvP+YCsCYNKughoF33GxgycQ==" 259 | }, 260 | "balanced-match": { 261 | "version": "1.0.0", 262 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz", 263 | "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=" 264 | }, 265 | "body-parser": { 266 | "version": "1.19.0", 267 | "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-1.19.0.tgz", 268 | "integrity": "sha512-dhEPs72UPbDnAQJ9ZKMNTP6ptJaionhP5cBb541nXPlW60Jepo9RV/a4fX4XWW9CuFNK22krhrj1+rgzifNCsw==", 269 | "dev": true, 270 | "requires": { 271 | "bytes": "3.1.0", 272 | "content-type": "~1.0.4", 273 | "debug": "2.6.9", 274 | "depd": "~1.1.2", 275 | "http-errors": "1.7.2", 276 | "iconv-lite": "0.4.24", 277 | "on-finished": "~2.3.0", 278 | "qs": "6.7.0", 279 | "raw-body": "2.4.0", 280 | "type-is": "~1.6.17" 281 | } 282 | }, 283 | "brace-expansion": { 284 | "version": "1.1.11", 285 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 286 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 287 | "requires": { 288 | "balanced-match": "^1.0.0", 289 | "concat-map": "0.0.1" 290 | } 291 | }, 292 | "braces": { 293 | "version": "1.8.5", 294 | "resolved": "https://registry.npmjs.org/braces/-/braces-1.8.5.tgz", 295 | "integrity": "sha1-uneWLhLf+WnWt2cR6RS3N4V79qc=", 296 | "requires": { 297 | "expand-range": "^1.8.1", 298 | "preserve": "^0.2.0", 299 | "repeat-element": "^1.1.2" 300 | } 301 | }, 302 | "bytes": { 303 | "version": "3.1.0", 304 | "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.1.0.tgz", 305 | "integrity": "sha512-zauLjrfCG+xvoyaqLoV8bLVXXNGC4JqlxFCutSDWA6fJrTo2ZuvLYTqZ7aHBLZSMOopbzwv8f+wZcVzfVTI2Dg==", 306 | "dev": true 307 | }, 308 | "callsites": { 309 | "version": "2.0.0", 310 | "resolved": "https://registry.npmjs.org/callsites/-/callsites-2.0.0.tgz", 311 | "integrity": "sha1-BuuE8A7qQT2oav/vrL/7Ngk7PFA=" 312 | }, 313 | "camelcase": { 314 | "version": "4.1.0", 315 | "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-4.1.0.tgz", 316 | "integrity": "sha1-1UVjW+HjPFQmScaRc+Xeas+uNN0=" 317 | }, 318 | "chalk": { 319 | "version": "1.1.3", 320 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-1.1.3.tgz", 321 | "integrity": "sha1-qBFcVeSnAv5NFQq9OHKCKn4J/Jg=", 322 | "requires": { 323 | "ansi-styles": "^2.2.1", 324 | "escape-string-regexp": "^1.0.2", 325 | "has-ansi": "^2.0.0", 326 | "strip-ansi": "^3.0.0", 327 | "supports-color": "^2.0.0" 328 | } 329 | }, 330 | "ci-info": { 331 | "version": "1.6.0", 332 | "resolved": "https://registry.npmjs.org/ci-info/-/ci-info-1.6.0.tgz", 333 | "integrity": "sha512-vsGdkwSCDpWmP80ncATX7iea5DWQemg1UgCW5J8tqjU3lYw4FBYuj89J0CTVomA7BEfvSZd84GmHko+MxFQU2A==" 334 | }, 335 | "cliui": { 336 | "version": "4.1.0", 337 | "resolved": "https://registry.npmjs.org/cliui/-/cliui-4.1.0.tgz", 338 | "integrity": "sha512-4FG+RSG9DL7uEwRUZXZn3SS34DiDPfzP0VOiEwtUWlE+AR2EIg+hSyvrIgUUfhdgR/UkAeW2QHgeP+hWrXs7jQ==", 339 | "requires": { 340 | "string-width": "^2.1.1", 341 | "strip-ansi": "^4.0.0", 342 | "wrap-ansi": "^2.0.0" 343 | }, 344 | "dependencies": { 345 | "ansi-regex": { 346 | "version": "3.0.0", 347 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-3.0.0.tgz", 348 | "integrity": "sha1-7QMXwyIGT3lGbAKWa922Bas32Zg=" 349 | }, 350 | "strip-ansi": { 351 | "version": "4.0.0", 352 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-4.0.0.tgz", 353 | "integrity": "sha1-qEeQIusaw2iocTibY1JixQXuNo8=", 354 | "requires": { 355 | "ansi-regex": "^3.0.0" 356 | } 357 | } 358 | } 359 | }, 360 | "code-point-at": { 361 | "version": "1.1.0", 362 | "resolved": "https://registry.npmjs.org/code-point-at/-/code-point-at-1.1.0.tgz", 363 | "integrity": "sha1-DQcLTQQ6W+ozovGkDi7bPZpMz3c=" 364 | }, 365 | "color-convert": { 366 | "version": "1.9.3", 367 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", 368 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", 369 | "requires": { 370 | "color-name": "1.1.3" 371 | } 372 | }, 373 | "color-name": { 374 | "version": "1.1.3", 375 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 376 | "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=" 377 | }, 378 | "commander": { 379 | "version": "2.20.3", 380 | "resolved": "https://registry.npmjs.org/commander/-/commander-2.20.3.tgz", 381 | "integrity": "sha512-GpVkmM8vF2vQUkj2LvZmD35JxeJOLCwJ9cUkugyk2nuhbv3+mJvpLYYt+0+USMxE+oj+ey/lJEnhZw75x/OMcQ==" 382 | }, 383 | "concat-map": { 384 | "version": "0.0.1", 385 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 386 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=" 387 | }, 388 | "config-chain": { 389 | "version": "1.1.12", 390 | "resolved": "https://registry.npmjs.org/config-chain/-/config-chain-1.1.12.tgz", 391 | "integrity": "sha512-a1eOIcu8+7lUInge4Rpf/n4Krkf3Dd9lqhljRzII1/Zno/kRtUWnznPO3jOKBmTEktkt3fkxisUcivoj0ebzoA==", 392 | "requires": { 393 | "ini": "^1.3.4", 394 | "proto-list": "~1.2.1" 395 | } 396 | }, 397 | "content-disposition": { 398 | "version": "0.5.3", 399 | "resolved": "https://registry.npmjs.org/content-disposition/-/content-disposition-0.5.3.tgz", 400 | "integrity": "sha512-ExO0774ikEObIAEV9kDo50o+79VCUdEB6n6lzKgGwupcVeRlhrj3qGAfwq8G6uBJjkqLrhT0qEYFcWng8z1z0g==", 401 | "dev": true, 402 | "requires": { 403 | "safe-buffer": "5.1.2" 404 | } 405 | }, 406 | "content-type": { 407 | "version": "1.0.4", 408 | "resolved": "https://registry.npmjs.org/content-type/-/content-type-1.0.4.tgz", 409 | "integrity": "sha512-hIP3EEPs8tB9AT1L+NUqtwOAps4mk2Zob89MWXMHjHWg9milF/j4osnnQLXBCBFBk/tvIG/tUc9mOUJiPBhPXA==", 410 | "dev": true 411 | }, 412 | "convert-source-map": { 413 | "version": "1.7.0", 414 | "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-1.7.0.tgz", 415 | "integrity": "sha512-4FJkXzKXEDB1snCFZlLP4gpC3JILicCpGbzG9f9G7tGqGCzETQ2hWPrcinA9oU4wtf2biUaEH5065UnMeR33oA==", 416 | "requires": { 417 | "safe-buffer": "~5.1.1" 418 | } 419 | }, 420 | "cookie": { 421 | "version": "0.4.0", 422 | "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.4.0.tgz", 423 | "integrity": "sha512-+Hp8fLp57wnUSt0tY0tHEXh4voZRDnoIrZPqlo3DPiI4y9lwg/jqx+1Om94/W6ZaPDOUbnjOt/99w66zk+l1Xg==", 424 | "dev": true 425 | }, 426 | "cookie-signature": { 427 | "version": "1.0.6", 428 | "resolved": "https://registry.npmjs.org/cookie-signature/-/cookie-signature-1.0.6.tgz", 429 | "integrity": "sha1-4wOogrNCzD7oylE6eZmXNNqzriw=", 430 | "dev": true 431 | }, 432 | "core-js": { 433 | "version": "2.6.10", 434 | "resolved": "https://registry.npmjs.org/core-js/-/core-js-2.6.10.tgz", 435 | "integrity": "sha512-I39t74+4t+zau64EN1fE5v2W31Adtc/REhzWN+gWRRXg6WH5qAsZm62DHpQ1+Yhe4047T55jvzz7MUqF/dBBlA==" 436 | }, 437 | "cross-spawn": { 438 | "version": "6.0.5", 439 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-6.0.5.tgz", 440 | "integrity": "sha512-eTVLrBSt7fjbDygz805pMnstIs2VTBNkRm0qxZd+M7A5XDdxVRWO5MxGBXZhjY4cqLYLdtrGqRf8mBPmzwSpWQ==", 441 | "requires": { 442 | "nice-try": "^1.0.4", 443 | "path-key": "^2.0.1", 444 | "semver": "^5.5.0", 445 | "shebang-command": "^1.2.0", 446 | "which": "^1.2.9" 447 | } 448 | }, 449 | "debug": { 450 | "version": "2.6.9", 451 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 452 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 453 | "requires": { 454 | "ms": "2.0.0" 455 | } 456 | }, 457 | "decamelize": { 458 | "version": "1.2.0", 459 | "resolved": "https://registry.npmjs.org/decamelize/-/decamelize-1.2.0.tgz", 460 | "integrity": "sha1-9lNNFRSCabIDUue+4m9QH5oZEpA=" 461 | }, 462 | "depd": { 463 | "version": "1.1.2", 464 | "resolved": "https://registry.npmjs.org/depd/-/depd-1.1.2.tgz", 465 | "integrity": "sha1-m81S4UwJd2PnSbJ0xDRu0uVgtak=", 466 | "dev": true 467 | }, 468 | "destroy": { 469 | "version": "1.0.4", 470 | "resolved": "https://registry.npmjs.org/destroy/-/destroy-1.0.4.tgz", 471 | "integrity": "sha1-l4hXRCxEdJ5CBmE+N5RiBYJqvYA=", 472 | "dev": true 473 | }, 474 | "detect-indent": { 475 | "version": "4.0.0", 476 | "resolved": "https://registry.npmjs.org/detect-indent/-/detect-indent-4.0.0.tgz", 477 | "integrity": "sha1-920GQ1LN9Docts5hnE7jqUdd4gg=", 478 | "requires": { 479 | "repeating": "^2.0.0" 480 | } 481 | }, 482 | "editorconfig": { 483 | "version": "0.15.3", 484 | "resolved": "https://registry.npmjs.org/editorconfig/-/editorconfig-0.15.3.tgz", 485 | "integrity": "sha512-M9wIMFx96vq0R4F+gRpY3o2exzb8hEj/n9S8unZtHSvYjibBp/iMufSzvmOcV/laG0ZtuTVGtiJggPOSW2r93g==", 486 | "requires": { 487 | "commander": "^2.19.0", 488 | "lru-cache": "^4.1.5", 489 | "semver": "^5.6.0", 490 | "sigmund": "^1.0.1" 491 | } 492 | }, 493 | "ee-first": { 494 | "version": "1.1.1", 495 | "resolved": "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz", 496 | "integrity": "sha1-WQxhFWsK4vTwJVcyoViyZrxWsh0=", 497 | "dev": true 498 | }, 499 | "encodeurl": { 500 | "version": "1.0.2", 501 | "resolved": "https://registry.npmjs.org/encodeurl/-/encodeurl-1.0.2.tgz", 502 | "integrity": "sha1-rT/0yG7C0CkyL1oCw6mmBslbP1k=", 503 | "dev": true 504 | }, 505 | "end-of-stream": { 506 | "version": "1.4.4", 507 | "resolved": "https://registry.npmjs.org/end-of-stream/-/end-of-stream-1.4.4.tgz", 508 | "integrity": "sha512-+uw1inIHVPQoaVuHzRyXd21icM+cnt4CzD5rW+NC1wjOUSTOs+Te7FOv7AhN7vS9x/oIyhLP5PR1H+phQAHu5Q==", 509 | "requires": { 510 | "once": "^1.4.0" 511 | } 512 | }, 513 | "escape-html": { 514 | "version": "1.0.3", 515 | "resolved": "https://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz", 516 | "integrity": "sha1-Aljq5NPQwJdN4cFpGI7wBR0dGYg=", 517 | "dev": true 518 | }, 519 | "escape-string-regexp": { 520 | "version": "1.0.5", 521 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", 522 | "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=" 523 | }, 524 | "esutils": { 525 | "version": "2.0.3", 526 | "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", 527 | "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==" 528 | }, 529 | "etag": { 530 | "version": "1.8.1", 531 | "resolved": "https://registry.npmjs.org/etag/-/etag-1.8.1.tgz", 532 | "integrity": "sha1-Qa4u62XvpiJorr/qg6x9eSmbCIc=", 533 | "dev": true 534 | }, 535 | "execa": { 536 | "version": "1.0.0", 537 | "resolved": "https://registry.npmjs.org/execa/-/execa-1.0.0.tgz", 538 | "integrity": "sha512-adbxcyWV46qiHyvSp50TKt05tB4tK3HcmF7/nxfAdhnox83seTDbwnaqKO4sXRy7roHAIFqJP/Rw/AuEbX61LA==", 539 | "requires": { 540 | "cross-spawn": "^6.0.0", 541 | "get-stream": "^4.0.0", 542 | "is-stream": "^1.1.0", 543 | "npm-run-path": "^2.0.0", 544 | "p-finally": "^1.0.0", 545 | "signal-exit": "^3.0.0", 546 | "strip-eof": "^1.0.0" 547 | } 548 | }, 549 | "expand-brackets": { 550 | "version": "0.1.5", 551 | "resolved": "https://registry.npmjs.org/expand-brackets/-/expand-brackets-0.1.5.tgz", 552 | "integrity": "sha1-3wcoTjQqgHzXM6xa9yQR5YHRF3s=", 553 | "requires": { 554 | "is-posix-bracket": "^0.1.0" 555 | } 556 | }, 557 | "expand-range": { 558 | "version": "1.8.2", 559 | "resolved": "https://registry.npmjs.org/expand-range/-/expand-range-1.8.2.tgz", 560 | "integrity": "sha1-opnv/TNf4nIeuujiV+x5ZE/IUzc=", 561 | "requires": { 562 | "fill-range": "^2.1.0" 563 | } 564 | }, 565 | "express": { 566 | "version": "4.17.1", 567 | "resolved": "https://registry.npmjs.org/express/-/express-4.17.1.tgz", 568 | "integrity": "sha512-mHJ9O79RqluphRrcw2X/GTh3k9tVv8YcoyY4Kkh4WDMUYKRZUq0h1o0w2rrrxBqM7VoeUVqgb27xlEMXTnYt4g==", 569 | "dev": true, 570 | "requires": { 571 | "accepts": "~1.3.7", 572 | "array-flatten": "1.1.1", 573 | "body-parser": "1.19.0", 574 | "content-disposition": "0.5.3", 575 | "content-type": "~1.0.4", 576 | "cookie": "0.4.0", 577 | "cookie-signature": "1.0.6", 578 | "debug": "2.6.9", 579 | "depd": "~1.1.2", 580 | "encodeurl": "~1.0.2", 581 | "escape-html": "~1.0.3", 582 | "etag": "~1.8.1", 583 | "finalhandler": "~1.1.2", 584 | "fresh": "0.5.2", 585 | "merge-descriptors": "1.0.1", 586 | "methods": "~1.1.2", 587 | "on-finished": "~2.3.0", 588 | "parseurl": "~1.3.3", 589 | "path-to-regexp": "0.1.7", 590 | "proxy-addr": "~2.0.5", 591 | "qs": "6.7.0", 592 | "range-parser": "~1.2.1", 593 | "safe-buffer": "5.1.2", 594 | "send": "0.17.1", 595 | "serve-static": "1.14.1", 596 | "setprototypeof": "1.1.1", 597 | "statuses": "~1.5.0", 598 | "type-is": "~1.6.18", 599 | "utils-merge": "1.0.1", 600 | "vary": "~1.1.2" 601 | } 602 | }, 603 | "extglob": { 604 | "version": "0.3.2", 605 | "resolved": "https://registry.npmjs.org/extglob/-/extglob-0.3.2.tgz", 606 | "integrity": "sha1-Lhj/PS9JqydlzskCPwEdqo2DSaE=", 607 | "requires": { 608 | "is-extglob": "^1.0.0" 609 | } 610 | }, 611 | "filename-regex": { 612 | "version": "2.0.1", 613 | "resolved": "https://registry.npmjs.org/filename-regex/-/filename-regex-2.0.1.tgz", 614 | "integrity": "sha1-wcS5vuPglyXdsQa3XB4wH+LxiyY=" 615 | }, 616 | "fill-range": { 617 | "version": "2.2.4", 618 | "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-2.2.4.tgz", 619 | "integrity": "sha512-cnrcCbj01+j2gTG921VZPnHbjmdAf8oQV/iGeV2kZxGSyfYjjTyY79ErsK1WJWMpw6DaApEX72binqJE+/d+5Q==", 620 | "requires": { 621 | "is-number": "^2.1.0", 622 | "isobject": "^2.0.0", 623 | "randomatic": "^3.0.0", 624 | "repeat-element": "^1.1.2", 625 | "repeat-string": "^1.5.2" 626 | } 627 | }, 628 | "finalhandler": { 629 | "version": "1.1.2", 630 | "resolved": "https://registry.npmjs.org/finalhandler/-/finalhandler-1.1.2.tgz", 631 | "integrity": "sha512-aAWcW57uxVNrQZqFXjITpW3sIUQmHGG3qSb9mUah9MgMC4NeWhNOlNjXEYq3HjRAvL6arUviZGGJsBg6z0zsWA==", 632 | "dev": true, 633 | "requires": { 634 | "debug": "2.6.9", 635 | "encodeurl": "~1.0.2", 636 | "escape-html": "~1.0.3", 637 | "on-finished": "~2.3.0", 638 | "parseurl": "~1.3.3", 639 | "statuses": "~1.5.0", 640 | "unpipe": "~1.0.0" 641 | } 642 | }, 643 | "find-up": { 644 | "version": "2.1.0", 645 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-2.1.0.tgz", 646 | "integrity": "sha1-RdG35QbHF93UgndaK3eSCjwMV6c=", 647 | "requires": { 648 | "locate-path": "^2.0.0" 649 | } 650 | }, 651 | "for-in": { 652 | "version": "1.0.2", 653 | "resolved": "https://registry.npmjs.org/for-in/-/for-in-1.0.2.tgz", 654 | "integrity": "sha1-gQaNKVqBQuwKxybG4iAMMPttXoA=" 655 | }, 656 | "for-own": { 657 | "version": "0.1.5", 658 | "resolved": "https://registry.npmjs.org/for-own/-/for-own-0.1.5.tgz", 659 | "integrity": "sha1-UmXGgaTylNq78XyVCbZ2OqhFEM4=", 660 | "requires": { 661 | "for-in": "^1.0.1" 662 | } 663 | }, 664 | "forwarded": { 665 | "version": "0.1.2", 666 | "resolved": "https://registry.npmjs.org/forwarded/-/forwarded-0.1.2.tgz", 667 | "integrity": "sha1-mMI9qxF1ZXuMBXPozszZGw/xjIQ=", 668 | "dev": true 669 | }, 670 | "fresh": { 671 | "version": "0.5.2", 672 | "resolved": "https://registry.npmjs.org/fresh/-/fresh-0.5.2.tgz", 673 | "integrity": "sha1-PYyt2Q2XZWn6g1qx+OSyOhBWBac=", 674 | "dev": true 675 | }, 676 | "fs.realpath": { 677 | "version": "1.0.0", 678 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 679 | "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=" 680 | }, 681 | "get-caller-file": { 682 | "version": "1.0.3", 683 | "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-1.0.3.tgz", 684 | "integrity": "sha512-3t6rVToeoZfYSGd8YoLFR2DJkiQrIiUrGcjvFX2mDw3bn6k2OtwHN0TNCLbBO+w8qTvimhDkv+LSscbJY1vE6w==" 685 | }, 686 | "get-stream": { 687 | "version": "4.1.0", 688 | "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-4.1.0.tgz", 689 | "integrity": "sha512-GMat4EJ5161kIy2HevLlr4luNjBgvmj413KaQA7jt4V8B4RDsfpHk7WQ9GVqfYyyx8OS/L66Kox+rJRNklLK7w==", 690 | "requires": { 691 | "pump": "^3.0.0" 692 | } 693 | }, 694 | "glob": { 695 | "version": "7.1.6", 696 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.6.tgz", 697 | "integrity": "sha512-LwaxwyZ72Lk7vZINtNNrywX0ZuLyStrdDtabefZKAY5ZGJhVtgdznluResxNmPitE0SAO+O26sWTHeKSI2wMBA==", 698 | "requires": { 699 | "fs.realpath": "^1.0.0", 700 | "inflight": "^1.0.4", 701 | "inherits": "2", 702 | "minimatch": "^3.0.4", 703 | "once": "^1.3.0", 704 | "path-is-absolute": "^1.0.0" 705 | } 706 | }, 707 | "glob-base": { 708 | "version": "0.3.0", 709 | "resolved": "https://registry.npmjs.org/glob-base/-/glob-base-0.3.0.tgz", 710 | "integrity": "sha1-27Fk9iIbHAscz4Kuoyi0l98Oo8Q=", 711 | "requires": { 712 | "glob-parent": "^2.0.0", 713 | "is-glob": "^2.0.0" 714 | } 715 | }, 716 | "glob-parent": { 717 | "version": "2.0.0", 718 | "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-2.0.0.tgz", 719 | "integrity": "sha1-gTg9ctsFT8zPUzbaqQLxgvbtuyg=", 720 | "requires": { 721 | "is-glob": "^2.0.0" 722 | } 723 | }, 724 | "globals": { 725 | "version": "9.18.0", 726 | "resolved": "https://registry.npmjs.org/globals/-/globals-9.18.0.tgz", 727 | "integrity": "sha512-S0nG3CLEQiY/ILxqtztTWH/3iRRdyBLw6KMDxnKMchrtbj2OFmehVh0WUCfW3DUrIgx/qFrJPICrq4Z4sTR9UQ==" 728 | }, 729 | "graceful-fs": { 730 | "version": "4.2.3", 731 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.3.tgz", 732 | "integrity": "sha512-a30VEBm4PEdx1dRB7MFK7BejejvCvBronbLjht+sHuGYj8PHs7M/5Z+rt5lw551vZ7yfTCj4Vuyy3mSJytDWRQ==" 733 | }, 734 | "has-ansi": { 735 | "version": "2.0.0", 736 | "resolved": "https://registry.npmjs.org/has-ansi/-/has-ansi-2.0.0.tgz", 737 | "integrity": "sha1-NPUEnOHs3ysGSa8+8k5F7TVBbZE=", 738 | "requires": { 739 | "ansi-regex": "^2.0.0" 740 | } 741 | }, 742 | "has-flag": { 743 | "version": "3.0.0", 744 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 745 | "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=" 746 | }, 747 | "home-or-tmp": { 748 | "version": "2.0.0", 749 | "resolved": "https://registry.npmjs.org/home-or-tmp/-/home-or-tmp-2.0.0.tgz", 750 | "integrity": "sha1-42w/LSyufXRqhX440Y1fMqeILbg=", 751 | "requires": { 752 | "os-homedir": "^1.0.0", 753 | "os-tmpdir": "^1.0.1" 754 | } 755 | }, 756 | "http-errors": { 757 | "version": "1.7.2", 758 | "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-1.7.2.tgz", 759 | "integrity": "sha512-uUQBt3H/cSIVfch6i1EuPNy/YsRSOUBXTVfZ+yR7Zjez3qjBz6i9+i4zjNaoqcoFVI4lQJ5plg63TvGfRSDCRg==", 760 | "dev": true, 761 | "requires": { 762 | "depd": "~1.1.2", 763 | "inherits": "2.0.3", 764 | "setprototypeof": "1.1.1", 765 | "statuses": ">= 1.5.0 < 2", 766 | "toidentifier": "1.0.0" 767 | }, 768 | "dependencies": { 769 | "inherits": { 770 | "version": "2.0.3", 771 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz", 772 | "integrity": "sha1-Yzwsg+PaQqUC9SRmAiSA9CCCYd4=", 773 | "dev": true 774 | } 775 | } 776 | }, 777 | "iconv-lite": { 778 | "version": "0.4.24", 779 | "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", 780 | "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", 781 | "dev": true, 782 | "requires": { 783 | "safer-buffer": ">= 2.1.2 < 3" 784 | } 785 | }, 786 | "inflight": { 787 | "version": "1.0.6", 788 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 789 | "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", 790 | "requires": { 791 | "once": "^1.3.0", 792 | "wrappy": "1" 793 | } 794 | }, 795 | "inherits": { 796 | "version": "2.0.4", 797 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 798 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==" 799 | }, 800 | "ini": { 801 | "version": "1.3.5", 802 | "resolved": "https://registry.npmjs.org/ini/-/ini-1.3.5.tgz", 803 | "integrity": "sha512-RZY5huIKCMRWDUqZlEi72f/lmXKMvuszcMBduliQ3nnWbx9X/ZBQO7DijMEYS9EhHBb2qacRUMtC7svLwe0lcw==" 804 | }, 805 | "invariant": { 806 | "version": "2.2.4", 807 | "resolved": "https://registry.npmjs.org/invariant/-/invariant-2.2.4.tgz", 808 | "integrity": "sha512-phJfQVBuaJM5raOpJjSfkiD6BpbCE4Ns//LaXl6wGYtUBY83nWS6Rf9tXm2e8VaK60JEjYldbPif/A2B1C2gNA==", 809 | "requires": { 810 | "loose-envify": "^1.0.0" 811 | } 812 | }, 813 | "invert-kv": { 814 | "version": "2.0.0", 815 | "resolved": "https://registry.npmjs.org/invert-kv/-/invert-kv-2.0.0.tgz", 816 | "integrity": "sha512-wPVv/y/QQ/Uiirj/vh3oP+1Ww+AWehmi1g5fFWGPF6IpCBCDVrhgHRMvrLfdYcwDh3QJbGXDW4JAuzxElLSqKA==" 817 | }, 818 | "ipaddr.js": { 819 | "version": "1.9.0", 820 | "resolved": "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-1.9.0.tgz", 821 | "integrity": "sha512-M4Sjn6N/+O6/IXSJseKqHoFc+5FdGJ22sXqnjTpdZweHK64MzEPAyQZyEU3R/KRv2GLoa7nNtg/C2Ev6m7z+eA==", 822 | "dev": true 823 | }, 824 | "is-buffer": { 825 | "version": "1.1.6", 826 | "resolved": "https://registry.npmjs.org/is-buffer/-/is-buffer-1.1.6.tgz", 827 | "integrity": "sha512-NcdALwpXkTm5Zvvbk7owOUSvVvBKDgKP5/ewfXEznmQFfs4ZRmanOeKBTjRVjka3QFoN6XJ+9F3USqfHqTaU5w==" 828 | }, 829 | "is-ci": { 830 | "version": "1.2.1", 831 | "resolved": "https://registry.npmjs.org/is-ci/-/is-ci-1.2.1.tgz", 832 | "integrity": "sha512-s6tfsaQaQi3JNciBH6shVqEDvhGut0SUXr31ag8Pd8BBbVVlcGfWhpPmEOoM6RJ5TFhbypvf5yyRw/VXW1IiWg==", 833 | "requires": { 834 | "ci-info": "^1.5.0" 835 | } 836 | }, 837 | "is-dotfile": { 838 | "version": "1.0.3", 839 | "resolved": "https://registry.npmjs.org/is-dotfile/-/is-dotfile-1.0.3.tgz", 840 | "integrity": "sha1-pqLzL/0t+wT1yiXs0Pa4PPeYoeE=" 841 | }, 842 | "is-equal-shallow": { 843 | "version": "0.1.3", 844 | "resolved": "https://registry.npmjs.org/is-equal-shallow/-/is-equal-shallow-0.1.3.tgz", 845 | "integrity": "sha1-IjgJj8Ih3gvPpdnqxMRdY4qhxTQ=", 846 | "requires": { 847 | "is-primitive": "^2.0.0" 848 | } 849 | }, 850 | "is-extendable": { 851 | "version": "0.1.1", 852 | "resolved": "https://registry.npmjs.org/is-extendable/-/is-extendable-0.1.1.tgz", 853 | "integrity": "sha1-YrEQ4omkcUGOPsNqYX1HLjAd/Ik=" 854 | }, 855 | "is-extglob": { 856 | "version": "1.0.0", 857 | "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-1.0.0.tgz", 858 | "integrity": "sha1-rEaBd8SUNAWgkvyPKXYMb/xiBsA=" 859 | }, 860 | "is-finite": { 861 | "version": "1.0.2", 862 | "resolved": "https://registry.npmjs.org/is-finite/-/is-finite-1.0.2.tgz", 863 | "integrity": "sha1-zGZ3aVYCvlUO8R6LSqYwU0K20Ko=", 864 | "requires": { 865 | "number-is-nan": "^1.0.0" 866 | } 867 | }, 868 | "is-fullwidth-code-point": { 869 | "version": "2.0.0", 870 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", 871 | "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=" 872 | }, 873 | "is-glob": { 874 | "version": "2.0.1", 875 | "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-2.0.1.tgz", 876 | "integrity": "sha1-0Jb5JqPe1WAPP9/ZEZjLCIjC2GM=", 877 | "requires": { 878 | "is-extglob": "^1.0.0" 879 | } 880 | }, 881 | "is-number": { 882 | "version": "2.1.0", 883 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-2.1.0.tgz", 884 | "integrity": "sha1-Afy7s5NGOlSPL0ZszhbezknbkI8=", 885 | "requires": { 886 | "kind-of": "^3.0.2" 887 | } 888 | }, 889 | "is-posix-bracket": { 890 | "version": "0.1.1", 891 | "resolved": "https://registry.npmjs.org/is-posix-bracket/-/is-posix-bracket-0.1.1.tgz", 892 | "integrity": "sha1-MzTceXdDaOkvAW5vvAqI9c1ua8Q=" 893 | }, 894 | "is-primitive": { 895 | "version": "2.0.0", 896 | "resolved": "https://registry.npmjs.org/is-primitive/-/is-primitive-2.0.0.tgz", 897 | "integrity": "sha1-IHurkWOEmcB7Kt8kCkGochADRXU=" 898 | }, 899 | "is-stream": { 900 | "version": "1.1.0", 901 | "resolved": "https://registry.npmjs.org/is-stream/-/is-stream-1.1.0.tgz", 902 | "integrity": "sha1-EtSj3U5o4Lec6428hBc66A2RykQ=" 903 | }, 904 | "isarray": { 905 | "version": "1.0.0", 906 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", 907 | "integrity": "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE=" 908 | }, 909 | "isexe": { 910 | "version": "2.0.0", 911 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 912 | "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=" 913 | }, 914 | "isobject": { 915 | "version": "2.1.0", 916 | "resolved": "https://registry.npmjs.org/isobject/-/isobject-2.1.0.tgz", 917 | "integrity": "sha1-8GVWEJaj8dou9GJy+BXIQNh+DIk=", 918 | "requires": { 919 | "isarray": "1.0.0" 920 | } 921 | }, 922 | "jest-environment-node": { 923 | "version": "23.4.0", 924 | "resolved": "https://registry.npmjs.org/jest-environment-node/-/jest-environment-node-23.4.0.tgz", 925 | "integrity": "sha1-V+gO0IQd6jAxZ8zozXlSHeuv3hA=", 926 | "requires": { 927 | "jest-mock": "^23.2.0", 928 | "jest-util": "^23.4.0" 929 | } 930 | }, 931 | "jest-message-util": { 932 | "version": "23.4.0", 933 | "resolved": "https://registry.npmjs.org/jest-message-util/-/jest-message-util-23.4.0.tgz", 934 | "integrity": "sha1-F2EMUJQjSVCNAaPR4L2iwHkIap8=", 935 | "requires": { 936 | "@babel/code-frame": "^7.0.0-beta.35", 937 | "chalk": "^2.0.1", 938 | "micromatch": "^2.3.11", 939 | "slash": "^1.0.0", 940 | "stack-utils": "^1.0.1" 941 | }, 942 | "dependencies": { 943 | "ansi-styles": { 944 | "version": "3.2.1", 945 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 946 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 947 | "requires": { 948 | "color-convert": "^1.9.0" 949 | } 950 | }, 951 | "chalk": { 952 | "version": "2.4.2", 953 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", 954 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", 955 | "requires": { 956 | "ansi-styles": "^3.2.1", 957 | "escape-string-regexp": "^1.0.5", 958 | "supports-color": "^5.3.0" 959 | } 960 | }, 961 | "supports-color": { 962 | "version": "5.5.0", 963 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 964 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 965 | "requires": { 966 | "has-flag": "^3.0.0" 967 | } 968 | } 969 | } 970 | }, 971 | "jest-mock": { 972 | "version": "23.2.0", 973 | "resolved": "https://registry.npmjs.org/jest-mock/-/jest-mock-23.2.0.tgz", 974 | "integrity": "sha1-rRxg8p6HGdR8JuETgJi20YsmETQ=" 975 | }, 976 | "jest-util": { 977 | "version": "23.4.0", 978 | "resolved": "https://registry.npmjs.org/jest-util/-/jest-util-23.4.0.tgz", 979 | "integrity": "sha1-TQY8uSe68KI4Mf9hvsLLv0l5NWE=", 980 | "requires": { 981 | "callsites": "^2.0.0", 982 | "chalk": "^2.0.1", 983 | "graceful-fs": "^4.1.11", 984 | "is-ci": "^1.0.10", 985 | "jest-message-util": "^23.4.0", 986 | "mkdirp": "^0.5.1", 987 | "slash": "^1.0.0", 988 | "source-map": "^0.6.0" 989 | }, 990 | "dependencies": { 991 | "ansi-styles": { 992 | "version": "3.2.1", 993 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 994 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 995 | "requires": { 996 | "color-convert": "^1.9.0" 997 | } 998 | }, 999 | "chalk": { 1000 | "version": "2.4.2", 1001 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", 1002 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", 1003 | "requires": { 1004 | "ansi-styles": "^3.2.1", 1005 | "escape-string-regexp": "^1.0.5", 1006 | "supports-color": "^5.3.0" 1007 | } 1008 | }, 1009 | "source-map": { 1010 | "version": "0.6.1", 1011 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", 1012 | "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==" 1013 | }, 1014 | "supports-color": { 1015 | "version": "5.5.0", 1016 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 1017 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 1018 | "requires": { 1019 | "has-flag": "^3.0.0" 1020 | } 1021 | } 1022 | } 1023 | }, 1024 | "js-beautify": { 1025 | "version": "1.10.2", 1026 | "resolved": "https://registry.npmjs.org/js-beautify/-/js-beautify-1.10.2.tgz", 1027 | "integrity": "sha512-ZtBYyNUYJIsBWERnQP0rPN9KjkrDfJcMjuVGcvXOUJrD1zmOGwhRwQ4msG+HJ+Ni/FA7+sRQEMYVzdTQDvnzvQ==", 1028 | "requires": { 1029 | "config-chain": "^1.1.12", 1030 | "editorconfig": "^0.15.3", 1031 | "glob": "^7.1.3", 1032 | "mkdirp": "~0.5.1", 1033 | "nopt": "~4.0.1" 1034 | } 1035 | }, 1036 | "js-tokens": { 1037 | "version": "3.0.2", 1038 | "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-3.0.2.tgz", 1039 | "integrity": "sha1-mGbfOVECEw449/mWvOtlRDIJwls=" 1040 | }, 1041 | "jsesc": { 1042 | "version": "1.3.0", 1043 | "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-1.3.0.tgz", 1044 | "integrity": "sha1-RsP+yMGJKxKwgz25vHYiF226s0s=" 1045 | }, 1046 | "json5": { 1047 | "version": "0.5.1", 1048 | "resolved": "https://registry.npmjs.org/json5/-/json5-0.5.1.tgz", 1049 | "integrity": "sha1-Hq3nrMASA0rYTiOWdn6tn6VJWCE=" 1050 | }, 1051 | "kind-of": { 1052 | "version": "3.2.2", 1053 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", 1054 | "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", 1055 | "requires": { 1056 | "is-buffer": "^1.1.5" 1057 | } 1058 | }, 1059 | "lcid": { 1060 | "version": "2.0.0", 1061 | "resolved": "https://registry.npmjs.org/lcid/-/lcid-2.0.0.tgz", 1062 | "integrity": "sha512-avPEb8P8EGnwXKClwsNUgryVjllcRqtMYa49NTsbQagYuT1DcXnl1915oxWjoyGrXR6zH/Y0Zc96xWsPcoDKeA==", 1063 | "requires": { 1064 | "invert-kv": "^2.0.0" 1065 | } 1066 | }, 1067 | "locate-path": { 1068 | "version": "2.0.0", 1069 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-2.0.0.tgz", 1070 | "integrity": "sha1-K1aLJl7slExtnA3pw9u7ygNUzY4=", 1071 | "requires": { 1072 | "p-locate": "^2.0.0", 1073 | "path-exists": "^3.0.0" 1074 | } 1075 | }, 1076 | "lodash": { 1077 | "version": "4.17.15", 1078 | "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.15.tgz", 1079 | "integrity": "sha512-8xOcRHvCjnocdS5cpwXQXVzmmh5e5+saE2QGoeQmbKmRS6J3VQppPOIt0MnmE+4xlZoumy0GPG0D0MVIQbNA1A==" 1080 | }, 1081 | "loose-envify": { 1082 | "version": "1.4.0", 1083 | "resolved": "https://registry.npmjs.org/loose-envify/-/loose-envify-1.4.0.tgz", 1084 | "integrity": "sha512-lyuxPGr/Wfhrlem2CL/UcnUc1zcqKAImBDzukY7Y5F/yQiNdko6+fRLevlw1HgMySw7f611UIY408EtxRSoK3Q==", 1085 | "requires": { 1086 | "js-tokens": "^3.0.0 || ^4.0.0" 1087 | } 1088 | }, 1089 | "lru-cache": { 1090 | "version": "4.1.5", 1091 | "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-4.1.5.tgz", 1092 | "integrity": "sha512-sWZlbEP2OsHNkXrMl5GYk/jKk70MBng6UU4YI/qGDYbgf6YbP4EvmqISbXCoJiRKs+1bSpFHVgQxvJ17F2li5g==", 1093 | "requires": { 1094 | "pseudomap": "^1.0.2", 1095 | "yallist": "^2.1.2" 1096 | } 1097 | }, 1098 | "map-age-cleaner": { 1099 | "version": "0.1.3", 1100 | "resolved": "https://registry.npmjs.org/map-age-cleaner/-/map-age-cleaner-0.1.3.tgz", 1101 | "integrity": "sha512-bJzx6nMoP6PDLPBFmg7+xRKeFZvFboMrGlxmNj9ClvX53KrmvM5bXFXEWjbz4cz1AFn+jWJ9z/DJSz7hrs0w3w==", 1102 | "requires": { 1103 | "p-defer": "^1.0.0" 1104 | } 1105 | }, 1106 | "math-random": { 1107 | "version": "1.0.4", 1108 | "resolved": "https://registry.npmjs.org/math-random/-/math-random-1.0.4.tgz", 1109 | "integrity": "sha512-rUxjysqif/BZQH2yhd5Aaq7vXMSx9NdEsQcyA07uEzIvxgI7zIr33gGsh+RU0/XjmQpCW7RsVof1vlkvQVCK5A==" 1110 | }, 1111 | "media-typer": { 1112 | "version": "0.3.0", 1113 | "resolved": "https://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz", 1114 | "integrity": "sha1-hxDXrwqmJvj/+hzgAWhUUmMlV0g=", 1115 | "dev": true 1116 | }, 1117 | "mem": { 1118 | "version": "4.3.0", 1119 | "resolved": "https://registry.npmjs.org/mem/-/mem-4.3.0.tgz", 1120 | "integrity": "sha512-qX2bG48pTqYRVmDB37rn/6PT7LcR8T7oAX3bf99u1Tt1nzxYfxkgqDwUwolPlXweM0XzBOBFzSx4kfp7KP1s/w==", 1121 | "requires": { 1122 | "map-age-cleaner": "^0.1.1", 1123 | "mimic-fn": "^2.0.0", 1124 | "p-is-promise": "^2.0.0" 1125 | } 1126 | }, 1127 | "merge-descriptors": { 1128 | "version": "1.0.1", 1129 | "resolved": "https://registry.npmjs.org/merge-descriptors/-/merge-descriptors-1.0.1.tgz", 1130 | "integrity": "sha1-sAqqVW3YtEVoFQ7J0blT8/kMu2E=", 1131 | "dev": true 1132 | }, 1133 | "methods": { 1134 | "version": "1.1.2", 1135 | "resolved": "https://registry.npmjs.org/methods/-/methods-1.1.2.tgz", 1136 | "integrity": "sha1-VSmk1nZUE07cxSZmVoNbD4Ua/O4=", 1137 | "dev": true 1138 | }, 1139 | "micromatch": { 1140 | "version": "2.3.11", 1141 | "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-2.3.11.tgz", 1142 | "integrity": "sha1-hmd8l9FyCzY0MdBNDRUpO9OMFWU=", 1143 | "requires": { 1144 | "arr-diff": "^2.0.0", 1145 | "array-unique": "^0.2.1", 1146 | "braces": "^1.8.2", 1147 | "expand-brackets": "^0.1.4", 1148 | "extglob": "^0.3.1", 1149 | "filename-regex": "^2.0.0", 1150 | "is-extglob": "^1.0.0", 1151 | "is-glob": "^2.0.1", 1152 | "kind-of": "^3.0.2", 1153 | "normalize-path": "^2.0.1", 1154 | "object.omit": "^2.0.0", 1155 | "parse-glob": "^3.0.4", 1156 | "regex-cache": "^0.4.2" 1157 | } 1158 | }, 1159 | "mime": { 1160 | "version": "1.6.0", 1161 | "resolved": "https://registry.npmjs.org/mime/-/mime-1.6.0.tgz", 1162 | "integrity": "sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg==", 1163 | "dev": true 1164 | }, 1165 | "mime-db": { 1166 | "version": "1.42.0", 1167 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.42.0.tgz", 1168 | "integrity": "sha512-UbfJCR4UAVRNgMpfImz05smAXK7+c+ZntjaA26ANtkXLlOe947Aag5zdIcKQULAiF9Cq4WxBi9jUs5zkA84bYQ==", 1169 | "dev": true 1170 | }, 1171 | "mime-types": { 1172 | "version": "2.1.25", 1173 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.25.tgz", 1174 | "integrity": "sha512-5KhStqB5xpTAeGqKBAMgwaYMnQik7teQN4IAzC7npDv6kzeU6prfkR67bc87J1kWMPGkoaZSq1npmexMgkmEVg==", 1175 | "dev": true, 1176 | "requires": { 1177 | "mime-db": "1.42.0" 1178 | } 1179 | }, 1180 | "mimic-fn": { 1181 | "version": "2.1.0", 1182 | "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-2.1.0.tgz", 1183 | "integrity": "sha512-OqbOk5oEQeAZ8WXWydlu9HJjz9WVdEIvamMCcXmuqUYjTknH/sqsWvhQ3vgwKFRR1HpjvNBKQ37nbJgYzGqGcg==" 1184 | }, 1185 | "minimatch": { 1186 | "version": "3.0.4", 1187 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", 1188 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 1189 | "requires": { 1190 | "brace-expansion": "^1.1.7" 1191 | } 1192 | }, 1193 | "minimist": { 1194 | "version": "0.0.8", 1195 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-0.0.8.tgz", 1196 | "integrity": "sha1-hX/Kv8M5fSYluCKCYuhqp6ARsF0=" 1197 | }, 1198 | "mkdirp": { 1199 | "version": "0.5.1", 1200 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.1.tgz", 1201 | "integrity": "sha1-MAV0OOrGz3+MR2fzhkjWaX11yQM=", 1202 | "requires": { 1203 | "minimist": "0.0.8" 1204 | } 1205 | }, 1206 | "ms": { 1207 | "version": "2.0.0", 1208 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 1209 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=" 1210 | }, 1211 | "negotiator": { 1212 | "version": "0.6.2", 1213 | "resolved": "https://registry.npmjs.org/negotiator/-/negotiator-0.6.2.tgz", 1214 | "integrity": "sha512-hZXc7K2e+PgeI1eDBe/10Ard4ekbfrrqG8Ep+8Jmf4JID2bNg7NvCPOZN+kfF574pFQI7mum2AUqDidoKqcTOw==", 1215 | "dev": true 1216 | }, 1217 | "nice-try": { 1218 | "version": "1.0.5", 1219 | "resolved": "https://registry.npmjs.org/nice-try/-/nice-try-1.0.5.tgz", 1220 | "integrity": "sha512-1nh45deeb5olNY7eX82BkPO7SSxR5SSYJiPTrTdFUVYwAl8CKMA5N9PjTYkHiRjisVcxcQ1HXdLhx2qxxJzLNQ==" 1221 | }, 1222 | "nopt": { 1223 | "version": "4.0.1", 1224 | "resolved": "https://registry.npmjs.org/nopt/-/nopt-4.0.1.tgz", 1225 | "integrity": "sha1-0NRoWv1UFRk8jHUFYC0NF81kR00=", 1226 | "requires": { 1227 | "abbrev": "1", 1228 | "osenv": "^0.1.4" 1229 | } 1230 | }, 1231 | "normalize-path": { 1232 | "version": "2.1.1", 1233 | "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-2.1.1.tgz", 1234 | "integrity": "sha1-GrKLVW4Zg2Oowab35vogE3/mrtk=", 1235 | "requires": { 1236 | "remove-trailing-separator": "^1.0.1" 1237 | } 1238 | }, 1239 | "npm-run-path": { 1240 | "version": "2.0.2", 1241 | "resolved": "https://registry.npmjs.org/npm-run-path/-/npm-run-path-2.0.2.tgz", 1242 | "integrity": "sha1-NakjLfo11wZ7TLLd8jV7GHFTbF8=", 1243 | "requires": { 1244 | "path-key": "^2.0.0" 1245 | } 1246 | }, 1247 | "number-is-nan": { 1248 | "version": "1.0.1", 1249 | "resolved": "https://registry.npmjs.org/number-is-nan/-/number-is-nan-1.0.1.tgz", 1250 | "integrity": "sha1-CXtgK1NCKlIsGvuHkDGDNpQaAR0=" 1251 | }, 1252 | "object.omit": { 1253 | "version": "2.0.1", 1254 | "resolved": "https://registry.npmjs.org/object.omit/-/object.omit-2.0.1.tgz", 1255 | "integrity": "sha1-Gpx0SCnznbuFjHbKNXmuKlTr0fo=", 1256 | "requires": { 1257 | "for-own": "^0.1.4", 1258 | "is-extendable": "^0.1.1" 1259 | } 1260 | }, 1261 | "on-finished": { 1262 | "version": "2.3.0", 1263 | "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.3.0.tgz", 1264 | "integrity": "sha1-IPEzZIGwg811M3mSoWlxqi2QaUc=", 1265 | "dev": true, 1266 | "requires": { 1267 | "ee-first": "1.1.1" 1268 | } 1269 | }, 1270 | "once": { 1271 | "version": "1.4.0", 1272 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 1273 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 1274 | "requires": { 1275 | "wrappy": "1" 1276 | } 1277 | }, 1278 | "os-homedir": { 1279 | "version": "1.0.2", 1280 | "resolved": "https://registry.npmjs.org/os-homedir/-/os-homedir-1.0.2.tgz", 1281 | "integrity": "sha1-/7xJiDNuDoM94MFox+8VISGqf7M=" 1282 | }, 1283 | "os-locale": { 1284 | "version": "3.1.0", 1285 | "resolved": "https://registry.npmjs.org/os-locale/-/os-locale-3.1.0.tgz", 1286 | "integrity": "sha512-Z8l3R4wYWM40/52Z+S265okfFj8Kt2cC2MKY+xNi3kFs+XGI7WXu/I309QQQYbRW4ijiZ+yxs9pqEhJh0DqW3Q==", 1287 | "requires": { 1288 | "execa": "^1.0.0", 1289 | "lcid": "^2.0.0", 1290 | "mem": "^4.0.0" 1291 | } 1292 | }, 1293 | "os-tmpdir": { 1294 | "version": "1.0.2", 1295 | "resolved": "https://registry.npmjs.org/os-tmpdir/-/os-tmpdir-1.0.2.tgz", 1296 | "integrity": "sha1-u+Z0BseaqFxc/sdm/lc0VV36EnQ=" 1297 | }, 1298 | "osenv": { 1299 | "version": "0.1.5", 1300 | "resolved": "https://registry.npmjs.org/osenv/-/osenv-0.1.5.tgz", 1301 | "integrity": "sha512-0CWcCECdMVc2Rw3U5w9ZjqX6ga6ubk1xDVKxtBQPK7wis/0F2r9T6k4ydGYhecl7YUBxBVxhL5oisPsNxAPe2g==", 1302 | "requires": { 1303 | "os-homedir": "^1.0.0", 1304 | "os-tmpdir": "^1.0.0" 1305 | } 1306 | }, 1307 | "outdent": { 1308 | "version": "0.5.0", 1309 | "resolved": "https://registry.npmjs.org/outdent/-/outdent-0.5.0.tgz", 1310 | "integrity": "sha512-/jHxFIzoMXdqPzTaCpFzAAWhpkSjZPF4Vsn6jAfNpmbH/ymsmd7Qc6VE9BGn0L6YMj6uwpQLxCECpus4ukKS9Q==" 1311 | }, 1312 | "p-defer": { 1313 | "version": "1.0.0", 1314 | "resolved": "https://registry.npmjs.org/p-defer/-/p-defer-1.0.0.tgz", 1315 | "integrity": "sha1-n26xgvbJqozXQwBKfU+WsZaw+ww=" 1316 | }, 1317 | "p-finally": { 1318 | "version": "1.0.0", 1319 | "resolved": "https://registry.npmjs.org/p-finally/-/p-finally-1.0.0.tgz", 1320 | "integrity": "sha1-P7z7FbiZpEEjs0ttzBi3JDNqLK4=" 1321 | }, 1322 | "p-is-promise": { 1323 | "version": "2.1.0", 1324 | "resolved": "https://registry.npmjs.org/p-is-promise/-/p-is-promise-2.1.0.tgz", 1325 | "integrity": "sha512-Y3W0wlRPK8ZMRbNq97l4M5otioeA5lm1z7bkNkxCka8HSPjR0xRWmpCmc9utiaLP9Jb1eD8BgeIxTW4AIF45Pg==" 1326 | }, 1327 | "p-limit": { 1328 | "version": "1.3.0", 1329 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-1.3.0.tgz", 1330 | "integrity": "sha512-vvcXsLAJ9Dr5rQOPk7toZQZJApBl2K4J6dANSsEuh6QI41JYcsS/qhTGa9ErIUUgK3WNQoJYvylxvjqmiqEA9Q==", 1331 | "requires": { 1332 | "p-try": "^1.0.0" 1333 | } 1334 | }, 1335 | "p-locate": { 1336 | "version": "2.0.0", 1337 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-2.0.0.tgz", 1338 | "integrity": "sha1-IKAQOyIqcMj9OcwuWAaA893l7EM=", 1339 | "requires": { 1340 | "p-limit": "^1.1.0" 1341 | } 1342 | }, 1343 | "p-try": { 1344 | "version": "1.0.0", 1345 | "resolved": "https://registry.npmjs.org/p-try/-/p-try-1.0.0.tgz", 1346 | "integrity": "sha1-y8ec26+P1CKOE/Yh8rGiN8GyB7M=" 1347 | }, 1348 | "parse-glob": { 1349 | "version": "3.0.4", 1350 | "resolved": "https://registry.npmjs.org/parse-glob/-/parse-glob-3.0.4.tgz", 1351 | "integrity": "sha1-ssN2z7EfNVE7rdFz7wu246OIORw=", 1352 | "requires": { 1353 | "glob-base": "^0.3.0", 1354 | "is-dotfile": "^1.0.0", 1355 | "is-extglob": "^1.0.0", 1356 | "is-glob": "^2.0.0" 1357 | } 1358 | }, 1359 | "parse5": { 1360 | "version": "4.0.0", 1361 | "resolved": "https://registry.npmjs.org/parse5/-/parse5-4.0.0.tgz", 1362 | "integrity": "sha512-VrZ7eOd3T1Fk4XWNXMgiGBK/z0MG48BWG2uQNU4I72fkQuKUTZpl+u9k+CxEG0twMVzSmXEEz12z5Fnw1jIQFA==" 1363 | }, 1364 | "parseurl": { 1365 | "version": "1.3.3", 1366 | "resolved": "https://registry.npmjs.org/parseurl/-/parseurl-1.3.3.tgz", 1367 | "integrity": "sha512-CiyeOxFT/JZyN5m0z9PfXw4SCBJ6Sygz1Dpl0wqjlhDEGGBP1GnsUVEL0p63hoG1fcj3fHynXi9NYO4nWOL+qQ==", 1368 | "dev": true 1369 | }, 1370 | "path-exists": { 1371 | "version": "3.0.0", 1372 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-3.0.0.tgz", 1373 | "integrity": "sha1-zg6+ql94yxiSXqfYENe1mwEP1RU=" 1374 | }, 1375 | "path-is-absolute": { 1376 | "version": "1.0.1", 1377 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 1378 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=" 1379 | }, 1380 | "path-key": { 1381 | "version": "2.0.1", 1382 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-2.0.1.tgz", 1383 | "integrity": "sha1-QRyttXTFoUDTpLGRDUDYDMn0C0A=" 1384 | }, 1385 | "path-to-regexp": { 1386 | "version": "0.1.7", 1387 | "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-0.1.7.tgz", 1388 | "integrity": "sha1-32BBeABfUi8V60SQ5yR6G/qmf4w=", 1389 | "dev": true 1390 | }, 1391 | "preact": { 1392 | "version": "8.5.3", 1393 | "resolved": "https://registry.npmjs.org/preact/-/preact-8.5.3.tgz", 1394 | "integrity": "sha512-O3kKP+1YdgqHOFsZF2a9JVdtqD+RPzCQc3rP+Ualf7V6rmRDchZ9MJbiGTT7LuyqFKZqlHSOyO/oMFmI2lVTsw==" 1395 | }, 1396 | "preserve": { 1397 | "version": "0.2.0", 1398 | "resolved": "https://registry.npmjs.org/preserve/-/preserve-0.2.0.tgz", 1399 | "integrity": "sha1-gV7R9uvGWSb4ZbMQwHE7yzMVzks=" 1400 | }, 1401 | "private": { 1402 | "version": "0.1.8", 1403 | "resolved": "https://registry.npmjs.org/private/-/private-0.1.8.tgz", 1404 | "integrity": "sha512-VvivMrbvd2nKkiG38qjULzlc+4Vx4wm/whI9pQD35YrARNnhxeiRktSOhSukRLFNlzg6Br/cJPet5J/u19r/mg==" 1405 | }, 1406 | "proto-list": { 1407 | "version": "1.2.4", 1408 | "resolved": "https://registry.npmjs.org/proto-list/-/proto-list-1.2.4.tgz", 1409 | "integrity": "sha1-IS1b/hMYMGpCD2QCuOJv85ZHqEk=" 1410 | }, 1411 | "proxy-addr": { 1412 | "version": "2.0.5", 1413 | "resolved": "https://registry.npmjs.org/proxy-addr/-/proxy-addr-2.0.5.tgz", 1414 | "integrity": "sha512-t/7RxHXPH6cJtP0pRG6smSr9QJidhB+3kXu0KgXnbGYMgzEnUxRQ4/LDdfOwZEMyIh3/xHb8PX3t+lfL9z+YVQ==", 1415 | "dev": true, 1416 | "requires": { 1417 | "forwarded": "~0.1.2", 1418 | "ipaddr.js": "1.9.0" 1419 | } 1420 | }, 1421 | "pseudomap": { 1422 | "version": "1.0.2", 1423 | "resolved": "https://registry.npmjs.org/pseudomap/-/pseudomap-1.0.2.tgz", 1424 | "integrity": "sha1-8FKijacOYYkX7wqKw0wa5aaChrM=" 1425 | }, 1426 | "pump": { 1427 | "version": "3.0.0", 1428 | "resolved": "https://registry.npmjs.org/pump/-/pump-3.0.0.tgz", 1429 | "integrity": "sha512-LwZy+p3SFs1Pytd/jYct4wpv49HiYCqd9Rlc5ZVdk0V+8Yzv6jR5Blk3TRmPL1ft69TxP0IMZGJ+WPFU2BFhww==", 1430 | "requires": { 1431 | "end-of-stream": "^1.1.0", 1432 | "once": "^1.3.1" 1433 | } 1434 | }, 1435 | "qs": { 1436 | "version": "6.7.0", 1437 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.7.0.tgz", 1438 | "integrity": "sha512-VCdBRNFTX1fyE7Nb6FYoURo/SPe62QCaAyzJvUjwRaIsc+NePBEniHlvxFmmX56+HZphIGtV0XeCirBtpDrTyQ==", 1439 | "dev": true 1440 | }, 1441 | "randomatic": { 1442 | "version": "3.1.1", 1443 | "resolved": "https://registry.npmjs.org/randomatic/-/randomatic-3.1.1.tgz", 1444 | "integrity": "sha512-TuDE5KxZ0J461RVjrJZCJc+J+zCkTb1MbH9AQUq68sMhOMcy9jLcb3BrZKgp9q9Ncltdg4QVqWrH02W2EFFVYw==", 1445 | "requires": { 1446 | "is-number": "^4.0.0", 1447 | "kind-of": "^6.0.0", 1448 | "math-random": "^1.0.1" 1449 | }, 1450 | "dependencies": { 1451 | "is-number": { 1452 | "version": "4.0.0", 1453 | "resolved": "https://registry.npmjs.org/is-number/-/is-number-4.0.0.tgz", 1454 | "integrity": "sha512-rSklcAIlf1OmFdyAqbnWTLVelsQ58uvZ66S/ZyawjWqIviTWCjg2PzVGw8WUA+nNuPTqb4wgA+NszrJ+08LlgQ==" 1455 | }, 1456 | "kind-of": { 1457 | "version": "6.0.2", 1458 | "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-6.0.2.tgz", 1459 | "integrity": "sha512-s5kLOcnH0XqDO+FvuaLX8DDjZ18CGFk7VygH40QoKPUQhW4e2rvM0rwUq0t8IQDOwYSeLK01U90OjzBTme2QqA==" 1460 | } 1461 | } 1462 | }, 1463 | "range-parser": { 1464 | "version": "1.2.1", 1465 | "resolved": "https://registry.npmjs.org/range-parser/-/range-parser-1.2.1.tgz", 1466 | "integrity": "sha512-Hrgsx+orqoygnmhFbKaHE6c296J+HTAQXoxEF6gNupROmmGJRoyzfG3ccAveqCBrwr/2yxQ5BVd/GTl5agOwSg==", 1467 | "dev": true 1468 | }, 1469 | "raw-body": { 1470 | "version": "2.4.0", 1471 | "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-2.4.0.tgz", 1472 | "integrity": "sha512-4Oz8DUIwdvoa5qMJelxipzi/iJIi40O5cGV1wNYp5hvZP8ZN0T+jiNkL0QepXs+EsQ9XJ8ipEDoiH70ySUJP3Q==", 1473 | "dev": true, 1474 | "requires": { 1475 | "bytes": "3.1.0", 1476 | "http-errors": "1.7.2", 1477 | "iconv-lite": "0.4.24", 1478 | "unpipe": "1.0.0" 1479 | } 1480 | }, 1481 | "regenerator-runtime": { 1482 | "version": "0.11.1", 1483 | "resolved": "https://registry.npmjs.org/regenerator-runtime/-/regenerator-runtime-0.11.1.tgz", 1484 | "integrity": "sha512-MguG95oij0fC3QV3URf4V2SDYGJhJnJGqvIIgdECeODCT98wSWDAJ94SSuVpYQUoTcGUIL6L4yNB7j1DFFHSBg==" 1485 | }, 1486 | "regex-cache": { 1487 | "version": "0.4.4", 1488 | "resolved": "https://registry.npmjs.org/regex-cache/-/regex-cache-0.4.4.tgz", 1489 | "integrity": "sha512-nVIZwtCjkC9YgvWkpM55B5rBhBYRZhAaJbgcFYXXsHnbZ9UZI9nnVWYZpBlCqv9ho2eZryPnWrZGsOdPwVWXWQ==", 1490 | "requires": { 1491 | "is-equal-shallow": "^0.1.3" 1492 | } 1493 | }, 1494 | "remove-trailing-separator": { 1495 | "version": "1.1.0", 1496 | "resolved": "https://registry.npmjs.org/remove-trailing-separator/-/remove-trailing-separator-1.1.0.tgz", 1497 | "integrity": "sha1-wkvOKig62tW8P1jg1IJJuSN52O8=" 1498 | }, 1499 | "repeat-element": { 1500 | "version": "1.1.3", 1501 | "resolved": "https://registry.npmjs.org/repeat-element/-/repeat-element-1.1.3.tgz", 1502 | "integrity": "sha512-ahGq0ZnV5m5XtZLMb+vP76kcAM5nkLqk0lpqAuojSKGgQtn4eRi4ZZGm2olo2zKFH+sMsWaqOCW1dqAnOru72g==" 1503 | }, 1504 | "repeat-string": { 1505 | "version": "1.6.1", 1506 | "resolved": "https://registry.npmjs.org/repeat-string/-/repeat-string-1.6.1.tgz", 1507 | "integrity": "sha1-jcrkcOHIirwtYA//Sndihtp15jc=" 1508 | }, 1509 | "repeating": { 1510 | "version": "2.0.1", 1511 | "resolved": "https://registry.npmjs.org/repeating/-/repeating-2.0.1.tgz", 1512 | "integrity": "sha1-UhTFOpJtNVJwdSf7q0FdvAjQbdo=", 1513 | "requires": { 1514 | "is-finite": "^1.0.0" 1515 | } 1516 | }, 1517 | "require-directory": { 1518 | "version": "2.1.1", 1519 | "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz", 1520 | "integrity": "sha1-jGStX9MNqxyXbiNE/+f3kqam30I=" 1521 | }, 1522 | "require-main-filename": { 1523 | "version": "1.0.1", 1524 | "resolved": "https://registry.npmjs.org/require-main-filename/-/require-main-filename-1.0.1.tgz", 1525 | "integrity": "sha1-l/cXtp1IeE9fUmpsWqj/3aBVpNE=" 1526 | }, 1527 | "safe-buffer": { 1528 | "version": "5.1.2", 1529 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 1530 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" 1531 | }, 1532 | "safer-buffer": { 1533 | "version": "2.1.2", 1534 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", 1535 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==", 1536 | "dev": true 1537 | }, 1538 | "semver": { 1539 | "version": "5.7.1", 1540 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", 1541 | "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==" 1542 | }, 1543 | "send": { 1544 | "version": "0.17.1", 1545 | "resolved": "https://registry.npmjs.org/send/-/send-0.17.1.tgz", 1546 | "integrity": "sha512-BsVKsiGcQMFwT8UxypobUKyv7irCNRHk1T0G680vk88yf6LBByGcZJOTJCrTP2xVN6yI+XjPJcNuE3V4fT9sAg==", 1547 | "dev": true, 1548 | "requires": { 1549 | "debug": "2.6.9", 1550 | "depd": "~1.1.2", 1551 | "destroy": "~1.0.4", 1552 | "encodeurl": "~1.0.2", 1553 | "escape-html": "~1.0.3", 1554 | "etag": "~1.8.1", 1555 | "fresh": "0.5.2", 1556 | "http-errors": "~1.7.2", 1557 | "mime": "1.6.0", 1558 | "ms": "2.1.1", 1559 | "on-finished": "~2.3.0", 1560 | "range-parser": "~1.2.1", 1561 | "statuses": "~1.5.0" 1562 | }, 1563 | "dependencies": { 1564 | "ms": { 1565 | "version": "2.1.1", 1566 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.1.tgz", 1567 | "integrity": "sha512-tgp+dl5cGk28utYktBsrFqA7HKgrhgPsg6Z/EfhWI4gl1Hwq8B/GmY/0oXZ6nF8hDVesS/FpnYaD/kOWhYQvyg==", 1568 | "dev": true 1569 | } 1570 | } 1571 | }, 1572 | "serve-static": { 1573 | "version": "1.14.1", 1574 | "resolved": "https://registry.npmjs.org/serve-static/-/serve-static-1.14.1.tgz", 1575 | "integrity": "sha512-JMrvUwE54emCYWlTI+hGrGv5I8dEwmco/00EvkzIIsR7MqrHonbD9pO2MOfFnpFntl7ecpZs+3mW+XbQZu9QCg==", 1576 | "dev": true, 1577 | "requires": { 1578 | "encodeurl": "~1.0.2", 1579 | "escape-html": "~1.0.3", 1580 | "parseurl": "~1.3.3", 1581 | "send": "0.17.1" 1582 | } 1583 | }, 1584 | "set-blocking": { 1585 | "version": "2.0.0", 1586 | "resolved": "https://registry.npmjs.org/set-blocking/-/set-blocking-2.0.0.tgz", 1587 | "integrity": "sha1-BF+XgtARrppoA93TgrJDkrPYkPc=" 1588 | }, 1589 | "setprototypeof": { 1590 | "version": "1.1.1", 1591 | "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.1.1.tgz", 1592 | "integrity": "sha512-JvdAWfbXeIGaZ9cILp38HntZSFSo3mWg6xGcJJsd+d4aRMOqauag1C63dJfDw7OaMYwEbHMOxEZ1lqVRYP2OAw==", 1593 | "dev": true 1594 | }, 1595 | "shebang-command": { 1596 | "version": "1.2.0", 1597 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-1.2.0.tgz", 1598 | "integrity": "sha1-RKrGW2lbAzmJaMOfNj/uXer98eo=", 1599 | "requires": { 1600 | "shebang-regex": "^1.0.0" 1601 | } 1602 | }, 1603 | "shebang-regex": { 1604 | "version": "1.0.0", 1605 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-1.0.0.tgz", 1606 | "integrity": "sha1-2kL0l0DAtC2yypcoVxyxkMmO/qM=" 1607 | }, 1608 | "sigmund": { 1609 | "version": "1.0.1", 1610 | "resolved": "https://registry.npmjs.org/sigmund/-/sigmund-1.0.1.tgz", 1611 | "integrity": "sha1-P/IfGYytIXX587eBhT/ZTQ0ZtZA=" 1612 | }, 1613 | "signal-exit": { 1614 | "version": "3.0.2", 1615 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.2.tgz", 1616 | "integrity": "sha1-tf3AjxKH6hF4Yo5BXiUTK3NkbG0=" 1617 | }, 1618 | "slash": { 1619 | "version": "1.0.0", 1620 | "resolved": "https://registry.npmjs.org/slash/-/slash-1.0.0.tgz", 1621 | "integrity": "sha1-xB8vbDn8FtHNF61LXYlhFK5HDVU=" 1622 | }, 1623 | "source-map": { 1624 | "version": "0.5.7", 1625 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.5.7.tgz", 1626 | "integrity": "sha1-igOdLRAh0i0eoUyA2OpGi6LvP8w=" 1627 | }, 1628 | "source-map-support": { 1629 | "version": "0.4.18", 1630 | "resolved": "https://registry.npmjs.org/source-map-support/-/source-map-support-0.4.18.tgz", 1631 | "integrity": "sha512-try0/JqxPLF9nOjvSta7tVondkP5dwgyLDjVoyMDlmjugT2lRZ1OfsrYTkCd2hkDnJTKRbO/Rl3orm8vlsUzbA==", 1632 | "requires": { 1633 | "source-map": "^0.5.6" 1634 | } 1635 | }, 1636 | "stack-utils": { 1637 | "version": "1.0.2", 1638 | "resolved": "https://registry.npmjs.org/stack-utils/-/stack-utils-1.0.2.tgz", 1639 | "integrity": "sha512-MTX+MeG5U994cazkjd/9KNAapsHnibjMLnfXodlkXw76JEea0UiNzrqidzo1emMwk7w5Qhc9jd4Bn9TBb1MFwA==" 1640 | }, 1641 | "statuses": { 1642 | "version": "1.5.0", 1643 | "resolved": "https://registry.npmjs.org/statuses/-/statuses-1.5.0.tgz", 1644 | "integrity": "sha1-Fhx9rBd2Wf2YEfQ3cfqZOBR4Yow=", 1645 | "dev": true 1646 | }, 1647 | "string-width": { 1648 | "version": "2.1.1", 1649 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-2.1.1.tgz", 1650 | "integrity": "sha512-nOqH59deCq9SRHlxq1Aw85Jnt4w6KvLKqWVik6oA9ZklXLNIOlqg4F2yrT1MVaTjAqvVwdfeZ7w7aCvJD7ugkw==", 1651 | "requires": { 1652 | "is-fullwidth-code-point": "^2.0.0", 1653 | "strip-ansi": "^4.0.0" 1654 | }, 1655 | "dependencies": { 1656 | "ansi-regex": { 1657 | "version": "3.0.0", 1658 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-3.0.0.tgz", 1659 | "integrity": "sha1-7QMXwyIGT3lGbAKWa922Bas32Zg=" 1660 | }, 1661 | "strip-ansi": { 1662 | "version": "4.0.0", 1663 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-4.0.0.tgz", 1664 | "integrity": "sha1-qEeQIusaw2iocTibY1JixQXuNo8=", 1665 | "requires": { 1666 | "ansi-regex": "^3.0.0" 1667 | } 1668 | } 1669 | } 1670 | }, 1671 | "strip-ansi": { 1672 | "version": "3.0.1", 1673 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-3.0.1.tgz", 1674 | "integrity": "sha1-ajhfuIU9lS1f8F0Oiq+UJ43GPc8=", 1675 | "requires": { 1676 | "ansi-regex": "^2.0.0" 1677 | } 1678 | }, 1679 | "strip-eof": { 1680 | "version": "1.0.0", 1681 | "resolved": "https://registry.npmjs.org/strip-eof/-/strip-eof-1.0.0.tgz", 1682 | "integrity": "sha1-u0P/VZim6wXYm1n80SnJgzE2Br8=" 1683 | }, 1684 | "supports-color": { 1685 | "version": "2.0.0", 1686 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-2.0.0.tgz", 1687 | "integrity": "sha1-U10EXOa2Nj+kARcIRimZXp3zJMc=" 1688 | }, 1689 | "to-fast-properties": { 1690 | "version": "1.0.3", 1691 | "resolved": "https://registry.npmjs.org/to-fast-properties/-/to-fast-properties-1.0.3.tgz", 1692 | "integrity": "sha1-uDVx+k2MJbguIxsG46MFXeTKGkc=" 1693 | }, 1694 | "toidentifier": { 1695 | "version": "1.0.0", 1696 | "resolved": "https://registry.npmjs.org/toidentifier/-/toidentifier-1.0.0.tgz", 1697 | "integrity": "sha512-yaOH/Pk/VEhBWWTlhI+qXxDFXlejDGcQipMlyxda9nthulaxLZUNcUqFxokp0vcYnvteJln5FNQDRrxj3YcbVw==", 1698 | "dev": true 1699 | }, 1700 | "trim-right": { 1701 | "version": "1.0.1", 1702 | "resolved": "https://registry.npmjs.org/trim-right/-/trim-right-1.0.1.tgz", 1703 | "integrity": "sha1-yy4SAwZ+DI3h9hQJS5/kVwTqYAM=" 1704 | }, 1705 | "type-is": { 1706 | "version": "1.6.18", 1707 | "resolved": "https://registry.npmjs.org/type-is/-/type-is-1.6.18.tgz", 1708 | "integrity": "sha512-TkRKr9sUTxEH8MdfuCSP7VizJyzRNMjj2J2do2Jr3Kym598JVdEksuzPQCnlFPW4ky9Q+iA+ma9BGm06XQBy8g==", 1709 | "dev": true, 1710 | "requires": { 1711 | "media-typer": "0.3.0", 1712 | "mime-types": "~2.1.24" 1713 | } 1714 | }, 1715 | "uglify-es": { 1716 | "version": "3.3.10", 1717 | "resolved": "https://registry.npmjs.org/uglify-es/-/uglify-es-3.3.10.tgz", 1718 | "integrity": "sha512-rPzPisCzW68Okj1zNrfa2dR9uEm43SevDmpR6FChoZABFk9dANGnzzBMgHYUXI3609//63fnVkyQ1SQmAMyjww==", 1719 | "requires": { 1720 | "commander": "~2.14.1", 1721 | "source-map": "~0.6.1" 1722 | }, 1723 | "dependencies": { 1724 | "commander": { 1725 | "version": "2.14.1", 1726 | "resolved": "https://registry.npmjs.org/commander/-/commander-2.14.1.tgz", 1727 | "integrity": "sha512-+YR16o3rK53SmWHU3rEM3tPAh2rwb1yPcQX5irVn7mb0gXbwuCCrnkbV5+PBfETdfg1vui07nM6PCG1zndcjQw==" 1728 | }, 1729 | "source-map": { 1730 | "version": "0.6.1", 1731 | "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", 1732 | "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==" 1733 | } 1734 | } 1735 | }, 1736 | "undom": { 1737 | "version": "0.3.3", 1738 | "resolved": "https://registry.npmjs.org/undom/-/undom-0.3.3.tgz", 1739 | "integrity": "sha1-WNGisM4GWXX3/DacGAoBMbYlwcM=" 1740 | }, 1741 | "unpipe": { 1742 | "version": "1.0.0", 1743 | "resolved": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz", 1744 | "integrity": "sha1-sr9O6FFKrmFltIF4KdIbLvSZBOw=", 1745 | "dev": true 1746 | }, 1747 | "utils-merge": { 1748 | "version": "1.0.1", 1749 | "resolved": "https://registry.npmjs.org/utils-merge/-/utils-merge-1.0.1.tgz", 1750 | "integrity": "sha1-n5VxD1CiZ5R7LMwSR0HBAoQn5xM=", 1751 | "dev": true 1752 | }, 1753 | "vary": { 1754 | "version": "1.1.2", 1755 | "resolved": "https://registry.npmjs.org/vary/-/vary-1.1.2.tgz", 1756 | "integrity": "sha1-IpnwLG3tMNSllhsLn3RSShj2NPw=", 1757 | "dev": true 1758 | }, 1759 | "which": { 1760 | "version": "1.3.1", 1761 | "resolved": "https://registry.npmjs.org/which/-/which-1.3.1.tgz", 1762 | "integrity": "sha512-HxJdYWq1MTIQbJ3nw0cqssHoTNU267KlrDuGZ1WYlxDStUtKUhOaJmh112/TZmHxxUfuJqPXSOm7tDyas0OSIQ==", 1763 | "requires": { 1764 | "isexe": "^2.0.0" 1765 | } 1766 | }, 1767 | "which-module": { 1768 | "version": "2.0.0", 1769 | "resolved": "https://registry.npmjs.org/which-module/-/which-module-2.0.0.tgz", 1770 | "integrity": "sha1-2e8H3Od7mQK4o6j6SzHD4/fm6Ho=" 1771 | }, 1772 | "wrap-ansi": { 1773 | "version": "2.1.0", 1774 | "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-2.1.0.tgz", 1775 | "integrity": "sha1-2Pw9KE3QV5T+hJc8rs3Rz4JP3YU=", 1776 | "requires": { 1777 | "string-width": "^1.0.1", 1778 | "strip-ansi": "^3.0.1" 1779 | }, 1780 | "dependencies": { 1781 | "is-fullwidth-code-point": { 1782 | "version": "1.0.0", 1783 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-1.0.0.tgz", 1784 | "integrity": "sha1-754xOG8DGn8NZDr4L95QxFfvAMs=", 1785 | "requires": { 1786 | "number-is-nan": "^1.0.0" 1787 | } 1788 | }, 1789 | "string-width": { 1790 | "version": "1.0.2", 1791 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-1.0.2.tgz", 1792 | "integrity": "sha1-EYvfW4zcUaKn5w0hHgfisLmxB9M=", 1793 | "requires": { 1794 | "code-point-at": "^1.0.0", 1795 | "is-fullwidth-code-point": "^1.0.0", 1796 | "strip-ansi": "^3.0.0" 1797 | } 1798 | } 1799 | } 1800 | }, 1801 | "wrappy": { 1802 | "version": "1.0.2", 1803 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 1804 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=" 1805 | }, 1806 | "y18n": { 1807 | "version": "3.2.1", 1808 | "resolved": "https://registry.npmjs.org/y18n/-/y18n-3.2.1.tgz", 1809 | "integrity": "sha1-bRX7qITAhnnA136I53WegR4H+kE=" 1810 | }, 1811 | "yallist": { 1812 | "version": "2.1.2", 1813 | "resolved": "https://registry.npmjs.org/yallist/-/yallist-2.1.2.tgz", 1814 | "integrity": "sha1-HBH5IY8HYImkfdUS+TxmmaaoHVI=" 1815 | }, 1816 | "yargs": { 1817 | "version": "11.1.1", 1818 | "resolved": "https://registry.npmjs.org/yargs/-/yargs-11.1.1.tgz", 1819 | "integrity": "sha512-PRU7gJrJaXv3q3yQZ/+/X6KBswZiaQ+zOmdprZcouPYtQgvNU35i+68M4b1ZHLZtYFT5QObFLV+ZkmJYcwKdiw==", 1820 | "requires": { 1821 | "cliui": "^4.0.0", 1822 | "decamelize": "^1.1.1", 1823 | "find-up": "^2.1.0", 1824 | "get-caller-file": "^1.0.1", 1825 | "os-locale": "^3.1.0", 1826 | "require-directory": "^2.1.1", 1827 | "require-main-filename": "^1.0.1", 1828 | "set-blocking": "^2.0.0", 1829 | "string-width": "^2.0.0", 1830 | "which-module": "^2.0.0", 1831 | "y18n": "^3.2.1", 1832 | "yargs-parser": "^9.0.2" 1833 | } 1834 | }, 1835 | "yargs-parser": { 1836 | "version": "9.0.2", 1837 | "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-9.0.2.tgz", 1838 | "integrity": "sha1-nM9qQ0YP5O1Aqbto9I1DuKaMwHc=", 1839 | "requires": { 1840 | "camelcase": "^4.1.0" 1841 | } 1842 | } 1843 | } 1844 | } 1845 | -------------------------------------------------------------------------------- /skate-ssr/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "wc-prerender", 3 | "version": "1.0.0", 4 | "description": "My master thesis project regarding pre-rendering of Web Components", 5 | "author": "Andreas Hahn", 6 | "license": "MIT", 7 | "scripts": { 8 | "start": "ts-node server.ts", 9 | "render": "ts-node prerender.ts" 10 | }, 11 | "dependencies": { 12 | "@skatejs/ssr": "^0.19.11" 13 | }, 14 | "repository": { 15 | "type": "git", 16 | "url": "git+https://github.com/drdreo/wc-prerender.git" 17 | }, 18 | "keywords": [ 19 | "webcomponents", 20 | "prerendering" 21 | ], 22 | "devDependencies": { 23 | "express": "latest", 24 | "ts-node": "^8.6.2" 25 | } 26 | } 27 | -------------------------------------------------------------------------------- /skate-ssr/prerender.ts: -------------------------------------------------------------------------------- 1 | import { render } from './render'; 2 | 3 | import { join } from 'path'; 4 | import { writeFile } from 'fs'; 5 | import { renderToPage } from './utils'; 6 | 7 | // the web component to render 8 | const Hello = require('./public/components/my-hello'); 9 | 10 | const hello = new Hello(); 11 | hello.textContent = 'Felix'; 12 | hello.setAttribute('greeting', 'Sias'); 13 | 14 | const ColorText = require('./public/components/color-text'); 15 | const colorText = new ColorText(); 16 | 17 | const RealCounter = require('./public/components/real-counter'); 18 | const counter = new RealCounter(); 19 | 20 | const allRendered = Promise.all([ 21 | render(hello), 22 | render(counter) 23 | ]); 24 | 25 | 26 | allRendered.then(serializedComponents => { 27 | const file = './public/pages/index.html'; 28 | 29 | renderToPage(file, serializedComponents.join('')).then(pageContent => { 30 | writeFile( 31 | join(__dirname, file.replace('.html', '.ssr.html')), 32 | pageContent, 33 | {encoding: 'utf8'}, 34 | async (err) => { 35 | if (err) { 36 | console.log(err); 37 | } else { 38 | console.log('[Skate/ssr] Pre-rendering finished successfully!'); 39 | } 40 | }); 41 | }); 42 | }); 43 | -------------------------------------------------------------------------------- /skate-ssr/public/components/color-text.js: -------------------------------------------------------------------------------- 1 | class ColorText extends HTMLElement { 2 | connectedCallback() { 3 | this.attachShadow({mode: "open"}); 4 | this.shadowRoot.innerHTML = ` 5 | `; 6 | } 7 | } 8 | 9 | customElements.define("color-text", ColorText); 10 | module.exports = ColorText; 11 | -------------------------------------------------------------------------------- /skate-ssr/public/components/color-text_comp.js: -------------------------------------------------------------------------------- 1 | class ColorText extends HTMLElement { 2 | connectedCallback() { 3 | this.attachShadow({mode: "open"}); 4 | this.shadowRoot.innerHTML = ` 5 | `; 6 | } 7 | } 8 | 9 | customElements.define("color-text", ColorText); 10 | -------------------------------------------------------------------------------- /skate-ssr/public/components/my-hello.js: -------------------------------------------------------------------------------- 1 | class Hello extends HTMLElement { 2 | 3 | connectedCallback() { 4 | this.attachShadow({mode: "open"}); 5 | this.shadowRoot.innerHTML = ` 6 | ${this.getAttribute("greeting")}, 7 | ! 8 | `; 9 | } 10 | 11 | get greeting() { 12 | return this.getAttribute("greeting"); 13 | } 14 | 15 | set greeting(value) { 16 | this.shadowRoot.querySelector("[data-greeting]").innerHTML = value; 17 | this.setAttribute("greeting", value); 18 | } 19 | } 20 | 21 | customElements.define("my-hello", Hello); 22 | module.exports = Hello; 23 | -------------------------------------------------------------------------------- /skate-ssr/public/components/my-hello_comp.js: -------------------------------------------------------------------------------- 1 | class Hello extends HTMLElement { 2 | 3 | connectedCallback() { 4 | this.attachShadow({mode: "open"}); 5 | this.shadowRoot.innerHTML = ` 6 | ${this.getAttribute("greeting")}, 7 | ! 8 | `; 9 | } 10 | 11 | get greeting() { 12 | return this.getAttribute("greeting"); 13 | } 14 | 15 | set greeting(value) { 16 | this.shadowRoot.querySelector("[data-greeting]").innerHTML = value; 17 | this.setAttribute("greeting", value); 18 | } 19 | } 20 | 21 | customElements.define("my-hello", Hello); 22 | -------------------------------------------------------------------------------- /skate-ssr/public/components/real-counter.js: -------------------------------------------------------------------------------- 1 | class RealCounter extends HTMLElement { 2 | 3 | 4 | constructor() { 5 | super(); 6 | 7 | this.counterValue = 0; 8 | } 9 | 10 | connectedCallback() { 11 | this.attachShadow({mode: "open"}); 12 | this.render(); 13 | this.interval = setInterval(() => { 14 | this.counter++; 15 | }, 500); 16 | } 17 | 18 | disconnectedCallback() { 19 | clearInterval(this.interval); 20 | } 21 | 22 | set counter(count) { 23 | console.log("setting counter to: " + count); 24 | this.counterValue = count; 25 | this.render(); 26 | } 27 | 28 | get counter() { 29 | return this.counterValue; 30 | } 31 | 32 | render() { 33 | this.shadowRoot.innerHTML = `
${this.counter}!
`; 34 | } 35 | } 36 | 37 | customElements.define("real-counter", RealCounter); 38 | module.exports = RealCounter; 39 | -------------------------------------------------------------------------------- /skate-ssr/public/components/real-counter_comp.js: -------------------------------------------------------------------------------- 1 | class RealCounter extends HTMLElement { 2 | constructor() { 3 | super(); 4 | 5 | this.counterValue = 0; 6 | } 7 | 8 | connectedCallback() { 9 | this.attachShadow({mode: "open"}); 10 | this.render(); 11 | this.interval = setInterval(() => { 12 | this.counter++; 13 | }, 500); 14 | } 15 | 16 | disconnectedCallback() { 17 | clearInterval(this.interval); 18 | } 19 | 20 | set counter(count) { 21 | console.log("setting counter to: " + count); 22 | this.counterValue = count; 23 | this.render(); 24 | } 25 | 26 | get counter() { 27 | return this.counterValue; 28 | } 29 | 30 | render() { 31 | this.shadowRoot.innerHTML = `
${this.counter}!
`; 32 | } 33 | } 34 | 35 | customElements.define("real-counter", RealCounter); 36 | -------------------------------------------------------------------------------- /skate-ssr/public/pages/index.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | Skate/SSR Pre-render 6 | 7 | 8 | 9 | 10 | 11 | 12 |

Skate/SSR Index.HTML

13 | 14 | 15 | 16 | -------------------------------------------------------------------------------- /skate-ssr/public/pages/index.ssr.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | Skate/SSR Pre-render 6 | 7 | 8 | 9 | 10 | 11 | 12 |

Skate/SSR Index.HTML

13 | 14 | 15 | Sias, 16 | ! 17 | Felix
18 | 0!
19 | 20 | -------------------------------------------------------------------------------- /skate-ssr/render.ts: -------------------------------------------------------------------------------- 1 | // This provides the DOM API, so load it first. 2 | require('@skatejs/ssr/register'); 3 | 4 | // Renders the provided DOM tree to a string. 5 | export const render = require('@skatejs/ssr'); 6 | export const shadowRootScript = ``; 7 | -------------------------------------------------------------------------------- /skate-ssr/server.ts: -------------------------------------------------------------------------------- 1 | import { join } from 'path'; 2 | import { readFile } from 'fs'; 3 | import express from 'express'; 4 | import { render, shadowRootScript } from './render'; 5 | import { renderToPage } from './utils'; 6 | 7 | const server = express(); 8 | const PORT = 3002; 9 | const timings = []; 10 | 11 | server.use(express.static('public')); 12 | 13 | server.get('/', (req, res) => { 14 | res.redirect('/index.ssr.html'); 15 | }); 16 | 17 | server.get('/ssr', async (req, res) => { 18 | const name = req.query.name || 'Felix'; 19 | const file = './public/pages/index.html'; 20 | // the web component to render 21 | const Hello = require('./public/components/my-hello'); 22 | const hello = new Hello(); 23 | hello.textContent = name; 24 | hello.setAttribute('greeting', 'Sias'); 25 | 26 | const startTime = process.hrtime() 27 | const serializedHello = await render(hello); 28 | const pageContent = await renderToPage(file, serializedHello); 29 | const endTime = process.hrtime(startTime)[1] / 1000000; 30 | timings.push(endTime); 31 | console.info('time: %dms', endTime); 32 | res.send(pageContent); 33 | }); 34 | 35 | server.get('/avg', async (req, res) => { 36 | res.json({data: timings, total: timings.length -1, avg: timings.reduce((a,b) => a + b, 0) / timings.length}); 37 | }); 38 | 39 | 40 | server.get('*', (req, res, next) => { 41 | console.log('Serving: ', req.url); 42 | let htmlFile = req.url; 43 | 44 | res.sendFile(join(__dirname + '/public/pages/' + htmlFile)); 45 | }); 46 | 47 | server.listen(PORT, () => { 48 | console.log(`Server listening at http://localhost:${PORT}`); 49 | }); 50 | -------------------------------------------------------------------------------- /skate-ssr/tsconfig.json: -------------------------------------------------------------------------------- 1 | { 2 | "compilerOptions": { 3 | "target": "es6", 4 | "module": "commonjs", 5 | "sourceMap": true, 6 | "resolveJsonModule": true, 7 | "lib": ["es6", "dom"], 8 | "esModuleInterop": true 9 | }, 10 | "include": [ 11 | "**/*.ts" 12 | ], 13 | "exclude": [ 14 | "node_modules" 15 | ] 16 | } 17 | -------------------------------------------------------------------------------- /skate-ssr/utils.ts: -------------------------------------------------------------------------------- 1 | import { readFile } from 'fs'; 2 | import { shadowRootScript } from './render'; 3 | 4 | export function renderToPage(file: string, component: string): Promise { 5 | return new Promise(resolve => { 6 | readFile(file, 'utf8', (err, data) => { 7 | let pageContent = data.replace('', `${shadowRootScript}`); 8 | resolve(pageContent.replace('', `${component}`)); 9 | }); 10 | }); 11 | } 12 | -------------------------------------------------------------------------------- /stringify.ts: -------------------------------------------------------------------------------- 1 | const shadowRootScript = ``; 2 | const shadowRootScriptCall = ``; 3 | 4 | 5 | export function stringify(node) { 6 | let str = ''; 7 | 8 | if (node.nodeName === '#document') { 9 | node = node.documentElement; 10 | str += ''; 11 | } 12 | 13 | if (node.nodeName === '#text') { 14 | return node.textContent; 15 | } 16 | 17 | str += `<${node.localName}${(node.attributes || []) 18 | .map(a => ` ${a.name}="${a.value}"`) 19 | .join('')}>`; 20 | 21 | if (node.nodeName === 'BODY') { 22 | str += shadowRootScript; 23 | } 24 | 25 | if (node.shadowRoot) { 26 | str += `${node.shadowRoot.childNodes 27 | .map(stringify) 28 | .join('')}${shadowRootScriptCall}`; 29 | } 30 | 31 | if (node.childNodes) { 32 | str += node.childNodes.map(stringify).join(''); 33 | } 34 | 35 | str += ``; 36 | 37 | return str; 38 | } 39 | -------------------------------------------------------------------------------- /test.ts: -------------------------------------------------------------------------------- 1 | const http = require("http"); 2 | const url = "http://localhost:3002/ssr"; 3 | 4 | setInterval(() => { 5 | http.get(url, res => {}); 6 | }, 100); 7 | 8 | --------------------------------------------------------------------------------