├── test ├── src │ ├── index.ts │ ├── components │ │ ├── css-in-js-test │ │ │ ├── css-in-js-test.css │ │ │ ├── readme.md │ │ │ ├── css-in-js-test.tsx │ │ │ └── index.html │ │ └── theme-provider │ │ │ ├── get-provider.tsx │ │ │ ├── theme-provider.tsx │ │ │ └── readme.md │ ├── index.html │ └── components.d.ts ├── cypress.json ├── cypress │ ├── snapshots │ │ └── css-in-js.spec.js │ │ │ ├── Should render style overrides - 1.snap.png │ │ │ ├── Should dynamically update theme - 1.snap.png │ │ │ └── Should render default template - 1.snap.png │ ├── support │ │ ├── index.js │ │ └── commands.js │ ├── utils │ │ └── index.js │ ├── plugins │ │ └── index.js │ └── integration │ │ └── css-in-js.spec.js ├── readme.md ├── stencil.config.ts ├── tsconfig.json ├── package.json └── package-lock.json ├── src ├── index.ts ├── types.ts ├── getStyle.ts └── CssInJs.tsx ├── .editorconfig ├── .gitignore ├── tsconfig.json ├── package.json ├── LICENSE └── README.md /test/src/index.ts: -------------------------------------------------------------------------------- 1 | export * from './components'; 2 | -------------------------------------------------------------------------------- /test/src/components/css-in-js-test/css-in-js-test.css: -------------------------------------------------------------------------------- 1 | [class^="root"] { 2 | font-family: Roboto; 3 | } 4 | -------------------------------------------------------------------------------- /src/index.ts: -------------------------------------------------------------------------------- 1 | export { CssInJs } from "./CssInJs"; 2 | export { getStyles } from "./getStyle"; 3 | export * from "./types"; 4 | -------------------------------------------------------------------------------- /test/cypress.json: -------------------------------------------------------------------------------- 1 | { 2 | "baseUrl": "http://localhost:3333", 3 | "viewportWidth": 1280, 4 | "viewportHeight": 720 5 | } 6 | -------------------------------------------------------------------------------- /test/cypress/snapshots/css-in-js.spec.js/Should render style overrides - 1.snap.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Justin-Palmer/stencil-css-in-js/HEAD/test/cypress/snapshots/css-in-js.spec.js/Should render style overrides - 1.snap.png -------------------------------------------------------------------------------- /test/cypress/snapshots/css-in-js.spec.js/Should dynamically update theme - 1.snap.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Justin-Palmer/stencil-css-in-js/HEAD/test/cypress/snapshots/css-in-js.spec.js/Should dynamically update theme - 1.snap.png -------------------------------------------------------------------------------- /test/cypress/snapshots/css-in-js.spec.js/Should render default template - 1.snap.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Justin-Palmer/stencil-css-in-js/HEAD/test/cypress/snapshots/css-in-js.spec.js/Should render default template - 1.snap.png -------------------------------------------------------------------------------- /test/readme.md: -------------------------------------------------------------------------------- 1 | # Stencil Test Application 2 | 3 | This is a Stencil application for testing the decorator functionality. 4 | 5 | ## Getting Started 6 | 7 | ```bash 8 | npm install 9 | npm start 10 | ``` 11 | 12 | To run the tests for the library, run: 13 | 14 | ```bash 15 | npm run cypress:run 16 | ``` 17 | -------------------------------------------------------------------------------- /.editorconfig: -------------------------------------------------------------------------------- 1 | # http://editorconfig.org 2 | 3 | root = true 4 | 5 | [*] 6 | charset = utf-8 7 | indent_style = space 8 | indent_size = 2 9 | end_of_line = lf 10 | insert_final_newline = true 11 | trim_trailing_whitespace = true 12 | 13 | [*.md] 14 | insert_final_newline = false 15 | trim_trailing_whitespace = false 16 | -------------------------------------------------------------------------------- /test/src/components/theme-provider/get-provider.tsx: -------------------------------------------------------------------------------- 1 | import { h } from "@stencil/core"; 2 | import { createProviderConsumer } from "@stencil/state-tunnel"; 3 | 4 | export interface State { 5 | theme: any; 6 | } 7 | 8 | export default createProviderConsumer( 9 | { 10 | theme: {} 11 | }, 12 | (subscribe, child) => ( 13 | 14 | ) 15 | ); 16 | -------------------------------------------------------------------------------- /test/stencil.config.ts: -------------------------------------------------------------------------------- 1 | import { Config } from "@stencil/core"; 2 | 3 | export const config: Config = { 4 | namespace: "stencil-css-in-js", 5 | srcIndexHtml: "src/index.html", 6 | outputTargets: [ 7 | { 8 | type: "dist", 9 | esmLoaderPath: "../loader" 10 | }, 11 | { 12 | type: "docs-readme" 13 | }, 14 | { 15 | type: "www", 16 | serviceWorker: null // disable service workers 17 | } 18 | ] 19 | }; 20 | -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | dist/ 2 | www/ 3 | loader/ 4 | 5 | *~ 6 | *.sw[mnpcod] 7 | *.log 8 | *.lock 9 | *.tmp 10 | *.tmp.* 11 | log.txt 12 | *.sublime-project 13 | *.sublime-workspace 14 | 15 | .stencil/ 16 | .idea/ 17 | .vscode/ 18 | .sass-cache/ 19 | .versions/ 20 | **node_modules/ 21 | $RECYCLE.BIN/ 22 | 23 | .DS_Store 24 | Thumbs.db 25 | UserInterfaceState.xcuserstate 26 | .env 27 | 28 | **/cypress/**/__diff_output__/** 29 | **/cypress/videos/** 30 | **/cypress/screenshots/** -------------------------------------------------------------------------------- /test/src/components/css-in-js-test/readme.md: -------------------------------------------------------------------------------- 1 | # my-component 2 | 3 | 4 | 5 | 6 | 7 | 8 | ## Dependencies 9 | 10 | ### Depends on 11 | 12 | - context-consumer 13 | 14 | ### Graph 15 | ```mermaid 16 | graph TD; 17 | my-component --> context-consumer 18 | style my-component fill:#f9f,stroke:#333,stroke-width:4px 19 | ``` 20 | 21 | ---------------------------------------------- 22 | 23 | *Built with [StencilJS](https://stenciljs.com/)* 24 | -------------------------------------------------------------------------------- /test/src/index.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 9 | Stencil Component Starter 10 | 11 | 12 | 13 | 14 | 15 | 16 | -------------------------------------------------------------------------------- /test/src/components/theme-provider/theme-provider.tsx: -------------------------------------------------------------------------------- 1 | import { Component, h, Host, Prop } from "@stencil/core"; 2 | import Tunnel from "./get-provider"; 3 | 4 | @Component({ 5 | tag: "theme-provider", 6 | shadow: true 7 | }) 8 | export class MyComponent { 9 | @Prop() theme = {}; 10 | 11 | render() { 12 | return ( 13 | 14 | 15 | 16 | 17 | 18 | ); 19 | } 20 | } 21 | -------------------------------------------------------------------------------- /src/types.ts: -------------------------------------------------------------------------------- 1 | import { StyleSheet } from "jss"; 2 | 3 | export interface Theme { 4 | [key: string]: any; 5 | } 6 | 7 | export interface Styles { 8 | [key: string]: any; 9 | } 10 | 11 | export interface StyleObject { 12 | sheet: StyleSheet; 13 | adoptedSheet: ExtendedCSSStyleSheet; 14 | } 15 | 16 | export interface ExtendedCSSStyleSheet extends CSSStyleSheet { 17 | // Needed due to typescript error with replaceSync not existing on type CSSStyleSheet at the moment. 18 | replaceSync?: any; 19 | "data-cssInJsId"?: any; 20 | } 21 | -------------------------------------------------------------------------------- /test/tsconfig.json: -------------------------------------------------------------------------------- 1 | { 2 | "compilerOptions": { 3 | "allowSyntheticDefaultImports": true, 4 | "allowUnreachableCode": false, 5 | "noImplicitAny": true, 6 | "declaration": false, 7 | "experimentalDecorators": true, 8 | "lib": ["dom", "es2017"], 9 | "moduleResolution": "node", 10 | "module": "esnext", 11 | "target": "es2017", 12 | "noUnusedLocals": true, 13 | "noUnusedParameters": true, 14 | "jsx": "react", 15 | "jsxFactory": "h" 16 | }, 17 | "include": ["src", "types/jsx.d.ts"], 18 | "exclude": ["node_modules"] 19 | } 20 | -------------------------------------------------------------------------------- /tsconfig.json: -------------------------------------------------------------------------------- 1 | { 2 | "files": ["src/index.ts"], 3 | "exclude": ["node_modules"], 4 | "compilerOptions": { 5 | "allowSyntheticDefaultImports": true, 6 | "allowUnreachableCode": false, 7 | "noImplicitAny": true, 8 | "experimentalDecorators": true, 9 | "lib": ["dom", "es2017"], 10 | "moduleResolution": "node", 11 | "module": "esnext", 12 | "target": "es2017", 13 | "noUnusedLocals": true, 14 | "noUnusedParameters": true, 15 | "jsx": "react", 16 | "jsxFactory": "h", 17 | "declaration": true, 18 | "declarationDir": "dist/", 19 | "outDir": "dist/" 20 | } 21 | } 22 | -------------------------------------------------------------------------------- /test/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "scripts": { 3 | "build": "stencil build --docs", 4 | "start": "stencil build --dev --watch --serve", 5 | "cypress:run": "cypress run", 6 | "cypress:open": "cypress open", 7 | "cypress:update-images": "cypress run --env updateSnapshots=true", 8 | "cypress:suppress-image-failure": "cypress run --env failOnSnapshotDiff=false", 9 | "generate": "stencil generate" 10 | }, 11 | "devDependencies": { 12 | "@stencil/core": "1.2.0", 13 | "@stencil/state-tunnel": "1.0.1", 14 | "cypress": "3.8.2", 15 | "cypress-image-snapshot": "3.1.1", 16 | "cypress-shadow-dom": "1.3.0" 17 | } 18 | } 19 | -------------------------------------------------------------------------------- /test/cypress/support/index.js: -------------------------------------------------------------------------------- 1 | // *********************************************************** 2 | // This example support/index.js is processed and 3 | // loaded automatically before your test files. 4 | // 5 | // This is a great place to put global configuration and 6 | // behavior that modifies Cypress. 7 | // 8 | // You can change the location of this file or turn off 9 | // automatically serving support files with the 10 | // 'supportFile' configuration option. 11 | // 12 | // You can read more here: 13 | // https://on.cypress.io/configuration 14 | // *********************************************************** 15 | 16 | // Import commands.js using ES2015 syntax: 17 | import './commands' 18 | 19 | // Alternatively you can use CommonJS syntax: 20 | // require('./commands') 21 | -------------------------------------------------------------------------------- /test/cypress/utils/index.js: -------------------------------------------------------------------------------- 1 | function getFragment(doc, template) { 2 | let fragment = new DocumentFragment(); 3 | 4 | template.forEach(item => { 5 | buildFragment(doc, item, fragment); 6 | }); 7 | 8 | return fragment; 9 | } 10 | 11 | function buildFragment(doc, template, parentElement) { 12 | let element = doc.createElement(template.component); 13 | 14 | if (template.innerHTML) { 15 | element.innerHTML = template.innerHTML; 16 | } 17 | 18 | if (template.props) { 19 | Object.keys(template.props).forEach(key => { 20 | element[key] = template.props[key]; 21 | }); 22 | } 23 | 24 | parentElement.appendChild(element); 25 | 26 | if (template.children) { 27 | for (const item of template.children) { 28 | buildFragment(doc, item, element); 29 | } 30 | } 31 | } 32 | 33 | export { getFragment }; 34 | -------------------------------------------------------------------------------- /test/src/components/css-in-js-test/css-in-js-test.tsx: -------------------------------------------------------------------------------- 1 | import { Component, h } from "@stencil/core"; 2 | import { CssInJs } from "../../../../dist/index"; 3 | import Tunnel from "../theme-provider/get-provider"; 4 | 5 | const styles = { 6 | root: { 7 | padding: "24px", 8 | background: (theme: any) => theme.background 9 | }, 10 | content: { 11 | color: "white" 12 | } 13 | }; 14 | 15 | @Component({ 16 | tag: "css-in-js-test", 17 | styleUrl: "css-in-js-test.css", 18 | shadow: true 19 | }) 20 | export class CssInJsTest { 21 | componentWillLoad() {} 22 | 23 | @CssInJs({ 24 | styles 25 | }) 26 | renderer = (classes: any) => { 27 | return ( 28 |
29 |
30 | 31 |
32 |
33 | ); 34 | }; 35 | } 36 | 37 | Tunnel.injectProps(CssInJsTest, ["theme"]); 38 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "stencil-css-in-js", 3 | "version": "1.0.0-beta.0", 4 | "description": "CSS-in-JS library for StencilJs", 5 | "author": "Justin Palmer", 6 | "license": "MIT", 7 | "keywords": [ 8 | "Stencil", 9 | "StencilJs", 10 | "Decorator", 11 | "CSS-in-JS", 12 | "CssInJs" 13 | ], 14 | "repository": { 15 | "type": "git", 16 | "url": "git+https://github.com/Justin-Palmer/stencil-css-in-js.git" 17 | }, 18 | "bugs": { 19 | "url": "https://github.com/Justin-Palmer/stencil-css-in-js/issues" 20 | }, 21 | "homepage": "https://github.com/Justin-Palmer/stencil-css-in-js", 22 | "main": "dist/index.js", 23 | "types": "dist/index.d.ts", 24 | "files": [ 25 | "dist/" 26 | ], 27 | "scripts": { 28 | "build": "tsc" 29 | }, 30 | "dependencies": { 31 | "jss": "10.0.3", 32 | "jss-preset-default": "10.0.3" 33 | }, 34 | "peerDependencies": { 35 | "@stencil/core": "^1.2.0" 36 | }, 37 | "devDependencies": { 38 | "@stencil/core": "1.2.0", 39 | "typescript": "^3.7.2" 40 | } 41 | } 42 | -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | MIT License 2 | 3 | Copyright (c) 2020 Justin-Palmer 4 | 5 | Permission is hereby granted, free of charge, to any person obtaining a copy 6 | of this software and associated documentation files (the "Software"), to deal 7 | in the Software without restriction, including without limitation the rights 8 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 9 | copies of the Software, and to permit persons to whom the Software is 10 | furnished to do so, subject to the following conditions: 11 | 12 | The above copyright notice and this permission notice shall be included in all 13 | copies or substantial portions of the Software. 14 | 15 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 16 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 17 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 18 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 19 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 20 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE 21 | SOFTWARE. 22 | -------------------------------------------------------------------------------- /test/src/components/theme-provider/readme.md: -------------------------------------------------------------------------------- 1 | # theme-provider 2 | 3 | 4 | 5 | 6 | 7 | 8 | ## Properties 9 | 10 | | Property | Attribute | Description | Type | Default | 11 | | -------- | --------- | ----------- | ---------------------------------------------------------------------- | ------------------------------------------------------------------------------------------------------ | 12 | | `theme` | -- | | `{ background: string; MyComponent: { root: { margin: string; }; }; }` | `{ background: "black", MyComponent: { root: { margin: "16px" } } }` | 13 | 14 | 15 | ## Dependencies 16 | 17 | ### Depends on 18 | 19 | - context-consumer 20 | 21 | ### Graph 22 | ```mermaid 23 | graph TD; 24 | theme-provider --> context-consumer 25 | style theme-provider fill:#f9f,stroke:#333,stroke-width:4px 26 | ``` 27 | 28 | ---------------------------------------------- 29 | 30 | *Built with [StencilJS](https://stenciljs.com/)* 31 | -------------------------------------------------------------------------------- /test/src/components/css-in-js-test/index.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 9 | Stencil Component Starter 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | Text 18 | 19 | 20 | 21 | 49 | 50 | 51 | -------------------------------------------------------------------------------- /test/src/components.d.ts: -------------------------------------------------------------------------------- 1 | /* tslint:disable */ 2 | /** 3 | * This is an autogenerated file created by the Stencil compiler. 4 | * It contains typing information for all components that exist in this project. 5 | */ 6 | 7 | 8 | import { HTMLStencilElement, JSXBase } from '@stencil/core/internal'; 9 | 10 | 11 | export namespace Components { 12 | interface CssInJsTest {} 13 | interface ThemeProvider { 14 | 'theme': {}; 15 | } 16 | } 17 | 18 | declare global { 19 | 20 | 21 | interface HTMLCssInJsTestElement extends Components.CssInJsTest, HTMLStencilElement {} 22 | var HTMLCssInJsTestElement: { 23 | prototype: HTMLCssInJsTestElement; 24 | new (): HTMLCssInJsTestElement; 25 | }; 26 | 27 | interface HTMLThemeProviderElement extends Components.ThemeProvider, HTMLStencilElement {} 28 | var HTMLThemeProviderElement: { 29 | prototype: HTMLThemeProviderElement; 30 | new (): HTMLThemeProviderElement; 31 | }; 32 | interface HTMLElementTagNameMap { 33 | 'css-in-js-test': HTMLCssInJsTestElement; 34 | 'theme-provider': HTMLThemeProviderElement; 35 | } 36 | } 37 | 38 | declare namespace LocalJSX { 39 | interface CssInJsTest extends JSXBase.HTMLAttributes {} 40 | interface ThemeProvider extends JSXBase.HTMLAttributes { 41 | 'theme'?: {}; 42 | } 43 | 44 | interface IntrinsicElements { 45 | 'css-in-js-test': CssInJsTest; 46 | 'theme-provider': ThemeProvider; 47 | } 48 | } 49 | 50 | export { LocalJSX as JSX }; 51 | 52 | 53 | declare module "@stencil/core" { 54 | export namespace JSX { 55 | interface IntrinsicElements extends LocalJSX.IntrinsicElements {} 56 | } 57 | } 58 | 59 | 60 | -------------------------------------------------------------------------------- /src/getStyle.ts: -------------------------------------------------------------------------------- 1 | import jss, { StyleSheet } from "jss"; 2 | import preset from "jss-preset-default"; 3 | import { Theme, Styles, StyleObject, ExtendedCSSStyleSheet } from "./types"; 4 | 5 | let sheets: Sheets = {}; 6 | let defaultKey = {}; 7 | 8 | jss.setup({ 9 | ...preset() 10 | }); 11 | 12 | function getStyles({ 13 | theme = defaultKey, 14 | styles, 15 | componentName, 16 | useAdoptedStyles 17 | }: GetStyles): StyleObject { 18 | if (!sheets[componentName]) { 19 | sheets[componentName] = new WeakMap(); 20 | } 21 | 22 | if (!sheets[componentName].has(theme)) { 23 | let componentStyles = { ...styles }; 24 | 25 | if (theme[componentName]) { 26 | for (const property in theme[componentName]) { 27 | componentStyles[property] = { 28 | ...componentStyles[property], 29 | ...theme[componentName][property] 30 | }; 31 | } 32 | } 33 | 34 | const sheet = jss.createStyleSheet(componentStyles); 35 | sheet.update(theme); 36 | sheets[componentName].set(theme, getStyleObject(sheet, useAdoptedStyles)); 37 | } 38 | 39 | return sheets[componentName].get(theme); 40 | } 41 | 42 | function getStyleObject( 43 | sheet: StyleSheet, 44 | useAdoptedStyles: boolean 45 | ): StyleObject { 46 | let adoptedSheet: ExtendedCSSStyleSheet = null; 47 | 48 | if (useAdoptedStyles) { 49 | adoptedSheet = new CSSStyleSheet(); 50 | adoptedSheet.replaceSync(sheet.toString()); 51 | 52 | Object.defineProperty(adoptedSheet, "data-cssInJsId", { 53 | value: "cssInJsId" 54 | }); 55 | } 56 | 57 | return { 58 | sheet, 59 | adoptedSheet 60 | }; 61 | } 62 | 63 | export { getStyles }; 64 | 65 | export interface GetStyles { 66 | theme: Theme; 67 | styles: Styles; 68 | componentName: string; 69 | useAdoptedStyles: boolean; 70 | } 71 | 72 | interface Sheets { 73 | [key: string]: any; 74 | } 75 | -------------------------------------------------------------------------------- /test/cypress/plugins/index.js: -------------------------------------------------------------------------------- 1 | // *********************************************************** 2 | // This example plugins/index.js can be used to load plugins 3 | // 4 | // You can change the location of this file or turn off loading 5 | // the plugins file with the 'pluginsFile' configuration option. 6 | // 7 | // You can read more here: 8 | // https://on.cypress.io/plugins-guide 9 | // *********************************************************** 10 | 11 | // This function is called when a project is opened or re-opened (e.g. due to 12 | // the project's config changing) 13 | 14 | const { addMatchImageSnapshotPlugin } = require('cypress-image-snapshot/plugin'); 15 | 16 | module.exports = (on, config) => { 17 | on('before:browser:launch', (browser = {}, args) => { 18 | if (browser.name === 'chrome' || browser.name === 'chromium') { 19 | // In headless mode, Cypress fixes the scale factor to 1, and this forces 20 | // screenshots to be taken with an image size matching the viewport size 21 | // instead of the viewport size multiplied by the scale factor. 22 | // 23 | // Since we also want to run the image regression tests in development mode, 24 | // we need to set the device scale factor to 1 in chrome / chromium. 25 | // 26 | // See: https://github.com/cypress-io/cypress/issues/2102#issuecomment-521299946 27 | // See: https://github.com/cypress-io/cypress/blame/a7dfda986531f9176468de4156e3f1215869c342/packages/server/lib/cypress.coffee#L132-L137 28 | args.push('--force-device-scale-factor=1'); 29 | } else if (browser.name === 'electron' && browser.isHeaded) { 30 | // eslint-disable-next-line no-console 31 | console.log( 32 | "There isn't currently a way of setting the device scale factor in Cypress when running headed electron so we disable the image regression commands." 33 | ); 34 | } 35 | 36 | return args; 37 | }); 38 | 39 | addMatchImageSnapshotPlugin(on, config); 40 | }; 41 | -------------------------------------------------------------------------------- /test/cypress/integration/css-in-js.spec.js: -------------------------------------------------------------------------------- 1 | const defaultTemplate = [ 2 | { 3 | component: "theme-provider", 4 | props: { theme: { background: "rgb(0, 0, 0)" } }, 5 | children: [ 6 | { 7 | component: "css-in-js-test", 8 | innerHTML: "Text Content" 9 | } 10 | ] 11 | } 12 | ]; 13 | 14 | context("CSS In JS", () => { 15 | beforeEach(() => { 16 | cy.visit("/"); 17 | }); 18 | 19 | it("Should render default template", () => { 20 | cy.mount(defaultTemplate); 21 | 22 | cy.shadowGet("css-in-js-test") 23 | .shadowFind("[data-cy=root]") 24 | .then(elements => { 25 | cy.wrap( 26 | getComputedStyle(elements[0]).getPropertyValue("background-color") 27 | ); 28 | }) 29 | .should("equal", "rgb(0, 0, 0)"); 30 | 31 | cy.matchImageSnapshot("Should render default template - 1"); 32 | }); 33 | 34 | it("Should dynamically update theme", () => { 35 | cy.mount(defaultTemplate); 36 | 37 | cy.shadowGet("css-in-js-test") 38 | .shadowFind("[data-cy=root]") 39 | .then(elements => { 40 | cy.wrap( 41 | getComputedStyle(elements[0]).getPropertyValue("background-color") 42 | ); 43 | }) 44 | .should("equal", "rgb(0, 0, 0)"); 45 | 46 | cy.get("theme-provider").updateProps({ 47 | theme: { background: "rgb(0, 125, 0)" } 48 | }); 49 | 50 | cy.shadowGet("css-in-js-test") 51 | .shadowFind("[data-cy=root]") 52 | .wait(300) 53 | .then(elements => { 54 | cy.wrap( 55 | getComputedStyle(elements[0]).getPropertyValue("background-color") 56 | ); 57 | }) 58 | .should("equal", "rgb(0, 125, 0)"); 59 | 60 | cy.matchImageSnapshot("Should dynamically update theme - 1"); 61 | }); 62 | 63 | it("Should render style overrides", () => { 64 | cy.mount(defaultTemplate); 65 | 66 | cy.get("theme-provider").updateProps({ 67 | theme: { 68 | background: "rgb(0, 0, 0)", 69 | CssInJsTest: { 70 | root: { 71 | padding: "48px" 72 | } 73 | } 74 | } 75 | }); 76 | 77 | cy.shadowGet("css-in-js-test") 78 | .shadowFind("[data-cy=root]") 79 | .wait(300) 80 | .then(elements => { 81 | cy.wrap(getComputedStyle(elements[0]).getPropertyValue("padding")); 82 | }) 83 | .should("equal", "48px"); 84 | 85 | cy.matchImageSnapshot("Should render style overrides - 1"); 86 | }); 87 | }); 88 | -------------------------------------------------------------------------------- /test/cypress/support/commands.js: -------------------------------------------------------------------------------- 1 | // *********************************************** 2 | // This example commands.js shows you how to 3 | // create various custom commands and overwrite 4 | // existing commands. 5 | // 6 | // For more comprehensive examples of custom 7 | // commands please read more here: 8 | // https://on.cypress.io/custom-commands 9 | // *********************************************** 10 | // 11 | // 12 | // -- This is a parent command -- 13 | // Cypress.Commands.add("login", (email, password) => { ... }) 14 | // 15 | // 16 | // -- This is a child command -- 17 | // Cypress.Commands.add("drag", { prevSubject: 'element'}, (subject, options) => { ... }) 18 | // 19 | // 20 | // -- This is a dual command -- 21 | // Cypress.Commands.add("dismiss", { prevSubject: 'optional'}, (subject, options) => { ... }) 22 | // 23 | // 24 | // -- This will overwrite an existing command -- 25 | // Cypress.Commands.overwrite("visit", (originalFn, url, options) => { ... }) 26 | 27 | import "cypress-shadow-dom"; 28 | import { addMatchImageSnapshotCommand } from "cypress-image-snapshot/command"; 29 | import { getFragment } from "../utils"; 30 | 31 | if (Cypress.browser.name === "electron" && Cypress.browser.isHeaded) { 32 | Cypress.Commands.add( 33 | "matchImageSnapshot", 34 | { 35 | prevSubject: ["optional", "element", "window", "document"] 36 | }, 37 | (_, name) => { 38 | cy.log( 39 | "In non-headless electron we can't control the device scale factor so have made `CypressSubject#matchImageSnapshot` a noop." 40 | ); 41 | } 42 | ); 43 | } else { 44 | addMatchImageSnapshotCommand(); 45 | } 46 | 47 | Cypress.Commands.add( 48 | "mount", 49 | (template, options = { width: 600, height: 600, padding: 24 }) => { 50 | cy.document().then(doc => { 51 | let fragment = getFragment(doc, template); 52 | 53 | doc.body.style.width = `${options.width}px`; 54 | doc.body.style.height = `${options.height}px`; 55 | doc.body.style.padding = `${options.padding}px`; 56 | 57 | doc.body.appendChild(fragment); 58 | }); 59 | 60 | cy.get(template[template.length - 1].component).should( 61 | "have.class", 62 | "hydrated" 63 | ); 64 | } 65 | ); 66 | 67 | Cypress.Commands.add( 68 | "updateProps", 69 | { 70 | prevSubject: true 71 | }, 72 | (subject, props) => { 73 | Object.keys(props).forEach(key => { 74 | subject[0][key] = props[key]; 75 | }); 76 | 77 | return subject; 78 | } 79 | ); 80 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # CSS-In-JS 2 | 3 | `stencil-css-in-js` is a decorator for using JSS with Stencil components to support stronger theming and style override functionality. 4 | 5 | ## Table of Contents 6 | 7 | - [Installation](#installation) 8 | - [Usage](#usage) 9 | - [Basic](#basic) 10 | - [Dynamic Styles](#dynamic-styles) 11 | - [Component Overrides](#component-overrides) 12 | - [componentWillLoad](#componentwillload) 13 | 14 | ## Installation 15 | 16 | ```bash 17 | npm install --save-dev stencil-css-in-js 18 | ``` 19 | 20 | ## Usage 21 | 22 | ### Basic 23 | 24 | ```ts 25 | import { Component, h } from "@stencil/core"; 26 | import { CssInJs } from "stencil-css-in-js"; 27 | 28 | const styles = { 29 | root: { 30 | padding: "24px", 31 | background: "black" 32 | }, 33 | content: { 34 | color: "white" 35 | } 36 | }; 37 | 38 | @Component({ 39 | tag: "css-in-js-test", 40 | shadow: true 41 | }) 42 | export class CssInJsTest { 43 | // componentWillLoad is required due to StencilJs build optimizations 44 | componentWillLoad() {} 45 | 46 | @CssInJs({ 47 | styles 48 | }) 49 | renderer = (classes: any) => { 50 | return ( 51 |
52 |
53 | 54 |
55 |
56 | ); 57 | }; 58 | } 59 | ``` 60 | 61 | ### Dynamic Styles 62 | 63 | Style rules will use the "theme" class property for dynamic theming. This can be set from either props or by using a state variable. Stencil's State Tunnel library is a good choice for providing a theming api for component libraries, as shown in the example below. 64 | 65 | ```ts 66 | import { Component, h } from "@stencil/core"; 67 | import { CssInJs } from "stencil-css-in-js"; 68 | import Tunnel from "../theme-provider/get-provider"; 69 | 70 | const styles = { 71 | root: { 72 | padding: "24px", 73 | background: (theme: any) => theme.background 74 | }, 75 | content: { 76 | color: "white" 77 | } 78 | }; 79 | 80 | @Component({ 81 | tag: "css-in-js-test", 82 | styleUrl: "css-in-js-test.css", 83 | shadow: true 84 | }) 85 | export class CssInJsTest { 86 | // componentWillLoad is required due to StencilJs build optimizations 87 | componentWillLoad() {} 88 | 89 | @CssInJs({ 90 | styles 91 | }) 92 | renderer = (classes: any) => { 93 | return ( 94 |
95 |
96 | 97 |
98 |
99 | ); 100 | }; 101 | } 102 | 103 | Tunnel.injectProps(CssInJsTest, ["theme"]); 104 | ``` 105 | 106 | ### Component Overrides 107 | 108 | While using predefined variables for theming does work for a lot of use cases, sometimes you'll want to provide the ability to completely override classes instead of just changing theme variables. This can be especially important for component libraries where you want to provide more flexibility to styling. 109 | 110 | ```ts 111 | import { Component, h, State } from "@stencil/core"; 112 | import { CssInJs } from "stencil-css-in-js"; 113 | 114 | const styles = { 115 | root: { 116 | padding: "24px", 117 | background: (theme: any) => theme.background 118 | }, 119 | content: { 120 | color: "white" 121 | } 122 | }; 123 | 124 | @Component({ 125 | tag: "css-in-js-test", 126 | styleUrl: "css-in-js-test.css", 127 | shadow: true 128 | }) 129 | export class CssInJsTest { 130 | @State() theme = { 131 | background: "black", 132 | CssInJsTest: { 133 | root: { 134 | padding: "48px" 135 | } 136 | } 137 | }; 138 | 139 | // componentWillLoad is required due to StencilJs build optimizations 140 | componentWillLoad() {} 141 | 142 | @CssInJs({ 143 | styles 144 | }) 145 | renderer = (classes: any) => { 146 | return ( 147 |
148 |
149 | 150 |
151 |
152 | ); 153 | }; 154 | } 155 | ``` 156 | 157 | While the example shows theme as State for readability purposes, you'll generally want theme to be passed as a prop to the component. 158 | 159 | ## componentWillLoad 160 | 161 | Although less than ideal, currently the lifecycle method `componentWillLoad` is required (even if it is empty) in components due to Stencil build optimizations. 162 | -------------------------------------------------------------------------------- /src/CssInJs.tsx: -------------------------------------------------------------------------------- 1 | import { h, Host, getElement } from "@stencil/core"; 2 | import { VNode, ComponentInterface } from "@stencil/core/dist/declarations"; 3 | import { getStyles } from "./getStyle"; 4 | import { StyleObject, Styles, Theme, ExtendedCSSStyleSheet } from "./types"; 5 | 6 | const useAdoptedStyles = useAdoptedStyleSheets(); 7 | 8 | export function CssInJs(options: CssInJsOptions): CssInJsDecorator { 9 | return (target: ComponentInterface, propertyKey: string) => { 10 | const componentName = target.constructor.name; 11 | 12 | const originalWillLoad = target.componentWillLoad; 13 | if (!originalWillLoad) { 14 | console.error( 15 | `componentWillLoad lifecycle method in ${componentName} missing. Required for CssInJs decorator.` 16 | ); 17 | } 18 | 19 | if (useAdoptedStyles) { 20 | target.componentWillLoad = function() { 21 | const willLoadResult = originalWillLoad?.call(this); 22 | const host = getElement(this); 23 | const root = (host.shadowRoot ?? host) as ExtendedShadowRoot; 24 | const stylesObject = getStyleObject(this, options.styles); 25 | 26 | watchTheme(this, options.styles, (newStyleObject: StyleObject) => { 27 | const adoptedSheet = root.adoptedStyleSheets; 28 | const index = adoptedSheet.findIndex( 29 | sheet => sheet["data-cssInJsId"] 30 | ); 31 | 32 | if (index !== -1) { 33 | root.adoptedStyleSheets = Object.assign([], adoptedSheet, { 34 | [index]: newStyleObject.adoptedSheet 35 | }); 36 | } else { 37 | root.adoptedStyleSheets = [ 38 | ...adoptedSheet, 39 | newStyleObject.adoptedSheet 40 | ]; 41 | } 42 | 43 | host.forceUpdate(); 44 | }); 45 | 46 | root.adoptedStyleSheets = [ 47 | ...root.adoptedStyleSheets, 48 | stylesObject.adoptedSheet 49 | ]; 50 | 51 | return willLoadResult; 52 | }; 53 | 54 | target.render = function() { 55 | return this[propertyKey]( 56 | getStyleObject(this, options.styles).sheet.classes 57 | ); 58 | }; 59 | } else { 60 | target.componentWillLoad = function() { 61 | const willLoadResult = originalWillLoad?.call(this); 62 | 63 | watchTheme(this, options.styles, () => { 64 | getElement(this).forceUpdate(); 65 | }); 66 | 67 | return willLoadResult; 68 | }; 69 | 70 | target.render = function() { 71 | const stylesObject = getStyleObject(this, options.styles); 72 | const cssString = stylesObject.sheet.toString(); 73 | let renderResult: VNode = this[propertyKey](stylesObject.sheet.classes); 74 | 75 | if (isHost(renderResult)) { 76 | prependStyleNode(renderResult, componentName, cssString); 77 | } else { 78 | renderResult = {renderResult}; 79 | prependStyleNode(renderResult, componentName, cssString); 80 | } 81 | 82 | return renderResult; 83 | }; 84 | } 85 | }; 86 | } 87 | 88 | function useAdoptedStyleSheets(): boolean { 89 | return Boolean((document as ExtendedDocument).adoptedStyleSheets); 90 | } 91 | 92 | function prependStyleNode( 93 | node: VNode, 94 | componentName: string, 95 | cssString: string 96 | ) { 97 | (node["$children$"] ?? []).unshift( 98 | 101 | ); 102 | } 103 | 104 | function isHost(node: VNode): boolean { 105 | return Object.values(node).includes(Host); 106 | } 107 | 108 | function getStyleObject(instance: ClassInstance, styles: Styles) { 109 | return getStyles({ 110 | theme: instance.theme, 111 | styles: styles, 112 | componentName: instance.constructor.name, 113 | useAdoptedStyles 114 | }); 115 | } 116 | 117 | function watchTheme( 118 | instance: ClassInstance, 119 | styles: Styles, 120 | callback?: (styleObject: StyleObject) => void 121 | ) { 122 | if (instance.theme) { 123 | let theme = instance.theme; 124 | 125 | Object.defineProperty(instance, "theme", { 126 | get: () => { 127 | return theme; 128 | }, 129 | set: newValue => { 130 | theme = newValue; 131 | 132 | let themeObject = getStyles({ 133 | theme: newValue, 134 | styles, 135 | componentName: instance.constructor.name, 136 | useAdoptedStyles 137 | }); 138 | 139 | callback?.(themeObject); 140 | } 141 | }); 142 | } 143 | } 144 | 145 | type CssInJsDecorator = ( 146 | target: ComponentInterface, 147 | propertyKey: string 148 | ) => void; 149 | 150 | interface ClassInstance extends ComponentInterface { 151 | theme: Theme; 152 | } 153 | 154 | interface CssInJsOptions { 155 | styles: Styles; 156 | } 157 | 158 | interface ExtendedShadowRoot extends ShadowRoot { 159 | adoptedStyleSheets: ExtendedCSSStyleSheet[]; 160 | } 161 | 162 | interface ExtendedDocument extends Document { 163 | adoptedStyleSheets: CSSStyleSheet[]; 164 | } 165 | -------------------------------------------------------------------------------- /test/package-lock.json: -------------------------------------------------------------------------------- 1 | { 2 | "requires": true, 3 | "lockfileVersion": 1, 4 | "dependencies": { 5 | "@cypress/listr-verbose-renderer": { 6 | "version": "0.4.1", 7 | "resolved": "https://registry.npmjs.org/@cypress/listr-verbose-renderer/-/listr-verbose-renderer-0.4.1.tgz", 8 | "integrity": "sha1-p3SS9LEdzHxEajSz4ochr9M8ZCo=", 9 | "dev": true, 10 | "requires": { 11 | "chalk": "^1.1.3", 12 | "cli-cursor": "^1.0.2", 13 | "date-fns": "^1.27.2", 14 | "figures": "^1.7.0" 15 | }, 16 | "dependencies": { 17 | "chalk": { 18 | "version": "1.1.3", 19 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-1.1.3.tgz", 20 | "integrity": "sha1-qBFcVeSnAv5NFQq9OHKCKn4J/Jg=", 21 | "dev": true, 22 | "requires": { 23 | "ansi-styles": "^2.2.1", 24 | "escape-string-regexp": "^1.0.2", 25 | "has-ansi": "^2.0.0", 26 | "strip-ansi": "^3.0.0", 27 | "supports-color": "^2.0.0" 28 | } 29 | }, 30 | "supports-color": { 31 | "version": "2.0.0", 32 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-2.0.0.tgz", 33 | "integrity": "sha1-U10EXOa2Nj+kARcIRimZXp3zJMc=", 34 | "dev": true 35 | } 36 | } 37 | }, 38 | "@cypress/xvfb": { 39 | "version": "1.2.4", 40 | "resolved": "https://registry.npmjs.org/@cypress/xvfb/-/xvfb-1.2.4.tgz", 41 | "integrity": "sha512-skbBzPggOVYCbnGgV+0dmBdW/s77ZkAOXIC1knS8NagwDjBrNC1LuXtQJeiN6l+m7lzmHtaoUw/ctJKdqkG57Q==", 42 | "dev": true, 43 | "requires": { 44 | "debug": "^3.1.0", 45 | "lodash.once": "^4.1.1" 46 | } 47 | }, 48 | "@stencil/core": { 49 | "version": "1.2.0", 50 | "resolved": "https://registry.npmjs.org/@stencil/core/-/core-1.2.0.tgz", 51 | "integrity": "sha512-ah2fZFb9k6NjmJ6Wh9OkEurPPz/fbK7F0cO21eJqTEb2tEPhwKBPbxdHqbCAHTWBl+jIKnEJMRRj5ri06wy5PQ==", 52 | "dev": true, 53 | "requires": { 54 | "typescript": "3.5.3" 55 | } 56 | }, 57 | "@stencil/state-tunnel": { 58 | "version": "1.0.1", 59 | "resolved": "https://registry.npmjs.org/@stencil/state-tunnel/-/state-tunnel-1.0.1.tgz", 60 | "integrity": "sha512-DYG8uROgL9hkjVTCtCfRBb0d3FwpiFB0muRrNZQ2X1Qo5hxMuNNji76/ILddqeq0AfgkKCW82xrMPDpy+rNIhQ==", 61 | "dev": true 62 | }, 63 | "@types/sizzle": { 64 | "version": "2.3.2", 65 | "resolved": "https://registry.npmjs.org/@types/sizzle/-/sizzle-2.3.2.tgz", 66 | "integrity": "sha512-7EJYyKTL7tFR8+gDbB6Wwz/arpGa0Mywk1TJbNzKzHtzbwVmY4HR9WqS5VV7dsBUKQmPNr192jHr/VpBluj/hg==", 67 | "dev": true 68 | }, 69 | "ajv": { 70 | "version": "6.11.0", 71 | "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.11.0.tgz", 72 | "integrity": "sha512-nCprB/0syFYy9fVYU1ox1l2KN8S9I+tziH8D4zdZuLT3N6RMlGSGt5FSTpAiHB/Whv8Qs1cWHma1aMKZyaHRKA==", 73 | "dev": true, 74 | "requires": { 75 | "fast-deep-equal": "^3.1.1", 76 | "fast-json-stable-stringify": "^2.0.0", 77 | "json-schema-traverse": "^0.4.1", 78 | "uri-js": "^4.2.2" 79 | } 80 | }, 81 | "ansi-escapes": { 82 | "version": "1.4.0", 83 | "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-1.4.0.tgz", 84 | "integrity": "sha1-06ioOzGapneTZisT52HHkRQiMG4=", 85 | "dev": true 86 | }, 87 | "ansi-regex": { 88 | "version": "2.1.1", 89 | "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-2.1.1.tgz", 90 | "integrity": "sha1-w7M6te42DYbg5ijwRorn7yfWVN8=", 91 | "dev": true 92 | }, 93 | "ansi-styles": { 94 | "version": "2.2.1", 95 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-2.2.1.tgz", 96 | "integrity": "sha1-tDLdM1i2NM914eRmQ2gkBTPB3b4=", 97 | "dev": true 98 | }, 99 | "app-path": { 100 | "version": "3.2.0", 101 | "resolved": "https://registry.npmjs.org/app-path/-/app-path-3.2.0.tgz", 102 | "integrity": "sha512-PQPaKXi64FZuofJkrtaO3I5RZESm9Yjv7tkeJaDz4EZMeBBfGtr5MyQ3m5AC7F0HVrISBLatPxAAAgvbe418fQ==", 103 | "dev": true, 104 | "requires": { 105 | "execa": "^1.0.0" 106 | }, 107 | "dependencies": { 108 | "execa": { 109 | "version": "1.0.0", 110 | "resolved": "https://registry.npmjs.org/execa/-/execa-1.0.0.tgz", 111 | "integrity": "sha512-adbxcyWV46qiHyvSp50TKt05tB4tK3HcmF7/nxfAdhnox83seTDbwnaqKO4sXRy7roHAIFqJP/Rw/AuEbX61LA==", 112 | "dev": true, 113 | "requires": { 114 | "cross-spawn": "^6.0.0", 115 | "get-stream": "^4.0.0", 116 | "is-stream": "^1.1.0", 117 | "npm-run-path": "^2.0.0", 118 | "p-finally": "^1.0.0", 119 | "signal-exit": "^3.0.0", 120 | "strip-eof": "^1.0.0" 121 | } 122 | }, 123 | "get-stream": { 124 | "version": "4.1.0", 125 | "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-4.1.0.tgz", 126 | "integrity": "sha512-GMat4EJ5161kIy2HevLlr4luNjBgvmj413KaQA7jt4V8B4RDsfpHk7WQ9GVqfYyyx8OS/L66Kox+rJRNklLK7w==", 127 | "dev": true, 128 | "requires": { 129 | "pump": "^3.0.0" 130 | } 131 | } 132 | } 133 | }, 134 | "arch": { 135 | "version": "2.1.1", 136 | "resolved": "https://registry.npmjs.org/arch/-/arch-2.1.1.tgz", 137 | "integrity": "sha512-BLM56aPo9vLLFVa8+/+pJLnrZ7QGGTVHWsCwieAWT9o9K8UeGaQbzZbGoabWLOo2ksBCztoXdqBZBplqLDDCSg==", 138 | "dev": true 139 | }, 140 | "asn1": { 141 | "version": "0.2.4", 142 | "resolved": "https://registry.npmjs.org/asn1/-/asn1-0.2.4.tgz", 143 | "integrity": "sha512-jxwzQpLQjSmWXgwaCZE9Nz+glAG01yF1QnWgbhGwHI5A6FRIEY6IVqtHhIepHqI7/kyEyQEagBC5mBEFlIYvdg==", 144 | "dev": true, 145 | "requires": { 146 | "safer-buffer": "~2.1.0" 147 | } 148 | }, 149 | "assert-plus": { 150 | "version": "1.0.0", 151 | "resolved": "https://registry.npmjs.org/assert-plus/-/assert-plus-1.0.0.tgz", 152 | "integrity": "sha1-8S4PPF13sLHN2RRpQuTpbB5N1SU=", 153 | "dev": true 154 | }, 155 | "async": { 156 | "version": "2.6.1", 157 | "resolved": "https://registry.npmjs.org/async/-/async-2.6.1.tgz", 158 | "integrity": "sha512-fNEiL2+AZt6AlAw/29Cr0UDe4sRAHCpEHh54WMz+Bb7QfNcFw4h3loofyJpLeQs4Yx7yuqu/2dLgM5hKOs6HlQ==", 159 | "dev": true, 160 | "requires": { 161 | "lodash": "^4.17.10" 162 | } 163 | }, 164 | "asynckit": { 165 | "version": "0.4.0", 166 | "resolved": "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz", 167 | "integrity": "sha1-x57Zf380y48robyXkLzDZkdLS3k=", 168 | "dev": true 169 | }, 170 | "aws-sign2": { 171 | "version": "0.7.0", 172 | "resolved": "https://registry.npmjs.org/aws-sign2/-/aws-sign2-0.7.0.tgz", 173 | "integrity": "sha1-tG6JCTSpWR8tL2+G1+ap8bP+dqg=", 174 | "dev": true 175 | }, 176 | "aws4": { 177 | "version": "1.9.1", 178 | "resolved": "https://registry.npmjs.org/aws4/-/aws4-1.9.1.tgz", 179 | "integrity": "sha512-wMHVg2EOHaMRxbzgFJ9gtjOOCrI80OHLG14rxi28XwOW8ux6IiEbRCGGGqCtdAIg4FQCbW20k9RsT4y3gJlFug==", 180 | "dev": true 181 | }, 182 | "balanced-match": { 183 | "version": "1.0.0", 184 | "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz", 185 | "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=", 186 | "dev": true 187 | }, 188 | "base64-js": { 189 | "version": "1.3.1", 190 | "resolved": "https://registry.npmjs.org/base64-js/-/base64-js-1.3.1.tgz", 191 | "integrity": "sha512-mLQ4i2QO1ytvGWFWmcngKO//JXAQueZvwEKtjgQFM4jIK0kU+ytMfplL8j+n5mspOfjHwoAg+9yhb7BwAHm36g==", 192 | "dev": true 193 | }, 194 | "bcrypt-pbkdf": { 195 | "version": "1.0.2", 196 | "resolved": "https://registry.npmjs.org/bcrypt-pbkdf/-/bcrypt-pbkdf-1.0.2.tgz", 197 | "integrity": "sha1-pDAdOJtqQ/m2f/PKEaP2Y342Dp4=", 198 | "dev": true, 199 | "requires": { 200 | "tweetnacl": "^0.14.3" 201 | } 202 | }, 203 | "bluebird": { 204 | "version": "3.5.0", 205 | "resolved": "https://registry.npmjs.org/bluebird/-/bluebird-3.5.0.tgz", 206 | "integrity": "sha1-eRQg1/VR7qKJdFOop3ZT+WYG1nw=", 207 | "dev": true 208 | }, 209 | "brace-expansion": { 210 | "version": "1.1.11", 211 | "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", 212 | "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", 213 | "dev": true, 214 | "requires": { 215 | "balanced-match": "^1.0.0", 216 | "concat-map": "0.0.1" 217 | } 218 | }, 219 | "buffer-crc32": { 220 | "version": "0.2.13", 221 | "resolved": "https://registry.npmjs.org/buffer-crc32/-/buffer-crc32-0.2.13.tgz", 222 | "integrity": "sha1-DTM+PwDqxQqhRUq9MO+MKl2ackI=", 223 | "dev": true 224 | }, 225 | "buffer-from": { 226 | "version": "1.1.1", 227 | "resolved": "https://registry.npmjs.org/buffer-from/-/buffer-from-1.1.1.tgz", 228 | "integrity": "sha512-MQcXEUbCKtEo7bhqEs6560Hyd4XaovZlO/k9V3hjVUF/zwW7KBVdSK4gIt/bzwS9MbR5qob+F5jusZsb0YQK2A==", 229 | "dev": true 230 | }, 231 | "cachedir": { 232 | "version": "1.3.0", 233 | "resolved": "https://registry.npmjs.org/cachedir/-/cachedir-1.3.0.tgz", 234 | "integrity": "sha512-O1ji32oyON9laVPJL1IZ5bmwd2cB46VfpxkDequezH+15FDzzVddEyrGEeX4WusDSqKxdyFdDQDEG1yo1GoWkg==", 235 | "dev": true, 236 | "requires": { 237 | "os-homedir": "^1.0.1" 238 | } 239 | }, 240 | "caseless": { 241 | "version": "0.12.0", 242 | "resolved": "https://registry.npmjs.org/caseless/-/caseless-0.12.0.tgz", 243 | "integrity": "sha1-G2gcIf+EAzyCZUMJBolCDRhxUdw=", 244 | "dev": true 245 | }, 246 | "chalk": { 247 | "version": "2.4.2", 248 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", 249 | "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", 250 | "dev": true, 251 | "requires": { 252 | "ansi-styles": "^3.2.1", 253 | "escape-string-regexp": "^1.0.5", 254 | "supports-color": "^5.3.0" 255 | }, 256 | "dependencies": { 257 | "ansi-styles": { 258 | "version": "3.2.1", 259 | "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", 260 | "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", 261 | "dev": true, 262 | "requires": { 263 | "color-convert": "^1.9.0" 264 | } 265 | } 266 | } 267 | }, 268 | "check-more-types": { 269 | "version": "2.24.0", 270 | "resolved": "https://registry.npmjs.org/check-more-types/-/check-more-types-2.24.0.tgz", 271 | "integrity": "sha1-FCD/sQ/URNz8ebQ4kbv//TKoRgA=", 272 | "dev": true 273 | }, 274 | "ci-info": { 275 | "version": "1.6.0", 276 | "resolved": "https://registry.npmjs.org/ci-info/-/ci-info-1.6.0.tgz", 277 | "integrity": "sha512-vsGdkwSCDpWmP80ncATX7iea5DWQemg1UgCW5J8tqjU3lYw4FBYuj89J0CTVomA7BEfvSZd84GmHko+MxFQU2A==", 278 | "dev": true 279 | }, 280 | "cli-cursor": { 281 | "version": "1.0.2", 282 | "resolved": "https://registry.npmjs.org/cli-cursor/-/cli-cursor-1.0.2.tgz", 283 | "integrity": "sha1-ZNo/fValRBLll5S9Ytw1KV6PKYc=", 284 | "dev": true, 285 | "requires": { 286 | "restore-cursor": "^1.0.1" 287 | } 288 | }, 289 | "cli-spinners": { 290 | "version": "0.1.2", 291 | "resolved": "https://registry.npmjs.org/cli-spinners/-/cli-spinners-0.1.2.tgz", 292 | "integrity": "sha1-u3ZNiOGF+54eaiofGXcjGPYF4xw=", 293 | "dev": true 294 | }, 295 | "cli-truncate": { 296 | "version": "0.2.1", 297 | "resolved": "https://registry.npmjs.org/cli-truncate/-/cli-truncate-0.2.1.tgz", 298 | "integrity": "sha1-nxXPuwcFAFNpIWxiasfQWrkN1XQ=", 299 | "dev": true, 300 | "requires": { 301 | "slice-ansi": "0.0.4", 302 | "string-width": "^1.0.1" 303 | } 304 | }, 305 | "code-point-at": { 306 | "version": "1.1.0", 307 | "resolved": "https://registry.npmjs.org/code-point-at/-/code-point-at-1.1.0.tgz", 308 | "integrity": "sha1-DQcLTQQ6W+ozovGkDi7bPZpMz3c=", 309 | "dev": true 310 | }, 311 | "color-convert": { 312 | "version": "1.9.3", 313 | "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", 314 | "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", 315 | "dev": true, 316 | "requires": { 317 | "color-name": "1.1.3" 318 | } 319 | }, 320 | "color-name": { 321 | "version": "1.1.3", 322 | "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", 323 | "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=", 324 | "dev": true 325 | }, 326 | "combined-stream": { 327 | "version": "1.0.8", 328 | "resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.8.tgz", 329 | "integrity": "sha512-FQN4MRfuJeHf7cBbBMJFXhKSDq+2kAArBlmRBvcvFE5BB1HZKXtSFASDhdlz9zOYwxh8lDdnvmMOe/+5cdoEdg==", 330 | "dev": true, 331 | "requires": { 332 | "delayed-stream": "~1.0.0" 333 | } 334 | }, 335 | "commander": { 336 | "version": "2.15.1", 337 | "resolved": "https://registry.npmjs.org/commander/-/commander-2.15.1.tgz", 338 | "integrity": "sha512-VlfT9F3V0v+jr4yxPc5gg9s62/fIVWsd2Bk2iD435um1NlGMYdVCq+MjcXnhYq2icNOizHr1kK+5TI6H0Hy0ag==", 339 | "dev": true 340 | }, 341 | "common-tags": { 342 | "version": "1.8.0", 343 | "resolved": "https://registry.npmjs.org/common-tags/-/common-tags-1.8.0.tgz", 344 | "integrity": "sha512-6P6g0uetGpW/sdyUy/iQQCbFF0kWVMSIVSyYz7Zgjcgh8mgw8PQzDNZeyZ5DQ2gM7LBoZPHmnjz8rUthkBG5tw==", 345 | "dev": true 346 | }, 347 | "concat-map": { 348 | "version": "0.0.1", 349 | "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", 350 | "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=", 351 | "dev": true 352 | }, 353 | "concat-stream": { 354 | "version": "1.6.2", 355 | "resolved": "https://registry.npmjs.org/concat-stream/-/concat-stream-1.6.2.tgz", 356 | "integrity": "sha512-27HBghJxjiZtIk3Ycvn/4kbJk/1uZuJFfuPEns6LaEvpvG1f0hTea8lilrouyo9mVc2GWdcEZ8OLoGmSADlrCw==", 357 | "dev": true, 358 | "requires": { 359 | "buffer-from": "^1.0.0", 360 | "inherits": "^2.0.3", 361 | "readable-stream": "^2.2.2", 362 | "typedarray": "^0.0.6" 363 | } 364 | }, 365 | "core-util-is": { 366 | "version": "1.0.2", 367 | "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.2.tgz", 368 | "integrity": "sha1-tf1UIgqivFq1eqtxQMlAdUUDwac=", 369 | "dev": true 370 | }, 371 | "cross-spawn": { 372 | "version": "6.0.5", 373 | "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-6.0.5.tgz", 374 | "integrity": "sha512-eTVLrBSt7fjbDygz805pMnstIs2VTBNkRm0qxZd+M7A5XDdxVRWO5MxGBXZhjY4cqLYLdtrGqRf8mBPmzwSpWQ==", 375 | "dev": true, 376 | "requires": { 377 | "nice-try": "^1.0.4", 378 | "path-key": "^2.0.1", 379 | "semver": "^5.5.0", 380 | "shebang-command": "^1.2.0", 381 | "which": "^1.2.9" 382 | } 383 | }, 384 | "cypress": { 385 | "version": "3.8.2", 386 | "resolved": "https://registry.npmjs.org/cypress/-/cypress-3.8.2.tgz", 387 | "integrity": "sha512-aTs0u3+dfEuLe0Ct0FVO5jD1ULqxbuqWUZwzBm0rxdLgLxIAOI/A9f/WkgY5Cfy1TEXe8pKC6Wal0ZpnkdGRSw==", 388 | "dev": true, 389 | "requires": { 390 | "@cypress/listr-verbose-renderer": "0.4.1", 391 | "@cypress/xvfb": "1.2.4", 392 | "@types/sizzle": "2.3.2", 393 | "arch": "2.1.1", 394 | "bluebird": "3.5.0", 395 | "cachedir": "1.3.0", 396 | "chalk": "2.4.2", 397 | "check-more-types": "2.24.0", 398 | "commander": "2.15.1", 399 | "common-tags": "1.8.0", 400 | "debug": "3.2.6", 401 | "eventemitter2": "4.1.2", 402 | "execa": "0.10.0", 403 | "executable": "4.1.1", 404 | "extract-zip": "1.6.7", 405 | "fs-extra": "5.0.0", 406 | "getos": "3.1.1", 407 | "is-ci": "1.2.1", 408 | "is-installed-globally": "0.1.0", 409 | "lazy-ass": "1.6.0", 410 | "listr": "0.12.0", 411 | "lodash": "4.17.15", 412 | "log-symbols": "2.2.0", 413 | "minimist": "1.2.0", 414 | "moment": "2.24.0", 415 | "ramda": "0.24.1", 416 | "request": "2.88.0", 417 | "request-progress": "3.0.0", 418 | "supports-color": "5.5.0", 419 | "tmp": "0.1.0", 420 | "untildify": "3.0.3", 421 | "url": "0.11.0", 422 | "yauzl": "2.10.0" 423 | } 424 | }, 425 | "cypress-image-snapshot": { 426 | "version": "3.1.1", 427 | "resolved": "https://registry.npmjs.org/cypress-image-snapshot/-/cypress-image-snapshot-3.1.1.tgz", 428 | "integrity": "sha512-r+rjnljehx45qhhV9M/lBsg34Ibys9JWSbPFo9ktV6ovnpxiZSh9GYM/SXEvtJoEonRF51M/Gn2G6J3UlaV6Dg==", 429 | "dev": true, 430 | "requires": { 431 | "chalk": "^2.4.1", 432 | "fs-extra": "^7.0.1", 433 | "glob": "^7.1.3", 434 | "jest-image-snapshot": "2.8.2", 435 | "pkg-dir": "^3.0.0", 436 | "term-img": "^4.0.0" 437 | }, 438 | "dependencies": { 439 | "fs-extra": { 440 | "version": "7.0.1", 441 | "resolved": "https://registry.npmjs.org/fs-extra/-/fs-extra-7.0.1.tgz", 442 | "integrity": "sha512-YJDaCJZEnBmcbw13fvdAM9AwNOJwOzrE4pqMqBq5nFiEqXUqHwlK4B+3pUw6JNvfSPtX05xFHtYy/1ni01eGCw==", 443 | "dev": true, 444 | "requires": { 445 | "graceful-fs": "^4.1.2", 446 | "jsonfile": "^4.0.0", 447 | "universalify": "^0.1.0" 448 | } 449 | } 450 | } 451 | }, 452 | "cypress-shadow-dom": { 453 | "version": "1.3.0", 454 | "resolved": "https://registry.npmjs.org/cypress-shadow-dom/-/cypress-shadow-dom-1.3.0.tgz", 455 | "integrity": "sha512-cxbCq4BJCg445dOsYIbIdLF2f8Huy4boAucUftbfeg8Q5yFTngg/iZZrO+HtYGc1fu/j5YoXIcWEdWgrpb8U/w==", 456 | "dev": true 457 | }, 458 | "dashdash": { 459 | "version": "1.14.1", 460 | "resolved": "https://registry.npmjs.org/dashdash/-/dashdash-1.14.1.tgz", 461 | "integrity": "sha1-hTz6D3y+L+1d4gMmuN1YEDX24vA=", 462 | "dev": true, 463 | "requires": { 464 | "assert-plus": "^1.0.0" 465 | } 466 | }, 467 | "date-fns": { 468 | "version": "1.30.1", 469 | "resolved": "https://registry.npmjs.org/date-fns/-/date-fns-1.30.1.tgz", 470 | "integrity": "sha512-hBSVCvSmWC+QypYObzwGOd9wqdDpOt+0wl0KbU+R+uuZBS1jN8VsD1ss3irQDknRj5NvxiTF6oj/nDRnN/UQNw==", 471 | "dev": true 472 | }, 473 | "debug": { 474 | "version": "3.2.6", 475 | "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.6.tgz", 476 | "integrity": "sha512-mel+jf7nrtEl5Pn1Qx46zARXKDpBbvzezse7p7LqINmdoIk8PYP5SySaxEmYv6TZ0JyEKA1hsCId6DIhgITtWQ==", 477 | "dev": true, 478 | "requires": { 479 | "ms": "^2.1.1" 480 | } 481 | }, 482 | "delayed-stream": { 483 | "version": "1.0.0", 484 | "resolved": "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz", 485 | "integrity": "sha1-3zrhmayt+31ECqrgsp4icrJOxhk=", 486 | "dev": true 487 | }, 488 | "ecc-jsbn": { 489 | "version": "0.1.2", 490 | "resolved": "https://registry.npmjs.org/ecc-jsbn/-/ecc-jsbn-0.1.2.tgz", 491 | "integrity": "sha1-OoOpBOVDUyh4dMVkt1SThoSamMk=", 492 | "dev": true, 493 | "requires": { 494 | "jsbn": "~0.1.0", 495 | "safer-buffer": "^2.1.0" 496 | } 497 | }, 498 | "elegant-spinner": { 499 | "version": "1.0.1", 500 | "resolved": "https://registry.npmjs.org/elegant-spinner/-/elegant-spinner-1.0.1.tgz", 501 | "integrity": "sha1-2wQ1IcldfjA/2PNFvtwzSc+wcp4=", 502 | "dev": true 503 | }, 504 | "end-of-stream": { 505 | "version": "1.4.4", 506 | "resolved": "https://registry.npmjs.org/end-of-stream/-/end-of-stream-1.4.4.tgz", 507 | "integrity": "sha512-+uw1inIHVPQoaVuHzRyXd21icM+cnt4CzD5rW+NC1wjOUSTOs+Te7FOv7AhN7vS9x/oIyhLP5PR1H+phQAHu5Q==", 508 | "dev": true, 509 | "requires": { 510 | "once": "^1.4.0" 511 | } 512 | }, 513 | "escape-string-regexp": { 514 | "version": "1.0.5", 515 | "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", 516 | "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=", 517 | "dev": true 518 | }, 519 | "eventemitter2": { 520 | "version": "4.1.2", 521 | "resolved": "https://registry.npmjs.org/eventemitter2/-/eventemitter2-4.1.2.tgz", 522 | "integrity": "sha1-DhqEd6+CGm7zmVsxG/dMI6UkfxU=", 523 | "dev": true 524 | }, 525 | "execa": { 526 | "version": "0.10.0", 527 | "resolved": "https://registry.npmjs.org/execa/-/execa-0.10.0.tgz", 528 | "integrity": "sha512-7XOMnz8Ynx1gGo/3hyV9loYNPWM94jG3+3T3Y8tsfSstFmETmENCMU/A/zj8Lyaj1lkgEepKepvd6240tBRvlw==", 529 | "dev": true, 530 | "requires": { 531 | "cross-spawn": "^6.0.0", 532 | "get-stream": "^3.0.0", 533 | "is-stream": "^1.1.0", 534 | "npm-run-path": "^2.0.0", 535 | "p-finally": "^1.0.0", 536 | "signal-exit": "^3.0.0", 537 | "strip-eof": "^1.0.0" 538 | } 539 | }, 540 | "executable": { 541 | "version": "4.1.1", 542 | "resolved": "https://registry.npmjs.org/executable/-/executable-4.1.1.tgz", 543 | "integrity": "sha512-8iA79xD3uAch729dUG8xaaBBFGaEa0wdD2VkYLFHwlqosEj/jT66AzcreRDSgV7ehnNLBW2WR5jIXwGKjVdTLg==", 544 | "dev": true, 545 | "requires": { 546 | "pify": "^2.2.0" 547 | } 548 | }, 549 | "exit-hook": { 550 | "version": "1.1.1", 551 | "resolved": "https://registry.npmjs.org/exit-hook/-/exit-hook-1.1.1.tgz", 552 | "integrity": "sha1-8FyiM7SMBdVP/wd2XfhQfpXAL/g=", 553 | "dev": true 554 | }, 555 | "extend": { 556 | "version": "3.0.2", 557 | "resolved": "https://registry.npmjs.org/extend/-/extend-3.0.2.tgz", 558 | "integrity": "sha512-fjquC59cD7CyW6urNXK0FBufkZcoiGG80wTuPujX590cB5Ttln20E2UB4S/WARVqhXffZl2LNgS+gQdPIIim/g==", 559 | "dev": true 560 | }, 561 | "extract-zip": { 562 | "version": "1.6.7", 563 | "resolved": "https://registry.npmjs.org/extract-zip/-/extract-zip-1.6.7.tgz", 564 | "integrity": "sha1-qEC0uK9kAyZMjbV/Txp0Mz74H+k=", 565 | "dev": true, 566 | "requires": { 567 | "concat-stream": "1.6.2", 568 | "debug": "2.6.9", 569 | "mkdirp": "0.5.1", 570 | "yauzl": "2.4.1" 571 | }, 572 | "dependencies": { 573 | "debug": { 574 | "version": "2.6.9", 575 | "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", 576 | "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", 577 | "dev": true, 578 | "requires": { 579 | "ms": "2.0.0" 580 | } 581 | }, 582 | "ms": { 583 | "version": "2.0.0", 584 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", 585 | "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=", 586 | "dev": true 587 | }, 588 | "yauzl": { 589 | "version": "2.4.1", 590 | "resolved": "https://registry.npmjs.org/yauzl/-/yauzl-2.4.1.tgz", 591 | "integrity": "sha1-lSj0QtqxsihOWLQ3m7GU4i4MQAU=", 592 | "dev": true, 593 | "requires": { 594 | "fd-slicer": "~1.0.1" 595 | } 596 | } 597 | } 598 | }, 599 | "extsprintf": { 600 | "version": "1.3.0", 601 | "resolved": "https://registry.npmjs.org/extsprintf/-/extsprintf-1.3.0.tgz", 602 | "integrity": "sha1-lpGEQOMEGnpBT4xS48V06zw+HgU=", 603 | "dev": true 604 | }, 605 | "fast-deep-equal": { 606 | "version": "3.1.1", 607 | "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.1.tgz", 608 | "integrity": "sha512-8UEa58QDLauDNfpbrX55Q9jrGHThw2ZMdOky5Gl1CDtVeJDPVrG4Jxx1N8jw2gkWaff5UUuX1KJd+9zGe2B+ZA==", 609 | "dev": true 610 | }, 611 | "fast-json-stable-stringify": { 612 | "version": "2.1.0", 613 | "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz", 614 | "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==", 615 | "dev": true 616 | }, 617 | "fd-slicer": { 618 | "version": "1.0.1", 619 | "resolved": "https://registry.npmjs.org/fd-slicer/-/fd-slicer-1.0.1.tgz", 620 | "integrity": "sha1-i1vL2ewyfFBBv5qwI/1nUPEXfmU=", 621 | "dev": true, 622 | "requires": { 623 | "pend": "~1.2.0" 624 | } 625 | }, 626 | "figures": { 627 | "version": "1.7.0", 628 | "resolved": "https://registry.npmjs.org/figures/-/figures-1.7.0.tgz", 629 | "integrity": "sha1-y+Hjr/zxzUS4DK3+0o3Hk6lwHS4=", 630 | "dev": true, 631 | "requires": { 632 | "escape-string-regexp": "^1.0.5", 633 | "object-assign": "^4.1.0" 634 | } 635 | }, 636 | "find-up": { 637 | "version": "3.0.0", 638 | "resolved": "https://registry.npmjs.org/find-up/-/find-up-3.0.0.tgz", 639 | "integrity": "sha512-1yD6RmLI1XBfxugvORwlck6f75tYL+iR0jqwsOrOxMZyGYqUuDhJ0l4AXdO1iX/FTs9cBAMEk1gWSEx1kSbylg==", 640 | "dev": true, 641 | "requires": { 642 | "locate-path": "^3.0.0" 643 | } 644 | }, 645 | "forever-agent": { 646 | "version": "0.6.1", 647 | "resolved": "https://registry.npmjs.org/forever-agent/-/forever-agent-0.6.1.tgz", 648 | "integrity": "sha1-+8cfDEGt6zf5bFd60e1C2P2sypE=", 649 | "dev": true 650 | }, 651 | "form-data": { 652 | "version": "2.3.3", 653 | "resolved": "https://registry.npmjs.org/form-data/-/form-data-2.3.3.tgz", 654 | "integrity": "sha512-1lLKB2Mu3aGP1Q/2eCOx0fNbRMe7XdwktwOruhfqqd0rIJWwN4Dh+E3hrPSlDCXnSR7UtZ1N38rVXm+6+MEhJQ==", 655 | "dev": true, 656 | "requires": { 657 | "asynckit": "^0.4.0", 658 | "combined-stream": "^1.0.6", 659 | "mime-types": "^2.1.12" 660 | } 661 | }, 662 | "fs-extra": { 663 | "version": "5.0.0", 664 | "resolved": "https://registry.npmjs.org/fs-extra/-/fs-extra-5.0.0.tgz", 665 | "integrity": "sha512-66Pm4RYbjzdyeuqudYqhFiNBbCIuI9kgRqLPSHIlXHidW8NIQtVdkM1yeZ4lXwuhbTETv3EUGMNHAAw6hiundQ==", 666 | "dev": true, 667 | "requires": { 668 | "graceful-fs": "^4.1.2", 669 | "jsonfile": "^4.0.0", 670 | "universalify": "^0.1.0" 671 | } 672 | }, 673 | "fs.realpath": { 674 | "version": "1.0.0", 675 | "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", 676 | "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=", 677 | "dev": true 678 | }, 679 | "get-stdin": { 680 | "version": "5.0.1", 681 | "resolved": "https://registry.npmjs.org/get-stdin/-/get-stdin-5.0.1.tgz", 682 | "integrity": "sha1-Ei4WFZHiH/TFJTAwVpPyDmOTo5g=", 683 | "dev": true 684 | }, 685 | "get-stream": { 686 | "version": "3.0.0", 687 | "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-3.0.0.tgz", 688 | "integrity": "sha1-jpQ9E1jcN1VQVOy+LtsFqhdO3hQ=", 689 | "dev": true 690 | }, 691 | "getos": { 692 | "version": "3.1.1", 693 | "resolved": "https://registry.npmjs.org/getos/-/getos-3.1.1.tgz", 694 | "integrity": "sha512-oUP1rnEhAr97rkitiszGP9EgDVYnmchgFzfqRzSkgtfv7ai6tEi7Ko8GgjNXts7VLWEqrTWyhsOKLe5C5b/Zkg==", 695 | "dev": true, 696 | "requires": { 697 | "async": "2.6.1" 698 | } 699 | }, 700 | "getpass": { 701 | "version": "0.1.7", 702 | "resolved": "https://registry.npmjs.org/getpass/-/getpass-0.1.7.tgz", 703 | "integrity": "sha1-Xv+OPmhNVprkyysSgmBOi6YhSfo=", 704 | "dev": true, 705 | "requires": { 706 | "assert-plus": "^1.0.0" 707 | } 708 | }, 709 | "glob": { 710 | "version": "7.1.6", 711 | "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.6.tgz", 712 | "integrity": "sha512-LwaxwyZ72Lk7vZINtNNrywX0ZuLyStrdDtabefZKAY5ZGJhVtgdznluResxNmPitE0SAO+O26sWTHeKSI2wMBA==", 713 | "dev": true, 714 | "requires": { 715 | "fs.realpath": "^1.0.0", 716 | "inflight": "^1.0.4", 717 | "inherits": "2", 718 | "minimatch": "^3.0.4", 719 | "once": "^1.3.0", 720 | "path-is-absolute": "^1.0.0" 721 | } 722 | }, 723 | "global-dirs": { 724 | "version": "0.1.1", 725 | "resolved": "https://registry.npmjs.org/global-dirs/-/global-dirs-0.1.1.tgz", 726 | "integrity": "sha1-sxnA3UYH81PzvpzKTHL8FIxJ9EU=", 727 | "dev": true, 728 | "requires": { 729 | "ini": "^1.3.4" 730 | } 731 | }, 732 | "graceful-fs": { 733 | "version": "4.2.3", 734 | "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.3.tgz", 735 | "integrity": "sha512-a30VEBm4PEdx1dRB7MFK7BejejvCvBronbLjht+sHuGYj8PHs7M/5Z+rt5lw551vZ7yfTCj4Vuyy3mSJytDWRQ==", 736 | "dev": true 737 | }, 738 | "har-schema": { 739 | "version": "2.0.0", 740 | "resolved": "https://registry.npmjs.org/har-schema/-/har-schema-2.0.0.tgz", 741 | "integrity": "sha1-qUwiJOvKwEeCoNkDVSHyRzW37JI=", 742 | "dev": true 743 | }, 744 | "har-validator": { 745 | "version": "5.1.3", 746 | "resolved": "https://registry.npmjs.org/har-validator/-/har-validator-5.1.3.tgz", 747 | "integrity": "sha512-sNvOCzEQNr/qrvJgc3UG/kD4QtlHycrzwS+6mfTrrSq97BvaYcPZZI1ZSqGSPR73Cxn4LKTD4PttRwfU7jWq5g==", 748 | "dev": true, 749 | "requires": { 750 | "ajv": "^6.5.5", 751 | "har-schema": "^2.0.0" 752 | } 753 | }, 754 | "has-ansi": { 755 | "version": "2.0.0", 756 | "resolved": "https://registry.npmjs.org/has-ansi/-/has-ansi-2.0.0.tgz", 757 | "integrity": "sha1-NPUEnOHs3ysGSa8+8k5F7TVBbZE=", 758 | "dev": true, 759 | "requires": { 760 | "ansi-regex": "^2.0.0" 761 | } 762 | }, 763 | "has-flag": { 764 | "version": "3.0.0", 765 | "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", 766 | "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=", 767 | "dev": true 768 | }, 769 | "http-signature": { 770 | "version": "1.2.0", 771 | "resolved": "https://registry.npmjs.org/http-signature/-/http-signature-1.2.0.tgz", 772 | "integrity": "sha1-muzZJRFHcvPZW2WmCruPfBj7rOE=", 773 | "dev": true, 774 | "requires": { 775 | "assert-plus": "^1.0.0", 776 | "jsprim": "^1.2.2", 777 | "sshpk": "^1.7.0" 778 | } 779 | }, 780 | "indent-string": { 781 | "version": "2.1.0", 782 | "resolved": "https://registry.npmjs.org/indent-string/-/indent-string-2.1.0.tgz", 783 | "integrity": "sha1-ji1INIdCEhtKghi3oTfppSBJ3IA=", 784 | "dev": true, 785 | "requires": { 786 | "repeating": "^2.0.0" 787 | } 788 | }, 789 | "inflight": { 790 | "version": "1.0.6", 791 | "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", 792 | "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", 793 | "dev": true, 794 | "requires": { 795 | "once": "^1.3.0", 796 | "wrappy": "1" 797 | } 798 | }, 799 | "inherits": { 800 | "version": "2.0.4", 801 | "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", 802 | "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", 803 | "dev": true 804 | }, 805 | "ini": { 806 | "version": "1.3.5", 807 | "resolved": "https://registry.npmjs.org/ini/-/ini-1.3.5.tgz", 808 | "integrity": "sha512-RZY5huIKCMRWDUqZlEi72f/lmXKMvuszcMBduliQ3nnWbx9X/ZBQO7DijMEYS9EhHBb2qacRUMtC7svLwe0lcw==", 809 | "dev": true 810 | }, 811 | "is-ci": { 812 | "version": "1.2.1", 813 | "resolved": "https://registry.npmjs.org/is-ci/-/is-ci-1.2.1.tgz", 814 | "integrity": "sha512-s6tfsaQaQi3JNciBH6shVqEDvhGut0SUXr31ag8Pd8BBbVVlcGfWhpPmEOoM6RJ5TFhbypvf5yyRw/VXW1IiWg==", 815 | "dev": true, 816 | "requires": { 817 | "ci-info": "^1.5.0" 818 | } 819 | }, 820 | "is-finite": { 821 | "version": "1.0.2", 822 | "resolved": "https://registry.npmjs.org/is-finite/-/is-finite-1.0.2.tgz", 823 | "integrity": "sha1-zGZ3aVYCvlUO8R6LSqYwU0K20Ko=", 824 | "dev": true, 825 | "requires": { 826 | "number-is-nan": "^1.0.0" 827 | } 828 | }, 829 | "is-fullwidth-code-point": { 830 | "version": "1.0.0", 831 | "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-1.0.0.tgz", 832 | "integrity": "sha1-754xOG8DGn8NZDr4L95QxFfvAMs=", 833 | "dev": true, 834 | "requires": { 835 | "number-is-nan": "^1.0.0" 836 | } 837 | }, 838 | "is-installed-globally": { 839 | "version": "0.1.0", 840 | "resolved": "https://registry.npmjs.org/is-installed-globally/-/is-installed-globally-0.1.0.tgz", 841 | "integrity": "sha1-Df2Y9akRFxbdU13aZJL2e/PSWoA=", 842 | "dev": true, 843 | "requires": { 844 | "global-dirs": "^0.1.0", 845 | "is-path-inside": "^1.0.0" 846 | } 847 | }, 848 | "is-path-inside": { 849 | "version": "1.0.1", 850 | "resolved": "https://registry.npmjs.org/is-path-inside/-/is-path-inside-1.0.1.tgz", 851 | "integrity": "sha1-jvW33lBDej/cprToZe96pVy0gDY=", 852 | "dev": true, 853 | "requires": { 854 | "path-is-inside": "^1.0.1" 855 | } 856 | }, 857 | "is-promise": { 858 | "version": "2.1.0", 859 | "resolved": "https://registry.npmjs.org/is-promise/-/is-promise-2.1.0.tgz", 860 | "integrity": "sha1-eaKp7OfwlugPNtKy87wWwf9L8/o=", 861 | "dev": true 862 | }, 863 | "is-stream": { 864 | "version": "1.1.0", 865 | "resolved": "https://registry.npmjs.org/is-stream/-/is-stream-1.1.0.tgz", 866 | "integrity": "sha1-EtSj3U5o4Lec6428hBc66A2RykQ=", 867 | "dev": true 868 | }, 869 | "is-typedarray": { 870 | "version": "1.0.0", 871 | "resolved": "https://registry.npmjs.org/is-typedarray/-/is-typedarray-1.0.0.tgz", 872 | "integrity": "sha1-5HnICFjfDBsR3dppQPlgEfzaSpo=", 873 | "dev": true 874 | }, 875 | "isarray": { 876 | "version": "1.0.0", 877 | "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", 878 | "integrity": "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE=", 879 | "dev": true 880 | }, 881 | "isexe": { 882 | "version": "2.0.0", 883 | "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", 884 | "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=", 885 | "dev": true 886 | }, 887 | "isstream": { 888 | "version": "0.1.2", 889 | "resolved": "https://registry.npmjs.org/isstream/-/isstream-0.1.2.tgz", 890 | "integrity": "sha1-R+Y/evVa+m+S4VAOaQ64uFKcCZo=", 891 | "dev": true 892 | }, 893 | "iterm2-version": { 894 | "version": "4.2.0", 895 | "resolved": "https://registry.npmjs.org/iterm2-version/-/iterm2-version-4.2.0.tgz", 896 | "integrity": "sha512-IoiNVk4SMPu6uTcK+1nA5QaHNok2BMDLjSl5UomrOixe5g4GkylhPwuiGdw00ysSCrXAKNMfFTu+u/Lk5f6OLQ==", 897 | "dev": true, 898 | "requires": { 899 | "app-path": "^3.2.0", 900 | "plist": "^3.0.1" 901 | } 902 | }, 903 | "jest-image-snapshot": { 904 | "version": "2.8.2", 905 | "resolved": "https://registry.npmjs.org/jest-image-snapshot/-/jest-image-snapshot-2.8.2.tgz", 906 | "integrity": "sha512-gtKgxfW5ifAikNI+fp0c0o/3byOeOUSmYeAELblGzINEZrDGUYxwUZtn5rNrgVuzjgGMBBsKYv/2gIM6VpzLaw==", 907 | "dev": true, 908 | "requires": { 909 | "chalk": "^1.1.3", 910 | "get-stdin": "^5.0.1", 911 | "lodash": "^4.17.4", 912 | "mkdirp": "^0.5.1", 913 | "pixelmatch": "^4.0.2", 914 | "pngjs": "^3.3.3", 915 | "rimraf": "^2.6.2" 916 | }, 917 | "dependencies": { 918 | "chalk": { 919 | "version": "1.1.3", 920 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-1.1.3.tgz", 921 | "integrity": "sha1-qBFcVeSnAv5NFQq9OHKCKn4J/Jg=", 922 | "dev": true, 923 | "requires": { 924 | "ansi-styles": "^2.2.1", 925 | "escape-string-regexp": "^1.0.2", 926 | "has-ansi": "^2.0.0", 927 | "strip-ansi": "^3.0.0", 928 | "supports-color": "^2.0.0" 929 | } 930 | }, 931 | "supports-color": { 932 | "version": "2.0.0", 933 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-2.0.0.tgz", 934 | "integrity": "sha1-U10EXOa2Nj+kARcIRimZXp3zJMc=", 935 | "dev": true 936 | } 937 | } 938 | }, 939 | "jsbn": { 940 | "version": "0.1.1", 941 | "resolved": "https://registry.npmjs.org/jsbn/-/jsbn-0.1.1.tgz", 942 | "integrity": "sha1-peZUwuWi3rXyAdls77yoDA7y9RM=", 943 | "dev": true 944 | }, 945 | "json-schema": { 946 | "version": "0.2.3", 947 | "resolved": "https://registry.npmjs.org/json-schema/-/json-schema-0.2.3.tgz", 948 | "integrity": "sha1-tIDIkuWaLwWVTOcnvT8qTogvnhM=", 949 | "dev": true 950 | }, 951 | "json-schema-traverse": { 952 | "version": "0.4.1", 953 | "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", 954 | "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", 955 | "dev": true 956 | }, 957 | "json-stringify-safe": { 958 | "version": "5.0.1", 959 | "resolved": "https://registry.npmjs.org/json-stringify-safe/-/json-stringify-safe-5.0.1.tgz", 960 | "integrity": "sha1-Epai1Y/UXxmg9s4B1lcB4sc1tus=", 961 | "dev": true 962 | }, 963 | "jsonfile": { 964 | "version": "4.0.0", 965 | "resolved": "https://registry.npmjs.org/jsonfile/-/jsonfile-4.0.0.tgz", 966 | "integrity": "sha1-h3Gq4HmbZAdrdmQPygWPnBDjPss=", 967 | "dev": true, 968 | "requires": { 969 | "graceful-fs": "^4.1.6" 970 | } 971 | }, 972 | "jsprim": { 973 | "version": "1.4.1", 974 | "resolved": "https://registry.npmjs.org/jsprim/-/jsprim-1.4.1.tgz", 975 | "integrity": "sha1-MT5mvB5cwG5Di8G3SZwuXFastqI=", 976 | "dev": true, 977 | "requires": { 978 | "assert-plus": "1.0.0", 979 | "extsprintf": "1.3.0", 980 | "json-schema": "0.2.3", 981 | "verror": "1.10.0" 982 | } 983 | }, 984 | "lazy-ass": { 985 | "version": "1.6.0", 986 | "resolved": "https://registry.npmjs.org/lazy-ass/-/lazy-ass-1.6.0.tgz", 987 | "integrity": "sha1-eZllXoZGwX8In90YfRUNMyTVRRM=", 988 | "dev": true 989 | }, 990 | "listr": { 991 | "version": "0.12.0", 992 | "resolved": "https://registry.npmjs.org/listr/-/listr-0.12.0.tgz", 993 | "integrity": "sha1-a84sD1YD+klYDqF81qAMwOX6RRo=", 994 | "dev": true, 995 | "requires": { 996 | "chalk": "^1.1.3", 997 | "cli-truncate": "^0.2.1", 998 | "figures": "^1.7.0", 999 | "indent-string": "^2.1.0", 1000 | "is-promise": "^2.1.0", 1001 | "is-stream": "^1.1.0", 1002 | "listr-silent-renderer": "^1.1.1", 1003 | "listr-update-renderer": "^0.2.0", 1004 | "listr-verbose-renderer": "^0.4.0", 1005 | "log-symbols": "^1.0.2", 1006 | "log-update": "^1.0.2", 1007 | "ora": "^0.2.3", 1008 | "p-map": "^1.1.1", 1009 | "rxjs": "^5.0.0-beta.11", 1010 | "stream-to-observable": "^0.1.0", 1011 | "strip-ansi": "^3.0.1" 1012 | }, 1013 | "dependencies": { 1014 | "chalk": { 1015 | "version": "1.1.3", 1016 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-1.1.3.tgz", 1017 | "integrity": "sha1-qBFcVeSnAv5NFQq9OHKCKn4J/Jg=", 1018 | "dev": true, 1019 | "requires": { 1020 | "ansi-styles": "^2.2.1", 1021 | "escape-string-regexp": "^1.0.2", 1022 | "has-ansi": "^2.0.0", 1023 | "strip-ansi": "^3.0.0", 1024 | "supports-color": "^2.0.0" 1025 | } 1026 | }, 1027 | "log-symbols": { 1028 | "version": "1.0.2", 1029 | "resolved": "https://registry.npmjs.org/log-symbols/-/log-symbols-1.0.2.tgz", 1030 | "integrity": "sha1-N2/3tY6jCGoPCfrMdGF+ylAeGhg=", 1031 | "dev": true, 1032 | "requires": { 1033 | "chalk": "^1.0.0" 1034 | } 1035 | }, 1036 | "supports-color": { 1037 | "version": "2.0.0", 1038 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-2.0.0.tgz", 1039 | "integrity": "sha1-U10EXOa2Nj+kARcIRimZXp3zJMc=", 1040 | "dev": true 1041 | } 1042 | } 1043 | }, 1044 | "listr-silent-renderer": { 1045 | "version": "1.1.1", 1046 | "resolved": "https://registry.npmjs.org/listr-silent-renderer/-/listr-silent-renderer-1.1.1.tgz", 1047 | "integrity": "sha1-kktaN1cVN3C/Go4/v3S4u/P5JC4=", 1048 | "dev": true 1049 | }, 1050 | "listr-update-renderer": { 1051 | "version": "0.2.0", 1052 | "resolved": "https://registry.npmjs.org/listr-update-renderer/-/listr-update-renderer-0.2.0.tgz", 1053 | "integrity": "sha1-yoDhd5tOcCZoB+ju0a1qvjmFUPk=", 1054 | "dev": true, 1055 | "requires": { 1056 | "chalk": "^1.1.3", 1057 | "cli-truncate": "^0.2.1", 1058 | "elegant-spinner": "^1.0.1", 1059 | "figures": "^1.7.0", 1060 | "indent-string": "^3.0.0", 1061 | "log-symbols": "^1.0.2", 1062 | "log-update": "^1.0.2", 1063 | "strip-ansi": "^3.0.1" 1064 | }, 1065 | "dependencies": { 1066 | "chalk": { 1067 | "version": "1.1.3", 1068 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-1.1.3.tgz", 1069 | "integrity": "sha1-qBFcVeSnAv5NFQq9OHKCKn4J/Jg=", 1070 | "dev": true, 1071 | "requires": { 1072 | "ansi-styles": "^2.2.1", 1073 | "escape-string-regexp": "^1.0.2", 1074 | "has-ansi": "^2.0.0", 1075 | "strip-ansi": "^3.0.0", 1076 | "supports-color": "^2.0.0" 1077 | } 1078 | }, 1079 | "indent-string": { 1080 | "version": "3.2.0", 1081 | "resolved": "https://registry.npmjs.org/indent-string/-/indent-string-3.2.0.tgz", 1082 | "integrity": "sha1-Sl/W0nzDMvN+VBmlBNu4NxBckok=", 1083 | "dev": true 1084 | }, 1085 | "log-symbols": { 1086 | "version": "1.0.2", 1087 | "resolved": "https://registry.npmjs.org/log-symbols/-/log-symbols-1.0.2.tgz", 1088 | "integrity": "sha1-N2/3tY6jCGoPCfrMdGF+ylAeGhg=", 1089 | "dev": true, 1090 | "requires": { 1091 | "chalk": "^1.0.0" 1092 | } 1093 | }, 1094 | "supports-color": { 1095 | "version": "2.0.0", 1096 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-2.0.0.tgz", 1097 | "integrity": "sha1-U10EXOa2Nj+kARcIRimZXp3zJMc=", 1098 | "dev": true 1099 | } 1100 | } 1101 | }, 1102 | "listr-verbose-renderer": { 1103 | "version": "0.4.1", 1104 | "resolved": "https://registry.npmjs.org/listr-verbose-renderer/-/listr-verbose-renderer-0.4.1.tgz", 1105 | "integrity": "sha1-ggb0z21S3cWCfl/RSYng6WWTOjU=", 1106 | "dev": true, 1107 | "requires": { 1108 | "chalk": "^1.1.3", 1109 | "cli-cursor": "^1.0.2", 1110 | "date-fns": "^1.27.2", 1111 | "figures": "^1.7.0" 1112 | }, 1113 | "dependencies": { 1114 | "chalk": { 1115 | "version": "1.1.3", 1116 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-1.1.3.tgz", 1117 | "integrity": "sha1-qBFcVeSnAv5NFQq9OHKCKn4J/Jg=", 1118 | "dev": true, 1119 | "requires": { 1120 | "ansi-styles": "^2.2.1", 1121 | "escape-string-regexp": "^1.0.2", 1122 | "has-ansi": "^2.0.0", 1123 | "strip-ansi": "^3.0.0", 1124 | "supports-color": "^2.0.0" 1125 | } 1126 | }, 1127 | "supports-color": { 1128 | "version": "2.0.0", 1129 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-2.0.0.tgz", 1130 | "integrity": "sha1-U10EXOa2Nj+kARcIRimZXp3zJMc=", 1131 | "dev": true 1132 | } 1133 | } 1134 | }, 1135 | "locate-path": { 1136 | "version": "3.0.0", 1137 | "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-3.0.0.tgz", 1138 | "integrity": "sha512-7AO748wWnIhNqAuaty2ZWHkQHRSNfPVIsPIfwEOWO22AmaoVrWavlOcMR5nzTLNYvp36X220/maaRsrec1G65A==", 1139 | "dev": true, 1140 | "requires": { 1141 | "p-locate": "^3.0.0", 1142 | "path-exists": "^3.0.0" 1143 | } 1144 | }, 1145 | "lodash": { 1146 | "version": "4.17.15", 1147 | "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.15.tgz", 1148 | "integrity": "sha512-8xOcRHvCjnocdS5cpwXQXVzmmh5e5+saE2QGoeQmbKmRS6J3VQppPOIt0MnmE+4xlZoumy0GPG0D0MVIQbNA1A==", 1149 | "dev": true 1150 | }, 1151 | "lodash.once": { 1152 | "version": "4.1.1", 1153 | "resolved": "https://registry.npmjs.org/lodash.once/-/lodash.once-4.1.1.tgz", 1154 | "integrity": "sha1-DdOXEhPHxW34gJd9UEyI+0cal6w=", 1155 | "dev": true 1156 | }, 1157 | "log-symbols": { 1158 | "version": "2.2.0", 1159 | "resolved": "https://registry.npmjs.org/log-symbols/-/log-symbols-2.2.0.tgz", 1160 | "integrity": "sha512-VeIAFslyIerEJLXHziedo2basKbMKtTw3vfn5IzG0XTjhAVEJyNHnL2p7vc+wBDSdQuUpNw3M2u6xb9QsAY5Eg==", 1161 | "dev": true, 1162 | "requires": { 1163 | "chalk": "^2.0.1" 1164 | } 1165 | }, 1166 | "log-update": { 1167 | "version": "1.0.2", 1168 | "resolved": "https://registry.npmjs.org/log-update/-/log-update-1.0.2.tgz", 1169 | "integrity": "sha1-GZKfZMQJPS0ucHWh2tivWcKWuNE=", 1170 | "dev": true, 1171 | "requires": { 1172 | "ansi-escapes": "^1.0.0", 1173 | "cli-cursor": "^1.0.2" 1174 | } 1175 | }, 1176 | "mime-db": { 1177 | "version": "1.43.0", 1178 | "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.43.0.tgz", 1179 | "integrity": "sha512-+5dsGEEovYbT8UY9yD7eE4XTc4UwJ1jBYlgaQQF38ENsKR3wj/8q8RFZrF9WIZpB2V1ArTVFUva8sAul1NzRzQ==", 1180 | "dev": true 1181 | }, 1182 | "mime-types": { 1183 | "version": "2.1.26", 1184 | "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.26.tgz", 1185 | "integrity": "sha512-01paPWYgLrkqAyrlDorC1uDwl2p3qZT7yl806vW7DvDoxwXi46jsjFbg+WdwotBIk6/MbEhO/dh5aZ5sNj/dWQ==", 1186 | "dev": true, 1187 | "requires": { 1188 | "mime-db": "1.43.0" 1189 | } 1190 | }, 1191 | "minimatch": { 1192 | "version": "3.0.4", 1193 | "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", 1194 | "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", 1195 | "dev": true, 1196 | "requires": { 1197 | "brace-expansion": "^1.1.7" 1198 | } 1199 | }, 1200 | "minimist": { 1201 | "version": "1.2.0", 1202 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.0.tgz", 1203 | "integrity": "sha1-o1AIsg9BOD7sH7kU9M1d95omQoQ=", 1204 | "dev": true 1205 | }, 1206 | "mkdirp": { 1207 | "version": "0.5.1", 1208 | "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.1.tgz", 1209 | "integrity": "sha1-MAV0OOrGz3+MR2fzhkjWaX11yQM=", 1210 | "dev": true, 1211 | "requires": { 1212 | "minimist": "0.0.8" 1213 | }, 1214 | "dependencies": { 1215 | "minimist": { 1216 | "version": "0.0.8", 1217 | "resolved": "https://registry.npmjs.org/minimist/-/minimist-0.0.8.tgz", 1218 | "integrity": "sha1-hX/Kv8M5fSYluCKCYuhqp6ARsF0=", 1219 | "dev": true 1220 | } 1221 | } 1222 | }, 1223 | "moment": { 1224 | "version": "2.24.0", 1225 | "resolved": "https://registry.npmjs.org/moment/-/moment-2.24.0.tgz", 1226 | "integrity": "sha512-bV7f+6l2QigeBBZSM/6yTNq4P2fNpSWj/0e7jQcy87A8e7o2nAfP/34/2ky5Vw4B9S446EtIhodAzkFCcR4dQg==", 1227 | "dev": true 1228 | }, 1229 | "ms": { 1230 | "version": "2.1.2", 1231 | "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", 1232 | "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", 1233 | "dev": true 1234 | }, 1235 | "nice-try": { 1236 | "version": "1.0.5", 1237 | "resolved": "https://registry.npmjs.org/nice-try/-/nice-try-1.0.5.tgz", 1238 | "integrity": "sha512-1nh45deeb5olNY7eX82BkPO7SSxR5SSYJiPTrTdFUVYwAl8CKMA5N9PjTYkHiRjisVcxcQ1HXdLhx2qxxJzLNQ==", 1239 | "dev": true 1240 | }, 1241 | "npm-run-path": { 1242 | "version": "2.0.2", 1243 | "resolved": "https://registry.npmjs.org/npm-run-path/-/npm-run-path-2.0.2.tgz", 1244 | "integrity": "sha1-NakjLfo11wZ7TLLd8jV7GHFTbF8=", 1245 | "dev": true, 1246 | "requires": { 1247 | "path-key": "^2.0.0" 1248 | } 1249 | }, 1250 | "number-is-nan": { 1251 | "version": "1.0.1", 1252 | "resolved": "https://registry.npmjs.org/number-is-nan/-/number-is-nan-1.0.1.tgz", 1253 | "integrity": "sha1-CXtgK1NCKlIsGvuHkDGDNpQaAR0=", 1254 | "dev": true 1255 | }, 1256 | "oauth-sign": { 1257 | "version": "0.9.0", 1258 | "resolved": "https://registry.npmjs.org/oauth-sign/-/oauth-sign-0.9.0.tgz", 1259 | "integrity": "sha512-fexhUFFPTGV8ybAtSIGbV6gOkSv8UtRbDBnAyLQw4QPKkgNlsH2ByPGtMUqdWkos6YCRmAqViwgZrJc/mRDzZQ==", 1260 | "dev": true 1261 | }, 1262 | "object-assign": { 1263 | "version": "4.1.1", 1264 | "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", 1265 | "integrity": "sha1-IQmtx5ZYh8/AXLvUQsrIv7s2CGM=", 1266 | "dev": true 1267 | }, 1268 | "once": { 1269 | "version": "1.4.0", 1270 | "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", 1271 | "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", 1272 | "dev": true, 1273 | "requires": { 1274 | "wrappy": "1" 1275 | } 1276 | }, 1277 | "onetime": { 1278 | "version": "1.1.0", 1279 | "resolved": "https://registry.npmjs.org/onetime/-/onetime-1.1.0.tgz", 1280 | "integrity": "sha1-ofeDj4MUxRbwXs78vEzP4EtO14k=", 1281 | "dev": true 1282 | }, 1283 | "ora": { 1284 | "version": "0.2.3", 1285 | "resolved": "https://registry.npmjs.org/ora/-/ora-0.2.3.tgz", 1286 | "integrity": "sha1-N1J9Igrc1Tw5tzVx11QVbV22V6Q=", 1287 | "dev": true, 1288 | "requires": { 1289 | "chalk": "^1.1.1", 1290 | "cli-cursor": "^1.0.2", 1291 | "cli-spinners": "^0.1.2", 1292 | "object-assign": "^4.0.1" 1293 | }, 1294 | "dependencies": { 1295 | "chalk": { 1296 | "version": "1.1.3", 1297 | "resolved": "https://registry.npmjs.org/chalk/-/chalk-1.1.3.tgz", 1298 | "integrity": "sha1-qBFcVeSnAv5NFQq9OHKCKn4J/Jg=", 1299 | "dev": true, 1300 | "requires": { 1301 | "ansi-styles": "^2.2.1", 1302 | "escape-string-regexp": "^1.0.2", 1303 | "has-ansi": "^2.0.0", 1304 | "strip-ansi": "^3.0.0", 1305 | "supports-color": "^2.0.0" 1306 | } 1307 | }, 1308 | "supports-color": { 1309 | "version": "2.0.0", 1310 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-2.0.0.tgz", 1311 | "integrity": "sha1-U10EXOa2Nj+kARcIRimZXp3zJMc=", 1312 | "dev": true 1313 | } 1314 | } 1315 | }, 1316 | "os-homedir": { 1317 | "version": "1.0.2", 1318 | "resolved": "https://registry.npmjs.org/os-homedir/-/os-homedir-1.0.2.tgz", 1319 | "integrity": "sha1-/7xJiDNuDoM94MFox+8VISGqf7M=", 1320 | "dev": true 1321 | }, 1322 | "p-finally": { 1323 | "version": "1.0.0", 1324 | "resolved": "https://registry.npmjs.org/p-finally/-/p-finally-1.0.0.tgz", 1325 | "integrity": "sha1-P7z7FbiZpEEjs0ttzBi3JDNqLK4=", 1326 | "dev": true 1327 | }, 1328 | "p-limit": { 1329 | "version": "2.2.2", 1330 | "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-2.2.2.tgz", 1331 | "integrity": "sha512-WGR+xHecKTr7EbUEhyLSh5Dube9JtdiG78ufaeLxTgpudf/20KqyMioIUZJAezlTIi6evxuoUs9YXc11cU+yzQ==", 1332 | "dev": true, 1333 | "requires": { 1334 | "p-try": "^2.0.0" 1335 | } 1336 | }, 1337 | "p-locate": { 1338 | "version": "3.0.0", 1339 | "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-3.0.0.tgz", 1340 | "integrity": "sha512-x+12w/To+4GFfgJhBEpiDcLozRJGegY+Ei7/z0tSLkMmxGZNybVMSfWj9aJn8Z5Fc7dBUNJOOVgPv2H7IwulSQ==", 1341 | "dev": true, 1342 | "requires": { 1343 | "p-limit": "^2.0.0" 1344 | } 1345 | }, 1346 | "p-map": { 1347 | "version": "1.2.0", 1348 | "resolved": "https://registry.npmjs.org/p-map/-/p-map-1.2.0.tgz", 1349 | "integrity": "sha512-r6zKACMNhjPJMTl8KcFH4li//gkrXWfbD6feV8l6doRHlzljFWGJ2AP6iKaCJXyZmAUMOPtvbW7EXkbWO/pLEA==", 1350 | "dev": true 1351 | }, 1352 | "p-try": { 1353 | "version": "2.2.0", 1354 | "resolved": "https://registry.npmjs.org/p-try/-/p-try-2.2.0.tgz", 1355 | "integrity": "sha512-R4nPAVTAU0B9D35/Gk3uJf/7XYbQcyohSKdvAxIRSNghFl4e71hVoGnBNQz9cWaXxO2I10KTC+3jMdvvoKw6dQ==", 1356 | "dev": true 1357 | }, 1358 | "path-exists": { 1359 | "version": "3.0.0", 1360 | "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-3.0.0.tgz", 1361 | "integrity": "sha1-zg6+ql94yxiSXqfYENe1mwEP1RU=", 1362 | "dev": true 1363 | }, 1364 | "path-is-absolute": { 1365 | "version": "1.0.1", 1366 | "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", 1367 | "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=", 1368 | "dev": true 1369 | }, 1370 | "path-is-inside": { 1371 | "version": "1.0.2", 1372 | "resolved": "https://registry.npmjs.org/path-is-inside/-/path-is-inside-1.0.2.tgz", 1373 | "integrity": "sha1-NlQX3t5EQw0cEa9hAn+s8HS9/FM=", 1374 | "dev": true 1375 | }, 1376 | "path-key": { 1377 | "version": "2.0.1", 1378 | "resolved": "https://registry.npmjs.org/path-key/-/path-key-2.0.1.tgz", 1379 | "integrity": "sha1-QRyttXTFoUDTpLGRDUDYDMn0C0A=", 1380 | "dev": true 1381 | }, 1382 | "pend": { 1383 | "version": "1.2.0", 1384 | "resolved": "https://registry.npmjs.org/pend/-/pend-1.2.0.tgz", 1385 | "integrity": "sha1-elfrVQpng/kRUzH89GY9XI4AelA=", 1386 | "dev": true 1387 | }, 1388 | "performance-now": { 1389 | "version": "2.1.0", 1390 | "resolved": "https://registry.npmjs.org/performance-now/-/performance-now-2.1.0.tgz", 1391 | "integrity": "sha1-Ywn04OX6kT7BxpMHrjZLSzd8nns=", 1392 | "dev": true 1393 | }, 1394 | "pify": { 1395 | "version": "2.3.0", 1396 | "resolved": "https://registry.npmjs.org/pify/-/pify-2.3.0.tgz", 1397 | "integrity": "sha1-7RQaasBDqEnqWISY59yosVMw6Qw=", 1398 | "dev": true 1399 | }, 1400 | "pixelmatch": { 1401 | "version": "4.0.2", 1402 | "resolved": "https://registry.npmjs.org/pixelmatch/-/pixelmatch-4.0.2.tgz", 1403 | "integrity": "sha1-j0fc7FARtHe2fbA8JDvB8wheiFQ=", 1404 | "dev": true, 1405 | "requires": { 1406 | "pngjs": "^3.0.0" 1407 | } 1408 | }, 1409 | "pkg-dir": { 1410 | "version": "3.0.0", 1411 | "resolved": "https://registry.npmjs.org/pkg-dir/-/pkg-dir-3.0.0.tgz", 1412 | "integrity": "sha512-/E57AYkoeQ25qkxMj5PBOVgF8Kiu/h7cYS30Z5+R7WaiCCBfLq58ZI/dSeaEKb9WVJV5n/03QwrN3IeWIFllvw==", 1413 | "dev": true, 1414 | "requires": { 1415 | "find-up": "^3.0.0" 1416 | } 1417 | }, 1418 | "plist": { 1419 | "version": "3.0.1", 1420 | "resolved": "https://registry.npmjs.org/plist/-/plist-3.0.1.tgz", 1421 | "integrity": "sha512-GpgvHHocGRyQm74b6FWEZZVRroHKE1I0/BTjAmySaohK+cUn+hZpbqXkc3KWgW3gQYkqcQej35FohcT0FRlkRQ==", 1422 | "dev": true, 1423 | "requires": { 1424 | "base64-js": "^1.2.3", 1425 | "xmlbuilder": "^9.0.7", 1426 | "xmldom": "0.1.x" 1427 | } 1428 | }, 1429 | "pngjs": { 1430 | "version": "3.4.0", 1431 | "resolved": "https://registry.npmjs.org/pngjs/-/pngjs-3.4.0.tgz", 1432 | "integrity": "sha512-NCrCHhWmnQklfH4MtJMRjZ2a8c80qXeMlQMv2uVp9ISJMTt562SbGd6n2oq0PaPgKm7Z6pL9E2UlLIhC+SHL3w==", 1433 | "dev": true 1434 | }, 1435 | "process-nextick-args": { 1436 | "version": "2.0.1", 1437 | "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-2.0.1.tgz", 1438 | "integrity": "sha512-3ouUOpQhtgrbOa17J7+uxOTpITYWaGP7/AhoR3+A+/1e9skrzelGi/dXzEYyvbxubEF6Wn2ypscTKiKJFFn1ag==", 1439 | "dev": true 1440 | }, 1441 | "psl": { 1442 | "version": "1.7.0", 1443 | "resolved": "https://registry.npmjs.org/psl/-/psl-1.7.0.tgz", 1444 | "integrity": "sha512-5NsSEDv8zY70ScRnOTn7bK7eanl2MvFrOrS/R6x+dBt5g1ghnj9Zv90kO8GwT8gxcu2ANyFprnFYB85IogIJOQ==", 1445 | "dev": true 1446 | }, 1447 | "pump": { 1448 | "version": "3.0.0", 1449 | "resolved": "https://registry.npmjs.org/pump/-/pump-3.0.0.tgz", 1450 | "integrity": "sha512-LwZy+p3SFs1Pytd/jYct4wpv49HiYCqd9Rlc5ZVdk0V+8Yzv6jR5Blk3TRmPL1ft69TxP0IMZGJ+WPFU2BFhww==", 1451 | "dev": true, 1452 | "requires": { 1453 | "end-of-stream": "^1.1.0", 1454 | "once": "^1.3.1" 1455 | } 1456 | }, 1457 | "punycode": { 1458 | "version": "2.1.1", 1459 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.1.1.tgz", 1460 | "integrity": "sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A==", 1461 | "dev": true 1462 | }, 1463 | "qs": { 1464 | "version": "6.5.2", 1465 | "resolved": "https://registry.npmjs.org/qs/-/qs-6.5.2.tgz", 1466 | "integrity": "sha512-N5ZAX4/LxJmF+7wN74pUD6qAh9/wnvdQcjq9TZjevvXzSUo7bfmw91saqMjzGS2xq91/odN2dW/WOl7qQHNDGA==", 1467 | "dev": true 1468 | }, 1469 | "querystring": { 1470 | "version": "0.2.0", 1471 | "resolved": "https://registry.npmjs.org/querystring/-/querystring-0.2.0.tgz", 1472 | "integrity": "sha1-sgmEkgO7Jd+CDadW50cAWHhSFiA=", 1473 | "dev": true 1474 | }, 1475 | "ramda": { 1476 | "version": "0.24.1", 1477 | "resolved": "https://registry.npmjs.org/ramda/-/ramda-0.24.1.tgz", 1478 | "integrity": "sha1-w7d1UZfzW43DUCIoJixMkd22uFc=", 1479 | "dev": true 1480 | }, 1481 | "readable-stream": { 1482 | "version": "2.3.7", 1483 | "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.7.tgz", 1484 | "integrity": "sha512-Ebho8K4jIbHAxnuxi7o42OrZgF/ZTNcsZj6nRKyUmkhLFq8CHItp/fy6hQZuZmP/n3yZ9VBUbp4zz/mX8hmYPw==", 1485 | "dev": true, 1486 | "requires": { 1487 | "core-util-is": "~1.0.0", 1488 | "inherits": "~2.0.3", 1489 | "isarray": "~1.0.0", 1490 | "process-nextick-args": "~2.0.0", 1491 | "safe-buffer": "~5.1.1", 1492 | "string_decoder": "~1.1.1", 1493 | "util-deprecate": "~1.0.1" 1494 | } 1495 | }, 1496 | "repeating": { 1497 | "version": "2.0.1", 1498 | "resolved": "https://registry.npmjs.org/repeating/-/repeating-2.0.1.tgz", 1499 | "integrity": "sha1-UhTFOpJtNVJwdSf7q0FdvAjQbdo=", 1500 | "dev": true, 1501 | "requires": { 1502 | "is-finite": "^1.0.0" 1503 | } 1504 | }, 1505 | "request": { 1506 | "version": "2.88.0", 1507 | "resolved": "https://registry.npmjs.org/request/-/request-2.88.0.tgz", 1508 | "integrity": "sha512-NAqBSrijGLZdM0WZNsInLJpkJokL72XYjUpnB0iwsRgxh7dB6COrHnTBNwN0E+lHDAJzu7kLAkDeY08z2/A0hg==", 1509 | "dev": true, 1510 | "requires": { 1511 | "aws-sign2": "~0.7.0", 1512 | "aws4": "^1.8.0", 1513 | "caseless": "~0.12.0", 1514 | "combined-stream": "~1.0.6", 1515 | "extend": "~3.0.2", 1516 | "forever-agent": "~0.6.1", 1517 | "form-data": "~2.3.2", 1518 | "har-validator": "~5.1.0", 1519 | "http-signature": "~1.2.0", 1520 | "is-typedarray": "~1.0.0", 1521 | "isstream": "~0.1.2", 1522 | "json-stringify-safe": "~5.0.1", 1523 | "mime-types": "~2.1.19", 1524 | "oauth-sign": "~0.9.0", 1525 | "performance-now": "^2.1.0", 1526 | "qs": "~6.5.2", 1527 | "safe-buffer": "^5.1.2", 1528 | "tough-cookie": "~2.4.3", 1529 | "tunnel-agent": "^0.6.0", 1530 | "uuid": "^3.3.2" 1531 | } 1532 | }, 1533 | "request-progress": { 1534 | "version": "3.0.0", 1535 | "resolved": "https://registry.npmjs.org/request-progress/-/request-progress-3.0.0.tgz", 1536 | "integrity": "sha1-TKdUCBx/7GP1BeT6qCWqBs1mnb4=", 1537 | "dev": true, 1538 | "requires": { 1539 | "throttleit": "^1.0.0" 1540 | } 1541 | }, 1542 | "restore-cursor": { 1543 | "version": "1.0.1", 1544 | "resolved": "https://registry.npmjs.org/restore-cursor/-/restore-cursor-1.0.1.tgz", 1545 | "integrity": "sha1-NGYfRohjJ/7SmRR5FSJS35LapUE=", 1546 | "dev": true, 1547 | "requires": { 1548 | "exit-hook": "^1.0.0", 1549 | "onetime": "^1.0.0" 1550 | } 1551 | }, 1552 | "rimraf": { 1553 | "version": "2.7.1", 1554 | "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.7.1.tgz", 1555 | "integrity": "sha512-uWjbaKIK3T1OSVptzX7Nl6PvQ3qAGtKEtVRjRuazjfL3Bx5eI409VZSqgND+4UNnmzLVdPj9FqFJNPqBZFve4w==", 1556 | "dev": true, 1557 | "requires": { 1558 | "glob": "^7.1.3" 1559 | } 1560 | }, 1561 | "rxjs": { 1562 | "version": "5.5.12", 1563 | "resolved": "https://registry.npmjs.org/rxjs/-/rxjs-5.5.12.tgz", 1564 | "integrity": "sha512-xx2itnL5sBbqeeiVgNPVuQQ1nC8Jp2WfNJhXWHmElW9YmrpS9UVnNzhP3EH3HFqexO5Tlp8GhYY+WEcqcVMvGw==", 1565 | "dev": true, 1566 | "requires": { 1567 | "symbol-observable": "1.0.1" 1568 | }, 1569 | "dependencies": { 1570 | "symbol-observable": { 1571 | "version": "1.0.1", 1572 | "resolved": "https://registry.npmjs.org/symbol-observable/-/symbol-observable-1.0.1.tgz", 1573 | "integrity": "sha1-g0D8RwLDEi310iKI+IKD9RPT/dQ=", 1574 | "dev": true 1575 | } 1576 | } 1577 | }, 1578 | "safe-buffer": { 1579 | "version": "5.1.2", 1580 | "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", 1581 | "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==", 1582 | "dev": true 1583 | }, 1584 | "safer-buffer": { 1585 | "version": "2.1.2", 1586 | "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", 1587 | "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==", 1588 | "dev": true 1589 | }, 1590 | "semver": { 1591 | "version": "5.7.1", 1592 | "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", 1593 | "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==", 1594 | "dev": true 1595 | }, 1596 | "shebang-command": { 1597 | "version": "1.2.0", 1598 | "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-1.2.0.tgz", 1599 | "integrity": "sha1-RKrGW2lbAzmJaMOfNj/uXer98eo=", 1600 | "dev": true, 1601 | "requires": { 1602 | "shebang-regex": "^1.0.0" 1603 | } 1604 | }, 1605 | "shebang-regex": { 1606 | "version": "1.0.0", 1607 | "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-1.0.0.tgz", 1608 | "integrity": "sha1-2kL0l0DAtC2yypcoVxyxkMmO/qM=", 1609 | "dev": true 1610 | }, 1611 | "signal-exit": { 1612 | "version": "3.0.2", 1613 | "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.2.tgz", 1614 | "integrity": "sha1-tf3AjxKH6hF4Yo5BXiUTK3NkbG0=", 1615 | "dev": true 1616 | }, 1617 | "slice-ansi": { 1618 | "version": "0.0.4", 1619 | "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-0.0.4.tgz", 1620 | "integrity": "sha1-7b+JA/ZvfOL46v1s7tZeJkyDGzU=", 1621 | "dev": true 1622 | }, 1623 | "sshpk": { 1624 | "version": "1.16.1", 1625 | "resolved": "https://registry.npmjs.org/sshpk/-/sshpk-1.16.1.tgz", 1626 | "integrity": "sha512-HXXqVUq7+pcKeLqqZj6mHFUMvXtOJt1uoUx09pFW6011inTMxqI8BA8PM95myrIyyKwdnzjdFjLiE6KBPVtJIg==", 1627 | "dev": true, 1628 | "requires": { 1629 | "asn1": "~0.2.3", 1630 | "assert-plus": "^1.0.0", 1631 | "bcrypt-pbkdf": "^1.0.0", 1632 | "dashdash": "^1.12.0", 1633 | "ecc-jsbn": "~0.1.1", 1634 | "getpass": "^0.1.1", 1635 | "jsbn": "~0.1.0", 1636 | "safer-buffer": "^2.0.2", 1637 | "tweetnacl": "~0.14.0" 1638 | } 1639 | }, 1640 | "stream-to-observable": { 1641 | "version": "0.1.0", 1642 | "resolved": "https://registry.npmjs.org/stream-to-observable/-/stream-to-observable-0.1.0.tgz", 1643 | "integrity": "sha1-Rb8dny19wJvtgfHDB8Qw5ouEz/4=", 1644 | "dev": true 1645 | }, 1646 | "string-width": { 1647 | "version": "1.0.2", 1648 | "resolved": "https://registry.npmjs.org/string-width/-/string-width-1.0.2.tgz", 1649 | "integrity": "sha1-EYvfW4zcUaKn5w0hHgfisLmxB9M=", 1650 | "dev": true, 1651 | "requires": { 1652 | "code-point-at": "^1.0.0", 1653 | "is-fullwidth-code-point": "^1.0.0", 1654 | "strip-ansi": "^3.0.0" 1655 | } 1656 | }, 1657 | "string_decoder": { 1658 | "version": "1.1.1", 1659 | "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", 1660 | "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", 1661 | "dev": true, 1662 | "requires": { 1663 | "safe-buffer": "~5.1.0" 1664 | } 1665 | }, 1666 | "strip-ansi": { 1667 | "version": "3.0.1", 1668 | "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-3.0.1.tgz", 1669 | "integrity": "sha1-ajhfuIU9lS1f8F0Oiq+UJ43GPc8=", 1670 | "dev": true, 1671 | "requires": { 1672 | "ansi-regex": "^2.0.0" 1673 | } 1674 | }, 1675 | "strip-eof": { 1676 | "version": "1.0.0", 1677 | "resolved": "https://registry.npmjs.org/strip-eof/-/strip-eof-1.0.0.tgz", 1678 | "integrity": "sha1-u0P/VZim6wXYm1n80SnJgzE2Br8=", 1679 | "dev": true 1680 | }, 1681 | "supports-color": { 1682 | "version": "5.5.0", 1683 | "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", 1684 | "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", 1685 | "dev": true, 1686 | "requires": { 1687 | "has-flag": "^3.0.0" 1688 | } 1689 | }, 1690 | "term-img": { 1691 | "version": "4.1.0", 1692 | "resolved": "https://registry.npmjs.org/term-img/-/term-img-4.1.0.tgz", 1693 | "integrity": "sha512-DFpBhaF5j+2f7kheKFc1ajsAUUDGOaNPpKPtiIMxlbfud6mvfFZuWGnTRpaujUa5J7yl6cIw/h6nyr4mSsENPg==", 1694 | "dev": true, 1695 | "requires": { 1696 | "ansi-escapes": "^4.1.0", 1697 | "iterm2-version": "^4.1.0" 1698 | }, 1699 | "dependencies": { 1700 | "ansi-escapes": { 1701 | "version": "4.3.0", 1702 | "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-4.3.0.tgz", 1703 | "integrity": "sha512-EiYhwo0v255HUL6eDyuLrXEkTi7WwVCLAw+SeOQ7M7qdun1z1pum4DEm/nuqIVbPvi9RPPc9k9LbyBv6H0DwVg==", 1704 | "dev": true, 1705 | "requires": { 1706 | "type-fest": "^0.8.1" 1707 | } 1708 | } 1709 | } 1710 | }, 1711 | "throttleit": { 1712 | "version": "1.0.0", 1713 | "resolved": "https://registry.npmjs.org/throttleit/-/throttleit-1.0.0.tgz", 1714 | "integrity": "sha1-nnhYNtr0Z0MUWlmEtiaNgoUorGw=", 1715 | "dev": true 1716 | }, 1717 | "tmp": { 1718 | "version": "0.1.0", 1719 | "resolved": "https://registry.npmjs.org/tmp/-/tmp-0.1.0.tgz", 1720 | "integrity": "sha512-J7Z2K08jbGcdA1kkQpJSqLF6T0tdQqpR2pnSUXsIchbPdTI9v3e85cLW0d6WDhwuAleOV71j2xWs8qMPfK7nKw==", 1721 | "dev": true, 1722 | "requires": { 1723 | "rimraf": "^2.6.3" 1724 | } 1725 | }, 1726 | "tough-cookie": { 1727 | "version": "2.4.3", 1728 | "resolved": "https://registry.npmjs.org/tough-cookie/-/tough-cookie-2.4.3.tgz", 1729 | "integrity": "sha512-Q5srk/4vDM54WJsJio3XNn6K2sCG+CQ8G5Wz6bZhRZoAe/+TxjWB/GlFAnYEbkYVlON9FMk/fE3h2RLpPXo4lQ==", 1730 | "dev": true, 1731 | "requires": { 1732 | "psl": "^1.1.24", 1733 | "punycode": "^1.4.1" 1734 | }, 1735 | "dependencies": { 1736 | "punycode": { 1737 | "version": "1.4.1", 1738 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-1.4.1.tgz", 1739 | "integrity": "sha1-wNWmOycYgArY4esPpSachN1BhF4=", 1740 | "dev": true 1741 | } 1742 | } 1743 | }, 1744 | "tunnel-agent": { 1745 | "version": "0.6.0", 1746 | "resolved": "https://registry.npmjs.org/tunnel-agent/-/tunnel-agent-0.6.0.tgz", 1747 | "integrity": "sha1-J6XeoGs2sEoKmWZ3SykIaPD8QP0=", 1748 | "dev": true, 1749 | "requires": { 1750 | "safe-buffer": "^5.0.1" 1751 | } 1752 | }, 1753 | "tweetnacl": { 1754 | "version": "0.14.5", 1755 | "resolved": "https://registry.npmjs.org/tweetnacl/-/tweetnacl-0.14.5.tgz", 1756 | "integrity": "sha1-WuaBd/GS1EViadEIr6k/+HQ/T2Q=", 1757 | "dev": true 1758 | }, 1759 | "type-fest": { 1760 | "version": "0.8.1", 1761 | "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.8.1.tgz", 1762 | "integrity": "sha512-4dbzIzqvjtgiM5rw1k5rEHtBANKmdudhGyBEajN01fEyhaAIhsoKNy6y7+IN93IfpFtwY9iqi7kD+xwKhQsNJA==", 1763 | "dev": true 1764 | }, 1765 | "typedarray": { 1766 | "version": "0.0.6", 1767 | "resolved": "https://registry.npmjs.org/typedarray/-/typedarray-0.0.6.tgz", 1768 | "integrity": "sha1-hnrHTjhkGHsdPUfZlqeOxciDB3c=", 1769 | "dev": true 1770 | }, 1771 | "typescript": { 1772 | "version": "3.5.3", 1773 | "resolved": "https://registry.npmjs.org/typescript/-/typescript-3.5.3.tgz", 1774 | "integrity": "sha512-ACzBtm/PhXBDId6a6sDJfroT2pOWt/oOnk4/dElG5G33ZL776N3Y6/6bKZJBFpd+b05F3Ct9qDjMeJmRWtE2/g==", 1775 | "dev": true 1776 | }, 1777 | "universalify": { 1778 | "version": "0.1.2", 1779 | "resolved": "https://registry.npmjs.org/universalify/-/universalify-0.1.2.tgz", 1780 | "integrity": "sha512-rBJeI5CXAlmy1pV+617WB9J63U6XcazHHF2f2dbJix4XzpUF0RS3Zbj0FGIOCAva5P/d/GBOYaACQ1w+0azUkg==", 1781 | "dev": true 1782 | }, 1783 | "untildify": { 1784 | "version": "3.0.3", 1785 | "resolved": "https://registry.npmjs.org/untildify/-/untildify-3.0.3.tgz", 1786 | "integrity": "sha512-iSk/J8efr8uPT/Z4eSUywnqyrQU7DSdMfdqK4iWEaUVVmcP5JcnpRqmVMwcwcnmI1ATFNgC5V90u09tBynNFKA==", 1787 | "dev": true 1788 | }, 1789 | "uri-js": { 1790 | "version": "4.2.2", 1791 | "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.2.2.tgz", 1792 | "integrity": "sha512-KY9Frmirql91X2Qgjry0Wd4Y+YTdrdZheS8TFwvkbLWf/G5KNJDCh6pKL5OZctEW4+0Baa5idK2ZQuELRwPznQ==", 1793 | "dev": true, 1794 | "requires": { 1795 | "punycode": "^2.1.0" 1796 | } 1797 | }, 1798 | "url": { 1799 | "version": "0.11.0", 1800 | "resolved": "https://registry.npmjs.org/url/-/url-0.11.0.tgz", 1801 | "integrity": "sha1-ODjpfPxgUh63PFJajlW/3Z4uKPE=", 1802 | "dev": true, 1803 | "requires": { 1804 | "punycode": "1.3.2", 1805 | "querystring": "0.2.0" 1806 | }, 1807 | "dependencies": { 1808 | "punycode": { 1809 | "version": "1.3.2", 1810 | "resolved": "https://registry.npmjs.org/punycode/-/punycode-1.3.2.tgz", 1811 | "integrity": "sha1-llOgNvt8HuQjQvIyXM7v6jkmxI0=", 1812 | "dev": true 1813 | } 1814 | } 1815 | }, 1816 | "util-deprecate": { 1817 | "version": "1.0.2", 1818 | "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", 1819 | "integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8=", 1820 | "dev": true 1821 | }, 1822 | "uuid": { 1823 | "version": "3.4.0", 1824 | "resolved": "https://registry.npmjs.org/uuid/-/uuid-3.4.0.tgz", 1825 | "integrity": "sha512-HjSDRw6gZE5JMggctHBcjVak08+KEVhSIiDzFnT9S9aegmp85S/bReBVTb4QTFaRNptJ9kuYaNhnbNEOkbKb/A==", 1826 | "dev": true 1827 | }, 1828 | "verror": { 1829 | "version": "1.10.0", 1830 | "resolved": "https://registry.npmjs.org/verror/-/verror-1.10.0.tgz", 1831 | "integrity": "sha1-OhBcoXBTr1XW4nDB+CiGguGNpAA=", 1832 | "dev": true, 1833 | "requires": { 1834 | "assert-plus": "^1.0.0", 1835 | "core-util-is": "1.0.2", 1836 | "extsprintf": "^1.2.0" 1837 | } 1838 | }, 1839 | "which": { 1840 | "version": "1.3.1", 1841 | "resolved": "https://registry.npmjs.org/which/-/which-1.3.1.tgz", 1842 | "integrity": "sha512-HxJdYWq1MTIQbJ3nw0cqssHoTNU267KlrDuGZ1WYlxDStUtKUhOaJmh112/TZmHxxUfuJqPXSOm7tDyas0OSIQ==", 1843 | "dev": true, 1844 | "requires": { 1845 | "isexe": "^2.0.0" 1846 | } 1847 | }, 1848 | "wrappy": { 1849 | "version": "1.0.2", 1850 | "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", 1851 | "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=", 1852 | "dev": true 1853 | }, 1854 | "xmlbuilder": { 1855 | "version": "9.0.7", 1856 | "resolved": "https://registry.npmjs.org/xmlbuilder/-/xmlbuilder-9.0.7.tgz", 1857 | "integrity": "sha1-Ey7mPS7FVlxVfiD0wi35rKaGsQ0=", 1858 | "dev": true 1859 | }, 1860 | "xmldom": { 1861 | "version": "0.1.31", 1862 | "resolved": "https://registry.npmjs.org/xmldom/-/xmldom-0.1.31.tgz", 1863 | "integrity": "sha512-yS2uJflVQs6n+CyjHoaBmVSqIDevTAWrzMmjG1Gc7h1qQ7uVozNhEPJAwZXWyGQ/Gafo3fCwrcaokezLPupVyQ==", 1864 | "dev": true 1865 | }, 1866 | "yauzl": { 1867 | "version": "2.10.0", 1868 | "resolved": "https://registry.npmjs.org/yauzl/-/yauzl-2.10.0.tgz", 1869 | "integrity": "sha1-x+sXyT4RLLEIb6bY5R+wZnt5pfk=", 1870 | "dev": true, 1871 | "requires": { 1872 | "buffer-crc32": "~0.2.3", 1873 | "fd-slicer": "~1.1.0" 1874 | }, 1875 | "dependencies": { 1876 | "fd-slicer": { 1877 | "version": "1.1.0", 1878 | "resolved": "https://registry.npmjs.org/fd-slicer/-/fd-slicer-1.1.0.tgz", 1879 | "integrity": "sha1-JcfInLH5B3+IkbvmHY85Dq4lbx4=", 1880 | "dev": true, 1881 | "requires": { 1882 | "pend": "~1.2.0" 1883 | } 1884 | } 1885 | } 1886 | } 1887 | } 1888 | } 1889 | --------------------------------------------------------------------------------