diff --git a/packages/core-hn-demo/www/build/app/ion-gesture.ion-scroll.js b/packages/core-hn-demo/www/build/app/ion-gesture.ion-scroll.js index ff086be4b1..768814b4ad 100644 --- a/packages/core-hn-demo/www/build/app/ion-gesture.ion-scroll.js +++ b/packages/core-hn-demo/www/build/app/ion-gesture.ion-scroll.js @@ -354,7 +354,7 @@ var Gesture = (function () { if (this.pan || this.hasPress) { Ionic.listener.enable(this, 'touchstart', true, this.attachTo); Ionic.listener.enable(this, 'mousedown', true, this.attachTo); - Ionic.dom.write(function () { + Core.dom.write(function () { applyStyles(getElementReference(_this.$el, _this.attachTo), GESTURE_INLINE_STYLES); }); } @@ -435,7 +435,7 @@ var Gesture = (function () { if (this.hasCapturedPan) { if (!this.isMoveQueued) { this.isMoveQueued = true; - Ionic.dom.write(function () { + Core.dom.write(function () { _this.isMoveQueued = false; detail.type = 'pan'; if (_this.onMove) { @@ -630,7 +630,7 @@ var Scroll = (function () { var self = this; if (!self.queued && self.enabled) { self.queued = true; - Ionic.dom.read(function (timeStamp) { + Core.dom.read(function (timeStamp) { self.queued = false; self.onScroll(timeStamp || Date.now()); }); @@ -695,7 +695,7 @@ var Scroll = (function () { self.tmr = setTimeout(function () { // haven't scrolled in a while, so it's a scrollend self.isScrolling = false; - Ionic.dom.read(function (timeStamp) { + Core.dom.read(function (timeStamp) { if (!self.isScrolling) { self.onEnd(timeStamp); } @@ -843,7 +843,7 @@ var Scroll = (function () { if (easedT < 1) { // do not use DomController here // must use nativeRaf in order to fire in the next frame - Ionic.dom.raf(step); + Core.dom.raf(step); } else { stopScroll = true; @@ -855,8 +855,8 @@ var Scroll = (function () { // start scroll loop self.isScrolling = true; // chill out for a frame first - Ionic.dom.write(function () { - Ionic.dom.write(function (timeStamp) { + Core.dom.write(function () { + Core.dom.write(function (timeStamp) { startTime = timeStamp; step(timeStamp); }); diff --git a/packages/core-hn-demo/www/build/app/ion-loading.ion-loading-controller.js b/packages/core-hn-demo/www/build/app/ion-loading.ion-loading-controller.js index 2fe864ec5f..87ec8d542f 100644 --- a/packages/core-hn-demo/www/build/app/ion-loading.ion-loading-controller.js +++ b/packages/core-hn-demo/www/build/app/ion-loading.ion-loading-controller.js @@ -129,7 +129,7 @@ var Loading = (function () { _this.animation.onFinish(function (a) { a.destroy(); Ionic.emit(_this, 'ionLoadingDidDismiss', { detail: { loading: _this } }); - Ionic.dom.write(function () { + Core.dom.write(function () { _this.$el.parentNode.removeChild(_this.$el); }); resolve(); diff --git a/packages/core-hn-demo/www/build/app/ion-menu.js b/packages/core-hn-demo/www/build/app/ion-menu.js index 8986f0dddf..02262490cb 100644 --- a/packages/core-hn-demo/www/build/app/ion-menu.js +++ b/packages/core-hn-demo/www/build/app/ion-menu.js @@ -565,7 +565,7 @@ var Menu = (function () { // disable swipe to go back gesture this._activeBlock = GESTURE_BLOCKER; // add css class - Ionic.dom.write(function () { + Core.dom.write(function () { _this._cntElm.classList.add('menu-content-open'); }); // emit open event @@ -575,7 +575,7 @@ var Menu = (function () { // enable swipe to go back gesture this._activeBlock = null; // remove css classes - Ionic.dom.write(function () { + Core.dom.write(function () { _this._cntElm.classList.remove('menu-content-open'); _this._cntElm.classList.remove('show-menu'); _this._backdropElm.classList.remove('show-menu'); diff --git a/packages/core-hn-demo/www/build/app/ion-modal.ion-modal-controller.js b/packages/core-hn-demo/www/build/app/ion-modal.ion-modal-controller.js index 98b4e36146..0b61498f02 100644 --- a/packages/core-hn-demo/www/build/app/ion-modal.ion-modal-controller.js +++ b/packages/core-hn-demo/www/build/app/ion-modal.ion-modal-controller.js @@ -182,7 +182,7 @@ var Modal = (function () { _this.animation.onFinish(function (a) { a.destroy(); Ionic.emit(_this, 'ionModalDidDismiss', { detail: { modal: _this } }); - Ionic.dom.write(function () { + Core.dom.write(function () { _this.$el.parentNode.removeChild(_this.$el); }); resolve(); diff --git a/packages/core/package-lock.json b/packages/core/package-lock.json index 466378c516..c59756a603 100644 --- a/packages/core/package-lock.json +++ b/packages/core/package-lock.json @@ -6,19 +6,4929 @@ "dependencies": { "@stencil/core": { "version": "0.0.2-7", - "resolved": "https://registry.npmjs.org/@stencil/core/-/core-0.0.2-7.tgz", - "integrity": "sha512-Onbx1Mnaao6ht8V8Qo1MRB5vOd+IQ/mOFE9Ns8pSkzEsbfDu5vU+v58cyXoGwTvIHNSxvmEA5pjOwxL3pjymNA==", "requires": { "chalk": "1.1.3", "chokidar": "1.7.0", - "clean-css": "4.1.7", - "jsdom": "11.1.0", + "clean-css": "4.1.5", + "jsdom": "11.0.0", + "node-fetch": "1.7.1", "node-sass": "4.5.3", "rollup": "0.41.4", "rollup-plugin-commonjs": "8.0.2", "rollup-plugin-node-resolve": "3.0.0", "typescript": "2.4.0", - "uglify-js": "3.0.25" + "uglify-es": "3.0.26" + }, + "dependencies": { + "@types/babel-core": { + "version": "6.7.14", + "bundled": true, + "requires": { + "@types/babel-template": "6.7.14", + "@types/babel-traverse": "6.7.17", + "@types/babel-types": "6.7.16" + } + }, + "@types/babel-template": { + "version": "6.7.14", + "bundled": true, + "requires": { + "@types/babel-types": "6.7.16", + "@types/babylon": "6.16.1" + } + }, + "@types/babel-traverse": { + "version": "6.7.17", + "bundled": true, + "requires": { + "@types/babel-types": "6.7.16" + } + }, + "@types/babel-types": { + "version": "6.7.16", + "bundled": true + }, + "@types/babylon": { + "version": "6.16.1", + "bundled": true, + "requires": { + "@types/babel-types": "6.7.16" + } + }, + "@types/css": { + "version": "0.0.30", + "bundled": true + }, + "@types/fs-extra": { + "version": "2.1.0", + "bundled": true, + "requires": { + "@types/node": "7.0.5" + } + }, + "@types/jest": { + "version": "18.1.1", + "bundled": true + }, + "@types/jsdom": { + "version": "11.0.0", + "bundled": true, + "requires": { + "@types/node": "7.0.5", + "@types/tough-cookie": "2.3.0", + "parse5": "3.0.2" + } + }, + "@types/node": { + "version": "7.0.5", + "bundled": true + }, + "@types/tough-cookie": { + "version": "2.3.0", + "bundled": true + }, + "abab": { + "version": "1.0.3", + "bundled": true + }, + "abbrev": { + "version": "1.1.0", + "bundled": true + }, + "acorn": { + "version": "4.0.13", + "bundled": true + }, + "acorn-globals": { + "version": "3.1.0", + "bundled": true, + "requires": { + "acorn": "4.0.13" + } + }, + "ajv": { + "version": "4.11.8", + "bundled": true, + "requires": { + "co": "4.6.0", + "json-stable-stringify": "1.0.1" + } + }, + "amdefine": { + "version": "1.0.1", + "bundled": true + }, + "ansi-align": { + "version": "2.0.0", + "bundled": true, + "requires": { + "string-width": "2.1.0" + }, + "dependencies": { + "ansi-regex": { + "version": "3.0.0", + "bundled": true + }, + "is-fullwidth-code-point": { + "version": "2.0.0", + "bundled": true + }, + "string-width": { + "version": "2.1.0", + "bundled": true, + "requires": { + "is-fullwidth-code-point": "2.0.0", + "strip-ansi": "4.0.0" + } + }, + "strip-ansi": { + "version": "4.0.0", + "bundled": true, + "requires": { + "ansi-regex": "3.0.0" + } + } + } + }, + "ansi-escapes": { + "version": "1.4.0", + "bundled": true + }, + "ansi-regex": { + "version": "2.1.1", + "bundled": true + }, + "ansi-styles": { + "version": "2.2.1", + "bundled": true + }, + "any-observable": { + "version": "0.2.0", + "bundled": true + }, + "anymatch": { + "version": "1.3.0", + "bundled": true, + "requires": { + "arrify": "1.0.1", + "micromatch": "2.3.11" + } + }, + "append-transform": { + "version": "0.4.0", + "bundled": true, + "requires": { + "default-require-extensions": "1.0.0" + } + }, + "aproba": { + "version": "1.1.2", + "bundled": true + }, + "are-we-there-yet": { + "version": "1.1.4", + "bundled": true, + "requires": { + "delegates": "1.0.0", + "readable-stream": "2.3.2" + } + }, + "argparse": { + "version": "1.0.9", + "bundled": true, + "requires": { + "sprintf-js": "1.0.3" + } + }, + "arr-diff": { + "version": "2.0.0", + "bundled": true, + "requires": { + "arr-flatten": "1.0.3" + } + }, + "arr-flatten": { + "version": "1.0.3", + "bundled": true + }, + "array-equal": { + "version": "1.0.0", + "bundled": true + }, + "array-find-index": { + "version": "1.0.2", + "bundled": true + }, + "array-union": { + "version": "1.0.2", + "bundled": true, + "requires": { + "array-uniq": "1.0.3" + } + }, + "array-uniq": { + "version": "1.0.3", + "bundled": true + }, + "array-unique": { + "version": "0.2.1", + "bundled": true + }, + "arrify": { + "version": "1.0.1", + "bundled": true + }, + "asn1": { + "version": "0.2.3", + "bundled": true + }, + "assert-plus": { + "version": "0.2.0", + "bundled": true + }, + "async": { + "version": "2.5.0", + "bundled": true, + "requires": { + "lodash": "4.17.4" + } + }, + "async-each": { + "version": "1.0.1", + "bundled": true + }, + "async-foreach": { + "version": "0.1.3", + "bundled": true + }, + "asynckit": { + "version": "0.4.0", + "bundled": true + }, + "aws-sign2": { + "version": "0.6.0", + "bundled": true + }, + "aws4": { + "version": "1.6.0", + "bundled": true + }, + "babel-cli": { + "version": "6.24.1", + "bundled": true, + "requires": { + "babel-core": "6.25.0", + "babel-polyfill": "6.23.0", + "babel-register": "6.24.1", + "babel-runtime": "6.23.0", + "chokidar": "1.7.0", + "commander": "2.10.0", + "convert-source-map": "1.5.0", + "fs-readdir-recursive": "1.0.0", + "glob": "7.1.2", + "lodash": "4.17.4", + "output-file-sync": "1.1.2", + "path-is-absolute": "1.0.1", + "slash": "1.0.0", + "source-map": "0.5.6", + "v8flags": "2.1.1" + } + }, + "babel-code-frame": { + "version": "6.22.0", + "bundled": true, + "requires": { + "chalk": "1.1.3", + "esutils": "2.0.2", + "js-tokens": "3.0.1" + } + }, + "babel-core": { + "version": "6.25.0", + "bundled": true, + "requires": { + "babel-code-frame": "6.22.0", + "babel-generator": "6.25.0", + "babel-helpers": "6.24.1", + "babel-messages": "6.23.0", + "babel-register": "6.24.1", + "babel-runtime": "6.23.0", + "babel-template": "6.25.0", + "babel-traverse": "6.25.0", + "babel-types": "6.25.0", + "babylon": "6.17.4", + "convert-source-map": "1.5.0", + "debug": "2.6.8", + "json5": "0.5.1", + "lodash": "4.17.4", + "minimatch": "3.0.4", + "path-is-absolute": "1.0.1", + "private": "0.1.7", + "slash": "1.0.0", + "source-map": "0.5.6" + } + }, + "babel-generator": { + "version": "6.25.0", + "bundled": true, + "requires": { + "babel-messages": "6.23.0", + "babel-runtime": "6.23.0", + "babel-types": "6.25.0", + "detect-indent": "4.0.0", + "jsesc": "1.3.0", + "lodash": "4.17.4", + "source-map": "0.5.6", + "trim-right": "1.0.1" + } + }, + "babel-helper-call-delegate": { + "version": "6.24.1", + "bundled": true, + "requires": { + "babel-helper-hoist-variables": "6.24.1", + "babel-runtime": "6.23.0", + "babel-traverse": "6.25.0", + "babel-types": "6.25.0" + } + }, + "babel-helper-define-map": { + "version": "6.24.1", + "bundled": true, + "requires": { + "babel-helper-function-name": "6.24.1", + "babel-runtime": "6.23.0", + "babel-types": "6.25.0", + "lodash": "4.17.4" + } + }, + "babel-helper-function-name": { + "version": "6.24.1", + "bundled": true, + "requires": { + "babel-helper-get-function-arity": "6.24.1", + "babel-runtime": "6.23.0", + "babel-template": "6.25.0", + "babel-traverse": "6.25.0", + "babel-types": "6.25.0" + } + }, + "babel-helper-get-function-arity": { + "version": "6.24.1", + "bundled": true, + "requires": { + "babel-runtime": "6.23.0", + "babel-types": "6.25.0" + } + }, + "babel-helper-hoist-variables": { + "version": "6.24.1", + "bundled": true, + "requires": { + "babel-runtime": "6.23.0", + "babel-types": "6.25.0" + } + }, + "babel-helper-optimise-call-expression": { + "version": "6.24.1", + "bundled": true, + "requires": { + "babel-runtime": "6.23.0", + "babel-types": "6.25.0" + } + }, + "babel-helper-replace-supers": { + "version": "6.24.1", + "bundled": true, + "requires": { + "babel-helper-optimise-call-expression": "6.24.1", + "babel-messages": "6.23.0", + "babel-runtime": "6.23.0", + "babel-template": "6.25.0", + "babel-traverse": "6.25.0", + "babel-types": "6.25.0" + } + }, + "babel-helpers": { + "version": "6.24.1", + "bundled": true, + "requires": { + "babel-runtime": "6.23.0", + "babel-template": "6.25.0" + } + }, + "babel-jest": { + "version": "19.0.0", + "bundled": true, + "requires": { + "babel-core": "6.25.0", + "babel-plugin-istanbul": "4.1.4", + "babel-preset-jest": "19.0.0" + } + }, + "babel-messages": { + "version": "6.23.0", + "bundled": true, + "requires": { + "babel-runtime": "6.23.0" + } + }, + "babel-plugin-istanbul": { + "version": "4.1.4", + "bundled": true, + "requires": { + "find-up": "2.1.0", + "istanbul-lib-instrument": "1.7.3", + "test-exclude": "4.1.1" + } + }, + "babel-plugin-jest-hoist": { + "version": "19.0.0", + "bundled": true + }, + "babel-plugin-transform-define": { + "version": "1.3.0", + "bundled": true, + "requires": { + "lodash": "4.17.4", + "traverse": "0.6.6" + } + }, + "babel-plugin-transform-es2015-arrow-functions": { + "version": "6.22.0", + "bundled": true, + "requires": { + "babel-runtime": "6.23.0" + } + }, + "babel-plugin-transform-es2015-block-scoped-functions": { + "version": "6.22.0", + "bundled": true, + "requires": { + "babel-runtime": "6.23.0" + } + }, + "babel-plugin-transform-es2015-block-scoping": { + "version": "6.24.1", + "bundled": true, + "requires": { + "babel-runtime": "6.23.0", + "babel-template": "6.25.0", + "babel-traverse": "6.25.0", + "babel-types": "6.25.0", + "lodash": "4.17.4" + } + }, + "babel-plugin-transform-es2015-classes": { + "version": "6.24.1", + "bundled": true, + "requires": { + "babel-helper-define-map": "6.24.1", + "babel-helper-function-name": "6.24.1", + "babel-helper-optimise-call-expression": "6.24.1", + "babel-helper-replace-supers": "6.24.1", + "babel-messages": "6.23.0", + "babel-runtime": "6.23.0", + "babel-template": "6.25.0", + "babel-traverse": "6.25.0", + "babel-types": "6.25.0" + } + }, + "babel-plugin-transform-es2015-destructuring": { + "version": "6.23.0", + "bundled": true, + "requires": { + "babel-runtime": "6.23.0" + } + }, + "babel-plugin-transform-es2015-parameters": { + "version": "6.24.1", + "bundled": true, + "requires": { + "babel-helper-call-delegate": "6.24.1", + "babel-helper-get-function-arity": "6.24.1", + "babel-runtime": "6.23.0", + "babel-template": "6.25.0", + "babel-traverse": "6.25.0", + "babel-types": "6.25.0" + } + }, + "babel-plugin-transform-es2015-shorthand-properties": { + "version": "6.24.1", + "bundled": true, + "requires": { + "babel-runtime": "6.23.0", + "babel-types": "6.25.0" + } + }, + "babel-plugin-transform-es2015-template-literals": { + "version": "6.22.0", + "bundled": true, + "requires": { + "babel-runtime": "6.23.0" + } + }, + "babel-polyfill": { + "version": "6.23.0", + "bundled": true, + "requires": { + "babel-runtime": "6.23.0", + "core-js": "2.4.1", + "regenerator-runtime": "0.10.5" + } + }, + "babel-preset-jest": { + "version": "19.0.0", + "bundled": true, + "requires": { + "babel-plugin-jest-hoist": "19.0.0" + } + }, + "babel-register": { + "version": "6.24.1", + "bundled": true, + "requires": { + "babel-core": "6.25.0", + "babel-runtime": "6.23.0", + "core-js": "2.4.1", + "home-or-tmp": "2.0.0", + "lodash": "4.17.4", + "mkdirp": "0.5.1", + "source-map-support": "0.4.15" + } + }, + "babel-runtime": { + "version": "6.23.0", + "bundled": true, + "requires": { + "core-js": "2.4.1", + "regenerator-runtime": "0.10.5" + } + }, + "babel-template": { + "version": "6.25.0", + "bundled": true, + "requires": { + "babel-runtime": "6.23.0", + "babel-traverse": "6.25.0", + "babel-types": "6.25.0", + "babylon": "6.17.4", + "lodash": "4.17.4" + } + }, + "babel-traverse": { + "version": "6.25.0", + "bundled": true, + "requires": { + "babel-code-frame": "6.22.0", + "babel-messages": "6.23.0", + "babel-runtime": "6.23.0", + "babel-types": "6.25.0", + "babylon": "6.17.4", + "debug": "2.6.8", + "globals": "9.18.0", + "invariant": "2.2.2", + "lodash": "4.17.4" + } + }, + "babel-types": { + "version": "6.25.0", + "bundled": true, + "requires": { + "babel-runtime": "6.23.0", + "esutils": "2.0.2", + "lodash": "4.17.4", + "to-fast-properties": "1.0.3" + } + }, + "babylon": { + "version": "6.17.4", + "bundled": true + }, + "balanced-match": { + "version": "1.0.0", + "bundled": true + }, + "bcrypt-pbkdf": { + "version": "1.0.1", + "bundled": true, + "optional": true, + "requires": { + "tweetnacl": "0.14.5" + } + }, + "binary-extensions": { + "version": "1.8.0", + "bundled": true + }, + "block-stream": { + "version": "0.0.9", + "bundled": true, + "requires": { + "inherits": "2.0.3" + } + }, + "boom": { + "version": "2.10.1", + "bundled": true, + "requires": { + "hoek": "2.16.3" + } + }, + "boxen": { + "version": "1.1.0", + "bundled": true, + "requires": { + "ansi-align": "2.0.0", + "camelcase": "4.1.0", + "chalk": "1.1.3", + "cli-boxes": "1.0.0", + "string-width": "2.1.0", + "term-size": "0.1.1", + "widest-line": "1.0.0" + }, + "dependencies": { + "ansi-regex": { + "version": "3.0.0", + "bundled": true + }, + "is-fullwidth-code-point": { + "version": "2.0.0", + "bundled": true + }, + "string-width": { + "version": "2.1.0", + "bundled": true, + "requires": { + "is-fullwidth-code-point": "2.0.0", + "strip-ansi": "4.0.0" + } + }, + "strip-ansi": { + "version": "4.0.0", + "bundled": true, + "requires": { + "ansi-regex": "3.0.0" + } + } + } + }, + "brace-expansion": { + "version": "1.1.8", + "bundled": true, + "requires": { + "balanced-match": "1.0.0", + "concat-map": "0.0.1" + } + }, + "braces": { + "version": "1.8.5", + "bundled": true, + "requires": { + "expand-range": "1.8.2", + "preserve": "0.2.0", + "repeat-element": "1.1.2" + } + }, + "browser-resolve": { + "version": "1.11.2", + "bundled": true, + "requires": { + "resolve": "1.1.7" + }, + "dependencies": { + "resolve": { + "version": "1.1.7", + "bundled": true + } + } + }, + "bser": { + "version": "2.0.0", + "bundled": true, + "requires": { + "node-int64": "0.4.0" + } + }, + "builtin-modules": { + "version": "1.1.1", + "bundled": true + }, + "callsites": { + "version": "2.0.0", + "bundled": true + }, + "camelcase": { + "version": "4.1.0", + "bundled": true + }, + "camelcase-keys": { + "version": "2.1.0", + "bundled": true, + "requires": { + "camelcase": "2.1.1", + "map-obj": "1.0.1" + }, + "dependencies": { + "camelcase": { + "version": "2.1.1", + "bundled": true + } + } + }, + "capture-stack-trace": { + "version": "1.0.0", + "bundled": true + }, + "caseless": { + "version": "0.12.0", + "bundled": true + }, + "chalk": { + "version": "1.1.3", + "bundled": true, + "requires": { + "ansi-styles": "2.2.1", + "escape-string-regexp": "1.0.5", + "has-ansi": "2.0.0", + "strip-ansi": "3.0.1", + "supports-color": "2.0.0" + } + }, + "chokidar": { + "version": "1.7.0", + "bundled": true, + "requires": { + "anymatch": "1.3.0", + "async-each": "1.0.1", + "fsevents": "1.1.2", + "glob-parent": "2.0.0", + "inherits": "2.0.3", + "is-binary-path": "1.0.1", + "is-glob": "2.0.1", + "path-is-absolute": "1.0.1", + "readdirp": "2.1.0" + } + }, + "ci-info": { + "version": "1.0.0", + "bundled": true + }, + "clean-css": { + "version": "4.1.5", + "bundled": true, + "requires": { + "source-map": "0.5.6" + } + }, + "cli-boxes": { + "version": "1.0.0", + "bundled": true + }, + "cli-cursor": { + "version": "2.1.0", + "bundled": true, + "requires": { + "restore-cursor": "2.0.0" + } + }, + "cli-spinners": { + "version": "0.1.2", + "bundled": true + }, + "cli-truncate": { + "version": "0.2.1", + "bundled": true, + "requires": { + "slice-ansi": "0.0.4", + "string-width": "1.0.2" + } + }, + "cli-width": { + "version": "2.1.0", + "bundled": true + }, + "clone": { + "version": "1.0.2", + "bundled": true + }, + "clone-stats": { + "version": "0.0.1", + "bundled": true + }, + "co": { + "version": "4.6.0", + "bundled": true + }, + "code-point-at": { + "version": "1.1.0", + "bundled": true + }, + "color-convert": { + "version": "1.9.0", + "bundled": true, + "requires": { + "color-name": "1.1.2" + } + }, + "color-name": { + "version": "1.1.2", + "bundled": true + }, + "colors": { + "version": "1.1.2", + "bundled": true + }, + "combined-stream": { + "version": "1.0.5", + "bundled": true, + "requires": { + "delayed-stream": "1.0.0" + } + }, + "commander": { + "version": "2.10.0", + "bundled": true, + "requires": { + "graceful-readlink": "1.0.1" + } + }, + "concat-map": { + "version": "0.0.1", + "bundled": true + }, + "configstore": { + "version": "3.1.0", + "bundled": true, + "requires": { + "dot-prop": "4.1.1", + "graceful-fs": "4.1.11", + "make-dir": "1.0.0", + "unique-string": "1.0.0", + "write-file-atomic": "2.1.0", + "xdg-basedir": "3.0.0" + } + }, + "console-control-strings": { + "version": "1.1.0", + "bundled": true + }, + "content-type-parser": { + "version": "1.0.1", + "bundled": true + }, + "convert-source-map": { + "version": "1.5.0", + "bundled": true + }, + "core-js": { + "version": "2.4.1", + "bundled": true + }, + "core-util-is": { + "version": "1.0.2", + "bundled": true + }, + "create-error-class": { + "version": "3.0.2", + "bundled": true, + "requires": { + "capture-stack-trace": "1.0.0" + } + }, + "cross-spawn": { + "version": "3.0.1", + "bundled": true, + "requires": { + "lru-cache": "4.1.1", + "which": "1.2.14" + } + }, + "cross-spawn-async": { + "version": "2.2.5", + "bundled": true, + "requires": { + "lru-cache": "4.1.1", + "which": "1.2.14" + } + }, + "cryptiles": { + "version": "2.0.5", + "bundled": true, + "requires": { + "boom": "2.10.1" + } + }, + "crypto-random-string": { + "version": "1.0.0", + "bundled": true + }, + "cssom": { + "version": "0.3.2", + "bundled": true + }, + "cssstyle": { + "version": "0.2.37", + "bundled": true, + "requires": { + "cssom": "0.3.2" + } + }, + "currently-unhandled": { + "version": "0.4.1", + "bundled": true, + "requires": { + "array-find-index": "1.0.2" + } + }, + "dashdash": { + "version": "1.14.1", + "bundled": true, + "requires": { + "assert-plus": "1.0.0" + }, + "dependencies": { + "assert-plus": { + "version": "1.0.0", + "bundled": true + } + } + }, + "date-fns": { + "version": "1.28.5", + "bundled": true + }, + "debug": { + "version": "2.6.8", + "bundled": true, + "requires": { + "ms": "2.0.0" + } + }, + "decamelize": { + "version": "1.2.0", + "bundled": true + }, + "deep-extend": { + "version": "0.4.2", + "bundled": true + }, + "deep-is": { + "version": "0.1.3", + "bundled": true + }, + "default-require-extensions": { + "version": "1.0.0", + "bundled": true, + "requires": { + "strip-bom": "2.0.0" + } + }, + "del": { + "version": "2.2.2", + "bundled": true, + "requires": { + "globby": "5.0.0", + "is-path-cwd": "1.0.0", + "is-path-in-cwd": "1.0.0", + "object-assign": "4.1.1", + "pify": "2.3.0", + "pinkie-promise": "2.0.1", + "rimraf": "2.6.1" + } + }, + "delayed-stream": { + "version": "1.0.0", + "bundled": true + }, + "delegates": { + "version": "1.0.0", + "bundled": true + }, + "detect-indent": { + "version": "4.0.0", + "bundled": true, + "requires": { + "repeating": "2.0.1" + } + }, + "diff": { + "version": "3.2.0", + "bundled": true + }, + "doctrine": { + "version": "0.7.2", + "bundled": true, + "requires": { + "esutils": "1.1.6", + "isarray": "0.0.1" + }, + "dependencies": { + "esutils": { + "version": "1.1.6", + "bundled": true + }, + "isarray": { + "version": "0.0.1", + "bundled": true + } + } + }, + "dot-prop": { + "version": "4.1.1", + "bundled": true, + "requires": { + "is-obj": "1.0.1" + } + }, + "duplexer3": { + "version": "0.1.4", + "bundled": true + }, + "ecc-jsbn": { + "version": "0.1.1", + "bundled": true, + "optional": true, + "requires": { + "jsbn": "0.1.1" + } + }, + "elegant-spinner": { + "version": "1.0.1", + "bundled": true + }, + "encoding": { + "version": "0.1.12", + "bundled": true, + "requires": { + "iconv-lite": "0.4.13" + } + }, + "errno": { + "version": "0.1.4", + "bundled": true, + "requires": { + "prr": "0.0.0" + } + }, + "error-ex": { + "version": "1.3.1", + "bundled": true, + "requires": { + "is-arrayish": "0.2.1" + } + }, + "escape-string-regexp": { + "version": "1.0.5", + "bundled": true + }, + "escodegen": { + "version": "1.8.1", + "bundled": true, + "requires": { + "esprima": "2.7.3", + "estraverse": "1.9.3", + "esutils": "2.0.2", + "optionator": "0.8.2", + "source-map": "0.2.0" + }, + "dependencies": { + "esprima": { + "version": "2.7.3", + "bundled": true + }, + "source-map": { + "version": "0.2.0", + "bundled": true, + "optional": true, + "requires": { + "amdefine": "1.0.1" + } + } + } + }, + "esprima": { + "version": "3.1.3", + "bundled": true + }, + "estraverse": { + "version": "1.9.3", + "bundled": true + }, + "estree-walker": { + "version": "0.3.1", + "bundled": true + }, + "esutils": { + "version": "2.0.2", + "bundled": true + }, + "exec-sh": { + "version": "0.2.0", + "bundled": true, + "requires": { + "merge": "1.2.0" + } + }, + "execa": { + "version": "0.6.3", + "bundled": true, + "requires": { + "cross-spawn": "5.1.0", + "get-stream": "3.0.0", + "is-stream": "1.1.0", + "npm-run-path": "2.0.2", + "p-finally": "1.0.0", + "signal-exit": "3.0.2", + "strip-eof": "1.0.0" + }, + "dependencies": { + "cross-spawn": { + "version": "5.1.0", + "bundled": true, + "requires": { + "lru-cache": "4.1.1", + "shebang-command": "1.2.0", + "which": "1.2.14" + } + } + } + }, + "exit-hook": { + "version": "1.1.1", + "bundled": true + }, + "expand-brackets": { + "version": "0.1.5", + "bundled": true, + "requires": { + "is-posix-bracket": "0.1.1" + } + }, + "expand-range": { + "version": "1.8.2", + "bundled": true, + "requires": { + "fill-range": "2.2.3" + } + }, + "extend": { + "version": "3.0.1", + "bundled": true + }, + "external-editor": { + "version": "2.0.4", + "bundled": true, + "requires": { + "iconv-lite": "0.4.18", + "jschardet": "1.4.2", + "tmp": "0.0.31" + }, + "dependencies": { + "iconv-lite": { + "version": "0.4.18", + "bundled": true + } + } + }, + "extglob": { + "version": "0.3.2", + "bundled": true, + "requires": { + "is-extglob": "1.0.0" + } + }, + "extsprintf": { + "version": "1.0.2", + "bundled": true + }, + "fast-levenshtein": { + "version": "2.0.6", + "bundled": true + }, + "fb-watchman": { + "version": "2.0.0", + "bundled": true, + "requires": { + "bser": "2.0.0" + } + }, + "figures": { + "version": "2.0.0", + "bundled": true, + "requires": { + "escape-string-regexp": "1.0.5" + } + }, + "filename-regex": { + "version": "2.0.1", + "bundled": true + }, + "fileset": { + "version": "2.0.3", + "bundled": true, + "requires": { + "glob": "7.1.2", + "minimatch": "3.0.4" + } + }, + "fill-range": { + "version": "2.2.3", + "bundled": true, + "requires": { + "is-number": "2.1.0", + "isobject": "2.1.0", + "randomatic": "1.1.7", + "repeat-element": "1.1.2", + "repeat-string": "1.6.1" + } + }, + "find-up": { + "version": "2.1.0", + "bundled": true, + "requires": { + "locate-path": "2.0.0" + } + }, + "findup-sync": { + "version": "0.3.0", + "bundled": true, + "requires": { + "glob": "5.0.15" + }, + "dependencies": { + "glob": { + "version": "5.0.15", + "bundled": true, + "requires": { + "inflight": "1.0.6", + "inherits": "2.0.3", + "minimatch": "3.0.4", + "once": "1.4.0", + "path-is-absolute": "1.0.1" + } + } + } + }, + "for-in": { + "version": "1.0.2", + "bundled": true + }, + "for-own": { + "version": "0.1.5", + "bundled": true, + "requires": { + "for-in": "1.0.2" + } + }, + "forever-agent": { + "version": "0.6.1", + "bundled": true + }, + "form-data": { + "version": "2.1.4", + "bundled": true, + "requires": { + "asynckit": "0.4.0", + "combined-stream": "1.0.5", + "mime-types": "2.1.15" + } + }, + "fs-extra": { + "version": "2.1.2", + "bundled": true, + "requires": { + "graceful-fs": "4.1.11", + "jsonfile": "2.4.0" + } + }, + "fs-readdir-recursive": { + "version": "1.0.0", + "bundled": true + }, + "fs.realpath": { + "version": "1.0.0", + "bundled": true + }, + "fsevents": { + "version": "1.1.2", + "bundled": true, + "optional": true, + "requires": { + "nan": "2.6.2", + "node-pre-gyp": "0.6.36" + }, + "dependencies": { + "abbrev": { + "version": "1.1.0", + "bundled": true, + "optional": true + }, + "ajv": { + "version": "4.11.8", + "bundled": true, + "optional": true, + "requires": { + "co": "4.6.0", + "json-stable-stringify": "1.0.1" + } + }, + "ansi-regex": { + "version": "2.1.1", + "bundled": true + }, + "aproba": { + "version": "1.1.1", + "bundled": true, + "optional": true + }, + "are-we-there-yet": { + "version": "1.1.4", + "bundled": true, + "optional": true, + "requires": { + "delegates": "1.0.0", + "readable-stream": "2.2.9" + } + }, + "asn1": { + "version": "0.2.3", + "bundled": true, + "optional": true + }, + "assert-plus": { + "version": "0.2.0", + "bundled": true, + "optional": true + }, + "asynckit": { + "version": "0.4.0", + "bundled": true, + "optional": true + }, + "aws-sign2": { + "version": "0.6.0", + "bundled": true, + "optional": true + }, + "aws4": { + "version": "1.6.0", + "bundled": true, + "optional": true + }, + "balanced-match": { + "version": "0.4.2", + "bundled": true + }, + "bcrypt-pbkdf": { + "version": "1.0.1", + "bundled": true, + "optional": true, + "requires": { + "tweetnacl": "0.14.5" + } + }, + "block-stream": { + "version": "0.0.9", + "bundled": true, + "requires": { + "inherits": "2.0.3" + } + }, + "boom": { + "version": "2.10.1", + "bundled": true, + "requires": { + "hoek": "2.16.3" + } + }, + "brace-expansion": { + "version": "1.1.7", + "bundled": true, + "requires": { + "balanced-match": "0.4.2", + "concat-map": "0.0.1" + } + }, + "buffer-shims": { + "version": "1.0.0", + "bundled": true + }, + "caseless": { + "version": "0.12.0", + "bundled": true, + "optional": true + }, + "co": { + "version": "4.6.0", + "bundled": true, + "optional": true + }, + "code-point-at": { + "version": "1.1.0", + "bundled": true + }, + "combined-stream": { + "version": "1.0.5", + "bundled": true, + "requires": { + "delayed-stream": "1.0.0" + } + }, + "concat-map": { + "version": "0.0.1", + "bundled": true + }, + "console-control-strings": { + "version": "1.1.0", + "bundled": true + }, + "core-util-is": { + "version": "1.0.2", + "bundled": true + }, + "cryptiles": { + "version": "2.0.5", + "bundled": true, + "optional": true, + "requires": { + "boom": "2.10.1" + } + }, + "dashdash": { + "version": "1.14.1", + "bundled": true, + "optional": true, + "requires": { + "assert-plus": "1.0.0" + }, + "dependencies": { + "assert-plus": { + "version": "1.0.0", + "bundled": true, + "optional": true + } + } + }, + "debug": { + "version": "2.6.8", + "bundled": true, + "optional": true, + "requires": { + "ms": "2.0.0" + } + }, + "deep-extend": { + "version": "0.4.2", + "bundled": true, + "optional": true + }, + "delayed-stream": { + "version": "1.0.0", + "bundled": true + }, + "delegates": { + "version": "1.0.0", + "bundled": true, + "optional": true + }, + "ecc-jsbn": { + "version": "0.1.1", + "bundled": true, + "optional": true, + "requires": { + "jsbn": "0.1.1" + } + }, + "extend": { + "version": "3.0.1", + "bundled": true, + "optional": true + }, + "extsprintf": { + "version": "1.0.2", + "bundled": true + }, + "forever-agent": { + "version": "0.6.1", + "bundled": true, + "optional": true + }, + "form-data": { + "version": "2.1.4", + "bundled": true, + "optional": true, + "requires": { + "asynckit": "0.4.0", + "combined-stream": "1.0.5", + "mime-types": "2.1.15" + } + }, + "fs.realpath": { + "version": "1.0.0", + "bundled": true + }, + "fstream": { + "version": "1.0.11", + "bundled": true, + "requires": { + "graceful-fs": "4.1.11", + "inherits": "2.0.3", + "mkdirp": "0.5.1", + "rimraf": "2.6.1" + } + }, + "fstream-ignore": { + "version": "1.0.5", + "bundled": true, + "optional": true, + "requires": { + "fstream": "1.0.11", + "inherits": "2.0.3", + "minimatch": "3.0.4" + } + }, + "gauge": { + "version": "2.7.4", + "bundled": true, + "optional": true, + "requires": { + "aproba": "1.1.1", + "console-control-strings": "1.1.0", + "has-unicode": "2.0.1", + "object-assign": "4.1.1", + "signal-exit": "3.0.2", + "string-width": "1.0.2", + "strip-ansi": "3.0.1", + "wide-align": "1.1.2" + } + }, + "getpass": { + "version": "0.1.7", + "bundled": true, + "optional": true, + "requires": { + "assert-plus": "1.0.0" + }, + "dependencies": { + "assert-plus": { + "version": "1.0.0", + "bundled": true, + "optional": true + } + } + }, + "glob": { + "version": "7.1.2", + "bundled": true, + "requires": { + "fs.realpath": "1.0.0", + "inflight": "1.0.6", + "inherits": "2.0.3", + "minimatch": "3.0.4", + "once": "1.4.0", + "path-is-absolute": "1.0.1" + } + }, + "graceful-fs": { + "version": "4.1.11", + "bundled": true + }, + "har-schema": { + "version": "1.0.5", + "bundled": true, + "optional": true + }, + "har-validator": { + "version": "4.2.1", + "bundled": true, + "optional": true, + "requires": { + "ajv": "4.11.8", + "har-schema": "1.0.5" + } + }, + "has-unicode": { + "version": "2.0.1", + "bundled": true, + "optional": true + }, + "hawk": { + "version": "3.1.3", + "bundled": true, + "optional": true, + "requires": { + "boom": "2.10.1", + "cryptiles": "2.0.5", + "hoek": "2.16.3", + "sntp": "1.0.9" + } + }, + "hoek": { + "version": "2.16.3", + "bundled": true + }, + "http-signature": { + "version": "1.1.1", + "bundled": true, + "optional": true, + "requires": { + "assert-plus": "0.2.0", + "jsprim": "1.4.0", + "sshpk": "1.13.0" + } + }, + "inflight": { + "version": "1.0.6", + "bundled": true, + "requires": { + "once": "1.4.0", + "wrappy": "1.0.2" + } + }, + "inherits": { + "version": "2.0.3", + "bundled": true + }, + "ini": { + "version": "1.3.4", + "bundled": true, + "optional": true + }, + "is-fullwidth-code-point": { + "version": "1.0.0", + "bundled": true, + "requires": { + "number-is-nan": "1.0.1" + } + }, + "is-typedarray": { + "version": "1.0.0", + "bundled": true, + "optional": true + }, + "isarray": { + "version": "1.0.0", + "bundled": true + }, + "isstream": { + "version": "0.1.2", + "bundled": true, + "optional": true + }, + "jodid25519": { + "version": "1.0.2", + "bundled": true, + "optional": true, + "requires": { + "jsbn": "0.1.1" + } + }, + "jsbn": { + "version": "0.1.1", + "bundled": true, + "optional": true + }, + "json-schema": { + "version": "0.2.3", + "bundled": true, + "optional": true + }, + "json-stable-stringify": { + "version": "1.0.1", + "bundled": true, + "optional": true, + "requires": { + "jsonify": "0.0.0" + } + }, + "json-stringify-safe": { + "version": "5.0.1", + "bundled": true, + "optional": true + }, + "jsonify": { + "version": "0.0.0", + "bundled": true, + "optional": true + }, + "jsprim": { + "version": "1.4.0", + "bundled": true, + "optional": true, + "requires": { + "assert-plus": "1.0.0", + "extsprintf": "1.0.2", + "json-schema": "0.2.3", + "verror": "1.3.6" + }, + "dependencies": { + "assert-plus": { + "version": "1.0.0", + "bundled": true, + "optional": true + } + } + }, + "mime-db": { + "version": "1.27.0", + "bundled": true + }, + "mime-types": { + "version": "2.1.15", + "bundled": true, + "requires": { + "mime-db": "1.27.0" + } + }, + "minimatch": { + "version": "3.0.4", + "bundled": true, + "requires": { + "brace-expansion": "1.1.7" + } + }, + "minimist": { + "version": "0.0.8", + "bundled": true + }, + "mkdirp": { + "version": "0.5.1", + "bundled": true, + "requires": { + "minimist": "0.0.8" + } + }, + "ms": { + "version": "2.0.0", + "bundled": true, + "optional": true + }, + "node-pre-gyp": { + "version": "0.6.36", + "bundled": true, + "optional": true, + "requires": { + "mkdirp": "0.5.1", + "nopt": "4.0.1", + "npmlog": "4.1.0", + "rc": "1.2.1", + "request": "2.81.0", + "rimraf": "2.6.1", + "semver": "5.3.0", + "tar": "2.2.1", + "tar-pack": "3.4.0" + } + }, + "nopt": { + "version": "4.0.1", + "bundled": true, + "optional": true, + "requires": { + "abbrev": "1.1.0", + "osenv": "0.1.4" + } + }, + "npmlog": { + "version": "4.1.0", + "bundled": true, + "optional": true, + "requires": { + "are-we-there-yet": "1.1.4", + "console-control-strings": "1.1.0", + "gauge": "2.7.4", + "set-blocking": "2.0.0" + } + }, + "number-is-nan": { + "version": "1.0.1", + "bundled": true + }, + "oauth-sign": { + "version": "0.8.2", + "bundled": true, + "optional": true + }, + "object-assign": { + "version": "4.1.1", + "bundled": true, + "optional": true + }, + "once": { + "version": "1.4.0", + "bundled": true, + "requires": { + "wrappy": "1.0.2" + } + }, + "os-homedir": { + "version": "1.0.2", + "bundled": true, + "optional": true + }, + "os-tmpdir": { + "version": "1.0.2", + "bundled": true, + "optional": true + }, + "osenv": { + "version": "0.1.4", + "bundled": true, + "optional": true, + "requires": { + "os-homedir": "1.0.2", + "os-tmpdir": "1.0.2" + } + }, + "path-is-absolute": { + "version": "1.0.1", + "bundled": true + }, + "performance-now": { + "version": "0.2.0", + "bundled": true, + "optional": true + }, + "process-nextick-args": { + "version": "1.0.7", + "bundled": true + }, + "punycode": { + "version": "1.4.1", + "bundled": true, + "optional": true + }, + "qs": { + "version": "6.4.0", + "bundled": true, + "optional": true + }, + "rc": { + "version": "1.2.1", + "bundled": true, + "optional": true, + "requires": { + "deep-extend": "0.4.2", + "ini": "1.3.4", + "minimist": "1.2.0", + "strip-json-comments": "2.0.1" + }, + "dependencies": { + "minimist": { + "version": "1.2.0", + "bundled": true, + "optional": true + } + } + }, + "readable-stream": { + "version": "2.2.9", + "bundled": true, + "requires": { + "buffer-shims": "1.0.0", + "core-util-is": "1.0.2", + "inherits": "2.0.3", + "isarray": "1.0.0", + "process-nextick-args": "1.0.7", + "string_decoder": "1.0.1", + "util-deprecate": "1.0.2" + } + }, + "request": { + "version": "2.81.0", + "bundled": true, + "optional": true, + "requires": { + "aws-sign2": "0.6.0", + "aws4": "1.6.0", + "caseless": "0.12.0", + "combined-stream": "1.0.5", + "extend": "3.0.1", + "forever-agent": "0.6.1", + "form-data": "2.1.4", + "har-validator": "4.2.1", + "hawk": "3.1.3", + "http-signature": "1.1.1", + "is-typedarray": "1.0.0", + "isstream": "0.1.2", + "json-stringify-safe": "5.0.1", + "mime-types": "2.1.15", + "oauth-sign": "0.8.2", + "performance-now": "0.2.0", + "qs": "6.4.0", + "safe-buffer": "5.0.1", + "stringstream": "0.0.5", + "tough-cookie": "2.3.2", + "tunnel-agent": "0.6.0", + "uuid": "3.0.1" + } + }, + "rimraf": { + "version": "2.6.1", + "bundled": true, + "requires": { + "glob": "7.1.2" + } + }, + "safe-buffer": { + "version": "5.0.1", + "bundled": true + }, + "semver": { + "version": "5.3.0", + "bundled": true, + "optional": true + }, + "set-blocking": { + "version": "2.0.0", + "bundled": true, + "optional": true + }, + "signal-exit": { + "version": "3.0.2", + "bundled": true, + "optional": true + }, + "sntp": { + "version": "1.0.9", + "bundled": true, + "optional": true, + "requires": { + "hoek": "2.16.3" + } + }, + "sshpk": { + "version": "1.13.0", + "bundled": true, + "optional": true, + "requires": { + "asn1": "0.2.3", + "assert-plus": "1.0.0", + "bcrypt-pbkdf": "1.0.1", + "dashdash": "1.14.1", + "ecc-jsbn": "0.1.1", + "getpass": "0.1.7", + "jodid25519": "1.0.2", + "jsbn": "0.1.1", + "tweetnacl": "0.14.5" + }, + "dependencies": { + "assert-plus": { + "version": "1.0.0", + "bundled": true, + "optional": true + } + } + }, + "string_decoder": { + "version": "1.0.1", + "bundled": true, + "requires": { + "safe-buffer": "5.0.1" + } + }, + "string-width": { + "version": "1.0.2", + "bundled": true, + "requires": { + "code-point-at": "1.1.0", + "is-fullwidth-code-point": "1.0.0", + "strip-ansi": "3.0.1" + } + }, + "stringstream": { + "version": "0.0.5", + "bundled": true, + "optional": true + }, + "strip-ansi": { + "version": "3.0.1", + "bundled": true, + "requires": { + "ansi-regex": "2.1.1" + } + }, + "strip-json-comments": { + "version": "2.0.1", + "bundled": true, + "optional": true + }, + "tar": { + "version": "2.2.1", + "bundled": true, + "requires": { + "block-stream": "0.0.9", + "fstream": "1.0.11", + "inherits": "2.0.3" + } + }, + "tar-pack": { + "version": "3.4.0", + "bundled": true, + "optional": true, + "requires": { + "debug": "2.6.8", + "fstream": "1.0.11", + "fstream-ignore": "1.0.5", + "once": "1.4.0", + "readable-stream": "2.2.9", + "rimraf": "2.6.1", + "tar": "2.2.1", + "uid-number": "0.0.6" + } + }, + "tough-cookie": { + "version": "2.3.2", + "bundled": true, + "optional": true, + "requires": { + "punycode": "1.4.1" + } + }, + "tunnel-agent": { + "version": "0.6.0", + "bundled": true, + "optional": true, + "requires": { + "safe-buffer": "5.0.1" + } + }, + "tweetnacl": { + "version": "0.14.5", + "bundled": true, + "optional": true + }, + "uid-number": { + "version": "0.0.6", + "bundled": true, + "optional": true + }, + "util-deprecate": { + "version": "1.0.2", + "bundled": true + }, + "uuid": { + "version": "3.0.1", + "bundled": true, + "optional": true + }, + "verror": { + "version": "1.3.6", + "bundled": true, + "optional": true, + "requires": { + "extsprintf": "1.0.2" + } + }, + "wide-align": { + "version": "1.1.2", + "bundled": true, + "optional": true, + "requires": { + "string-width": "1.0.2" + } + }, + "wrappy": { + "version": "1.0.2", + "bundled": true + } + } + }, + "fstream": { + "version": "1.0.11", + "bundled": true, + "requires": { + "graceful-fs": "4.1.11", + "inherits": "2.0.3", + "mkdirp": "0.5.1", + "rimraf": "2.6.1" + } + }, + "gauge": { + "version": "2.7.4", + "bundled": true, + "requires": { + "aproba": "1.1.2", + "console-control-strings": "1.1.0", + "has-unicode": "2.0.1", + "object-assign": "4.1.1", + "signal-exit": "3.0.2", + "string-width": "1.0.2", + "strip-ansi": "3.0.1", + "wide-align": "1.1.2" + } + }, + "gaze": { + "version": "1.1.2", + "bundled": true, + "requires": { + "globule": "1.2.0" + } + }, + "get-caller-file": { + "version": "1.0.2", + "bundled": true + }, + "get-stdin": { + "version": "4.0.1", + "bundled": true + }, + "get-stream": { + "version": "3.0.0", + "bundled": true + }, + "getpass": { + "version": "0.1.7", + "bundled": true, + "requires": { + "assert-plus": "1.0.0" + }, + "dependencies": { + "assert-plus": { + "version": "1.0.0", + "bundled": true + } + } + }, + "glob": { + "version": "7.1.2", + "bundled": true, + "requires": { + "fs.realpath": "1.0.0", + "inflight": "1.0.6", + "inherits": "2.0.3", + "minimatch": "3.0.4", + "once": "1.4.0", + "path-is-absolute": "1.0.1" + } + }, + "glob-base": { + "version": "0.3.0", + "bundled": true, + "requires": { + "glob-parent": "2.0.0", + "is-glob": "2.0.1" + } + }, + "glob-parent": { + "version": "2.0.0", + "bundled": true, + "requires": { + "is-glob": "2.0.1" + } + }, + "globals": { + "version": "9.18.0", + "bundled": true + }, + "globby": { + "version": "5.0.0", + "bundled": true, + "requires": { + "array-union": "1.0.2", + "arrify": "1.0.1", + "glob": "7.1.2", + "object-assign": "4.1.1", + "pify": "2.3.0", + "pinkie-promise": "2.0.1" + } + }, + "globule": { + "version": "1.2.0", + "bundled": true, + "requires": { + "glob": "7.1.2", + "lodash": "4.17.4", + "minimatch": "3.0.4" + } + }, + "google-closure-compiler": { + "version": "20170218.0.0", + "bundled": true, + "requires": { + "chalk": "1.1.3", + "vinyl": "1.2.0", + "vinyl-sourcemaps-apply": "0.2.1" + } + }, + "got": { + "version": "6.7.1", + "bundled": true, + "requires": { + "create-error-class": "3.0.2", + "duplexer3": "0.1.4", + "get-stream": "3.0.0", + "is-redirect": "1.0.0", + "is-retry-allowed": "1.1.0", + "is-stream": "1.1.0", + "lowercase-keys": "1.0.0", + "safe-buffer": "5.1.1", + "timed-out": "4.0.1", + "unzip-response": "2.0.1", + "url-parse-lax": "1.0.0" + } + }, + "graceful-fs": { + "version": "4.1.11", + "bundled": true + }, + "graceful-readlink": { + "version": "1.0.1", + "bundled": true + }, + "growly": { + "version": "1.3.0", + "bundled": true + }, + "handlebars": { + "version": "4.0.10", + "bundled": true, + "requires": { + "async": "1.5.2", + "optimist": "0.6.1", + "source-map": "0.4.4" + }, + "dependencies": { + "async": { + "version": "1.5.2", + "bundled": true + }, + "source-map": { + "version": "0.4.4", + "bundled": true, + "requires": { + "amdefine": "1.0.1" + } + } + } + }, + "har-schema": { + "version": "1.0.5", + "bundled": true + }, + "har-validator": { + "version": "4.2.1", + "bundled": true, + "requires": { + "ajv": "4.11.8", + "har-schema": "1.0.5" + } + }, + "has-ansi": { + "version": "2.0.0", + "bundled": true, + "requires": { + "ansi-regex": "2.1.1" + } + }, + "has-flag": { + "version": "1.0.0", + "bundled": true + }, + "has-unicode": { + "version": "2.0.1", + "bundled": true + }, + "has-yarn": { + "version": "1.0.0", + "bundled": true + }, + "hawk": { + "version": "3.1.3", + "bundled": true, + "requires": { + "boom": "2.10.1", + "cryptiles": "2.0.5", + "hoek": "2.16.3", + "sntp": "1.0.9" + } + }, + "hoek": { + "version": "2.16.3", + "bundled": true + }, + "home-or-tmp": { + "version": "2.0.0", + "bundled": true, + "requires": { + "os-homedir": "1.0.2", + "os-tmpdir": "1.0.2" + } + }, + "hosted-git-info": { + "version": "2.5.0", + "bundled": true + }, + "html-encoding-sniffer": { + "version": "1.0.1", + "bundled": true, + "requires": { + "whatwg-encoding": "1.0.1" + } + }, + "http-signature": { + "version": "1.1.1", + "bundled": true, + "requires": { + "assert-plus": "0.2.0", + "jsprim": "1.4.0", + "sshpk": "1.13.1" + } + }, + "iconv-lite": { + "version": "0.4.13", + "bundled": true + }, + "import-lazy": { + "version": "2.1.0", + "bundled": true + }, + "imurmurhash": { + "version": "0.1.4", + "bundled": true + }, + "in-publish": { + "version": "2.0.0", + "bundled": true + }, + "indent-string": { + "version": "2.1.0", + "bundled": true, + "requires": { + "repeating": "2.0.1" + } + }, + "inflight": { + "version": "1.0.6", + "bundled": true, + "requires": { + "once": "1.4.0", + "wrappy": "1.0.2" + } + }, + "inherits": { + "version": "2.0.3", + "bundled": true + }, + "ini": { + "version": "1.3.4", + "bundled": true + }, + "inquirer": { + "version": "3.1.1", + "bundled": true, + "requires": { + "ansi-escapes": "2.0.0", + "chalk": "1.1.3", + "cli-cursor": "2.1.0", + "cli-width": "2.1.0", + "external-editor": "2.0.4", + "figures": "2.0.0", + "lodash": "4.17.4", + "mute-stream": "0.0.7", + "run-async": "2.3.0", + "rx-lite": "4.0.8", + "rx-lite-aggregates": "4.0.8", + "string-width": "2.1.0", + "strip-ansi": "3.0.1", + "through": "2.3.8" + }, + "dependencies": { + "ansi-escapes": { + "version": "2.0.0", + "bundled": true + }, + "ansi-regex": { + "version": "3.0.0", + "bundled": true + }, + "is-fullwidth-code-point": { + "version": "2.0.0", + "bundled": true + }, + "string-width": { + "version": "2.1.0", + "bundled": true, + "requires": { + "is-fullwidth-code-point": "2.0.0", + "strip-ansi": "4.0.0" + }, + "dependencies": { + "strip-ansi": { + "version": "4.0.0", + "bundled": true, + "requires": { + "ansi-regex": "3.0.0" + } + } + } + } + } + }, + "invariant": { + "version": "2.2.2", + "bundled": true, + "requires": { + "loose-envify": "1.3.1" + } + }, + "invert-kv": { + "version": "1.0.0", + "bundled": true + }, + "is-arrayish": { + "version": "0.2.1", + "bundled": true + }, + "is-binary-path": { + "version": "1.0.1", + "bundled": true, + "requires": { + "binary-extensions": "1.8.0" + } + }, + "is-buffer": { + "version": "1.1.5", + "bundled": true + }, + "is-builtin-module": { + "version": "1.0.0", + "bundled": true, + "requires": { + "builtin-modules": "1.1.1" + } + }, + "is-ci": { + "version": "1.0.10", + "bundled": true, + "requires": { + "ci-info": "1.0.0" + } + }, + "is-dotfile": { + "version": "1.0.3", + "bundled": true + }, + "is-equal-shallow": { + "version": "0.1.3", + "bundled": true, + "requires": { + "is-primitive": "2.0.0" + } + }, + "is-extendable": { + "version": "0.1.1", + "bundled": true + }, + "is-extglob": { + "version": "1.0.0", + "bundled": true + }, + "is-finite": { + "version": "1.0.2", + "bundled": true, + "requires": { + "number-is-nan": "1.0.1" + } + }, + "is-fullwidth-code-point": { + "version": "1.0.0", + "bundled": true, + "requires": { + "number-is-nan": "1.0.1" + } + }, + "is-glob": { + "version": "2.0.1", + "bundled": true, + "requires": { + "is-extglob": "1.0.0" + } + }, + "is-module": { + "version": "1.0.0", + "bundled": true + }, + "is-npm": { + "version": "1.0.0", + "bundled": true + }, + "is-number": { + "version": "2.1.0", + "bundled": true, + "requires": { + "kind-of": "3.2.2" + } + }, + "is-obj": { + "version": "1.0.1", + "bundled": true + }, + "is-path-cwd": { + "version": "1.0.0", + "bundled": true + }, + "is-path-in-cwd": { + "version": "1.0.0", + "bundled": true, + "requires": { + "is-path-inside": "1.0.0" + } + }, + "is-path-inside": { + "version": "1.0.0", + "bundled": true, + "requires": { + "path-is-inside": "1.0.2" + } + }, + "is-posix-bracket": { + "version": "0.1.1", + "bundled": true + }, + "is-primitive": { + "version": "2.0.0", + "bundled": true + }, + "is-promise": { + "version": "2.1.0", + "bundled": true + }, + "is-redirect": { + "version": "1.0.0", + "bundled": true + }, + "is-retry-allowed": { + "version": "1.1.0", + "bundled": true + }, + "is-stream": { + "version": "1.1.0", + "bundled": true + }, + "is-typedarray": { + "version": "1.0.0", + "bundled": true + }, + "is-utf8": { + "version": "0.2.1", + "bundled": true + }, + "isarray": { + "version": "1.0.0", + "bundled": true + }, + "isexe": { + "version": "2.0.0", + "bundled": true + }, + "isobject": { + "version": "2.1.0", + "bundled": true, + "requires": { + "isarray": "1.0.0" + } + }, + "isstream": { + "version": "0.1.2", + "bundled": true + }, + "istanbul-api": { + "version": "1.1.10", + "bundled": true, + "requires": { + "async": "2.5.0", + "fileset": "2.0.3", + "istanbul-lib-coverage": "1.1.1", + "istanbul-lib-hook": "1.0.7", + "istanbul-lib-instrument": "1.7.3", + "istanbul-lib-report": "1.1.1", + "istanbul-lib-source-maps": "1.2.1", + "istanbul-reports": "1.1.1", + "js-yaml": "3.8.4", + "mkdirp": "0.5.1", + "once": "1.4.0" + } + }, + "istanbul-lib-coverage": { + "version": "1.1.1", + "bundled": true + }, + "istanbul-lib-hook": { + "version": "1.0.7", + "bundled": true, + "requires": { + "append-transform": "0.4.0" + } + }, + "istanbul-lib-instrument": { + "version": "1.7.3", + "bundled": true, + "requires": { + "babel-generator": "6.25.0", + "babel-template": "6.25.0", + "babel-traverse": "6.25.0", + "babel-types": "6.25.0", + "babylon": "6.17.4", + "istanbul-lib-coverage": "1.1.1", + "semver": "5.3.0" + } + }, + "istanbul-lib-report": { + "version": "1.1.1", + "bundled": true, + "requires": { + "istanbul-lib-coverage": "1.1.1", + "mkdirp": "0.5.1", + "path-parse": "1.0.5", + "supports-color": "3.2.3" + }, + "dependencies": { + "supports-color": { + "version": "3.2.3", + "bundled": true, + "requires": { + "has-flag": "1.0.0" + } + } + } + }, + "istanbul-lib-source-maps": { + "version": "1.2.1", + "bundled": true, + "requires": { + "debug": "2.6.8", + "istanbul-lib-coverage": "1.1.1", + "mkdirp": "0.5.1", + "rimraf": "2.6.1", + "source-map": "0.5.6" + } + }, + "istanbul-reports": { + "version": "1.1.1", + "bundled": true, + "requires": { + "handlebars": "4.0.10" + } + }, + "jest": { + "version": "19.0.2", + "bundled": true, + "requires": { + "jest-cli": "19.0.2" + }, + "dependencies": { + "jest-cli": { + "version": "19.0.2", + "bundled": true, + "requires": { + "ansi-escapes": "1.4.0", + "callsites": "2.0.0", + "chalk": "1.1.3", + "graceful-fs": "4.1.11", + "is-ci": "1.0.10", + "istanbul-api": "1.1.10", + "istanbul-lib-coverage": "1.1.1", + "istanbul-lib-instrument": "1.7.3", + "jest-changed-files": "19.0.2", + "jest-config": "19.0.4", + "jest-environment-jsdom": "19.0.2", + "jest-haste-map": "19.0.2", + "jest-jasmine2": "19.0.2", + "jest-message-util": "19.0.0", + "jest-regex-util": "19.0.0", + "jest-resolve-dependencies": "19.0.0", + "jest-runtime": "19.0.4", + "jest-snapshot": "19.0.2", + "jest-util": "19.0.2", + "micromatch": "2.3.11", + "node-notifier": "5.1.2", + "slash": "1.0.0", + "string-length": "1.0.1", + "throat": "3.2.0", + "which": "1.2.14", + "worker-farm": "1.3.1", + "yargs": "6.6.0" + } + } + } + }, + "jest-changed-files": { + "version": "19.0.2", + "bundled": true + }, + "jest-config": { + "version": "19.0.4", + "bundled": true, + "requires": { + "chalk": "1.1.3", + "jest-environment-jsdom": "19.0.2", + "jest-environment-node": "19.0.2", + "jest-jasmine2": "19.0.2", + "jest-regex-util": "19.0.0", + "jest-resolve": "19.0.2", + "jest-validate": "19.0.2", + "pretty-format": "19.0.0" + } + }, + "jest-diff": { + "version": "19.0.0", + "bundled": true, + "requires": { + "chalk": "1.1.3", + "diff": "3.2.0", + "jest-matcher-utils": "19.0.0", + "pretty-format": "19.0.0" + } + }, + "jest-environment-jsdom": { + "version": "19.0.2", + "bundled": true, + "requires": { + "jest-mock": "19.0.0", + "jest-util": "19.0.2", + "jsdom": "9.12.0" + }, + "dependencies": { + "jsdom": { + "version": "9.12.0", + "bundled": true, + "requires": { + "abab": "1.0.3", + "acorn": "4.0.13", + "acorn-globals": "3.1.0", + "array-equal": "1.0.0", + "content-type-parser": "1.0.1", + "cssom": "0.3.2", + "cssstyle": "0.2.37", + "escodegen": "1.8.1", + "html-encoding-sniffer": "1.0.1", + "nwmatcher": "1.4.1", + "parse5": "1.5.1", + "request": "2.81.0", + "sax": "1.2.4", + "symbol-tree": "3.2.2", + "tough-cookie": "2.3.2", + "webidl-conversions": "4.0.1", + "whatwg-encoding": "1.0.1", + "whatwg-url": "4.8.0", + "xml-name-validator": "2.0.1" + } + }, + "parse5": { + "version": "1.5.1", + "bundled": true + } + } + }, + "jest-environment-node": { + "version": "19.0.2", + "bundled": true, + "requires": { + "jest-mock": "19.0.0", + "jest-util": "19.0.2" + } + }, + "jest-file-exists": { + "version": "19.0.0", + "bundled": true + }, + "jest-haste-map": { + "version": "19.0.2", + "bundled": true, + "requires": { + "fb-watchman": "2.0.0", + "graceful-fs": "4.1.11", + "micromatch": "2.3.11", + "sane": "1.5.0", + "worker-farm": "1.3.1" + } + }, + "jest-jasmine2": { + "version": "19.0.2", + "bundled": true, + "requires": { + "graceful-fs": "4.1.11", + "jest-matcher-utils": "19.0.0", + "jest-matchers": "19.0.0", + "jest-message-util": "19.0.0", + "jest-snapshot": "19.0.2" + } + }, + "jest-matcher-utils": { + "version": "19.0.0", + "bundled": true, + "requires": { + "chalk": "1.1.3", + "pretty-format": "19.0.0" + } + }, + "jest-matchers": { + "version": "19.0.0", + "bundled": true, + "requires": { + "jest-diff": "19.0.0", + "jest-matcher-utils": "19.0.0", + "jest-message-util": "19.0.0", + "jest-regex-util": "19.0.0" + } + }, + "jest-message-util": { + "version": "19.0.0", + "bundled": true, + "requires": { + "chalk": "1.1.3", + "micromatch": "2.3.11" + } + }, + "jest-mock": { + "version": "19.0.0", + "bundled": true + }, + "jest-regex-util": { + "version": "19.0.0", + "bundled": true + }, + "jest-resolve": { + "version": "19.0.2", + "bundled": true, + "requires": { + "browser-resolve": "1.11.2", + "jest-haste-map": "19.0.2", + "resolve": "1.3.3" + } + }, + "jest-resolve-dependencies": { + "version": "19.0.0", + "bundled": true, + "requires": { + "jest-file-exists": "19.0.0" + } + }, + "jest-runtime": { + "version": "19.0.4", + "bundled": true, + "requires": { + "babel-core": "6.25.0", + "babel-jest": "19.0.0", + "babel-plugin-istanbul": "4.1.4", + "chalk": "1.1.3", + "graceful-fs": "4.1.11", + "jest-config": "19.0.4", + "jest-file-exists": "19.0.0", + "jest-haste-map": "19.0.2", + "jest-regex-util": "19.0.0", + "jest-resolve": "19.0.2", + "jest-util": "19.0.2", + "json-stable-stringify": "1.0.1", + "micromatch": "2.3.11", + "strip-bom": "3.0.0", + "yargs": "6.6.0" + }, + "dependencies": { + "strip-bom": { + "version": "3.0.0", + "bundled": true + } + } + }, + "jest-snapshot": { + "version": "19.0.2", + "bundled": true, + "requires": { + "chalk": "1.1.3", + "jest-diff": "19.0.0", + "jest-file-exists": "19.0.0", + "jest-matcher-utils": "19.0.0", + "jest-util": "19.0.2", + "natural-compare": "1.4.0", + "pretty-format": "19.0.0" + } + }, + "jest-util": { + "version": "19.0.2", + "bundled": true, + "requires": { + "chalk": "1.1.3", + "graceful-fs": "4.1.11", + "jest-file-exists": "19.0.0", + "jest-message-util": "19.0.0", + "jest-mock": "19.0.0", + "jest-validate": "19.0.2", + "leven": "2.1.0", + "mkdirp": "0.5.1" + } + }, + "jest-validate": { + "version": "19.0.2", + "bundled": true, + "requires": { + "chalk": "1.1.3", + "jest-matcher-utils": "19.0.0", + "leven": "2.1.0", + "pretty-format": "19.0.0" + } + }, + "js-base64": { + "version": "2.1.9", + "bundled": true + }, + "js-tokens": { + "version": "3.0.1", + "bundled": true + }, + "js-yaml": { + "version": "3.8.4", + "bundled": true, + "requires": { + "argparse": "1.0.9", + "esprima": "3.1.3" + } + }, + "jsbn": { + "version": "0.1.1", + "bundled": true, + "optional": true + }, + "jschardet": { + "version": "1.4.2", + "bundled": true + }, + "jsdom": { + "version": "11.0.0", + "bundled": true, + "requires": { + "abab": "1.0.3", + "acorn": "4.0.13", + "acorn-globals": "3.1.0", + "array-equal": "1.0.0", + "content-type-parser": "1.0.1", + "cssom": "0.3.2", + "cssstyle": "0.2.37", + "escodegen": "1.8.1", + "html-encoding-sniffer": "1.0.1", + "nwmatcher": "1.4.1", + "parse5": "3.0.2", + "pn": "1.0.0", + "request": "2.81.0", + "request-promise-native": "1.0.4", + "sax": "1.2.4", + "symbol-tree": "3.2.2", + "tough-cookie": "2.3.2", + "webidl-conversions": "4.0.1", + "whatwg-encoding": "1.0.1", + "whatwg-url": "4.8.0", + "xml-name-validator": "2.0.1" + } + }, + "jsesc": { + "version": "1.3.0", + "bundled": true + }, + "json-schema": { + "version": "0.2.3", + "bundled": true + }, + "json-stable-stringify": { + "version": "1.0.1", + "bundled": true, + "requires": { + "jsonify": "0.0.0" + } + }, + "json-stringify-safe": { + "version": "5.0.1", + "bundled": true + }, + "json5": { + "version": "0.5.1", + "bundled": true + }, + "jsonfile": { + "version": "2.4.0", + "bundled": true, + "requires": { + "graceful-fs": "4.1.11" + } + }, + "jsonify": { + "version": "0.0.0", + "bundled": true + }, + "jsprim": { + "version": "1.4.0", + "bundled": true, + "requires": { + "assert-plus": "1.0.0", + "extsprintf": "1.0.2", + "json-schema": "0.2.3", + "verror": "1.3.6" + }, + "dependencies": { + "assert-plus": { + "version": "1.0.0", + "bundled": true + } + } + }, + "kind-of": { + "version": "3.2.2", + "bundled": true, + "requires": { + "is-buffer": "1.1.5" + } + }, + "knuth-shuffle": { + "version": "1.0.1", + "bundled": true + }, + "latest-version": { + "version": "3.1.0", + "bundled": true, + "requires": { + "package-json": "4.0.1" + } + }, + "lcid": { + "version": "1.0.0", + "bundled": true, + "requires": { + "invert-kv": "1.0.0" + } + }, + "leven": { + "version": "2.1.0", + "bundled": true + }, + "levn": { + "version": "0.3.0", + "bundled": true, + "requires": { + "prelude-ls": "1.1.2", + "type-check": "0.3.2" + } + }, + "listr": { + "version": "0.11.0", + "bundled": true, + "requires": { + "chalk": "1.1.3", + "cli-truncate": "0.2.1", + "figures": "1.7.0", + "indent-string": "2.1.0", + "is-promise": "2.1.0", + "is-stream": "1.1.0", + "listr-silent-renderer": "1.1.1", + "listr-update-renderer": "0.2.0", + "listr-verbose-renderer": "0.4.0", + "log-symbols": "1.0.2", + "log-update": "1.0.2", + "ora": "0.2.3", + "rxjs": "5.4.2", + "stream-to-observable": "0.1.0", + "strip-ansi": "3.0.1" + }, + "dependencies": { + "figures": { + "version": "1.7.0", + "bundled": true, + "requires": { + "escape-string-regexp": "1.0.5", + "object-assign": "4.1.1" + } + }, + "stream-to-observable": { + "version": "0.1.0", + "bundled": true + } + } + }, + "listr-silent-renderer": { + "version": "1.1.1", + "bundled": true + }, + "listr-update-renderer": { + "version": "0.2.0", + "bundled": true, + "requires": { + "chalk": "1.1.3", + "cli-truncate": "0.2.1", + "elegant-spinner": "1.0.1", + "figures": "1.7.0", + "indent-string": "3.1.0", + "log-symbols": "1.0.2", + "log-update": "1.0.2", + "strip-ansi": "3.0.1" + }, + "dependencies": { + "figures": { + "version": "1.7.0", + "bundled": true, + "requires": { + "escape-string-regexp": "1.0.5", + "object-assign": "4.1.1" + } + }, + "indent-string": { + "version": "3.1.0", + "bundled": true + } + } + }, + "listr-verbose-renderer": { + "version": "0.4.0", + "bundled": true, + "requires": { + "chalk": "1.1.3", + "cli-cursor": "1.0.2", + "date-fns": "1.28.5", + "figures": "1.7.0" + }, + "dependencies": { + "cli-cursor": { + "version": "1.0.2", + "bundled": true, + "requires": { + "restore-cursor": "1.0.1" + } + }, + "figures": { + "version": "1.7.0", + "bundled": true, + "requires": { + "escape-string-regexp": "1.0.5", + "object-assign": "4.1.1" + } + }, + "onetime": { + "version": "1.1.0", + "bundled": true + }, + "restore-cursor": { + "version": "1.0.1", + "bundled": true, + "requires": { + "exit-hook": "1.1.1", + "onetime": "1.1.0" + } + } + } + }, + "load-json-file": { + "version": "1.1.0", + "bundled": true, + "requires": { + "graceful-fs": "4.1.11", + "parse-json": "2.2.0", + "pify": "2.3.0", + "pinkie-promise": "2.0.1", + "strip-bom": "2.0.0" + } + }, + "locate-path": { + "version": "2.0.0", + "bundled": true, + "requires": { + "p-locate": "2.0.0", + "path-exists": "3.0.0" + } + }, + "lodash": { + "version": "4.17.4", + "bundled": true + }, + "lodash.assign": { + "version": "4.2.0", + "bundled": true + }, + "lodash.clonedeep": { + "version": "4.5.0", + "bundled": true + }, + "lodash.mergewith": { + "version": "4.6.0", + "bundled": true + }, + "log-symbols": { + "version": "1.0.2", + "bundled": true, + "requires": { + "chalk": "1.1.3" + } + }, + "log-update": { + "version": "1.0.2", + "bundled": true, + "requires": { + "ansi-escapes": "1.4.0", + "cli-cursor": "1.0.2" + }, + "dependencies": { + "cli-cursor": { + "version": "1.0.2", + "bundled": true, + "requires": { + "restore-cursor": "1.0.1" + } + }, + "onetime": { + "version": "1.1.0", + "bundled": true + }, + "restore-cursor": { + "version": "1.0.1", + "bundled": true, + "requires": { + "exit-hook": "1.1.1", + "onetime": "1.1.0" + } + } + } + }, + "loose-envify": { + "version": "1.3.1", + "bundled": true, + "requires": { + "js-tokens": "3.0.1" + } + }, + "loud-rejection": { + "version": "1.6.0", + "bundled": true, + "requires": { + "currently-unhandled": "0.4.1", + "signal-exit": "3.0.2" + } + }, + "lowercase-keys": { + "version": "1.0.0", + "bundled": true + }, + "lru-cache": { + "version": "4.1.1", + "bundled": true, + "requires": { + "pseudomap": "1.0.2", + "yallist": "2.1.2" + } + }, + "magic-string": { + "version": "0.19.1", + "bundled": true, + "requires": { + "vlq": "0.2.2" + } + }, + "make-dir": { + "version": "1.0.0", + "bundled": true, + "requires": { + "pify": "2.3.0" + } + }, + "makeerror": { + "version": "1.0.11", + "bundled": true, + "requires": { + "tmpl": "1.0.4" + } + }, + "map-obj": { + "version": "1.0.1", + "bundled": true + }, + "memory-fs": { + "version": "0.4.1", + "bundled": true, + "requires": { + "errno": "0.1.4", + "readable-stream": "2.3.2" + } + }, + "meow": { + "version": "3.7.0", + "bundled": true, + "requires": { + "camelcase-keys": "2.1.0", + "decamelize": "1.2.0", + "loud-rejection": "1.6.0", + "map-obj": "1.0.1", + "minimist": "1.2.0", + "normalize-package-data": "2.4.0", + "object-assign": "4.1.1", + "read-pkg-up": "1.0.1", + "redent": "1.0.0", + "trim-newlines": "1.0.0" + }, + "dependencies": { + "minimist": { + "version": "1.2.0", + "bundled": true + } + } + }, + "merge": { + "version": "1.2.0", + "bundled": true + }, + "micromatch": { + "version": "2.3.11", + "bundled": true, + "requires": { + "arr-diff": "2.0.0", + "array-unique": "0.2.1", + "braces": "1.8.5", + "expand-brackets": "0.1.5", + "extglob": "0.3.2", + "filename-regex": "2.0.1", + "is-extglob": "1.0.0", + "is-glob": "2.0.1", + "kind-of": "3.2.2", + "normalize-path": "2.1.1", + "object.omit": "2.0.1", + "parse-glob": "3.0.4", + "regex-cache": "0.4.3" + } + }, + "mime-db": { + "version": "1.27.0", + "bundled": true + }, + "mime-types": { + "version": "2.1.15", + "bundled": true, + "requires": { + "mime-db": "1.27.0" + } + }, + "mimic-fn": { + "version": "1.1.0", + "bundled": true + }, + "minimatch": { + "version": "3.0.4", + "bundled": true, + "requires": { + "brace-expansion": "1.1.8" + } + }, + "minimist": { + "version": "0.0.8", + "bundled": true + }, + "mkdirp": { + "version": "0.5.1", + "bundled": true, + "requires": { + "minimist": "0.0.8" + } + }, + "ms": { + "version": "2.0.0", + "bundled": true + }, + "mute-stream": { + "version": "0.0.7", + "bundled": true + }, + "nan": { + "version": "2.6.2", + "bundled": true + }, + "natural-compare": { + "version": "1.4.0", + "bundled": true + }, + "node-fetch": { + "version": "1.7.1", + "bundled": true, + "requires": { + "encoding": "0.1.12", + "is-stream": "1.1.0" + } + }, + "node-gyp": { + "version": "3.6.2", + "bundled": true, + "requires": { + "fstream": "1.0.11", + "glob": "7.1.2", + "graceful-fs": "4.1.11", + "minimatch": "3.0.4", + "mkdirp": "0.5.1", + "nopt": "3.0.6", + "npmlog": "4.1.2", + "osenv": "0.1.4", + "request": "2.81.0", + "rimraf": "2.6.1", + "semver": "5.3.0", + "tar": "2.2.1", + "which": "1.2.14" + } + }, + "node-int64": { + "version": "0.4.0", + "bundled": true + }, + "node-notifier": { + "version": "5.1.2", + "bundled": true, + "requires": { + "growly": "1.3.0", + "semver": "5.3.0", + "shellwords": "0.1.0", + "which": "1.2.14" + } + }, + "node-sass": { + "version": "4.5.3", + "bundled": true, + "requires": { + "async-foreach": "0.1.3", + "chalk": "1.1.3", + "cross-spawn": "3.0.1", + "gaze": "1.1.2", + "get-stdin": "4.0.1", + "glob": "7.1.2", + "in-publish": "2.0.0", + "lodash.assign": "4.2.0", + "lodash.clonedeep": "4.5.0", + "lodash.mergewith": "4.6.0", + "meow": "3.7.0", + "mkdirp": "0.5.1", + "nan": "2.6.2", + "node-gyp": "3.6.2", + "npmlog": "4.1.2", + "request": "2.81.0", + "sass-graph": "2.2.4", + "stdout-stream": "1.4.0" + } + }, + "nopt": { + "version": "3.0.6", + "bundled": true, + "requires": { + "abbrev": "1.1.0" + } + }, + "normalize-package-data": { + "version": "2.4.0", + "bundled": true, + "requires": { + "hosted-git-info": "2.5.0", + "is-builtin-module": "1.0.0", + "semver": "5.3.0", + "validate-npm-package-license": "3.0.1" + } + }, + "normalize-path": { + "version": "2.1.1", + "bundled": true, + "requires": { + "remove-trailing-separator": "1.0.2" + } + }, + "np": { + "version": "2.16.0", + "bundled": true, + "requires": { + "any-observable": "0.2.0", + "chalk": "1.1.3", + "del": "2.2.2", + "execa": "0.6.3", + "has-yarn": "1.0.0", + "inquirer": "3.1.1", + "listr": "0.11.0", + "log-symbols": "1.0.2", + "meow": "3.7.0", + "read-pkg-up": "2.0.0", + "rxjs": "5.4.2", + "semver": "5.3.0", + "split": "1.0.0", + "stream-to-observable": "0.2.0", + "update-notifier": "2.2.0" + }, + "dependencies": { + "load-json-file": { + "version": "2.0.0", + "bundled": true, + "requires": { + "graceful-fs": "4.1.11", + "parse-json": "2.2.0", + "pify": "2.3.0", + "strip-bom": "3.0.0" + } + }, + "path-type": { + "version": "2.0.0", + "bundled": true, + "requires": { + "pify": "2.3.0" + } + }, + "read-pkg": { + "version": "2.0.0", + "bundled": true, + "requires": { + "load-json-file": "2.0.0", + "normalize-package-data": "2.4.0", + "path-type": "2.0.0" + } + }, + "read-pkg-up": { + "version": "2.0.0", + "bundled": true, + "requires": { + "find-up": "2.1.0", + "read-pkg": "2.0.0" + } + }, + "strip-bom": { + "version": "3.0.0", + "bundled": true + } + } + }, + "npm-run-path": { + "version": "2.0.2", + "bundled": true, + "requires": { + "path-key": "2.0.1" + } + }, + "npmlog": { + "version": "4.1.2", + "bundled": true, + "requires": { + "are-we-there-yet": "1.1.4", + "console-control-strings": "1.1.0", + "gauge": "2.7.4", + "set-blocking": "2.0.0" + } + }, + "number-is-nan": { + "version": "1.0.1", + "bundled": true + }, + "nwmatcher": { + "version": "1.4.1", + "bundled": true + }, + "oauth-sign": { + "version": "0.8.2", + "bundled": true + }, + "object-assign": { + "version": "4.1.1", + "bundled": true + }, + "object.omit": { + "version": "2.0.1", + "bundled": true, + "requires": { + "for-own": "0.1.5", + "is-extendable": "0.1.1" + } + }, + "once": { + "version": "1.4.0", + "bundled": true, + "requires": { + "wrappy": "1.0.2" + } + }, + "onetime": { + "version": "2.0.1", + "bundled": true, + "requires": { + "mimic-fn": "1.1.0" + } + }, + "optimist": { + "version": "0.6.1", + "bundled": true, + "requires": { + "minimist": "0.0.8", + "wordwrap": "0.0.3" + } + }, + "optionator": { + "version": "0.8.2", + "bundled": true, + "requires": { + "deep-is": "0.1.3", + "fast-levenshtein": "2.0.6", + "levn": "0.3.0", + "prelude-ls": "1.1.2", + "type-check": "0.3.2", + "wordwrap": "1.0.0" + }, + "dependencies": { + "wordwrap": { + "version": "1.0.0", + "bundled": true + } + } + }, + "ora": { + "version": "0.2.3", + "bundled": true, + "requires": { + "chalk": "1.1.3", + "cli-cursor": "1.0.2", + "cli-spinners": "0.1.2", + "object-assign": "4.1.1" + }, + "dependencies": { + "cli-cursor": { + "version": "1.0.2", + "bundled": true, + "requires": { + "restore-cursor": "1.0.1" + } + }, + "onetime": { + "version": "1.1.0", + "bundled": true + }, + "restore-cursor": { + "version": "1.0.1", + "bundled": true, + "requires": { + "exit-hook": "1.1.1", + "onetime": "1.1.0" + } + } + } + }, + "os-homedir": { + "version": "1.0.2", + "bundled": true + }, + "os-locale": { + "version": "1.4.0", + "bundled": true, + "requires": { + "lcid": "1.0.0" + } + }, + "os-tmpdir": { + "version": "1.0.2", + "bundled": true + }, + "osenv": { + "version": "0.1.4", + "bundled": true, + "requires": { + "os-homedir": "1.0.2", + "os-tmpdir": "1.0.2" + } + }, + "output-file-sync": { + "version": "1.1.2", + "bundled": true, + "requires": { + "graceful-fs": "4.1.11", + "mkdirp": "0.5.1", + "object-assign": "4.1.1" + } + }, + "p-finally": { + "version": "1.0.0", + "bundled": true + }, + "p-limit": { + "version": "1.1.0", + "bundled": true + }, + "p-locate": { + "version": "2.0.0", + "bundled": true, + "requires": { + "p-limit": "1.1.0" + } + }, + "package-json": { + "version": "4.0.1", + "bundled": true, + "requires": { + "got": "6.7.1", + "registry-auth-token": "3.3.1", + "registry-url": "3.1.0", + "semver": "5.3.0" + } + }, + "parse-glob": { + "version": "3.0.4", + "bundled": true, + "requires": { + "glob-base": "0.3.0", + "is-dotfile": "1.0.3", + "is-extglob": "1.0.0", + "is-glob": "2.0.1" + } + }, + "parse-json": { + "version": "2.2.0", + "bundled": true, + "requires": { + "error-ex": "1.3.1" + } + }, + "parse5": { + "version": "3.0.2", + "bundled": true, + "requires": { + "@types/node": "6.0.79" + }, + "dependencies": { + "@types/node": { + "version": "6.0.79", + "bundled": true + } + } + }, + "path-exists": { + "version": "3.0.0", + "bundled": true + }, + "path-is-absolute": { + "version": "1.0.1", + "bundled": true + }, + "path-is-inside": { + "version": "1.0.2", + "bundled": true + }, + "path-key": { + "version": "2.0.1", + "bundled": true + }, + "path-parse": { + "version": "1.0.5", + "bundled": true + }, + "path-type": { + "version": "1.1.0", + "bundled": true, + "requires": { + "graceful-fs": "4.1.11", + "pify": "2.3.0", + "pinkie-promise": "2.0.1" + } + }, + "performance-now": { + "version": "0.2.0", + "bundled": true + }, + "pify": { + "version": "2.3.0", + "bundled": true + }, + "pinkie": { + "version": "2.0.4", + "bundled": true + }, + "pinkie-promise": { + "version": "2.0.1", + "bundled": true, + "requires": { + "pinkie": "2.0.4" + } + }, + "pn": { + "version": "1.0.0", + "bundled": true + }, + "prelude-ls": { + "version": "1.1.2", + "bundled": true + }, + "prepend-http": { + "version": "1.0.4", + "bundled": true + }, + "preserve": { + "version": "0.2.0", + "bundled": true + }, + "pretty-format": { + "version": "19.0.0", + "bundled": true, + "requires": { + "ansi-styles": "3.1.0" + }, + "dependencies": { + "ansi-styles": { + "version": "3.1.0", + "bundled": true, + "requires": { + "color-convert": "1.9.0" + } + } + } + }, + "private": { + "version": "0.1.7", + "bundled": true + }, + "process-nextick-args": { + "version": "1.0.7", + "bundled": true + }, + "prr": { + "version": "0.0.0", + "bundled": true + }, + "pseudomap": { + "version": "1.0.2", + "bundled": true + }, + "punycode": { + "version": "1.4.1", + "bundled": true + }, + "qs": { + "version": "6.4.0", + "bundled": true + }, + "randomatic": { + "version": "1.1.7", + "bundled": true, + "requires": { + "is-number": "3.0.0", + "kind-of": "4.0.0" + }, + "dependencies": { + "is-number": { + "version": "3.0.0", + "bundled": true, + "requires": { + "kind-of": "3.2.2" + }, + "dependencies": { + "kind-of": { + "version": "3.2.2", + "bundled": true, + "requires": { + "is-buffer": "1.1.5" + } + } + } + }, + "kind-of": { + "version": "4.0.0", + "bundled": true, + "requires": { + "is-buffer": "1.1.5" + } + } + } + }, + "rc": { + "version": "1.2.1", + "bundled": true, + "requires": { + "deep-extend": "0.4.2", + "ini": "1.3.4", + "minimist": "1.2.0", + "strip-json-comments": "2.0.1" + }, + "dependencies": { + "minimist": { + "version": "1.2.0", + "bundled": true + } + } + }, + "read-pkg": { + "version": "1.1.0", + "bundled": true, + "requires": { + "load-json-file": "1.1.0", + "normalize-package-data": "2.4.0", + "path-type": "1.1.0" + } + }, + "read-pkg-up": { + "version": "1.0.1", + "bundled": true, + "requires": { + "find-up": "1.1.2", + "read-pkg": "1.1.0" + }, + "dependencies": { + "find-up": { + "version": "1.1.2", + "bundled": true, + "requires": { + "path-exists": "2.1.0", + "pinkie-promise": "2.0.1" + } + }, + "path-exists": { + "version": "2.1.0", + "bundled": true, + "requires": { + "pinkie-promise": "2.0.1" + } + } + } + }, + "readable-stream": { + "version": "2.3.2", + "bundled": true, + "requires": { + "core-util-is": "1.0.2", + "inherits": "2.0.3", + "isarray": "1.0.0", + "process-nextick-args": "1.0.7", + "safe-buffer": "5.1.1", + "string_decoder": "1.0.3", + "util-deprecate": "1.0.2" + } + }, + "readdirp": { + "version": "2.1.0", + "bundled": true, + "requires": { + "graceful-fs": "4.1.11", + "minimatch": "3.0.4", + "readable-stream": "2.3.2", + "set-immediate-shim": "1.0.1" + } + }, + "redent": { + "version": "1.0.0", + "bundled": true, + "requires": { + "indent-string": "2.1.0", + "strip-indent": "1.0.1" + } + }, + "regenerator-runtime": { + "version": "0.10.5", + "bundled": true + }, + "regex-cache": { + "version": "0.4.3", + "bundled": true, + "requires": { + "is-equal-shallow": "0.1.3", + "is-primitive": "2.0.0" + } + }, + "registry-auth-token": { + "version": "3.3.1", + "bundled": true, + "requires": { + "rc": "1.2.1", + "safe-buffer": "5.1.1" + } + }, + "registry-url": { + "version": "3.1.0", + "bundled": true, + "requires": { + "rc": "1.2.1" + } + }, + "remove-trailing-separator": { + "version": "1.0.2", + "bundled": true + }, + "repeat-element": { + "version": "1.1.2", + "bundled": true + }, + "repeat-string": { + "version": "1.6.1", + "bundled": true + }, + "repeating": { + "version": "2.0.1", + "bundled": true, + "requires": { + "is-finite": "1.0.2" + } + }, + "replace-ext": { + "version": "0.0.1", + "bundled": true + }, + "request": { + "version": "2.81.0", + "bundled": true, + "requires": { + "aws-sign2": "0.6.0", + "aws4": "1.6.0", + "caseless": "0.12.0", + "combined-stream": "1.0.5", + "extend": "3.0.1", + "forever-agent": "0.6.1", + "form-data": "2.1.4", + "har-validator": "4.2.1", + "hawk": "3.1.3", + "http-signature": "1.1.1", + "is-typedarray": "1.0.0", + "isstream": "0.1.2", + "json-stringify-safe": "5.0.1", + "mime-types": "2.1.15", + "oauth-sign": "0.8.2", + "performance-now": "0.2.0", + "qs": "6.4.0", + "safe-buffer": "5.1.1", + "stringstream": "0.0.5", + "tough-cookie": "2.3.2", + "tunnel-agent": "0.6.0", + "uuid": "3.1.0" + } + }, + "request-promise-core": { + "version": "1.1.1", + "bundled": true, + "requires": { + "lodash": "4.17.4" + } + }, + "request-promise-native": { + "version": "1.0.4", + "bundled": true, + "requires": { + "request-promise-core": "1.1.1", + "stealthy-require": "1.1.1", + "tough-cookie": "2.3.2" + } + }, + "require-directory": { + "version": "2.1.1", + "bundled": true + }, + "require-main-filename": { + "version": "1.0.1", + "bundled": true + }, + "resolve": { + "version": "1.3.3", + "bundled": true, + "requires": { + "path-parse": "1.0.5" + } + }, + "restore-cursor": { + "version": "2.0.0", + "bundled": true, + "requires": { + "onetime": "2.0.1", + "signal-exit": "3.0.2" + } + }, + "rimraf": { + "version": "2.6.1", + "bundled": true, + "requires": { + "glob": "7.1.2" + } + }, + "rollup": { + "version": "0.41.4", + "bundled": true, + "requires": { + "source-map-support": "0.4.15" + } + }, + "rollup-plugin-commonjs": { + "version": "8.0.2", + "bundled": true, + "requires": { + "acorn": "4.0.13", + "estree-walker": "0.3.1", + "magic-string": "0.19.1", + "resolve": "1.3.3", + "rollup-pluginutils": "2.0.1" + } + }, + "rollup-plugin-node-resolve": { + "version": "3.0.0", + "bundled": true, + "requires": { + "browser-resolve": "1.11.2", + "builtin-modules": "1.1.1", + "is-module": "1.0.0", + "resolve": "1.3.3" + } + }, + "rollup-pluginutils": { + "version": "2.0.1", + "bundled": true, + "requires": { + "estree-walker": "0.3.1", + "micromatch": "2.3.11" + } + }, + "run-async": { + "version": "2.3.0", + "bundled": true, + "requires": { + "is-promise": "2.1.0" + } + }, + "rx-lite": { + "version": "4.0.8", + "bundled": true + }, + "rx-lite-aggregates": { + "version": "4.0.8", + "bundled": true, + "requires": { + "rx-lite": "4.0.8" + } + }, + "rxjs": { + "version": "5.4.2", + "bundled": true, + "requires": { + "symbol-observable": "1.0.4" + } + }, + "safe-buffer": { + "version": "5.1.1", + "bundled": true + }, + "sane": { + "version": "1.5.0", + "bundled": true, + "requires": { + "anymatch": "1.3.0", + "exec-sh": "0.2.0", + "fb-watchman": "1.9.2", + "minimatch": "3.0.4", + "minimist": "1.2.0", + "walker": "1.0.7", + "watch": "0.10.0" + }, + "dependencies": { + "bser": { + "version": "1.0.2", + "bundled": true, + "requires": { + "node-int64": "0.4.0" + } + }, + "fb-watchman": { + "version": "1.9.2", + "bundled": true, + "requires": { + "bser": "1.0.2" + } + }, + "minimist": { + "version": "1.2.0", + "bundled": true + } + } + }, + "sass-graph": { + "version": "2.2.4", + "bundled": true, + "requires": { + "glob": "7.1.2", + "lodash": "4.17.4", + "scss-tokenizer": "0.2.3", + "yargs": "7.1.0" + }, + "dependencies": { + "camelcase": { + "version": "3.0.0", + "bundled": true + }, + "cliui": { + "version": "3.2.0", + "bundled": true, + "requires": { + "string-width": "1.0.2", + "strip-ansi": "3.0.1", + "wrap-ansi": "2.1.0" + } + }, + "yargs": { + "version": "7.1.0", + "bundled": true, + "requires": { + "camelcase": "3.0.0", + "cliui": "3.2.0", + "decamelize": "1.2.0", + "get-caller-file": "1.0.2", + "os-locale": "1.4.0", + "read-pkg-up": "1.0.1", + "require-directory": "2.1.1", + "require-main-filename": "1.0.1", + "set-blocking": "2.0.0", + "string-width": "1.0.2", + "which-module": "1.0.0", + "y18n": "3.2.1", + "yargs-parser": "5.0.0" + } + }, + "yargs-parser": { + "version": "5.0.0", + "bundled": true, + "requires": { + "camelcase": "3.0.0" + } + } + } + }, + "sax": { + "version": "1.2.4", + "bundled": true + }, + "scss-tokenizer": { + "version": "0.2.3", + "bundled": true, + "requires": { + "js-base64": "2.1.9", + "source-map": "0.4.4" + }, + "dependencies": { + "source-map": { + "version": "0.4.4", + "bundled": true, + "requires": { + "amdefine": "1.0.1" + } + } + } + }, + "semver": { + "version": "5.3.0", + "bundled": true + }, + "semver-diff": { + "version": "2.1.0", + "bundled": true, + "requires": { + "semver": "5.3.0" + } + }, + "set-blocking": { + "version": "2.0.0", + "bundled": true + }, + "set-immediate-shim": { + "version": "1.0.1", + "bundled": true + }, + "shebang-command": { + "version": "1.2.0", + "bundled": true, + "requires": { + "shebang-regex": "1.0.0" + } + }, + "shebang-regex": { + "version": "1.0.0", + "bundled": true + }, + "shellwords": { + "version": "0.1.0", + "bundled": true + }, + "signal-exit": { + "version": "3.0.2", + "bundled": true + }, + "slash": { + "version": "1.0.0", + "bundled": true + }, + "slice-ansi": { + "version": "0.0.4", + "bundled": true + }, + "slide": { + "version": "1.1.6", + "bundled": true + }, + "sntp": { + "version": "1.0.9", + "bundled": true, + "requires": { + "hoek": "2.16.3" + } + }, + "source-map": { + "version": "0.5.6", + "bundled": true + }, + "source-map-support": { + "version": "0.4.15", + "bundled": true, + "requires": { + "source-map": "0.5.6" + } + }, + "spdx-correct": { + "version": "1.0.2", + "bundled": true, + "requires": { + "spdx-license-ids": "1.2.2" + } + }, + "spdx-expression-parse": { + "version": "1.0.4", + "bundled": true + }, + "spdx-license-ids": { + "version": "1.2.2", + "bundled": true + }, + "split": { + "version": "1.0.0", + "bundled": true, + "requires": { + "through": "2.3.8" + } + }, + "sprintf-js": { + "version": "1.0.3", + "bundled": true + }, + "sshpk": { + "version": "1.13.1", + "bundled": true, + "requires": { + "asn1": "0.2.3", + "assert-plus": "1.0.0", + "bcrypt-pbkdf": "1.0.1", + "dashdash": "1.14.1", + "ecc-jsbn": "0.1.1", + "getpass": "0.1.7", + "jsbn": "0.1.1", + "tweetnacl": "0.14.5" + }, + "dependencies": { + "assert-plus": { + "version": "1.0.0", + "bundled": true + } + } + }, + "stdout-stream": { + "version": "1.4.0", + "bundled": true, + "requires": { + "readable-stream": "2.3.2" + } + }, + "stealthy-require": { + "version": "1.1.1", + "bundled": true + }, + "stream-to-observable": { + "version": "0.2.0", + "bundled": true, + "requires": { + "any-observable": "0.2.0" + } + }, + "string_decoder": { + "version": "1.0.3", + "bundled": true, + "requires": { + "safe-buffer": "5.1.1" + } + }, + "string-length": { + "version": "1.0.1", + "bundled": true, + "requires": { + "strip-ansi": "3.0.1" + } + }, + "string-width": { + "version": "1.0.2", + "bundled": true, + "requires": { + "code-point-at": "1.1.0", + "is-fullwidth-code-point": "1.0.0", + "strip-ansi": "3.0.1" + } + }, + "stringstream": { + "version": "0.0.5", + "bundled": true + }, + "strip-ansi": { + "version": "3.0.1", + "bundled": true, + "requires": { + "ansi-regex": "2.1.1" + } + }, + "strip-bom": { + "version": "2.0.0", + "bundled": true, + "requires": { + "is-utf8": "0.2.1" + } + }, + "strip-eof": { + "version": "1.0.0", + "bundled": true + }, + "strip-indent": { + "version": "1.0.1", + "bundled": true, + "requires": { + "get-stdin": "4.0.1" + } + }, + "strip-json-comments": { + "version": "2.0.1", + "bundled": true + }, + "supports-color": { + "version": "2.0.0", + "bundled": true + }, + "symbol-observable": { + "version": "1.0.4", + "bundled": true + }, + "symbol-tree": { + "version": "3.2.2", + "bundled": true + }, + "tar": { + "version": "2.2.1", + "bundled": true, + "requires": { + "block-stream": "0.0.9", + "fstream": "1.0.11", + "inherits": "2.0.3" + } + }, + "term-size": { + "version": "0.1.1", + "bundled": true, + "requires": { + "execa": "0.4.0" + }, + "dependencies": { + "execa": { + "version": "0.4.0", + "bundled": true, + "requires": { + "cross-spawn-async": "2.2.5", + "is-stream": "1.1.0", + "npm-run-path": "1.0.0", + "object-assign": "4.1.1", + "path-key": "1.0.0", + "strip-eof": "1.0.0" + } + }, + "npm-run-path": { + "version": "1.0.0", + "bundled": true, + "requires": { + "path-key": "1.0.0" + } + }, + "path-key": { + "version": "1.0.0", + "bundled": true + } + } + }, + "test-exclude": { + "version": "4.1.1", + "bundled": true, + "requires": { + "arrify": "1.0.1", + "micromatch": "2.3.11", + "object-assign": "4.1.1", + "read-pkg-up": "1.0.1", + "require-main-filename": "1.0.1" + } + }, + "throat": { + "version": "3.2.0", + "bundled": true + }, + "through": { + "version": "2.3.8", + "bundled": true + }, + "timed-out": { + "version": "4.0.1", + "bundled": true + }, + "tmp": { + "version": "0.0.31", + "bundled": true, + "requires": { + "os-tmpdir": "1.0.2" + } + }, + "tmpl": { + "version": "1.0.4", + "bundled": true + }, + "to-fast-properties": { + "version": "1.0.3", + "bundled": true + }, + "tough-cookie": { + "version": "2.3.2", + "bundled": true, + "requires": { + "punycode": "1.4.1" + } + }, + "tr46": { + "version": "0.0.3", + "bundled": true + }, + "traverse": { + "version": "0.6.6", + "bundled": true + }, + "trim-newlines": { + "version": "1.0.0", + "bundled": true + }, + "trim-right": { + "version": "1.0.1", + "bundled": true + }, + "tslib": { + "version": "1.7.1", + "bundled": true + }, + "tslint": { + "version": "5.4.3", + "bundled": true, + "requires": { + "babel-code-frame": "6.22.0", + "colors": "1.1.2", + "commander": "2.10.0", + "diff": "3.2.0", + "glob": "7.1.2", + "minimatch": "3.0.4", + "resolve": "1.3.3", + "semver": "5.3.0", + "tslib": "1.7.1", + "tsutils": "2.4.0" + } + }, + "tslint-eslint-rules": { + "version": "1.6.1", + "bundled": true, + "requires": { + "doctrine": "0.7.2", + "tslint": "3.15.1" + }, + "dependencies": { + "diff": { + "version": "2.2.3", + "bundled": true + }, + "tslint": { + "version": "3.15.1", + "bundled": true, + "requires": { + "colors": "1.1.2", + "diff": "2.2.3", + "findup-sync": "0.3.0", + "glob": "7.1.2", + "optimist": "0.6.1", + "resolve": "1.3.3", + "underscore.string": "3.3.4" + } + } + } + }, + "tslint-ionic-rules": { + "version": "0.0.8", + "bundled": true, + "requires": { + "tslint-eslint-rules": "1.6.1" + } + }, + "tsutils": { + "version": "2.4.0", + "bundled": true + }, + "tunnel-agent": { + "version": "0.6.0", + "bundled": true, + "requires": { + "safe-buffer": "5.1.1" + } + }, + "tweetnacl": { + "version": "0.14.5", + "bundled": true, + "optional": true + }, + "type-check": { + "version": "0.3.2", + "bundled": true, + "requires": { + "prelude-ls": "1.1.2" + } + }, + "typescript": { + "version": "2.4.0", + "bundled": true + }, + "uglify-es": { + "version": "3.0.26", + "bundled": true, + "requires": { + "commander": "2.11.0", + "source-map": "0.5.6" + }, + "dependencies": { + "commander": { + "version": "2.11.0", + "bundled": true + } + } + }, + "uglify-js": { + "version": "3.0.21", + "bundled": true, + "requires": { + "commander": "2.9.0", + "source-map": "0.5.6" + }, + "dependencies": { + "commander": { + "version": "2.9.0", + "bundled": true, + "requires": { + "graceful-readlink": "1.0.1" + } + } + } + }, + "underscore.string": { + "version": "3.3.4", + "bundled": true, + "requires": { + "sprintf-js": "1.0.3", + "util-deprecate": "1.0.2" + } + }, + "unique-string": { + "version": "1.0.0", + "bundled": true, + "requires": { + "crypto-random-string": "1.0.0" + } + }, + "unzip-response": { + "version": "2.0.1", + "bundled": true + }, + "update-notifier": { + "version": "2.2.0", + "bundled": true, + "requires": { + "boxen": "1.1.0", + "chalk": "1.1.3", + "configstore": "3.1.0", + "import-lazy": "2.1.0", + "is-npm": "1.0.0", + "latest-version": "3.1.0", + "semver-diff": "2.1.0", + "xdg-basedir": "3.0.0" + } + }, + "url-parse-lax": { + "version": "1.0.0", + "bundled": true, + "requires": { + "prepend-http": "1.0.4" + } + }, + "user-home": { + "version": "1.1.1", + "bundled": true + }, + "util-deprecate": { + "version": "1.0.2", + "bundled": true + }, + "uuid": { + "version": "3.1.0", + "bundled": true + }, + "v8flags": { + "version": "2.1.1", + "bundled": true, + "requires": { + "user-home": "1.1.1" + } + }, + "validate-npm-package-license": { + "version": "3.0.1", + "bundled": true, + "requires": { + "spdx-correct": "1.0.2", + "spdx-expression-parse": "1.0.4" + } + }, + "verror": { + "version": "1.3.6", + "bundled": true, + "requires": { + "extsprintf": "1.0.2" + } + }, + "vinyl": { + "version": "1.2.0", + "bundled": true, + "requires": { + "clone": "1.0.2", + "clone-stats": "0.0.1", + "replace-ext": "0.0.1" + } + }, + "vinyl-sourcemaps-apply": { + "version": "0.2.1", + "bundled": true, + "requires": { + "source-map": "0.5.6" + } + }, + "vlq": { + "version": "0.2.2", + "bundled": true + }, + "walker": { + "version": "1.0.7", + "bundled": true, + "requires": { + "makeerror": "1.0.11" + } + }, + "watch": { + "version": "0.10.0", + "bundled": true + }, + "webidl-conversions": { + "version": "4.0.1", + "bundled": true + }, + "whatwg-encoding": { + "version": "1.0.1", + "bundled": true, + "requires": { + "iconv-lite": "0.4.13" + } + }, + "whatwg-url": { + "version": "4.8.0", + "bundled": true, + "requires": { + "tr46": "0.0.3", + "webidl-conversions": "3.0.1" + }, + "dependencies": { + "webidl-conversions": { + "version": "3.0.1", + "bundled": true + } + } + }, + "which": { + "version": "1.2.14", + "bundled": true, + "requires": { + "isexe": "2.0.0" + } + }, + "which-module": { + "version": "1.0.0", + "bundled": true + }, + "wide-align": { + "version": "1.1.2", + "bundled": true, + "requires": { + "string-width": "1.0.2" + } + }, + "widest-line": { + "version": "1.0.0", + "bundled": true, + "requires": { + "string-width": "1.0.2" + } + }, + "wordwrap": { + "version": "0.0.3", + "bundled": true + }, + "worker-farm": { + "version": "1.3.1", + "bundled": true, + "requires": { + "errno": "0.1.4", + "xtend": "4.0.1" + } + }, + "wrap-ansi": { + "version": "2.1.0", + "bundled": true, + "requires": { + "string-width": "1.0.2", + "strip-ansi": "3.0.1" + } + }, + "wrappy": { + "version": "1.0.2", + "bundled": true + }, + "write-file-atomic": { + "version": "2.1.0", + "bundled": true, + "requires": { + "graceful-fs": "4.1.11", + "imurmurhash": "0.1.4", + "slide": "1.1.6" + } + }, + "xdg-basedir": { + "version": "3.0.0", + "bundled": true + }, + "xml-name-validator": { + "version": "2.0.1", + "bundled": true + }, + "xtend": { + "version": "4.0.1", + "bundled": true + }, + "y18n": { + "version": "3.2.1", + "bundled": true + }, + "yallist": { + "version": "2.1.2", + "bundled": true + }, + "yargs": { + "version": "6.6.0", + "bundled": true, + "requires": { + "camelcase": "3.0.0", + "cliui": "3.2.0", + "decamelize": "1.2.0", + "get-caller-file": "1.0.2", + "os-locale": "1.4.0", + "read-pkg-up": "1.0.1", + "require-directory": "2.1.1", + "require-main-filename": "1.0.1", + "set-blocking": "2.0.0", + "string-width": "1.0.2", + "which-module": "1.0.0", + "y18n": "3.2.1", + "yargs-parser": "4.2.1" + }, + "dependencies": { + "camelcase": { + "version": "3.0.0", + "bundled": true + }, + "cliui": { + "version": "3.2.0", + "bundled": true, + "requires": { + "string-width": "1.0.2", + "strip-ansi": "3.0.1", + "wrap-ansi": "2.1.0" + } + } + } + }, + "yargs-parser": { + "version": "4.2.1", + "bundled": true, + "requires": { + "camelcase": "3.0.0" + }, + "dependencies": { + "camelcase": { + "version": "3.0.0", + "bundled": true + } + } + } } }, "@stencil/dev-server": { @@ -72,85 +4982,21 @@ } } }, - "@types/node": { - "version": "6.0.84", - "resolved": "https://registry.npmjs.org/@types/node/-/node-6.0.84.tgz", - "integrity": "sha512-1SvEazClhUBRNroJM3oB3xf3u2r6xGmHDGbdigqNPHvNKLl8/BtATgO9eC04ZLuovpSh0B20BF1QJxdi+qmTlg==" - }, - "abab": { - "version": "1.0.3", - "resolved": "https://registry.npmjs.org/abab/-/abab-1.0.3.tgz", - "integrity": "sha1-uB3l9ydOxOdW15fNg08wNkJyTl0=" - }, - "abbrev": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/abbrev/-/abbrev-1.1.0.tgz", - "integrity": "sha1-0FVMIlZjbi9W58LlrRg/hZQo2B8=" - }, - "acorn": { - "version": "4.0.13", - "resolved": "https://registry.npmjs.org/acorn/-/acorn-4.0.13.tgz", - "integrity": "sha1-EFSVrlNh1pe9GVyCUZLhrX8lN4c=" - }, - "acorn-globals": { - "version": "3.1.0", - "resolved": "https://registry.npmjs.org/acorn-globals/-/acorn-globals-3.1.0.tgz", - "integrity": "sha1-/YJw9x+7SZawBPqIDuXUZXOnMb8=", - "requires": { - "acorn": "4.0.13" - } - }, - "ajv": { - "version": "4.11.8", - "resolved": "https://registry.npmjs.org/ajv/-/ajv-4.11.8.tgz", - "integrity": "sha1-gv+wKynmYq5TvcIK8VlHcGc5xTY=", - "requires": { - "co": "4.6.0", - "json-stable-stringify": "1.0.1" - } - }, - "amdefine": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/amdefine/-/amdefine-1.0.1.tgz", - "integrity": "sha1-SlKCrBZHKek2Gbz9OtFR+BfOkfU=" - }, - "ansi-regex": { - "version": "2.1.1", - "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-2.1.1.tgz", - "integrity": "sha1-w7M6te42DYbg5ijwRorn7yfWVN8=" - }, - "ansi-styles": { - "version": "2.2.1", - "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-2.2.1.tgz", - "integrity": "sha1-tDLdM1i2NM914eRmQ2gkBTPB3b4=" - }, "anymatch": { "version": "1.3.0", "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-1.3.0.tgz", "integrity": "sha1-o+Uvo5FoyCX/V7AkgSbOWo/5VQc=", + "dev": true, "requires": { "arrify": "1.0.1", "micromatch": "2.3.11" } }, - "aproba": { - "version": "1.1.2", - "resolved": "https://registry.npmjs.org/aproba/-/aproba-1.1.2.tgz", - "integrity": "sha512-ZpYajIfO0j2cOFTO955KUMIKNmj6zhX8kVztMAxFsDaMwz+9Z9SV0uou2pC9HJqcfpffOsjnbrDMvkNy+9RXPw==" - }, - "are-we-there-yet": { - "version": "1.1.4", - "resolved": "https://registry.npmjs.org/are-we-there-yet/-/are-we-there-yet-1.1.4.tgz", - "integrity": "sha1-u13KOCu5TwXhUZQ3PRb9O6HKEQ0=", - "requires": { - "delegates": "1.0.0", - "readable-stream": "2.3.3" - } - }, "arr-diff": { "version": "2.0.0", "resolved": "https://registry.npmjs.org/arr-diff/-/arr-diff-2.0.0.tgz", "integrity": "sha1-jzuCf5Vai9ZpaX5KQlasPOrjVs8=", + "dev": true, "requires": { "arr-flatten": "1.1.0" } @@ -158,89 +5004,38 @@ "arr-flatten": { "version": "1.1.0", "resolved": "https://registry.npmjs.org/arr-flatten/-/arr-flatten-1.1.0.tgz", - "integrity": "sha512-L3hKV5R/p5o81R7O02IGnwpDmkp6E982XhtbuwSe3O4qOtMMMtodicASA1Cny2U+aCXcNpml+m4dPsvsJ3jatg==" - }, - "array-equal": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/array-equal/-/array-equal-1.0.0.tgz", - "integrity": "sha1-jCpe8kcv2ep0KwTHenUJO6J1fJM=" - }, - "array-find-index": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/array-find-index/-/array-find-index-1.0.2.tgz", - "integrity": "sha1-3wEKoSh+Fku9pvlyOwqWoexBh6E=" + "integrity": "sha512-L3hKV5R/p5o81R7O02IGnwpDmkp6E982XhtbuwSe3O4qOtMMMtodicASA1Cny2U+aCXcNpml+m4dPsvsJ3jatg==", + "dev": true }, "array-unique": { "version": "0.2.1", "resolved": "https://registry.npmjs.org/array-unique/-/array-unique-0.2.1.tgz", - "integrity": "sha1-odl8yvy8JiXMcPrc6zalDFiwGlM=" + "integrity": "sha1-odl8yvy8JiXMcPrc6zalDFiwGlM=", + "dev": true }, "arrify": { "version": "1.0.1", "resolved": "https://registry.npmjs.org/arrify/-/arrify-1.0.1.tgz", - "integrity": "sha1-iYUI2iIm84DfkEcoRWhJwVAaSw0=" - }, - "asn1": { - "version": "0.2.3", - "resolved": "https://registry.npmjs.org/asn1/-/asn1-0.2.3.tgz", - "integrity": "sha1-2sh4dxPJlmhJ/IGAd36+nB3fO4Y=" - }, - "assert-plus": { - "version": "0.2.0", - "resolved": "https://registry.npmjs.org/assert-plus/-/assert-plus-0.2.0.tgz", - "integrity": "sha1-104bh+ev/A24qttwIfP+SBAasjQ=" + "integrity": "sha1-iYUI2iIm84DfkEcoRWhJwVAaSw0=", + "dev": true }, "async-each": { "version": "1.0.1", "resolved": "https://registry.npmjs.org/async-each/-/async-each-1.0.1.tgz", - "integrity": "sha1-GdOGodntxufByF04iu28xW0zYC0=" - }, - "async-foreach": { - "version": "0.1.3", - "resolved": "https://registry.npmjs.org/async-foreach/-/async-foreach-0.1.3.tgz", - "integrity": "sha1-NhIfhFwFeBct5Bmpfb6x0W7DRUI=" - }, - "asynckit": { - "version": "0.4.0", - "resolved": "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz", - "integrity": "sha1-x57Zf380y48robyXkLzDZkdLS3k=" - }, - "aws-sign2": { - "version": "0.6.0", - "resolved": "https://registry.npmjs.org/aws-sign2/-/aws-sign2-0.6.0.tgz", - "integrity": "sha1-FDQt0428yU0OW4fXY81jYSwOeU8=" - }, - "aws4": { - "version": "1.6.0", - "resolved": "https://registry.npmjs.org/aws4/-/aws4-1.6.0.tgz", - "integrity": "sha1-g+9cqGCysy5KDe7e6MdxudtXRx4=" + "integrity": "sha1-GdOGodntxufByF04iu28xW0zYC0=", + "dev": true }, "balanced-match": { "version": "1.0.0", "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz", - "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=" - }, - "bcrypt-pbkdf": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/bcrypt-pbkdf/-/bcrypt-pbkdf-1.0.1.tgz", - "integrity": "sha1-Y7xdy2EzG5K8Bf1SiVPDNGKgb40=", - "optional": true, - "requires": { - "tweetnacl": "0.14.5" - } + "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=", + "dev": true }, "binary-extensions": { "version": "1.8.0", "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-1.8.0.tgz", - "integrity": "sha1-SOyNFt9Dd+rl+liEaCSAr02Vx3Q=" - }, - "block-stream": { - "version": "0.0.9", - "resolved": "https://registry.npmjs.org/block-stream/-/block-stream-0.0.9.tgz", - "integrity": "sha1-E+v+d4oDIFz+A3UUgeu0szAMEmo=", - "requires": { - "inherits": "2.0.3" - } + "integrity": "sha1-SOyNFt9Dd+rl+liEaCSAr02Vx3Q=", + "dev": true }, "body": { "version": "5.1.0", @@ -254,18 +5049,11 @@ "safe-json-parse": "1.0.1" } }, - "boom": { - "version": "2.10.1", - "resolved": "https://registry.npmjs.org/boom/-/boom-2.10.1.tgz", - "integrity": "sha1-OciRjO/1eZ+D+UkqhI9iWt0Mdm8=", - "requires": { - "hoek": "2.16.3" - } - }, "brace-expansion": { "version": "1.1.8", "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.8.tgz", "integrity": "sha1-wHshHHyVLsH479Uad+8NHTmQopI=", + "dev": true, "requires": { "balanced-match": "1.0.0", "concat-map": "0.0.1" @@ -275,73 +5063,24 @@ "version": "1.8.5", "resolved": "https://registry.npmjs.org/braces/-/braces-1.8.5.tgz", "integrity": "sha1-uneWLhLf+WnWt2cR6RS3N4V79qc=", + "dev": true, "requires": { "expand-range": "1.8.2", "preserve": "0.2.0", "repeat-element": "1.1.2" } }, - "browser-resolve": { - "version": "1.11.2", - "resolved": "https://registry.npmjs.org/browser-resolve/-/browser-resolve-1.11.2.tgz", - "integrity": "sha1-j/CbCixCFxihBRwmCzLkj0QpOM4=", - "requires": { - "resolve": "1.1.7" - }, - "dependencies": { - "resolve": { - "version": "1.1.7", - "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.1.7.tgz", - "integrity": "sha1-IDEU2CrSxe2ejgQRs5ModeiJ6Xs=" - } - } - }, - "builtin-modules": { - "version": "1.1.1", - "resolved": "https://registry.npmjs.org/builtin-modules/-/builtin-modules-1.1.1.tgz", - "integrity": "sha1-Jw8HbFpywC9bZaR9+Uxf46J4iS8=" - }, "bytes": { "version": "1.0.0", "resolved": "https://registry.npmjs.org/bytes/-/bytes-1.0.0.tgz", "integrity": "sha1-NWnt6Lo0MV+rmcPpLLBMciDeH6g=", "dev": true }, - "camelcase": { - "version": "2.1.1", - "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-2.1.1.tgz", - "integrity": "sha1-fB0W1nmhu+WcoCys7PsBHiAfWh8=" - }, - "camelcase-keys": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/camelcase-keys/-/camelcase-keys-2.1.0.tgz", - "integrity": "sha1-MIvur/3ygRkFHvodkyITyRuPkuc=", - "requires": { - "camelcase": "2.1.1", - "map-obj": "1.0.1" - } - }, - "caseless": { - "version": "0.12.0", - "resolved": "https://registry.npmjs.org/caseless/-/caseless-0.12.0.tgz", - "integrity": "sha1-G2gcIf+EAzyCZUMJBolCDRhxUdw=" - }, - "chalk": { - "version": "1.1.3", - "resolved": "https://registry.npmjs.org/chalk/-/chalk-1.1.3.tgz", - "integrity": "sha1-qBFcVeSnAv5NFQq9OHKCKn4J/Jg=", - "requires": { - "ansi-styles": "2.2.1", - "escape-string-regexp": "1.0.5", - "has-ansi": "2.0.0", - "strip-ansi": "3.0.1", - "supports-color": "2.0.0" - } - }, "chokidar": { "version": "1.7.0", "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-1.7.0.tgz", "integrity": "sha1-eY5ol3gVHIB2tLNg5e3SjNortGg=", + "dev": true, "requires": { "anymatch": "1.3.0", "async-each": "1.0.1", @@ -354,34 +5093,6 @@ "readdirp": "2.1.0" } }, - "clean-css": { - "version": "4.1.7", - "resolved": "https://registry.npmjs.org/clean-css/-/clean-css-4.1.7.tgz", - "integrity": "sha1-ua6k+FZ5iJzz6ui0A0nsTr390DI=", - "requires": { - "source-map": "0.5.6" - } - }, - "cliui": { - "version": "3.2.0", - "resolved": "https://registry.npmjs.org/cliui/-/cliui-3.2.0.tgz", - "integrity": "sha1-EgYBU3qRbSmUD5NNo7SNWFo5IT0=", - "requires": { - "string-width": "1.0.2", - "strip-ansi": "3.0.1", - "wrap-ansi": "2.1.0" - } - }, - "co": { - "version": "4.6.0", - "resolved": "https://registry.npmjs.org/co/-/co-4.6.0.tgz", - "integrity": "sha1-bqa989hTrlTMuOR7+gvz+QMfsYQ=" - }, - "code-point-at": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/code-point-at/-/code-point-at-1.1.0.tgz", - "integrity": "sha1-DQcLTQQ6W+ozovGkDi7bPZpMz3c=" - }, "color-convert": { "version": "1.9.0", "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.0.tgz", @@ -397,26 +5108,11 @@ "integrity": "sha1-XIq3K2S9IhXWF66VWeuxSEdc+Y0=", "dev": true }, - "combined-stream": { - "version": "1.0.5", - "resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.5.tgz", - "integrity": "sha1-k4NwpXtKUd6ix3wV1cX9+JUWQAk=", - "requires": { - "delayed-stream": "1.0.0" - } - }, - "commander": { - "version": "2.9.0", - "resolved": "https://registry.npmjs.org/commander/-/commander-2.9.0.tgz", - "integrity": "sha1-nJkJQXbhIkDLItbFFGCYQA/g99Q=", - "requires": { - "graceful-readlink": "1.0.1" - } - }, "concat-map": { "version": "0.0.1", "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", - "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=" + "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=", + "dev": true }, "concurrently": { "version": "3.5.0", @@ -502,16 +5198,6 @@ } } }, - "console-control-strings": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/console-control-strings/-/console-control-strings-1.1.0.tgz", - "integrity": "sha1-PXz0Rk22RG6mRL9LOVB/mFEAjo4=" - }, - "content-type-parser": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/content-type-parser/-/content-type-parser-1.0.1.tgz", - "integrity": "sha1-w+VpiMU8ZRJ/tG1AMqOpACRv3JQ=" - }, "continuable-cache": { "version": "0.3.1", "resolved": "https://registry.npmjs.org/continuable-cache/-/continuable-cache-0.3.1.tgz", @@ -521,60 +5207,8 @@ "core-util-is": { "version": "1.0.2", "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.2.tgz", - "integrity": "sha1-tf1UIgqivFq1eqtxQMlAdUUDwac=" - }, - "cross-spawn": { - "version": "3.0.1", - "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-3.0.1.tgz", - "integrity": "sha1-ElYDfsufDF9549bvE14wdwGEuYI=", - "requires": { - "lru-cache": "4.1.1", - "which": "1.2.14" - } - }, - "cryptiles": { - "version": "2.0.5", - "resolved": "https://registry.npmjs.org/cryptiles/-/cryptiles-2.0.5.tgz", - "integrity": "sha1-O9/s3GCBR8HGcgL6KR59ylnqo7g=", - "requires": { - "boom": "2.10.1" - } - }, - "cssom": { - "version": "0.3.2", - "resolved": "https://registry.npmjs.org/cssom/-/cssom-0.3.2.tgz", - "integrity": "sha1-uANhcMefB6kP8vFuIihAJ6JDhIs=" - }, - "cssstyle": { - "version": "0.2.37", - "resolved": "https://registry.npmjs.org/cssstyle/-/cssstyle-0.2.37.tgz", - "integrity": "sha1-VBCXI0yyUTyDzu06zdwn/yeYfVQ=", - "requires": { - "cssom": "0.3.2" - } - }, - "currently-unhandled": { - "version": "0.4.1", - "resolved": "https://registry.npmjs.org/currently-unhandled/-/currently-unhandled-0.4.1.tgz", - "integrity": "sha1-mI3zP+qxke95mmE2nddsF635V+o=", - "requires": { - "array-find-index": "1.0.2" - } - }, - "dashdash": { - "version": "1.14.1", - "resolved": "https://registry.npmjs.org/dashdash/-/dashdash-1.14.1.tgz", - "integrity": "sha1-hTz6D3y+L+1d4gMmuN1YEDX24vA=", - "requires": { - "assert-plus": "1.0.0" - }, - "dependencies": { - "assert-plus": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/assert-plus/-/assert-plus-1.0.0.tgz", - "integrity": "sha1-8S4PPF13sLHN2RRpQuTpbB5N1SU=" - } - } + "integrity": "sha1-tf1UIgqivFq1eqtxQMlAdUUDwac=", + "dev": true }, "date-fns": { "version": "1.28.5", @@ -591,35 +5225,6 @@ "ms": "2.0.0" } }, - "decamelize": { - "version": "1.2.0", - "resolved": "https://registry.npmjs.org/decamelize/-/decamelize-1.2.0.tgz", - "integrity": "sha1-9lNNFRSCabIDUue+4m9QH5oZEpA=" - }, - "deep-is": { - "version": "0.1.3", - "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.3.tgz", - "integrity": "sha1-s2nW+128E+7PUk+RsHD+7cNXzzQ=" - }, - "delayed-stream": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz", - "integrity": "sha1-3zrhmayt+31ECqrgsp4icrJOxhk=" - }, - "delegates": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/delegates/-/delegates-1.0.0.tgz", - "integrity": "sha1-hMbhWbgZBP3KWaDvRM2HDTElD5o=" - }, - "ecc-jsbn": { - "version": "0.1.1", - "resolved": "https://registry.npmjs.org/ecc-jsbn/-/ecc-jsbn-0.1.1.tgz", - "integrity": "sha1-D8c6ntXw1Tw4GTOYUj735UN3dQU=", - "optional": true, - "requires": { - "jsbn": "0.1.1" - } - }, "ecstatic": { "version": "2.2.1", "resolved": "https://registry.npmjs.org/ecstatic/-/ecstatic-2.2.1.tgz", @@ -642,66 +5247,17 @@ "xtend": "4.0.1" } }, - "error-ex": { - "version": "1.3.1", - "resolved": "https://registry.npmjs.org/error-ex/-/error-ex-1.3.1.tgz", - "integrity": "sha1-+FWobOYa3E6GIcPNoh56dhLDqNw=", - "requires": { - "is-arrayish": "0.2.1" - } - }, "escape-string-regexp": { "version": "1.0.5", "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", - "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=" - }, - "escodegen": { - "version": "1.8.1", - "resolved": "https://registry.npmjs.org/escodegen/-/escodegen-1.8.1.tgz", - "integrity": "sha1-WltTr0aTEQvrsIZ6o0MN07cKEBg=", - "requires": { - "esprima": "2.7.3", - "estraverse": "1.9.3", - "esutils": "2.0.2", - "optionator": "0.8.2", - "source-map": "0.2.0" - }, - "dependencies": { - "source-map": { - "version": "0.2.0", - "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.2.0.tgz", - "integrity": "sha1-2rc/vPwrqBm03gO9b26qSBZLP50=", - "optional": true, - "requires": { - "amdefine": "1.0.1" - } - } - } - }, - "esprima": { - "version": "2.7.3", - "resolved": "https://registry.npmjs.org/esprima/-/esprima-2.7.3.tgz", - "integrity": "sha1-luO3DVd59q1JzQMmc9HDEnZ7pYE=" - }, - "estraverse": { - "version": "1.9.3", - "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-1.9.3.tgz", - "integrity": "sha1-r2fy3JIlgkFZUJJgkaQAXSnJu0Q=" - }, - "estree-walker": { - "version": "0.3.1", - "resolved": "https://registry.npmjs.org/estree-walker/-/estree-walker-0.3.1.tgz", - "integrity": "sha1-5rGlHPcpJSTnI3wxLl/mZgwc4ao=" - }, - "esutils": { - "version": "2.0.2", - "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.2.tgz", - "integrity": "sha1-Cr9PHKpbyx96nYrMbepPqqBLrJs=" + "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=", + "dev": true }, "expand-brackets": { "version": "0.1.5", "resolved": "https://registry.npmjs.org/expand-brackets/-/expand-brackets-0.1.5.tgz", "integrity": "sha1-3wcoTjQqgHzXM6xa9yQR5YHRF3s=", + "dev": true, "requires": { "is-posix-bracket": "0.1.1" } @@ -710,33 +5266,20 @@ "version": "1.8.2", "resolved": "https://registry.npmjs.org/expand-range/-/expand-range-1.8.2.tgz", "integrity": "sha1-opnv/TNf4nIeuujiV+x5ZE/IUzc=", + "dev": true, "requires": { "fill-range": "2.2.3" } }, - "extend": { - "version": "3.0.1", - "resolved": "https://registry.npmjs.org/extend/-/extend-3.0.1.tgz", - "integrity": "sha1-p1Xqe8Gt/MWjHOfnYtuq3F5jZEQ=" - }, "extglob": { "version": "0.3.2", "resolved": "https://registry.npmjs.org/extglob/-/extglob-0.3.2.tgz", "integrity": "sha1-Lhj/PS9JqydlzskCPwEdqo2DSaE=", + "dev": true, "requires": { "is-extglob": "1.0.0" } }, - "extsprintf": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/extsprintf/-/extsprintf-1.0.2.tgz", - "integrity": "sha1-4QgOBljjALBilJkMxw4VAiNf1VA=" - }, - "fast-levenshtein": { - "version": "2.0.6", - "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", - "integrity": "sha1-PYpcZog6FqMMqGQ+hR8Zuqd5eRc=" - }, "faye-websocket": { "version": "0.10.0", "resolved": "https://registry.npmjs.org/faye-websocket/-/faye-websocket-0.10.0.tgz", @@ -749,12 +5292,14 @@ "filename-regex": { "version": "2.0.1", "resolved": "https://registry.npmjs.org/filename-regex/-/filename-regex-2.0.1.tgz", - "integrity": "sha1-wcS5vuPglyXdsQa3XB4wH+LxiyY=" + "integrity": "sha1-wcS5vuPglyXdsQa3XB4wH+LxiyY=", + "dev": true }, "fill-range": { "version": "2.2.3", "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-2.2.3.tgz", "integrity": "sha1-ULd9/X5Gm8dJJHCWNpn+eoSFpyM=", + "dev": true, "requires": { "is-number": "2.1.0", "isobject": "2.1.0", @@ -763,52 +5308,26 @@ "repeat-string": "1.6.1" } }, - "find-up": { - "version": "1.1.2", - "resolved": "https://registry.npmjs.org/find-up/-/find-up-1.1.2.tgz", - "integrity": "sha1-ay6YIrGizgpgq2TWEOzK1TyyTQ8=", - "requires": { - "path-exists": "2.1.0", - "pinkie-promise": "2.0.1" - } - }, "for-in": { "version": "1.0.2", "resolved": "https://registry.npmjs.org/for-in/-/for-in-1.0.2.tgz", - "integrity": "sha1-gQaNKVqBQuwKxybG4iAMMPttXoA=" + "integrity": "sha1-gQaNKVqBQuwKxybG4iAMMPttXoA=", + "dev": true }, "for-own": { "version": "0.1.5", "resolved": "https://registry.npmjs.org/for-own/-/for-own-0.1.5.tgz", "integrity": "sha1-UmXGgaTylNq78XyVCbZ2OqhFEM4=", + "dev": true, "requires": { "for-in": "1.0.2" } }, - "forever-agent": { - "version": "0.6.1", - "resolved": "https://registry.npmjs.org/forever-agent/-/forever-agent-0.6.1.tgz", - "integrity": "sha1-+8cfDEGt6zf5bFd60e1C2P2sypE=" - }, - "form-data": { - "version": "2.1.4", - "resolved": "https://registry.npmjs.org/form-data/-/form-data-2.1.4.tgz", - "integrity": "sha1-M8GDrPGTJ27KqYFDpp6Uv+4XUNE=", - "requires": { - "asynckit": "0.4.0", - "combined-stream": "1.0.5", - "mime-types": "2.1.15" - } - }, - "fs.realpath": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", - "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=" - }, "fsevents": { "version": "1.1.2", "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-1.1.2.tgz", "integrity": "sha512-Sn44E5wQW4bTHXvQmvSHwqbuiXtduD6Rrjm2ZtUEGbyrig+nUH3t/QD4M4/ZXViY556TBpRgZkHLDx3JxPwxiw==", + "dev": true, "optional": true, "requires": { "nan": "2.6.2", @@ -817,12 +5336,16 @@ "dependencies": { "abbrev": { "version": "1.1.0", - "bundled": true, + "resolved": "https://registry.npmjs.org/abbrev/-/abbrev-1.1.0.tgz", + "integrity": "sha1-0FVMIlZjbi9W58LlrRg/hZQo2B8=", + "dev": true, "optional": true }, "ajv": { "version": "4.11.8", - "bundled": true, + "resolved": "https://registry.npmjs.org/ajv/-/ajv-4.11.8.tgz", + "integrity": "sha1-gv+wKynmYq5TvcIK8VlHcGc5xTY=", + "dev": true, "optional": true, "requires": { "co": "4.6.0", @@ -831,16 +5354,22 @@ }, "ansi-regex": { "version": "2.1.1", - "bundled": true + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-2.1.1.tgz", + "integrity": "sha1-w7M6te42DYbg5ijwRorn7yfWVN8=", + "dev": true }, "aproba": { "version": "1.1.1", - "bundled": true, + "resolved": "https://registry.npmjs.org/aproba/-/aproba-1.1.1.tgz", + "integrity": "sha1-ldNgDwdxCqDpKYxyatXs8urLq6s=", + "dev": true, "optional": true }, "are-we-there-yet": { "version": "1.1.4", - "bundled": true, + "resolved": "https://registry.npmjs.org/are-we-there-yet/-/are-we-there-yet-1.1.4.tgz", + "integrity": "sha1-u13KOCu5TwXhUZQ3PRb9O6HKEQ0=", + "dev": true, "optional": true, "requires": { "delegates": "1.0.0", @@ -849,36 +5378,50 @@ }, "asn1": { "version": "0.2.3", - "bundled": true, + "resolved": "https://registry.npmjs.org/asn1/-/asn1-0.2.3.tgz", + "integrity": "sha1-2sh4dxPJlmhJ/IGAd36+nB3fO4Y=", + "dev": true, "optional": true }, "assert-plus": { "version": "0.2.0", - "bundled": true, + "resolved": "https://registry.npmjs.org/assert-plus/-/assert-plus-0.2.0.tgz", + "integrity": "sha1-104bh+ev/A24qttwIfP+SBAasjQ=", + "dev": true, "optional": true }, "asynckit": { "version": "0.4.0", - "bundled": true, + "resolved": "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz", + "integrity": "sha1-x57Zf380y48robyXkLzDZkdLS3k=", + "dev": true, "optional": true }, "aws-sign2": { "version": "0.6.0", - "bundled": true, + "resolved": "https://registry.npmjs.org/aws-sign2/-/aws-sign2-0.6.0.tgz", + "integrity": "sha1-FDQt0428yU0OW4fXY81jYSwOeU8=", + "dev": true, "optional": true }, "aws4": { "version": "1.6.0", - "bundled": true, + "resolved": "https://registry.npmjs.org/aws4/-/aws4-1.6.0.tgz", + "integrity": "sha1-g+9cqGCysy5KDe7e6MdxudtXRx4=", + "dev": true, "optional": true }, "balanced-match": { "version": "0.4.2", - "bundled": true + "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-0.4.2.tgz", + "integrity": "sha1-yz8+PHMtwPAe5wtAPzAuYddwmDg=", + "dev": true }, "bcrypt-pbkdf": { "version": "1.0.1", - "bundled": true, + "resolved": "https://registry.npmjs.org/bcrypt-pbkdf/-/bcrypt-pbkdf-1.0.1.tgz", + "integrity": "sha1-Y7xdy2EzG5K8Bf1SiVPDNGKgb40=", + "dev": true, "optional": true, "requires": { "tweetnacl": "0.14.5" @@ -886,21 +5429,27 @@ }, "block-stream": { "version": "0.0.9", - "bundled": true, + "resolved": "https://registry.npmjs.org/block-stream/-/block-stream-0.0.9.tgz", + "integrity": "sha1-E+v+d4oDIFz+A3UUgeu0szAMEmo=", + "dev": true, "requires": { "inherits": "2.0.3" } }, "boom": { "version": "2.10.1", - "bundled": true, + "resolved": "https://registry.npmjs.org/boom/-/boom-2.10.1.tgz", + "integrity": "sha1-OciRjO/1eZ+D+UkqhI9iWt0Mdm8=", + "dev": true, "requires": { "hoek": "2.16.3" } }, "brace-expansion": { "version": "1.1.7", - "bundled": true, + "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.7.tgz", + "integrity": "sha1-Pv/DxQ4ABTH7cg6v+A8K6O8jz1k=", + "dev": true, "requires": { "balanced-match": "0.4.2", "concat-map": "0.0.1" @@ -908,44 +5457,62 @@ }, "buffer-shims": { "version": "1.0.0", - "bundled": true + "resolved": "https://registry.npmjs.org/buffer-shims/-/buffer-shims-1.0.0.tgz", + "integrity": "sha1-mXjOMXOIxkmth5MCjDR37wRKi1E=", + "dev": true }, "caseless": { "version": "0.12.0", - "bundled": true, + "resolved": "https://registry.npmjs.org/caseless/-/caseless-0.12.0.tgz", + "integrity": "sha1-G2gcIf+EAzyCZUMJBolCDRhxUdw=", + "dev": true, "optional": true }, "co": { "version": "4.6.0", - "bundled": true, + "resolved": "https://registry.npmjs.org/co/-/co-4.6.0.tgz", + "integrity": "sha1-bqa989hTrlTMuOR7+gvz+QMfsYQ=", + "dev": true, "optional": true }, "code-point-at": { "version": "1.1.0", - "bundled": true + "resolved": "https://registry.npmjs.org/code-point-at/-/code-point-at-1.1.0.tgz", + "integrity": "sha1-DQcLTQQ6W+ozovGkDi7bPZpMz3c=", + "dev": true }, "combined-stream": { "version": "1.0.5", - "bundled": true, + "resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.5.tgz", + "integrity": "sha1-k4NwpXtKUd6ix3wV1cX9+JUWQAk=", + "dev": true, "requires": { "delayed-stream": "1.0.0" } }, "concat-map": { "version": "0.0.1", - "bundled": true + "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", + "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=", + "dev": true }, "console-control-strings": { "version": "1.1.0", - "bundled": true + "resolved": "https://registry.npmjs.org/console-control-strings/-/console-control-strings-1.1.0.tgz", + "integrity": "sha1-PXz0Rk22RG6mRL9LOVB/mFEAjo4=", + "dev": true }, "core-util-is": { "version": "1.0.2", - "bundled": true + "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.2.tgz", + "integrity": "sha1-tf1UIgqivFq1eqtxQMlAdUUDwac=", + "dev": true }, "cryptiles": { "version": "2.0.5", - "bundled": true, + "resolved": "https://registry.npmjs.org/cryptiles/-/cryptiles-2.0.5.tgz", + "integrity": "sha1-O9/s3GCBR8HGcgL6KR59ylnqo7g=", + "dev": true, "optional": true, "requires": { "boom": "2.10.1" @@ -953,7 +5520,9 @@ }, "dashdash": { "version": "1.14.1", - "bundled": true, + "resolved": "https://registry.npmjs.org/dashdash/-/dashdash-1.14.1.tgz", + "integrity": "sha1-hTz6D3y+L+1d4gMmuN1YEDX24vA=", + "dev": true, "optional": true, "requires": { "assert-plus": "1.0.0" @@ -961,14 +5530,18 @@ "dependencies": { "assert-plus": { "version": "1.0.0", - "bundled": true, + "resolved": "https://registry.npmjs.org/assert-plus/-/assert-plus-1.0.0.tgz", + "integrity": "sha1-8S4PPF13sLHN2RRpQuTpbB5N1SU=", + "dev": true, "optional": true } } }, "debug": { "version": "2.6.8", - "bundled": true, + "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.8.tgz", + "integrity": "sha1-5zFTHKLt4n0YgiJCfaF4IdaP9Pw=", + "dev": true, "optional": true, "requires": { "ms": "2.0.0" @@ -976,21 +5549,29 @@ }, "deep-extend": { "version": "0.4.2", - "bundled": true, + "resolved": "https://registry.npmjs.org/deep-extend/-/deep-extend-0.4.2.tgz", + "integrity": "sha1-SLaZwn4zS/ifEIkr5DL25MfTSn8=", + "dev": true, "optional": true }, "delayed-stream": { "version": "1.0.0", - "bundled": true + "resolved": "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz", + "integrity": "sha1-3zrhmayt+31ECqrgsp4icrJOxhk=", + "dev": true }, "delegates": { "version": "1.0.0", - "bundled": true, + "resolved": "https://registry.npmjs.org/delegates/-/delegates-1.0.0.tgz", + "integrity": "sha1-hMbhWbgZBP3KWaDvRM2HDTElD5o=", + "dev": true, "optional": true }, "ecc-jsbn": { "version": "0.1.1", - "bundled": true, + "resolved": "https://registry.npmjs.org/ecc-jsbn/-/ecc-jsbn-0.1.1.tgz", + "integrity": "sha1-D8c6ntXw1Tw4GTOYUj735UN3dQU=", + "dev": true, "optional": true, "requires": { "jsbn": "0.1.1" @@ -998,21 +5579,29 @@ }, "extend": { "version": "3.0.1", - "bundled": true, + "resolved": "https://registry.npmjs.org/extend/-/extend-3.0.1.tgz", + "integrity": "sha1-p1Xqe8Gt/MWjHOfnYtuq3F5jZEQ=", + "dev": true, "optional": true }, "extsprintf": { "version": "1.0.2", - "bundled": true + "resolved": "https://registry.npmjs.org/extsprintf/-/extsprintf-1.0.2.tgz", + "integrity": "sha1-4QgOBljjALBilJkMxw4VAiNf1VA=", + "dev": true }, "forever-agent": { "version": "0.6.1", - "bundled": true, + "resolved": "https://registry.npmjs.org/forever-agent/-/forever-agent-0.6.1.tgz", + "integrity": "sha1-+8cfDEGt6zf5bFd60e1C2P2sypE=", + "dev": true, "optional": true }, "form-data": { "version": "2.1.4", - "bundled": true, + "resolved": "https://registry.npmjs.org/form-data/-/form-data-2.1.4.tgz", + "integrity": "sha1-M8GDrPGTJ27KqYFDpp6Uv+4XUNE=", + "dev": true, "optional": true, "requires": { "asynckit": "0.4.0", @@ -1022,11 +5611,15 @@ }, "fs.realpath": { "version": "1.0.0", - "bundled": true + "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", + "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=", + "dev": true }, "fstream": { "version": "1.0.11", - "bundled": true, + "resolved": "https://registry.npmjs.org/fstream/-/fstream-1.0.11.tgz", + "integrity": "sha1-XB+x8RdHcRTwYyoOtLcbPLD9MXE=", + "dev": true, "requires": { "graceful-fs": "4.1.11", "inherits": "2.0.3", @@ -1036,7 +5629,9 @@ }, "fstream-ignore": { "version": "1.0.5", - "bundled": true, + "resolved": "https://registry.npmjs.org/fstream-ignore/-/fstream-ignore-1.0.5.tgz", + "integrity": "sha1-nDHa40dnAY/h0kmyTa2mfQktoQU=", + "dev": true, "optional": true, "requires": { "fstream": "1.0.11", @@ -1046,7 +5641,9 @@ }, "gauge": { "version": "2.7.4", - "bundled": true, + "resolved": "https://registry.npmjs.org/gauge/-/gauge-2.7.4.tgz", + "integrity": "sha1-LANAXHU4w51+s3sxcCLjJfsBi/c=", + "dev": true, "optional": true, "requires": { "aproba": "1.1.1", @@ -1061,7 +5658,9 @@ }, "getpass": { "version": "0.1.7", - "bundled": true, + "resolved": "https://registry.npmjs.org/getpass/-/getpass-0.1.7.tgz", + "integrity": "sha1-Xv+OPmhNVprkyysSgmBOi6YhSfo=", + "dev": true, "optional": true, "requires": { "assert-plus": "1.0.0" @@ -1069,14 +5668,18 @@ "dependencies": { "assert-plus": { "version": "1.0.0", - "bundled": true, + "resolved": "https://registry.npmjs.org/assert-plus/-/assert-plus-1.0.0.tgz", + "integrity": "sha1-8S4PPF13sLHN2RRpQuTpbB5N1SU=", + "dev": true, "optional": true } } }, "glob": { "version": "7.1.2", - "bundled": true, + "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.2.tgz", + "integrity": "sha512-MJTUg1kjuLeQCJ+ccE4Vpa6kKVXkPYJ2mOCQyUuKLcLQsdrMCpBPUi8qVE6+YuaJkozeA9NusTAw3hLr8Xe5EQ==", + "dev": true, "requires": { "fs.realpath": "1.0.0", "inflight": "1.0.6", @@ -1088,16 +5691,22 @@ }, "graceful-fs": { "version": "4.1.11", - "bundled": true + "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.1.11.tgz", + "integrity": "sha1-Dovf5NHduIVNZOBOp8AOKgJuVlg=", + "dev": true }, "har-schema": { "version": "1.0.5", - "bundled": true, + "resolved": "https://registry.npmjs.org/har-schema/-/har-schema-1.0.5.tgz", + "integrity": "sha1-0mMTX0MwfALGAq/I/pWXDAFRNp4=", + "dev": true, "optional": true }, "har-validator": { "version": "4.2.1", - "bundled": true, + "resolved": "https://registry.npmjs.org/har-validator/-/har-validator-4.2.1.tgz", + "integrity": "sha1-M0gdDxu/9gDdID11gSpqX7oALio=", + "dev": true, "optional": true, "requires": { "ajv": "4.11.8", @@ -1106,12 +5715,16 @@ }, "has-unicode": { "version": "2.0.1", - "bundled": true, + "resolved": "https://registry.npmjs.org/has-unicode/-/has-unicode-2.0.1.tgz", + "integrity": "sha1-4Ob+aijPUROIVeCG0Wkedx3iqLk=", + "dev": true, "optional": true }, "hawk": { "version": "3.1.3", - "bundled": true, + "resolved": "https://registry.npmjs.org/hawk/-/hawk-3.1.3.tgz", + "integrity": "sha1-B4REvXwWQLD+VA0sm3PVlnjo4cQ=", + "dev": true, "optional": true, "requires": { "boom": "2.10.1", @@ -1122,11 +5735,15 @@ }, "hoek": { "version": "2.16.3", - "bundled": true + "resolved": "https://registry.npmjs.org/hoek/-/hoek-2.16.3.tgz", + "integrity": "sha1-ILt0A9POo5jpHcRxCo/xuCdKJe0=", + "dev": true }, "http-signature": { "version": "1.1.1", - "bundled": true, + "resolved": "https://registry.npmjs.org/http-signature/-/http-signature-1.1.1.tgz", + "integrity": "sha1-33LiZwZs0Kxn+3at+OE0qPvPkb8=", + "dev": true, "optional": true, "requires": { "assert-plus": "0.2.0", @@ -1136,7 +5753,9 @@ }, "inflight": { "version": "1.0.6", - "bundled": true, + "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", + "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", + "dev": true, "requires": { "once": "1.4.0", "wrappy": "1.0.2" @@ -1144,37 +5763,51 @@ }, "inherits": { "version": "2.0.3", - "bundled": true + "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz", + "integrity": "sha1-Yzwsg+PaQqUC9SRmAiSA9CCCYd4=", + "dev": true }, "ini": { "version": "1.3.4", - "bundled": true, + "resolved": "https://registry.npmjs.org/ini/-/ini-1.3.4.tgz", + "integrity": "sha1-BTfLedr1m1mhpRff9wbIbsA5Fi4=", + "dev": true, "optional": true }, "is-fullwidth-code-point": { "version": "1.0.0", - "bundled": true, + "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-1.0.0.tgz", + "integrity": "sha1-754xOG8DGn8NZDr4L95QxFfvAMs=", + "dev": true, "requires": { "number-is-nan": "1.0.1" } }, "is-typedarray": { "version": "1.0.0", - "bundled": true, + "resolved": "https://registry.npmjs.org/is-typedarray/-/is-typedarray-1.0.0.tgz", + "integrity": "sha1-5HnICFjfDBsR3dppQPlgEfzaSpo=", + "dev": true, "optional": true }, "isarray": { "version": "1.0.0", - "bundled": true + "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", + "integrity": "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE=", + "dev": true }, "isstream": { "version": "0.1.2", - "bundled": true, + "resolved": "https://registry.npmjs.org/isstream/-/isstream-0.1.2.tgz", + "integrity": "sha1-R+Y/evVa+m+S4VAOaQ64uFKcCZo=", + "dev": true, "optional": true }, "jodid25519": { "version": "1.0.2", - "bundled": true, + "resolved": "https://registry.npmjs.org/jodid25519/-/jodid25519-1.0.2.tgz", + "integrity": "sha1-BtSRIlUJNBlHfUJWM2BuDpB4KWc=", + "dev": true, "optional": true, "requires": { "jsbn": "0.1.1" @@ -1182,17 +5815,23 @@ }, "jsbn": { "version": "0.1.1", - "bundled": true, + "resolved": "https://registry.npmjs.org/jsbn/-/jsbn-0.1.1.tgz", + "integrity": "sha1-peZUwuWi3rXyAdls77yoDA7y9RM=", + "dev": true, "optional": true }, "json-schema": { "version": "0.2.3", - "bundled": true, + "resolved": "https://registry.npmjs.org/json-schema/-/json-schema-0.2.3.tgz", + "integrity": "sha1-tIDIkuWaLwWVTOcnvT8qTogvnhM=", + "dev": true, "optional": true }, "json-stable-stringify": { "version": "1.0.1", - "bundled": true, + "resolved": "https://registry.npmjs.org/json-stable-stringify/-/json-stable-stringify-1.0.1.tgz", + "integrity": "sha1-mnWdOcXy/1A/1TAGRu1EX4jE+a8=", + "dev": true, "optional": true, "requires": { "jsonify": "0.0.0" @@ -1200,17 +5839,23 @@ }, "json-stringify-safe": { "version": "5.0.1", - "bundled": true, + "resolved": "https://registry.npmjs.org/json-stringify-safe/-/json-stringify-safe-5.0.1.tgz", + "integrity": "sha1-Epai1Y/UXxmg9s4B1lcB4sc1tus=", + "dev": true, "optional": true }, "jsonify": { "version": "0.0.0", - "bundled": true, + "resolved": "https://registry.npmjs.org/jsonify/-/jsonify-0.0.0.tgz", + "integrity": "sha1-LHS27kHZPKUbe1qu6PUDYx0lKnM=", + "dev": true, "optional": true }, "jsprim": { "version": "1.4.0", - "bundled": true, + "resolved": "https://registry.npmjs.org/jsprim/-/jsprim-1.4.0.tgz", + "integrity": "sha1-o7h+QCmNjDgFUtjMdiigu5WiKRg=", + "dev": true, "optional": true, "requires": { "assert-plus": "1.0.0", @@ -1221,48 +5866,64 @@ "dependencies": { "assert-plus": { "version": "1.0.0", - "bundled": true, + "resolved": "https://registry.npmjs.org/assert-plus/-/assert-plus-1.0.0.tgz", + "integrity": "sha1-8S4PPF13sLHN2RRpQuTpbB5N1SU=", + "dev": true, "optional": true } } }, "mime-db": { "version": "1.27.0", - "bundled": true + "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.27.0.tgz", + "integrity": "sha1-gg9XIpa70g7CXtVeW13oaeVDbrE=", + "dev": true }, "mime-types": { "version": "2.1.15", - "bundled": true, + "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.15.tgz", + "integrity": "sha1-pOv1BkCUVpI3uM9wBGd20J/JKu0=", + "dev": true, "requires": { "mime-db": "1.27.0" } }, "minimatch": { "version": "3.0.4", - "bundled": true, + "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", + "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", + "dev": true, "requires": { "brace-expansion": "1.1.7" } }, "minimist": { "version": "0.0.8", - "bundled": true + "resolved": "https://registry.npmjs.org/minimist/-/minimist-0.0.8.tgz", + "integrity": "sha1-hX/Kv8M5fSYluCKCYuhqp6ARsF0=", + "dev": true }, "mkdirp": { "version": "0.5.1", - "bundled": true, + "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.1.tgz", + "integrity": "sha1-MAV0OOrGz3+MR2fzhkjWaX11yQM=", + "dev": true, "requires": { "minimist": "0.0.8" } }, "ms": { "version": "2.0.0", - "bundled": true, + "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", + "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=", + "dev": true, "optional": true }, "node-pre-gyp": { "version": "0.6.36", - "bundled": true, + "resolved": "https://registry.npmjs.org/node-pre-gyp/-/node-pre-gyp-0.6.36.tgz", + "integrity": "sha1-22BBEst04NR3VU6bUFsXq936t4Y=", + "dev": true, "optional": true, "requires": { "mkdirp": "0.5.1", @@ -1278,7 +5939,9 @@ }, "nopt": { "version": "4.0.1", - "bundled": true, + "resolved": "https://registry.npmjs.org/nopt/-/nopt-4.0.1.tgz", + "integrity": "sha1-0NRoWv1UFRk8jHUFYC0NF81kR00=", + "dev": true, "optional": true, "requires": { "abbrev": "1.1.0", @@ -1287,7 +5950,9 @@ }, "npmlog": { "version": "4.1.0", - "bundled": true, + "resolved": "https://registry.npmjs.org/npmlog/-/npmlog-4.1.0.tgz", + "integrity": "sha512-ocolIkZYZt8UveuiDS0yAkkIjid1o7lPG8cYm05yNYzBn8ykQtaiPMEGp8fY9tKdDgm8okpdKzkvu1y9hUYugA==", + "dev": true, "optional": true, "requires": { "are-we-there-yet": "1.1.4", @@ -1298,38 +5963,52 @@ }, "number-is-nan": { "version": "1.0.1", - "bundled": true + "resolved": "https://registry.npmjs.org/number-is-nan/-/number-is-nan-1.0.1.tgz", + "integrity": "sha1-CXtgK1NCKlIsGvuHkDGDNpQaAR0=", + "dev": true }, "oauth-sign": { "version": "0.8.2", - "bundled": true, + "resolved": "https://registry.npmjs.org/oauth-sign/-/oauth-sign-0.8.2.tgz", + "integrity": "sha1-Rqarfwrq2N6unsBWV4C31O/rnUM=", + "dev": true, "optional": true }, "object-assign": { "version": "4.1.1", - "bundled": true, + "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", + "integrity": "sha1-IQmtx5ZYh8/AXLvUQsrIv7s2CGM=", + "dev": true, "optional": true }, "once": { "version": "1.4.0", - "bundled": true, + "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", + "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", + "dev": true, "requires": { "wrappy": "1.0.2" } }, "os-homedir": { "version": "1.0.2", - "bundled": true, + "resolved": "https://registry.npmjs.org/os-homedir/-/os-homedir-1.0.2.tgz", + "integrity": "sha1-/7xJiDNuDoM94MFox+8VISGqf7M=", + "dev": true, "optional": true }, "os-tmpdir": { "version": "1.0.2", - "bundled": true, + "resolved": "https://registry.npmjs.org/os-tmpdir/-/os-tmpdir-1.0.2.tgz", + "integrity": "sha1-u+Z0BseaqFxc/sdm/lc0VV36EnQ=", + "dev": true, "optional": true }, "osenv": { "version": "0.1.4", - "bundled": true, + "resolved": "https://registry.npmjs.org/osenv/-/osenv-0.1.4.tgz", + "integrity": "sha1-Qv5tWVPfBsgGS+bxdsPQWqqjRkQ=", + "dev": true, "optional": true, "requires": { "os-homedir": "1.0.2", @@ -1338,30 +6017,42 @@ }, "path-is-absolute": { "version": "1.0.1", - "bundled": true + "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", + "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=", + "dev": true }, "performance-now": { "version": "0.2.0", - "bundled": true, + "resolved": "https://registry.npmjs.org/performance-now/-/performance-now-0.2.0.tgz", + "integrity": "sha1-M+8wxcd9TqIcWlOGnZG1bY8lVeU=", + "dev": true, "optional": true }, "process-nextick-args": { "version": "1.0.7", - "bundled": true + "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-1.0.7.tgz", + "integrity": "sha1-FQ4gt1ZZCtP5EJPyWk8q2L/zC6M=", + "dev": true }, "punycode": { "version": "1.4.1", - "bundled": true, + "resolved": "https://registry.npmjs.org/punycode/-/punycode-1.4.1.tgz", + "integrity": "sha1-wNWmOycYgArY4esPpSachN1BhF4=", + "dev": true, "optional": true }, "qs": { "version": "6.4.0", - "bundled": true, + "resolved": "https://registry.npmjs.org/qs/-/qs-6.4.0.tgz", + "integrity": "sha1-E+JtKK1rD/qpExLNO/cI7TUecjM=", + "dev": true, "optional": true }, "rc": { "version": "1.2.1", - "bundled": true, + "resolved": "https://registry.npmjs.org/rc/-/rc-1.2.1.tgz", + "integrity": "sha1-LgPo5C7kULjLPc5lvhv4l04d/ZU=", + "dev": true, "optional": true, "requires": { "deep-extend": "0.4.2", @@ -1372,14 +6063,18 @@ "dependencies": { "minimist": { "version": "1.2.0", - "bundled": true, + "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.0.tgz", + "integrity": "sha1-o1AIsg9BOD7sH7kU9M1d95omQoQ=", + "dev": true, "optional": true } } }, "readable-stream": { "version": "2.2.9", - "bundled": true, + "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.2.9.tgz", + "integrity": "sha1-z3jsb0ptHrQ9JkiMrJfwQudLf8g=", + "dev": true, "requires": { "buffer-shims": "1.0.0", "core-util-is": "1.0.2", @@ -1392,7 +6087,9 @@ }, "request": { "version": "2.81.0", - "bundled": true, + "resolved": "https://registry.npmjs.org/request/-/request-2.81.0.tgz", + "integrity": "sha1-xpKJRqDgbF+Nb4qTM0af/aRimKA=", + "dev": true, "optional": true, "requires": { "aws-sign2": "0.6.0", @@ -1421,33 +6118,45 @@ }, "rimraf": { "version": "2.6.1", - "bundled": true, + "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.6.1.tgz", + "integrity": "sha1-wjOOxkPfeht/5cVPqG9XQopV8z0=", + "dev": true, "requires": { "glob": "7.1.2" } }, "safe-buffer": { "version": "5.0.1", - "bundled": true + "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.0.1.tgz", + "integrity": "sha1-0mPKVGls2KMGtcplUekt5XkY++c=", + "dev": true }, "semver": { "version": "5.3.0", - "bundled": true, + "resolved": "https://registry.npmjs.org/semver/-/semver-5.3.0.tgz", + "integrity": "sha1-myzl094C0XxgEq0yaqa00M9U+U8=", + "dev": true, "optional": true }, "set-blocking": { "version": "2.0.0", - "bundled": true, + "resolved": "https://registry.npmjs.org/set-blocking/-/set-blocking-2.0.0.tgz", + "integrity": "sha1-BF+XgtARrppoA93TgrJDkrPYkPc=", + "dev": true, "optional": true }, "signal-exit": { "version": "3.0.2", - "bundled": true, + "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.2.tgz", + "integrity": "sha1-tf3AjxKH6hF4Yo5BXiUTK3NkbG0=", + "dev": true, "optional": true }, "sntp": { "version": "1.0.9", - "bundled": true, + "resolved": "https://registry.npmjs.org/sntp/-/sntp-1.0.9.tgz", + "integrity": "sha1-ZUEYTMkK7qbG57NeJlkIJEPGYZg=", + "dev": true, "optional": true, "requires": { "hoek": "2.16.3" @@ -1455,7 +6164,9 @@ }, "sshpk": { "version": "1.13.0", - "bundled": true, + "resolved": "https://registry.npmjs.org/sshpk/-/sshpk-1.13.0.tgz", + "integrity": "sha1-/yo+T9BEl1Vf7Zezmg/YL6+zozw=", + "dev": true, "optional": true, "requires": { "asn1": "0.2.3", @@ -1471,21 +6182,27 @@ "dependencies": { "assert-plus": { "version": "1.0.0", - "bundled": true, + "resolved": "https://registry.npmjs.org/assert-plus/-/assert-plus-1.0.0.tgz", + "integrity": "sha1-8S4PPF13sLHN2RRpQuTpbB5N1SU=", + "dev": true, "optional": true } } }, "string_decoder": { "version": "1.0.1", - "bundled": true, + "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.0.1.tgz", + "integrity": "sha1-YuIA8DmVWmgQ2N8KM//A8BNmLZg=", + "dev": true, "requires": { "safe-buffer": "5.0.1" } }, "string-width": { "version": "1.0.2", - "bundled": true, + "resolved": "https://registry.npmjs.org/string-width/-/string-width-1.0.2.tgz", + "integrity": "sha1-EYvfW4zcUaKn5w0hHgfisLmxB9M=", + "dev": true, "requires": { "code-point-at": "1.1.0", "is-fullwidth-code-point": "1.0.0", @@ -1494,24 +6211,32 @@ }, "stringstream": { "version": "0.0.5", - "bundled": true, + "resolved": "https://registry.npmjs.org/stringstream/-/stringstream-0.0.5.tgz", + "integrity": "sha1-TkhM1N5aC7vuGORjB3EKioFiGHg=", + "dev": true, "optional": true }, "strip-ansi": { "version": "3.0.1", - "bundled": true, + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-3.0.1.tgz", + "integrity": "sha1-ajhfuIU9lS1f8F0Oiq+UJ43GPc8=", + "dev": true, "requires": { "ansi-regex": "2.1.1" } }, "strip-json-comments": { "version": "2.0.1", - "bundled": true, + "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-2.0.1.tgz", + "integrity": "sha1-PFMZQukIwml8DsNEhYwobHygpgo=", + "dev": true, "optional": true }, "tar": { "version": "2.2.1", - "bundled": true, + "resolved": "https://registry.npmjs.org/tar/-/tar-2.2.1.tgz", + "integrity": "sha1-jk0qJWwOIYXGsYrWlK7JaLg8sdE=", + "dev": true, "requires": { "block-stream": "0.0.9", "fstream": "1.0.11", @@ -1520,7 +6245,9 @@ }, "tar-pack": { "version": "3.4.0", - "bundled": true, + "resolved": "https://registry.npmjs.org/tar-pack/-/tar-pack-3.4.0.tgz", + "integrity": "sha1-I74tf2cagzk3bL2wuP4/3r8xeYQ=", + "dev": true, "optional": true, "requires": { "debug": "2.6.8", @@ -1535,7 +6262,9 @@ }, "tough-cookie": { "version": "2.3.2", - "bundled": true, + "resolved": "https://registry.npmjs.org/tough-cookie/-/tough-cookie-2.3.2.tgz", + "integrity": "sha1-8IH3bkyFcg5sN6X6ztc3FQ2EByo=", + "dev": true, "optional": true, "requires": { "punycode": "1.4.1" @@ -1543,7 +6272,9 @@ }, "tunnel-agent": { "version": "0.6.0", - "bundled": true, + "resolved": "https://registry.npmjs.org/tunnel-agent/-/tunnel-agent-0.6.0.tgz", + "integrity": "sha1-J6XeoGs2sEoKmWZ3SykIaPD8QP0=", + "dev": true, "optional": true, "requires": { "safe-buffer": "5.0.1" @@ -1551,26 +6282,36 @@ }, "tweetnacl": { "version": "0.14.5", - "bundled": true, + "resolved": "https://registry.npmjs.org/tweetnacl/-/tweetnacl-0.14.5.tgz", + "integrity": "sha1-WuaBd/GS1EViadEIr6k/+HQ/T2Q=", + "dev": true, "optional": true }, "uid-number": { "version": "0.0.6", - "bundled": true, + "resolved": "https://registry.npmjs.org/uid-number/-/uid-number-0.0.6.tgz", + "integrity": "sha1-DqEOgDXo61uOREnwbaHHMGY7qoE=", + "dev": true, "optional": true }, "util-deprecate": { "version": "1.0.2", - "bundled": true + "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", + "integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8=", + "dev": true }, "uuid": { "version": "3.0.1", - "bundled": true, + "resolved": "https://registry.npmjs.org/uuid/-/uuid-3.0.1.tgz", + "integrity": "sha1-ZUS7ot/ajBzxfmKaOjBeK7H+5sE=", + "dev": true, "optional": true }, "verror": { "version": "1.3.6", - "bundled": true, + "resolved": "https://registry.npmjs.org/verror/-/verror-1.3.6.tgz", + "integrity": "sha1-z/XfEpRtKX0rqu+qJoniW+AcAFw=", + "dev": true, "optional": true, "requires": { "extsprintf": "1.0.2" @@ -1578,7 +6319,9 @@ }, "wide-align": { "version": "1.1.2", - "bundled": true, + "resolved": "https://registry.npmjs.org/wide-align/-/wide-align-1.1.2.tgz", + "integrity": "sha512-ijDLlyQ7s6x1JgCLur53osjm/UXUYD9+0PbYKrBsYisYXzCxN+HC3mYDNy/dWdmf3AwqwU3CXwDCvsNgGK1S0w==", + "dev": true, "optional": true, "requires": { "string-width": "1.0.2" @@ -1586,86 +6329,17 @@ }, "wrappy": { "version": "1.0.2", - "bundled": true + "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", + "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=", + "dev": true } } }, - "fstream": { - "version": "1.0.11", - "resolved": "https://registry.npmjs.org/fstream/-/fstream-1.0.11.tgz", - "integrity": "sha1-XB+x8RdHcRTwYyoOtLcbPLD9MXE=", - "requires": { - "graceful-fs": "4.1.11", - "inherits": "2.0.3", - "mkdirp": "0.5.1", - "rimraf": "2.6.1" - } - }, - "gauge": { - "version": "2.7.4", - "resolved": "https://registry.npmjs.org/gauge/-/gauge-2.7.4.tgz", - "integrity": "sha1-LANAXHU4w51+s3sxcCLjJfsBi/c=", - "requires": { - "aproba": "1.1.2", - "console-control-strings": "1.1.0", - "has-unicode": "2.0.1", - "object-assign": "4.1.1", - "signal-exit": "3.0.2", - "string-width": "1.0.2", - "strip-ansi": "3.0.1", - "wide-align": "1.1.2" - } - }, - "gaze": { - "version": "1.1.2", - "resolved": "https://registry.npmjs.org/gaze/-/gaze-1.1.2.tgz", - "integrity": "sha1-hHIkZ3rbiHDWeSV+0ziP22HkAQU=", - "requires": { - "globule": "1.2.0" - } - }, - "get-caller-file": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-1.0.2.tgz", - "integrity": "sha1-9wLmMSfn4jHBYKgMFVSstw1QR+U=" - }, - "get-stdin": { - "version": "4.0.1", - "resolved": "https://registry.npmjs.org/get-stdin/-/get-stdin-4.0.1.tgz", - "integrity": "sha1-uWjGsKBDhDJJAui/Gl3zJXmkUP4=" - }, - "getpass": { - "version": "0.1.7", - "resolved": "https://registry.npmjs.org/getpass/-/getpass-0.1.7.tgz", - "integrity": "sha1-Xv+OPmhNVprkyysSgmBOi6YhSfo=", - "requires": { - "assert-plus": "1.0.0" - }, - "dependencies": { - "assert-plus": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/assert-plus/-/assert-plus-1.0.0.tgz", - "integrity": "sha1-8S4PPF13sLHN2RRpQuTpbB5N1SU=" - } - } - }, - "glob": { - "version": "7.1.2", - "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.2.tgz", - "integrity": "sha512-MJTUg1kjuLeQCJ+ccE4Vpa6kKVXkPYJ2mOCQyUuKLcLQsdrMCpBPUi8qVE6+YuaJkozeA9NusTAw3hLr8Xe5EQ==", - "requires": { - "fs.realpath": "1.0.0", - "inflight": "1.0.6", - "inherits": "2.0.3", - "minimatch": "3.0.4", - "once": "1.4.0", - "path-is-absolute": "1.0.1" - } - }, "glob-base": { "version": "0.3.0", "resolved": "https://registry.npmjs.org/glob-base/-/glob-base-0.3.0.tgz", "integrity": "sha1-27Fk9iIbHAscz4Kuoyi0l98Oo8Q=", + "dev": true, "requires": { "glob-parent": "2.0.0", "is-glob": "2.0.1" @@ -1675,51 +6349,16 @@ "version": "2.0.0", "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-2.0.0.tgz", "integrity": "sha1-gTg9ctsFT8zPUzbaqQLxgvbtuyg=", + "dev": true, "requires": { "is-glob": "2.0.1" } }, - "globule": { - "version": "1.2.0", - "resolved": "https://registry.npmjs.org/globule/-/globule-1.2.0.tgz", - "integrity": "sha1-HcScaCLdnoovoAuiopUAboZkvQk=", - "requires": { - "glob": "7.1.2", - "lodash": "4.17.4", - "minimatch": "3.0.4" - } - }, "graceful-fs": { "version": "4.1.11", "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.1.11.tgz", - "integrity": "sha1-Dovf5NHduIVNZOBOp8AOKgJuVlg=" - }, - "graceful-readlink": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/graceful-readlink/-/graceful-readlink-1.0.1.tgz", - "integrity": "sha1-TK+tdrxi8C+gObL5Tpo906ORpyU=" - }, - "har-schema": { - "version": "1.0.5", - "resolved": "https://registry.npmjs.org/har-schema/-/har-schema-1.0.5.tgz", - "integrity": "sha1-0mMTX0MwfALGAq/I/pWXDAFRNp4=" - }, - "har-validator": { - "version": "4.2.1", - "resolved": "https://registry.npmjs.org/har-validator/-/har-validator-4.2.1.tgz", - "integrity": "sha1-M0gdDxu/9gDdID11gSpqX7oALio=", - "requires": { - "ajv": "4.11.8", - "har-schema": "1.0.5" - } - }, - "has-ansi": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/has-ansi/-/has-ansi-2.0.0.tgz", - "integrity": "sha1-NPUEnOHs3ysGSa8+8k5F7TVBbZE=", - "requires": { - "ansi-regex": "2.1.1" - } + "integrity": "sha1-Dovf5NHduIVNZOBOp8AOKgJuVlg=", + "dev": true }, "has-flag": { "version": "1.0.0", @@ -1727,92 +6366,17 @@ "integrity": "sha1-nZ55MWXOAXoA8AQYxD+UKnsdEfo=", "dev": true }, - "has-unicode": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/has-unicode/-/has-unicode-2.0.1.tgz", - "integrity": "sha1-4Ob+aijPUROIVeCG0Wkedx3iqLk=" - }, - "hawk": { - "version": "3.1.3", - "resolved": "https://registry.npmjs.org/hawk/-/hawk-3.1.3.tgz", - "integrity": "sha1-B4REvXwWQLD+VA0sm3PVlnjo4cQ=", - "requires": { - "boom": "2.10.1", - "cryptiles": "2.0.5", - "hoek": "2.16.3", - "sntp": "1.0.9" - } - }, "he": { "version": "1.1.1", "resolved": "https://registry.npmjs.org/he/-/he-1.1.1.tgz", "integrity": "sha1-k0EP0hsAlzUVH4howvJx80J+I/0=", "dev": true }, - "hoek": { - "version": "2.16.3", - "resolved": "https://registry.npmjs.org/hoek/-/hoek-2.16.3.tgz", - "integrity": "sha1-ILt0A9POo5jpHcRxCo/xuCdKJe0=" - }, - "hosted-git-info": { - "version": "2.5.0", - "resolved": "https://registry.npmjs.org/hosted-git-info/-/hosted-git-info-2.5.0.tgz", - "integrity": "sha512-pNgbURSuab90KbTqvRPsseaTxOJCZBD0a7t+haSN33piP9cCM4l0CqdzAif2hUqm716UovKB2ROmiabGAKVXyg==" - }, - "html-encoding-sniffer": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/html-encoding-sniffer/-/html-encoding-sniffer-1.0.1.tgz", - "integrity": "sha1-eb96eF6klf5mFl5zQVPzY/9UN9o=", - "requires": { - "whatwg-encoding": "1.0.1" - } - }, - "http-signature": { - "version": "1.1.1", - "resolved": "https://registry.npmjs.org/http-signature/-/http-signature-1.1.1.tgz", - "integrity": "sha1-33LiZwZs0Kxn+3at+OE0qPvPkb8=", - "requires": { - "assert-plus": "0.2.0", - "jsprim": "1.4.0", - "sshpk": "1.13.1" - } - }, - "iconv-lite": { - "version": "0.4.13", - "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.13.tgz", - "integrity": "sha1-H4irpKsLFQjoMSrMOTRfNumS4vI=" - }, - "in-publish": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/in-publish/-/in-publish-2.0.0.tgz", - "integrity": "sha1-4g/146KvwmkDILbcVSaCqcf631E=" - }, - "indent-string": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/indent-string/-/indent-string-2.1.0.tgz", - "integrity": "sha1-ji1INIdCEhtKghi3oTfppSBJ3IA=", - "requires": { - "repeating": "2.0.1" - } - }, - "inflight": { - "version": "1.0.6", - "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", - "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", - "requires": { - "once": "1.4.0", - "wrappy": "1.0.2" - } - }, "inherits": { "version": "2.0.3", "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz", - "integrity": "sha1-Yzwsg+PaQqUC9SRmAiSA9CCCYd4=" - }, - "invert-kv": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/invert-kv/-/invert-kv-1.0.0.tgz", - "integrity": "sha1-EEqOSqym09jNFXqO+L+rLXo//bY=" + "integrity": "sha1-Yzwsg+PaQqUC9SRmAiSA9CCCYd4=", + "dev": true }, "ionicons": { "version": "3.0.0", @@ -1820,15 +6384,11 @@ "integrity": "sha1-QLja9P16MRUL0AIWD2ZJbiKpjDw=", "dev": true }, - "is-arrayish": { - "version": "0.2.1", - "resolved": "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.2.1.tgz", - "integrity": "sha1-d8mYQFJ6qOyxqLppe4BkWnqSap0=" - }, "is-binary-path": { "version": "1.0.1", "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-1.0.1.tgz", "integrity": "sha1-dfFmQrSA8YenEcgUFh/TpKdlWJg=", + "dev": true, "requires": { "binary-extensions": "1.8.0" } @@ -1836,25 +6396,20 @@ "is-buffer": { "version": "1.1.5", "resolved": "https://registry.npmjs.org/is-buffer/-/is-buffer-1.1.5.tgz", - "integrity": "sha1-Hzsm72E7IUuIy8ojzGwB2Hlh7sw=" - }, - "is-builtin-module": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/is-builtin-module/-/is-builtin-module-1.0.0.tgz", - "integrity": "sha1-VAVy0096wxGfj3bDDLwbHgN6/74=", - "requires": { - "builtin-modules": "1.1.1" - } + "integrity": "sha1-Hzsm72E7IUuIy8ojzGwB2Hlh7sw=", + "dev": true }, "is-dotfile": { "version": "1.0.3", "resolved": "https://registry.npmjs.org/is-dotfile/-/is-dotfile-1.0.3.tgz", - "integrity": "sha1-pqLzL/0t+wT1yiXs0Pa4PPeYoeE=" + "integrity": "sha1-pqLzL/0t+wT1yiXs0Pa4PPeYoeE=", + "dev": true }, "is-equal-shallow": { "version": "0.1.3", "resolved": "https://registry.npmjs.org/is-equal-shallow/-/is-equal-shallow-0.1.3.tgz", "integrity": "sha1-IjgJj8Ih3gvPpdnqxMRdY4qhxTQ=", + "dev": true, "requires": { "is-primitive": "2.0.0" } @@ -1862,46 +6417,29 @@ "is-extendable": { "version": "0.1.1", "resolved": "https://registry.npmjs.org/is-extendable/-/is-extendable-0.1.1.tgz", - "integrity": "sha1-YrEQ4omkcUGOPsNqYX1HLjAd/Ik=" + "integrity": "sha1-YrEQ4omkcUGOPsNqYX1HLjAd/Ik=", + "dev": true }, "is-extglob": { "version": "1.0.0", "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-1.0.0.tgz", - "integrity": "sha1-rEaBd8SUNAWgkvyPKXYMb/xiBsA=" - }, - "is-finite": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/is-finite/-/is-finite-1.0.2.tgz", - "integrity": "sha1-zGZ3aVYCvlUO8R6LSqYwU0K20Ko=", - "requires": { - "number-is-nan": "1.0.1" - } - }, - "is-fullwidth-code-point": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-1.0.0.tgz", - "integrity": "sha1-754xOG8DGn8NZDr4L95QxFfvAMs=", - "requires": { - "number-is-nan": "1.0.1" - } + "integrity": "sha1-rEaBd8SUNAWgkvyPKXYMb/xiBsA=", + "dev": true }, "is-glob": { "version": "2.0.1", "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-2.0.1.tgz", "integrity": "sha1-0Jb5JqPe1WAPP9/ZEZjLCIjC2GM=", + "dev": true, "requires": { "is-extglob": "1.0.0" } }, - "is-module": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/is-module/-/is-module-1.0.0.tgz", - "integrity": "sha1-Mlj7afeMFNW4FdZkM2tM/7ZEFZE=" - }, "is-number": { "version": "2.1.0", "resolved": "https://registry.npmjs.org/is-number/-/is-number-2.1.0.tgz", "integrity": "sha1-Afy7s5NGOlSPL0ZszhbezknbkI8=", + "dev": true, "requires": { "kind-of": "3.2.2" } @@ -1909,22 +6447,14 @@ "is-posix-bracket": { "version": "0.1.1", "resolved": "https://registry.npmjs.org/is-posix-bracket/-/is-posix-bracket-0.1.1.tgz", - "integrity": "sha1-MzTceXdDaOkvAW5vvAqI9c1ua8Q=" + "integrity": "sha1-MzTceXdDaOkvAW5vvAqI9c1ua8Q=", + "dev": true }, "is-primitive": { "version": "2.0.0", "resolved": "https://registry.npmjs.org/is-primitive/-/is-primitive-2.0.0.tgz", - "integrity": "sha1-IHurkWOEmcB7Kt8kCkGochADRXU=" - }, - "is-typedarray": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/is-typedarray/-/is-typedarray-1.0.0.tgz", - "integrity": "sha1-5HnICFjfDBsR3dppQPlgEfzaSpo=" - }, - "is-utf8": { - "version": "0.2.1", - "resolved": "https://registry.npmjs.org/is-utf8/-/is-utf8-0.2.1.tgz", - "integrity": "sha1-Sw2hRCEE0bM2NA6AeX6GXPOffXI=" + "integrity": "sha1-IHurkWOEmcB7Kt8kCkGochADRXU=", + "dev": true }, "is-wsl": { "version": "1.1.0", @@ -1935,163 +6465,38 @@ "isarray": { "version": "1.0.0", "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", - "integrity": "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE=" - }, - "isexe": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", - "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=" + "integrity": "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE=", + "dev": true }, "isobject": { "version": "2.1.0", "resolved": "https://registry.npmjs.org/isobject/-/isobject-2.1.0.tgz", "integrity": "sha1-8GVWEJaj8dou9GJy+BXIQNh+DIk=", + "dev": true, "requires": { "isarray": "1.0.0" } }, - "isstream": { - "version": "0.1.2", - "resolved": "https://registry.npmjs.org/isstream/-/isstream-0.1.2.tgz", - "integrity": "sha1-R+Y/evVa+m+S4VAOaQ64uFKcCZo=" - }, - "js-base64": { - "version": "2.1.9", - "resolved": "https://registry.npmjs.org/js-base64/-/js-base64-2.1.9.tgz", - "integrity": "sha1-8OgK4DmkvWVLXygfyT8EqRSn/M4=" - }, - "jsbn": { - "version": "0.1.1", - "resolved": "https://registry.npmjs.org/jsbn/-/jsbn-0.1.1.tgz", - "integrity": "sha1-peZUwuWi3rXyAdls77yoDA7y9RM=", - "optional": true - }, - "jsdom": { - "version": "11.1.0", - "resolved": "https://registry.npmjs.org/jsdom/-/jsdom-11.1.0.tgz", - "integrity": "sha512-vKKDU+Xh9O6VgzdOYf5Rmqbgp+Yz4YTBC19gaLtctXch33EmNucA395KJGGboldafPW1vv9XLuiprO4+wXfl0g==", - "requires": { - "abab": "1.0.3", - "acorn": "4.0.13", - "acorn-globals": "3.1.0", - "array-equal": "1.0.0", - "content-type-parser": "1.0.1", - "cssom": "0.3.2", - "cssstyle": "0.2.37", - "escodegen": "1.8.1", - "html-encoding-sniffer": "1.0.1", - "nwmatcher": "1.4.1", - "parse5": "3.0.2", - "pn": "1.0.0", - "request": "2.81.0", - "request-promise-native": "1.0.4", - "sax": "1.2.4", - "symbol-tree": "3.2.2", - "tough-cookie": "2.3.2", - "webidl-conversions": "4.0.1", - "whatwg-encoding": "1.0.1", - "whatwg-url": "6.1.0", - "xml-name-validator": "2.0.1" - } - }, - "json-schema": { - "version": "0.2.3", - "resolved": "https://registry.npmjs.org/json-schema/-/json-schema-0.2.3.tgz", - "integrity": "sha1-tIDIkuWaLwWVTOcnvT8qTogvnhM=" - }, - "json-stable-stringify": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/json-stable-stringify/-/json-stable-stringify-1.0.1.tgz", - "integrity": "sha1-mnWdOcXy/1A/1TAGRu1EX4jE+a8=", - "requires": { - "jsonify": "0.0.0" - } - }, - "json-stringify-safe": { - "version": "5.0.1", - "resolved": "https://registry.npmjs.org/json-stringify-safe/-/json-stringify-safe-5.0.1.tgz", - "integrity": "sha1-Epai1Y/UXxmg9s4B1lcB4sc1tus=" - }, - "jsonify": { - "version": "0.0.0", - "resolved": "https://registry.npmjs.org/jsonify/-/jsonify-0.0.0.tgz", - "integrity": "sha1-LHS27kHZPKUbe1qu6PUDYx0lKnM=" - }, - "jsprim": { - "version": "1.4.0", - "resolved": "https://registry.npmjs.org/jsprim/-/jsprim-1.4.0.tgz", - "integrity": "sha1-o7h+QCmNjDgFUtjMdiigu5WiKRg=", - "requires": { - "assert-plus": "1.0.0", - "extsprintf": "1.0.2", - "json-schema": "0.2.3", - "verror": "1.3.6" - }, - "dependencies": { - "assert-plus": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/assert-plus/-/assert-plus-1.0.0.tgz", - "integrity": "sha1-8S4PPF13sLHN2RRpQuTpbB5N1SU=" - } - } - }, "kind-of": { "version": "3.2.2", "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", + "dev": true, "requires": { "is-buffer": "1.1.5" } }, - "lcid": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/lcid/-/lcid-1.0.0.tgz", - "integrity": "sha1-MIrMr6C8SDo4Z7S28rlQYlHRuDU=", - "requires": { - "invert-kv": "1.0.0" - } - }, - "levn": { - "version": "0.3.0", - "resolved": "https://registry.npmjs.org/levn/-/levn-0.3.0.tgz", - "integrity": "sha1-OwmSTt+fCDwEkP3UwLxEIeBHZO4=", - "requires": { - "prelude-ls": "1.1.2", - "type-check": "0.3.2" - } - }, "livereload-js": { "version": "2.2.2", "resolved": "https://registry.npmjs.org/livereload-js/-/livereload-js-2.2.2.tgz", "integrity": "sha1-bIclfmSKtHW8JOoldFftzB+NC8I=", "dev": true }, - "load-json-file": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/load-json-file/-/load-json-file-1.1.0.tgz", - "integrity": "sha1-lWkFcI1YtLq0wiYbBPWfMcmTdMA=", - "requires": { - "graceful-fs": "4.1.11", - "parse-json": "2.2.0", - "pify": "2.3.0", - "pinkie-promise": "2.0.1", - "strip-bom": "2.0.0" - } - }, "lodash": { "version": "4.17.4", "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.4.tgz", - "integrity": "sha1-eCA6TRwyiuHYbcpkYONptX9AVa4=" - }, - "lodash.assign": { - "version": "4.2.0", - "resolved": "https://registry.npmjs.org/lodash.assign/-/lodash.assign-4.2.0.tgz", - "integrity": "sha1-DZnzzNem0mHRm9rrkkUAXShYCOc=" - }, - "lodash.clonedeep": { - "version": "4.5.0", - "resolved": "https://registry.npmjs.org/lodash.clonedeep/-/lodash.clonedeep-4.5.0.tgz", - "integrity": "sha1-4j8/nE+Pvd6HJSnBBxhXoIblzO8=" + "integrity": "sha1-eCA6TRwyiuHYbcpkYONptX9AVa4=", + "dev": true }, "lodash.debounce": { "version": "4.0.8", @@ -2099,68 +6504,11 @@ "integrity": "sha1-gteb/zCmfEAF/9XiUVMArZyk168=", "dev": true }, - "lodash.mergewith": { - "version": "4.6.0", - "resolved": "https://registry.npmjs.org/lodash.mergewith/-/lodash.mergewith-4.6.0.tgz", - "integrity": "sha1-FQzwoWeR9ZA7iJHqsVRgknS96lU=" - }, - "lodash.sortby": { - "version": "4.7.0", - "resolved": "https://registry.npmjs.org/lodash.sortby/-/lodash.sortby-4.7.0.tgz", - "integrity": "sha1-7dFMgk4sycHgsKG0K7UhBRakJDg=" - }, - "loud-rejection": { - "version": "1.6.0", - "resolved": "https://registry.npmjs.org/loud-rejection/-/loud-rejection-1.6.0.tgz", - "integrity": "sha1-W0b4AUft7leIcPCG0Eghz5mOVR8=", - "requires": { - "currently-unhandled": "0.4.1", - "signal-exit": "3.0.2" - } - }, - "lru-cache": { - "version": "4.1.1", - "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-4.1.1.tgz", - "integrity": "sha512-q4spe4KTfsAS1SUHLO0wz8Qiyf1+vMIAgpRYioFYDMNqKfHQbg+AVDH3i4fvpl71/P1L0dBl+fQi+P37UYf0ew==", - "requires": { - "pseudomap": "1.0.2", - "yallist": "2.1.2" - } - }, - "magic-string": { - "version": "0.19.1", - "resolved": "https://registry.npmjs.org/magic-string/-/magic-string-0.19.1.tgz", - "integrity": "sha1-FNdoATyvLsj96hakmvgvw3fnUgE=", - "requires": { - "vlq": "0.2.2" - } - }, - "map-obj": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/map-obj/-/map-obj-1.0.1.tgz", - "integrity": "sha1-2TPOuSBdgr3PSIb2dCvcK03qFG0=" - }, - "meow": { - "version": "3.7.0", - "resolved": "https://registry.npmjs.org/meow/-/meow-3.7.0.tgz", - "integrity": "sha1-cstmi0JSKCkKu/qFaJJYcwioAfs=", - "requires": { - "camelcase-keys": "2.1.0", - "decamelize": "1.2.0", - "loud-rejection": "1.6.0", - "map-obj": "1.0.1", - "minimist": "1.2.0", - "normalize-package-data": "2.4.0", - "object-assign": "4.1.1", - "read-pkg-up": "1.0.1", - "redent": "1.0.0", - "trim-newlines": "1.0.0" - } - }, "micromatch": { "version": "2.3.11", "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-2.3.11.tgz", "integrity": "sha1-hmd8l9FyCzY0MdBNDRUpO9OMFWU=", + "dev": true, "requires": { "arr-diff": "2.0.0", "array-unique": "0.2.1", @@ -2183,23 +6531,11 @@ "integrity": "sha1-WR2E02U6awtKO5343lqoEI5y5eA=", "dev": true }, - "mime-db": { - "version": "1.27.0", - "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.27.0.tgz", - "integrity": "sha1-gg9XIpa70g7CXtVeW13oaeVDbrE=" - }, - "mime-types": { - "version": "2.1.15", - "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.15.tgz", - "integrity": "sha1-pOv1BkCUVpI3uM9wBGd20J/JKu0=", - "requires": { - "mime-db": "1.27.0" - } - }, "minimatch": { "version": "3.0.4", "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", + "dev": true, "requires": { "brace-expansion": "1.1.8" } @@ -2207,22 +6543,8 @@ "minimist": { "version": "1.2.0", "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.0.tgz", - "integrity": "sha1-o1AIsg9BOD7sH7kU9M1d95omQoQ=" - }, - "mkdirp": { - "version": "0.5.1", - "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.1.tgz", - "integrity": "sha1-MAV0OOrGz3+MR2fzhkjWaX11yQM=", - "requires": { - "minimist": "0.0.8" - }, - "dependencies": { - "minimist": { - "version": "0.0.8", - "resolved": "https://registry.npmjs.org/minimist/-/minimist-0.0.8.tgz", - "integrity": "sha1-hX/Kv8M5fSYluCKCYuhqp6ARsF0=" - } - } + "integrity": "sha1-o1AIsg9BOD7sH7kU9M1d95omQoQ=", + "dev": true }, "ms": { "version": "2.0.0", @@ -2233,128 +6555,35 @@ "nan": { "version": "2.6.2", "resolved": "https://registry.npmjs.org/nan/-/nan-2.6.2.tgz", - "integrity": "sha1-5P805slf37WuzAjeZZb0NgWn20U=" - }, - "node-gyp": { - "version": "3.6.2", - "resolved": "https://registry.npmjs.org/node-gyp/-/node-gyp-3.6.2.tgz", - "integrity": "sha1-m/vlRWIoYoSDjnUOrAUpWFP6HGA=", - "requires": { - "fstream": "1.0.11", - "glob": "7.1.2", - "graceful-fs": "4.1.11", - "minimatch": "3.0.4", - "mkdirp": "0.5.1", - "nopt": "3.0.6", - "npmlog": "4.1.2", - "osenv": "0.1.4", - "request": "2.81.0", - "rimraf": "2.6.1", - "semver": "5.3.0", - "tar": "2.2.1", - "which": "1.2.14" - } - }, - "node-sass": { - "version": "4.5.3", - "resolved": "https://registry.npmjs.org/node-sass/-/node-sass-4.5.3.tgz", - "integrity": "sha1-0JydEXlkEjnRuX/8YjH9zsU+FWg=", - "requires": { - "async-foreach": "0.1.3", - "chalk": "1.1.3", - "cross-spawn": "3.0.1", - "gaze": "1.1.2", - "get-stdin": "4.0.1", - "glob": "7.1.2", - "in-publish": "2.0.0", - "lodash.assign": "4.2.0", - "lodash.clonedeep": "4.5.0", - "lodash.mergewith": "4.6.0", - "meow": "3.7.0", - "mkdirp": "0.5.1", - "nan": "2.6.2", - "node-gyp": "3.6.2", - "npmlog": "4.1.2", - "request": "2.81.0", - "sass-graph": "2.2.4", - "stdout-stream": "1.4.0" - } - }, - "nopt": { - "version": "3.0.6", - "resolved": "https://registry.npmjs.org/nopt/-/nopt-3.0.6.tgz", - "integrity": "sha1-xkZdvwirzU2zWTF/eaxopkayj/k=", - "requires": { - "abbrev": "1.1.0" - } - }, - "normalize-package-data": { - "version": "2.4.0", - "resolved": "https://registry.npmjs.org/normalize-package-data/-/normalize-package-data-2.4.0.tgz", - "integrity": "sha512-9jjUFbTPfEy3R/ad/2oNbKtW9Hgovl5O1FvFWKkKblNXoN/Oou6+9+KKohPK13Yc3/TyunyWhJp6gvRNR/PPAw==", - "requires": { - "hosted-git-info": "2.5.0", - "is-builtin-module": "1.0.0", - "semver": "5.3.0", - "validate-npm-package-license": "3.0.1" - } + "integrity": "sha1-5P805slf37WuzAjeZZb0NgWn20U=", + "dev": true, + "optional": true }, "normalize-path": { "version": "2.1.1", "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-2.1.1.tgz", "integrity": "sha1-GrKLVW4Zg2Oowab35vogE3/mrtk=", + "dev": true, "requires": { "remove-trailing-separator": "1.0.2" } }, - "npmlog": { - "version": "4.1.2", - "resolved": "https://registry.npmjs.org/npmlog/-/npmlog-4.1.2.tgz", - "integrity": "sha512-2uUqazuKlTaSI/dC8AzicUck7+IrEaOnN/e0jd3Xtt1KcGpwx30v50mL7oPyr/h9bL3E4aZccVwpwP+5W9Vjkg==", - "requires": { - "are-we-there-yet": "1.1.4", - "console-control-strings": "1.1.0", - "gauge": "2.7.4", - "set-blocking": "2.0.0" - } - }, - "number-is-nan": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/number-is-nan/-/number-is-nan-1.0.1.tgz", - "integrity": "sha1-CXtgK1NCKlIsGvuHkDGDNpQaAR0=" - }, - "nwmatcher": { - "version": "1.4.1", - "resolved": "https://registry.npmjs.org/nwmatcher/-/nwmatcher-1.4.1.tgz", - "integrity": "sha1-eumwew6oBNt+JfBctf5Al9TklJ8=" - }, - "oauth-sign": { - "version": "0.8.2", - "resolved": "https://registry.npmjs.org/oauth-sign/-/oauth-sign-0.8.2.tgz", - "integrity": "sha1-Rqarfwrq2N6unsBWV4C31O/rnUM=" - }, "object-assign": { "version": "4.1.1", "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", - "integrity": "sha1-IQmtx5ZYh8/AXLvUQsrIv7s2CGM=" + "integrity": "sha1-IQmtx5ZYh8/AXLvUQsrIv7s2CGM=", + "dev": true }, "object.omit": { "version": "2.0.1", "resolved": "https://registry.npmjs.org/object.omit/-/object.omit-2.0.1.tgz", "integrity": "sha1-Gpx0SCnznbuFjHbKNXmuKlTr0fo=", + "dev": true, "requires": { "for-own": "0.1.5", "is-extendable": "0.1.1" } }, - "once": { - "version": "1.4.0", - "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", - "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", - "requires": { - "wrappy": "1.0.2" - } - }, "opn": { "version": "5.1.0", "resolved": "https://registry.npmjs.org/opn/-/opn-5.1.0.tgz", @@ -2364,50 +6593,11 @@ "is-wsl": "1.1.0" } }, - "optionator": { - "version": "0.8.2", - "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.8.2.tgz", - "integrity": "sha1-NkxeQJ0/TWMB1sC0wFu6UBgK62Q=", - "requires": { - "deep-is": "0.1.3", - "fast-levenshtein": "2.0.6", - "levn": "0.3.0", - "prelude-ls": "1.1.2", - "type-check": "0.3.2", - "wordwrap": "1.0.0" - } - }, - "os-homedir": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/os-homedir/-/os-homedir-1.0.2.tgz", - "integrity": "sha1-/7xJiDNuDoM94MFox+8VISGqf7M=" - }, - "os-locale": { - "version": "1.4.0", - "resolved": "https://registry.npmjs.org/os-locale/-/os-locale-1.4.0.tgz", - "integrity": "sha1-IPnxeuKe00XoveWDsT0gCYA8FNk=", - "requires": { - "lcid": "1.0.0" - } - }, - "os-tmpdir": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/os-tmpdir/-/os-tmpdir-1.0.2.tgz", - "integrity": "sha1-u+Z0BseaqFxc/sdm/lc0VV36EnQ=" - }, - "osenv": { - "version": "0.1.4", - "resolved": "https://registry.npmjs.org/osenv/-/osenv-0.1.4.tgz", - "integrity": "sha1-Qv5tWVPfBsgGS+bxdsPQWqqjRkQ=", - "requires": { - "os-homedir": "1.0.2", - "os-tmpdir": "1.0.2" - } - }, "parse-glob": { "version": "3.0.4", "resolved": "https://registry.npmjs.org/parse-glob/-/parse-glob-3.0.4.tgz", "integrity": "sha1-ssN2z7EfNVE7rdFz7wu246OIORw=", + "dev": true, "requires": { "glob-base": "0.3.0", "is-dotfile": "1.0.3", @@ -2415,112 +6605,35 @@ "is-glob": "2.0.1" } }, - "parse-json": { - "version": "2.2.0", - "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-2.2.0.tgz", - "integrity": "sha1-9ID0BDTvgHQfhGkJn43qGPVaTck=", - "requires": { - "error-ex": "1.3.1" - } - }, - "parse5": { - "version": "3.0.2", - "resolved": "https://registry.npmjs.org/parse5/-/parse5-3.0.2.tgz", - "integrity": "sha1-Be/1fw70V3+xRKefi5qWemzERRA=", - "requires": { - "@types/node": "6.0.84" - } - }, - "path-exists": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-2.1.0.tgz", - "integrity": "sha1-D+tsZPD8UY2adU3V77YscCJ2H0s=", - "requires": { - "pinkie-promise": "2.0.1" - } - }, "path-is-absolute": { "version": "1.0.1", "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", - "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=" - }, - "path-parse": { - "version": "1.0.5", - "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.5.tgz", - "integrity": "sha1-PBrfhx6pzWyUMbbqK9dKD/BVxME=" - }, - "path-type": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/path-type/-/path-type-1.1.0.tgz", - "integrity": "sha1-WcRPfuSR2nBNpBXaWkBwuk+P5EE=", - "requires": { - "graceful-fs": "4.1.11", - "pify": "2.3.0", - "pinkie-promise": "2.0.1" - } - }, - "performance-now": { - "version": "0.2.0", - "resolved": "https://registry.npmjs.org/performance-now/-/performance-now-0.2.0.tgz", - "integrity": "sha1-M+8wxcd9TqIcWlOGnZG1bY8lVeU=" - }, - "pify": { - "version": "2.3.0", - "resolved": "https://registry.npmjs.org/pify/-/pify-2.3.0.tgz", - "integrity": "sha1-7RQaasBDqEnqWISY59yosVMw6Qw=" - }, - "pinkie": { - "version": "2.0.4", - "resolved": "https://registry.npmjs.org/pinkie/-/pinkie-2.0.4.tgz", - "integrity": "sha1-clVrgM+g1IqXToDnckjoDtT3+HA=" - }, - "pinkie-promise": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/pinkie-promise/-/pinkie-promise-2.0.1.tgz", - "integrity": "sha1-ITXW36ejWMBprJsXh3YogihFD/o=", - "requires": { - "pinkie": "2.0.4" - } - }, - "pn": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/pn/-/pn-1.0.0.tgz", - "integrity": "sha1-HPWjCw2AbNGPiPxBprXUrWFbO6k=" - }, - "prelude-ls": { - "version": "1.1.2", - "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.1.2.tgz", - "integrity": "sha1-IZMqVJ9eUv/ZqCf1cOBL5iqX2lQ=" + "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=", + "dev": true }, "preserve": { "version": "0.2.0", "resolved": "https://registry.npmjs.org/preserve/-/preserve-0.2.0.tgz", - "integrity": "sha1-gV7R9uvGWSb4ZbMQwHE7yzMVzks=" + "integrity": "sha1-gV7R9uvGWSb4ZbMQwHE7yzMVzks=", + "dev": true }, "process-nextick-args": { "version": "1.0.7", "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-1.0.7.tgz", - "integrity": "sha1-FQ4gt1ZZCtP5EJPyWk8q2L/zC6M=" - }, - "pseudomap": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/pseudomap/-/pseudomap-1.0.2.tgz", - "integrity": "sha1-8FKijacOYYkX7wqKw0wa5aaChrM=" - }, - "punycode": { - "version": "1.4.1", - "resolved": "https://registry.npmjs.org/punycode/-/punycode-1.4.1.tgz", - "integrity": "sha1-wNWmOycYgArY4esPpSachN1BhF4=" + "integrity": "sha1-FQ4gt1ZZCtP5EJPyWk8q2L/zC6M=", + "dev": true }, "qs": { "version": "6.4.0", "resolved": "https://registry.npmjs.org/qs/-/qs-6.4.0.tgz", - "integrity": "sha1-E+JtKK1rD/qpExLNO/cI7TUecjM=" + "integrity": "sha1-E+JtKK1rD/qpExLNO/cI7TUecjM=", + "dev": true }, "randomatic": { "version": "1.1.7", "resolved": "https://registry.npmjs.org/randomatic/-/randomatic-1.1.7.tgz", "integrity": "sha512-D5JUjPyJbaJDkuAazpVnSfVkLlpeO3wDlPROTMLGKG1zMFNFRgrciKo1ltz/AzNTkqE0HzDx655QOL51N06how==", + "dev": true, "requires": { "is-number": "3.0.0", "kind-of": "4.0.0" @@ -2530,6 +6643,7 @@ "version": "3.0.0", "resolved": "https://registry.npmjs.org/is-number/-/is-number-3.0.0.tgz", "integrity": "sha1-JP1iAaR4LPUFYcgQJ2r8fRLXEZU=", + "dev": true, "requires": { "kind-of": "3.2.2" }, @@ -2538,6 +6652,7 @@ "version": "3.2.2", "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", + "dev": true, "requires": { "is-buffer": "1.1.5" } @@ -2548,6 +6663,7 @@ "version": "4.0.0", "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-4.0.0.tgz", "integrity": "sha1-IIE989cSkosgc3hpGkUGb65y3Vc=", + "dev": true, "requires": { "is-buffer": "1.1.5" } @@ -2572,29 +6688,11 @@ } } }, - "read-pkg": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/read-pkg/-/read-pkg-1.1.0.tgz", - "integrity": "sha1-9f+qXs0pyzHAR0vKfXVra7KePyg=", - "requires": { - "load-json-file": "1.1.0", - "normalize-package-data": "2.4.0", - "path-type": "1.1.0" - } - }, - "read-pkg-up": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/read-pkg-up/-/read-pkg-up-1.0.1.tgz", - "integrity": "sha1-nWPBMnbAZZGNV/ACpX9AobZD+wI=", - "requires": { - "find-up": "1.1.2", - "read-pkg": "1.1.0" - } - }, "readable-stream": { "version": "2.3.3", "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.3.tgz", "integrity": "sha512-m+qzzcn7KUxEmd1gMbchF+Y2eIUbieUaxkWtptyHywrX0rE8QEYqPC07Vuy4Wm32/xE16NcdBctb8S0Xe/5IeQ==", + "dev": true, "requires": { "core-util-is": "1.0.2", "inherits": "2.0.3", @@ -2609,6 +6707,7 @@ "version": "2.1.0", "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-2.1.0.tgz", "integrity": "sha1-TtCtBg3zBzMAxIRANz9y0cxkLXg=", + "dev": true, "requires": { "graceful-fs": "4.1.11", "minimatch": "3.0.4", @@ -2616,19 +6715,11 @@ "set-immediate-shim": "1.0.1" } }, - "redent": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/redent/-/redent-1.0.0.tgz", - "integrity": "sha1-z5Fqsf1fHxbfsggi3W7H9zDCr94=", - "requires": { - "indent-string": "2.1.0", - "strip-indent": "1.0.1" - } - }, "regex-cache": { "version": "0.4.3", "resolved": "https://registry.npmjs.org/regex-cache/-/regex-cache-0.4.3.tgz", "integrity": "sha1-mxpsNdTQ3871cRrmUejp09cRQUU=", + "dev": true, "requires": { "is-equal-shallow": "0.1.3", "is-primitive": "2.0.0" @@ -2637,138 +6728,20 @@ "remove-trailing-separator": { "version": "1.0.2", "resolved": "https://registry.npmjs.org/remove-trailing-separator/-/remove-trailing-separator-1.0.2.tgz", - "integrity": "sha1-abBi2XhyetFNxrVrpKt3L9jXBRE=" + "integrity": "sha1-abBi2XhyetFNxrVrpKt3L9jXBRE=", + "dev": true }, "repeat-element": { "version": "1.1.2", "resolved": "https://registry.npmjs.org/repeat-element/-/repeat-element-1.1.2.tgz", - "integrity": "sha1-7wiaF40Ug7quTZPrmLT55OEdmQo=" + "integrity": "sha1-7wiaF40Ug7quTZPrmLT55OEdmQo=", + "dev": true }, "repeat-string": { "version": "1.6.1", "resolved": "https://registry.npmjs.org/repeat-string/-/repeat-string-1.6.1.tgz", - "integrity": "sha1-jcrkcOHIirwtYA//Sndihtp15jc=" - }, - "repeating": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/repeating/-/repeating-2.0.1.tgz", - "integrity": "sha1-UhTFOpJtNVJwdSf7q0FdvAjQbdo=", - "requires": { - "is-finite": "1.0.2" - } - }, - "request": { - "version": "2.81.0", - "resolved": "https://registry.npmjs.org/request/-/request-2.81.0.tgz", - "integrity": "sha1-xpKJRqDgbF+Nb4qTM0af/aRimKA=", - "requires": { - "aws-sign2": "0.6.0", - "aws4": "1.6.0", - "caseless": "0.12.0", - "combined-stream": "1.0.5", - "extend": "3.0.1", - "forever-agent": "0.6.1", - "form-data": "2.1.4", - "har-validator": "4.2.1", - "hawk": "3.1.3", - "http-signature": "1.1.1", - "is-typedarray": "1.0.0", - "isstream": "0.1.2", - "json-stringify-safe": "5.0.1", - "mime-types": "2.1.15", - "oauth-sign": "0.8.2", - "performance-now": "0.2.0", - "qs": "6.4.0", - "safe-buffer": "5.1.1", - "stringstream": "0.0.5", - "tough-cookie": "2.3.2", - "tunnel-agent": "0.6.0", - "uuid": "3.1.0" - } - }, - "request-promise-core": { - "version": "1.1.1", - "resolved": "https://registry.npmjs.org/request-promise-core/-/request-promise-core-1.1.1.tgz", - "integrity": "sha1-Pu4AssWqgyOc+wTFcA2jb4HNCLY=", - "requires": { - "lodash": "4.17.4" - } - }, - "request-promise-native": { - "version": "1.0.4", - "resolved": "https://registry.npmjs.org/request-promise-native/-/request-promise-native-1.0.4.tgz", - "integrity": "sha1-hpiOyO7kCORVefzoO/0Fs635oVU=", - "requires": { - "request-promise-core": "1.1.1", - "stealthy-require": "1.1.1", - "tough-cookie": "2.3.2" - } - }, - "require-directory": { - "version": "2.1.1", - "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz", - "integrity": "sha1-jGStX9MNqxyXbiNE/+f3kqam30I=" - }, - "require-main-filename": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/require-main-filename/-/require-main-filename-1.0.1.tgz", - "integrity": "sha1-l/cXtp1IeE9fUmpsWqj/3aBVpNE=" - }, - "resolve": { - "version": "1.3.3", - "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.3.3.tgz", - "integrity": "sha1-ZVkHw0aahoDcLeOidaj91paR8OU=", - "requires": { - "path-parse": "1.0.5" - } - }, - "rimraf": { - "version": "2.6.1", - "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.6.1.tgz", - "integrity": "sha1-wjOOxkPfeht/5cVPqG9XQopV8z0=", - "requires": { - "glob": "7.1.2" - } - }, - "rollup": { - "version": "0.41.4", - "resolved": "https://registry.npmjs.org/rollup/-/rollup-0.41.4.tgz", - "integrity": "sha1-qXBYAXYyn56thoVNf9TEbedSrvg=", - "requires": { - "source-map-support": "0.4.15" - } - }, - "rollup-plugin-commonjs": { - "version": "8.0.2", - "resolved": "https://registry.npmjs.org/rollup-plugin-commonjs/-/rollup-plugin-commonjs-8.0.2.tgz", - "integrity": "sha1-mLFYm/4ypsD2d5C2DAtJmXKv7Yk=", - "requires": { - "acorn": "4.0.13", - "estree-walker": "0.3.1", - "magic-string": "0.19.1", - "resolve": "1.3.3", - "rollup-pluginutils": "2.0.1" - } - }, - "rollup-plugin-node-resolve": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/rollup-plugin-node-resolve/-/rollup-plugin-node-resolve-3.0.0.tgz", - "integrity": "sha1-i4l8TDAw1QASd7BRSyXSygloPuA=", - "requires": { - "browser-resolve": "1.11.2", - "builtin-modules": "1.1.1", - "is-module": "1.0.0", - "resolve": "1.3.3" - } - }, - "rollup-pluginutils": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/rollup-pluginutils/-/rollup-pluginutils-2.0.1.tgz", - "integrity": "sha1-fslbNXP2VDpGpkYb2afFRFJdD8A=", - "requires": { - "estree-walker": "0.3.1", - "micromatch": "2.3.11" - } + "integrity": "sha1-jcrkcOHIirwtYA//Sndihtp15jc=", + "dev": true }, "rx": { "version": "2.3.24", @@ -2779,7 +6752,8 @@ "safe-buffer": { "version": "5.1.1", "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.1.tgz", - "integrity": "sha512-kKvNJn6Mm93gAczWVJg7wH+wGYWNrDHdWvpUmHyEsgCtIwwo3bqPtV4tR5tuPaUhTOo/kvhVwd8XwwOllGYkbg==" + "integrity": "sha512-kKvNJn6Mm93gAczWVJg7wH+wGYWNrDHdWvpUmHyEsgCtIwwo3bqPtV4tR5tuPaUhTOo/kvhVwd8XwwOllGYkbg==", + "dev": true }, "safe-json-parse": { "version": "1.0.1", @@ -2787,81 +6761,11 @@ "integrity": "sha1-PnZyPjjf3aE8mx0poeB//uSzC1c=", "dev": true }, - "sass-graph": { - "version": "2.2.4", - "resolved": "https://registry.npmjs.org/sass-graph/-/sass-graph-2.2.4.tgz", - "integrity": "sha1-E/vWPNHK8JCLn9k0dq1DpR0eC0k=", - "requires": { - "glob": "7.1.2", - "lodash": "4.17.4", - "scss-tokenizer": "0.2.3", - "yargs": "7.1.0" - } - }, - "sax": { - "version": "1.2.4", - "resolved": "https://registry.npmjs.org/sax/-/sax-1.2.4.tgz", - "integrity": "sha512-NqVDv9TpANUjFm0N8uM5GxL36UgKi9/atZw+x7YFnQ8ckwFGKrl4xX4yWtrey3UJm5nP1kUbnYgLopqWNSRhWw==" - }, - "scss-tokenizer": { - "version": "0.2.3", - "resolved": "https://registry.npmjs.org/scss-tokenizer/-/scss-tokenizer-0.2.3.tgz", - "integrity": "sha1-jrBtualyMzOCTT9VMGQRSYR85dE=", - "requires": { - "js-base64": "2.1.9", - "source-map": "0.4.4" - }, - "dependencies": { - "source-map": { - "version": "0.4.4", - "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.4.4.tgz", - "integrity": "sha1-66T12pwNyZneaAMti092FzZSA2s=", - "requires": { - "amdefine": "1.0.1" - } - } - } - }, - "semver": { - "version": "5.3.0", - "resolved": "https://registry.npmjs.org/semver/-/semver-5.3.0.tgz", - "integrity": "sha1-myzl094C0XxgEq0yaqa00M9U+U8=" - }, - "set-blocking": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/set-blocking/-/set-blocking-2.0.0.tgz", - "integrity": "sha1-BF+XgtARrppoA93TgrJDkrPYkPc=" - }, "set-immediate-shim": { "version": "1.0.1", "resolved": "https://registry.npmjs.org/set-immediate-shim/-/set-immediate-shim-1.0.1.tgz", - "integrity": "sha1-SysbJ+uAip+NzEgaWOXlb1mfP2E=" - }, - "signal-exit": { - "version": "3.0.2", - "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.2.tgz", - "integrity": "sha1-tf3AjxKH6hF4Yo5BXiUTK3NkbG0=" - }, - "sntp": { - "version": "1.0.9", - "resolved": "https://registry.npmjs.org/sntp/-/sntp-1.0.9.tgz", - "integrity": "sha1-ZUEYTMkK7qbG57NeJlkIJEPGYZg=", - "requires": { - "hoek": "2.16.3" - } - }, - "source-map": { - "version": "0.5.6", - "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.5.6.tgz", - "integrity": "sha1-dc449SvwczxafwwRjYEzSiu19BI=" - }, - "source-map-support": { - "version": "0.4.15", - "resolved": "https://registry.npmjs.org/source-map-support/-/source-map-support-0.4.15.tgz", - "integrity": "sha1-AyAt9lwG0r2MfsI2KhkwVv7407E=", - "requires": { - "source-map": "0.5.6" - } + "integrity": "sha1-SysbJ+uAip+NzEgaWOXlb1mfP2E=", + "dev": true }, "spawn-command": { "version": "0.0.2-1", @@ -2869,63 +6773,11 @@ "integrity": "sha1-YvXpRmmBwbeW3Fkpk34RycaSG9A=", "dev": true }, - "spdx-correct": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/spdx-correct/-/spdx-correct-1.0.2.tgz", - "integrity": "sha1-SzBz2TP/UfORLwOsVRlJikFQ20A=", - "requires": { - "spdx-license-ids": "1.2.2" - } - }, - "spdx-expression-parse": { - "version": "1.0.4", - "resolved": "https://registry.npmjs.org/spdx-expression-parse/-/spdx-expression-parse-1.0.4.tgz", - "integrity": "sha1-m98vIOH0DtRH++JzJmGR/O1RYmw=" - }, - "spdx-license-ids": { - "version": "1.2.2", - "resolved": "https://registry.npmjs.org/spdx-license-ids/-/spdx-license-ids-1.2.2.tgz", - "integrity": "sha1-yd96NCRZSt5r0RkA1ZZpbcBrrFc=" - }, - "sshpk": { - "version": "1.13.1", - "resolved": "https://registry.npmjs.org/sshpk/-/sshpk-1.13.1.tgz", - "integrity": "sha1-US322mKHFEMW3EwY/hzx2UBzm+M=", - "requires": { - "asn1": "0.2.3", - "assert-plus": "1.0.0", - "bcrypt-pbkdf": "1.0.1", - "dashdash": "1.14.1", - "ecc-jsbn": "0.1.1", - "getpass": "0.1.7", - "jsbn": "0.1.1", - "tweetnacl": "0.14.5" - }, - "dependencies": { - "assert-plus": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/assert-plus/-/assert-plus-1.0.0.tgz", - "integrity": "sha1-8S4PPF13sLHN2RRpQuTpbB5N1SU=" - } - } - }, - "stdout-stream": { - "version": "1.4.0", - "resolved": "https://registry.npmjs.org/stdout-stream/-/stdout-stream-1.4.0.tgz", - "integrity": "sha1-osfIWH5U2UJ+qe2zrD8s1SLfN4s=", - "requires": { - "readable-stream": "2.3.3" - } - }, - "stealthy-require": { - "version": "1.1.1", - "resolved": "https://registry.npmjs.org/stealthy-require/-/stealthy-require-1.1.1.tgz", - "integrity": "sha1-NbCYdbT/SfJqd35QmzCQoyJr8ks=" - }, "string_decoder": { "version": "1.0.3", "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.0.3.tgz", "integrity": "sha512-4AH6Z5fzNNBcH+6XDMfA/BTt87skxqJlO0lAh3Dker5zThcAxG6mKz+iGu308UKoPPQ8Dcqx/4JhujzltRa+hQ==", + "dev": true, "requires": { "safe-buffer": "5.1.1" } @@ -2936,65 +6788,6 @@ "integrity": "sha1-QpMuWYo1LQH8IuwzZ9nYTuxsmt0=", "dev": true }, - "string-width": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/string-width/-/string-width-1.0.2.tgz", - "integrity": "sha1-EYvfW4zcUaKn5w0hHgfisLmxB9M=", - "requires": { - "code-point-at": "1.1.0", - "is-fullwidth-code-point": "1.0.0", - "strip-ansi": "3.0.1" - } - }, - "stringstream": { - "version": "0.0.5", - "resolved": "https://registry.npmjs.org/stringstream/-/stringstream-0.0.5.tgz", - "integrity": "sha1-TkhM1N5aC7vuGORjB3EKioFiGHg=" - }, - "strip-ansi": { - "version": "3.0.1", - "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-3.0.1.tgz", - "integrity": "sha1-ajhfuIU9lS1f8F0Oiq+UJ43GPc8=", - "requires": { - "ansi-regex": "2.1.1" - } - }, - "strip-bom": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-2.0.0.tgz", - "integrity": "sha1-YhmoVhZSBJHzV4i9vxRHqZx+aw4=", - "requires": { - "is-utf8": "0.2.1" - } - }, - "strip-indent": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/strip-indent/-/strip-indent-1.0.1.tgz", - "integrity": "sha1-DHlipq3vp7vUrDZkYKY4VSrhoKI=", - "requires": { - "get-stdin": "4.0.1" - } - }, - "supports-color": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-2.0.0.tgz", - "integrity": "sha1-U10EXOa2Nj+kARcIRimZXp3zJMc=" - }, - "symbol-tree": { - "version": "3.2.2", - "resolved": "https://registry.npmjs.org/symbol-tree/-/symbol-tree-3.2.2.tgz", - "integrity": "sha1-rifbOPZgp64uHDt9G8KQgZuFGeY=" - }, - "tar": { - "version": "2.2.1", - "resolved": "https://registry.npmjs.org/tar/-/tar-2.2.1.tgz", - "integrity": "sha1-jk0qJWwOIYXGsYrWlK7JaLg8sdE=", - "requires": { - "block-stream": "0.0.9", - "fstream": "1.0.11", - "inherits": "2.0.3" - } - }, "tiny-lr": { "version": "1.0.5", "resolved": "https://registry.npmjs.org/tiny-lr/-/tiny-lr-1.0.5.tgz", @@ -3009,66 +6802,12 @@ "qs": "6.4.0" } }, - "tough-cookie": { - "version": "2.3.2", - "resolved": "https://registry.npmjs.org/tough-cookie/-/tough-cookie-2.3.2.tgz", - "integrity": "sha1-8IH3bkyFcg5sN6X6ztc3FQ2EByo=", - "requires": { - "punycode": "1.4.1" - } - }, - "tr46": { - "version": "0.0.3", - "resolved": "https://registry.npmjs.org/tr46/-/tr46-0.0.3.tgz", - "integrity": "sha1-gYT9NH2snNwYWZLzpmIuFLnZq2o=" - }, "tree-kill": { "version": "1.1.0", "resolved": "https://registry.npmjs.org/tree-kill/-/tree-kill-1.1.0.tgz", "integrity": "sha1-yWPc8DciiS7FnLpWnpQLcZVNFyk=", "dev": true }, - "trim-newlines": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/trim-newlines/-/trim-newlines-1.0.0.tgz", - "integrity": "sha1-WIeWa7WCpFA6QetST301ARgVphM=" - }, - "tunnel-agent": { - "version": "0.6.0", - "resolved": "https://registry.npmjs.org/tunnel-agent/-/tunnel-agent-0.6.0.tgz", - "integrity": "sha1-J6XeoGs2sEoKmWZ3SykIaPD8QP0=", - "requires": { - "safe-buffer": "5.1.1" - } - }, - "tweetnacl": { - "version": "0.14.5", - "resolved": "https://registry.npmjs.org/tweetnacl/-/tweetnacl-0.14.5.tgz", - "integrity": "sha1-WuaBd/GS1EViadEIr6k/+HQ/T2Q=", - "optional": true - }, - "type-check": { - "version": "0.3.2", - "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.3.2.tgz", - "integrity": "sha1-WITKtRLPHTVeP7eE8wgEsrUg23I=", - "requires": { - "prelude-ls": "1.1.2" - } - }, - "typescript": { - "version": "2.4.0", - "resolved": "https://registry.npmjs.org/typescript/-/typescript-2.4.0.tgz", - "integrity": "sha1-rvWo1AS+ujatM5q/B53d3/+6ht0=" - }, - "uglify-js": { - "version": "3.0.25", - "resolved": "https://registry.npmjs.org/uglify-js/-/uglify-js-3.0.25.tgz", - "integrity": "sha512-JO1XE0WZ9m6UpDkN7WCyPNAWI6EN3K0g40ekcoJKejViYmryJ0BaLxXjvra1IsAeIlJfq72scTbhl0jknsT2GA==", - "requires": { - "commander": "2.9.0", - "source-map": "0.5.6" - } - }, "url-join": { "version": "2.0.2", "resolved": "https://registry.npmjs.org/url-join/-/url-join-2.0.2.tgz", @@ -3078,39 +6817,8 @@ "util-deprecate": { "version": "1.0.2", "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", - "integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8=" - }, - "uuid": { - "version": "3.1.0", - "resolved": "https://registry.npmjs.org/uuid/-/uuid-3.1.0.tgz", - "integrity": "sha512-DIWtzUkw04M4k3bf1IcpS2tngXEL26YUD2M0tMDUpnUrz2hgzUBlD55a4FjdLGPvfHxS6uluGWvaVEqgBcVa+g==" - }, - "validate-npm-package-license": { - "version": "3.0.1", - "resolved": "https://registry.npmjs.org/validate-npm-package-license/-/validate-npm-package-license-3.0.1.tgz", - "integrity": "sha1-KAS6vnEq0zeUWaz74kdGqywwP7w=", - "requires": { - "spdx-correct": "1.0.2", - "spdx-expression-parse": "1.0.4" - } - }, - "verror": { - "version": "1.3.6", - "resolved": "https://registry.npmjs.org/verror/-/verror-1.3.6.tgz", - "integrity": "sha1-z/XfEpRtKX0rqu+qJoniW+AcAFw=", - "requires": { - "extsprintf": "1.0.2" - } - }, - "vlq": { - "version": "0.2.2", - "resolved": "https://registry.npmjs.org/vlq/-/vlq-0.2.2.tgz", - "integrity": "sha1-4xbVJXtAuGu0PLjV/qXX9U1rDKE=" - }, - "webidl-conversions": { - "version": "4.0.1", - "resolved": "https://registry.npmjs.org/webidl-conversions/-/webidl-conversions-4.0.1.tgz", - "integrity": "sha1-gBWherg+fhsxFjhIas6B2mziBqA=" + "integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8=", + "dev": true }, "websocket-driver": { "version": "0.6.5", @@ -3127,126 +6835,11 @@ "integrity": "sha1-domUmcGEtu91Q3fC27DNbLVdKec=", "dev": true }, - "whatwg-encoding": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/whatwg-encoding/-/whatwg-encoding-1.0.1.tgz", - "integrity": "sha1-PGxFGhmO567FWx7GHQkgxngBpfQ=", - "requires": { - "iconv-lite": "0.4.13" - } - }, - "whatwg-url": { - "version": "6.1.0", - "resolved": "https://registry.npmjs.org/whatwg-url/-/whatwg-url-6.1.0.tgz", - "integrity": "sha1-X8gnm5PXVIO5ztiyYjmFSEehhXg=", - "requires": { - "lodash.sortby": "4.7.0", - "tr46": "0.0.3", - "webidl-conversions": "4.0.1" - } - }, - "which": { - "version": "1.2.14", - "resolved": "https://registry.npmjs.org/which/-/which-1.2.14.tgz", - "integrity": "sha1-mofEN48D6CfOyvGs31bHNsAcFOU=", - "requires": { - "isexe": "2.0.0" - } - }, - "which-module": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/which-module/-/which-module-1.0.0.tgz", - "integrity": "sha1-u6Y8qGGUiZT/MHc2CJ47lgJsKk8=" - }, - "wide-align": { - "version": "1.1.2", - "resolved": "https://registry.npmjs.org/wide-align/-/wide-align-1.1.2.tgz", - "integrity": "sha512-ijDLlyQ7s6x1JgCLur53osjm/UXUYD9+0PbYKrBsYisYXzCxN+HC3mYDNy/dWdmf3AwqwU3CXwDCvsNgGK1S0w==", - "requires": { - "string-width": "1.0.2" - } - }, - "wordwrap": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/wordwrap/-/wordwrap-1.0.0.tgz", - "integrity": "sha1-J1hIEIkUVqQXHI0CJkQa3pDLyus=" - }, - "wrap-ansi": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-2.1.0.tgz", - "integrity": "sha1-2Pw9KE3QV5T+hJc8rs3Rz4JP3YU=", - "requires": { - "string-width": "1.0.2", - "strip-ansi": "3.0.1" - } - }, - "wrappy": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", - "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=" - }, - "xml-name-validator": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/xml-name-validator/-/xml-name-validator-2.0.1.tgz", - "integrity": "sha1-TYuPHszTQZqjYgYb7O9RXh5VljU=" - }, "xtend": { "version": "4.0.1", "resolved": "https://registry.npmjs.org/xtend/-/xtend-4.0.1.tgz", "integrity": "sha1-pcbVMr5lbiPbgg77lDofBJmNY68=", "dev": true - }, - "y18n": { - "version": "3.2.1", - "resolved": "https://registry.npmjs.org/y18n/-/y18n-3.2.1.tgz", - "integrity": "sha1-bRX7qITAhnnA136I53WegR4H+kE=" - }, - "yallist": { - "version": "2.1.2", - "resolved": "https://registry.npmjs.org/yallist/-/yallist-2.1.2.tgz", - "integrity": "sha1-HBH5IY8HYImkfdUS+TxmmaaoHVI=" - }, - "yargs": { - "version": "7.1.0", - "resolved": "https://registry.npmjs.org/yargs/-/yargs-7.1.0.tgz", - "integrity": "sha1-a6MY6xaWFyf10oT46gA+jWFU0Mg=", - "requires": { - "camelcase": "3.0.0", - "cliui": "3.2.0", - "decamelize": "1.2.0", - "get-caller-file": "1.0.2", - "os-locale": "1.4.0", - "read-pkg-up": "1.0.1", - "require-directory": "2.1.1", - "require-main-filename": "1.0.1", - "set-blocking": "2.0.0", - "string-width": "1.0.2", - "which-module": "1.0.0", - "y18n": "3.2.1", - "yargs-parser": "5.0.0" - }, - "dependencies": { - "camelcase": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-3.0.0.tgz", - "integrity": "sha1-MvxLn82vhF/N9+c7uXysImHwqwo=" - } - } - }, - "yargs-parser": { - "version": "5.0.0", - "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-5.0.0.tgz", - "integrity": "sha1-J17PDX/+Bcd+ZOfIbkzZS/DhIoo=", - "requires": { - "camelcase": "3.0.0" - }, - "dependencies": { - "camelcase": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-3.0.0.tgz", - "integrity": "sha1-MvxLn82vhF/N9+c7uXysImHwqwo=" - } - } } } } diff --git a/packages/core/src/animations/interfaces.ts b/packages/core/src/animations/interfaces.d.ts similarity index 100% rename from packages/core/src/animations/interfaces.ts rename to packages/core/src/animations/interfaces.d.ts diff --git a/packages/core/src/components/app/app.tsx b/packages/core/src/components/app/app.tsx index 2e5249e1d3..327349bd05 100644 --- a/packages/core/src/components/app/app.tsx +++ b/packages/core/src/components/app/app.tsx @@ -1,4 +1,4 @@ -import { Component, h } from '@stencil/core'; +import { Component } from '@stencil/core'; @Component({ diff --git a/packages/core/src/components/avatar/avatar.tsx b/packages/core/src/components/avatar/avatar.tsx index 5c005a505f..34707f9d25 100644 --- a/packages/core/src/components/avatar/avatar.tsx +++ b/packages/core/src/components/avatar/avatar.tsx @@ -1,4 +1,4 @@ -import { Component, h } from '@stencil/core'; +import { Component } from '@stencil/core'; /** diff --git a/packages/core/src/components/badge/badge.spec.tsx.save b/packages/core/src/components/badge/badge.spec.tsx.save deleted file mode 100644 index 1ce3d89815..0000000000 --- a/packages/core/src/components/badge/badge.spec.tsx.save +++ /dev/null @@ -1,21 +0,0 @@ -import { componentTest } from '@stencil/core'; - -const mount = componentTest.mount; - -describe('', () => { - it('contains a slot', () => { - const wrapper = mount(); - expect(wrapper.find('slot')).to.have.length(1); - }); - - it('renders slot components as direct children', () => { - const wrapper = mount( - - 5 Why hello there - - ); - - expect(wrapper.contains(5, 'Why', 'hello', 'there')).to.equal(true); - }) -}); - diff --git a/packages/core/src/components/badge/badge.tsx b/packages/core/src/components/badge/badge.tsx index 4b5f03aba1..5bc2ef1c3a 100644 --- a/packages/core/src/components/badge/badge.tsx +++ b/packages/core/src/components/badge/badge.tsx @@ -1,4 +1,4 @@ -import { Component, h } from '@stencil/core'; +import { Component } from '@stencil/core'; /** * @name Badge diff --git a/packages/core/src/components/button/button.tsx b/packages/core/src/components/button/button.tsx index d91962db0a..35cb8d15fa 100644 --- a/packages/core/src/components/button/button.tsx +++ b/packages/core/src/components/button/button.tsx @@ -1,4 +1,4 @@ -import { Component, h, Prop, CssClassObject } from '@stencil/core'; +import { Component, Element, Prop, CssClassMap } from '@stencil/core'; /** * @name Button @@ -69,7 +69,7 @@ import { Component, h, Prop, CssClassObject } from '@stencil/core'; } }) export class Button { - $el: HTMLElement; + @Element() private el: HTMLElement; @Prop() itemButton: boolean = false; @@ -166,7 +166,7 @@ export class Button { * Get the classes based on the button type * e.g. alert-button, action-sheet-button */ - getButtonClassList(buttonType: string, mode: string): string[] { + private getButtonClassList(buttonType: string, mode: string): string[] { if (!buttonType) { return []; } @@ -182,7 +182,7 @@ export class Button { * Get the classes based on the type * e.g. block, full, round, large */ - getClassList(buttonType: string, type: string, mode: string): string[] { + private getClassList(buttonType: string, type: string, mode: string): string[] { if (!type) { return []; } @@ -197,7 +197,7 @@ export class Button { * @hidden * Get the classes for the color */ - getColorClassList(color: string, buttonType: string, style: string, mode: string): string[] { + private getColorClassList(color: string, buttonType: string, style: string, mode: string): string[] { style = (buttonType !== 'bar-button' && style === 'solid') ? 'default' : style; let className = buttonType + @@ -226,7 +226,7 @@ export class Button { * Get the classes for the style * e.g. outline, clear, solid */ - getStyleClassList(buttonType: string): string[] { + private getStyleClassList(buttonType: string): string[] { let classList = [].concat( this.outline ? this.getColorClassList(this.color, buttonType, 'outline', this.mode) : [], this.clear ? this.getColorClassList(this.color, buttonType, 'clear', this.mode) : [], @@ -244,7 +244,7 @@ export class Button { * @hidden * Get the item classes for the button */ - getItemClassList(size: string) { + private getItemClassList(size: string) { let classList = [].concat( this.itemButton && !size ? 'item-button' : [] ); @@ -256,9 +256,9 @@ export class Button { * @hidden * Get the element classes to add to the child element */ - getElementClassList() { + private getElementClassList() { let classList = [].concat( - this.$el.className.length ? this.$el.className.split(' ') : [] + this.el.className.length ? this.el.className.split(' ') : [] ); return classList; @@ -278,7 +278,7 @@ export class Button { const decorator = (this.strong ? 'strong' : null); - const buttonClasses: CssClassObject = [] + const buttonClasses: CssClassMap = [] .concat( this.getButtonClassList(this.buttonType, this.mode), this.getClassList(this.buttonType, shape, this.mode), diff --git a/packages/core/src/components/buttons/buttons.tsx b/packages/core/src/components/buttons/buttons.tsx index 7d1c4efe85..78a694381c 100644 --- a/packages/core/src/components/buttons/buttons.tsx +++ b/packages/core/src/components/buttons/buttons.tsx @@ -1,4 +1,4 @@ -import { Component, h } from '@stencil/core'; +import { Component, Element } from '@stencil/core'; @Component({ @@ -8,10 +8,10 @@ import { Component, h } from '@stencil/core'; } }) export class Buttons { - $el: HTMLElement; + @Element() private el: HTMLElement; ionViewDidLoad() { - const buttons = this.$el.querySelectorAll('ion-button') as any; + const buttons = this.el.querySelectorAll('ion-button') as any; for (var i = 0; i < buttons.length; i++) { buttons[i].setAttribute('button-type', 'bar-button'); } diff --git a/packages/core/src/components/card-content/card-content.tsx b/packages/core/src/components/card-content/card-content.tsx index 5242cd8751..ce59959a12 100644 --- a/packages/core/src/components/card-content/card-content.tsx +++ b/packages/core/src/components/card-content/card-content.tsx @@ -1,4 +1,4 @@ -import { Component, h } from '@stencil/core'; +import { Component } from '@stencil/core'; @Component({ tag: 'ion-card-content', diff --git a/packages/core/src/components/card-header/card-header.tsx b/packages/core/src/components/card-header/card-header.tsx index 537e0d609c..21c1be7c07 100644 --- a/packages/core/src/components/card-header/card-header.tsx +++ b/packages/core/src/components/card-header/card-header.tsx @@ -1,4 +1,4 @@ -import { Component, h } from '@stencil/core'; +import { Component } from '@stencil/core'; @Component({ diff --git a/packages/core/src/components/card-title/card-title.tsx b/packages/core/src/components/card-title/card-title.tsx index 950a4d431e..2b7fb03eb0 100644 --- a/packages/core/src/components/card-title/card-title.tsx +++ b/packages/core/src/components/card-title/card-title.tsx @@ -1,4 +1,4 @@ -import { Component, h } from '@stencil/core'; +import { Component } from '@stencil/core'; @Component({ diff --git a/packages/core/src/components/card/card.tsx b/packages/core/src/components/card/card.tsx index a88a4ae267..41a0a34a45 100644 --- a/packages/core/src/components/card/card.tsx +++ b/packages/core/src/components/card/card.tsx @@ -1,4 +1,4 @@ -import { Component, h } from '@stencil/core'; +import { Component } from '@stencil/core'; @Component({ tag: 'ion-card', diff --git a/packages/core/src/components/chip-button/chip-button.tsx b/packages/core/src/components/chip-button/chip-button.tsx index 517970bd6c..5a32849d97 100644 --- a/packages/core/src/components/chip-button/chip-button.tsx +++ b/packages/core/src/components/chip-button/chip-button.tsx @@ -1,4 +1,4 @@ -import { Component, CssClassObject, h, Prop } from '@stencil/core'; +import { Component, CssClassMap, Element, Prop } from '@stencil/core'; @Component({ @@ -10,9 +10,9 @@ import { Component, CssClassObject, h, Prop } from '@stencil/core'; }, }) export class ChipButton { - $el: HTMLElement; - mode: string; - color: string; + @Element() private el: HTMLElement; + private mode: string; + private color: string; @Prop() href: string; @@ -31,7 +31,7 @@ export class ChipButton { * Get the classes based on the button type * e.g. alert-button, action-sheet-button */ - getButtonClassList(buttonType: string, mode: string): string[] { + private getButtonClassList(buttonType: string, mode: string): string[] { if (!buttonType) { return []; } @@ -45,7 +45,7 @@ export class ChipButton { * @hidden * Get the classes for the color */ - getColorClassList(color: string, buttonType: string, style: string, mode: string): string[] { + private getColorClassList(color: string, buttonType: string, style: string, mode: string): string[] { let className = (style === 'default') ? `${buttonType}` : `${buttonType}-${style}`; return [`${className}-${mode}`].concat( @@ -59,7 +59,7 @@ export class ChipButton { * Get the classes for the style * Chip buttons can only be clear or default (solid) */ - getStyleClassList(buttonType: string): string[] { + private getStyleClassList(buttonType: string): string[] { let classList = [].concat( this.clear ? this.getColorClassList(this.color, buttonType, 'clear', this.mode) : [] ); @@ -75,9 +75,9 @@ export class ChipButton { * @hidden * Get the element classes to add to the child element */ - getElementClassList() { + private getElementClassList() { let classList = [].concat( - this.$el.className.length ? this.$el.className.split(' ') : [] + this.el.className.length ? this.el.className.split(' ') : [] ); return classList; @@ -86,7 +86,7 @@ export class ChipButton { render() { const buttonType = 'chip-button'; - var buttonClasses: CssClassObject = [] + var buttonClasses: CssClassMap = [] .concat( this.getButtonClassList(buttonType, this.mode), this.getElementClassList(), diff --git a/packages/core/src/components/chip/chip.tsx b/packages/core/src/components/chip/chip.tsx index 0a5d22b188..95289139a5 100644 --- a/packages/core/src/components/chip/chip.tsx +++ b/packages/core/src/components/chip/chip.tsx @@ -1,4 +1,4 @@ -import { Component, h } from '@stencil/core'; +import { Component } from '@stencil/core'; /** * @name Chip diff --git a/packages/core/src/components/content/content.tsx b/packages/core/src/components/content/content.tsx index d42111d5c0..91a0c37b0c 100644 --- a/packages/core/src/components/content/content.tsx +++ b/packages/core/src/components/content/content.tsx @@ -1,8 +1,7 @@ -import { Component, h, Ionic, Prop } from '@stencil/core'; +import { Component, Element, Prop } from '@stencil/core'; +import { Scroll, ScrollDetail } from '../../index'; import { createThemedClasses } from '../../utils/theme'; import { getParentElement, getToolbarHeight } from '../../utils/helpers'; -import { Scroll } from '../scroll/scroll-interface'; -import { ScrollDetail } from '../../utils/interfaces'; @Component({ @@ -16,7 +15,8 @@ import { ScrollDetail } from '../../utils/interfaces'; export class Content { private mode: string; private color: string; - $el: HTMLElement; + @Element() private el: HTMLElement; + $scroll: Scroll; $scrollDetail: ScrollDetail = {}; $fixed: HTMLElement; @@ -81,7 +81,7 @@ export class Content { const props: any = {}; const scrollStyle: any = {}; - const pageChildren: HTMLElement[] = getParentElement(this.$el).children; + const pageChildren: HTMLElement[] = getParentElement(this.el).children; const headerHeight = getToolbarHeight('ION-HEADER', pageChildren, this.mode, '44px', '56px'); const footerHeight = getToolbarHeight('ION-FOOTER', pageChildren, this.mode, '50px', '48px'); diff --git a/packages/core/src/components/core-hn/main.scss b/packages/core/src/components/core-hn/main.scss deleted file mode 100644 index 88b9a9d8f1..0000000000 --- a/packages/core/src/components/core-hn/main.scss +++ /dev/null @@ -1,121 +0,0 @@ -ion-label { - white-space: normal !important; -} - -ion-toolbar ion-button.header-button button { - color: white !important; -} - -.points { - color: #327eff; - font-weight: bold; - width: 45px; -} - -.header-icon { - color: white; - font-size: 3.4rem !important; - margin-left: 15px !important; - width: 3.4rem; -} - -.page-number { - line-height: 3; -} - -.pager { - text-align: center; -} - -ion-footer ion-toolbar div.toolbar-background { - background: white; -} - -ion-footer { - height: 48px; -} - -ion-footer ion-toolbar { - min-height: 48px !important; -} - -.comments-text { - color: #717883; - cursor: pointer; -} - -.list-header a { - color: #202939; - text-decoration: none; -} - -.item-content { - padding-top: 5px; - padding-bottom: 5px; -} - -.comments-title { - line-height: 2.1; -} - -.header-button { - width: 7rem; - opacity: 1; -} - -.header-button-selected { - opacity: 1 !important; -} - -.header-button-selected button { - font-weight: bold; - opacity: 1 !important; -} - -.no-select { - opacity: 0.6 !important; -} - -.tabs-bar { - display: flex; - line-height: 2.4; -} - -.no-back button { - opacity: 0.3; -} - -.yes-back button { - opacity: 1; - color: #327eff !important; -} - -.close-button ion-icon { - color: white; - font-size: 2.3rem; - margin-left: 15px; -} - -.ionic-icon { - height: 40px; - float: left; - margin-left: 10px; -} - -ion-toolbar.toolbar-ios .ionic-icon { - margin-right: 10px; -} - -ion-list.nested-comments { - margin-left: 30px; -} - -@media(max-width: 330px) { - .header-button { - width: 6.3rem; - } - - ion-toolbar.toolbar-ios .ionic-icon { - margin-right: 13px; - } -} \ No newline at end of file diff --git a/packages/core/src/components/fab/fab-container.tsx b/packages/core/src/components/fab/fab-container.tsx index c915da03d2..7f0ee9680c 100644 --- a/packages/core/src/components/fab/fab-container.tsx +++ b/packages/core/src/components/fab/fab-container.tsx @@ -1,4 +1,4 @@ -import { Component, h, Method } from '@stencil/core'; +import { Component, Element, Method } from '@stencil/core'; /** @@ -87,14 +87,14 @@ import { Component, h, Method } from '@stencil/core'; tag: 'ion-fab', }) export class FabContainer { - $el: HTMLElement; + @Element() private el: HTMLElement; /** * Close an active FAB list container */ @Method() close() { - const fab: any = this.$el.querySelector('ion-fab-button'); + const fab: any = this.el.querySelector('ion-fab-button'); fab.close(); } diff --git a/packages/core/src/components/fab/fab-list.tsx b/packages/core/src/components/fab/fab-list.tsx index aa576ca3f6..4b96e83aab 100644 --- a/packages/core/src/components/fab/fab-list.tsx +++ b/packages/core/src/components/fab/fab-list.tsx @@ -1,6 +1,4 @@ -import { Component, h, PropDidChange, State, VNodeData } from '@stencil/core'; - -import { HostElement } from '../../utils/interfaces'; +import { Component, Element, PropDidChange, State } from '@stencil/core'; /** @@ -31,13 +29,13 @@ import { HostElement } from '../../utils/interfaces'; tag: 'ion-fab-list', }) export class FabList { - $el: HTMLElement; + @Element() private el: HTMLElement; - @State() activated: boolean = false; + @State() private activated: boolean = false; @PropDidChange('activated') activatedChange(activated: boolean) { - const fabs = this.$el.querySelectorAll('ion-fab-button') as NodeListOf; + const fabs = this.el.querySelectorAll('ion-fab-button') as NodeListOf; // if showing the fabs add a timeout, else show immediately var timeout = activated ? 30 : 0; @@ -47,7 +45,7 @@ export class FabList { } } - hostData(): VNodeData { + hostData() { return { class: { 'fab-list-active': this.activated diff --git a/packages/core/src/components/fab/fab.tsx b/packages/core/src/components/fab/fab.tsx index b2e73cb399..d9e64de89e 100755 --- a/packages/core/src/components/fab/fab.tsx +++ b/packages/core/src/components/fab/fab.tsx @@ -1,7 +1,5 @@ -import { Component, CssClassObject, h, Method, Prop, State } from '@stencil/core'; - +import { Component, Element, CssClassMap, Method, Prop, State } from '@stencil/core'; import { createThemedClasses } from '../../utils/theme'; -import { HostElement } from '../../utils/interfaces'; /** @@ -58,29 +56,24 @@ import { HostElement } from '../../utils/interfaces'; } }) export class FabButton { - $el: HTMLElement; - mode: string; - color: string; - - @State() activated: boolean = false; - - @State() closeActivated: boolean = false; - - @State() show: boolean = false; - - @State() inContainer: boolean = false; - - @State() inList: boolean = false; + @Element() private el: HTMLElement; + private mode: string; + private color: string; @Prop() href: string; + @State() private activated: boolean = false; + @State() private show: boolean = false; + @State() private inContainer: boolean = false; + @State() private inList: boolean = false; + /** * @Prop {boolean} If true, sets the button into a disabled state. */ @Prop() disabled: boolean = false; ionViewDidLoad() { - const parentNode = this.$el.parentNode.nodeName; + const parentNode = this.el.parentNode.nodeName; this.inList = (parentNode === 'ION-FAB-LIST'); this.inContainer = (parentNode === 'ION-FAB'); @@ -97,7 +90,7 @@ export class FabButton { * @hidden */ setActiveLists(activated: boolean) { - const lists = this.$el.parentElement.querySelectorAll('ion-fab-list') as NodeListOf; + const lists = this.el.parentElement.querySelectorAll('ion-fab-list') as NodeListOf; if (lists.length > 0) { this.activated = activated; @@ -123,7 +116,7 @@ export class FabButton { */ getElementClassList() { let classList = [].concat( - this.$el.className.length ? this.$el.className.split(' ') : [] + this.el.className.length ? this.el.className.split(' ') : [] ); return classList; @@ -172,7 +165,7 @@ export class FabButton { render() { const themedClasses = createThemedClasses(this.mode, this.color, 'fab'); - var fabClasses: CssClassObject = [] + var fabClasses: CssClassMap = [] .concat( this.getElementClassList(), this.getFabListClassList(), diff --git a/packages/core/src/components/fixed/fixed.tsx b/packages/core/src/components/fixed/fixed.tsx index 4b39816ac1..8475752803 100644 --- a/packages/core/src/components/fixed/fixed.tsx +++ b/packages/core/src/components/fixed/fixed.tsx @@ -1,4 +1,4 @@ -import { Component, h, Ionic, VNodeData } from '@stencil/core'; +import { Component, Element } from '@stencil/core'; import { getParentElement, getToolbarHeight } from '../../utils/helpers'; @@ -7,11 +7,11 @@ import { getParentElement, getToolbarHeight } from '../../utils/helpers'; styleUrl: 'fixed.scss' }) export class Fixed { - $el: HTMLElement; + @Element() private el: HTMLElement; mode: string; - hostData(): VNodeData { - const pageChildren: HTMLElement[] = getParentElement(this.$el).children; + hostData() { + const pageChildren: HTMLElement[] = getParentElement(this.el).children; const headerHeight = getToolbarHeight('ION-HEADER', pageChildren, this.mode, '44px', '56px'); const footerHeight = getToolbarHeight('ION-FOOTER', pageChildren, this.mode, '50px', '48px'); diff --git a/packages/core/src/components/footer/footer.tsx b/packages/core/src/components/footer/footer.tsx index c8dce1a3e4..4496d0666a 100644 --- a/packages/core/src/components/footer/footer.tsx +++ b/packages/core/src/components/footer/footer.tsx @@ -1,4 +1,4 @@ -import { Component, h } from '@stencil/core'; +import { Component } from '@stencil/core'; @Component({ diff --git a/packages/core/src/components/fractal-tree/fractal-tree.tsx b/packages/core/src/components/fractal-tree/fractal-tree.tsx deleted file mode 100644 index 85e9e30990..0000000000 --- a/packages/core/src/components/fractal-tree/fractal-tree.tsx +++ /dev/null @@ -1,72 +0,0 @@ -import { Component, h, State } from '@stencil/core'; - -declare var d3: any; - -@Component({ - tag: 'fractal-tree' -}) -export class NewsContainer { - - svg: any = { - width: 1280, - height: 600 - }; - running = false; - realMax = 11; - mainSvg: Element; - - @State() currentMax: number = 0; - @State() baseW: number = 80; - @State() heightFactor: number = 0; - @State() lean: number = 0; - - - ionViewDidLoad() { - this.mainSvg = document.querySelector('#mainSvg'); - d3.select(this.mainSvg).on('mousemove', this.onMouseMove.bind(this)); - - this.next(); - } - - next() { - if (this.currentMax < this.realMax) { - this.currentMax = this.currentMax + 1; - setTimeout(this.next.bind(this), 500); - } - } - - onMouseMove() { - if (this.running) return; - this.running = true; - - const [x, y] = d3.mouse(this.mainSvg), - - scaleFactor = d3.scaleLinear().domain([this.svg.height, 0]) - .range([0, .8]), - - scaleLean = d3.scaleLinear().domain([0, this.svg.width / 2, this.svg.width]) - .range([.5, 0, -.5]); - - this.heightFactor = scaleFactor(y); - this.lean = scaleLean(x); - this.running = false; - } - - render() { - return ( - - - - - - ); - } -} diff --git a/packages/core/src/components/fractal-tree/pythagoras.tsx b/packages/core/src/components/fractal-tree/pythagoras.tsx deleted file mode 100644 index 0d0fa88726..0000000000 --- a/packages/core/src/components/fractal-tree/pythagoras.tsx +++ /dev/null @@ -1,110 +0,0 @@ -import { Component, h, Prop } from '@stencil/core'; - -declare var d3: any; - -@Component({ - tag: 'pythagoras-node' -}) -export class Pythagoras { - - nextRight: number; - nextLeft: number; - A: number; - B: number; - rotate: string; - - @Prop() w: number; - @Prop() x: number; - @Prop() y: number; - @Prop() heightFactor: number; - @Prop() lean: number; - @Prop() left: number; - @Prop() right: number; - @Prop() lvl: number; - @Prop() maxlvl: number; - - deg(radians: any) { - return radians * (180 / Math.PI); - } - - memoizedCalc(args: any) { - const memo: any = {}; - - // const key = ({ this.w, this.heightFactor, this.lean }) => [this.w, this.heightFactor, this.lean].join('-'); - const key = [args.w, args.heightFactor, args.lean].join('-'); - - const memoKey = key; - - if (memo[memoKey]) { - return memo[memoKey]; - } else { - const { w, heightFactor, lean } = args; - - const trigH = heightFactor * w; - - const result = { - nextRight: Math.sqrt(trigH ** 2 + (w * (.5 + lean)) ** 2), - nextLeft: Math.sqrt(trigH ** 2 + (w * (.5 - lean)) ** 2), - A: this.deg(Math.atan(trigH / ((.5 - lean) * w))), - B: this.deg(Math.atan(trigH / ((.5 + lean) * w))) - }; - - memo[memoKey] = result; - return result; - } - } - - calculate(): any { - if (this.lvl >= this.maxlvl || this.w < 1) { - return null; - } - - const memoizedValue = this.memoizedCalc({ - w: this.w, - heightFactor: this.heightFactor, - lean: this.lean - }); - - this.nextRight = memoizedValue.nextRight; - this.nextLeft = memoizedValue.nextLeft; - this.A = memoizedValue.A; - this.B = memoizedValue.B; - - this.rotate = ''; - - if (this.left) { - this.rotate = `rotate(${-this.A} 0 ${this.w})`; - } else if (this.right) { - this.rotate = `rotate(${this.B} ${this.w} ${this.w})`; - } - } - - ionViewWillUpdate() { - this.calculate(); - } - - render() { - return ( - - - - - - - - - ); - } -} diff --git a/packages/core/src/components/gesture/gesture.tsx b/packages/core/src/components/gesture/gesture.tsx index 9807bf996b..b4ea0d2bdf 100644 --- a/packages/core/src/components/gesture/gesture.tsx +++ b/packages/core/src/components/gesture/gesture.tsx @@ -1,7 +1,6 @@ import { applyStyles, getElementReference, pointerCoordX, pointerCoordY } from '../../utils/helpers'; import { BlockerDelegate } from './gesture-controller'; -import { Component, Ionic, Listen, Prop, PropDidChange } from '@stencil/core'; -import { GestureCallback, GestureDetail, GlobalNamespace } from '../../utils/interfaces'; +import { Component, Element, Event, EventEmitter, Listen, Prop, PropDidChange } from '@stencil/core'; import { GestureController, GestureDelegate, BLOCK_ALL } from './gesture-controller'; import { PanRecognizer } from './recognizers'; @@ -10,7 +9,7 @@ import { PanRecognizer } from './recognizers'; tag: 'ion-gesture' }) export class Gesture { - private $el: HTMLElement; + @Element() private el: HTMLElement; private ctrl: GestureController; private detail: GestureDetail = {}; private positions: number[] = []; @@ -24,6 +23,12 @@ export class Gesture { private isMoveQueued = false; private blocker: BlockerDelegate; + @Event() private ionGestureMove: EventEmitter; + @Event() private ionGestureStart: EventEmitter; + @Event() private ionGestureEnd: EventEmitter; + @Event() private ionGestureNotCaptured: EventEmitter; + @Event() private ionPress: EventEmitter; + @Prop() attachTo: string = 'child'; @Prop() autoBlockAll: boolean = false; @Prop() block: string = null; @@ -44,7 +49,7 @@ export class Gesture { ionViewDidLoad() { - this.ctrl = (Ionic as GlobalNamespace).controllers.gesture = ((Ionic as GlobalNamespace).controllers.gesture || new GestureController()); + this.ctrl = Ionic.controllers.gesture = (Ionic.controllers.gesture || new GestureController()); this.gesture = this.ctrl.createGesture(this.gestureName, this.gesturePriority, this.disableScroll); @@ -57,11 +62,11 @@ export class Gesture { this.hasPress = (types.indexOf('press') > -1); if (this.pan || this.hasPress) { - Ionic.listener.enable(this, 'touchstart', true, this.attachTo); - Ionic.listener.enable(this, 'mousedown', true, this.attachTo); + Core.enableListener(this, 'touchstart', true, this.attachTo); + Core.enableListener(this, 'mousedown', true, this.attachTo); - Ionic.dom.write(() => { - applyStyles(getElementReference(this.$el, this.attachTo), GESTURE_INLINE_STYLES); + Core.dom.write(() => { + applyStyles(getElementReference(this.el, this.attachTo), GESTURE_INLINE_STYLES); }); } @@ -78,7 +83,7 @@ export class Gesture { this.blocker.destroy(); } if (block) { - this.blocker = this.ctrl.createBlocker(block.split(',')); + this.blocker = this.ctrl.createBlocker({ disable: block.split(',')}); } } @@ -178,14 +183,14 @@ export class Gesture { if (!this.isMoveQueued) { this.isMoveQueued = true; - Ionic.dom.write(() => { + Core.dom.write(() => { this.isMoveQueued = false; detail.type = 'pan'; if (this.onMove) { this.onMove(detail); } else { - Ionic.emit(this, 'ionGestureMove', { detail: this.detail }); + this.ionGestureMove.emit(this.detail); } }); } @@ -249,7 +254,7 @@ export class Gesture { if (this.onStart) { this.onStart(this.detail); } else { - Ionic.emit(this, 'ionGestureStart', { detail: this.detail }); + this.ionGestureStart.emit(this.detail); } this.hasCapturedPan = true; @@ -306,7 +311,7 @@ export class Gesture { if (this.onEnd) { this.onEnd(detail); } else { - Ionic.emit(this, 'ionGestureEnd', { detail: detail }); + this.ionGestureEnd.emit(detail); } } else if (this.hasPress) { @@ -316,7 +321,7 @@ export class Gesture { if (this.notCaptured) { this.notCaptured(detail); } else { - Ionic.emit(this, 'ionGestureNotCaptured', { detail: detail }); + this.ionGestureNotCaptured.emit(detail); } } @@ -338,7 +343,7 @@ export class Gesture { if (this.onPress) { this.onPress(detail); } else { - Ionic.emit(this, 'ionPress', { detail: detail }); + this.ionPress.emit(detail); } } } @@ -348,17 +353,17 @@ export class Gesture { private enableMouse(shouldEnable: boolean) { if (this.requiresMove) { - Ionic.listener.enable(this, 'document:mousemove', shouldEnable); + Core.enableListener(this, 'document:mousemove', shouldEnable); } - Ionic.listener.enable(this, 'document:mouseup', shouldEnable); + Core.enableListener(this, 'document:mouseup', shouldEnable); } private enableTouch(shouldEnable: boolean) { if (this.requiresMove) { - Ionic.listener.enable(this, 'touchmove', shouldEnable); + Core.enableListener(this, 'touchmove', shouldEnable); } - Ionic.listener.enable(this, 'touchend', shouldEnable); + Core.enableListener(this, 'touchend', shouldEnable); } @@ -394,3 +399,27 @@ function now(ev: UIEvent) { return ev.timeStamp || Date.now(); } + +export interface GestureDetail { + type?: string; + event?: UIEvent; + startX?: number; + startY?: number; + startTimeStamp?: number; + currentX?: number; + currentY?: number; + velocityX?: number; + velocityY?: number; + deltaX?: number; + deltaY?: number; + directionX?: 'left'|'right'; + directionY?: 'up'|'down'; + velocityDirectionX?: 'left'|'right'; + velocityDirectionY?: 'up'|'down'; + timeStamp?: number; +} + + +export interface GestureCallback { + (detail?: GestureDetail): boolean|void; +} diff --git a/packages/core/src/components/header/header.tsx b/packages/core/src/components/header/header.tsx index 869a692e28..2bddb5c997 100644 --- a/packages/core/src/components/header/header.tsx +++ b/packages/core/src/components/header/header.tsx @@ -1,4 +1,4 @@ -import { Component, h } from '@stencil/core'; +import { Component } from '@stencil/core'; @Component({ diff --git a/packages/core/src/components/icon/icon.tsx b/packages/core/src/components/icon/icon.tsx index c9bdb4c09d..60c8af183d 100644 --- a/packages/core/src/components/icon/icon.tsx +++ b/packages/core/src/components/icon/icon.tsx @@ -1,6 +1,4 @@ -import { Component, h, Prop, State, VNodeData } from '@stencil/core'; - -declare const publicPath: string; +import { Component, Prop, State } from '@stencil/core'; @Component({ @@ -61,32 +59,39 @@ export class Icon { let iconName = this.name.toLowerCase(); + // default to "md" if somehow the mode wasn't set + const mode = this.mode || 'md'; + + if (!(/^md-|^ios-|^logo-/.test(iconName))) { + // this does not have one of the defaults + // so lets auto add in the mode prefix for them + iconName = mode + '-' + iconName; + + } else if (this.ios && mode === 'ios') { + // if an icon was passed in using the ios or md attributes + // set the iconName to whatever was passed in + // when we're also on that mode + // basically, use the ios attribute when you're on ios + iconName = this.ios; + + } else if (this.md && mode === 'md') { + // use the md attribute when you're in md mode + // and the md attribute has been set + iconName = this.md; + } + + // only allow alpha characters and dash const invalidChars = iconName.replace(/[a-z]|-/g, ''); if (invalidChars !== '') { console.error(`invalid characters in ion-icon name: ${invalidChars}`); return null; } - if (!(/^md-|^ios-|^logo-/.test(iconName))) { - // this does not have one of the defaults - // so lets auto add in the mode prefix for them - iconName = this.mode + '-' + iconName; - } - - // if an icon was passed in using the ios or md attributes - // set the iconName to whatever was passed in - if (this.ios && this.mode === 'ios') { - iconName = this.ios; - - } else if (this.md && this.mode === 'md') { - iconName = this.md; - } - return iconName; } - hostData(): VNodeData { + hostData() { const attrs: {[attrName: string]: string} = { 'role': 'img' }; @@ -128,6 +133,7 @@ export class Icon { // add this url to our list of active requests IonIcon.activeRequests[svgUrl] = true; + // kick off the request for the external svg file const xhr = new XMLHttpRequest(); xhr.addEventListener('load', function() { // awesome, we've finished loading the svg file @@ -139,12 +145,12 @@ export class Icon { let svgContent = this.responseText; if (this.status >= 400) { - // ok, not awesome, something is up + // umm, not awesome, something is up console.error('Icon could not be loaded:', svgUrl); - svgContent = ``; + svgContent = ``; } - // cache it in the global IonIcon constant + // cache the svg content in the global IonIcon constant IonIcon.svgContents[svgUrl] = svgContent; // find any callbacks waiting on this url @@ -152,7 +158,7 @@ export class Icon { if (svgLoadCallbacks) { // loop through all the callbacks that are waiting on the svg content for (var i = 0; i < svgLoadCallbacks.length; i++) { - // fire off this callback which + // fire off this callback which was provided by an instance svgLoadCallbacks[i](svgContent); } delete IonIcon.loadCallbacks[svgUrl]; diff --git a/packages/core/src/components/item-divider/item-divider.tsx b/packages/core/src/components/item-divider/item-divider.tsx index 2a5cf322b6..e8c19301f5 100644 --- a/packages/core/src/components/item-divider/item-divider.tsx +++ b/packages/core/src/components/item-divider/item-divider.tsx @@ -1,4 +1,4 @@ -import { Component, h } from '@stencil/core'; +import { Component } from '@stencil/core'; @Component({ diff --git a/packages/core/src/components/item-sliding/item-option.tsx b/packages/core/src/components/item-sliding/item-option.tsx index 6ee02fd410..5b75d586c6 100644 --- a/packages/core/src/components/item-sliding/item-option.tsx +++ b/packages/core/src/components/item-sliding/item-option.tsx @@ -1,7 +1,7 @@ -import { Component, CssClassObject, h, Method, Prop, State } from '@stencil/core'; - +import { Component, Prop } from '@stencil/core'; import { createThemedClasses } from '../../utils/theme'; + /** * @name ItemOption * @description @@ -23,7 +23,7 @@ export class ItemOption { */ @Prop() disabled: boolean = false; - notCaptured(ev: any) { + notCaptured() { // if (!clickedOptionButton(ev)) { // this.closeOpened(); // } diff --git a/packages/core/src/components/item-sliding/item-options.tsx b/packages/core/src/components/item-sliding/item-options.tsx index 7e40eb7d06..3e55737c04 100644 --- a/packages/core/src/components/item-sliding/item-options.tsx +++ b/packages/core/src/components/item-sliding/item-options.tsx @@ -1,5 +1,4 @@ -import { Component, h, Ionic, Prop } from '@stencil/core'; - +import { Component, Element, Prop } from '@stencil/core'; import { isRightSide, Side } from '../../utils/helpers'; @@ -28,7 +27,7 @@ import { isRightSide, Side } from '../../utils/helpers'; tag: 'ion-item-options' }) export class ItemOptions { - $el: HTMLElement; + @Element() private el: HTMLElement; /** * @input {string} The side the option button should be on. Defaults to `"right"`. @@ -39,7 +38,7 @@ export class ItemOptions { /** * @output {event} Emitted when the item has been fully swiped. */ - // @Output() ionSwipe: EventEmitter = new EventEmitter(); + // @Event() ionSwipe: EventEmitter; /** * @hidden @@ -49,18 +48,11 @@ export class ItemOptions { return isRightSide(this.side, isRTL, true); } - /** - * @output {event} Emitted when the item has been fully swiped. - */ - ionSwipe(itemSliding: any) { - Ionic.emit(itemSliding, 'ionSwipe'); - } - /** * @hidden */ width(): number { - return this.$el.offsetWidth; + return this.el.offsetWidth; } render() { diff --git a/packages/core/src/components/item-sliding/item-sliding.tsx b/packages/core/src/components/item-sliding/item-sliding.tsx index 9ceb183bf5..cabf83d3d4 100644 --- a/packages/core/src/components/item-sliding/item-sliding.tsx +++ b/packages/core/src/components/item-sliding/item-sliding.tsx @@ -1,6 +1,6 @@ -import { Component, h, Ionic, Method, State } from '@stencil/core'; +import { Component, Element, Event, EventEmitter, HostElement, Method, State } from '@stencil/core'; -import { GestureDetail, HostElement } from '../../utils/interfaces'; +import { GestureDetail } from '../../index'; import { swipeShouldReset } from '../../utils/helpers'; // import { ItemOptions } from './item-options'; @@ -135,32 +135,33 @@ const enum SlidingState { } }) export class ItemSliding { - $el: HTMLElement; - item: HostElement; - list: HostElement; + @Element() private el: HTMLElement; - openAmount: number = 0; - startX: number = 0; - optsWidthRightSide: number = 0; - optsWidthLeftSide: number = 0; - sides: number; - tmr: any = null; + private item: HostElement; + private list: HostElement; + + private openAmount: number = 0; + private startX: number = 0; + private optsWidthRightSide: number = 0; + private optsWidthLeftSide: number = 0; + private sides: number; + private tmr: any = null; // TODO file with item sliding interfaces & item options implement // leftOptions: ItemOptions; // rightOptions: ItemOptions; - leftOptions: any; - rightOptions: any; + private leftOptions: any; + private rightOptions: any; - optsDirty: boolean = true; + private optsDirty: boolean = true; @State() state: SlidingState = SlidingState.Disabled; - preSelectedContainer: ItemSliding = null; - selectedContainer: ItemSliding = null; + private preSelectedContainer: ItemSliding = null; + private selectedContainer: ItemSliding = null; openContainer: ItemSliding = null; - firstCoordX: number; - firstTimestamp: number; + private firstCoordX: number; + private firstTimestamp: number; /** * @output {event} Emitted when the sliding position changes. @@ -183,12 +184,10 @@ export class ItemSliding { * ``` * */ - ionDrag() { - Ionic.emit(this, 'ionDrag'); - } + @Event() ionDrag: EventEmitter; ionViewDidLoad() { - const options = this.$el.querySelectorAll('ion-item-options') as NodeListOf; + const options = this.el.querySelectorAll('ion-item-options') as NodeListOf; let sides = 0; @@ -209,10 +208,10 @@ export class ItemSliding { this.optsDirty = true; this.sides = sides; - this.item = this.$el.querySelector('ion-item') as HostElement; + this.item = this.el.querySelector('ion-item') as HostElement; // Get the parent list to close open containers - this.list = this.$el.closest('ion-list') as HostElement; + this.list = this.el.closest('ion-list') as HostElement; } canStart(gesture: GestureDetail): boolean { @@ -422,7 +421,7 @@ export class ItemSliding { } this.item.style.transform = `translate3d(${-openAmount}px,0,0)`; - this.ionDrag(); + this.ionDrag.emit(); } private setState(state: SlidingState) { diff --git a/packages/core/src/components/item/item.tsx b/packages/core/src/components/item/item.tsx index fa73db6e11..cba0da386e 100644 --- a/packages/core/src/components/item/item.tsx +++ b/packages/core/src/components/item/item.tsx @@ -1,5 +1,5 @@ -import { Component, Prop, h, Listen } from '@stencil/core'; -import { CssClassObject } from '../../utils/interfaces'; +import { Component, Element, Prop, Listen } from '@stencil/core'; +import { CssClassMap } from '../../index'; import { createThemedClasses } from '../../utils/theme'; @@ -12,8 +12,9 @@ import { createThemedClasses } from '../../utils/theme'; } }) export class Item { - $el: HTMLElement; - childStyles: CssClassObject = Object.create(null); + private childStyles: CssClassMap = Object.create(null); + + @Element() private el: HTMLElement; @Prop() mode: string; @Prop() color: string; @@ -39,7 +40,7 @@ export class Item { ionViewDidLoad() { // Add item-button classes to each ion-button in the item - const buttons = this.$el.querySelectorAll('ion-button') as any; + const buttons = this.el.querySelectorAll('ion-button') as any; for (var i = 0; i < buttons.length; i++) { buttons[i].itemButton = true; } diff --git a/packages/core/src/components/label/label.tsx b/packages/core/src/components/label/label.tsx index b65f545b05..2721704cf1 100644 --- a/packages/core/src/components/label/label.tsx +++ b/packages/core/src/components/label/label.tsx @@ -1,4 +1,5 @@ -import { Component, h } from '@stencil/core'; +import { Component } from '@stencil/core'; + @Component({ tag: 'ion-label', diff --git a/packages/core/src/components/list-header/list-header.tsx b/packages/core/src/components/list-header/list-header.tsx index ab8b9c96f8..50890e45bb 100644 --- a/packages/core/src/components/list-header/list-header.tsx +++ b/packages/core/src/components/list-header/list-header.tsx @@ -1,4 +1,5 @@ -import { Component, h } from '@stencil/core'; +import { Component } from '@stencil/core'; + @Component({ tag: 'ion-list-header', diff --git a/packages/core/src/components/list/list.tsx b/packages/core/src/components/list/list.tsx index 2eda6baf8e..fb2d3e8a2c 100644 --- a/packages/core/src/components/list/list.tsx +++ b/packages/core/src/components/list/list.tsx @@ -1,7 +1,8 @@ -import { Component, h, Method, State } from '@stencil/core'; +import { Component, Method, State } from '@stencil/core'; import { ItemSliding } from '../item-sliding/item-sliding'; + @Component({ tag: 'ion-list', styleUrls: { diff --git a/packages/core/src/components/loading-controller/loading-controller.tsx b/packages/core/src/components/loading-controller/loading-controller.tsx index d53382baf8..44ce7f073a 100644 --- a/packages/core/src/components/loading-controller/loading-controller.tsx +++ b/packages/core/src/components/loading-controller/loading-controller.tsx @@ -1,5 +1,5 @@ -import { Component, Listen, Ionic } from '@stencil/core'; -import { GlobalNamespace, LoadingEvent, LoadingOptions, Loading, IonicControllerApi } from '../../utils/interfaces'; +import { Component, Listen } from '@stencil/core'; +import { LoadingEvent, LoadingOptions, Loading, IonicControllerApi } from '../../index'; @Component({ @@ -15,19 +15,19 @@ export class LoadingController implements IonicControllerApi { ionViewDidLoad() { this.appRoot = document.querySelector('ion-app') || document.body; - (Ionic as GlobalNamespace).loadController('loading', this); + Ionic.loadController('loading', this); } load(opts?: LoadingOptions) { // create ionic's wrapping ion-loading component - const loading: Loading = document.createElement('ion-loading') as any; + const loading = document.createElement('ion-loading'); const id = this.ids++; // give this loading a unique id loading.id = `loading-${id}`; - loading.style.zIndex = (20000 + id); + loading.style.zIndex = (20000 + id).toString(); // convert the passed in loading options into props // that get passed down into the new loading @@ -45,7 +45,7 @@ export class LoadingController implements IonicControllerApi { @Listen('body:ionLoadingDidLoad') viewDidLoad(ev: LoadingEvent) { - const loading = ev.detail.loading; + const loading = ev.loading; const loadingResolve = this.loadingResolves[loading.id]; if (loadingResolve) { loadingResolve(loading); @@ -56,13 +56,13 @@ export class LoadingController implements IonicControllerApi { @Listen('body:ionLoadingWillPresent') willPresent(ev: LoadingEvent) { - this.loadings.push(ev.detail.loading); + this.loadings.push(ev.loading); } @Listen('body:ionLoadingWillDismiss, body:ionLoadingDidUnload') willDismiss(ev: LoadingEvent) { - const index = this.loadings.indexOf(ev.detail.loading); + const index = this.loadings.indexOf(ev.loading); if (index > -1) { this.loadings.splice(index, 1); } diff --git a/packages/core/src/components/loading/animations/ios.enter.ts b/packages/core/src/components/loading/animations/ios.enter.ts index a7171603fa..5bfbacd55c 100644 --- a/packages/core/src/components/loading/animations/ios.enter.ts +++ b/packages/core/src/components/loading/animations/ios.enter.ts @@ -1,4 +1,3 @@ -const Ionic = (window as any).Ionic; /** diff --git a/packages/core/src/components/loading/animations/ios.leave.ts b/packages/core/src/components/loading/animations/ios.leave.ts index c31bab715a..f7b4c1b3e2 100644 --- a/packages/core/src/components/loading/animations/ios.leave.ts +++ b/packages/core/src/components/loading/animations/ios.leave.ts @@ -1,4 +1,3 @@ -const Ionic = (window as any).Ionic; /** diff --git a/packages/core/src/components/loading/loading.tsx b/packages/core/src/components/loading/loading.tsx index b1caf43718..9b012331f0 100644 --- a/packages/core/src/components/loading/loading.tsx +++ b/packages/core/src/components/loading/loading.tsx @@ -1,5 +1,5 @@ -import { Component, h, Listen, Prop, State, Ionic } from '@stencil/core'; -import { AnimationBuilder, Animation, Loading as ILoading, LoadingEvent } from '../../utils/interfaces'; +import { Component, Element, Event, EventEmitter, Listen, Prop, State } from '@stencil/core'; +import { AnimationBuilder, Animation } from '../../index'; import iOSEnterAnimation from './animations/ios.enter'; import iOSLeaveAnimation from './animations/ios.leave'; @@ -16,10 +16,21 @@ import iOSLeaveAnimation from './animations/ios.leave'; theme: 'loading' } }) -export class Loading implements ILoading { - $el: HTMLElement; - animation: Animation; - durationTimeout: any; +export class Loading { + private animation: Animation; + private durationTimeout: any; + + @Element() private el: HTMLElement; + + @Event() private ionLoadingDidLoad: EventEmitter; + @Event() private ionLoadingDidPresent: EventEmitter; + @Event() private ionLoadingWillPresent: EventEmitter; + @Event() private ionLoadingWillDismiss: EventEmitter; + @Event() private ionLoadingDidDismiss: EventEmitter; + @Event() private ionLoadingDidUnload: EventEmitter; + + @State() private showSpinner: boolean = null; + @State() private spinner: string; @Prop() cssClass: string; @Prop() content: string; @@ -28,11 +39,8 @@ export class Loading implements ILoading { @Prop() enterAnimation: AnimationBuilder; @Prop() exitAnimation: AnimationBuilder; @Prop() id: string; - @State() showSpinner: boolean = null; - @State() spinner: string; @Prop() showBackdrop: boolean = true; - @Listen('ionDismiss') onDismiss(ev: UIEvent) { ev.stopPropagation(); @@ -49,7 +57,7 @@ export class Loading implements ILoading { if (this.showSpinner === null || this.showSpinner === undefined) { this.showSpinner = !!(this.spinner && this.spinner !== 'hide'); } - Ionic.emit(this, 'ionLoadingDidLoad', { detail: { loading: this } } as LoadingEvent); + this.ionLoadingDidLoad.emit({ loading: this } as LoadingEvent); } ionViewDidEnter() { @@ -62,7 +70,7 @@ export class Loading implements ILoading { this.durationTimeout = setTimeout(() => this.dismiss(), this.duration); } - Ionic.emit(this, 'ionLoadingDidPresent', { detail: { loading: this } } as LoadingEvent); + this.ionLoadingDidPresent.emit({ loading: this } as LoadingEvent); } present() { @@ -77,7 +85,7 @@ export class Loading implements ILoading { this.animation = null; } - Ionic.emit(this, 'ionLoadingWillPresent', { detail: { loading: this } } as LoadingEvent); + this.ionLoadingWillPresent.emit({ loading: this } as LoadingEvent); // get the user's animation fn if one was provided let animationBuilder = this.enterAnimation; @@ -90,7 +98,7 @@ export class Loading implements ILoading { } // build the animation and kick it off - this.animation = animationBuilder(this.$el); + this.animation = animationBuilder(this.el); this.animation.onFinish((a: any) => { a.destroy(); @@ -108,7 +116,7 @@ export class Loading implements ILoading { } return new Promise(resolve => { - Ionic.emit(this, 'ionLoadingWillDismiss', { detail: { loading: this } } as LoadingEvent); + this.ionLoadingWillDismiss.emit({ loading: this } as LoadingEvent); // get the user's animation fn if one was provided let animationBuilder = this.exitAnimation; @@ -121,20 +129,22 @@ export class Loading implements ILoading { } // build the animation and kick it off - this.animation = animationBuilder(this.$el); + this.animation = animationBuilder(this.el); this.animation.onFinish((a: any) => { a.destroy(); - Ionic.emit(this, 'ionLoadingDidDismiss', { detail: { loading: this } } as LoadingEvent); - Ionic.dom.write(() => { - this.$el.parentNode.removeChild(this.$el); + this.ionLoadingDidDismiss.emit({ loading: this } as LoadingEvent); + + Core.dom.write(() => { + this.el.parentNode.removeChild(this.el); }); + resolve(); }).play(); }); } ionViewDidUnload() { - Ionic.emit(this, 'ionLoadingDidUnload', { detail: { loading: this } } as LoadingEvent); + this.ionLoadingDidUnload.emit({ loading: this }as LoadingEvent); } render() { @@ -176,3 +186,18 @@ export class Loading implements ILoading { ]; } } + + +export interface LoadingOptions { + spinner?: string; + content?: string; + cssClass?: string; + showBackdrop?: boolean; + dismissOnPageChange?: boolean; + duration?: number; +} + + +export interface LoadingEvent { + loading: Loading; +} diff --git a/packages/core/src/components/menu/menu-controller.ts b/packages/core/src/components/menu/menu-controller.ts index 717397015d..ddc6bb1b08 100644 --- a/packages/core/src/components/menu/menu-controller.ts +++ b/packages/core/src/components/menu/menu-controller.ts @@ -1,8 +1,8 @@ -import { Menu, MenuController as IMenuController } from '../../utils/interfaces'; -import { MenuType, MenuRevealType, MenuPushType, MenuOverlayType } from './menu-types'; +import { Menu, MenuType } from '../../index'; +import { MenuRevealType, MenuPushType, MenuOverlayType } from './menu-types'; -export class MenuController implements IMenuController { +export class MenuController { private _menus: Array = []; private _menuTypes: { [name: string]: new(...args: any[]) => MenuType } = {}; diff --git a/packages/core/src/components/menu/menu-types.ts b/packages/core/src/components/menu/menu-types.ts index ffe2425789..e82bb7d9e9 100644 --- a/packages/core/src/components/menu/menu-types.ts +++ b/packages/core/src/components/menu/menu-types.ts @@ -1,5 +1,4 @@ -import { Animation, Menu, MenuType as IMenuType } from '../../utils/interfaces'; -const Ionic = (window as any).Ionic; +import { Animation, Menu } from '../../index'; /** @@ -9,7 +8,7 @@ const Ionic = (window as any).Ionic; * type will provide their own animations for open and close * and registers itself with Menu. */ -export class MenuType implements IMenuType { +export class MenuType { ani: Animation; isOpening: boolean; diff --git a/packages/core/src/components/menu/menu.tsx b/packages/core/src/components/menu/menu.tsx index 18670481b8..7b7b8f719c 100644 --- a/packages/core/src/components/menu/menu.tsx +++ b/packages/core/src/components/menu/menu.tsx @@ -1,5 +1,4 @@ -import { Component, h, Prop, Ionic, PropDidChange } from '@stencil/core'; -import { VNodeData, GlobalNamespace, Menu as IMenu } from '../../utils/interfaces'; +import { Component, Element, Event, EventEmitter, Prop, PropDidChange } from '@stencil/core'; import { MenuController } from './menu-controller'; import { MenuType } from './menu-types'; @@ -15,8 +14,8 @@ import { MenuType } from './menu-types'; theme: 'menu' } }) -export class Menu implements IMenu { - private $el: HTMLElement; +export class Menu { + @Element() private el: HTMLElement; private _backdropElm: HTMLElement; private _ctrl: MenuController; private _unregCntClick: Function; @@ -31,6 +30,10 @@ export class Menu implements IMenu { mode: string; color: string; + @Event() ionDrag: EventEmitter; + @Event() ionOpen: EventEmitter; + @Event() ionClose: EventEmitter; + /** * @hidden */ @@ -96,7 +99,7 @@ export class Menu implements IMenu { constructor() { // get or create the MenuController singleton - this._ctrl = (Ionic as GlobalNamespace).controllers.menu = ((Ionic as GlobalNamespace).controllers.menu || new MenuController()); + this._ctrl = Ionic.controllers.menu = (Ionic.controllers.menu || new MenuController()); } @@ -104,7 +107,7 @@ export class Menu implements IMenu { * @hidden */ ionViewDidLoad() { - this._backdropElm = this.$el.querySelector('.menu-backdrop') as HTMLElement; + this._backdropElm = this.el.querySelector('.menu-backdrop') as HTMLElement; this._init = true; @@ -139,7 +142,7 @@ export class Menu implements IMenu { this.enable(isEnabled); } - hostData(): VNodeData { + hostData() { return { attrs: { 'role': 'navigation', @@ -259,7 +262,7 @@ export class Menu implements IMenu { this._getType().setProgessStep(stepValue); - Ionic.emit(this, 'ionDrag', { detail: { menu: this } }); + this.ionDrag.emit({ menu: this }); } _swipeEnd(shouldCompleteLeft: boolean, shouldCompleteRight: boolean, stepValue: number, velocity: number) { @@ -283,7 +286,7 @@ export class Menu implements IMenu { private _before() { // this places the menu into the correct location before it animates in // this css class doesn't actually kick off any animations - this.$el.classList.add('show-menu'); + this.el.classList.add('show-menu'); this._backdropElm.classList.add('show-backdrop'); this.resize(); @@ -311,26 +314,26 @@ export class Menu implements IMenu { this._activeBlock = GESTURE_BLOCKER; // add css class - Ionic.dom.write(() => { + Core.dom.write(() => { this._cntElm.classList.add('menu-content-open'); }); // emit open event - Ionic.emit(this, 'ionOpen', { detail: { menu: this } }); + this.ionOpen.emit({ menu: this }); } else { // enable swipe to go back gesture this._activeBlock = null; // remove css classes - Ionic.dom.write(() => { + Core.dom.write(() => { this._cntElm.classList.remove('menu-content-open'); this._cntElm.classList.remove('show-menu'); this._backdropElm.classList.remove('show-menu'); }); // emit close event - Ionic.emit(this, 'ionClose', { detail: { menu: this } }); + this.ionClose.emit({ menu: this }); } } @@ -446,7 +449,7 @@ export class Menu implements IMenu { * @hidden */ getMenuElement(): HTMLElement { - return this.$el.querySelector('.menu-inner') as HTMLElement; + return this.el.querySelector('.menu-inner') as HTMLElement; } /** @@ -481,8 +484,8 @@ export class Menu implements IMenu { const onBackdropClick = this.onBackdropClick.bind(this); if (shouldAdd && !this._unregBdClick) { - this._unregBdClick = Ionic.listener.add(this._cntElm, 'click', onBackdropClick, { capture: true }); - this._unregCntClick = Ionic.listener.add(this._cntElm, 'click', onBackdropClick, { capture: true }); + this._unregBdClick = Core.addListener(this._cntElm, 'click', onBackdropClick, { capture: true }); + this._unregCntClick = Core.addListener(this._cntElm, 'click', onBackdropClick, { capture: true }); } else if (!shouldAdd && this._unregBdClick) { this._unregBdClick(); diff --git a/packages/core/src/components/modal-controller/modal-controller.tsx b/packages/core/src/components/modal-controller/modal-controller.tsx index 9a28e13609..8085968627 100644 --- a/packages/core/src/components/modal-controller/modal-controller.tsx +++ b/packages/core/src/components/modal-controller/modal-controller.tsx @@ -1,5 +1,5 @@ -import { Component, Listen, Ionic } from '@stencil/core'; -import { GlobalNamespace, ModalEvent, ModalOptions, Modal, IonicControllerApi } from '../../utils/interfaces'; +import { Component, Listen } from '@stencil/core'; +import { ModalEvent, ModalOptions, Modal, IonicControllerApi } from '../../index'; @Component({ @@ -15,19 +15,19 @@ export class ModalController implements IonicControllerApi { ionViewDidLoad() { this.appRoot = document.querySelector('ion-app') || document.body; - (Ionic as GlobalNamespace).loadController('modal', this); + Ionic.loadController('modal', this); } load(opts?: ModalOptions) { // create ionic's wrapping ion-modal component - const modal: Modal = document.createElement('ion-modal') as any; + const modal = document.createElement('ion-modal'); const id = this.ids++; // give this modal a unique id modal.id = `modal-${id}`; - modal.style.zIndex = (10000 + id); + modal.style.zIndex = (10000 + id).toString(); // convert the passed in modal options into props // that get passed down into the new modal @@ -45,7 +45,7 @@ export class ModalController implements IonicControllerApi { @Listen('body:ionModalDidLoad') viewDidLoad(ev: ModalEvent) { - const modal = ev.detail.modal; + const modal = ev.modal; const modalResolve = this.modalResolves[modal.id]; if (modalResolve) { modalResolve(modal); @@ -56,13 +56,13 @@ export class ModalController implements IonicControllerApi { @Listen('body:ionModalWillPresent') willPresent(ev: ModalEvent) { - this.modals.push(ev.detail.modal); + this.modals.push(ev.modal); } @Listen('body:ionModalWillDismiss, body:ionModalDidUnload') willDismiss(ev: ModalEvent) { - const index = this.modals.indexOf(ev.detail.modal); + const index = this.modals.indexOf(ev.modal); if (index > -1) { this.modals.splice(index, 1); } diff --git a/packages/core/src/components/modal/animations/ios.enter.ts b/packages/core/src/components/modal/animations/ios.enter.ts index 9eb987df38..2cdefba667 100644 --- a/packages/core/src/components/modal/animations/ios.enter.ts +++ b/packages/core/src/components/modal/animations/ios.enter.ts @@ -1,4 +1,3 @@ -const Ionic = (window as any).Ionic; /** diff --git a/packages/core/src/components/modal/animations/ios.leave.ts b/packages/core/src/components/modal/animations/ios.leave.ts index 712120afab..6c07e4749d 100644 --- a/packages/core/src/components/modal/animations/ios.leave.ts +++ b/packages/core/src/components/modal/animations/ios.leave.ts @@ -1,4 +1,3 @@ -const Ionic = (window as any).Ionic; /** diff --git a/packages/core/src/components/modal/modal.tsx b/packages/core/src/components/modal/modal.tsx index 6d4f76eafa..cff7f68c25 100644 --- a/packages/core/src/components/modal/modal.tsx +++ b/packages/core/src/components/modal/modal.tsx @@ -1,5 +1,5 @@ -import { Component, h, Listen, Prop, Ionic } from '@stencil/core'; -import { AnimationBuilder, Animation, Modal as IModal, ModalEvent } from '../../utils/interfaces'; +import { Component, Element, Event, EventEmitter, Listen, Prop } from '@stencil/core'; +import { AnimationBuilder, Animation } from '../../index'; import { createThemedClasses } from '../../utils/theme'; import iOSEnterAnimation from './animations/ios.enter'; @@ -14,9 +14,15 @@ import iOSLeaveAnimation from './animations/ios.leave'; wp: 'modal.wp.scss' } }) -export class Modal implements IModal { - $el: HTMLElement; - animation: Animation; +export class Modal { + @Element() private el: HTMLElement; + + @Event() ionModalDidLoad: EventEmitter; + @Event() ionModalWillPresent: EventEmitter; + @Event() ionModalDidPresent: EventEmitter; + @Event() ionModalWillDismiss: EventEmitter; + @Event() ionModalDidDismiss: EventEmitter; + @Event() ionModalDidUnload: EventEmitter; @Prop() mode: string; @Prop() color: string; @@ -29,6 +35,10 @@ export class Modal implements IModal { @Prop() id: string; @Prop() showBackdrop: boolean = true; + + + private animation: Animation; + @Listen('ionDismiss') onDismiss(ev: UIEvent) { ev.stopPropagation(); @@ -38,7 +48,7 @@ export class Modal implements IModal { } ionViewDidLoad() { - Ionic.emit(this, 'ionModalDidLoad', { detail: { modal: this } } as ModalEvent); + this.ionModalDidLoad.emit({ modal: this }); } present() { @@ -53,7 +63,7 @@ export class Modal implements IModal { this.animation = null; } - Ionic.emit(this, 'ionModalWillPresent', { detail: { modal: this } } as ModalEvent); + this.ionModalWillPresent.emit({ modal: this } as ModalEvent); // get the user's animation fn if one was provided let animationBuilder = this.enterAnimation; @@ -66,11 +76,11 @@ export class Modal implements IModal { } // build the animation and kick it off - this.animation = animationBuilder(this.$el); + this.animation = animationBuilder(this.el); this.animation.onFinish((a: any) => { a.destroy(); - Ionic.emit(this, 'ionModalDidPresent', { detail: { modal: this } } as ModalEvent); + this.ionModalDidPresent.emit({ modal: this }); resolve(); }).play(); } @@ -82,7 +92,7 @@ export class Modal implements IModal { } return new Promise(resolve => { - Ionic.emit(this, 'ionModalWillDismiss', { detail: { modal: this } } as ModalEvent); + this.ionModalWillDismiss.emit({ modal: this }); // get the user's animation fn if one was provided let animationBuilder = this.exitAnimation; @@ -95,12 +105,13 @@ export class Modal implements IModal { } // build the animation and kick it off - this.animation = animationBuilder(this.$el); + this.animation = animationBuilder(this.el); this.animation.onFinish((a: any) => { a.destroy(); - Ionic.emit(this, 'ionModalDidDismiss', { detail: { modal: this } } as ModalEvent); - Ionic.dom.write(() => { - this.$el.parentNode.removeChild(this.$el); + this.ionModalDidDismiss.emit({ modal: this }); + + Core.dom.write(() => { + this.el.parentNode.removeChild(this.el); }); resolve(); }).play(); @@ -108,7 +119,7 @@ export class Modal implements IModal { } ionViewDidUnload() { - Ionic.emit(this, 'ionModalDidUnload', { detail: { modal: this } } as ModalEvent); + this.ionModalDidUnload.emit({ modal: this }); } backdropClick() { @@ -152,3 +163,19 @@ export class Modal implements IModal { ]; } } + + +export interface ModalOptions { + component: string; + componentProps?: any; + showBackdrop?: boolean; + enableBackdropDismiss?: boolean; + enterAnimation?: AnimationBuilder; + exitAnimation?: AnimationBuilder; + cssClass?: string; +} + + +export interface ModalEvent { + modal: Modal; +} diff --git a/packages/core/src/components/note/note.tsx b/packages/core/src/components/note/note.tsx index f127e2308b..698210ec31 100644 --- a/packages/core/src/components/note/note.tsx +++ b/packages/core/src/components/note/note.tsx @@ -1,4 +1,4 @@ -import { Component, h } from '@stencil/core'; +import { Component } from '@stencil/core'; /** diff --git a/packages/core/src/components/page/page.tsx b/packages/core/src/components/page/page.tsx index 0dcf9ba912..91890403b3 100644 --- a/packages/core/src/components/page/page.tsx +++ b/packages/core/src/components/page/page.tsx @@ -1,4 +1,4 @@ -import { Component, h } from '@stencil/core'; +import { Component } from '@stencil/core'; @Component({ diff --git a/packages/core/src/components/router/route.tsx b/packages/core/src/components/router/route.tsx index e8c667bc56..7a21e6d4cc 100644 --- a/packages/core/src/components/router/route.tsx +++ b/packages/core/src/components/router/route.tsx @@ -9,8 +9,6 @@ import { Component, Prop, State } from '@stencil/core'; tag: 'ion-route' }) export class Route { - $el: HTMLElement; - @Prop() url: string; @Prop() component: string; diff --git a/packages/core/src/components/scroll/scroll-interface.ts b/packages/core/src/components/scroll/scroll-interface.ts deleted file mode 100644 index 36fd356dca..0000000000 --- a/packages/core/src/components/scroll/scroll-interface.ts +++ /dev/null @@ -1,14 +0,0 @@ -import { ScrollCallback } from '../../utils/interfaces'; - - -export interface Scroll { - enabled: boolean; - jsScroll: boolean; - - ionScrollStart: ScrollCallback; - ionScroll: ScrollCallback; - ionScrollEnd: ScrollCallback; - - scrollToTop: (duration: number) => Promise; - scrollToBottom: (duration: number) => Promise; -} diff --git a/packages/core/src/components/scroll/scroll.tsx b/packages/core/src/components/scroll/scroll.tsx index c81cfcb6c3..c0d54e9c25 100644 --- a/packages/core/src/components/scroll/scroll.tsx +++ b/packages/core/src/components/scroll/scroll.tsx @@ -1,44 +1,34 @@ -import { Component, Listen, h, Ionic, Prop } from '@stencil/core'; +import { Component, Element, Listen, Prop } from '@stencil/core'; +import { GestureDetail } from '../../index'; import { GestureController, GestureDelegate } from '../gesture/gesture-controller'; -import { GlobalNamespace, ScrollCallback, ScrollDetail } from '../../utils/interfaces'; -import { Scroll as IScroll } from './scroll-interface'; @Component({ tag: 'ion-scroll' }) -export class Scroll implements IScroll { - private $el: HTMLElement; +export class Scroll { + @Element() private el: HTMLElement; + private gesture: GestureDelegate; private positions: number[] = []; private _l: number; private _t: number; private tmr: any; private queued = false; - private eventOpts: any; isScrolling: boolean = false; detail: ScrollDetail = {}; - constructor() { - this.eventOpts = { - detail: this.detail, - bubbles: true, - composed: true - }; - } - @Prop() enabled: boolean = true; @Prop() jsScroll: boolean = false; @Prop() ionScrollStart: ScrollCallback; @Prop() ionScroll: ScrollCallback; @Prop() ionScrollEnd: ScrollCallback; - ionViewDidLoad() { - if (Ionic.isServer) return; + if (Core.isServer) return; - const ctrl = (Ionic as GlobalNamespace).controllers.gesture = ((Ionic as GlobalNamespace).controllers.gesture || new GestureController()); + const ctrl = Ionic.controllers.gesture = (Ionic.controllers.gesture || new GestureController()); this.gesture = ctrl.createGesture('scroll', 100, false); } @@ -53,7 +43,7 @@ export class Scroll implements IScroll { if (!self.queued && self.enabled) { self.queued = true; - Ionic.dom.read(function(timeStamp) { + Core.dom.read(function(timeStamp) { self.queued = false; self.onScroll(timeStamp || Date.now()); }); @@ -89,8 +79,6 @@ export class Scroll implements IScroll { // emit only on the first scroll event if (self.ionScrollStart) { self.ionScrollStart(detail); - } else { - Ionic.emit(this, 'ionScrollStart', this.eventOpts); } } @@ -136,7 +124,7 @@ export class Scroll implements IScroll { // haven't scrolled in a while, so it's a scrollend self.isScrolling = false; - Ionic.dom.read(function(timeStamp) { + Core.dom.read(function(timeStamp) { if (!self.isScrolling) { self.onEnd(timeStamp); } @@ -146,8 +134,6 @@ export class Scroll implements IScroll { // emit on each scroll event if (self.ionScrollStart) { self.ionScroll(detail); - } else { - Ionic.emit(this, 'ionScroll', this.eventOpts); } } @@ -161,9 +147,6 @@ export class Scroll implements IScroll { // emit that the scroll has ended if (self.ionScrollEnd) { self.ionScrollEnd(detail); - - } else { - Ionic.emit(this, 'ionScrollEnd', this.eventOpts); } } @@ -171,9 +154,9 @@ export class Scroll implements IScroll { enableJsScroll(contentTop: number, contentBottom: number) { this.jsScroll = true; - Ionic.listener.enable(this, 'scroll', false); + Core.enableListener(this, 'scroll', false); - Ionic.listener.enable(this, 'touchstart', true); + Core.enableListener(this, 'touchstart', true); contentTop; contentBottom; } @@ -187,8 +170,8 @@ export class Scroll implements IScroll { return; } - Ionic.listener.enable(this, 'touchmove', true); - Ionic.listener.enable(this, 'touchend', true); + Core.enableListener(this, 'touchmove', true); + Core.enableListener(this, 'touchend', true); throw 'jsScroll: TODO!'; } @@ -202,8 +185,8 @@ export class Scroll implements IScroll { @Listen('touchend', { passive: true, enabled: false }) onTouchEnd() { - Ionic.listener.enable(this, 'touchmove', false); - Ionic.listener.enable(this, 'touchend', false); + Core.enableListener(this, 'touchmove', false); + Core.enableListener(this, 'touchend', false); if (!this.enabled) { return; @@ -218,7 +201,7 @@ export class Scroll implements IScroll { if (this.jsScroll) { return this._t; } - return this._t = this.$el.scrollTop; + return this._t = this.el.scrollTop; } /** @@ -228,7 +211,7 @@ export class Scroll implements IScroll { if (this.jsScroll) { return 0; } - return this._l = this.$el.scrollLeft; + return this._l = this.el.scrollLeft; } /** @@ -238,10 +221,10 @@ export class Scroll implements IScroll { this._t = top; if (this.jsScroll) { - this.$el.style.transform = this.$el.style.webkitTransform = `translate3d(${this._l * -1}px,${top * -1}px,0px)`; + this.el.style.transform = this.el.style.webkitTransform = `translate3d(${this._l * -1}px,${top * -1}px,0px)`; } else { - this.$el.scrollTop = top; + this.el.scrollTop = top; } } @@ -252,10 +235,10 @@ export class Scroll implements IScroll { this._l = left; if (this.jsScroll) { - this.$el.style.transform = this.$el.style.webkitTransform = `translate3d(${left * -1}px,${this._t * -1}px,0px)`; + this.el.style.transform = this.el.style.webkitTransform = `translate3d(${left * -1}px,${this._t * -1}px,0px)`; } else { - this.$el.scrollLeft = left; + this.el.scrollLeft = left; } } @@ -273,7 +256,7 @@ export class Scroll implements IScroll { } const self = this; - const el = self.$el; + const el = self.el; if (!el) { // invalid element done(); @@ -300,7 +283,7 @@ export class Scroll implements IScroll { function step(timeStamp: number) { attempts++; - if (!self.$el || stopScroll || attempts > maxAttempts) { + if (!self.el || stopScroll || attempts > maxAttempts) { self.isScrolling = false; el.style.transform = el.style.webkitTransform = ''; done(); @@ -324,7 +307,7 @@ export class Scroll implements IScroll { if (easedT < 1) { // do not use DomController here // must use nativeRaf in order to fire in the next frame - Ionic.dom.raf(step); + Core.dom.raf(step); } else { stopScroll = true; @@ -338,8 +321,8 @@ export class Scroll implements IScroll { self.isScrolling = true; // chill out for a frame first - Ionic.dom.write(() => { - Ionic.dom.write(timeStamp => { + Core.dom.write(() => { + Core.dom.write(timeStamp => { startTime = timeStamp; step(timeStamp); }); @@ -354,8 +337,8 @@ export class Scroll implements IScroll { scrollToBottom(duration: number): Promise { let y = 0; - if (this.$el) { - y = this.$el.scrollHeight - this.$el.clientHeight; + if (this.el) { + y = this.el.scrollHeight - this.el.clientHeight; } return this.scrollTo(0, y, duration); } @@ -372,3 +355,23 @@ export class Scroll implements IScroll { } +export interface ScrollDetail extends GestureDetail { + scrollTop?: number; + scrollLeft?: number; + scrollHeight?: number; + scrollWidth?: number; + contentHeight?: number; + contentWidth?: number; + contentTop?: number; + contentBottom?: number; + contentElement?: HTMLElement; + fixedElement?: HTMLElement; + scrollElement?: HTMLElement; + headerElement?: HTMLElement; + footerElement?: HTMLElement; +} + + +export interface ScrollCallback { + (detail?: ScrollDetail): boolean|void; +} diff --git a/packages/core/src/components/searchbar/searchbar.tsx b/packages/core/src/components/searchbar/searchbar.tsx index 01acfbf1e2..97173de05b 100644 --- a/packages/core/src/components/searchbar/searchbar.tsx +++ b/packages/core/src/components/searchbar/searchbar.tsx @@ -1,5 +1,5 @@ -import { Component, h, Ionic, Prop, State } from '@stencil/core'; -import { VNodeData } from '../../utils/interfaces'; +import { Component, Element, Event, EventEmitter, Prop, State } from '@stencil/core'; + /** * @name Searchbar @@ -32,13 +32,14 @@ import { VNodeData } from '../../utils/interfaces'; } }) export class Searchbar { - $el: HTMLElement; + private _isCancelVisible: boolean = false; + private _shouldBlur: boolean = true; + private _shouldAlignLeft: boolean = true; - _isCancelVisible: boolean = false; - _shouldBlur: boolean = true; - _shouldAlignLeft: boolean = true; + @Element() el: HTMLElement; @Prop() mode: string; + @Prop() color: string; @State() activated: boolean = false; @@ -46,20 +47,30 @@ export class Searchbar { @State() focused: boolean = false; -// /** -// * @output {event} Emitted when the Searchbar input has changed, including when it's cleared. -// */ -// @Output() ionInput: EventEmitter = new EventEmitter(); + /** + * @output {event} Emitted when the Searchbar input has changed, including when it's cleared. + */ + @Event() ionInput: EventEmitter; -// /** -// * @output {event} Emitted when the cancel button is clicked. -// */ -// @Output() ionCancel: EventEmitter = new EventEmitter(); + /** + * @output {event} Emitted when the cancel button is clicked. + */ + @Event() ionCancel: EventEmitter; -// /** -// * @output {event} Emitted when the clear input button is clicked. -// */ -// @Output() ionClear: EventEmitter = new EventEmitter(); + /** + * @output {event} Emitted when the clear input button is clicked. + */ + @Event() ionClear: EventEmitter; + + /** + * @output {event} + */ + @Event() ionBlur: EventEmitter; + + /** + * @output {event} + */ + @Event() ionFocus: EventEmitter; /** @@ -137,7 +148,7 @@ export class Searchbar { * Clears the input field and triggers the control change. */ clearInput(ev: UIEvent) { - Ionic.emit(this, 'ionClear', { detail: { event: ev } }); + this.ionClear.emit({event: ev}); // setTimeout() fixes https://github.com/ionic-team/ionic/issues/7527 // wait for 4 frames @@ -145,7 +156,7 @@ export class Searchbar { let value = this.value; if (value !== undefined && value !== '') { this.value = ''; - Ionic.emit(this, 'ionInput', { detail: { event: ev } }); + this.ionInput.emit({event: ev}); } }, 16 * 4); this._shouldBlur = false; @@ -158,7 +169,7 @@ export class Searchbar { * then calls the custom cancel function if the user passed one in. */ cancelSearchbar(ev: UIEvent) { - Ionic.emit(this, 'ionCancel', { detail: { event: ev } }); + this.ionCancel.emit({event: ev}); this.clearInput(ev); this._shouldBlur = true; @@ -180,7 +191,7 @@ export class Searchbar { * @hidden */ inputUpdated() { - // const inputEle = this.$el.querySelector('.searchbar-input') as HTMLInputElement; + // const inputEle = this.el.querySelector('.searchbar-input') as HTMLInputElement; // It is important not to re-assign the value if it is the same, because, // otherwise, the caret is moved to the end of the input @@ -198,14 +209,14 @@ export class Searchbar { * based on whether there is a value in the searchbar or not. */ inputBlurred() { - const inputEle = this.$el.querySelector('.searchbar-input') as HTMLElement; + const inputEle = this.el.querySelector('.searchbar-input') as HTMLElement; // _shouldBlur determines if it should blur // if we are clearing the input we still want to stay focused in the input if (this._shouldBlur === false) { inputEle.focus(); this._shouldBlur = true; - Ionic.emit(this, 'ionBlur', { detail: { this: this } }); + this.ionBlur.emit({this: this}); this.inputUpdated(); return; } @@ -222,7 +233,7 @@ export class Searchbar { this.activated = true; this.focused = true; - Ionic.emit(this, 'ionFocus', { detail: { this: this } }); + this.ionFocus.emit({this: this}); this.inputUpdated(); this.positionElements(); @@ -257,8 +268,8 @@ export class Searchbar { */ positionPlaceholder() { const isRTL = document.dir === 'rtl'; - const inputEle = this.$el.querySelector('.searchbar-input') as HTMLElement; - const iconEle = this.$el.querySelector('.searchbar-search-icon') as HTMLElement; + const inputEle = this.el.querySelector('.searchbar-input') as HTMLElement; + const iconEle = this.el.querySelector('.searchbar-search-icon') as HTMLElement; if (this._shouldAlignLeft) { inputEle.removeAttribute('style'); @@ -297,7 +308,7 @@ export class Searchbar { */ positionCancelButton() { const isRTL = document.dir === 'rtl'; - const cancelButton = this.$el.querySelector('.searchbar-ios-cancel') as HTMLElement; + const cancelButton = this.el.querySelector('.searchbar-ios-cancel') as HTMLElement; const shouldShowCancel = this.focused; if (shouldShowCancel !== this._isCancelVisible) { @@ -322,7 +333,7 @@ export class Searchbar { } } - hostData(): VNodeData { + hostData() { return { class: { 'searchbar-active': this.activated, diff --git a/packages/core/src/components/segment-button/segment-button.tsx b/packages/core/src/components/segment-button/segment-button.tsx index dbeab8fe39..5de2d6d60c 100644 --- a/packages/core/src/components/segment-button/segment-button.tsx +++ b/packages/core/src/components/segment-button/segment-button.tsx @@ -1,6 +1,6 @@ -import { Component, h, Ionic, Prop, State } from '@stencil/core'; +import { Component, Event, EventEmitter, Prop, State } from '@stencil/core'; -import { CssClassObject } from '../../utils/interfaces'; +import { CssClassMap } from '../../index'; import { createThemedClasses } from '../../utils/theme'; @@ -49,6 +49,8 @@ export class SegmentButton { mode: string; color: string; + @Event() ionClick: EventEmitter; + @State() activated: boolean = false; /* @@ -81,11 +83,10 @@ export class SegmentButton { clearTimeout(this.styleTmr); this.styleTmr = setTimeout(() => { - Ionic.emit(this, 'ionClick', { - detail: { - 'segmentButton': this, - } - }); + const ev: SegmentButtonEvent = { + 'segmentButton': this + }; + this.ionClick.emit(ev); }); } @@ -105,7 +106,7 @@ export class SegmentButton { render() { const segmentButtonCss = createThemedClasses(this.mode, this.color, 'segment-button'); - var segmentButtonClasses: CssClassObject = [] + var segmentButtonClasses: CssClassMap = [] .concat( this.getElementClassList() ) @@ -123,3 +124,8 @@ export class SegmentButton { ]; } } + + +export interface SegmentButtonEvent { + segmentButton: SegmentButton; +} diff --git a/packages/core/src/components/segment/segment.tsx b/packages/core/src/components/segment/segment.tsx index b054db718a..c67b16cb2d 100644 --- a/packages/core/src/components/segment/segment.tsx +++ b/packages/core/src/components/segment/segment.tsx @@ -1,6 +1,6 @@ -import { Component, h, Listen, Prop, PropDidChange } from '@stencil/core'; +import { Component, Element, HostElement, Listen, Prop, PropDidChange } from '@stencil/core'; -import { HostElement, SegmentButtonEvent, VNodeData } from '../../utils/interfaces'; +import { SegmentButtonEvent } from '../../index'; /** @@ -72,7 +72,7 @@ import { HostElement, SegmentButtonEvent, VNodeData } from '../../utils/interfac }) export class Segment { buttons: NodeListOf; - $el: HTMLElement; + @Element() el: HTMLElement; @Prop({ state: true }) disabled: boolean = false; @@ -84,7 +84,7 @@ export class Segment { } ionViewDidLoad() { - this.buttons = this.$el.querySelectorAll('ion-segment-button') as NodeListOf; + this.buttons = this.el.querySelectorAll('ion-segment-button') as NodeListOf; for (var i = 0; i < this.buttons.length; i++) { const button = this.buttons[i].$instance; @@ -101,7 +101,7 @@ export class Segment { @Listen('ionClick') segmentClick(ev: SegmentButtonEvent) { - let selectedButton = ev.detail.segmentButton; + let selectedButton = ev.segmentButton; this.value = selectedButton.value; this.selectButton(this.value); @@ -117,7 +117,7 @@ export class Segment { return true; } - hostData(): VNodeData { + hostData() { return { class: { 'segment-disabled': this.disabled diff --git a/packages/core/src/components/skeleton-text/skeleton-text.tsx b/packages/core/src/components/skeleton-text/skeleton-text.tsx index 842863119e..b86d9ffb21 100644 --- a/packages/core/src/components/skeleton-text/skeleton-text.tsx +++ b/packages/core/src/components/skeleton-text/skeleton-text.tsx @@ -1,4 +1,4 @@ -import { Component, h, Prop } from '@stencil/core'; +import { Component, Prop } from '@stencil/core'; @Component({ diff --git a/packages/core/src/components/slides/slide.tsx b/packages/core/src/components/slides/slide.tsx index 4d4b5aced9..5448a2f378 100644 --- a/packages/core/src/components/slides/slide.tsx +++ b/packages/core/src/components/slides/slide.tsx @@ -1,4 +1,5 @@ -import { Component, h, VNodeData } from '@stencil/core'; +import { Component } from '@stencil/core'; + /** * @name Slide @@ -17,7 +18,8 @@ import { Component, h, VNodeData } from '@stencil/core'; styleUrl: 'slide.scss' }) export class Slide { - hostData(): VNodeData { + + hostData() { return { class: { 'slide-zoom': true, diff --git a/packages/core/src/components/slides/slides.tsx b/packages/core/src/components/slides/slides.tsx index d37e254f52..866a4f860f 100644 --- a/packages/core/src/components/slides/slides.tsx +++ b/packages/core/src/components/slides/slides.tsx @@ -1,6 +1,7 @@ -import { Component, h, Prop, Ionic } from '@stencil/core'; +import { Component, Element, Prop } from '@stencil/core'; import { Swiper } from './vendor/swiper'; + /** * @name Slides * @description @@ -29,7 +30,7 @@ import { Swiper } from './vendor/swiper'; }) export class Slides { swiper: any; - $el: HTMLElement; + @Element() el: HTMLElement; /** * @input {string} The animation effect of the slides. @@ -168,7 +169,7 @@ export class Slides { emitEvent(eventName: string) { return (data: any) => { - Ionic.emit(this, eventName, data); + Core.emit(this.el, eventName, data); }; } @@ -223,7 +224,7 @@ export class Slides { if (!this._init) { console.debug(`ion-slides, init`); - this.container = this.$el.children[0] as HTMLElement; + this.container = this.el.children[0] as HTMLElement; var swiperOptions = { height: this.height, diff --git a/packages/core/src/components/spinner/spinner.tsx b/packages/core/src/components/spinner/spinner.tsx index 2da7b55fb1..7c3e657f26 100644 --- a/packages/core/src/components/spinner/spinner.tsx +++ b/packages/core/src/components/spinner/spinner.tsx @@ -1,6 +1,6 @@ -import { Component, h, Prop, VNodeData, Ionic } from '@stencil/core'; -import { SPINNERS, SpinnerConfig } from './spinner-configs'; +import { Component, Prop } from '@stencil/core'; import { createThemedClasses } from '../../utils/theme'; +import { SPINNERS, SpinnerConfig } from './spinner-configs'; @Component({ @@ -31,7 +31,7 @@ export class Spinner { } } - hostData(): VNodeData { + hostData() { const spinnerThemedClasses = createThemedClasses(this.mode, this.color, `spinner spinner-${this.name}`); spinnerThemedClasses['spinner-paused'] = true; diff --git a/packages/core/src/components/stencil-site/demos-page.tsx b/packages/core/src/components/stencil-site/demos-page.tsx deleted file mode 100644 index 5fa4326302..0000000000 --- a/packages/core/src/components/stencil-site/demos-page.tsx +++ /dev/null @@ -1,13 +0,0 @@ -import { Component, h } from '@stencil/core'; - - -@Component({ - tag: 'demos-page' -}) -export class DemosPage { - render() { - return ( -

Demos

- ); - } -} diff --git a/packages/core/src/components/stencil-site/docs-page.tsx b/packages/core/src/components/stencil-site/docs-page.tsx deleted file mode 100644 index 457a43bd75..0000000000 --- a/packages/core/src/components/stencil-site/docs-page.tsx +++ /dev/null @@ -1,13 +0,0 @@ -import { Component, h } from '@stencil/core'; - - -@Component({ - tag: 'docs-page' -}) -export class DocsPage { - render() { - return ( -

Documentation

- ); - } -} diff --git a/packages/core/src/components/stencil-site/landing-page.scss b/packages/core/src/components/stencil-site/landing-page.scss deleted file mode 100644 index e69de29bb2..0000000000 diff --git a/packages/core/src/components/stencil-site/landing-page.tsx b/packages/core/src/components/stencil-site/landing-page.tsx deleted file mode 100644 index 202ef179fc..0000000000 --- a/packages/core/src/components/stencil-site/landing-page.tsx +++ /dev/null @@ -1,13 +0,0 @@ -import { Component, h } from '@stencil/core'; - - -@Component({ - tag: 'landing-page' -}) -export class LandingPage { - render() { - return ( -

Landing Page

- ); - } -} diff --git a/packages/core/src/components/stencil-site/site-header.scss b/packages/core/src/components/stencil-site/site-header.scss deleted file mode 100644 index 83641754e0..0000000000 --- a/packages/core/src/components/stencil-site/site-header.scss +++ /dev/null @@ -1,5 +0,0 @@ -site-header { - a { - color: #fff; - } -} diff --git a/packages/core/src/components/stencil-site/site-header.tsx b/packages/core/src/components/stencil-site/site-header.tsx deleted file mode 100644 index 7bf05533ed..0000000000 --- a/packages/core/src/components/stencil-site/site-header.tsx +++ /dev/null @@ -1,28 +0,0 @@ -import { Component, h, } from '@stencil/core'; - -@Component({ - tag: 'site-header', - styleUrl: 'site-header.scss' -}) -export class SiteHeader { - render() { - return ( - - - - - - - - - Home - Docs - Demos - - - - - - ) - } -} diff --git a/packages/core/src/components/stencil-site/stencil-site.scss b/packages/core/src/components/stencil-site/stencil-site.scss deleted file mode 100644 index e69de29bb2..0000000000 diff --git a/packages/core/src/components/stencil-site/stencil-site.tsx b/packages/core/src/components/stencil-site/stencil-site.tsx deleted file mode 100644 index 31b194d50d..0000000000 --- a/packages/core/src/components/stencil-site/stencil-site.tsx +++ /dev/null @@ -1,28 +0,0 @@ -import { Component, h } from '@stencil/core'; - -@Component({ - tag: 'stencil-site' -}) -export class App { - constructor() { - } - render() { - return ( -
- - - - -
- - - -
- -
-
- ); - } -} diff --git a/packages/core/src/components/tabs/tab-bar.tsx b/packages/core/src/components/tabs/tab-bar.tsx index 7d29821a43..4c1ae99d7c 100644 --- a/packages/core/src/components/tabs/tab-bar.tsx +++ b/packages/core/src/components/tabs/tab-bar.tsx @@ -21,7 +21,7 @@ export class TabBar { @Prop() tabsLayout: string = 'icon-top' /* - hostData(): VNodeData { + hostData() { return { attrs: { 'role': 'tablist' diff --git a/packages/core/src/components/tabs/tab-button.tsx b/packages/core/src/components/tabs/tab-button.tsx index 31783226ea..ef557ea5a0 100644 --- a/packages/core/src/components/tabs/tab-button.tsx +++ b/packages/core/src/components/tabs/tab-button.tsx @@ -1,5 +1,5 @@ -import { Component, Prop, h } from '@stencil/core'; -import { VNodeData } from '../../utils/interfaces'; +import { Component, Prop } from '@stencil/core'; + @Component({ tag: 'ion-tab-button', @@ -16,7 +16,7 @@ export class TabButton { @Prop() index: number; - hostData(): VNodeData { + hostData() { const tab = this.tab; if(!tab) return {}; diff --git a/packages/core/src/components/tabs/tab-highlight.tsx b/packages/core/src/components/tabs/tab-highlight.tsx index fc09f7c209..dd18b50e7f 100644 --- a/packages/core/src/components/tabs/tab-highlight.tsx +++ b/packages/core/src/components/tabs/tab-highlight.tsx @@ -1,4 +1,4 @@ -import { Component, h } from '@stencil/core'; +import { Component } from '@stencil/core'; @Component({ diff --git a/packages/core/src/components/tabs/tab.tsx b/packages/core/src/components/tabs/tab.tsx index 7169841733..a1fa3813a9 100644 --- a/packages/core/src/components/tabs/tab.tsx +++ b/packages/core/src/components/tabs/tab.tsx @@ -1,5 +1,4 @@ -import { Component, h, Prop, State, Ionic } from '@stencil/core'; -import { VNodeData } from '../../utils/interfaces'; +import { Component, Event, EventEmitter, Prop, State } from '@stencil/core'; @Component({ @@ -9,6 +8,7 @@ import { VNodeData } from '../../utils/interfaces'; } }) export class Tab { + /** * @prop {Page} Set the root component for this tab. */ @@ -67,7 +67,9 @@ export class Tab { */ @Prop() onSelected: Function; - hostData(): VNodeData { + @Event() ionTabDidLoad: EventEmitter; + + hostData() { return { style: { display: !this.isSelected && 'none' || '' @@ -84,20 +86,12 @@ export class Tab { ionViewDidLoad() { setTimeout(() => { - Ionic.emit(this, 'ionTabDidLoad', { - detail: { - tab: this - } - }) + this.ionTabDidLoad.emit({ tab: this }) }, 0) } ionViewDidUnload() { - Ionic.emit(this, 'ionTabDidLoad', { - detail: { - tab: this - } - }) + this.ionTabDidLoad.emit({ tab: this }) } render() { diff --git a/packages/core/src/components/tabs/tabs.tsx b/packages/core/src/components/tabs/tabs.tsx index df491576f5..410ca5869d 100644 --- a/packages/core/src/components/tabs/tabs.tsx +++ b/packages/core/src/components/tabs/tabs.tsx @@ -1,4 +1,5 @@ -import { Component, h, State, Prop, Listen, PropDidChange } from '@stencil/core'; +import { Component, State, Prop, Listen, PropDidChange } from '@stencil/core'; + @Component({ tag: 'ion-tabs', diff --git a/packages/core/src/components/thumbnail/thumbnail.tsx b/packages/core/src/components/thumbnail/thumbnail.tsx index dfed326b7e..580247b8c5 100644 --- a/packages/core/src/components/thumbnail/thumbnail.tsx +++ b/packages/core/src/components/thumbnail/thumbnail.tsx @@ -1,4 +1,4 @@ -import { Component, h } from '@stencil/core'; +import { Component } from '@stencil/core'; @Component({ diff --git a/packages/core/src/components/title/title.tsx b/packages/core/src/components/title/title.tsx index 1addc531ee..8dff2d7ce6 100644 --- a/packages/core/src/components/title/title.tsx +++ b/packages/core/src/components/title/title.tsx @@ -1,6 +1,7 @@ -import { Component, h } from '@stencil/core'; +import { Component } from '@stencil/core'; import { createThemedClasses } from '../../utils/theme'; + /** * @name Title * @description diff --git a/packages/core/src/components/toggle/toggle.tsx b/packages/core/src/components/toggle/toggle.tsx index d291f51197..50aab28ea3 100644 --- a/packages/core/src/components/toggle/toggle.tsx +++ b/packages/core/src/components/toggle/toggle.tsx @@ -1,5 +1,6 @@ -import { Component, h, Listen, Prop, VNodeData, Ionic, PropDidChange } from '@stencil/core'; -import { BooleanInputComponent, GestureDetail } from '../../utils/interfaces'; +import { Component, Event, EventEmitter, Listen, Prop, PropDidChange } from '@stencil/core'; +import { BooleanInputComponent, GestureDetail } from '../../index'; + @Component({ tag: 'ion-toggle', @@ -20,6 +21,11 @@ export class Toggle implements BooleanInputComponent { startX: number; styleTmr: any; + @Event() ionChange: EventEmitter; + @Event() ionStyle: EventEmitter; + @Event() ionFocus: EventEmitter; + @Event() ionBlur: EventEmitter; + @Prop() color: string; @Prop() mode: string; @@ -34,7 +40,7 @@ export class Toggle implements BooleanInputComponent { @PropDidChange('checked') changed(val: boolean) { - Ionic.emit(this, 'ionChange', { detail: { checked: val } }); + this.ionChange.emit({ checked: val }); this.emitStyle(); } @@ -47,13 +53,11 @@ export class Toggle implements BooleanInputComponent { clearTimeout(this.styleTmr); this.styleTmr = setTimeout(() => { - Ionic.emit(this, 'ionStyle', { - detail: { - 'toggle-disabled': this.disabled, - 'toggle-checked': this.checked, - 'toggle-activated': this.activated, - 'toggle-focus': this.hasFocus - } + this.ionStyle.emit({ + 'toggle-disabled': this.disabled, + 'toggle-checked': this.checked, + 'toggle-activated': this.activated, + 'toggle-focus': this.hasFocus }); }); } @@ -120,7 +124,7 @@ export class Toggle implements BooleanInputComponent { fireFocus() { if (!this.hasFocus) { this.hasFocus = true; - Ionic.emit(this, 'ionFocus'); + this.ionFocus.emit(); this.emitStyle(); } } @@ -129,12 +133,12 @@ export class Toggle implements BooleanInputComponent { fireBlur() { if (this.hasFocus) { this.hasFocus = false; - Ionic.emit(this, 'ionBlur'); + this.ionBlur.emit(); this.emitStyle(); } } - hostData(): VNodeData { + hostData() { return { class: { 'toggle-activated': this.activated, diff --git a/packages/core/src/components/toolbar/navbar.tsx b/packages/core/src/components/toolbar/navbar.tsx index 85a07b3a5b..0a76761008 100644 --- a/packages/core/src/components/toolbar/navbar.tsx +++ b/packages/core/src/components/toolbar/navbar.tsx @@ -1,4 +1,4 @@ -import { Component, h, Prop, VNodeData, Ionic } from '@stencil/core'; +import { Component, Element, Prop } from '@stencil/core'; import { createThemedClasses } from '../../utils/theme'; @@ -45,7 +45,7 @@ import { createThemedClasses } from '../../utils/theme'; } }) export class Navbar { - $el: HTMLElement; + @Element() el: HTMLElement; mode: string; color: string; sbPadding: boolean = Ionic.config.getBoolean('statusbarPadding'); @@ -63,13 +63,13 @@ export class Navbar { } ionViewDidLoad() { - const buttons = this.$el.querySelectorAll('ion-button') as any; + const buttons = this.el.querySelectorAll('ion-button') as any; for (var i = 0; i < buttons.length; i++) { buttons[i].setAttribute('button-type', 'bar-button'); } } - hostData(): VNodeData { + hostData() { return { class: { 'statusbar-padding': Ionic.config.getBoolean('statusbarPadding') diff --git a/packages/core/src/components/toolbar/toolbar.tsx b/packages/core/src/components/toolbar/toolbar.tsx index cf6aa53942..f07b52300d 100644 --- a/packages/core/src/components/toolbar/toolbar.tsx +++ b/packages/core/src/components/toolbar/toolbar.tsx @@ -1,4 +1,4 @@ -import { Component, h, Ionic, VNodeData } from '@stencil/core'; +import { Component, Element } from '@stencil/core'; import { createThemedClasses } from '../../utils/theme'; @@ -102,18 +102,18 @@ import { createThemedClasses } from '../../utils/theme'; } }) export class Toolbar { - $el: HTMLElement; + @Element() el: HTMLElement; mode: string; color: string; ionViewDidLoad() { - const buttons = this.$el.querySelectorAll('ion-button') as any; + const buttons = this.el.querySelectorAll('ion-button') as any; for (var i = 0; i < buttons.length; i++) { buttons[i].setAttribute('button-type', 'bar-button'); } } - hostData(): VNodeData { + hostData() { return { class: { 'statusbar-padding': Ionic.config.getBoolean('statusbarPadding') diff --git a/packages/core/src/global/config-controller.ts b/packages/core/src/global/config-controller.ts new file mode 100644 index 0000000000..6481470c5c --- /dev/null +++ b/packages/core/src/global/config-controller.ts @@ -0,0 +1,46 @@ +import { ConfigApi } from '../index'; +import { PlatformConfig } from './platform-configs'; + + +export function createConfigController(configObj: any, platforms: PlatformConfig[]): ConfigApi { + configObj = configObj || {}; + + function get(key: string, fallback?: any): any { + if (configObj[key] !== undefined) { + return configObj[key]; + } + + let settings: any = null; + + for (let i = 0; i < platforms.length; i++) { + settings = platforms[i]['settings']; + if (settings && settings[key] !== undefined) { + return settings[key]; + } + } + + return fallback !== undefined ? fallback : null; + } + + function getBoolean(key: string, fallback: boolean): boolean { + const val = get(key); + if (val === null) { + return fallback !== undefined ? fallback : false; + } + if (typeof val === 'string') { + return val === 'true'; + } + return !!val; + } + + function getNumber(key: string, fallback: number): number { + const val = parseFloat(get(key)); + return isNaN(val) ? (fallback !== undefined ? fallback : NaN) : val; + } + + return { + get: get, + getBoolean: getBoolean, + getNumber: getNumber + }; +} diff --git a/packages/core/src/global/ionic-global.ts b/packages/core/src/global/ionic-global.ts new file mode 100644 index 0000000000..04328b5099 --- /dev/null +++ b/packages/core/src/global/ionic-global.ts @@ -0,0 +1,99 @@ +import { createConfigController } from './config-controller'; +import { detectPlatforms, PLATFORM_CONFIGS } from './platform-configs'; +import { IonicControllerApi, IonicGlobal } from '../index'; + + +// create the Ionic global (if one doesn't exist) +const Ionic: IonicGlobal = (window as any)['Ionic'] = (window as any)['Ionic'] || {}; + +// create the Ionic.config from raw config object (if it exists) +// and convert Ionic.config into a ConfigApi that has a get() fn +Ionic.config = createConfigController( + Ionic.config, + detectPlatforms(window.location.href, window.navigator.userAgent, PLATFORM_CONFIGS, 'core') +); + +// get the mode via config settings and set it to +// both Ionic and the Core global +Core.mode = Ionic.mode = Ionic.config.get('mode', 'md'); + + +// used to store the queued controller promises to +// be resolved when the controller finishes loading +const queuedCtrlResolves: {[ctrlName: string]: any[]} = {}; + + +// create a container for all of the controllers that get loaded +Ionic.controllers = {}; + +Ionic.controller = (ctrlName: string, opts?: any) => { + // loading a controller is always async so return a promise + return new Promise((resolve: Function) => { + // see if we already have the controller loaded + const ctrl = Ionic.controllers[ctrlName]; + if (ctrl) { + // we've already loaded this controller + // resolve it immediately + resolveController(ctrl, resolve, opts); + + } else { + // oh noz! we haven't already loaded this controller yet! + const ctrlResolveQueue = queuedCtrlResolves[ctrlName]; + if (ctrlResolveQueue) { + // cool we've already "started" to load the controller + // but it hasn't finished loading yet, so let's add + // this one also to the queue of to-be resolved promises + ctrlResolveQueue.push(resolve, opts); + + } else { + // looks like we haven't even started the request yet, + // let's add the component to the DOM and create + // a queue for this controller + queuedCtrlResolves[ctrlName] = [resolve, opts]; + + // create our controller element + // and append it to the body + document.body.appendChild(document.createElement(`ion-${ctrlName}-controller`)); + } + } + }); +}; + + +Ionic.loadController = (ctrlName: string, ctrl: IonicControllerApi) => { + // this method is called when the singleton + // instance of our controller initially loads + + // add this controller instance to our map of controller singletons + Ionic.controllers[ctrlName] = ctrl; + + // check for to-be resolved controller promises + const pendingCtrlResolves = queuedCtrlResolves[ctrlName]; + if (pendingCtrlResolves) { + for (var i = 0; i < pendingCtrlResolves.length; i += 2) { + // first arg is the original promise's resolve + // which still needs to be resolved + // second arg was the originally passed in options + resolveController(ctrl, pendingCtrlResolves[i], pendingCtrlResolves[i + 1]); + } + + // all good, go ahead and remove from the queue + delete queuedCtrlResolves[ctrlName]; + } +}; + + +function resolveController(ctrl: IonicControllerApi, resolve: Function, opts: any) { + if (opts) { + // if the call had options passed in then + // it should run the controller's load() method + // and let the controller's load() do the resolve + // which then will resolve the user's promise + ctrl.load(opts).then(resolve); + + } else { + // no options passed in, so resolve with + // the actual controller instance + resolve(ctrl); + } +} diff --git a/packages/core/src/global/platform-configs.ts b/packages/core/src/global/platform-configs.ts new file mode 100644 index 0000000000..af2f085e93 --- /dev/null +++ b/packages/core/src/global/platform-configs.ts @@ -0,0 +1,105 @@ + +const IPAD = 'ipad'; +const IPHONE = 'iphone'; +const IOS = 'ios'; +const WINDOWS_PHONE = ['windows phone']; + + +// order from most specifc to least specific +export const PLATFORM_CONFIGS: PlatformConfig[] = [ + + { + name: IPAD, + isMatch: (url, userAgent) => isPlatformMatch(url, userAgent, IPAD, [IPAD], WINDOWS_PHONE) + }, + + { + name: IPHONE, + isMatch: (url, userAgent) => isPlatformMatch(url, userAgent, IPHONE, [IPHONE], WINDOWS_PHONE) + }, + + { + name: IOS, + settings: { + mode: IOS, + }, + isMatch: (url, userAgent) => isPlatformMatch(url, userAgent, IOS, [IPHONE, IPAD, 'ipod'], WINDOWS_PHONE) + }, + + { + name: 'android', + settings: { + activator: 'ripple', + mode: 'md', + }, + isMatch: (url, userAgent) => isPlatformMatch(url, userAgent, 'android', ['android', 'silk'], WINDOWS_PHONE) + }, + + { + name: 'windows', + settings: { + mode: 'wp' + }, + isMatch: (url, userAgent) => isPlatformMatch(url, userAgent, 'windows', WINDOWS_PHONE, []) + }, + + { + name: 'core', + settings: { + mode: 'md' + } + }, + +]; + + +export function detectPlatforms(url: string, userAgent: string, platforms: PlatformConfig[], defaultPlatform: string) { + // bracket notation to ensure they're not property renamed + let validPlatforms = platforms.filter(p => p.isMatch && p.isMatch(url, userAgent)); + + if (!validPlatforms.length) { + validPlatforms = platforms.filter(p => p.name === defaultPlatform); + } + + return validPlatforms; +} + + +export function isPlatformMatch(url: string, userAgent: string, platformName: string, userAgentAtLeastHas: string[], userAgentMustNotHave: string[]) { + const queryValue = queryParam(url, 'ionicplatform'); + if (queryValue) { + return queryValue === platformName; + } + + if (userAgent) { + userAgent = userAgent.toLowerCase(); + + for (var i = 0; i < userAgentAtLeastHas.length; i++) { + if (userAgent.indexOf(userAgentAtLeastHas[i]) > -1) { + for (var j = 0; j < userAgentMustNotHave.length; j++) { + if (userAgent.indexOf(userAgentMustNotHave[j]) > -1) { + return false; + } + } + return true; + } + } + } + + return false; +} + + +function queryParam(url: string, key: string) { + key = key.replace(/[\[]/, '\\[').replace(/[\]]/, '\\]'); + var regex = new RegExp('[\\?&]' + key + '=([^&#]*)'); + var results = regex.exec(url); + return results ? decodeURIComponent(results[1].replace(/\+/g, ' ')) : null; +} + + +export interface PlatformConfig { + name: string; + isMatch?: {(url: string, userAgent: string): boolean}; + settings?: any; +} diff --git a/packages/core/src/index.d.ts b/packages/core/src/index.d.ts new file mode 100644 index 0000000000..8d75a8a908 --- /dev/null +++ b/packages/core/src/index.d.ts @@ -0,0 +1,90 @@ +import { Animation, AnimationBuilder } from './animations/interfaces'; +import { Loading, LoadingEvent, LoadingOptions } from './components/loading/loading'; +import { LoadingController } from './components/loading-controller/loading-controller'; +import { GestureDetail, GestureCallback } from './components/gesture/gesture'; +import { Menu } from './components/menu/menu'; +import { MenuType } from './components/menu/menu-types'; +import { MenuController } from './components/menu/menu-controller'; +import { Modal, ModalOptions, ModalEvent } from './components/modal/modal'; +import { ModalController } from './components/modal-controller/modal-controller'; +import { Scroll, ScrollCallback, ScrollDetail } from './components/scroll/scroll'; +import { Segment } from './components/segment/segment'; +import { SegmentButton, SegmentButtonEvent } from './components/segment-button/segment-button'; +import * as Stencil from '@stencil/core'; + + +declare global { + const Ionic: IonicGlobal; +} + + +export interface IonicGlobal extends Stencil.AppGlobal { + Animation?: Animation; + controllers?: {[ctrlName: string]: any}; + controller?: IonicController; + config: ConfigApi; + loadController?: (ctrlName: string, ctrl: any) => void; + mode: string; +} + + +export interface IonicController { + (ctrlName: 'loading', opts: LoadingOptions): Promise; + (ctrlName: 'menu'): Promise; + (ctrlName: 'modal', opts: ModalOptions): Promise; + (ctrlName: string, opts?: any): Promise; +} + + +export interface IonicControllerApi { + load?: (opts?: any) => Promise; +} + + +export interface ConfigApi { + get: (key: string, fallback?: any) => any; + getBoolean: (key: string, fallback?: boolean) => boolean; + getNumber: (key: string, fallback?: number) => number; +} + + +export type CssClassMap = { [className: string]: boolean }; + + +export interface BaseInputComponent { + disabled: boolean; + hasFocus: boolean; + value: string; + + fireFocus: () => void; + fireBlur: () => void; +} + + +export interface BooleanInputComponent extends BaseInputComponent { + checked: boolean; + toggle: (ev: UIEvent) => void; +} + + +export { + Animation, + AnimationBuilder, + GestureDetail, + Loading, + LoadingOptions, + LoadingController, + LoadingEvent, + Menu, + MenuController, + MenuType, + Modal, + ModalOptions, + ModalEvent, + Scroll, + ScrollCallback, + ScrollDetail, + Segment, + SegmentButton, + SegmentButtonEvent +} diff --git a/packages/core/src/utils/interfaces.ts b/packages/core/src/utils/interfaces.ts deleted file mode 100644 index b511edecc8..0000000000 --- a/packages/core/src/utils/interfaces.ts +++ /dev/null @@ -1,898 +0,0 @@ - -export interface Ionic { - emit: EventEmit; - listener: { - enable: EventListenerEnable; - add: AddEventListenerApi; - }; - theme: IonicTheme; - controller?: IonicController; - dom: DomControllerApi; - config: ConfigApi; - Animation?: Animation; - isServer: boolean; - isClient: boolean; -} - - -export interface IonicController { - (ctrlName: 'loading', opts: LoadingOptions): Promise; - (ctrlName: 'menu'): Promise; - (ctrlName: 'modal', opts: ModalOptions): Promise; - (ctrlName: string, opts?: any): Promise; -} - - -export interface IonicControllerApi { - load?: (opts?: any) => Promise; -} - - -export interface GlobalNamespace { - staticDir?: string; - components?: LoadComponentMeta[]; - defineComponents?: (coreVersion: number, bundleId: string, modulesImporterFn: ModulesImporterFn, cmp0?: LoadComponentMeta, cmp1?: LoadComponentMeta, cmp2?: LoadComponentMeta) => void; - eventNameFn?: (eventName: string) => string; - config?: Object; - loadController?: (ctrlName: string, ctrl: any) => any; - controllers?: {[ctrlName: string]: any}; - ConfigCtrl?: ConfigApi; - DomCtrl?: DomControllerApi; - QueueCtrl?: QueueApi; - Animation?: any; -} - - -export interface Menu { - setOpen(shouldOpen: boolean, animated?: boolean): Promise; - open(): Promise; - close(): Promise; - toggle(): Promise; - enable(shouldEnable: boolean): Menu; - swipeEnable(shouldEnable: boolean): Menu; - isAnimating: boolean; - isOpen: boolean; - isRightSide: boolean; - enabled: boolean; - side: string; - id: string; - maxEdgeStart: number; - persistent: boolean; - swipeEnabled: boolean; - type: string; - width(): number; - getMenuElement(): HTMLElement; - getContentElement(): HTMLElement; - getBackdropElement(): HTMLElement; -} - - -export interface MenuType { - ani: any; - isOpening: boolean; - setOpen(shouldOpen: boolean, animated: boolean, done: Function): void; - setProgressStart(isOpen: boolean): void; - setProgessStep(stepValue: number): void; - setProgressEnd(shouldComplete: boolean, currentStepValue: number, velocity: number, done: Function): void; - destroy(): void; -} - - -export interface MenuController { - open(menuId?: string): Promise; - close(menuId?: string): Promise; - toggle(menuId?: string): Promise; - enable(shouldEnable: boolean, menuId?: string): void; - swipeEnable(shouldEnable: boolean, menuId?: string): void; - isOpen(menuId?: string): boolean; - isEnabled(menuId?: string): boolean; - get(menuId?: string): Menu; - getOpen(): Menu; - getMenus(): Menu[]; -} - - -export interface Modal { - component: string; - componentProps?: any; - id: string; - style?: { - zIndex: number; - }; - showBackdrop: boolean; - enableBackdropDismiss: boolean; - enterAnimation: AnimationBuilder; - exitAnimation: AnimationBuilder; - cssClass: string; - present: () => Promise; - dismiss: () => Promise; -} - - -export interface ModalOptions { - component: string; - componentProps?: any; - showBackdrop?: boolean; - enableBackdropDismiss?: boolean; - enterAnimation?: AnimationBuilder; - exitAnimation?: AnimationBuilder; - cssClass?: string; -} - - -export interface ModalEvent { - detail: { - modal: Modal; - }; -} - - -export interface Loading { - id: string; - style?: { - zIndex: number; - }; - showBackdrop: boolean; - enterAnimation: AnimationBuilder; - exitAnimation: AnimationBuilder; - cssClass: string; - present: () => Promise; - dismiss: () => Promise; -} - - -export interface LoadingOptions { - spinner?: string; - content?: string; - cssClass?: string; - showBackdrop?: boolean; - dismissOnPageChange?: boolean; - duration?: number; -} - - -export interface LoadingEvent { - detail: { - loading: Loading; - }; -} - - -export interface AddEventListenerApi { - (elm: HTMLElement|HTMLDocument|Window, eventName: string, cb: (ev?: any) => void, opts?: ListenOptions): Function; -} - - -export interface EventEmit { - (instance: any, eventName: string, data?: CustomEventOptions): void; -} - - -export interface CustomEventOptions { - bubbles?: boolean; - cancelable?: boolean; - composed?: boolean; - detail?: any; -} - - -export interface EventListenerEnable { - (instance: any, eventName: string, enabled: boolean, attachTo?: string): void; -} - - -export interface EventListenerCallback { - (ev?: any): void; -} - - -export interface GestureDetail { - type?: string; - event?: UIEvent; - startX?: number; - startY?: number; - startTimeStamp?: number; - currentX?: number; - currentY?: number; - velocityX?: number; - velocityY?: number; - deltaX?: number; - deltaY?: number; - directionX?: 'left'|'right'; - directionY?: 'up'|'down'; - velocityDirectionX?: 'left'|'right'; - velocityDirectionY?: 'up'|'down'; - timeStamp?: number; -} - - -export interface GestureCallback { - (detail?: GestureDetail): boolean|void; -} - - -export interface SegmentButtonEvent { - detail: { - segmentButton: any; - }; -} - - -export interface ScrollDetail extends GestureDetail { - scrollTop?: number; - scrollLeft?: number; - scrollHeight?: number; - scrollWidth?: number; - contentHeight?: number; - contentWidth?: number; - contentTop?: number; - contentBottom?: number; - domWrite?: DomControllerCallback; - contentElement?: HTMLElement; - fixedElement?: HTMLElement; - scrollElement?: HTMLElement; - headerElement?: HTMLElement; - footerElement?: HTMLElement; -} - - -export interface ScrollCallback { - (detail?: ScrollDetail): boolean|void; -} - - -export interface ContentDimensions { - contentHeight: number; - contentTop: number; - contentBottom: number; - - contentWidth: number; - contentLeft: number; - - scrollHeight: number; - scrollTop: number; - - scrollWidth: number; - scrollLeft: number; -} - - -export interface QueueApi { - add: (cb: Function, priority?: number) => void; - flush: (cb?: Function) => void; -} - - -export interface DomControllerApi { - read: DomControllerCallback; - write: DomControllerCallback; - raf: DomControllerCallback; - now(): number; -} - -export interface RafCallback { - (timeStamp?: number): void; -} - - -export interface DomControllerCallback { - (cb: RafCallback): void; -} - - -export interface LoadComponentMeta { - /** - * tag name (ion-badge) - */ - [0]: string; - - /** - * map of the modes and bundle ids - */ - [1]: { - [modeName: string]: { - /** - * bundleId - */ - [0]: string; - - /** - * styles - */ - [1]: string; - } - }; - - /** - * props - */ - [2]: any[]; - - /** - * slot - */ - [3]: number; - - /** - * host - */ - [4]: any; - - /** - * listeners - */ - [5]: ComponentListenersData[]; - - /** - * states - */ - [6]: StateMeta[]; - - /** - * watchers - */ - [7]: ComponentWatchersData[]; - - /** - * methods - */ - [8]: MethodMeta[]; - - /** - * shadow - */ - [9]: boolean; -} - - -export interface Bundle { - id?: string; - components?: ComponentMeta[]; - modeName?: string; - bundledJsModules?: string; - content?: string; - fileName?: string; - filePath?: string; -} - - -export interface FormatComponentDataOptions { - defaultAttrCase?: number; - minimumData?: boolean; - onlyIncludeModeName?: string; - includeStyles?: boolean; -} - - -export interface ComponentListenersData { - /** - * methodName - */ - [0]: string; - - /** - * eventName - */ - [1]: string; - - /** - * capture - */ - [2]: number; - - /** - * passive - */ - [3]: number; - - /** - * enabled - */ - [4]: number; -} - - -export interface ComponentWatchersData { - [methodName: string]: any; -} - - -export interface ModulesImporterFn { - (importer: any, h: Function, t: Function, Ionic: Ionic): void; -} - - -export interface ComponentDecorator { - (opts?: ComponentOptions): any; -} - - -export interface ComponentOptions { - tag: string; - styleUrls?: string | string[] | ModeStyles; - styles?: string | string[]; - shadow?: boolean; - host?: HostMeta; -} - -export interface ModeStyles { - [modeName: string]: string | string[]; -} - - -export interface PropDecorator { - (opts?: PropOptions): any; -} - - -export interface PropOptions { - type?: string; - twoWay?: boolean; -} - - -export interface PropMeta { - propName?: string; - propType?: number; - attribName?: string; - attribCase?: number; - isTwoWay?: boolean; -} - - -export type MethodMeta = string; - - -export interface MethodDecorator { - (opts?: MethodOptions): any; -} - - -export interface MethodOptions {} - - -export interface ListenDecorator { - (eventName: string, opts?: ListenOptions): any; -} - - -export interface ListenOptions { - eventName?: string; - capture?: boolean; - passive?: boolean; - enabled?: boolean; -} - - -export interface ListenMeta { - eventMethod?: string; - eventName?: string; - eventCapture?: boolean; - eventPassive?: boolean; - eventEnabled?: boolean; -} - - -export interface StateDecorator { - (): any; -} - - -export type StateMeta = string; - - -export interface WatchDecorator { - (propName: string): any; -} - - -export interface WatchOpts { - fn: string; -} - - -export interface WatchMeta extends WatchOpts { - propName?: string; -} - - -export interface IonicTheme { - (instance: any, cssClassName: string, vnodeData?: VNodeData): VNodeData; -} - - -export interface ConfigApi { - get: (key: string, fallback?: any) => any; - getBoolean: (key: string, fallback?: boolean) => boolean; - getNumber: (key: string, fallback?: number) => number; -} - - -export interface ComponentMeta { - // "Meta" suffix to ensure property renaming - tagNameMeta?: string; - methodsMeta?: MethodMeta[]; - propsMeta?: PropMeta[]; - listenersMeta?: ListenMeta[]; - watchersMeta?: WatchMeta[]; - statesMeta?: StateMeta[]; - modesMeta?: ModesMeta; - modesStyleMeta?: ModesStyleMeta; - isShadowMeta?: boolean; - hostMeta?: HostMeta; - slotMeta?: number; - componentModuleMeta?: any; - componentClass?: string; - componentUrl?: string; -} - - -export interface ModesMeta { - [modeName: string]: ModeMeta; -} - - -export interface ModesStyleMeta { - [modeName: string]: ModeStyleMeta; -} - - -export interface ModeStyleMeta { - styleUrls?: string[]; - styles?: string[]; -} - - -export interface ModeMeta { - /** - * bundleId - */ - [0]?: string; - - /** - * styles - */ - [1]?: string; -} - -export interface HostMeta { - [key: string]: any; -} - - -export interface Component { - ionViewWillLoad?: () => void; - ionViewDidLoad?: () => void; - ionViewWillUpdate?: () => void; - ionViewDidUpdate?: () => void; - ionViewDidUnload?: () => void; - - render?: () => any; - hostData?: () => VNodeData; - - mode?: string; - color?: string; - - // public properties - $el?: HostElement; - - // private properties - __values?: ComponentActiveValues; - - [memberName: string]: any; -} - - -export interface ComponentActiveListeners { - [eventName: string]: Function; -} - - -export interface ComponentActiveWatchers { - [propName: string]: Function; -} - - -export interface ComponentActiveValues { - [propName: string]: any; -} - - -export interface BaseInputComponent extends Component { - disabled: boolean; - hasFocus: boolean; - value: string; - - fireFocus: () => void; - fireBlur: () => void; -} - - -export interface BooleanInputComponent extends BaseInputComponent { - checked: boolean; - toggle: (ev: UIEvent) => void; -} - - -export interface ComponentModule { - new (): Component; -} - - -export interface ComponentRegistry { - [tag: string]: ComponentMeta; -} - - -export interface HostElement extends HTMLElement { - // web component APIs - connectedCallback: () => void; - attributeChangedCallback?: (attribName: string, oldVal: string, newVal: string, namespace: string) => void; - disconnectedCallback?: () => void; - - // public properties - $instance?: Component; - - // private methods - _render: (isUpdateRender?: boolean) => void; - _initLoad: () => void; - _queueUpdate: () => void; - - // private properties - _activelyLoadingChildren?: HostElement[]; - _ancestorHostElement?: HostElement; - _hasConnected?: boolean; - _hasDestroyed?: boolean; - _hasLoaded?: boolean; - _hostContentNodes?: HostContentNodes; - _isQueuedForUpdate?: boolean; - _listeners?: ComponentActiveListeners; - _root?: HTMLElement | ShadowRoot; - _vnode: VNode; - _watchers?: ComponentActiveWatchers; -} - - -export interface RendererApi { - (oldVNode: VNode | Element, newVNode: VNode, isUpdate?: boolean, hostContentNodes?: HostContentNodes): VNode; -} - - -export interface DomApi { - $head: HTMLHeadElement; - $body: HTMLElement; - $nodeType(node: any): number; - $createEvent(): CustomEvent; - $createElement(tagName: K): HTMLElementTagNameMap[K]; - $createElement(tagName: string): HTMLElement; - $createElementNS(namespace: string, tagName: string): any; - $createTextNode(text: string): Text; - $insertBefore(parentNode: Node, newNode: Node, referenceNode: Node): void; - $removeChild(node: Node, child: Node): void; - $appendChild(node: Node, child: Node): void; - $childNodes(node: Node): NodeList; - $parentNode(node: Node): Node; - $nextSibling(node: Node): Node; - $tagName(elm: any): string; - $getTextContent(node: any): string; - $setTextContent(node: Node, text: string): void; - $getAttribute(elm: any, key: string): string; - $setAttribute(elm: any, key: string, val: any): void; - $setAttributeNS(elm: any, namespaceURI: string, qualifiedName: string, value: string): void; - $removeAttribute(elm: any, key: string): void; -} - -export type Key = string | number; - - -export interface Hyperscript { - (sel: any): VNode; - (sel: Node, data: VNodeData): VNode; - (sel: any, data: VNodeData): VNode; - (sel: any, text: string): VNode; - (sel: any, children: Array): VNode; - (sel: any, data: VNodeData, text: string): VNode; - (sel: any, data: VNodeData, children: Array): VNode; - (sel: any, data: VNodeData, children: VNode): VNode; -} - - -export interface HostContentNodes { - defaultSlot?: Node[]; - namedSlots?: {[slotName: string]: Node[]}; -} - - -export type CssClassObject = { [className: string]: boolean }; - - - -export interface VNode { - // using v prefixes largely so closure has no issue property renaming - vtag: string; - vtext: string; - vchildren: VNode[]; - vprops: any; - vattrs: any; - vclass: CssClassObject; - vstyle: any; - vlisteners: any; - vkey: Key; - elm: Element|Node; - vnamespace: any; - assignedListener: any; - skipDataOnUpdate: boolean; - skipChildrenOnUpdate: boolean; -} - -export interface VNodeData { - props?: any; - attrs?: any; - class?: CssClassObject; - style?: any; - on?: any; - key?: Key; - ns?: any; // for SVGs -} - -/** - * used by production compiler - */ -export interface VNodeProdData { - /** - * props - */ - p?: any; - /** - * attrs - */ - a?: any; - /** - * css classes - */ - c?: CssClassObject; - /** - * styles - */ - s?: any; - /** - * on (event listeners) - */ - o?: any; - /** - * key - */ - k?: Key; - /** - * namespace - */ - n?: any; - /** - * check once - */ - x?: number; -} - - -export interface PlatformApi { - registerComponents?: (components?: LoadComponentMeta[]) => ComponentMeta[]; - defineComponent: (cmpMeta: ComponentMeta, HostElementConstructor?: any) => void; - getComponentMeta: (elm: Element) => ComponentMeta; - loadBundle: (bundleId: string, cb: Function) => void; - render?: RendererApi; - config: ConfigApi; - connectHostElement: (elm: HostElement, slotMeta: number) => void; - queue: QueueApi; - isServer?: boolean; - attachStyles: (cmpMeta: ComponentMeta, elm: HostElement, instance: Component) => void; - getMode: (elm: Element) => string; - appRoot?: HostElement; - appLoaded?: () => void; - onAppLoad?: (rootElm: HostElement, css: string) => void; - hasAppLoaded?: boolean; - tmpDisconnected?: boolean; -} - - -export interface PlatformConfig { - name: string; - isMatch?: {(url: string, userAgent: string): boolean}; - settings?: any; -} - - -export interface Animation { - new(elm?: Node|Node[]|NodeList): Animation; - add: (childAnimation: Animation) => Animation; - addElement: (elm: Node|Node[]|NodeList) => Animation; - afterAddClass: (className: string) => Animation; - afterClearStyles: (propertyNames: string[]) => Animation; - afterRemoveClass: (className: string) => Animation; - afterStyles: (styles: { [property: string]: any; }) => Animation; - beforeAddClass: (className: string) => Animation; - beforeClearStyles: (propertyNames: string[]) => Animation; - beforeRemoveClass: (className: string) => Animation; - beforeStyles: (styles: { [property: string]: any; }) => Animation; - destroy: () => void; - duration: (milliseconds: number) => Animation; - getDuration(opts?: PlayOptions): number; - easing: (name: string) => Animation; - easingReverse: (name: string) => Animation; - from: (prop: string, val: any) => Animation; - fromTo: (prop: string, fromVal: any, toVal: any, clearProperyAfterTransition?: boolean) => Animation; - hasCompleted: boolean; - isPlaying: boolean; - onFinish: (callback: (animation: Animation) => void, opts?: {oneTimeCallback?: boolean, clearExistingCallacks?: boolean}) => Animation; - play: (opts?: PlayOptions) => void; - syncPlay: () => void; - progressEnd: (shouldComplete: boolean, currentStepValue: number, dur: number) => void; - progressStep: (stepValue: number) => void; - progressStart: () => void; - reverse: (shouldReverse?: boolean) => Animation; - stop: (stepValue?: number) => void; - to: (prop: string, val: any, clearProperyAfterTransition?: boolean) => Animation; -} - - -export interface AnimationBuilder { - (elm?: HTMLElement): Animation; -} - - -export interface AnimationOptions { - animation?: string; - duration?: number; - easing?: string; - direction?: string; - isRTL?: boolean; - ev?: any; -} - - -export interface PlayOptions { - duration?: number; - promise?: boolean; -} - - -export interface EffectProperty { - effectName: string; - trans: boolean; - wc?: string; - to?: EffectState; - from?: EffectState; - [state: string]: any; -} - - -export interface EffectState { - val: any; - num: number; - effectUnit: string; -} - - -export interface RequestIdleCallback { - (callback: IdleCallback, options?: { timeout?: number }): number; -} - - -export interface IdleCallback { - (deadline: IdleDeadline, options?: IdleOptions): void; -} - - -export interface IdleDeadline { - didTimeout: boolean; - timeRemaining: () => number; -} - - -export interface IdleOptions { - timeout?: number; -} - - -export interface BundleCallbacks { - [bundleId: string]: Function[]; -} diff --git a/packages/core/src/utils/theme.ts b/packages/core/src/utils/theme.ts index 45a8f61fc9..e7c1eca719 100644 --- a/packages/core/src/utils/theme.ts +++ b/packages/core/src/utils/theme.ts @@ -1,10 +1,11 @@ -import { CssClassObject } from '@stencil/core'; +import { CssClassMap } from '@stencil/core'; -export function createThemedClasses(mode: string, color: string, classList: string): CssClassObject { - let allClassObj: CssClassObject = {}; + +export function createThemedClasses(mode: string, color: string, classList: string): CssClassMap { + let allClassObj: CssClassMap = {}; return classList.split(' ') - .reduce((classObj: CssClassObject, classString: string): CssClassObject => { + .reduce((classObj: CssClassMap, classString: string): CssClassMap => { classObj[classString] = true; if (mode) { diff --git a/packages/core/stencil.config.js b/packages/core/stencil.config.js index 143977c4ef..41095e8035 100644 --- a/packages/core/stencil.config.js +++ b/packages/core/stencil.config.js @@ -23,7 +23,8 @@ exports.config = { { components: ['ion-tabs', 'ion-tab', 'ion-tab-bar', 'ion-tab-button', 'ion-tab-highlight'] }, { components: ['ion-toggle'] } ], - preamble: '(C) Ionic http://ionicframework.com - MIT License' + preamble: '(C) Ionic http://ionicframework.com - MIT License', + global: 'src/global/ionic-global.ts' }; exports.devServerConfig = { diff --git a/packages/ionic-angular/src/components/gesture/gesture.ts b/packages/ionic-angular/src/components/gesture/gesture.ts index d414f33c53..f4a9d449e3 100644 --- a/packages/ionic-angular/src/components/gesture/gesture.ts +++ b/packages/ionic-angular/src/components/gesture/gesture.ts @@ -60,7 +60,7 @@ export class Gesture { Ionic.listener.enable(this, 'touchstart', true, this.attachTo); Ionic.listener.enable(this, 'mousedown', true, this.attachTo); - Ionic.dom.write(() => { + Core.dom.write(() => { applyStyles(getElementReference(this.$el, this.attachTo), GESTURE_INLINE_STYLES); }); } @@ -178,7 +178,7 @@ export class Gesture { if (!this.isMoveQueued) { this.isMoveQueued = true; - Ionic.dom.write(() => { + Core.dom.write(() => { this.isMoveQueued = false; detail.type = 'pan'; diff --git a/packages/ionic-angular/src/components/scroll/scroll.ts b/packages/ionic-angular/src/components/scroll/scroll.ts index 38cb7a161d..e394867e39 100644 --- a/packages/ionic-angular/src/components/scroll/scroll.ts +++ b/packages/ionic-angular/src/components/scroll/scroll.ts @@ -44,7 +44,7 @@ export class Scroll implements IScroll { if (!self.queued && self.enabled) { self.queued = true; - Ionic.dom.read(function(timeStamp) { + Core.dom.read(function(timeStamp) { self.queued = false; self.onScroll(timeStamp || Date.now()); }); @@ -127,7 +127,7 @@ export class Scroll implements IScroll { // haven't scrolled in a while, so it's a scrollend self.isScrolling = false; - Ionic.dom.read(function(timeStamp) { + Core.dom.read(function(timeStamp) { if (!self.isScrolling) { self.onEnd(timeStamp); } @@ -315,7 +315,7 @@ export class Scroll implements IScroll { if (easedT < 1) { // do not use DomController here // must use nativeRaf in order to fire in the next frame - Ionic.dom.raf(step); + Core.dom.raf(step); } else { stopScroll = true; @@ -329,8 +329,8 @@ export class Scroll implements IScroll { self.isScrolling = true; // chill out for a frame first - Ionic.dom.write(() => { - Ionic.dom.write(timeStamp => { + Core.dom.write(() => { + Core.dom.write(timeStamp => { startTime = timeStamp; step(timeStamp); }); diff --git a/packages/ionic-angular/src/util/interfaces.ts b/packages/ionic-angular/src/util/interfaces.ts deleted file mode 100644 index 313245d5bb..0000000000 --- a/packages/ionic-angular/src/util/interfaces.ts +++ /dev/null @@ -1,918 +0,0 @@ - -export interface Ionic { - emit: EventEmit; - listener: { - enable: EventListenerEnable; - add: AddEventListenerApi; - }; - theme: IonicTheme; - controller?: IonicController; - dom: DomControllerApi; - config: ConfigApi; - Animation?: Animation; - isServer: boolean; - isClient: boolean; -} - - -export interface IonicController { - (ctrlName: 'loading', opts: LoadingOptions): Promise; - (ctrlName: 'menu'): Promise; - (ctrlName: 'modal', opts: ModalOptions): Promise; - (ctrlName: string, opts?: any): Promise; -} - - -export interface IonicControllerApi { - load?: (opts?: any) => Promise; -} - - -export interface IonicGlobal { - staticDir?: string; - components?: LoadComponentData[]; - defineComponents?: (coreVersion: number, bundleId: string, modulesImporterFn: ModulesImporterFn, cmp0?: ComponentModeData, cmp1?: ComponentModeData, cmp2?: ComponentModeData) => void; - eventNameFn?: (eventName: string) => string; - config?: Object; - loadController?: (ctrlName: string, ctrl: any) => any; - controllers?: {[ctrlName: string]: any}; - ConfigCtrl?: ConfigApi; - DomCtrl?: DomControllerApi; - QueueCtrl?: QueueApi; - Animation?: any; -} - - -export interface Menu { - setOpen(shouldOpen: boolean, animated?: boolean): Promise; - open(): Promise; - close(): Promise; - toggle(): Promise; - enable(shouldEnable: boolean): Menu; - swipeEnable(shouldEnable: boolean): Menu; - isAnimating: boolean; - isOpen: boolean; - isRightSide: boolean; - enabled: boolean; - side: string; - id: string; - maxEdgeStart: number; - persistent: boolean; - swipeEnabled: boolean; - type: string; - width(): number; - getMenuElement(): HTMLElement; - getContentElement(): HTMLElement; - getBackdropElement(): HTMLElement; -} - - -export interface MenuType { - ani: any; - isOpening: boolean; - setOpen(shouldOpen: boolean, animated: boolean, done: Function): void; - setProgressStart(isOpen: boolean): void; - setProgessStep(stepValue: number): void; - setProgressEnd(shouldComplete: boolean, currentStepValue: number, velocity: number, done: Function): void; - destroy(): void; -} - - -export interface MenuController { - open(menuId?: string): Promise; - close(menuId?: string): Promise; - toggle(menuId?: string): Promise; - enable(shouldEnable: boolean, menuId?: string): void; - swipeEnable(shouldEnable: boolean, menuId?: string): void; - isOpen(menuId?: string): boolean; - isEnabled(menuId?: string): boolean; - get(menuId?: string): Menu; - getOpen(): Menu; - getMenus(): Menu[]; -} - - -export interface Modal { - component: string; - componentProps?: any; - id: string; - style?: { - zIndex: number; - }; - showBackdrop: boolean; - enableBackdropDismiss: boolean; - enterAnimation: AnimationBuilder; - exitAnimation: AnimationBuilder; - cssClass: string; - present: () => Promise; - dismiss: () => Promise; -} - - -export interface ModalOptions { - component: string; - componentProps?: any; - showBackdrop?: boolean; - enableBackdropDismiss?: boolean; - enterAnimation?: AnimationBuilder; - exitAnimation?: AnimationBuilder; - cssClass?: string; -} - - -export interface ModalEvent { - detail: { - modal: Modal; - }; -} - - -export interface Loading { - id: string; - style?: { - zIndex: number; - }; - showBackdrop: boolean; - enterAnimation: AnimationBuilder; - exitAnimation: AnimationBuilder; - cssClass: string; - present: () => Promise; - dismiss: () => Promise; -} - - -export interface LoadingOptions { - spinner?: string; - content?: string; - cssClass?: string; - showBackdrop?: boolean; - dismissOnPageChange?: boolean; - duration?: number; -} - - -export interface LoadingEvent { - detail: { - loading: Loading; - }; -} - - -export interface AddEventListenerApi { - (elm: HTMLElement|HTMLDocument|Window, eventName: string, cb: (ev?: any) => void, opts?: ListenOptions): Function; -} - - -export interface EventEmit { - (instance: any, eventName: string, data?: CustomEventOptions): void; -} - - -export interface CustomEventOptions { - bubbles?: boolean; - cancelable?: boolean; - composed?: boolean; - detail?: any; -} - - -export interface EventListenerEnable { - (instance: any, eventName: string, enabled: boolean, attachTo?: string): void; -} - - -export interface EventListenerCallback { - (ev?: any): void; -} - - -export interface GestureDetail { - type?: string; - event?: UIEvent; - startX?: number; - startY?: number; - startTimeStamp?: number; - currentX?: number; - currentY?: number; - velocityX?: number; - velocityY?: number; - deltaX?: number; - deltaY?: number; - directionX?: 'left'|'right'; - directionY?: 'up'|'down'; - velocityDirectionX?: 'left'|'right'; - velocityDirectionY?: 'up'|'down'; - timeStamp?: number; -} - - -export interface GestureCallback { - (detail?: GestureDetail): boolean|void; -} - - -export interface ScrollDetail extends GestureDetail { - scrollTop?: number; - scrollLeft?: number; - scrollHeight?: number; - scrollWidth?: number; - contentHeight?: number; - contentWidth?: number; - contentTop?: number; - contentBottom?: number; - domWrite?: DomControllerCallback; - contentElement?: HTMLElement; - fixedElement?: HTMLElement; - scrollElement?: HTMLElement; - headerElement?: HTMLElement; - footerElement?: HTMLElement; -} - - -export interface ScrollCallback { - (detail?: ScrollDetail): boolean|void; -} - - -export interface ContentDimensions { - contentHeight: number; - contentTop: number; - contentBottom: number; - - contentWidth: number; - contentLeft: number; - - scrollHeight: number; - scrollTop: number; - - scrollWidth: number; - scrollLeft: number; -} - - -export interface QueueApi { - add: (cb: Function, priority?: number) => void; - flush: (cb?: Function) => void; -} - - -export interface DomControllerApi { - read: DomControllerCallback; - write: DomControllerCallback; - raf: DomControllerCallback; - now(): number; -} - -export interface RafCallback { - (timeStamp?: number): void; -} - - -export interface DomControllerCallback { - (cb: RafCallback): void; -} - - -export interface LoadComponentData { - /** - * tag name (ion-badge) - */ - [0]: string; - - /** - * map of the modes and bundle ids - */ - [1]: { - [modeCode: string]: string; - }; - - /** - * slot meta - */ - [2]: number; - - /** - * props - */ - [3]: any[]; - - /** - * bundle priority - */ - [4]: LoadPriority; -} - - -export type LoadPriority = number; - - -export interface Bundle { - id?: string; - components?: BundleComponent[]; - bundledJsModules?: string; - content?: string; - fileName?: string; - filePath?: string; - priority?: number; -} - - -export interface BundleComponent { - component: ManifestComponentMeta; - modeName: string; - modeMeta: ModeMeta; -} - - -export interface ManifestComponentMeta extends ComponentMeta { - componentClass: string; - componentUrl: string; -} - - -export interface ComponentModeData { - /** - * tag name (ion-badge) - */ - [0]: string; - - /** - * props - */ - [1]: any[][]; - - /** - * methods - */ - [2]: MethodMeta[]; - - /** - * states - */ - [3]: StateMeta[]; - - /** - * listeners - */ - [4]: ComponentListenersData[]; - - /** - * watchers - */ - [5]: ComponentWatchersData[]; - - /** - * shadow - */ - [6]: boolean; - - /** - * host - */ - [7]: any; - - /** - * mode code, which is a number that'll - * map to a mode name later (ios, md, wp) - */ - [8]: number; - - - /** - * component mode styles - */ - [9]: string; -} - - -export interface ComponentListenersData { - /** - * methodName - */ - [0]: string; - - /** - * eventName - */ - [1]: string; - - /** - * capture - */ - [2]: number; - - /** - * passive - */ - [3]: number; - - /** - * enabled - */ - [4]: number; -} - - -export interface ComponentWatchersData { - [methodName: string]: any; -} - - -export interface ModulesImporterFn { - (importer: any, h: Function, t: Function, Ionic: Ionic): void; -} - - -export interface ComponentDecorator { - (opts?: ComponentOptions): any; -} - - -export interface ComponentOptions { - tag: string; - styleUrls?: string | string[] | ModeStyles; - shadow?: boolean; - host?: HostMeta; -} - -export interface ModeStyles { - [modeName: string]: string | string[]; -} - - -export interface PropDecorator { - (opts?: PropOptions): any; -} - - -export interface PropOptions { - type?: number; -} - - -export interface PropMeta { - propName?: string; - propType?: any; - attribName?: string; - attribCase?: number; -} - - -export type MethodMeta = string; - - -export interface MethodDecorator { - (opts?: MethodOptions): any; -} - - -export interface MethodOptions {} - - -export interface ListenDecorator { - (eventName: string, opts?: ListenOptions): any; -} - - -export interface ListenOptions { - eventName?: string; - capture?: boolean; - passive?: boolean; - enabled?: boolean; -} - - -export interface ListenMeta extends ListenOptions { - methodName?: string; -} - - -export interface StateDecorator { - (): any; -} - - -export type StateMeta = string; - - -export interface WatchDecorator { - (propName: string): any; -} - - -export interface WatchOpts { - fn: string; -} - - -export interface WatchMeta extends WatchOpts { - propName?: string; -} - - -export interface IonicTheme { - (instance: any, cssClassName: string, vnodeData?: VNodeData): VNodeData; -} - - -export interface ConfigApi { - get: (key: string, fallback?: any) => any; - getBoolean: (key: string, fallback?: boolean) => boolean; - getNumber: (key: string, fallback?: number) => number; -} - - -export interface ComponentMeta { - // "Meta" suffix to ensure property renaming - tagNameMeta?: string; - methodsMeta?: MethodMeta[]; - propsMeta?: PropMeta[]; - listenersMeta?: ListenMeta[]; - watchersMeta?: WatchMeta[]; - statesMeta?: StateMeta[]; - modesMeta?: {[modeCode: string]: ModeMeta}; - isShadowMeta?: boolean; - hostMeta?: HostMeta; - slotMeta?: number; - componentModuleMeta?: any; - priorityMeta?: LoadPriority; -} - - -export interface ModeMeta { - bundleId?: string; - styles?: string; - styleUrls?: string[]; -} - -export interface HostMeta { - [key: string]: any; -} - -export interface Component { - ionViewWillLoad?: () => void; - ionViewDidLoad?: () => void; - ionViewWillUpdate?: () => void; - ionViewDidUpdate?: () => void; - ionViewDidUnload?: () => void; - - render?: () => VNode; - hostData?: () => VNodeData; - - mode?: string; - color?: string; - - // public properties - $el?: HostElement; - - // private properties - __values?: ComponentActiveValues; - - [memberName: string]: any; -} - - -export interface ComponentActiveListeners { - [eventName: string]: Function; -} - - -export interface ComponentActiveWatchers { - [propName: string]: Function; -} - - -export interface ComponentActiveValues { - [propName: string]: any; -} - - -export interface BaseInputComponent extends Component { - disabled: boolean; - hasFocus: boolean; - value: string; - - fireFocus: () => void; - fireBlur: () => void; -} - - -export interface BooleanInputComponent extends BaseInputComponent { - checked: boolean; - toggle: (ev: UIEvent) => void; -} - - -export interface ComponentModule { - new (): Component; -} - - -export interface ComponentRegistry { - [tag: string]: ComponentMeta; -} - - -export interface HostElement extends HTMLElement { - // web component APIs - connectedCallback: () => void; - attributeChangedCallback?: (attribName: string, oldVal: string, newVal: string, namespace: string) => void; - disconnectedCallback?: () => void; - - // public properties - $instance?: Component; - - // private methods - _render: (isUpdateRender?: boolean) => void; - _initLoad: () => void; - _queueUpdate: () => void; - - // private properties - _activelyLoadingChildren?: HostElement[]; - _ancestorHostElement?: HostElement; - _hasConnected?: boolean; - _hasDestroyed?: boolean; - _hasLoaded?: boolean; - _hostContentNodes?: HostContentNodes; - _isQueuedForUpdate?: boolean; - _listeners?: ComponentActiveListeners; - _root?: HTMLElement | ShadowRoot; - _vnode: VNode; - _watchers?: ComponentActiveWatchers; -} - - -export interface RendererApi { - (oldVNode: VNode | Element, newVNode: VNode, isUpdate?: boolean, hostContentNodes?: HostContentNodes): VNode; -} - - -export interface DomApi { - $head: HTMLHeadElement; - $body: HTMLElement; - $nodeType(node: any): number; - $createEvent(): CustomEvent; - $createElement(tagName: K): HTMLElementTagNameMap[K]; - $createElement(tagName: string): HTMLElement; - $createElementNS(namespace: string, tagName: string): any; - $createTextNode(text: string): Text; - $insertBefore(parentNode: Node, newNode: Node, referenceNode: Node): void; - $removeChild(node: Node, child: Node): void; - $appendChild(node: Node, child: Node): void; - $childNodes(node: Node): NodeList; - $parentNode(node: Node): Node; - $nextSibling(node: Node): Node; - $tagName(elm: any): string; - $getTextContent(node: any): string; - $setTextContent(node: Node, text: string): void; - $getAttribute(elm: any, key: string): string; - $setAttribute(elm: any, key: string, val: string): void; - $setAttributeNS(elm: any, namespaceURI: string, qualifiedName: string, value: string): void; - $removeAttribute(elm: any, key: string): void; -} - -export type Key = string | number; - - -export interface Hyperscript { - (sel: any): VNode; - (sel: Node, data: VNodeData): VNode; - (sel: any, data: VNodeData): VNode; - (sel: any, text: string): VNode; - (sel: any, children: Array): VNode; - (sel: any, data: VNodeData, text: string): VNode; - (sel: any, data: VNodeData, children: Array): VNode; - (sel: any, data: VNodeData, children: VNode): VNode; -} - - -export interface HostContentNodes { - defaultSlot?: Node[]; - namedSlots?: {[slotName: string]: Node[]}; -} - - -export type CssClassObject = { [className: string]: boolean }; - - - -export interface VNode { - // using v prefixes largely so closure has no issue property renaming - vtag: string; - vtext: string; - vchildren: VNode[]; - vprops: any; - vattrs: any; - vclass: CssClassObject; - vstyle: any; - vlisteners: any; - vkey: Key; - elm: Element|Node; - vnamespace: any; - assignedListener: any; - skipDataOnUpdate: boolean; - skipChildrenOnUpdate: boolean; -} - -export interface VNodeData { - props?: any; - attrs?: any; - class?: CssClassObject; - style?: any; - on?: any; - key?: Key; - ns?: any; // for SVGs -} - -/** - * used by production compiler - */ -export interface VNodeProdData { - /** - * props - */ - p?: any; - /** - * attrs - */ - a?: any; - /** - * css classes - */ - c?: CssClassObject; - /** - * styles - */ - s?: any; - /** - * on (event listeners) - */ - o?: any; - /** - * key - */ - k?: Key; - /** - * namespace - */ - n?: any; - /** - * check once - */ - x?: number; -} - - -export interface PlatformApi { - registerComponents: (components?: LoadComponentData[]) => ComponentMeta[]; - defineComponent: (cmpMeta: ComponentMeta, HostElementConstructor?: any) => void; - getComponentMeta: (elm: Element) => ComponentMeta; - loadBundle: (bundleId: string, priority: LoadPriority, cb: Function) => void; - render?: RendererApi; - config: ConfigApi; - collectHostContent: (elm: HostElement, slotMeta: number) => void; - queue: QueueApi; - css?: {[cmpModeId: string]: string}; - isServer?: boolean; - attachStyles: (cmpMeta: ComponentMeta, elm: HostElement, instance: Component) => void; - getMode: (elm: Element) => string; - appRoot?: HostElement; - hasAppLoaded?: boolean; - appLoaded: () => void; - tmpDisconnected?: boolean; - onReady?: Promise; -} - -export interface PlatformConfig { - name: string; - isMatch?: {(url: string, userAgent: string): boolean}; - settings?: any; -} - - -export interface ServerInitConfig { - staticDir: string; - sys?: UniversalSys; - config?: Object; -} - -export interface HydrateConfig { - req?: any; - url?: string; - referrer?: string; - userAgent?: string; - cookie?: string; - config?: Object; -} - - -export interface UniversalSys { - fs?: { - readdirSync?(path: string | Buffer): string[]; - readFileSync?(filename: string, encoding: string): string; - statSync?(path: string | Buffer): { - isDirectory?(): boolean; - } - }; - path?: { - join?: (...paths: string[]) => string; - }; - isValidComponent?: (fileName: string) => boolean; -} - - -export interface Animation { - new(elm?: Node|Node[]|NodeList): Animation; - add: (childAnimation: Animation) => Animation; - addElement: (elm: Node|Node[]|NodeList) => Animation; - afterAddClass: (className: string) => Animation; - afterClearStyles: (propertyNames: string[]) => Animation; - afterRemoveClass: (className: string) => Animation; - afterStyles: (styles: { [property: string]: any; }) => Animation; - beforeAddClass: (className: string) => Animation; - beforeClearStyles: (propertyNames: string[]) => Animation; - beforeRemoveClass: (className: string) => Animation; - beforeStyles: (styles: { [property: string]: any; }) => Animation; - destroy: () => void; - duration: (milliseconds: number) => Animation; - getDuration(opts?: PlayOptions): number; - easing: (name: string) => Animation; - easingReverse: (name: string) => Animation; - from: (prop: string, val: any) => Animation; - fromTo: (prop: string, fromVal: any, toVal: any, clearProperyAfterTransition?: boolean) => Animation; - hasCompleted: boolean; - isPlaying: boolean; - onFinish: (callback: (animation: Animation) => void, opts?: {oneTimeCallback?: boolean, clearExistingCallacks?: boolean}) => Animation; - play: (opts?: PlayOptions) => void; - syncPlay: () => void; - progressEnd: (shouldComplete: boolean, currentStepValue: number, dur: number) => void; - progressStep: (stepValue: number) => void; - progressStart: () => void; - reverse: (shouldReverse?: boolean) => Animation; - stop: (stepValue?: number) => void; - to: (prop: string, val: any, clearProperyAfterTransition?: boolean) => Animation; -} - - -export interface AnimationBuilder { - (elm?: HTMLElement): Animation; -} - - -export interface AnimationOptions { - animation?: string; - duration?: number; - easing?: string; - direction?: string; - isRTL?: boolean; - ev?: any; -} - - -export interface PlayOptions { - duration?: number; - promise?: boolean; -} - - -export interface EffectProperty { - effectName: string; - trans: boolean; - wc?: string; - to?: EffectState; - from?: EffectState; - [state: string]: any; -} - - -export interface EffectState { - val: any; - num: number; - effectUnit: string; -} - - -export interface RequestIdleCallback { - (callback: IdleCallback, options?: { timeout?: number }): number; -} - - -export interface IdleCallback { - (deadline: IdleDeadline, options?: IdleOptions): void; -} - - -export interface IdleDeadline { - didTimeout: boolean; - timeRemaining: () => number; -} - - -export interface IdleOptions { - timeout?: number; -} - - -export interface BundleCallbacks { - [bundleId: string]: Function[]; -} diff --git a/packages/stencil-fiber-demo/src/components/app.tsx b/packages/stencil-fiber-demo/src/components/app.tsx index 803a81c535..a70524a4ce 100644 --- a/packages/stencil-fiber-demo/src/components/app.tsx +++ b/packages/stencil-fiber-demo/src/components/app.tsx @@ -1,4 +1,4 @@ -import { Component, Prop, h, VNodeData } from '@stencil/core'; +import { Component, Prop } from '@stencil/core'; @Component({ tag: 'fiber-demo' @@ -17,7 +17,7 @@ export class FiberDemo { this.seconds = (this.seconds % 10) + 1; } - hostData(): VNodeData { + hostData() { const elapsed = this.elapsed; const t = (elapsed / 1000) % 10; const scale = 1 + (t > 5 ? 10 - t : t) / 10; diff --git a/packages/stencil-fiber-demo/src/components/dot.tsx b/packages/stencil-fiber-demo/src/components/dot.tsx index 0cdd3ebd05..d1f6416d69 100644 --- a/packages/stencil-fiber-demo/src/components/dot.tsx +++ b/packages/stencil-fiber-demo/src/components/dot.tsx @@ -1,4 +1,4 @@ -import { Component, Prop, State, VNodeData } from '@stencil/core'; +import { Component, Prop, State } from '@stencil/core'; @Component({ tag: 'fiber-dot' @@ -19,7 +19,7 @@ export class FiberDot { this.hover = false; } - hostData(): VNodeData { + hostData() { const s = this.size * 1.3; const style = { position: 'absolute',