From 6d24940a8b514d7306de0795152b60e4b43ccc09 Mon Sep 17 00:00:00 2001 From: "greenkeeper[bot]" Date: Sat, 24 Jun 2017 01:40:13 +0000 Subject: [PATCH 01/12] chore(package): update eslint to version 4.1.0 --- package.json | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/package.json b/package.json index ff4386b1067..a27f036412c 100644 --- a/package.json +++ b/package.json @@ -45,7 +45,7 @@ "cz-conventional-changelog": "^2.0.0", "del-cli": "^1.0.0", "dom-events": "^0.1.1", - "eslint": "^3.6.1", + "eslint": "^4.1.0", "eslint-config-google": "^0.7.1", "eslint-plugin-mocha": "^4.8.0", "extract-text-webpack-plugin": "^2.1.2", From d38161cb2bcbfc9fc76dba92268ac356cbbf2ebf Mon Sep 17 00:00:00 2001 From: Alex Sheehan Date: Thu, 29 Jun 2017 14:03:43 -0400 Subject: [PATCH 02/12] chore: Update eslint and fix lines that break the rules --- packages/mdc-base/component.js | 1 - packages/mdc-base/foundation.js | 1 - packages/mdc-checkbox/foundation.js | 6 +- packages/mdc-drawer/persistent/index.js | 16 +- packages/mdc-drawer/slidable/constants.js | 4 +- packages/mdc-drawer/slidable/foundation.js | 1 - packages/mdc-drawer/temporary/index.js | 10 +- packages/mdc-menu/simple/foundation.js | 4 +- packages/mdc-ripple/index.js | 4 +- packages/mdc-tabs/index.js | 6 +- packages/mdc-toolbar/foundation.js | 2 +- ...ewrite-decl-statements-for-closure-test.js | 2 +- ...rite-sass-import-statements-for-closure.js | 2 +- .../mdc-drawer/slidable.foundation.test.js | 1 - test/unit/mdc-menu/simple.foundation.test.js | 272 ++++++------ .../mdc-ripple/foundation-activation.test.js | 324 +++++++------- .../foundation-deactivation.test.js | 420 +++++++++--------- test/unit/mdc-ripple/foundation.test.js | 162 +++---- .../mdc-tabs/mdc-tab-bar-foundation.test.js | 4 +- .../mdc-tab-bar-scroller-foundation.test.js | 6 +- webpack.config.js | 2 +- 21 files changed, 625 insertions(+), 625 deletions(-) diff --git a/packages/mdc-base/component.js b/packages/mdc-base/component.js index 1c99603eaee..383a87ad316 100644 --- a/packages/mdc-base/component.js +++ b/packages/mdc-base/component.js @@ -20,7 +20,6 @@ import MDCFoundation from './foundation'; * @template F */ export default class MDCComponent { - /** * @param {!Element} root * @return {!MDCComponent} diff --git a/packages/mdc-base/foundation.js b/packages/mdc-base/foundation.js index eb78a1f2d75..ceedd307c34 100644 --- a/packages/mdc-base/foundation.js +++ b/packages/mdc-base/foundation.js @@ -18,7 +18,6 @@ * @template A */ export default class MDCFoundation { - /** @return enum{cssClasses} */ static get cssClasses() { // Classes extending MDCFoundation should implement this method to return an object which exports every diff --git a/packages/mdc-checkbox/foundation.js b/packages/mdc-checkbox/foundation.js index 28fb5c85aee..68e09b7306c 100644 --- a/packages/mdc-checkbox/foundation.js +++ b/packages/mdc-checkbox/foundation.js @@ -208,15 +208,15 @@ export default class MDCCheckboxFoundation extends MDCFoundation { if (newState === TRANSITION_STATE_UNCHECKED) { return ''; } - // fallthrough + // fallthrough case TRANSITION_STATE_UNCHECKED: return newState === TRANSITION_STATE_CHECKED ? ANIM_UNCHECKED_CHECKED : ANIM_UNCHECKED_INDETERMINATE; case TRANSITION_STATE_CHECKED: return newState === TRANSITION_STATE_UNCHECKED ? ANIM_CHECKED_UNCHECKED : ANIM_CHECKED_INDETERMINATE; - // TRANSITION_STATE_INDETERMINATE + // TRANSITION_STATE_INDETERMINATE default: return newState === TRANSITION_STATE_CHECKED ? - ANIM_INDETERMINATE_CHECKED : ANIM_INDETERMINATE_UNCHECKED; + ANIM_INDETERMINATE_CHECKED : ANIM_INDETERMINATE_UNCHECKED; } } diff --git a/packages/mdc-drawer/persistent/index.js b/packages/mdc-drawer/persistent/index.js index e18a8c7b92b..dc15b746c17 100644 --- a/packages/mdc-drawer/persistent/index.js +++ b/packages/mdc-drawer/persistent/index.js @@ -38,7 +38,7 @@ export class MDCPersistentDrawer extends MDCComponent { } } - /* Return the drawer element inside the component. */ + // Return the drawer element inside the component. get drawer() { return this.root_.querySelector(MDCPersistentDrawerFoundation.strings.DRAWER_SELECTOR); } @@ -52,22 +52,22 @@ export class MDCPersistentDrawer extends MDCComponent { hasClass: (className) => this.root_.classList.contains(className), hasNecessaryDom: () => Boolean(this.drawer), registerInteractionHandler: (evt, handler) => - this.root_.addEventListener(util.remapEvent(evt), handler, util.applyPassive()), + this.root_.addEventListener(util.remapEvent(evt), handler, util.applyPassive()), deregisterInteractionHandler: (evt, handler) => - this.root_.removeEventListener(util.remapEvent(evt), handler, util.applyPassive()), + this.root_.removeEventListener(util.remapEvent(evt), handler, util.applyPassive()), registerDrawerInteractionHandler: (evt, handler) => - this.drawer.addEventListener(util.remapEvent(evt), handler), + this.drawer.addEventListener(util.remapEvent(evt), handler), deregisterDrawerInteractionHandler: (evt, handler) => - this.drawer.removeEventListener(util.remapEvent(evt), handler), + this.drawer.removeEventListener(util.remapEvent(evt), handler), registerTransitionEndHandler: (handler) => - this.root_.addEventListener('transitionend', handler), + this.root_.addEventListener('transitionend', handler), deregisterTransitionEndHandler: (handler) => - this.root_.removeEventListener('transitionend', handler), + this.root_.removeEventListener('transitionend', handler), registerDocumentKeydownHandler: (handler) => document.addEventListener('keydown', handler), deregisterDocumentKeydownHandler: (handler) => document.removeEventListener('keydown', handler), getDrawerWidth: () => this.drawer.offsetWidth, setTranslateX: (value) => this.drawer.style.setProperty( - util.getTransformPropertyName(), value === null ? null : `translateX(${value}px)`), + util.getTransformPropertyName(), value === null ? null : `translateX(${value}px)`), getFocusableElements: () => this.drawer.querySelectorAll(FOCUSABLE_ELEMENTS), saveElementTabState: (el) => util.saveElementTabState(el), restoreElementTabState: (el) => util.restoreElementTabState(el), diff --git a/packages/mdc-drawer/slidable/constants.js b/packages/mdc-drawer/slidable/constants.js index cc46f00850c..d69bfc5e238 100644 --- a/packages/mdc-drawer/slidable/constants.js +++ b/packages/mdc-drawer/slidable/constants.js @@ -15,5 +15,5 @@ */ export const FOCUSABLE_ELEMENTS = - 'a[href], area[href], input:not([disabled]), select:not([disabled]), textarea:not([disabled]), ' + - 'button:not([disabled]), iframe, object, embed, [tabindex], [contenteditable]'; + 'a[href], area[href], input:not([disabled]), select:not([disabled]), textarea:not([disabled]), ' + + 'button:not([disabled]), iframe, object, embed, [tabindex], [contenteditable]'; diff --git a/packages/mdc-drawer/slidable/foundation.js b/packages/mdc-drawer/slidable/foundation.js index 7a1507708d0..200b3a47f16 100644 --- a/packages/mdc-drawer/slidable/foundation.js +++ b/packages/mdc-drawer/slidable/foundation.js @@ -17,7 +17,6 @@ import {MDCFoundation} from '@material/base'; export class MDCSlidableDrawerFoundation extends MDCFoundation { - static get defaultAdapter() { return { addClass: (/* className: string */) => {}, diff --git a/packages/mdc-drawer/temporary/index.js b/packages/mdc-drawer/temporary/index.js index 1e4bab081c4..8e2d1e61736 100644 --- a/packages/mdc-drawer/temporary/index.js +++ b/packages/mdc-drawer/temporary/index.js @@ -54,20 +54,20 @@ export class MDCTemporaryDrawer extends MDCComponent { removeBodyClass: (className) => document.body.classList.remove(className), hasNecessaryDom: () => Boolean(this.drawer), registerInteractionHandler: (evt, handler) => - this.root_.addEventListener(util.remapEvent(evt), handler, util.applyPassive()), + this.root_.addEventListener(util.remapEvent(evt), handler, util.applyPassive()), deregisterInteractionHandler: (evt, handler) => - this.root_.removeEventListener(util.remapEvent(evt), handler, util.applyPassive()), + this.root_.removeEventListener(util.remapEvent(evt), handler, util.applyPassive()), registerDrawerInteractionHandler: (evt, handler) => - this.drawer.addEventListener(util.remapEvent(evt), handler), + this.drawer.addEventListener(util.remapEvent(evt), handler), deregisterDrawerInteractionHandler: (evt, handler) => - this.drawer.removeEventListener(util.remapEvent(evt), handler), + this.drawer.removeEventListener(util.remapEvent(evt), handler), registerTransitionEndHandler: (handler) => this.drawer.addEventListener('transitionend', handler), deregisterTransitionEndHandler: (handler) => this.drawer.removeEventListener('transitionend', handler), registerDocumentKeydownHandler: (handler) => document.addEventListener('keydown', handler), deregisterDocumentKeydownHandler: (handler) => document.removeEventListener('keydown', handler), getDrawerWidth: () => this.drawer.offsetWidth, setTranslateX: (value) => this.drawer.style.setProperty( - util.getTransformPropertyName(), value === null ? null : `translateX(${value}px)`), + util.getTransformPropertyName(), value === null ? null : `translateX(${value}px)`), updateCssVariable: (value) => { if (util.supportsCssCustomProperties()) { this.root_.style.setProperty(OPACITY_VAR_NAME, value); diff --git a/packages/mdc-menu/simple/foundation.js b/packages/mdc-menu/simple/foundation.js index 479dd4d42c9..738f5b957b6 100644 --- a/packages/mdc-menu/simple/foundation.js +++ b/packages/mdc-menu/simple/foundation.js @@ -192,7 +192,7 @@ export default class MDCSimpleMenuFoundation extends MDCFoundation { animationLoop_() { const time = this.adapter_.getAccurateTime(); const {TRANSITION_DURATION_MS, TRANSITION_X1, TRANSITION_Y1, TRANSITION_X2, TRANSITION_Y2, - TRANSITION_SCALE_ADJUSTMENT_X, TRANSITION_SCALE_ADJUSTMENT_Y} = MDCSimpleMenuFoundation.numbers; + TRANSITION_SCALE_ADJUSTMENT_X, TRANSITION_SCALE_ADJUSTMENT_Y} = MDCSimpleMenuFoundation.numbers; const currentTime = clamp((time - this.startTime_) / TRANSITION_DURATION_MS); // Animate X axis very slowly, so that only the Y axis animation is visible during fade-out. @@ -477,5 +477,3 @@ export default class MDCSimpleMenuFoundation extends MDCFoundation { return this.isOpen_; } } - - diff --git a/packages/mdc-ripple/index.js b/packages/mdc-ripple/index.js index 4d7ac73d829..f37c6758add 100644 --- a/packages/mdc-ripple/index.js +++ b/packages/mdc-ripple/index.js @@ -42,9 +42,9 @@ export class MDCRipple extends MDCComponent { addClass: (className) => instance.root_.classList.add(className), removeClass: (className) => instance.root_.classList.remove(className), registerInteractionHandler: (evtType, handler) => - instance.root_.addEventListener(evtType, handler, util.applyPassive()), + instance.root_.addEventListener(evtType, handler, util.applyPassive()), deregisterInteractionHandler: (evtType, handler) => - instance.root_.removeEventListener(evtType, handler, util.applyPassive()), + instance.root_.removeEventListener(evtType, handler, util.applyPassive()), registerResizeHandler: (handler) => window.addEventListener('resize', handler), deregisterResizeHandler: (handler) => window.removeEventListener('resize', handler), updateCssVariable: (varName, value) => instance.root_.style.setProperty(varName, value), diff --git a/packages/mdc-tabs/index.js b/packages/mdc-tabs/index.js index 45ef07500a1..511fb84607f 100644 --- a/packages/mdc-tabs/index.js +++ b/packages/mdc-tabs/index.js @@ -14,6 +14,6 @@ * limitations under the License. */ - export {MDCTabFoundation, MDCTab} from './tab'; - export {MDCTabBarFoundation, MDCTabBar} from './tab-bar'; - export {MDCTabBarScrollerFoundation, MDCTabBarScroller} from './tab-bar-scroller'; +export {MDCTabFoundation, MDCTab} from './tab'; +export {MDCTabBarFoundation, MDCTabBar} from './tab-bar'; +export {MDCTabBarScrollerFoundation, MDCTabBarScroller} from './tab-bar-scroller'; diff --git a/packages/mdc-toolbar/foundation.js b/packages/mdc-toolbar/foundation.js index 3fe71e7853c..e1afd5358bb 100644 --- a/packages/mdc-toolbar/foundation.js +++ b/packages/mdc-toolbar/foundation.js @@ -61,7 +61,7 @@ export default class MDCToolbarFoundation extends MDCFoundation { this.calculations_ = { toolbarRowHeight: 0, // Calculated Height ratio. We use ratio to calculate corresponding heights in resize event. - toolbarRatio: 0, // The ratio of toolbar height to row height + toolbarRatio: 0, // The ratio of toolbar height to row height flexibleExpansionRatio: 0, // The ratio of flexible space height to row height maxTranslateYRatio: 0, // The ratio of max toolbar move up distance to row height scrollThresholdRatio: 0, // The ratio of max scrollTop that we should listen to to row height diff --git a/scripts/rewrite-decl-statements-for-closure-test.js b/scripts/rewrite-decl-statements-for-closure-test.js index de57e1d87e3..17cdb318192 100644 --- a/scripts/rewrite-decl-statements-for-closure-test.js +++ b/scripts/rewrite-decl-statements-for-closure-test.js @@ -121,7 +121,7 @@ function rewriteDeclarationSource(node, srcFile, rootDir) { const pathParts = source.split('/'); const isMDCImport = pathParts[0] === '@material'; if (isMDCImport) { - const modName = pathParts[1]; // @material/ + const modName = pathParts[1]; // @material/ const atMaterialReplacementPath = `${rootDir}/mdc-${modName}`; const rewrittenSource = [atMaterialReplacementPath].concat(pathParts.slice(2)).join('/'); source = rewrittenSource; diff --git a/scripts/rewrite-sass-import-statements-for-closure.js b/scripts/rewrite-sass-import-statements-for-closure.js index d9d32ff9403..6f0e8392f43 100644 --- a/scripts/rewrite-sass-import-statements-for-closure.js +++ b/scripts/rewrite-sass-import-statements-for-closure.js @@ -73,7 +73,7 @@ function rewriteImportDeclaration(importSource, srcFile, rootDir) { const pathParts = importSource.split('/'); const isMDCImport = pathParts[0] === '@material'; if (isMDCImport) { - const modName = pathParts[1]; // @material/ + const modName = pathParts[1]; // @material/ const atMaterialReplacementPath = `${rootDir}/${modName}`; const rewrittenImportSource = [atMaterialReplacementPath].concat(pathParts.slice(2)).join('/'); importSource = rewrittenImportSource; diff --git a/test/unit/mdc-drawer/slidable.foundation.test.js b/test/unit/mdc-drawer/slidable.foundation.test.js index a16ba706b22..0abf4e0a4a9 100644 --- a/test/unit/mdc-drawer/slidable.foundation.test.js +++ b/test/unit/mdc-drawer/slidable.foundation.test.js @@ -25,7 +25,6 @@ function setupTest(isRootTransitioningEventTarget) { const mockAdapter = td.object(MDCSlidableDrawerFoundation.defaultAdapter); class MDCFakeSlideableDrawerFoundation extends MDCSlidableDrawerFoundation { - isRootTransitioningEventTarget_() { return isRootTransitioningEventTarget; } diff --git a/test/unit/mdc-menu/simple.foundation.test.js b/test/unit/mdc-menu/simple.foundation.test.js index 45c88349fb8..c50b81170e0 100644 --- a/test/unit/mdc-menu/simple.foundation.test.js +++ b/test/unit/mdc-menu/simple.foundation.test.js @@ -105,20 +105,20 @@ testFoundation('#open adds the open class to the menu', ({foundation, mockAdapte }); testFoundation('#open removes the animation class at the end of the animation', - ({foundation, mockAdapter, mockRaf}) => { - td.when(mockAdapter.getAccurateTime()).thenReturn(0); - td.when(mockAdapter.hasClass('mdc-simple-menu--open-from-top-right')).thenReturn(true); - - foundation.open(); - mockRaf.flush(); - mockRaf.flush(); - td.verify(mockAdapter.addClass('mdc-simple-menu--animating')); - - td.when(mockAdapter.getAccurateTime()).thenReturn(500); - mockRaf.flush(); - mockRaf.flush(); - td.verify(mockAdapter.removeClass('mdc-simple-menu--animating')); - }); + ({foundation, mockAdapter, mockRaf}) => { + td.when(mockAdapter.getAccurateTime()).thenReturn(0); + td.when(mockAdapter.hasClass('mdc-simple-menu--open-from-top-right')).thenReturn(true); + + foundation.open(); + mockRaf.flush(); + mockRaf.flush(); + td.verify(mockAdapter.addClass('mdc-simple-menu--animating')); + + td.when(mockAdapter.getAccurateTime()).thenReturn(500); + mockRaf.flush(); + mockRaf.flush(); + td.verify(mockAdapter.removeClass('mdc-simple-menu--animating')); + }); testFoundation('#open focuses the menu at the end of the animation', ({foundation, mockAdapter, mockRaf}) => { td.when(mockAdapter.getAccurateTime()).thenReturn(0); @@ -146,130 +146,130 @@ testFoundation('#open on a not focused menu does not focust at index 0', ({found }); testFoundation('#open anchors the menu on the top left in LTR, given enough room', - ({foundation, mockAdapter, mockRaf}) => { - td.when(mockAdapter.hasAnchor()).thenReturn(true); - td.when(mockAdapter.isRtl()).thenReturn(false); - td.when(mockAdapter.getInnerDimensions()).thenReturn({height: 200, width: 100}); - td.when(mockAdapter.getWindowDimensions()).thenReturn({height: 1000, width: 1000}); - td.when(mockAdapter.getAnchorDimensions()).thenReturn({ - height: 20, width: 40, top: 20, bottom: 40, left: 20, right: 60, - }); - td.when(mockAdapter.getAccurateTime()).thenReturn(0); - - foundation.open(); - mockRaf.flush(); - mockRaf.flush(); - - td.when(mockAdapter.getAccurateTime()).thenReturn(500); - mockRaf.flush(); - td.verify(mockAdapter.setTransformOrigin('top left')); - td.verify(mockAdapter.setPosition({left: '0', top: '0'})); + ({foundation, mockAdapter, mockRaf}) => { + td.when(mockAdapter.hasAnchor()).thenReturn(true); + td.when(mockAdapter.isRtl()).thenReturn(false); + td.when(mockAdapter.getInnerDimensions()).thenReturn({height: 200, width: 100}); + td.when(mockAdapter.getWindowDimensions()).thenReturn({height: 1000, width: 1000}); + td.when(mockAdapter.getAnchorDimensions()).thenReturn({ + height: 20, width: 40, top: 20, bottom: 40, left: 20, right: 60, }); + td.when(mockAdapter.getAccurateTime()).thenReturn(0); + + foundation.open(); + mockRaf.flush(); + mockRaf.flush(); + + td.when(mockAdapter.getAccurateTime()).thenReturn(500); + mockRaf.flush(); + td.verify(mockAdapter.setTransformOrigin('top left')); + td.verify(mockAdapter.setPosition({left: '0', top: '0'})); + }); testFoundation('#open anchors the menu on the top right in LTR when close to the right edge', - ({foundation, mockAdapter, mockRaf}) => { - td.when(mockAdapter.hasAnchor()).thenReturn(true); - td.when(mockAdapter.isRtl()).thenReturn(false); - td.when(mockAdapter.getInnerDimensions()).thenReturn({height: 200, width: 100}); - td.when(mockAdapter.getWindowDimensions()).thenReturn({height: 1000, width: 1000}); - td.when(mockAdapter.getAnchorDimensions()).thenReturn({ - height: 20, width: 40, top: 20, bottom: 40, left: 950, right: 990, - }); - td.when(mockAdapter.getAccurateTime()).thenReturn(0); - - foundation.open(); - mockRaf.flush(); - mockRaf.flush(); - - td.when(mockAdapter.getAccurateTime()).thenReturn(500); - mockRaf.flush(); - td.verify(mockAdapter.setTransformOrigin('top right')); - td.verify(mockAdapter.setPosition({right: '0', top: '0'})); + ({foundation, mockAdapter, mockRaf}) => { + td.when(mockAdapter.hasAnchor()).thenReturn(true); + td.when(mockAdapter.isRtl()).thenReturn(false); + td.when(mockAdapter.getInnerDimensions()).thenReturn({height: 200, width: 100}); + td.when(mockAdapter.getWindowDimensions()).thenReturn({height: 1000, width: 1000}); + td.when(mockAdapter.getAnchorDimensions()).thenReturn({ + height: 20, width: 40, top: 20, bottom: 40, left: 950, right: 990, }); + td.when(mockAdapter.getAccurateTime()).thenReturn(0); + + foundation.open(); + mockRaf.flush(); + mockRaf.flush(); + + td.when(mockAdapter.getAccurateTime()).thenReturn(500); + mockRaf.flush(); + td.verify(mockAdapter.setTransformOrigin('top right')); + td.verify(mockAdapter.setPosition({right: '0', top: '0'})); + }); testFoundation('#open anchors the menu on the top right in RTL, given enough room', - ({foundation, mockAdapter, mockRaf}) => { - td.when(mockAdapter.hasAnchor()).thenReturn(true); - td.when(mockAdapter.isRtl()).thenReturn(true); - td.when(mockAdapter.getInnerDimensions()).thenReturn({height: 200, width: 100}); - td.when(mockAdapter.getWindowDimensions()).thenReturn({height: 1000, width: 1000}); - td.when(mockAdapter.getAnchorDimensions()).thenReturn({ - height: 20, width: 40, top: 20, bottom: 40, left: 500, right: 540, - }); - td.when(mockAdapter.getAccurateTime()).thenReturn(0); - - foundation.open(); - mockRaf.flush(); - mockRaf.flush(); - - td.when(mockAdapter.getAccurateTime()).thenReturn(500); - mockRaf.flush(); - td.verify(mockAdapter.setTransformOrigin('top right')); - td.verify(mockAdapter.setPosition({right: '0', top: '0'})); + ({foundation, mockAdapter, mockRaf}) => { + td.when(mockAdapter.hasAnchor()).thenReturn(true); + td.when(mockAdapter.isRtl()).thenReturn(true); + td.when(mockAdapter.getInnerDimensions()).thenReturn({height: 200, width: 100}); + td.when(mockAdapter.getWindowDimensions()).thenReturn({height: 1000, width: 1000}); + td.when(mockAdapter.getAnchorDimensions()).thenReturn({ + height: 20, width: 40, top: 20, bottom: 40, left: 500, right: 540, }); + td.when(mockAdapter.getAccurateTime()).thenReturn(0); + + foundation.open(); + mockRaf.flush(); + mockRaf.flush(); + + td.when(mockAdapter.getAccurateTime()).thenReturn(500); + mockRaf.flush(); + td.verify(mockAdapter.setTransformOrigin('top right')); + td.verify(mockAdapter.setPosition({right: '0', top: '0'})); + }); testFoundation('#open anchors the menu on the top left in RTL when close to the left edge', - ({foundation, mockAdapter, mockRaf}) => { - td.when(mockAdapter.hasAnchor()).thenReturn(true); - td.when(mockAdapter.isRtl()).thenReturn(true); - td.when(mockAdapter.getInnerDimensions()).thenReturn({height: 200, width: 100}); - td.when(mockAdapter.getWindowDimensions()).thenReturn({height: 1000, width: 1000}); - td.when(mockAdapter.getAnchorDimensions()).thenReturn({ - height: 20, width: 40, top: 20, bottom: 40, left: 10, right: 50, - }); - td.when(mockAdapter.getAccurateTime()).thenReturn(0); - - foundation.open(); - mockRaf.flush(); - mockRaf.flush(); - - td.when(mockAdapter.getAccurateTime()).thenReturn(500); - mockRaf.flush(); - td.verify(mockAdapter.setTransformOrigin('top left')); - td.verify(mockAdapter.setPosition({left: '0', top: '0'})); + ({foundation, mockAdapter, mockRaf}) => { + td.when(mockAdapter.hasAnchor()).thenReturn(true); + td.when(mockAdapter.isRtl()).thenReturn(true); + td.when(mockAdapter.getInnerDimensions()).thenReturn({height: 200, width: 100}); + td.when(mockAdapter.getWindowDimensions()).thenReturn({height: 1000, width: 1000}); + td.when(mockAdapter.getAnchorDimensions()).thenReturn({ + height: 20, width: 40, top: 20, bottom: 40, left: 10, right: 50, }); + td.when(mockAdapter.getAccurateTime()).thenReturn(0); + + foundation.open(); + mockRaf.flush(); + mockRaf.flush(); + + td.when(mockAdapter.getAccurateTime()).thenReturn(500); + mockRaf.flush(); + td.verify(mockAdapter.setTransformOrigin('top left')); + td.verify(mockAdapter.setPosition({left: '0', top: '0'})); + }); testFoundation('#open anchors the menu on the bottom left in LTR when close to the bottom edge', - ({foundation, mockAdapter, mockRaf}) => { - td.when(mockAdapter.hasAnchor()).thenReturn(true); - td.when(mockAdapter.isRtl()).thenReturn(false); - td.when(mockAdapter.getInnerDimensions()).thenReturn({height: 200, width: 100}); - td.when(mockAdapter.getWindowDimensions()).thenReturn({height: 1000, width: 1000}); - td.when(mockAdapter.getAnchorDimensions()).thenReturn({ - height: 20, width: 40, top: 900, bottom: 920, left: 10, right: 50, - }); - td.when(mockAdapter.getAccurateTime()).thenReturn(0); - - foundation.open(); - mockRaf.flush(); - mockRaf.flush(); - - td.when(mockAdapter.getAccurateTime()).thenReturn(500); - mockRaf.flush(); - td.verify(mockAdapter.setTransformOrigin('bottom left')); - td.verify(mockAdapter.setPosition({left: '0', bottom: '0'})); + ({foundation, mockAdapter, mockRaf}) => { + td.when(mockAdapter.hasAnchor()).thenReturn(true); + td.when(mockAdapter.isRtl()).thenReturn(false); + td.when(mockAdapter.getInnerDimensions()).thenReturn({height: 200, width: 100}); + td.when(mockAdapter.getWindowDimensions()).thenReturn({height: 1000, width: 1000}); + td.when(mockAdapter.getAnchorDimensions()).thenReturn({ + height: 20, width: 40, top: 900, bottom: 920, left: 10, right: 50, }); + td.when(mockAdapter.getAccurateTime()).thenReturn(0); + + foundation.open(); + mockRaf.flush(); + mockRaf.flush(); + + td.when(mockAdapter.getAccurateTime()).thenReturn(500); + mockRaf.flush(); + td.verify(mockAdapter.setTransformOrigin('bottom left')); + td.verify(mockAdapter.setPosition({left: '0', bottom: '0'})); + }); testFoundation('#open anchors the menu on the top left in LTR when not close to the bottom edge', - ({foundation, mockAdapter, mockRaf}) => { - td.when(mockAdapter.hasAnchor()).thenReturn(true); - td.when(mockAdapter.isRtl()).thenReturn(false); - td.when(mockAdapter.getInnerDimensions()).thenReturn({height: 200, width: 100}); - td.when(mockAdapter.getWindowDimensions()).thenReturn({height: 1000, width: 1000}); - td.when(mockAdapter.getAnchorDimensions()).thenReturn({ - height: 20, width: 40, top: 900, bottom: 20, left: 10, right: 50, - }); - td.when(mockAdapter.getAccurateTime()).thenReturn(0); - - foundation.open(); - mockRaf.flush(); - mockRaf.flush(); - - td.when(mockAdapter.getAccurateTime()).thenReturn(500); - mockRaf.flush(); - td.verify(mockAdapter.setTransformOrigin('top left')); - td.verify(mockAdapter.setPosition({left: '0', top: '0'})); + ({foundation, mockAdapter, mockRaf}) => { + td.when(mockAdapter.hasAnchor()).thenReturn(true); + td.when(mockAdapter.isRtl()).thenReturn(false); + td.when(mockAdapter.getInnerDimensions()).thenReturn({height: 200, width: 100}); + td.when(mockAdapter.getWindowDimensions()).thenReturn({height: 1000, width: 1000}); + td.when(mockAdapter.getAnchorDimensions()).thenReturn({ + height: 20, width: 40, top: 900, bottom: 20, left: 10, right: 50, }); + td.when(mockAdapter.getAccurateTime()).thenReturn(0); + + foundation.open(); + mockRaf.flush(); + mockRaf.flush(); + + td.when(mockAdapter.getAccurateTime()).thenReturn(500); + mockRaf.flush(); + td.verify(mockAdapter.setTransformOrigin('top left')); + td.verify(mockAdapter.setPosition({left: '0', top: '0'})); + }); testFoundation('#close does nothing if event target has aria-disabled set to true', ({foundation, mockAdapter}) => { @@ -304,20 +304,20 @@ testFoundation('#close removes the open class from the menu', ({foundation, mock }); testFoundation('#close removes the animation class at the end of the animation', - ({foundation, mockAdapter, mockRaf}) => { - td.when(mockAdapter.getAccurateTime()).thenReturn(0); - td.when(mockAdapter.hasClass('mdc-simple-menu--open')).thenReturn(true); - td.when(mockAdapter.hasClass('mdc-simple-menu--open-from-bottom-right')).thenReturn(true); - - foundation.close(); - mockRaf.flush(); - mockRaf.flush(); - td.verify(mockAdapter.addClass('mdc-simple-menu--animating')); - - td.when(mockAdapter.getAccurateTime()).thenReturn(500); - mockRaf.flush(); - td.verify(mockAdapter.removeClass('mdc-simple-menu--animating')); - }); + ({foundation, mockAdapter, mockRaf}) => { + td.when(mockAdapter.getAccurateTime()).thenReturn(0); + td.when(mockAdapter.hasClass('mdc-simple-menu--open')).thenReturn(true); + td.when(mockAdapter.hasClass('mdc-simple-menu--open-from-bottom-right')).thenReturn(true); + + foundation.close(); + mockRaf.flush(); + mockRaf.flush(); + td.verify(mockAdapter.addClass('mdc-simple-menu--animating')); + + td.when(mockAdapter.getAccurateTime()).thenReturn(500); + mockRaf.flush(); + td.verify(mockAdapter.removeClass('mdc-simple-menu--animating')); + }); test('#isOpen returns true when the menu is open', () => { const {foundation} = setupTest(); diff --git a/test/unit/mdc-ripple/foundation-activation.test.js b/test/unit/mdc-ripple/foundation-activation.test.js index 5621233a1d7..480e31c8073 100644 --- a/test/unit/mdc-ripple/foundation-activation.test.js +++ b/test/unit/mdc-ripple/foundation-activation.test.js @@ -47,39 +47,41 @@ testFoundation('adds activation classes on mousedown', ({foundation, adapter, mo }); testFoundation('sets FG position from the coords to the center within surface on mousedown', - ({foundation, adapter, mockRaf}) => { - const handlers = captureHandlers(adapter); - const left = 50; - const top = 50; - const width = 200; - const height = 100; - const maxSize = Math.max(width, height); - const initialSize = maxSize * numbers.INITIAL_ORIGIN_SCALE; - const pageX = 100; - const pageY = 75; - - td.when(adapter.computeBoundingRect()).thenReturn({width, height, left, top}); - foundation.init(); - mockRaf.flush(); - - handlers.mousedown({pageX, pageY}); - mockRaf.flush(); - - const startPosition = { - x: pageX - left - (initialSize / 2), - y: pageY - top - (initialSize / 2), - }; - - const endPosition = { - x: (width / 2) - (initialSize / 2), - y: (height / 2) - (initialSize / 2), - }; - - td.verify(adapter.updateCssVariable(strings.VAR_FG_TRANSLATE_START, - `${startPosition.x}px, ${startPosition.y}px`)); - td.verify(adapter.updateCssVariable(strings.VAR_FG_TRANSLATE_END, - `${endPosition.x}px, ${endPosition.y}px`)); - }); + ({foundation, adapter, mockRaf}) => { + const handlers = captureHandlers(adapter); + const left = 50; + const top = 50; + const width = 200; + const height = 100; + const maxSize = Math.max(width, height); + const initialSize = maxSize * numbers.INITIAL_ORIGIN_SCALE; + const pageX = 100; + const pageY = 75; + + td.when(adapter.computeBoundingRect()).thenReturn({width, height, left, top}); + foundation.init(); + mockRaf.flush(); + + handlers.mousedown({pageX, pageY}); + mockRaf.flush(); + + const startPosition = { + x: pageX - left - (initialSize / 2), + y: pageY - top - (initialSize / 2), + }; + + const endPosition = { + x: (width / 2) - (initialSize / 2), + y: (height / 2) - (initialSize / 2), + }; + + td.verify(adapter.updateCssVariable( + strings.VAR_FG_TRANSLATE_START, `${startPosition.x}px, ${startPosition.y}px` + )); + td.verify(adapter.updateCssVariable( + strings.VAR_FG_TRANSLATE_END, `${endPosition.x}px, ${endPosition.y}px` + )); + }); testFoundation('adds activation classes on touchstart', ({foundation, adapter, mockRaf}) => { const handlers = captureHandlers(adapter); @@ -93,39 +95,41 @@ testFoundation('adds activation classes on touchstart', ({foundation, adapter, m }); testFoundation('sets FG position from the coords to the center within surface on touchstart', - ({foundation, adapter, mockRaf}) => { - const handlers = captureHandlers(adapter); - const left = 50; - const top = 50; - const width = 200; - const height = 100; - const maxSize = Math.max(width, height); - const initialSize = maxSize * numbers.INITIAL_ORIGIN_SCALE; - const pageX = 100; - const pageY = 75; - - td.when(adapter.computeBoundingRect()).thenReturn({width, height, left, top}); - foundation.init(); - mockRaf.flush(); - - handlers.touchstart({changedTouches: [{pageX, pageY}]}); - mockRaf.flush(); - - const startPosition = { - x: pageX - left - (initialSize / 2), - y: pageY - top - (initialSize / 2), - }; - - const endPosition = { - x: (width / 2) - (initialSize / 2), - y: (height / 2) - (initialSize / 2), - }; - - td.verify(adapter.updateCssVariable(strings.VAR_FG_TRANSLATE_START, - `${startPosition.x}px, ${startPosition.y}px`)); - td.verify(adapter.updateCssVariable(strings.VAR_FG_TRANSLATE_END, - `${endPosition.x}px, ${endPosition.y}px`)); - }); + ({foundation, adapter, mockRaf}) => { + const handlers = captureHandlers(adapter); + const left = 50; + const top = 50; + const width = 200; + const height = 100; + const maxSize = Math.max(width, height); + const initialSize = maxSize * numbers.INITIAL_ORIGIN_SCALE; + const pageX = 100; + const pageY = 75; + + td.when(adapter.computeBoundingRect()).thenReturn({width, height, left, top}); + foundation.init(); + mockRaf.flush(); + + handlers.touchstart({changedTouches: [{pageX, pageY}]}); + mockRaf.flush(); + + const startPosition = { + x: pageX - left - (initialSize / 2), + y: pageY - top - (initialSize / 2), + }; + + const endPosition = { + x: (width / 2) - (initialSize / 2), + y: (height / 2) - (initialSize / 2), + }; + + td.verify( + adapter.updateCssVariable(strings.VAR_FG_TRANSLATE_START, `${startPosition.x}px, ${startPosition.y}px`) + ); + td.verify( + adapter.updateCssVariable(strings.VAR_FG_TRANSLATE_END, `${endPosition.x}px, ${endPosition.y}px`) + ); + }); testFoundation('adds activation classes on pointerdown', ({foundation, adapter, mockRaf}) => { const handlers = captureHandlers(adapter); @@ -139,53 +143,55 @@ testFoundation('adds activation classes on pointerdown', ({foundation, adapter, }); testFoundation('sets FG position from the coords to the center within surface on pointerdown', - ({foundation, adapter, mockRaf}) => { - const handlers = captureHandlers(adapter); - const left = 50; - const top = 50; - const width = 200; - const height = 100; - const maxSize = Math.max(width, height); - const initialSize = maxSize * numbers.INITIAL_ORIGIN_SCALE; - const pageX = 100; - const pageY = 75; - - td.when(adapter.computeBoundingRect()).thenReturn({width, height, left, top}); - foundation.init(); - mockRaf.flush(); - - handlers.pointerdown({pageX, pageY}); - mockRaf.flush(); - - const startPosition = { - x: pageX - left - (initialSize / 2), - y: pageY - top - (initialSize / 2), - }; - - const endPosition = { - x: (width / 2) - (initialSize / 2), - y: (height / 2) - (initialSize / 2), - }; - - td.verify(adapter.updateCssVariable(strings.VAR_FG_TRANSLATE_START, - `${startPosition.x}px, ${startPosition.y}px`)); - td.verify(adapter.updateCssVariable(strings.VAR_FG_TRANSLATE_END, - `${endPosition.x}px, ${endPosition.y}px`)); - }); + ({foundation, adapter, mockRaf}) => { + const handlers = captureHandlers(adapter); + const left = 50; + const top = 50; + const width = 200; + const height = 100; + const maxSize = Math.max(width, height); + const initialSize = maxSize * numbers.INITIAL_ORIGIN_SCALE; + const pageX = 100; + const pageY = 75; + + td.when(adapter.computeBoundingRect()).thenReturn({width, height, left, top}); + foundation.init(); + mockRaf.flush(); + + handlers.pointerdown({pageX, pageY}); + mockRaf.flush(); + + const startPosition = { + x: pageX - left - (initialSize / 2), + y: pageY - top - (initialSize / 2), + }; + + const endPosition = { + x: (width / 2) - (initialSize / 2), + y: (height / 2) - (initialSize / 2), + }; + + td.verify(adapter.updateCssVariable( + strings.VAR_FG_TRANSLATE_START, `${startPosition.x}px, ${startPosition.y}px` + )); + td.verify(adapter.updateCssVariable( + strings.VAR_FG_TRANSLATE_END, `${endPosition.x}px, ${endPosition.y}px` + )); + }); testFoundation('adds activation classes on keydown when surface is made active', - ({foundation, adapter, mockRaf}) => { - const handlers = captureHandlers(adapter); - td.when(adapter.isSurfaceActive()).thenReturn(true); - foundation.init(); - mockRaf.flush(); + ({foundation, adapter, mockRaf}) => { + const handlers = captureHandlers(adapter); + td.when(adapter.isSurfaceActive()).thenReturn(true); + foundation.init(); + mockRaf.flush(); - handlers.keydown(); - mockRaf.flush(); + handlers.keydown(); + mockRaf.flush(); - td.verify(adapter.addClass(cssClasses.BG_ACTIVE_FILL)); - td.verify(adapter.addClass(cssClasses.FG_ACTIVATION)); - }); + td.verify(adapter.addClass(cssClasses.BG_ACTIVE_FILL)); + td.verify(adapter.addClass(cssClasses.FG_ACTIVATION)); + }); testFoundation('sets FG position to center on non-pointer activation', ({foundation, adapter, mockRaf}) => { const handlers = captureHandlers(adapter); @@ -210,9 +216,9 @@ testFoundation('sets FG position to center on non-pointer activation', ({foundat }; td.verify(adapter.updateCssVariable(strings.VAR_FG_TRANSLATE_START, - `${position.x}px, ${position.y}px`)); + `${position.x}px, ${position.y}px`)); td.verify(adapter.updateCssVariable(strings.VAR_FG_TRANSLATE_END, - `${position.x}px, ${position.y}px`)); + `${position.x}px, ${position.y}px`)); }); testFoundation('adds activation classes on programmatic activation', ({foundation, adapter, mockRaf}) => { @@ -250,54 +256,54 @@ testFoundation('sets FG position to center on non-pointer activation', ({foundat }; td.verify(adapter.updateCssVariable(strings.VAR_FG_TRANSLATE_START, - `${position.x}px, ${position.y}px`)); + `${position.x}px, ${position.y}px`)); td.verify(adapter.updateCssVariable(strings.VAR_FG_TRANSLATE_END, - `${position.x}px, ${position.y}px`)); + `${position.x}px, ${position.y}px`)); }); testFoundation('does not redundantly add classes on touchstart followed by mousedown', - ({foundation, adapter, mockRaf}) => { - const handlers = captureHandlers(adapter); - foundation.init(); - mockRaf.flush(); - - handlers.touchstart({changedTouches: [{pageX: 0, pageY: 0}]}); - mockRaf.flush(); - handlers.mousedown(); - mockRaf.flush(); - td.verify(adapter.addClass(cssClasses.BG_ACTIVE_FILL), {times: 1}); - td.verify(adapter.addClass(cssClasses.FG_ACTIVATION), {times: 1}); - }); + ({foundation, adapter, mockRaf}) => { + const handlers = captureHandlers(adapter); + foundation.init(); + mockRaf.flush(); + + handlers.touchstart({changedTouches: [{pageX: 0, pageY: 0}]}); + mockRaf.flush(); + handlers.mousedown(); + mockRaf.flush(); + td.verify(adapter.addClass(cssClasses.BG_ACTIVE_FILL), {times: 1}); + td.verify(adapter.addClass(cssClasses.FG_ACTIVATION), {times: 1}); + }); testFoundation('does not redundantly add classes on touchstart followed by pointerstart', - ({foundation, adapter, mockRaf}) => { - const handlers = captureHandlers(adapter); - foundation.init(); - mockRaf.flush(); - - handlers.touchstart({changedTouches: [{pageX: 0, pageY: 0}]}); - mockRaf.flush(); - handlers.pointerdown(); - mockRaf.flush(); - td.verify(adapter.addClass(cssClasses.BG_ACTIVE_FILL), {times: 1}); - td.verify(adapter.addClass(cssClasses.FG_ACTIVATION), {times: 1}); - }); + ({foundation, adapter, mockRaf}) => { + const handlers = captureHandlers(adapter); + foundation.init(); + mockRaf.flush(); + + handlers.touchstart({changedTouches: [{pageX: 0, pageY: 0}]}); + mockRaf.flush(); + handlers.pointerdown(); + mockRaf.flush(); + td.verify(adapter.addClass(cssClasses.BG_ACTIVE_FILL), {times: 1}); + td.verify(adapter.addClass(cssClasses.FG_ACTIVATION), {times: 1}); + }); testFoundation('removes deactivation classes on activate to ensure ripples can be retriggered', - ({foundation, adapter, mockRaf}) => { - const handlers = captureHandlers(adapter); - foundation.init(); - mockRaf.flush(); + ({foundation, adapter, mockRaf}) => { + const handlers = captureHandlers(adapter); + foundation.init(); + mockRaf.flush(); - handlers.mousedown(); - mockRaf.flush(); - handlers.mouseup(); - mockRaf.flush(); - handlers.mousedown(); - mockRaf.flush(); + handlers.mousedown(); + mockRaf.flush(); + handlers.mouseup(); + mockRaf.flush(); + handlers.mousedown(); + mockRaf.flush(); - td.verify(adapter.removeClass(cssClasses.FG_DEACTIVATION)); - }); + td.verify(adapter.removeClass(cssClasses.FG_DEACTIVATION)); + }); testFoundation('displays the foreground ripple on activation when unbounded', ({foundation, adapter, mockRaf}) => { const handlers = captureHandlers(adapter); @@ -313,16 +319,16 @@ testFoundation('displays the foreground ripple on activation when unbounded', ({ }); testFoundation('clears translation custom properties when unbounded in case ripple was switched from bounded', - ({foundation, adapter, mockRaf}) => { - const handlers = captureHandlers(adapter); + ({foundation, adapter, mockRaf}) => { + const handlers = captureHandlers(adapter); - td.when(adapter.isUnbounded()).thenReturn(true); - foundation.init(); - mockRaf.flush(); + td.when(adapter.isUnbounded()).thenReturn(true); + foundation.init(); + mockRaf.flush(); - handlers.pointerdown({pageX: 100, pageY: 75}); - mockRaf.flush(); + handlers.pointerdown({pageX: 100, pageY: 75}); + mockRaf.flush(); - td.verify(adapter.updateCssVariable(strings.VAR_FG_TRANSLATE_START, '')); - td.verify(adapter.updateCssVariable(strings.VAR_FG_TRANSLATE_END, '')); - }); + td.verify(adapter.updateCssVariable(strings.VAR_FG_TRANSLATE_START, '')); + td.verify(adapter.updateCssVariable(strings.VAR_FG_TRANSLATE_END, '')); + }); diff --git a/test/unit/mdc-ripple/foundation-deactivation.test.js b/test/unit/mdc-ripple/foundation-deactivation.test.js index 4f579ac5507..3e66a6e15a4 100644 --- a/test/unit/mdc-ripple/foundation-deactivation.test.js +++ b/test/unit/mdc-ripple/foundation-deactivation.test.js @@ -100,56 +100,56 @@ testFoundation('runs deactivation UX on mouseup after mousedown', ({foundation, }); testFoundation('runs deactivation on keyup after keydown when keydown makes surface active', - ({foundation, adapter, mockRaf}) => { - const handlers = captureHandlers(adapter); - const clock = lolex.install(); - td.when(adapter.isSurfaceActive()).thenReturn(true); + ({foundation, adapter, mockRaf}) => { + const handlers = captureHandlers(adapter); + const clock = lolex.install(); + td.when(adapter.isSurfaceActive()).thenReturn(true); - foundation.init(); - mockRaf.flush(); + foundation.init(); + mockRaf.flush(); - handlers.keydown({key: 'Space'}); - mockRaf.flush(); + handlers.keydown({key: 'Space'}); + mockRaf.flush(); - handlers.keyup({key: 'Space'}); - mockRaf.flush(); - clock.tick(DEACTIVATION_TIMEOUT_MS); + handlers.keyup({key: 'Space'}); + mockRaf.flush(); + clock.tick(DEACTIVATION_TIMEOUT_MS); - td.verify(adapter.removeClass(cssClasses.BG_FOCUSED)); - td.verify(adapter.removeClass(cssClasses.BG_ACTIVE_FILL), {times: 2}); - td.verify(adapter.removeClass(cssClasses.FG_ACTIVATION), {times: 2}); - td.verify(adapter.addClass(cssClasses.FG_DEACTIVATION)); + td.verify(adapter.removeClass(cssClasses.BG_FOCUSED)); + td.verify(adapter.removeClass(cssClasses.BG_ACTIVE_FILL), {times: 2}); + td.verify(adapter.removeClass(cssClasses.FG_ACTIVATION), {times: 2}); + td.verify(adapter.addClass(cssClasses.FG_DEACTIVATION)); - clock.tick(numbers.FG_DEACTIVATION_MS); - td.verify(adapter.removeClass(cssClasses.FG_DEACTIVATION)); + clock.tick(numbers.FG_DEACTIVATION_MS); + td.verify(adapter.removeClass(cssClasses.FG_DEACTIVATION)); - clock.uninstall(); - }); + clock.uninstall(); + }); testFoundation('does not run deactivation on keyup after keydown if keydown did not make surface active', - ({foundation, adapter, mockRaf}) => { - const handlers = captureHandlers(adapter); - const clock = lolex.install(); - td.when(adapter.isSurfaceActive()).thenReturn(false); - - foundation.init(); - mockRaf.flush(); - - handlers.keydown({key: 'Space'}); - mockRaf.flush(); - - handlers.keyup({key: 'Space'}); - mockRaf.flush(); - clock.tick(DEACTIVATION_TIMEOUT_MS); - - // Note that all of these should be called 0 times since a keydown that does not make a surface active should never - // activate it in the first place. - td.verify(adapter.removeClass(cssClasses.BG_FOCUSED), {times: 0}); - td.verify(adapter.removeClass(cssClasses.BG_ACTIVE_FILL), {times: 0}); - td.verify(adapter.removeClass(cssClasses.FG_ACTIVATION), {times: 0}); - td.verify(adapter.addClass(cssClasses.FG_DEACTIVATION), {times: 0}); - clock.uninstall(); - }); + ({foundation, adapter, mockRaf}) => { + const handlers = captureHandlers(adapter); + const clock = lolex.install(); + td.when(adapter.isSurfaceActive()).thenReturn(false); + + foundation.init(); + mockRaf.flush(); + + handlers.keydown({key: 'Space'}); + mockRaf.flush(); + + handlers.keyup({key: 'Space'}); + mockRaf.flush(); + clock.tick(DEACTIVATION_TIMEOUT_MS); + + // Note that all of these should be called 0 times since a keydown that does not make a surface active should never + // activate it in the first place. + td.verify(adapter.removeClass(cssClasses.BG_FOCUSED), {times: 0}); + td.verify(adapter.removeClass(cssClasses.BG_ACTIVE_FILL), {times: 0}); + td.verify(adapter.removeClass(cssClasses.FG_ACTIVATION), {times: 0}); + td.verify(adapter.addClass(cssClasses.FG_DEACTIVATION), {times: 0}); + clock.uninstall(); + }); testFoundation('runs deactivation UX on public deactivate() call', ({foundation, adapter, mockRaf}) => { const clock = lolex.install(); @@ -176,29 +176,29 @@ testFoundation('runs deactivation UX on public deactivate() call', ({foundation, }); testFoundation('runs deactivation UX when activation UX timer finishes first (activation held for a long time)', - ({foundation, adapter, mockRaf}) => { - const handlers = captureHandlers(adapter); - const clock = lolex.install(); - foundation.init(); - mockRaf.flush(); + ({foundation, adapter, mockRaf}) => { + const handlers = captureHandlers(adapter); + const clock = lolex.install(); + foundation.init(); + mockRaf.flush(); - handlers.mousedown({pageX: 0, pageY: 0}); - mockRaf.flush(); + handlers.mousedown({pageX: 0, pageY: 0}); + mockRaf.flush(); - clock.tick(DEACTIVATION_TIMEOUT_MS); - handlers.mouseup(); - mockRaf.flush(); + clock.tick(DEACTIVATION_TIMEOUT_MS); + handlers.mouseup(); + mockRaf.flush(); - td.verify(adapter.removeClass(cssClasses.BG_FOCUSED)); - td.verify(adapter.removeClass(cssClasses.BG_ACTIVE_FILL), {times: 2}); - td.verify(adapter.removeClass(cssClasses.FG_ACTIVATION), {times: 2}); - td.verify(adapter.addClass(cssClasses.FG_DEACTIVATION)); + td.verify(adapter.removeClass(cssClasses.BG_FOCUSED)); + td.verify(adapter.removeClass(cssClasses.BG_ACTIVE_FILL), {times: 2}); + td.verify(adapter.removeClass(cssClasses.FG_ACTIVATION), {times: 2}); + td.verify(adapter.addClass(cssClasses.FG_DEACTIVATION)); - clock.tick(numbers.FG_DEACTIVATION_MS); - td.verify(adapter.removeClass(cssClasses.FG_DEACTIVATION)); + clock.tick(numbers.FG_DEACTIVATION_MS); + td.verify(adapter.removeClass(cssClasses.FG_DEACTIVATION)); - clock.uninstall(); - }); + clock.uninstall(); + }); testFoundation('clears any pending deactivation UX timers when re-triggered', ({foundation, adapter, mockRaf}) => { const handlers = captureHandlers(adapter); @@ -236,176 +236,176 @@ testFoundation('clears any pending deactivation UX timers when re-triggered', ({ }); testFoundation('clears any pending foreground deactivation class removal timers when re-triggered', - ({foundation, adapter, mockRaf}) => { - const handlers = captureHandlers(adapter); - const clock = lolex.install(); - foundation.init(); - mockRaf.flush(); - - // Trigger the first interaction - handlers.mousedown({pageX: 0, pageY: 0}); - mockRaf.flush(); - handlers.mouseup(); - mockRaf.flush(); - - // Tick the clock such that the deactivation UX gets run, but _not_ so the foreground deactivation removal - // timer gets run - clock.tick(DEACTIVATION_TIMEOUT_MS); - - // Sanity check that the foreground deactivation class removal was only called once within - // the activation code. - td.verify(adapter.removeClass(cssClasses.FG_DEACTIVATION), {times: 1}); - - // Trigger another activation - handlers.mousedown({pageX: 0, pageY: 0}); - mockRaf.flush(); - - // Tick the clock past the time when the initial foreground deactivation timer would have ran. - clock.tick(numbers.FG_DEACTIVATION_MS); - - // Verify that the foreground deactivation class removal was only called twice: once within the - // original activation, and again within this subsequent activation; NOT by means of any timers firing. - td.verify(adapter.removeClass(cssClasses.FG_DEACTIVATION), {times: 2}); - }); + ({foundation, adapter, mockRaf}) => { + const handlers = captureHandlers(adapter); + const clock = lolex.install(); + foundation.init(); + mockRaf.flush(); + + // Trigger the first interaction + handlers.mousedown({pageX: 0, pageY: 0}); + mockRaf.flush(); + handlers.mouseup(); + mockRaf.flush(); + + // Tick the clock such that the deactivation UX gets run, but _not_ so the foreground deactivation removal + // timer gets run + clock.tick(DEACTIVATION_TIMEOUT_MS); + + // Sanity check that the foreground deactivation class removal was only called once within + // the activation code. + td.verify(adapter.removeClass(cssClasses.FG_DEACTIVATION), {times: 1}); + + // Trigger another activation + handlers.mousedown({pageX: 0, pageY: 0}); + mockRaf.flush(); + + // Tick the clock past the time when the initial foreground deactivation timer would have ran. + clock.tick(numbers.FG_DEACTIVATION_MS); + + // Verify that the foreground deactivation class removal was only called twice: once within the + // original activation, and again within this subsequent activation; NOT by means of any timers firing. + td.verify(adapter.removeClass(cssClasses.FG_DEACTIVATION), {times: 2}); + }); testFoundation('waits until activation UX timer runs before removing active fill classes', - ({foundation, adapter, mockRaf}) => { - const handlers = captureHandlers(adapter); - const clock = lolex.install(); + ({foundation, adapter, mockRaf}) => { + const handlers = captureHandlers(adapter); + const clock = lolex.install(); - foundation.init(); - mockRaf.flush(); + foundation.init(); + mockRaf.flush(); - handlers.mousedown({pageX: 0, pageY: 0}); - mockRaf.flush(); + handlers.mousedown({pageX: 0, pageY: 0}); + mockRaf.flush(); - handlers.mouseup(); - mockRaf.flush(); - clock.tick(DEACTIVATION_TIMEOUT_MS - 1); + handlers.mouseup(); + mockRaf.flush(); + clock.tick(DEACTIVATION_TIMEOUT_MS - 1); - td.verify(adapter.removeClass(cssClasses.BG_ACTIVE_FILL), {times: 1}); - td.verify(adapter.removeClass(cssClasses.FG_ACTIVATION), {times: 1}); - td.verify(adapter.addClass(cssClasses.FG_DEACTIVATION), {times: 0}); - clock.uninstall(); - }); + td.verify(adapter.removeClass(cssClasses.BG_ACTIVE_FILL), {times: 1}); + td.verify(adapter.removeClass(cssClasses.FG_ACTIVATION), {times: 1}); + td.verify(adapter.addClass(cssClasses.FG_DEACTIVATION), {times: 0}); + clock.uninstall(); + }); testFoundation('waits until actual deactivation UX is needed if animation finishes before deactivating', - ({foundation, adapter, mockRaf}) => { - const handlers = captureHandlers(adapter); - const clock = lolex.install(); + ({foundation, adapter, mockRaf}) => { + const handlers = captureHandlers(adapter); + const clock = lolex.install(); - foundation.init(); - mockRaf.flush(); + foundation.init(); + mockRaf.flush(); - handlers.mousedown({pageX: 0, pageY: 0}); - mockRaf.flush(); - clock.tick(DEACTIVATION_TIMEOUT_MS); + handlers.mousedown({pageX: 0, pageY: 0}); + mockRaf.flush(); + clock.tick(DEACTIVATION_TIMEOUT_MS); - td.verify(adapter.removeClass(cssClasses.BG_ACTIVE_FILL), {times: 1}); - td.verify(adapter.removeClass(cssClasses.FG_ACTIVATION), {times: 1}); - td.verify(adapter.addClass(cssClasses.FG_DEACTIVATION), {times: 0}); - clock.uninstall(); - }); + td.verify(adapter.removeClass(cssClasses.BG_ACTIVE_FILL), {times: 1}); + td.verify(adapter.removeClass(cssClasses.FG_ACTIVATION), {times: 1}); + td.verify(adapter.addClass(cssClasses.FG_DEACTIVATION), {times: 0}); + clock.uninstall(); + }); testFoundation('removes BG_FOCUSED class immediately without waiting for animationend event', - ({foundation, adapter, mockRaf}) => { - const handlers = captureHandlers(adapter); - const clock = lolex.install(); + ({foundation, adapter, mockRaf}) => { + const handlers = captureHandlers(adapter); + const clock = lolex.install(); - foundation.init(); - mockRaf.flush(); + foundation.init(); + mockRaf.flush(); - handlers.mousedown({pageX: 0, pageY: 0}); - mockRaf.flush(); + handlers.mousedown({pageX: 0, pageY: 0}); + mockRaf.flush(); - handlers.mouseup(); - mockRaf.flush(); + handlers.mouseup(); + mockRaf.flush(); - td.verify(adapter.removeClass(cssClasses.BG_FOCUSED)); - clock.uninstall(); - }); + td.verify(adapter.removeClass(cssClasses.BG_FOCUSED)); + clock.uninstall(); + }); testFoundation('only re-activates when there are no additional pointer events to be processed', - ({foundation, adapter, mockRaf}) => { - const handlers = captureHandlers(adapter); - const clock = lolex.install(); - foundation.init(); - mockRaf.flush(); - - // Simulate Android 6 / Chrome latest event flow. - handlers.pointerdown({pageX: 0, pageY: 0}); - mockRaf.flush(); - handlers.touchstart({changedTouches: [{pageX: 0, pageY: 0}]}); - mockRaf.flush(); - - clock.tick(DEACTIVATION_TIMEOUT_MS); - handlers.pointerup(); - mockRaf.flush(); - - // At this point, the deactivation UX should have run, since the initial activation was triggered by - // a pointerdown event. - td.verify(adapter.removeClass(cssClasses.BG_ACTIVE_FILL), {times: 2}); - td.verify(adapter.removeClass(cssClasses.FG_ACTIVATION), {times: 2}); - td.verify(adapter.addClass(cssClasses.FG_DEACTIVATION), {times: 1}); - - handlers.touchend(); - mockRaf.flush(); - - // Verify that deactivation UX has not been run redundantly - td.verify(adapter.removeClass(cssClasses.BG_FOCUSED), {times: 1}); - td.verify(adapter.removeClass(cssClasses.BG_ACTIVE_FILL), {times: 2}); - td.verify(adapter.removeClass(cssClasses.FG_ACTIVATION), {times: 2}); - td.verify(adapter.addClass(cssClasses.FG_DEACTIVATION), {times: 1}); - - handlers.mousedown({pageX: 0, pageY: 0}); - mockRaf.flush(); - - // Verify that activation only happened once, at pointerdown - td.verify(adapter.addClass(cssClasses.BG_ACTIVE_FILL), {times: 1}); - td.verify(adapter.addClass(cssClasses.FG_ACTIVATION), {times: 1}); - - handlers.mouseup(); - mockRaf.flush(); - clock.tick(DEACTIVATION_TIMEOUT_MS); - - // Finally, verify that since mouseup happened, we can re-activate the ripple. - handlers.mousedown({pageX: 0, pageY: 0}); - mockRaf.flush(); - td.verify(adapter.addClass(cssClasses.BG_ACTIVE_FILL), {times: 2}); - td.verify(adapter.addClass(cssClasses.FG_ACTIVATION), {times: 2}); - clock.uninstall(); - }); + ({foundation, adapter, mockRaf}) => { + const handlers = captureHandlers(adapter); + const clock = lolex.install(); + foundation.init(); + mockRaf.flush(); + + // Simulate Android 6 / Chrome latest event flow. + handlers.pointerdown({pageX: 0, pageY: 0}); + mockRaf.flush(); + handlers.touchstart({changedTouches: [{pageX: 0, pageY: 0}]}); + mockRaf.flush(); + + clock.tick(DEACTIVATION_TIMEOUT_MS); + handlers.pointerup(); + mockRaf.flush(); + + // At this point, the deactivation UX should have run, since the initial activation was triggered by + // a pointerdown event. + td.verify(adapter.removeClass(cssClasses.BG_ACTIVE_FILL), {times: 2}); + td.verify(adapter.removeClass(cssClasses.FG_ACTIVATION), {times: 2}); + td.verify(adapter.addClass(cssClasses.FG_DEACTIVATION), {times: 1}); + + handlers.touchend(); + mockRaf.flush(); + + // Verify that deactivation UX has not been run redundantly + td.verify(adapter.removeClass(cssClasses.BG_FOCUSED), {times: 1}); + td.verify(adapter.removeClass(cssClasses.BG_ACTIVE_FILL), {times: 2}); + td.verify(adapter.removeClass(cssClasses.FG_ACTIVATION), {times: 2}); + td.verify(adapter.addClass(cssClasses.FG_DEACTIVATION), {times: 1}); + + handlers.mousedown({pageX: 0, pageY: 0}); + mockRaf.flush(); + + // Verify that activation only happened once, at pointerdown + td.verify(adapter.addClass(cssClasses.BG_ACTIVE_FILL), {times: 1}); + td.verify(adapter.addClass(cssClasses.FG_ACTIVATION), {times: 1}); + + handlers.mouseup(); + mockRaf.flush(); + clock.tick(DEACTIVATION_TIMEOUT_MS); + + // Finally, verify that since mouseup happened, we can re-activate the ripple. + handlers.mousedown({pageX: 0, pageY: 0}); + mockRaf.flush(); + td.verify(adapter.addClass(cssClasses.BG_ACTIVE_FILL), {times: 2}); + td.verify(adapter.addClass(cssClasses.FG_ACTIVATION), {times: 2}); + clock.uninstall(); + }); testFoundation('ensures pointer event deactivation occurs even if activation rAF not run', - ({foundation, adapter, mockRaf}) => { - const handlers = captureHandlers(adapter); - const clock = lolex.install(); - foundation.init(); - mockRaf.flush(); - - handlers.mousedown({pageX: 0, pageY: 0}); - mockRaf.pendingFrames.shift(); - handlers.mouseup(); - mockRaf.flush(); - clock.tick(DEACTIVATION_TIMEOUT_MS); - - td.verify(adapter.removeClass(cssClasses.BG_FOCUSED), {times: 1}); - clock.uninstall(); - }); + ({foundation, adapter, mockRaf}) => { + const handlers = captureHandlers(adapter); + const clock = lolex.install(); + foundation.init(); + mockRaf.flush(); + + handlers.mousedown({pageX: 0, pageY: 0}); + mockRaf.pendingFrames.shift(); + handlers.mouseup(); + mockRaf.flush(); + clock.tick(DEACTIVATION_TIMEOUT_MS); + + td.verify(adapter.removeClass(cssClasses.BG_FOCUSED), {times: 1}); + clock.uninstall(); + }); testFoundation('ensures non-pointer event deactivation does not occurs even if activation rAF not run', - ({foundation, adapter, mockRaf}) => { - const handlers = captureHandlers(adapter); - const clock = lolex.install(); - foundation.init(); - mockRaf.flush(); - - handlers.keydown({key: 'Space'}); - mockRaf.pendingFrames.shift(); - handlers.keyup({key: 'Space'}); - mockRaf.flush(); - clock.tick(DEACTIVATION_TIMEOUT_MS); - - td.verify(adapter.removeClass(cssClasses.BG_FOCUSED), {times: 0}); - clock.uninstall(); - }); + ({foundation, adapter, mockRaf}) => { + const handlers = captureHandlers(adapter); + const clock = lolex.install(); + foundation.init(); + mockRaf.flush(); + + handlers.keydown({key: 'Space'}); + mockRaf.pendingFrames.shift(); + handlers.keyup({key: 'Space'}); + mockRaf.flush(); + clock.tick(DEACTIVATION_TIMEOUT_MS); + + td.verify(adapter.removeClass(cssClasses.BG_FOCUSED), {times: 0}); + clock.uninstall(); + }); diff --git a/test/unit/mdc-ripple/foundation.test.js b/test/unit/mdc-ripple/foundation.test.js index 07e89cfcbdc..d72b685e2b4 100644 --- a/test/unit/mdc-ripple/foundation.test.js +++ b/test/unit/mdc-ripple/foundation.test.js @@ -62,67 +62,67 @@ testFoundation('#init adds unbounded class when adapter indicates unbounded', ({ }); testFoundation('#init does not add unbounded class when adapter does not indicate unbounded (default)', - ({adapter, foundation, mockRaf}) => { - foundation.init(); - mockRaf.flush(); + ({adapter, foundation, mockRaf}) => { + foundation.init(); + mockRaf.flush(); - td.verify(adapter.addClass(cssClasses.UNBOUNDED), {times: 0}); - }); + td.verify(adapter.addClass(cssClasses.UNBOUNDED), {times: 0}); + }); testFoundation('#init gracefully exits when css variables are not supported', false, - ({foundation, adapter, mockRaf}) => { - foundation.init(); - mockRaf.flush(); + ({foundation, adapter, mockRaf}) => { + foundation.init(); + mockRaf.flush(); - td.verify(adapter.addClass(cssClasses.ROOT), {times: 0}); - }); + td.verify(adapter.addClass(cssClasses.ROOT), {times: 0}); + }); testFoundation(`#init sets ${strings.VAR_SURFACE_WIDTH} css variable to the clientRect's width`, - ({foundation, adapter, mockRaf}) => { - td.when(adapter.computeBoundingRect()).thenReturn({width: 200, height: 100}); - foundation.init(); - mockRaf.flush(); + ({foundation, adapter, mockRaf}) => { + td.when(adapter.computeBoundingRect()).thenReturn({width: 200, height: 100}); + foundation.init(); + mockRaf.flush(); - td.verify(adapter.updateCssVariable(strings.VAR_SURFACE_WIDTH, '200px')); - }); + td.verify(adapter.updateCssVariable(strings.VAR_SURFACE_WIDTH, '200px')); + }); testFoundation(`#init sets ${strings.VAR_SURFACE_HEIGHT} css variable to the clientRect's height`, - ({foundation, adapter, mockRaf}) => { - td.when(adapter.computeBoundingRect()).thenReturn({width: 200, height: 100}); - foundation.init(); - mockRaf.flush(); + ({foundation, adapter, mockRaf}) => { + td.when(adapter.computeBoundingRect()).thenReturn({width: 200, height: 100}); + foundation.init(); + mockRaf.flush(); - td.verify(adapter.updateCssVariable(strings.VAR_SURFACE_HEIGHT, '100px')); - }); + td.verify(adapter.updateCssVariable(strings.VAR_SURFACE_HEIGHT, '100px')); + }); testFoundation(`#init sets ${strings.VAR_FG_SIZE} to the circumscribing circle's diameter`, - ({foundation, adapter, mockRaf}) => { - const size = 200; - td.when(adapter.computeBoundingRect()).thenReturn({width: size, height: size / 2}); - foundation.init(); - mockRaf.flush(); - const initialSize = size * numbers.INITIAL_ORIGIN_SCALE; - - td.verify(adapter.updateCssVariable(strings.VAR_FG_SIZE, `${initialSize}px`)); - }); + ({foundation, adapter, mockRaf}) => { + const size = 200; + td.when(adapter.computeBoundingRect()).thenReturn({width: size, height: size / 2}); + foundation.init(); + mockRaf.flush(); + const initialSize = size * numbers.INITIAL_ORIGIN_SCALE; + + td.verify(adapter.updateCssVariable(strings.VAR_FG_SIZE, `${initialSize}px`)); + }); testFoundation(`#init centers via ${strings.VAR_LEFT} and ${strings.VAR_TOP} when unbounded`, - ({foundation, adapter, mockRaf}) => { - const width = 200; - const height = 100; - const maxSize = Math.max(width, height); - const initialSize = maxSize * numbers.INITIAL_ORIGIN_SCALE; - - td.when(adapter.computeBoundingRect()).thenReturn({width, height}); - td.when(adapter.isUnbounded()).thenReturn(true); - foundation.init(); - mockRaf.flush(); - - td.verify(adapter.updateCssVariable(strings.VAR_LEFT, + ({foundation, adapter, mockRaf}) => { + const width = 200; + const height = 100; + const maxSize = Math.max(width, height); + const initialSize = maxSize * numbers.INITIAL_ORIGIN_SCALE; + + td.when(adapter.computeBoundingRect()).thenReturn({width, height}); + td.when(adapter.isUnbounded()).thenReturn(true); + foundation.init(); + mockRaf.flush(); + + td.verify(adapter.updateCssVariable(strings.VAR_LEFT, `${Math.round((width / 2) - (initialSize / 2))}px`)); - td.verify(adapter.updateCssVariable(strings.VAR_TOP, + td.verify(adapter.updateCssVariable(strings.VAR_TOP, `${Math.round((height / 2) - (initialSize / 2))}px`)); - }); + }); testFoundation('#init registers events for all types of common interactions', ({foundation, adapter}) => { const expectedEvents = [ @@ -211,36 +211,36 @@ testFoundation('#destroy removes all CSS variables', ({foundation, adapter, mock }); testFoundation(`#layout sets ${strings.VAR_SURFACE_WIDTH} css variable to the clientRect's width`, - ({foundation, adapter, mockRaf}) => { - td.when(adapter.computeBoundingRect()).thenReturn({width: 200, height: 100}); - foundation.layout(); - mockRaf.flush(); + ({foundation, adapter, mockRaf}) => { + td.when(adapter.computeBoundingRect()).thenReturn({width: 200, height: 100}); + foundation.layout(); + mockRaf.flush(); - td.verify(adapter.updateCssVariable(strings.VAR_SURFACE_WIDTH, '200px')); - }); + td.verify(adapter.updateCssVariable(strings.VAR_SURFACE_WIDTH, '200px')); + }); testFoundation(`#layout sets ${strings.VAR_SURFACE_HEIGHT} css variable to the clientRect's height`, - ({foundation, adapter, mockRaf}) => { - td.when(adapter.computeBoundingRect()).thenReturn({width: 200, height: 100}); - foundation.layout(); - mockRaf.flush(); + ({foundation, adapter, mockRaf}) => { + td.when(adapter.computeBoundingRect()).thenReturn({width: 200, height: 100}); + foundation.layout(); + mockRaf.flush(); - td.verify(adapter.updateCssVariable(strings.VAR_SURFACE_HEIGHT, '100px')); - }); + td.verify(adapter.updateCssVariable(strings.VAR_SURFACE_HEIGHT, '100px')); + }); testFoundation(`#layout sets ${strings.VAR_FG_SIZE} to the circumscribing circle's diameter`, - ({foundation, adapter, mockRaf}) => { - const width = 200; - const height = 100; - const maxSize = Math.max(width, height); - const initialSize = maxSize * numbers.INITIAL_ORIGIN_SCALE; + ({foundation, adapter, mockRaf}) => { + const width = 200; + const height = 100; + const maxSize = Math.max(width, height); + const initialSize = maxSize * numbers.INITIAL_ORIGIN_SCALE; - td.when(adapter.computeBoundingRect()).thenReturn({width, height}); - foundation.layout(); - mockRaf.flush(); + td.when(adapter.computeBoundingRect()).thenReturn({width, height}); + foundation.layout(); + mockRaf.flush(); - td.verify(adapter.updateCssVariable(strings.VAR_FG_SIZE, `${initialSize}px`)); - }); + td.verify(adapter.updateCssVariable(strings.VAR_FG_SIZE, `${initialSize}px`)); + }); testFoundation(`#layout sets ${strings.VAR_FG_SCALE} based on the difference between the ` + 'proportion of the max radius and the initial size', ({foundation, adapter, mockRaf}) => { @@ -261,22 +261,22 @@ testFoundation(`#layout sets ${strings.VAR_FG_SCALE} based on the difference bet }); testFoundation(`#layout centers via ${strings.VAR_LEFT} and ${strings.VAR_TOP} when unbounded`, - ({foundation, adapter, mockRaf}) => { - const width = 200; - const height = 100; - const maxSize = Math.max(width, height); - const initialSize = maxSize * numbers.INITIAL_ORIGIN_SCALE; - - td.when(adapter.computeBoundingRect()).thenReturn({width, height}); - td.when(adapter.isUnbounded()).thenReturn(true); - foundation.layout(); - mockRaf.flush(); - - td.verify(adapter.updateCssVariable(strings.VAR_LEFT, + ({foundation, adapter, mockRaf}) => { + const width = 200; + const height = 100; + const maxSize = Math.max(width, height); + const initialSize = maxSize * numbers.INITIAL_ORIGIN_SCALE; + + td.when(adapter.computeBoundingRect()).thenReturn({width, height}); + td.when(adapter.isUnbounded()).thenReturn(true); + foundation.layout(); + mockRaf.flush(); + + td.verify(adapter.updateCssVariable(strings.VAR_LEFT, `${Math.round((width / 2) - (initialSize / 2))}px`)); - td.verify(adapter.updateCssVariable(strings.VAR_TOP, + td.verify(adapter.updateCssVariable(strings.VAR_TOP, `${Math.round((height / 2) - (initialSize / 2))}px`)); - }); + }); testFoundation('#layout debounces calls within the same frame', ({foundation, mockRaf}) => { foundation.layout(); diff --git a/test/unit/mdc-tabs/mdc-tab-bar-foundation.test.js b/test/unit/mdc-tabs/mdc-tab-bar-foundation.test.js index f7108fdf7f3..9c969b4aa69 100644 --- a/test/unit/mdc-tabs/mdc-tab-bar-foundation.test.js +++ b/test/unit/mdc-tabs/mdc-tab-bar-foundation.test.js @@ -118,8 +118,8 @@ test('#switchToTabAtIndex does nothing if the currently active tab is clicked', foundation.switchToTabAtIndex(0, true); td.verify(mockAdapter.setTabActiveAtIndex( - td.matchers.anything(), td.matchers.isA(Boolean) - ), {times: 0}); + td.matchers.anything(), td.matchers.isA(Boolean) + ), {times: 0}); td.verify(mockAdapter.notifyChange(td.matchers.anything()), {times: 0}); }); diff --git a/test/unit/mdc-tabs/mdc-tab-bar-scroller-foundation.test.js b/test/unit/mdc-tabs/mdc-tab-bar-scroller-foundation.test.js index cbaf64373cb..f1161baf610 100644 --- a/test/unit/mdc-tabs/mdc-tab-bar-scroller-foundation.test.js +++ b/test/unit/mdc-tabs/mdc-tab-bar-scroller-foundation.test.js @@ -496,9 +496,9 @@ test('focus in RTL context scrolls forward if distance between the right edge of const tabBarWidth = 900; td.when(mockAdapter.registerCapturedInteractionHandler(evtType, td.matchers.isA(Function))) - .thenDo((evtType, handler) => { - tabEvent = handler; - }); + .thenDo((evtType, handler) => { + tabEvent = handler; + }); td.when(mockAdapter.eventTargetHasClass(td.matchers.anything(), td.matchers.anything())).thenReturn(true); td.when(mockAdapter.isRTL()).thenReturn(true); diff --git a/webpack.config.js b/webpack.config.js index 5368addd463..cc2afae4e23 100644 --- a/webpack.config.js +++ b/webpack.config.js @@ -150,7 +150,7 @@ module.exports = [{ name: 'css', entry: { 'material-components-web': path.resolve( - './packages/material-components-web/material-components-web.scss'), + './packages/material-components-web/material-components-web.scss'), 'mdc.animation': path.resolve('./packages/mdc-animation/mdc-animation.scss'), 'mdc.button': path.resolve('./packages/mdc-button/mdc-button.scss'), 'mdc.card': path.resolve('./packages/mdc-card/mdc-card.scss'), From 1528ed7cfe9d29a0098054b13024d4faa48823ab Mon Sep 17 00:00:00 2001 From: Yiran Mao Date: Thu, 6 Jul 2017 14:28:53 -0400 Subject: [PATCH 03/12] feat(layout-grid): Implement layout grid alignment. (#885) Closes #749. --- demos/layout-grid.html | 22 +++-- packages/mdc-layout-grid/README.md | 93 +++++++++++-------- packages/mdc-layout-grid/mdc-layout-grid.scss | 9 ++ 3 files changed, 78 insertions(+), 46 deletions(-) diff --git a/demos/layout-grid.html b/demos/layout-grid.html index f33bba53438..2fcf373a78f 100644 --- a/demos/layout-grid.html +++ b/demos/layout-grid.html @@ -69,11 +69,6 @@ max-width: 1280px; } - .demo-grid.left-align { - margin-left: 0; - margin-right: auto; - } - .demo-grid-legend { margin: 16px 0 8px 0; } @@ -288,7 +283,8 @@ -
Grid with max width (1280px) and center alignment
+

Grid with max width

+
Grid with max width (1280px) and center alignment by default
@@ -298,7 +294,7 @@
Grid with max width (1280px) and left alignment
-
+
@@ -306,7 +302,7 @@
-
Fixed column width layout grid
+

Fixed column width layout grid

@@ -338,6 +334,7 @@
+
Fixed column width layout grid and center alignment by default
@@ -346,6 +343,15 @@
+
Fixed column width layout grid and right alignment
+
+
+
+
+
+
+
+
diff --git a/packages/mdc-layout-grid/README.md b/packages/mdc-layout-grid/README.md index ce2884e511f..3df1c91dbe2 100644 --- a/packages/mdc-layout-grid/README.md +++ b/packages/mdc-layout-grid/README.md @@ -92,7 +92,9 @@ You can change the margins and gutters for a grid using the `--mdc-layout-grid-m You can change the margins and gutters using sass variables if you are compiling from them. MDC layout grid uses sass map `mdc-layout-grid-default-margin` and `mdc-layout-grid-default-gutter` to define margins and gutters on different screen types. -### Column spans +### Grid cells + +#### Column spans ```html
@@ -131,13 +133,49 @@ In the example above, the first cell has a default span of 6, the second 4, and the first cell becomes 8 columns wide instead, and the second 6 columns wide. At phone sizes, the third cell becomes 4 columns wide. +#### Cell reordering + +By default, items are positioned in the source order. However, you can reorder them by using the +`mdc-layout-grid__cell--order-{number}` classes, where `{order}` is an integer between 1 and 12. + +```html +
+
+
+
+
+
+
+``` + +Please bear in mind that this may have an impact on accessibility, since screen readers and other tools tend to follow +source order. + + +#### Cell alignment -### Max width +Items are defined to stretch, by default, taking up the height of their corresponding row. You can switch to a different +behavior by using one of the `mdc-layout-grid__cell--align-{position}` alignment classes, where `{position}` is one of +`{top}`, `{middle}` or `{bottom}`. + +```html +
+
+
+
+
+
+
+``` + +### Grid with restricted width + +#### Max width MDC layout grids take up the parent element space by default. However, user can set `$mdc-layout-grid-max-width` to restrict the max-width of the layout grid. -### Fixed column width grid +#### Fixed column width grid You can designate each column to have a certain width by using `mdc-layout-grid--fixed-column-width` modifier. The column width can be specified through sass map `$mdc-layout-grid-column-width` or css custom properties `--mdc-layout-grid-column-width-{screen_size}`. The column width is set to 72px on all devices by default. @@ -156,6 +194,20 @@ You can designate each column to have a certain width by using `mdc-layout-grid-
``` +#### Alignment of grid + +The grid is by default center aligned. User can add `mdc-layout-grid--align-left` +or `mdc-layout-grid--align-right` modifier class to change this behavior. Note, these +modifiers will have no effect when the grid already fills its container. + +``` +
+
+
+
+
+
+``` ### Nested grid @@ -180,41 +232,6 @@ However, Material guideline do not recommend have a deeply nested grid since it
``` -### Reordering - -By default, items are positioned in the source order. However, you can reorder them by using the -`mdc-layout-grid__cell--order-{number}` classes, where `{order}` is an integer between 1 and 12. - -```html -
-
-
-
-
-
-
-``` - -Please bear in mind that this may have an impact on accessibility, since screen readers and other tools tend to follow -source order. - - -### Alignment - -Items are defined to stretch, by default, taking up the height of their corresponding row. You can switch to a different -behavior by using one of the `mdc-layout-grid__cell--align-{position}` alignment classes, where `{position}` is one of -`{top}`, `{middle}` or `{bottom}`. - -```html -
-
-
-
-
-
-
-``` - ## Sass mixin usage diff --git a/packages/mdc-layout-grid/mdc-layout-grid.scss b/packages/mdc-layout-grid/mdc-layout-grid.scss index 8d903d702e5..8e572753df5 100644 --- a/packages/mdc-layout-grid/mdc-layout-grid.scss +++ b/packages/mdc-layout-grid/mdc-layout-grid.scss @@ -97,4 +97,13 @@ } } +.mdc-layout-grid--align-left { + margin-right: auto; + margin-left: 0; +} + +.mdc-layout-grid--align-right { + margin-right: 0; + margin-left: auto; +} // postcss-bem-linter: end From 3812fbdce3f88eca439e9d33b6b80e9a142a0a82 Mon Sep 17 00:00:00 2001 From: Toufic Batache Date: Thu, 6 Jul 2017 21:58:16 +0300 Subject: [PATCH 04/12] fix(fab): FAB z-index is wrong (#888) Resolves #872 --- demos/fab.html | 1 + 1 file changed, 1 insertion(+) diff --git a/demos/fab.html b/demos/fab.html index 3d66da8a00c..1c04282a9ce 100644 --- a/demos/fab.html +++ b/demos/fab.html @@ -36,6 +36,7 @@ position: fixed; bottom: 1rem; right: 1rem; + z-index: 1; } @media(min-width: 1024px) { From 6e0a8c9caca759ed461f643a1d15150c7fb99a20 Mon Sep 17 00:00:00 2001 From: pgbross Date: Thu, 6 Jul 2017 22:25:57 +0100 Subject: [PATCH 05/12] feat(framework-examples): Add Vue continuous slider example (#827) --- framework-examples/vue/package-lock.json | 6021 +++++++++++++++++ framework-examples/vue/package.json | 1 + framework-examples/vue/src/App.vue | 32 +- .../vue/src/v-mdc-checkbox/Checkbox.vue | 2 +- .../vue/src/v-mdc-slider/Slider.vue | 148 + 5 files changed, 6198 insertions(+), 6 deletions(-) create mode 100644 framework-examples/vue/package-lock.json create mode 100644 framework-examples/vue/src/v-mdc-slider/Slider.vue diff --git a/framework-examples/vue/package-lock.json b/framework-examples/vue/package-lock.json new file mode 100644 index 00000000000..531f6fe7d2a --- /dev/null +++ b/framework-examples/vue/package-lock.json @@ -0,0 +1,6021 @@ +{ + "name": "v-mdc-example", + "version": "0.1.0", + "lockfileVersion": 1, + "dependencies": { + "@material/animation": { + "version": "0.1.5", + "resolved": "https://registry.npmjs.org/@material/animation/-/animation-0.1.5.tgz", + "integrity": "sha1-ecRczc3oooakw9eVWHOyB55OXDI=" + }, + "@material/base": { + "version": "0.1.3", + "resolved": "https://registry.npmjs.org/@material/base/-/base-0.1.3.tgz", + "integrity": "sha1-9Y9g9RZN9NDq7HBzCQiwIlX3bc0=" + }, + "@material/button": { + "version": "0.3.7", + "resolved": "https://registry.npmjs.org/@material/button/-/button-0.3.7.tgz", + "integrity": "sha1-ORJ5EyL39xKaWiI5wwmOixCkzrg=", + "dependencies": { + "@material/animation": { + "version": "0.2.3", + "resolved": "https://registry.npmjs.org/@material/animation/-/animation-0.2.3.tgz", + "integrity": "sha1-JfJJYs1knnZFmharI0t4Rqen9Bk=" + }, + "@material/base": { + "version": "0.2.0", + "resolved": "https://registry.npmjs.org/@material/base/-/base-0.2.0.tgz", + "integrity": "sha1-aF4sNEqgN+Qr55eOHzZf8YO586E=" + }, + "@material/ripple": { + "version": "0.6.2", + "resolved": "https://registry.npmjs.org/@material/ripple/-/ripple-0.6.2.tgz", + "integrity": "sha1-qFVtt8FB019VgsWZC+hpC++d7lk=" + }, + "@material/typography": { + "version": "0.2.2", + "resolved": "https://registry.npmjs.org/@material/typography/-/typography-0.2.2.tgz", + "integrity": "sha1-3F8HY619blrVyGw5SzYPK0zzC7I=" + } + } + }, + "@material/checkbox": { + "version": "0.1.2", + "resolved": "https://registry.npmjs.org/@material/checkbox/-/checkbox-0.1.2.tgz", + "integrity": "sha1-zdoF602snwlRXIeC/cyYrwsqEck=" + }, + "@material/drawer": { + "version": "0.1.4", + "resolved": "https://registry.npmjs.org/@material/drawer/-/drawer-0.1.4.tgz", + "integrity": "sha1-k4Ed3zCJnJrDWOm0jmFEL8nBlo4=", + "dependencies": { + "@material/typography": { + "version": "0.2.2", + "resolved": "https://registry.npmjs.org/@material/typography/-/typography-0.2.2.tgz", + "integrity": "sha1-3F8HY619blrVyGw5SzYPK0zzC7I=" + } + } + }, + "@material/elevation": { + "version": "0.1.8", + "resolved": "https://registry.npmjs.org/@material/elevation/-/elevation-0.1.8.tgz", + "integrity": "sha1-V6HzVBozDQNWM9t/XbgsRi0MytA=", + "dependencies": { + "@material/animation": { + "version": "0.2.3", + "resolved": "https://registry.npmjs.org/@material/animation/-/animation-0.2.3.tgz", + "integrity": "sha1-JfJJYs1knnZFmharI0t4Rqen9Bk=" + } + } + }, + "@material/form-field": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/@material/form-field/-/form-field-0.1.1.tgz", + "integrity": "sha1-ATDjz/8PPGmT0jwZF8rlnS0MHvY=" + }, + "@material/icon-toggle": { + "version": "0.1.12", + "resolved": "https://registry.npmjs.org/@material/icon-toggle/-/icon-toggle-0.1.12.tgz", + "integrity": "sha1-5wds0PcHH7zSBg/j1Od07LugHZw=", + "dependencies": { + "@material/animation": { + "version": "0.2.3", + "resolved": "https://registry.npmjs.org/@material/animation/-/animation-0.2.3.tgz", + "integrity": "sha1-JfJJYs1knnZFmharI0t4Rqen9Bk=" + }, + "@material/base": { + "version": "0.2.0", + "resolved": "https://registry.npmjs.org/@material/base/-/base-0.2.0.tgz", + "integrity": "sha1-aF4sNEqgN+Qr55eOHzZf8YO586E=" + }, + "@material/ripple": { + "version": "0.6.2", + "resolved": "https://registry.npmjs.org/@material/ripple/-/ripple-0.6.2.tgz", + "integrity": "sha1-qFVtt8FB019VgsWZC+hpC++d7lk=" + } + } + }, + "@material/list": { + "version": "0.1.0", + "resolved": "https://registry.npmjs.org/@material/list/-/list-0.1.0.tgz", + "integrity": "sha1-yKJLtNRjnpgf16Jx5K+9266jl0g=" + }, + "@material/ripple": { + "version": "0.1.2", + "resolved": "https://registry.npmjs.org/@material/ripple/-/ripple-0.1.2.tgz", + "integrity": "sha1-BvOxfbujE3snpo8lZkTi1qMrumI=" + }, + "@material/rtl": { + "version": "0.1.5", + "resolved": "https://registry.npmjs.org/@material/rtl/-/rtl-0.1.5.tgz", + "integrity": "sha512-ZyRjfi3lOUTrawgm7nndejgL8+l4zlLL/IXkz6+XTbwACkj73QUxK8Sp9K8aniOZPn5LBjF2gAiSVHrK/V1axg==" + }, + "@material/slider": { + "version": "0.1.0", + "resolved": "https://registry.npmjs.org/@material/slider/-/slider-0.1.0.tgz", + "integrity": "sha512-2iUGnd8h8dkWFS9JnEmC0h811vkuRITahkgW6evO4QmNJUAqMkGjnGX/D2Kdaf7uuJ9TQ+Of7peHMfdr3hoR6w==", + "dependencies": { + "@material/animation": { + "version": "0.2.3", + "resolved": "https://registry.npmjs.org/@material/animation/-/animation-0.2.3.tgz", + "integrity": "sha1-JfJJYs1knnZFmharI0t4Rqen9Bk=" + }, + "@material/base": { + "version": "0.2.0", + "resolved": "https://registry.npmjs.org/@material/base/-/base-0.2.0.tgz", + "integrity": "sha1-aF4sNEqgN+Qr55eOHzZf8YO586E=" + } + } + }, + "@material/snackbar": { + "version": "0.1.11", + "resolved": "https://registry.npmjs.org/@material/snackbar/-/snackbar-0.1.11.tgz", + "integrity": "sha1-Bl+gO/4lkjInaytxXJUyJCriNBo=", + "dependencies": { + "@material/animation": { + "version": "0.2.3", + "resolved": "https://registry.npmjs.org/@material/animation/-/animation-0.2.3.tgz", + "integrity": "sha1-JfJJYs1knnZFmharI0t4Rqen9Bk=" + }, + "@material/typography": { + "version": "0.2.2", + "resolved": "https://registry.npmjs.org/@material/typography/-/typography-0.2.2.tgz", + "integrity": "sha1-3F8HY619blrVyGw5SzYPK0zzC7I=" + } + } + }, + "@material/theme": { + "version": "0.1.5", + "resolved": "https://registry.npmjs.org/@material/theme/-/theme-0.1.5.tgz", + "integrity": "sha1-XHvZoZdNjBwOrPA34CNarZxctpk=" + }, + "@material/typography": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/@material/typography/-/typography-0.1.1.tgz", + "integrity": "sha1-+y40N70yhNOen7kUhXZ63msr0ME=" + }, + "abbrev": { + "version": "1.0.9", + "resolved": "https://registry.npmjs.org/abbrev/-/abbrev-1.0.9.tgz", + "integrity": "sha1-kbR5JYinc4wl813W9jdSovh3YTU=", + "dev": true + }, + "accepts": { + "version": "1.3.3", + "resolved": "https://registry.npmjs.org/accepts/-/accepts-1.3.3.tgz", + "integrity": "sha1-w8p0NJOGSMPg2cHjKN1otiLChMo=", + "dev": true + }, + "acorn": { + "version": "5.0.3", + "resolved": "https://registry.npmjs.org/acorn/-/acorn-5.0.3.tgz", + "integrity": "sha1-xGDfCEkUY/AozLguqzcwvwEIez0=", + "dev": true + }, + "acorn-globals": { + "version": "1.0.9", + "resolved": "https://registry.npmjs.org/acorn-globals/-/acorn-globals-1.0.9.tgz", + "integrity": "sha1-VbtemGkVB7dFedBRNBMhfDgMVM8=", + "dev": true, + "dependencies": { + "acorn": { + "version": "2.7.0", + "resolved": "https://registry.npmjs.org/acorn/-/acorn-2.7.0.tgz", + "integrity": "sha1-q259nYhqrKiwhbwzEreaGYQz8Oc=", + "dev": true + } + } + }, + "acorn-jsx": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-3.0.1.tgz", + "integrity": "sha1-r9+UiPsezvyDSPb7IvRk4ypYs2s=", + "dev": true, + "dependencies": { + "acorn": { + "version": "3.3.0", + "resolved": "https://registry.npmjs.org/acorn/-/acorn-3.3.0.tgz", + "integrity": "sha1-ReN/s56No/JbruP/U2niu18iAXo=", + "dev": true + } + } + }, + "ajv": { + "version": "4.11.8", + "resolved": "https://registry.npmjs.org/ajv/-/ajv-4.11.8.tgz", + "integrity": "sha1-gv+wKynmYq5TvcIK8VlHcGc5xTY=", + "dev": true + }, + "ajv-keywords": { + "version": "1.5.1", + "resolved": "https://registry.npmjs.org/ajv-keywords/-/ajv-keywords-1.5.1.tgz", + "integrity": "sha1-MU3QpLM2j609/NxU7eYXG4htrzw=", + "dev": true + }, + "align-text": { + "version": "0.1.4", + "resolved": "https://registry.npmjs.org/align-text/-/align-text-0.1.4.tgz", + "integrity": "sha1-DNkKVhCT810KmSVsIrcGlDP60Rc=", + "dev": true + }, + "alphanum-sort": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/alphanum-sort/-/alphanum-sort-1.0.2.tgz", + "integrity": "sha1-l6ERlkmyEa0zaR2fn0hqjsn74KM=", + "dev": true + }, + "amdefine": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/amdefine/-/amdefine-1.0.1.tgz", + "integrity": "sha1-SlKCrBZHKek2Gbz9OtFR+BfOkfU=", + "dev": true + }, + "ansi-escapes": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-1.4.0.tgz", + "integrity": "sha1-06ioOzGapneTZisT52HHkRQiMG4=", + "dev": true + }, + "ansi-html": { + "version": "0.0.7", + "resolved": "https://registry.npmjs.org/ansi-html/-/ansi-html-0.0.7.tgz", + "integrity": "sha1-gTWEAhliqenm/QOflA0S9WynhZ4=", + "dev": true + }, + "ansi-regex": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-2.1.1.tgz", + "integrity": "sha1-w7M6te42DYbg5ijwRorn7yfWVN8=", + "dev": true + }, + "ansi-styles": { + "version": "2.2.1", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-2.2.1.tgz", + "integrity": "sha1-tDLdM1i2NM914eRmQ2gkBTPB3b4=", + "dev": true + }, + "anymatch": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-1.3.0.tgz", + "integrity": "sha1-o+Uvo5FoyCX/V7AkgSbOWo/5VQc=", + "dev": true + }, + "aproba": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/aproba/-/aproba-1.1.2.tgz", + "integrity": "sha512-ZpYajIfO0j2cOFTO955KUMIKNmj6zhX8kVztMAxFsDaMwz+9Z9SV0uou2pC9HJqcfpffOsjnbrDMvkNy+9RXPw==", + "dev": true + }, + "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=", + "dev": true + }, + "argparse": { + "version": "1.0.9", + "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.9.tgz", + "integrity": "sha1-c9g7wmP4bpf4zE9rrhsOkKfSLIY=", + "dev": true + }, + "arr-diff": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/arr-diff/-/arr-diff-2.0.0.tgz", + "integrity": "sha1-jzuCf5Vai9ZpaX5KQlasPOrjVs8=", + "dev": true + }, + "arr-flatten": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/arr-flatten/-/arr-flatten-1.0.3.tgz", + "integrity": "sha1-onTthawIhJtr14R8RYB0XcUa37E=", + "dev": true + }, + "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=", + "dev": true + }, + "array-flatten": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/array-flatten/-/array-flatten-1.1.1.tgz", + "integrity": "sha1-ml9pkFGx5wczKPKgCJaLZOopVdI=", + "dev": true + }, + "array-union": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/array-union/-/array-union-1.0.2.tgz", + "integrity": "sha1-mjRBDk9OPaI96jdb5b5w8kd47Dk=", + "dev": true + }, + "array-uniq": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/array-uniq/-/array-uniq-1.0.3.tgz", + "integrity": "sha1-r2rId6Jcx/dOBYiUdThY39sk/bY=", + "dev": true + }, + "array-unique": { + "version": "0.2.1", + "resolved": "https://registry.npmjs.org/array-unique/-/array-unique-0.2.1.tgz", + "integrity": "sha1-odl8yvy8JiXMcPrc6zalDFiwGlM=", + "dev": true + }, + "arrify": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/arrify/-/arrify-1.0.1.tgz", + "integrity": "sha1-iYUI2iIm84DfkEcoRWhJwVAaSw0=", + "dev": true + }, + "asap": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/asap/-/asap-1.0.0.tgz", + "integrity": "sha1-sqRdpf36ILBJb8N2jMJ8EvqRan0=", + "dev": true + }, + "asn1": { + "version": "0.2.3", + "resolved": "https://registry.npmjs.org/asn1/-/asn1-0.2.3.tgz", + "integrity": "sha1-2sh4dxPJlmhJ/IGAd36+nB3fO4Y=", + "dev": true + }, + "assert": { + "version": "1.4.1", + "resolved": "https://registry.npmjs.org/assert/-/assert-1.4.1.tgz", + "integrity": "sha1-mZEtWRg2tab1s0XA8H7vwI/GXZE=", + "dev": true + }, + "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=", + "dev": true + }, + "ast-types": { + "version": "0.9.6", + "resolved": "https://registry.npmjs.org/ast-types/-/ast-types-0.9.6.tgz", + "integrity": "sha1-ECyenpAF0+fjgpvwxPok7oYu6bk=", + "dev": true + }, + "async": { + "version": "1.5.2", + "resolved": "https://registry.npmjs.org/async/-/async-1.5.2.tgz", + "integrity": "sha1-7GphrlZIDAw8skHJVhjiCJL5Zyo=", + "dev": true + }, + "async-each": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/async-each/-/async-each-1.0.1.tgz", + "integrity": "sha1-GdOGodntxufByF04iu28xW0zYC0=", + "dev": true + }, + "async-foreach": { + "version": "0.1.3", + "resolved": "https://registry.npmjs.org/async-foreach/-/async-foreach-0.1.3.tgz", + "integrity": "sha1-NhIfhFwFeBct5Bmpfb6x0W7DRUI=", + "dev": true + }, + "asynckit": { + "version": "0.4.0", + "resolved": "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz", + "integrity": "sha1-x57Zf380y48robyXkLzDZkdLS3k=", + "dev": true + }, + "autoprefixer": { + "version": "6.7.7", + "resolved": "https://registry.npmjs.org/autoprefixer/-/autoprefixer-6.7.7.tgz", + "integrity": "sha1-Hb0cg1ZY41zj+ZhAmdsAWFx4IBQ=", + "dev": true + }, + "aws-sign2": { + "version": "0.6.0", + "resolved": "https://registry.npmjs.org/aws-sign2/-/aws-sign2-0.6.0.tgz", + "integrity": "sha1-FDQt0428yU0OW4fXY81jYSwOeU8=", + "dev": true + }, + "aws4": { + "version": "1.6.0", + "resolved": "https://registry.npmjs.org/aws4/-/aws4-1.6.0.tgz", + "integrity": "sha1-g+9cqGCysy5KDe7e6MdxudtXRx4=", + "dev": true + }, + "babel-code-frame": { + "version": "6.22.0", + "resolved": "https://registry.npmjs.org/babel-code-frame/-/babel-code-frame-6.22.0.tgz", + "integrity": "sha1-AnYgvuVnqIwyVhV05/0IAdMxGOQ=", + "dev": true + }, + "babel-core": { + "version": "6.25.0", + "resolved": "https://registry.npmjs.org/babel-core/-/babel-core-6.25.0.tgz", + "integrity": "sha1-fdQrBGPHQunVKW3rPsZ6kyLa1yk=", + "dev": true + }, + "babel-generator": { + "version": "6.25.0", + "resolved": "https://registry.npmjs.org/babel-generator/-/babel-generator-6.25.0.tgz", + "integrity": "sha1-M6GvcNXyiQrrRlpKd5PB32qeqfw=", + "dev": true + }, + "babel-helper-bindify-decorators": { + "version": "6.24.1", + "resolved": "https://registry.npmjs.org/babel-helper-bindify-decorators/-/babel-helper-bindify-decorators-6.24.1.tgz", + "integrity": "sha1-FMGeXxQte0fxmlJDHlKxzLxAozA=", + "dev": true + }, + "babel-helper-builder-binary-assignment-operator-visitor": { + "version": "6.24.1", + "resolved": "https://registry.npmjs.org/babel-helper-builder-binary-assignment-operator-visitor/-/babel-helper-builder-binary-assignment-operator-visitor-6.24.1.tgz", + "integrity": "sha1-zORReto1b0IgvK6KAsKzRvmlZmQ=", + "dev": true + }, + "babel-helper-call-delegate": { + "version": "6.24.1", + "resolved": "https://registry.npmjs.org/babel-helper-call-delegate/-/babel-helper-call-delegate-6.24.1.tgz", + "integrity": "sha1-7Oaqzdx25Bw0YfiL/Fdb0Nqi340=", + "dev": true + }, + "babel-helper-define-map": { + "version": "6.24.1", + "resolved": "https://registry.npmjs.org/babel-helper-define-map/-/babel-helper-define-map-6.24.1.tgz", + "integrity": "sha1-epdH8ljYlH0y1RX2qhx70CIEoIA=", + "dev": true + }, + "babel-helper-explode-assignable-expression": { + "version": "6.24.1", + "resolved": "https://registry.npmjs.org/babel-helper-explode-assignable-expression/-/babel-helper-explode-assignable-expression-6.24.1.tgz", + "integrity": "sha1-8luCz33BBDPFX3BZLVdGQArCLKo=", + "dev": true + }, + "babel-helper-explode-class": { + "version": "6.24.1", + "resolved": "https://registry.npmjs.org/babel-helper-explode-class/-/babel-helper-explode-class-6.24.1.tgz", + "integrity": "sha1-fcKjkQ3uAHBW4eMdZAztPVTqqes=", + "dev": true + }, + "babel-helper-function-name": { + "version": "6.24.1", + "resolved": "https://registry.npmjs.org/babel-helper-function-name/-/babel-helper-function-name-6.24.1.tgz", + "integrity": "sha1-00dbjAPtmCQqJbSDUasYOZ01gKk=", + "dev": true + }, + "babel-helper-get-function-arity": { + "version": "6.24.1", + "resolved": "https://registry.npmjs.org/babel-helper-get-function-arity/-/babel-helper-get-function-arity-6.24.1.tgz", + "integrity": "sha1-j3eCqpNAfEHTqlCQj4mwMbG2hT0=", + "dev": true + }, + "babel-helper-hoist-variables": { + "version": "6.24.1", + "resolved": "https://registry.npmjs.org/babel-helper-hoist-variables/-/babel-helper-hoist-variables-6.24.1.tgz", + "integrity": "sha1-HssnaJydJVE+rbyZFKc/VAi+enY=", + "dev": true + }, + "babel-helper-optimise-call-expression": { + "version": "6.24.1", + "resolved": "https://registry.npmjs.org/babel-helper-optimise-call-expression/-/babel-helper-optimise-call-expression-6.24.1.tgz", + "integrity": "sha1-96E0J7qfc/j0+pk8VKl4gtEkQlc=", + "dev": true + }, + "babel-helper-regex": { + "version": "6.24.1", + "resolved": "https://registry.npmjs.org/babel-helper-regex/-/babel-helper-regex-6.24.1.tgz", + "integrity": "sha1-024i+rEAjXnYhkjjIRaGgShFbOg=", + "dev": true + }, + "babel-helper-remap-async-to-generator": { + "version": "6.24.1", + "resolved": "https://registry.npmjs.org/babel-helper-remap-async-to-generator/-/babel-helper-remap-async-to-generator-6.24.1.tgz", + "integrity": "sha1-XsWBgnrXI/7N04HxySg5BnbkVRs=", + "dev": true + }, + "babel-helper-replace-supers": { + "version": "6.24.1", + "resolved": "https://registry.npmjs.org/babel-helper-replace-supers/-/babel-helper-replace-supers-6.24.1.tgz", + "integrity": "sha1-v22/5Dk40XNpohPKiov3S2qQqxo=", + "dev": true + }, + "babel-helpers": { + "version": "6.24.1", + "resolved": "https://registry.npmjs.org/babel-helpers/-/babel-helpers-6.24.1.tgz", + "integrity": "sha1-NHHenK7DiOXIUOWX5Yom3fN2ArI=", + "dev": true + }, + "babel-loader": { + "version": "6.4.1", + "resolved": "https://registry.npmjs.org/babel-loader/-/babel-loader-6.4.1.tgz", + "integrity": "sha1-CzQRLVsHSKjc2/Uaz2+b1C1QuMo=", + "dev": true + }, + "babel-messages": { + "version": "6.23.0", + "resolved": "https://registry.npmjs.org/babel-messages/-/babel-messages-6.23.0.tgz", + "integrity": "sha1-8830cDhYA1sqKVHG7F7fbGLyYw4=", + "dev": true + }, + "babel-plugin-check-es2015-constants": { + "version": "6.22.0", + "resolved": "https://registry.npmjs.org/babel-plugin-check-es2015-constants/-/babel-plugin-check-es2015-constants-6.22.0.tgz", + "integrity": "sha1-NRV7EBQm/S/9PaP3XH0ekYNbv4o=", + "dev": true + }, + "babel-plugin-syntax-async-functions": { + "version": "6.13.0", + "resolved": "https://registry.npmjs.org/babel-plugin-syntax-async-functions/-/babel-plugin-syntax-async-functions-6.13.0.tgz", + "integrity": "sha1-ytnK0RkbWtY0vzCuCHI5HgZHvpU=", + "dev": true + }, + "babel-plugin-syntax-async-generators": { + "version": "6.13.0", + "resolved": "https://registry.npmjs.org/babel-plugin-syntax-async-generators/-/babel-plugin-syntax-async-generators-6.13.0.tgz", + "integrity": "sha1-a8lj67FuzLrmuStZbrfzXDQqi5o=", + "dev": true + }, + "babel-plugin-syntax-class-properties": { + "version": "6.13.0", + "resolved": "https://registry.npmjs.org/babel-plugin-syntax-class-properties/-/babel-plugin-syntax-class-properties-6.13.0.tgz", + "integrity": "sha1-1+sjt5oxf4VDlixQW4J8fWysJ94=", + "dev": true + }, + "babel-plugin-syntax-decorators": { + "version": "6.13.0", + "resolved": "https://registry.npmjs.org/babel-plugin-syntax-decorators/-/babel-plugin-syntax-decorators-6.13.0.tgz", + "integrity": "sha1-MSVjtNvePMgGzuPkFszurd0RrAs=", + "dev": true + }, + "babel-plugin-syntax-dynamic-import": { + "version": "6.18.0", + "resolved": "https://registry.npmjs.org/babel-plugin-syntax-dynamic-import/-/babel-plugin-syntax-dynamic-import-6.18.0.tgz", + "integrity": "sha1-jWomIpyDdFqZgqRBBRVyyqF5sdo=", + "dev": true + }, + "babel-plugin-syntax-exponentiation-operator": { + "version": "6.13.0", + "resolved": "https://registry.npmjs.org/babel-plugin-syntax-exponentiation-operator/-/babel-plugin-syntax-exponentiation-operator-6.13.0.tgz", + "integrity": "sha1-nufoM3KQ2pUoggGmpX9BcDF4MN4=", + "dev": true + }, + "babel-plugin-syntax-object-rest-spread": { + "version": "6.13.0", + "resolved": "https://registry.npmjs.org/babel-plugin-syntax-object-rest-spread/-/babel-plugin-syntax-object-rest-spread-6.13.0.tgz", + "integrity": "sha1-/WU28rzhODb/o6VFjEkDpZe7O/U=", + "dev": true + }, + "babel-plugin-syntax-trailing-function-commas": { + "version": "6.22.0", + "resolved": "https://registry.npmjs.org/babel-plugin-syntax-trailing-function-commas/-/babel-plugin-syntax-trailing-function-commas-6.22.0.tgz", + "integrity": "sha1-ugNgk3+NBuQBgKQ/4NVhb/9TLPM=", + "dev": true + }, + "babel-plugin-transform-async-generator-functions": { + "version": "6.24.1", + "resolved": "https://registry.npmjs.org/babel-plugin-transform-async-generator-functions/-/babel-plugin-transform-async-generator-functions-6.24.1.tgz", + "integrity": "sha1-8FiQAUX9PpkHpt3yjaWfIVJYpds=", + "dev": true + }, + "babel-plugin-transform-async-to-generator": { + "version": "6.24.1", + "resolved": "https://registry.npmjs.org/babel-plugin-transform-async-to-generator/-/babel-plugin-transform-async-to-generator-6.24.1.tgz", + "integrity": "sha1-ZTbjeK/2yx1VF6wOQOs+n8jQh2E=", + "dev": true + }, + "babel-plugin-transform-class-properties": { + "version": "6.24.1", + "resolved": "https://registry.npmjs.org/babel-plugin-transform-class-properties/-/babel-plugin-transform-class-properties-6.24.1.tgz", + "integrity": "sha1-anl2PqYdM9NvN7YRqp3vgagbRqw=", + "dev": true + }, + "babel-plugin-transform-decorators": { + "version": "6.24.1", + "resolved": "https://registry.npmjs.org/babel-plugin-transform-decorators/-/babel-plugin-transform-decorators-6.24.1.tgz", + "integrity": "sha1-eIAT2PjGtSIr33s0Q5Df13Vp4k0=", + "dev": true + }, + "babel-plugin-transform-es2015-arrow-functions": { + "version": "6.22.0", + "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-arrow-functions/-/babel-plugin-transform-es2015-arrow-functions-6.22.0.tgz", + "integrity": "sha1-RSaSy3EdX3ncf4XkQM5BufJE0iE=", + "dev": true + }, + "babel-plugin-transform-es2015-block-scoped-functions": { + "version": "6.22.0", + "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-block-scoped-functions/-/babel-plugin-transform-es2015-block-scoped-functions-6.22.0.tgz", + "integrity": "sha1-u8UbSflk1wy42OC5ToICRs46YUE=", + "dev": true + }, + "babel-plugin-transform-es2015-block-scoping": { + "version": "6.24.1", + "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-block-scoping/-/babel-plugin-transform-es2015-block-scoping-6.24.1.tgz", + "integrity": "sha1-dsKV3DpHQbFmWt/TFnIV3P8ypXY=", + "dev": true + }, + "babel-plugin-transform-es2015-classes": { + "version": "6.24.1", + "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-classes/-/babel-plugin-transform-es2015-classes-6.24.1.tgz", + "integrity": "sha1-WkxYpQyclGHlZLSyo7+ryXolhNs=", + "dev": true + }, + "babel-plugin-transform-es2015-computed-properties": { + "version": "6.24.1", + "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-computed-properties/-/babel-plugin-transform-es2015-computed-properties-6.24.1.tgz", + "integrity": "sha1-b+Ko0WiV1WNPTNmZttNICjCBWbM=", + "dev": true + }, + "babel-plugin-transform-es2015-destructuring": { + "version": "6.23.0", + "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-destructuring/-/babel-plugin-transform-es2015-destructuring-6.23.0.tgz", + "integrity": "sha1-mXux8auWf2gtKwh2/jWNYOdlxW0=", + "dev": true + }, + "babel-plugin-transform-es2015-duplicate-keys": { + "version": "6.24.1", + "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-duplicate-keys/-/babel-plugin-transform-es2015-duplicate-keys-6.24.1.tgz", + "integrity": "sha1-c+s9MQypaePvnskcU3QabxV2Qj4=", + "dev": true + }, + "babel-plugin-transform-es2015-for-of": { + "version": "6.23.0", + "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-for-of/-/babel-plugin-transform-es2015-for-of-6.23.0.tgz", + "integrity": "sha1-9HyVsrYT3x0+zC/bdXNiPHUkhpE=", + "dev": true + }, + "babel-plugin-transform-es2015-function-name": { + "version": "6.24.1", + "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-function-name/-/babel-plugin-transform-es2015-function-name-6.24.1.tgz", + "integrity": "sha1-g0yJhTvDaxrw86TF26qU/Y6sqos=", + "dev": true + }, + "babel-plugin-transform-es2015-literals": { + "version": "6.22.0", + "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-literals/-/babel-plugin-transform-es2015-literals-6.22.0.tgz", + "integrity": "sha1-T1SgLWzWbPkVKAAZox0xklN3yi4=", + "dev": true + }, + "babel-plugin-transform-es2015-modules-amd": { + "version": "6.24.1", + "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-modules-amd/-/babel-plugin-transform-es2015-modules-amd-6.24.1.tgz", + "integrity": "sha1-Oz5UAXI5hC1tGcMBHEvS8AoA0VQ=", + "dev": true + }, + "babel-plugin-transform-es2015-modules-commonjs": { + "version": "6.24.1", + "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-modules-commonjs/-/babel-plugin-transform-es2015-modules-commonjs-6.24.1.tgz", + "integrity": "sha1-0+MQtA72ZKNmIiAAl8bUQCmPK/4=", + "dev": true + }, + "babel-plugin-transform-es2015-modules-systemjs": { + "version": "6.24.1", + "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-modules-systemjs/-/babel-plugin-transform-es2015-modules-systemjs-6.24.1.tgz", + "integrity": "sha1-/4mhQrkRmpBhlfXxBuzzBdlAfSM=", + "dev": true + }, + "babel-plugin-transform-es2015-modules-umd": { + "version": "6.24.1", + "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-modules-umd/-/babel-plugin-transform-es2015-modules-umd-6.24.1.tgz", + "integrity": "sha1-rJl+YoXNGO1hdq22B9YCNErThGg=", + "dev": true + }, + "babel-plugin-transform-es2015-object-super": { + "version": "6.24.1", + "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-object-super/-/babel-plugin-transform-es2015-object-super-6.24.1.tgz", + "integrity": "sha1-JM72muIcuDp/hgPa0CH1cusnj40=", + "dev": true + }, + "babel-plugin-transform-es2015-parameters": { + "version": "6.24.1", + "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-parameters/-/babel-plugin-transform-es2015-parameters-6.24.1.tgz", + "integrity": "sha1-V6w1GrScrxSpfNE7CfZv3wpiXys=", + "dev": true + }, + "babel-plugin-transform-es2015-shorthand-properties": { + "version": "6.24.1", + "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-shorthand-properties/-/babel-plugin-transform-es2015-shorthand-properties-6.24.1.tgz", + "integrity": "sha1-JPh11nIch2YbvZmkYi5R8U3jiqA=", + "dev": true + }, + "babel-plugin-transform-es2015-spread": { + "version": "6.22.0", + "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-spread/-/babel-plugin-transform-es2015-spread-6.22.0.tgz", + "integrity": "sha1-1taKmfia7cRTbIGlQujdnxdG+NE=", + "dev": true + }, + "babel-plugin-transform-es2015-sticky-regex": { + "version": "6.24.1", + "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-sticky-regex/-/babel-plugin-transform-es2015-sticky-regex-6.24.1.tgz", + "integrity": "sha1-AMHNsaynERLN8M9hJsLta0V8zbw=", + "dev": true + }, + "babel-plugin-transform-es2015-template-literals": { + "version": "6.22.0", + "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-template-literals/-/babel-plugin-transform-es2015-template-literals-6.22.0.tgz", + "integrity": "sha1-qEs0UPfp+PH2g51taH2oS7EjbY0=", + "dev": true + }, + "babel-plugin-transform-es2015-typeof-symbol": { + "version": "6.23.0", + "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-typeof-symbol/-/babel-plugin-transform-es2015-typeof-symbol-6.23.0.tgz", + "integrity": "sha1-3sCfHN3/lLUqxz1QXITfWdzOs3I=", + "dev": true + }, + "babel-plugin-transform-es2015-unicode-regex": { + "version": "6.24.1", + "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-unicode-regex/-/babel-plugin-transform-es2015-unicode-regex-6.24.1.tgz", + "integrity": "sha1-04sS9C6nMj9yk4fxinxa4frrNek=", + "dev": true + }, + "babel-plugin-transform-exponentiation-operator": { + "version": "6.24.1", + "resolved": "https://registry.npmjs.org/babel-plugin-transform-exponentiation-operator/-/babel-plugin-transform-exponentiation-operator-6.24.1.tgz", + "integrity": "sha1-KrDJx/MJj6SJB3cruBP+QejeOg4=", + "dev": true + }, + "babel-plugin-transform-object-rest-spread": { + "version": "6.23.0", + "resolved": "https://registry.npmjs.org/babel-plugin-transform-object-rest-spread/-/babel-plugin-transform-object-rest-spread-6.23.0.tgz", + "integrity": "sha1-h11ryb52HFiirj/u5dxIldjH+SE=", + "dev": true + }, + "babel-plugin-transform-regenerator": { + "version": "6.24.1", + "resolved": "https://registry.npmjs.org/babel-plugin-transform-regenerator/-/babel-plugin-transform-regenerator-6.24.1.tgz", + "integrity": "sha1-uNowWtQ8PJm0hI5P5AN7dw0jxBg=", + "dev": true + }, + "babel-plugin-transform-runtime": { + "version": "6.23.0", + "resolved": "https://registry.npmjs.org/babel-plugin-transform-runtime/-/babel-plugin-transform-runtime-6.23.0.tgz", + "integrity": "sha1-iEkNRGUC6puOfvsP4J7E2ZR5se4=", + "dev": true + }, + "babel-plugin-transform-strict-mode": { + "version": "6.24.1", + "resolved": "https://registry.npmjs.org/babel-plugin-transform-strict-mode/-/babel-plugin-transform-strict-mode-6.24.1.tgz", + "integrity": "sha1-1fr3qleKZbvlkc9e2uBKDGcCB1g=", + "dev": true + }, + "babel-preset-es2015": { + "version": "6.24.1", + "resolved": "https://registry.npmjs.org/babel-preset-es2015/-/babel-preset-es2015-6.24.1.tgz", + "integrity": "sha1-1EBQ1rwsn+6nAqrzjXJ6AhBTiTk=", + "dev": true + }, + "babel-preset-stage-2": { + "version": "6.24.1", + "resolved": "https://registry.npmjs.org/babel-preset-stage-2/-/babel-preset-stage-2-6.24.1.tgz", + "integrity": "sha1-2eKWD7PXEYfw5k7sYrwHdnIZvcE=", + "dev": true + }, + "babel-preset-stage-3": { + "version": "6.24.1", + "resolved": "https://registry.npmjs.org/babel-preset-stage-3/-/babel-preset-stage-3-6.24.1.tgz", + "integrity": "sha1-g2raCp56f6N8sTj7kyb4eTSkg5U=", + "dev": true + }, + "babel-register": { + "version": "6.24.1", + "resolved": "https://registry.npmjs.org/babel-register/-/babel-register-6.24.1.tgz", + "integrity": "sha1-fhDhOi9xBlvfrVoXh7pFvKbe118=", + "dev": true + }, + "babel-runtime": { + "version": "6.23.0", + "resolved": "https://registry.npmjs.org/babel-runtime/-/babel-runtime-6.23.0.tgz", + "integrity": "sha1-CpSJ8UTecO+zzkMArM2zKeL8VDs=", + "dev": true + }, + "babel-template": { + "version": "6.25.0", + "resolved": "https://registry.npmjs.org/babel-template/-/babel-template-6.25.0.tgz", + "integrity": "sha1-ZlJBFmt8KqTGGdceGSlpVSsQwHE=", + "dev": true + }, + "babel-traverse": { + "version": "6.25.0", + "resolved": "https://registry.npmjs.org/babel-traverse/-/babel-traverse-6.25.0.tgz", + "integrity": "sha1-IldJfi/NGbie3BPEyROB+VEklvE=", + "dev": true + }, + "babel-types": { + "version": "6.25.0", + "resolved": "https://registry.npmjs.org/babel-types/-/babel-types-6.25.0.tgz", + "integrity": "sha1-cK+ySNVmDl0Y+BHZHIMDtUE0oY4=", + "dev": true + }, + "babylon": { + "version": "6.17.3", + "resolved": "https://registry.npmjs.org/babylon/-/babylon-6.17.3.tgz", + "integrity": "sha512-mq0x3HCAGGmQyZXviOVe5TRsw37Ijy3D43jCqt/9WVf+onx2dUgW3PosnqCbScAFhRO9DGs8nxoMzU0iiosMqQ==", + "dev": true + }, + "balanced-match": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz", + "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=", + "dev": true + }, + "base64-js": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/base64-js/-/base64-js-1.2.0.tgz", + "integrity": "sha1-o5mS1yNYSBGYK+XikLtqU9hnAPE=", + "dev": true + }, + "bcrypt-pbkdf": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/bcrypt-pbkdf/-/bcrypt-pbkdf-1.0.1.tgz", + "integrity": "sha1-Y7xdy2EzG5K8Bf1SiVPDNGKgb40=", + "dev": true, + "optional": true + }, + "big.js": { + "version": "3.1.3", + "resolved": "https://registry.npmjs.org/big.js/-/big.js-3.1.3.tgz", + "integrity": "sha1-TK2iGTZS6zyp7I5VyQFWacmAaXg=", + "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=", + "dev": true + }, + "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=", + "dev": true + }, + "bluebird": { + "version": "3.5.0", + "resolved": "https://registry.npmjs.org/bluebird/-/bluebird-3.5.0.tgz", + "integrity": "sha1-eRQg1/VR7qKJdFOop3ZT+WYG1nw=", + "dev": true + }, + "boolbase": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/boolbase/-/boolbase-1.0.0.tgz", + "integrity": "sha1-aN/1++YMUes3cl6p4+0xDcwed24=", + "dev": true + }, + "boom": { + "version": "2.10.1", + "resolved": "https://registry.npmjs.org/boom/-/boom-2.10.1.tgz", + "integrity": "sha1-OciRjO/1eZ+D+UkqhI9iWt0Mdm8=", + "dev": true + }, + "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 + }, + "braces": { + "version": "1.8.5", + "resolved": "https://registry.npmjs.org/braces/-/braces-1.8.5.tgz", + "integrity": "sha1-uneWLhLf+WnWt2cR6RS3N4V79qc=", + "dev": true + }, + "browser-stdout": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/browser-stdout/-/browser-stdout-1.3.0.tgz", + "integrity": "sha1-81HTKWnTL6XXpVZxVCY9korjvR8=", + "dev": true + }, + "browserify-aes": { + "version": "0.4.0", + "resolved": "https://registry.npmjs.org/browserify-aes/-/browserify-aes-0.4.0.tgz", + "integrity": "sha1-BnFJtmjfMcS1hTPgLQHoBthgjiw=", + "dev": true + }, + "browserify-zlib": { + "version": "0.1.4", + "resolved": "https://registry.npmjs.org/browserify-zlib/-/browserify-zlib-0.1.4.tgz", + "integrity": "sha1-uzX4pRn2AOD6a4SFJByXnQFB+y0=", + "dev": true + }, + "browserslist": { + "version": "1.7.7", + "resolved": "https://registry.npmjs.org/browserslist/-/browserslist-1.7.7.tgz", + "integrity": "sha1-C9dnBCWL6CmyOYu1Dkti0aFmsLk=", + "dev": true + }, + "buffer": { + "version": "4.9.1", + "resolved": "https://registry.npmjs.org/buffer/-/buffer-4.9.1.tgz", + "integrity": "sha1-bRu2AbB6TvztlwlBMgkwJ8lbwpg=", + "dev": true + }, + "builtin-modules": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/builtin-modules/-/builtin-modules-1.1.1.tgz", + "integrity": "sha1-Jw8HbFpywC9bZaR9+Uxf46J4iS8=", + "dev": true + }, + "builtin-status-codes": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/builtin-status-codes/-/builtin-status-codes-3.0.0.tgz", + "integrity": "sha1-hZgoeOIbmOHGZCXgPQF0eI9Wnug=", + "dev": true + }, + "caller-path": { + "version": "0.1.0", + "resolved": "https://registry.npmjs.org/caller-path/-/caller-path-0.1.0.tgz", + "integrity": "sha1-lAhe9jWB7NPaqSREqP6U6CV3dR8=", + "dev": true + }, + "callsites": { + "version": "0.2.0", + "resolved": "https://registry.npmjs.org/callsites/-/callsites-0.2.0.tgz", + "integrity": "sha1-r6uWJikQp/M8GaV3WCXGnzTjUMo=", + "dev": true + }, + "camel-case": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/camel-case/-/camel-case-3.0.0.tgz", + "integrity": "sha1-yjw2iKTpzzpM2nd9xNy8cTJJz3M=", + "dev": true + }, + "camelcase": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-1.2.1.tgz", + "integrity": "sha1-m7UwTS4LVmmLLHWLCKPqqdqlijk=", + "dev": true + }, + "camelcase-keys": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/camelcase-keys/-/camelcase-keys-2.1.0.tgz", + "integrity": "sha1-MIvur/3ygRkFHvodkyITyRuPkuc=", + "dev": true, + "dependencies": { + "camelcase": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-2.1.1.tgz", + "integrity": "sha1-fB0W1nmhu+WcoCys7PsBHiAfWh8=", + "dev": true + } + } + }, + "caniuse-api": { + "version": "1.6.1", + "resolved": "https://registry.npmjs.org/caniuse-api/-/caniuse-api-1.6.1.tgz", + "integrity": "sha1-tTTnxzTE+B7F++isoq0kNUuWLGw=", + "dev": true + }, + "caniuse-db": { + "version": "1.0.30000684", + "resolved": "https://registry.npmjs.org/caniuse-db/-/caniuse-db-1.0.30000684.tgz", + "integrity": "sha1-maywEYuP0f3WAaFeDA8t/BWoFoA=", + "dev": true + }, + "caseless": { + "version": "0.12.0", + "resolved": "https://registry.npmjs.org/caseless/-/caseless-0.12.0.tgz", + "integrity": "sha1-G2gcIf+EAzyCZUMJBolCDRhxUdw=", + "dev": true + }, + "center-align": { + "version": "0.1.3", + "resolved": "https://registry.npmjs.org/center-align/-/center-align-0.1.3.tgz", + "integrity": "sha1-qg0yYptu6XIgBBHL1EYckHvCt60=", + "dev": true + }, + "chalk": { + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/chalk/-/chalk-1.1.3.tgz", + "integrity": "sha1-qBFcVeSnAv5NFQq9OHKCKn4J/Jg=", + "dev": true + }, + "change-case": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/change-case/-/change-case-3.0.1.tgz", + "integrity": "sha1-7l9a0EFa0a2egHLPSc1M+nZgpVQ=", + "dev": true + }, + "character-parser": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/character-parser/-/character-parser-1.2.1.tgz", + "integrity": "sha1-wN3kqxgnE7kZuXCVmhI+zBow/NY=", + "dev": true + }, + "chokidar": { + "version": "1.7.0", + "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-1.7.0.tgz", + "integrity": "sha1-eY5ol3gVHIB2tLNg5e3SjNortGg=", + "dev": true, + "dependencies": { + "is-extglob": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-1.0.0.tgz", + "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 + } + } + }, + "circular-json": { + "version": "0.3.1", + "resolved": "https://registry.npmjs.org/circular-json/-/circular-json-0.3.1.tgz", + "integrity": "sha1-vos2rvzN6LPKeqLWr8B6NyQsDS0=", + "dev": true + }, + "clap": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/clap/-/clap-1.2.0.tgz", + "integrity": "sha1-WckP4+E3EEdG/xlGmiemNP9oyFc=", + "dev": true + }, + "clean-css": { + "version": "4.1.4", + "resolved": "https://registry.npmjs.org/clean-css/-/clean-css-4.1.4.tgz", + "integrity": "sha1-7siBHbJ0V+AHjYypIfqBty+oK/Q=", + "dev": true + }, + "cli-cursor": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/cli-cursor/-/cli-cursor-1.0.2.tgz", + "integrity": "sha1-ZNo/fValRBLll5S9Ytw1KV6PKYc=", + "dev": true + }, + "cli-width": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/cli-width/-/cli-width-2.1.0.tgz", + "integrity": "sha1-sjTKIJsp72b8UY2bmNWEewDt8Ao=", + "dev": true + }, + "cliui": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/cliui/-/cliui-2.1.0.tgz", + "integrity": "sha1-S0dXYP+AJkx2LDoXGQMukcf+oNE=", + "dev": true, + "dependencies": { + "wordwrap": { + "version": "0.0.2", + "resolved": "https://registry.npmjs.org/wordwrap/-/wordwrap-0.0.2.tgz", + "integrity": "sha1-t5Zpu0LstAn4PVg8rVLKF+qhZD8=", + "dev": true + } + } + }, + "clone": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/clone/-/clone-1.0.2.tgz", + "integrity": "sha1-Jgt6meux7f4kdTgXX3gyQ8sZ0Uk=", + "dev": true + }, + "co": { + "version": "4.6.0", + "resolved": "https://registry.npmjs.org/co/-/co-4.6.0.tgz", + "integrity": "sha1-bqa989hTrlTMuOR7+gvz+QMfsYQ=", + "dev": true + }, + "coa": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/coa/-/coa-1.0.3.tgz", + "integrity": "sha1-G1Sl4dz3fJkEVdTe6pjFZEFtyJM=", + "dev": true + }, + "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=", + "dev": true + }, + "color": { + "version": "0.11.4", + "resolved": "https://registry.npmjs.org/color/-/color-0.11.4.tgz", + "integrity": "sha1-bXtcdPtl6EHNSHkq0e1eB7kE12Q=", + "dev": true + }, + "color-convert": { + "version": "1.9.0", + "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.0.tgz", + "integrity": "sha1-Gsz5fdc5uYO/mU1W/sj5WFNkG3o=", + "dev": true + }, + "color-name": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.2.tgz", + "integrity": "sha1-XIq3K2S9IhXWF66VWeuxSEdc+Y0=", + "dev": true + }, + "color-string": { + "version": "0.3.0", + "resolved": "https://registry.npmjs.org/color-string/-/color-string-0.3.0.tgz", + "integrity": "sha1-J9RvtnAlxcL6JZk7+/V55HhBuZE=", + "dev": true + }, + "colormin": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/colormin/-/colormin-1.1.2.tgz", + "integrity": "sha1-6i90IKcrlogaOKrlnsEkpvcpgTM=", + "dev": true + }, + "colors": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/colors/-/colors-1.1.2.tgz", + "integrity": "sha1-FopHAXVran9RoSzgyXv6KMCE7WM=", + "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=", + "dev": true + }, + "commander": { + "version": "2.9.0", + "resolved": "https://registry.npmjs.org/commander/-/commander-2.9.0.tgz", + "integrity": "sha1-nJkJQXbhIkDLItbFFGCYQA/g99Q=", + "dev": true + }, + "commondir": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/commondir/-/commondir-1.0.1.tgz", + "integrity": "sha1-3dgA2gxmEnOTzKWVDqloo6rxJTs=", + "dev": true + }, + "concat-map": { + "version": "0.0.1", + "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", + "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=", + "dev": true + }, + "concat-stream": { + "version": "1.6.0", + "resolved": "https://registry.npmjs.org/concat-stream/-/concat-stream-1.6.0.tgz", + "integrity": "sha1-CqxmL9Ur54lk1VMvaUeE5wEQrPc=", + "dev": true + }, + "config-chain": { + "version": "1.1.11", + "resolved": "https://registry.npmjs.org/config-chain/-/config-chain-1.1.11.tgz", + "integrity": "sha1-q6CXR9++TD5w52am5BWG4YWfxvI=", + "dev": true + }, + "connect-history-api-fallback": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/connect-history-api-fallback/-/connect-history-api-fallback-1.3.0.tgz", + "integrity": "sha1-5R0X+PDvDbkKZP20feMFFVbp8Wk=", + "dev": true + }, + "console-browserify": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/console-browserify/-/console-browserify-1.1.0.tgz", + "integrity": "sha1-8CQcRXMKn8YyOyBtvzjtx0HQuxA=", + "dev": true + }, + "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=", + "dev": true + }, + "consolidate": { + "version": "0.14.5", + "resolved": "https://registry.npmjs.org/consolidate/-/consolidate-0.14.5.tgz", + "integrity": "sha1-WiUEe8dvcwcmZ8jLUsmJiI9JTGM=", + "dev": true + }, + "constant-case": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/constant-case/-/constant-case-2.0.0.tgz", + "integrity": "sha1-QXV2TTidP6nI7NKRhu1gBSQ7akY=", + "dev": true + }, + "constantinople": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/constantinople/-/constantinople-3.0.2.tgz", + "integrity": "sha1-S5RdmTeQe82Y7ldRIsOBdRZUQUE=", + "dev": true, + "dependencies": { + "acorn": { + "version": "2.7.0", + "resolved": "https://registry.npmjs.org/acorn/-/acorn-2.7.0.tgz", + "integrity": "sha1-q259nYhqrKiwhbwzEreaGYQz8Oc=", + "dev": true + } + } + }, + "constants-browserify": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/constants-browserify/-/constants-browserify-1.0.0.tgz", + "integrity": "sha1-wguW2MYXdIqvHBYCF2DNJ/y4y3U=", + "dev": true + }, + "content-disposition": { + "version": "0.5.2", + "resolved": "https://registry.npmjs.org/content-disposition/-/content-disposition-0.5.2.tgz", + "integrity": "sha1-DPaLud318r55YcOoUXjLhdunjLQ=", + "dev": true + }, + "content-type": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/content-type/-/content-type-1.0.2.tgz", + "integrity": "sha1-t9ETrueo3Se9IRM8TcJSnfFyHu0=", + "dev": true + }, + "convert-source-map": { + "version": "1.5.0", + "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-1.5.0.tgz", + "integrity": "sha1-ms1whRxtXf3ZPZKC5e35SgP/RrU=", + "dev": true + }, + "cookie": { + "version": "0.3.1", + "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.3.1.tgz", + "integrity": "sha1-5+Ch+e9DtMi6klxcWpboBtFoc7s=", + "dev": true + }, + "cookie-signature": { + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/cookie-signature/-/cookie-signature-1.0.6.tgz", + "integrity": "sha1-4wOogrNCzD7oylE6eZmXNNqzriw=", + "dev": true + }, + "core-js": { + "version": "2.4.1", + "resolved": "https://registry.npmjs.org/core-js/-/core-js-2.4.1.tgz", + "integrity": "sha1-TekR5mew6ukSTjQlS1OupvxhjT4=", + "dev": true + }, + "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=", + "dev": true + }, + "cross-spawn": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-3.0.1.tgz", + "integrity": "sha1-ElYDfsufDF9549bvE14wdwGEuYI=", + "dev": true + }, + "cryptiles": { + "version": "2.0.5", + "resolved": "https://registry.npmjs.org/cryptiles/-/cryptiles-2.0.5.tgz", + "integrity": "sha1-O9/s3GCBR8HGcgL6KR59ylnqo7g=", + "dev": true + }, + "crypto-browserify": { + "version": "3.3.0", + "resolved": "https://registry.npmjs.org/crypto-browserify/-/crypto-browserify-3.3.0.tgz", + "integrity": "sha1-ufx1u0oO1h3PHNXa6W6zDJw+UGw=", + "dev": true + }, + "css": { + "version": "1.0.8", + "resolved": "https://registry.npmjs.org/css/-/css-1.0.8.tgz", + "integrity": "sha1-k4aBHKgrzMnuf7WnMrHioxfIo+c=", + "dev": true + }, + "css-color-names": { + "version": "0.0.4", + "resolved": "https://registry.npmjs.org/css-color-names/-/css-color-names-0.0.4.tgz", + "integrity": "sha1-gIrcLnnPhHOAabZGyyDsJ762KeA=", + "dev": true + }, + "css-loader": { + "version": "0.23.1", + "resolved": "https://registry.npmjs.org/css-loader/-/css-loader-0.23.1.tgz", + "integrity": "sha1-n6I/K1wJZSNZEK1ezvO4o2OQ/lA=", + "dev": true + }, + "css-parse": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/css-parse/-/css-parse-1.0.4.tgz", + "integrity": "sha1-OLBQP7+dqfVOnB29pg4UXHcRe90=", + "dev": true + }, + "css-select": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/css-select/-/css-select-1.2.0.tgz", + "integrity": "sha1-KzoRBTnFNV8c2NMUYj6HCxIeyFg=", + "dev": true, + "dependencies": { + "domutils": { + "version": "1.5.1", + "resolved": "https://registry.npmjs.org/domutils/-/domutils-1.5.1.tgz", + "integrity": "sha1-3NhIiib1Y9YQeeSMn3t+Mjc2gs8=", + "dev": true + } + } + }, + "css-selector-tokenizer": { + "version": "0.5.4", + "resolved": "https://registry.npmjs.org/css-selector-tokenizer/-/css-selector-tokenizer-0.5.4.tgz", + "integrity": "sha1-E5uv00o1/QwUKEhwSeBpnm9qLCE=", + "dev": true + }, + "css-stringify": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/css-stringify/-/css-stringify-1.0.5.tgz", + "integrity": "sha1-sNBClG2ylTu50pKQCmy19tASIDE=", + "dev": true + }, + "css-what": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/css-what/-/css-what-2.1.0.tgz", + "integrity": "sha1-lGfQMsOM+u+58teVASUwYvh/ob0=", + "dev": true + }, + "cssesc": { + "version": "0.1.0", + "resolved": "https://registry.npmjs.org/cssesc/-/cssesc-0.1.0.tgz", + "integrity": "sha1-yBSQPkViM3GgR3tAEJqq++6t27Q=", + "dev": true + }, + "cssnano": { + "version": "3.10.0", + "resolved": "https://registry.npmjs.org/cssnano/-/cssnano-3.10.0.tgz", + "integrity": "sha1-Tzj2zqK5sX+gFJDyPx3GjqZcHDg=", + "dev": true + }, + "csso": { + "version": "2.3.2", + "resolved": "https://registry.npmjs.org/csso/-/csso-2.3.2.tgz", + "integrity": "sha1-3dUsWHAz9J6Utx/FVWnyUuj/X4U=", + "dev": true + }, + "currently-unhandled": { + "version": "0.4.1", + "resolved": "https://registry.npmjs.org/currently-unhandled/-/currently-unhandled-0.4.1.tgz", + "integrity": "sha1-mI3zP+qxke95mmE2nddsF635V+o=", + "dev": true + }, + "d": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/d/-/d-1.0.0.tgz", + "integrity": "sha1-dUu1v+VUUdpppYuU1F9MWwRi1Y8=", + "dev": true + }, + "dashdash": { + "version": "1.14.1", + "resolved": "https://registry.npmjs.org/dashdash/-/dashdash-1.14.1.tgz", + "integrity": "sha1-hTz6D3y+L+1d4gMmuN1YEDX24vA=", + "dev": true, + "dependencies": { + "assert-plus": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/assert-plus/-/assert-plus-1.0.0.tgz", + "integrity": "sha1-8S4PPF13sLHN2RRpQuTpbB5N1SU=", + "dev": true + } + } + }, + "date-now": { + "version": "0.1.4", + "resolved": "https://registry.npmjs.org/date-now/-/date-now-0.1.4.tgz", + "integrity": "sha1-6vQ5/U1ISK105cx9vvIAZyueNFs=", + "dev": true + }, + "de-indent": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/de-indent/-/de-indent-1.0.2.tgz", + "integrity": "sha1-sgOOhG3DO6pXlhKNCAS0VbjB4h0=", + "dev": true + }, + "debug": { + "version": "2.6.8", + "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.8.tgz", + "integrity": "sha1-5zFTHKLt4n0YgiJCfaF4IdaP9Pw=", + "dev": true + }, + "decamelize": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/decamelize/-/decamelize-1.2.0.tgz", + "integrity": "sha1-9lNNFRSCabIDUue+4m9QH5oZEpA=", + "dev": true + }, + "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=", + "dev": true + }, + "defined": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/defined/-/defined-1.0.0.tgz", + "integrity": "sha1-yY2bzvdWdBiOEQlpFRGZ45sfppM=", + "dev": true + }, + "del": { + "version": "2.2.2", + "resolved": "https://registry.npmjs.org/del/-/del-2.2.2.tgz", + "integrity": "sha1-wSyYHQZ4RshLyvhiz/kw2Qf/0ag=", + "dev": true + }, + "delayed-stream": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz", + "integrity": "sha1-3zrhmayt+31ECqrgsp4icrJOxhk=", + "dev": true + }, + "delegates": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/delegates/-/delegates-1.0.0.tgz", + "integrity": "sha1-hMbhWbgZBP3KWaDvRM2HDTElD5o=", + "dev": true + }, + "depd": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/depd/-/depd-1.1.0.tgz", + "integrity": "sha1-4b2Cxqq2ztlluXuIsX7T5SjKGMM=", + "dev": true + }, + "destroy": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/destroy/-/destroy-1.0.4.tgz", + "integrity": "sha1-l4hXRCxEdJ5CBmE+N5RiBYJqvYA=", + "dev": true + }, + "detect-indent": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/detect-indent/-/detect-indent-4.0.0.tgz", + "integrity": "sha1-920GQ1LN9Docts5hnE7jqUdd4gg=", + "dev": true + }, + "diff": { + "version": "3.2.0", + "resolved": "https://registry.npmjs.org/diff/-/diff-3.2.0.tgz", + "integrity": "sha1-yc45Okt8vQsFinJck98pkCeGj/k=", + "dev": true + }, + "doctrine": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-2.0.0.tgz", + "integrity": "sha1-xz2NKQnSIpHhoAejlYBNqLZl/mM=", + "dev": true + }, + "dom-converter": { + "version": "0.1.4", + "resolved": "https://registry.npmjs.org/dom-converter/-/dom-converter-0.1.4.tgz", + "integrity": "sha1-pF71cnuJDJv/5tfIduexnLDhfzs=", + "dev": true, + "dependencies": { + "utila": { + "version": "0.3.3", + "resolved": "https://registry.npmjs.org/utila/-/utila-0.3.3.tgz", + "integrity": "sha1-1+jn1+MJEHCSsF+NloiCTWM6QiY=", + "dev": true + } + } + }, + "dom-serializer": { + "version": "0.1.0", + "resolved": "https://registry.npmjs.org/dom-serializer/-/dom-serializer-0.1.0.tgz", + "integrity": "sha1-BzxpdUbOB4DOI75KKOKT5AvDDII=", + "dev": true, + "dependencies": { + "domelementtype": { + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/domelementtype/-/domelementtype-1.1.3.tgz", + "integrity": "sha1-vSh3PiZCiBrsUVRJJCmcXNgiGFs=", + "dev": true + } + } + }, + "domain-browser": { + "version": "1.1.7", + "resolved": "https://registry.npmjs.org/domain-browser/-/domain-browser-1.1.7.tgz", + "integrity": "sha1-hnqksJP6oF8d4IwG9NeyH9+GmLw=", + "dev": true + }, + "domelementtype": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/domelementtype/-/domelementtype-1.3.0.tgz", + "integrity": "sha1-sXrtguirWeUt2cGbF1bg/BhyBMI=", + "dev": true + }, + "domhandler": { + "version": "2.4.1", + "resolved": "https://registry.npmjs.org/domhandler/-/domhandler-2.4.1.tgz", + "integrity": "sha1-iS5HAAqZvlW783dP/qBWHYh5wlk=", + "dev": true + }, + "domutils": { + "version": "1.6.2", + "resolved": "https://registry.npmjs.org/domutils/-/domutils-1.6.2.tgz", + "integrity": "sha1-GVjMC0yUJuntNn+xyOhUiRsPo/8=", + "dev": true + }, + "dot-case": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/dot-case/-/dot-case-2.1.1.tgz", + "integrity": "sha1-NNzzf1Co6TwrO8qLt/uRVcfaO+4=", + "dev": true + }, + "ecc-jsbn": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/ecc-jsbn/-/ecc-jsbn-0.1.1.tgz", + "integrity": "sha1-D8c6ntXw1Tw4GTOYUj735UN3dQU=", + "dev": true, + "optional": true + }, + "editorconfig": { + "version": "0.13.2", + "resolved": "https://registry.npmjs.org/editorconfig/-/editorconfig-0.13.2.tgz", + "integrity": "sha1-jleSbZ7mmrbLmZ8CfCFxRnrM6zU=", + "dev": true, + "dependencies": { + "lru-cache": { + "version": "3.2.0", + "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-3.2.0.tgz", + "integrity": "sha1-cXibO39Tmb7IVl3aOKow0qCX7+4=", + "dev": true + } + } + }, + "ee-first": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz", + "integrity": "sha1-WQxhFWsK4vTwJVcyoViyZrxWsh0=", + "dev": true + }, + "electron-to-chromium": { + "version": "1.3.14", + "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.3.14.tgz", + "integrity": "sha1-ZK8Pnv08PGrNV9cfg7Scp+6cS0M=", + "dev": true + }, + "emojis-list": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/emojis-list/-/emojis-list-2.1.0.tgz", + "integrity": "sha1-TapNnbAPmBmIDHn6RXrlsJof04k=", + "dev": true + }, + "encodeurl": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/encodeurl/-/encodeurl-1.0.1.tgz", + "integrity": "sha1-eePVhlU0aQn+bw9Fpd5oEDspTSA=", + "dev": true + }, + "enhanced-resolve": { + "version": "0.9.1", + "resolved": "https://registry.npmjs.org/enhanced-resolve/-/enhanced-resolve-0.9.1.tgz", + "integrity": "sha1-TW5omzcl+GCQknzMhs2fFjW4ni4=", + "dev": true, + "dependencies": { + "memory-fs": { + "version": "0.2.0", + "resolved": "https://registry.npmjs.org/memory-fs/-/memory-fs-0.2.0.tgz", + "integrity": "sha1-8rslNovBIeORwlIN6Slpyu4KApA=", + "dev": true + } + } + }, + "entities": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/entities/-/entities-1.1.1.tgz", + "integrity": "sha1-blwtClYhtdra7O+AuQ7ftc13cvA=", + "dev": true + }, + "errno": { + "version": "0.1.4", + "resolved": "https://registry.npmjs.org/errno/-/errno-0.1.4.tgz", + "integrity": "sha1-uJbiOp5ei6M4cfyZar02NfyaHH0=", + "dev": true + }, + "error-ex": { + "version": "1.3.1", + "resolved": "https://registry.npmjs.org/error-ex/-/error-ex-1.3.1.tgz", + "integrity": "sha1-+FWobOYa3E6GIcPNoh56dhLDqNw=", + "dev": true + }, + "es5-ext": { + "version": "0.10.23", + "resolved": "https://registry.npmjs.org/es5-ext/-/es5-ext-0.10.23.tgz", + "integrity": "sha1-dXi1G+l0IHpUh4IbVlOMIk5Oezg=", + "dev": true + }, + "es6-iterator": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/es6-iterator/-/es6-iterator-2.0.1.tgz", + "integrity": "sha1-jjGcnwRTv1ddN0lAplWSDlnKVRI=", + "dev": true + }, + "es6-map": { + "version": "0.1.5", + "resolved": "https://registry.npmjs.org/es6-map/-/es6-map-0.1.5.tgz", + "integrity": "sha1-kTbgUD3MBqMBaQ8LsU/042TpSfA=", + "dev": true + }, + "es6-set": { + "version": "0.1.5", + "resolved": "https://registry.npmjs.org/es6-set/-/es6-set-0.1.5.tgz", + "integrity": "sha1-0rPsXU2ADO2BjbU40ol02wpzzLE=", + "dev": true + }, + "es6-symbol": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/es6-symbol/-/es6-symbol-3.1.1.tgz", + "integrity": "sha1-vwDvT9q2uhtG7Le2KbTH7VcVzHc=", + "dev": true + }, + "es6-templates": { + "version": "0.2.3", + "resolved": "https://registry.npmjs.org/es6-templates/-/es6-templates-0.2.3.tgz", + "integrity": "sha1-XLmsn7He1usSOTQrgdeSu7QHjuQ=", + "dev": true + }, + "es6-weak-map": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/es6-weak-map/-/es6-weak-map-2.0.2.tgz", + "integrity": "sha1-XjqzIlH/0VOKH45f+hNXdy+S2W8=", + "dev": true + }, + "escape-html": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz", + "integrity": "sha1-Aljq5NPQwJdN4cFpGI7wBR0dGYg=", + "dev": true + }, + "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=", + "dev": true + }, + "escodegen": { + "version": "1.8.1", + "resolved": "https://registry.npmjs.org/escodegen/-/escodegen-1.8.1.tgz", + "integrity": "sha1-WltTr0aTEQvrsIZ6o0MN07cKEBg=", + "dev": true, + "dependencies": { + "estraverse": { + "version": "1.9.3", + "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-1.9.3.tgz", + "integrity": "sha1-r2fy3JIlgkFZUJJgkaQAXSnJu0Q=", + "dev": true + }, + "source-map": { + "version": "0.2.0", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.2.0.tgz", + "integrity": "sha1-2rc/vPwrqBm03gO9b26qSBZLP50=", + "dev": true, + "optional": true + } + } + }, + "escope": { + "version": "3.6.0", + "resolved": "https://registry.npmjs.org/escope/-/escope-3.6.0.tgz", + "integrity": "sha1-4Bl16BJ4GhY6ba392AOY3GTIicM=", + "dev": true + }, + "eslint": { + "version": "3.19.0", + "resolved": "https://registry.npmjs.org/eslint/-/eslint-3.19.0.tgz", + "integrity": "sha1-yPxiAcf0DdCJQbh8CFdnOGpnmsw=", + "dev": true + }, + "eslint-config-standard": { + "version": "6.2.1", + "resolved": "https://registry.npmjs.org/eslint-config-standard/-/eslint-config-standard-6.2.1.tgz", + "integrity": "sha1-06aKr8cZFjnn7kQec0hzkCY1QpI=", + "dev": true + }, + "eslint-friendly-formatter": { + "version": "2.0.7", + "resolved": "https://registry.npmjs.org/eslint-friendly-formatter/-/eslint-friendly-formatter-2.0.7.tgz", + "integrity": "sha1-ZX+VoZr0mJY2r+uxzJ3mzrvQiO4=", + "dev": true, + "dependencies": { + "minimist": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.0.tgz", + "integrity": "sha1-o1AIsg9BOD7sH7kU9M1d95omQoQ=", + "dev": true + } + } + }, + "eslint-loader": { + "version": "1.7.1", + "resolved": "https://registry.npmjs.org/eslint-loader/-/eslint-loader-1.7.1.tgz", + "integrity": "sha1-ULFY3WJy3O+5fphCVIN/gaWALOA=", + "dev": true, + "dependencies": { + "loader-utils": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/loader-utils/-/loader-utils-1.1.0.tgz", + "integrity": "sha1-yYrvSIvM7aL/teLeZG1qdUQp9c0=", + "dev": true + } + } + }, + "eslint-plugin-html": { + "version": "1.7.0", + "resolved": "https://registry.npmjs.org/eslint-plugin-html/-/eslint-plugin-html-1.7.0.tgz", + "integrity": "sha1-KlsDiE2NVq35rZhk6cA2SA+2Kck=", + "dev": true + }, + "eslint-plugin-promise": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/eslint-plugin-promise/-/eslint-plugin-promise-2.0.1.tgz", + "integrity": "sha1-qXWc76XjirEbsu9loE7wQjCaoKQ=", + "dev": true + }, + "eslint-plugin-standard": { + "version": "2.3.1", + "resolved": "https://registry.npmjs.org/eslint-plugin-standard/-/eslint-plugin-standard-2.3.1.tgz", + "integrity": "sha1-Z2W9Km2ezce98bFFrkuzDit7hvg=", + "dev": true + }, + "espree": { + "version": "3.4.3", + "resolved": "https://registry.npmjs.org/espree/-/espree-3.4.3.tgz", + "integrity": "sha1-KRC1zNSc6JPC//+qtP2LOjG4I3Q=", + "dev": true + }, + "esprima": { + "version": "2.7.3", + "resolved": "https://registry.npmjs.org/esprima/-/esprima-2.7.3.tgz", + "integrity": "sha1-luO3DVd59q1JzQMmc9HDEnZ7pYE=", + "dev": true + }, + "esquery": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.0.0.tgz", + "integrity": "sha1-z7qLV9f7qT8XKYqKAGoEzaE9gPo=", + "dev": true + }, + "esrecurse": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.1.0.tgz", + "integrity": "sha1-RxO2U2rffyrE8yfVWed1a/9kgiA=", + "dev": true, + "dependencies": { + "estraverse": { + "version": "4.1.1", + "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-4.1.1.tgz", + "integrity": "sha1-9srKcokzqFDvkGYdDheYK6RxEaI=", + "dev": true + } + } + }, + "estraverse": { + "version": "4.2.0", + "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-4.2.0.tgz", + "integrity": "sha1-De4/7TH81GlhjOc0IJn8GvoL2xM=", + "dev": true + }, + "esutils": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.2.tgz", + "integrity": "sha1-Cr9PHKpbyx96nYrMbepPqqBLrJs=", + "dev": true + }, + "etag": { + "version": "1.8.0", + "resolved": "https://registry.npmjs.org/etag/-/etag-1.8.0.tgz", + "integrity": "sha1-b2Ma7zNtbEY2K1F2QETOIWvjwFE=", + "dev": true + }, + "event-emitter": { + "version": "0.3.5", + "resolved": "https://registry.npmjs.org/event-emitter/-/event-emitter-0.3.5.tgz", + "integrity": "sha1-34xp7vFkeSPHFXuc6DhAYQsCzDk=", + "dev": true + }, + "eventemitter3": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/eventemitter3/-/eventemitter3-1.2.0.tgz", + "integrity": "sha1-HIaZHYFq0eUEdQ5zh0Ik7PO+xQg=", + "dev": true + }, + "events": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/events/-/events-1.1.1.tgz", + "integrity": "sha1-nr23Y1rQmccNzEwqH1AEKI6L2SQ=", + "dev": true + }, + "eventsource-polyfill": { + "version": "0.9.6", + "resolved": "https://registry.npmjs.org/eventsource-polyfill/-/eventsource-polyfill-0.9.6.tgz", + "integrity": "sha1-EODRh/ERsWfyj9q5GIQ859gY8Tw=", + "dev": true + }, + "exit-hook": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/exit-hook/-/exit-hook-1.1.1.tgz", + "integrity": "sha1-8FyiM7SMBdVP/wd2XfhQfpXAL/g=", + "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 + }, + "expand-range": { + "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 + }, + "express": { + "version": "4.15.3", + "resolved": "https://registry.npmjs.org/express/-/express-4.15.3.tgz", + "integrity": "sha1-urZdDwOqgMNYQIly/HAPkWlEtmI=", + "dev": true, + "dependencies": { + "debug": { + "version": "2.6.7", + "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.7.tgz", + "integrity": "sha1-krrR9tBbu2u6Isyoi80OyJTChh4=", + "dev": true + } + } + }, + "extend": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/extend/-/extend-3.0.1.tgz", + "integrity": "sha1-p1Xqe8Gt/MWjHOfnYtuq3F5jZEQ=", + "dev": true + }, + "extglob": { + "version": "0.3.2", + "resolved": "https://registry.npmjs.org/extglob/-/extglob-0.3.2.tgz", + "integrity": "sha1-Lhj/PS9JqydlzskCPwEdqo2DSaE=", + "dev": true, + "dependencies": { + "is-extglob": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-1.0.0.tgz", + "integrity": "sha1-rEaBd8SUNAWgkvyPKXYMb/xiBsA=", + "dev": true + } + } + }, + "extract-text-webpack-plugin": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/extract-text-webpack-plugin/-/extract-text-webpack-plugin-1.0.1.tgz", + "integrity": "sha1-yVvzy6rEnclvHcbgclSfu2VMzSw=", + "dev": true + }, + "extsprintf": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/extsprintf/-/extsprintf-1.0.2.tgz", + "integrity": "sha1-4QgOBljjALBilJkMxw4VAiNf1VA=", + "dev": true + }, + "fast-levenshtein": { + "version": "2.0.6", + "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", + "integrity": "sha1-PYpcZog6FqMMqGQ+hR8Zuqd5eRc=", + "dev": true + }, + "fastparse": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/fastparse/-/fastparse-1.1.1.tgz", + "integrity": "sha1-0eJkOzipTXWDtHkGDmxK/8lAcfg=", + "dev": true + }, + "figures": { + "version": "1.7.0", + "resolved": "https://registry.npmjs.org/figures/-/figures-1.7.0.tgz", + "integrity": "sha1-y+Hjr/zxzUS4DK3+0o3Hk6lwHS4=", + "dev": true + }, + "file-entry-cache": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-2.0.0.tgz", + "integrity": "sha1-w5KZDD5oR4PYOLjISkXYoEhFg2E=", + "dev": true + }, + "file-loader": { + "version": "0.9.0", + "resolved": "https://registry.npmjs.org/file-loader/-/file-loader-0.9.0.tgz", + "integrity": "sha1-HS2t3UJM5tGwfP4/eXMb7TYXq0I=", + "dev": true + }, + "filename-regex": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/filename-regex/-/filename-regex-2.0.1.tgz", + "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 + }, + "finalhandler": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/finalhandler/-/finalhandler-1.0.3.tgz", + "integrity": "sha1-70fneVDpmXgOhgIqVg4yF+DQzIk=", + "dev": true, + "dependencies": { + "debug": { + "version": "2.6.7", + "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.7.tgz", + "integrity": "sha1-krrR9tBbu2u6Isyoi80OyJTChh4=", + "dev": true + } + } + }, + "find-cache-dir": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/find-cache-dir/-/find-cache-dir-0.1.1.tgz", + "integrity": "sha1-yN765XyKUqinhPnjHFfHQumToLk=", + "dev": true + }, + "find-up": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/find-up/-/find-up-1.1.2.tgz", + "integrity": "sha1-ay6YIrGizgpgq2TWEOzK1TyyTQ8=", + "dev": true + }, + "flat-cache": { + "version": "1.2.2", + "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-1.2.2.tgz", + "integrity": "sha1-+oZxTnLCHbiGAXYezy9VXRq8a5Y=", + "dev": true + }, + "flatten": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/flatten/-/flatten-1.0.2.tgz", + "integrity": "sha1-2uRqnXj74lKSJYzB54CkHZXAN4I=", + "dev": true + }, + "for-in": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/for-in/-/for-in-1.0.2.tgz", + "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 + }, + "forever-agent": { + "version": "0.6.1", + "resolved": "https://registry.npmjs.org/forever-agent/-/forever-agent-0.6.1.tgz", + "integrity": "sha1-+8cfDEGt6zf5bFd60e1C2P2sypE=", + "dev": true + }, + "form-data": { + "version": "2.1.4", + "resolved": "https://registry.npmjs.org/form-data/-/form-data-2.1.4.tgz", + "integrity": "sha1-M8GDrPGTJ27KqYFDpp6Uv+4XUNE=", + "dev": true + }, + "forwarded": { + "version": "0.1.0", + "resolved": "https://registry.npmjs.org/forwarded/-/forwarded-0.1.0.tgz", + "integrity": "sha1-Ge+YdMSuHCl7zweP3mOgm2aoQ2M=", + "dev": true + }, + "fresh": { + "version": "0.5.0", + "resolved": "https://registry.npmjs.org/fresh/-/fresh-0.5.0.tgz", + "integrity": "sha1-9HTKXmqSRtb9jglTz6m5yAWvp44=", + "dev": true + }, + "fs.realpath": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", + "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=", + "dev": true + }, + "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, + "dependencies": { + "abbrev": { + "version": "1.1.0", + "bundled": true, + "dev": true, + "optional": true + }, + "ajv": { + "version": "4.11.8", + "bundled": true, + "dev": true, + "optional": true + }, + "ansi-regex": { + "version": "2.1.1", + "bundled": true, + "dev": true + }, + "aproba": { + "version": "1.1.1", + "bundled": true, + "dev": true, + "optional": true + }, + "are-we-there-yet": { + "version": "1.1.4", + "bundled": true, + "dev": true, + "optional": true + }, + "asn1": { + "version": "0.2.3", + "bundled": true, + "dev": true, + "optional": true + }, + "assert-plus": { + "version": "0.2.0", + "bundled": true, + "dev": true, + "optional": true + }, + "asynckit": { + "version": "0.4.0", + "bundled": true, + "dev": true, + "optional": true + }, + "aws-sign2": { + "version": "0.6.0", + "bundled": true, + "dev": true, + "optional": true + }, + "aws4": { + "version": "1.6.0", + "bundled": true, + "dev": true, + "optional": true + }, + "balanced-match": { + "version": "0.4.2", + "bundled": true, + "dev": true + }, + "bcrypt-pbkdf": { + "version": "1.0.1", + "bundled": true, + "dev": true, + "optional": true + }, + "block-stream": { + "version": "0.0.9", + "bundled": true, + "dev": true + }, + "boom": { + "version": "2.10.1", + "bundled": true, + "dev": true + }, + "brace-expansion": { + "version": "1.1.7", + "bundled": true, + "dev": true + }, + "buffer-shims": { + "version": "1.0.0", + "bundled": true, + "dev": true + }, + "caseless": { + "version": "0.12.0", + "bundled": true, + "dev": true, + "optional": true + }, + "co": { + "version": "4.6.0", + "bundled": true, + "dev": true, + "optional": true + }, + "code-point-at": { + "version": "1.1.0", + "bundled": true, + "dev": true + }, + "combined-stream": { + "version": "1.0.5", + "bundled": true, + "dev": true + }, + "concat-map": { + "version": "0.0.1", + "bundled": true, + "dev": true + }, + "console-control-strings": { + "version": "1.1.0", + "bundled": true, + "dev": true + }, + "core-util-is": { + "version": "1.0.2", + "bundled": true, + "dev": true + }, + "cryptiles": { + "version": "2.0.5", + "bundled": true, + "dev": true, + "optional": true + }, + "dashdash": { + "version": "1.14.1", + "bundled": true, + "dev": true, + "optional": true, + "dependencies": { + "assert-plus": { + "version": "1.0.0", + "bundled": true, + "dev": true, + "optional": true + } + } + }, + "debug": { + "version": "2.6.8", + "bundled": true, + "dev": true, + "optional": true + }, + "deep-extend": { + "version": "0.4.2", + "bundled": true, + "dev": true, + "optional": true + }, + "delayed-stream": { + "version": "1.0.0", + "bundled": true, + "dev": true + }, + "delegates": { + "version": "1.0.0", + "bundled": true, + "dev": true, + "optional": true + }, + "ecc-jsbn": { + "version": "0.1.1", + "bundled": true, + "dev": true, + "optional": true + }, + "extend": { + "version": "3.0.1", + "bundled": true, + "dev": true, + "optional": true + }, + "extsprintf": { + "version": "1.0.2", + "bundled": true, + "dev": true + }, + "forever-agent": { + "version": "0.6.1", + "bundled": true, + "dev": true, + "optional": true + }, + "form-data": { + "version": "2.1.4", + "bundled": true, + "dev": true, + "optional": true + }, + "fs.realpath": { + "version": "1.0.0", + "bundled": true, + "dev": true + }, + "fstream": { + "version": "1.0.11", + "bundled": true, + "dev": true + }, + "fstream-ignore": { + "version": "1.0.5", + "bundled": true, + "dev": true, + "optional": true + }, + "gauge": { + "version": "2.7.4", + "bundled": true, + "dev": true, + "optional": true + }, + "getpass": { + "version": "0.1.7", + "bundled": true, + "dev": true, + "optional": true, + "dependencies": { + "assert-plus": { + "version": "1.0.0", + "bundled": true, + "dev": true, + "optional": true + } + } + }, + "glob": { + "version": "7.1.2", + "bundled": true, + "dev": true + }, + "graceful-fs": { + "version": "4.1.11", + "bundled": true, + "dev": true + }, + "har-schema": { + "version": "1.0.5", + "bundled": true, + "dev": true, + "optional": true + }, + "har-validator": { + "version": "4.2.1", + "bundled": true, + "dev": true, + "optional": true + }, + "has-unicode": { + "version": "2.0.1", + "bundled": true, + "dev": true, + "optional": true + }, + "hawk": { + "version": "3.1.3", + "bundled": true, + "dev": true, + "optional": true + }, + "hoek": { + "version": "2.16.3", + "bundled": true, + "dev": true + }, + "http-signature": { + "version": "1.1.1", + "bundled": true, + "dev": true, + "optional": true + }, + "inflight": { + "version": "1.0.6", + "bundled": true, + "dev": true + }, + "inherits": { + "version": "2.0.3", + "bundled": true, + "dev": true + }, + "ini": { + "version": "1.3.4", + "bundled": true, + "dev": true, + "optional": true + }, + "is-fullwidth-code-point": { + "version": "1.0.0", + "bundled": true, + "dev": true + }, + "is-typedarray": { + "version": "1.0.0", + "bundled": true, + "dev": true, + "optional": true + }, + "isarray": { + "version": "1.0.0", + "bundled": true, + "dev": true + }, + "isstream": { + "version": "0.1.2", + "bundled": true, + "dev": true, + "optional": true + }, + "jodid25519": { + "version": "1.0.2", + "bundled": true, + "dev": true, + "optional": true + }, + "jsbn": { + "version": "0.1.1", + "bundled": true, + "dev": true, + "optional": true + }, + "json-schema": { + "version": "0.2.3", + "bundled": true, + "dev": true, + "optional": true + }, + "json-stable-stringify": { + "version": "1.0.1", + "bundled": true, + "dev": true, + "optional": true + }, + "json-stringify-safe": { + "version": "5.0.1", + "bundled": true, + "dev": true, + "optional": true + }, + "jsonify": { + "version": "0.0.0", + "bundled": true, + "dev": true, + "optional": true + }, + "jsprim": { + "version": "1.4.0", + "bundled": true, + "dev": true, + "optional": true, + "dependencies": { + "assert-plus": { + "version": "1.0.0", + "bundled": true, + "dev": true, + "optional": true + } + } + }, + "mime-db": { + "version": "1.27.0", + "bundled": true, + "dev": true + }, + "mime-types": { + "version": "2.1.15", + "bundled": true, + "dev": true + }, + "minimatch": { + "version": "3.0.4", + "bundled": true, + "dev": true + }, + "minimist": { + "version": "0.0.8", + "bundled": true, + "dev": true + }, + "mkdirp": { + "version": "0.5.1", + "bundled": true, + "dev": true + }, + "ms": { + "version": "2.0.0", + "bundled": true, + "dev": true, + "optional": true + }, + "node-pre-gyp": { + "version": "0.6.36", + "bundled": true, + "dev": true, + "optional": true + }, + "nopt": { + "version": "4.0.1", + "bundled": true, + "dev": true, + "optional": true + }, + "npmlog": { + "version": "4.1.0", + "bundled": true, + "dev": true, + "optional": true + }, + "number-is-nan": { + "version": "1.0.1", + "bundled": true, + "dev": true + }, + "oauth-sign": { + "version": "0.8.2", + "bundled": true, + "dev": true, + "optional": true + }, + "object-assign": { + "version": "4.1.1", + "bundled": true, + "dev": true, + "optional": true + }, + "once": { + "version": "1.4.0", + "bundled": true, + "dev": true + }, + "os-homedir": { + "version": "1.0.2", + "bundled": true, + "dev": true, + "optional": true + }, + "os-tmpdir": { + "version": "1.0.2", + "bundled": true, + "dev": true, + "optional": true + }, + "osenv": { + "version": "0.1.4", + "bundled": true, + "dev": true, + "optional": true + }, + "path-is-absolute": { + "version": "1.0.1", + "bundled": true, + "dev": true + }, + "performance-now": { + "version": "0.2.0", + "bundled": true, + "dev": true, + "optional": true + }, + "process-nextick-args": { + "version": "1.0.7", + "bundled": true, + "dev": true + }, + "punycode": { + "version": "1.4.1", + "bundled": true, + "dev": true, + "optional": true + }, + "qs": { + "version": "6.4.0", + "bundled": true, + "dev": true, + "optional": true + }, + "rc": { + "version": "1.2.1", + "bundled": true, + "dev": true, + "optional": true, + "dependencies": { + "minimist": { + "version": "1.2.0", + "bundled": true, + "dev": true, + "optional": true + } + } + }, + "readable-stream": { + "version": "2.2.9", + "bundled": true, + "dev": true + }, + "request": { + "version": "2.81.0", + "bundled": true, + "dev": true, + "optional": true + }, + "rimraf": { + "version": "2.6.1", + "bundled": true, + "dev": true + }, + "safe-buffer": { + "version": "5.0.1", + "bundled": true, + "dev": true + }, + "semver": { + "version": "5.3.0", + "bundled": true, + "dev": true, + "optional": true + }, + "set-blocking": { + "version": "2.0.0", + "bundled": true, + "dev": true, + "optional": true + }, + "signal-exit": { + "version": "3.0.2", + "bundled": true, + "dev": true, + "optional": true + }, + "sntp": { + "version": "1.0.9", + "bundled": true, + "dev": true, + "optional": true + }, + "sshpk": { + "version": "1.13.0", + "bundled": true, + "dev": true, + "optional": true, + "dependencies": { + "assert-plus": { + "version": "1.0.0", + "bundled": true, + "dev": true, + "optional": true + } + } + }, + "string_decoder": { + "version": "1.0.1", + "bundled": true, + "dev": true + }, + "string-width": { + "version": "1.0.2", + "bundled": true, + "dev": true + }, + "stringstream": { + "version": "0.0.5", + "bundled": true, + "dev": true, + "optional": true + }, + "strip-ansi": { + "version": "3.0.1", + "bundled": true, + "dev": true + }, + "strip-json-comments": { + "version": "2.0.1", + "bundled": true, + "dev": true, + "optional": true + }, + "tar": { + "version": "2.2.1", + "bundled": true, + "dev": true + }, + "tar-pack": { + "version": "3.4.0", + "bundled": true, + "dev": true, + "optional": true + }, + "tough-cookie": { + "version": "2.3.2", + "bundled": true, + "dev": true, + "optional": true + }, + "tunnel-agent": { + "version": "0.6.0", + "bundled": true, + "dev": true, + "optional": true + }, + "tweetnacl": { + "version": "0.14.5", + "bundled": true, + "dev": true, + "optional": true + }, + "uid-number": { + "version": "0.0.6", + "bundled": true, + "dev": true, + "optional": true + }, + "util-deprecate": { + "version": "1.0.2", + "bundled": true, + "dev": true + }, + "uuid": { + "version": "3.0.1", + "bundled": true, + "dev": true, + "optional": true + }, + "verror": { + "version": "1.3.6", + "bundled": true, + "dev": true, + "optional": true + }, + "wide-align": { + "version": "1.1.2", + "bundled": true, + "dev": true, + "optional": true + }, + "wrappy": { + "version": "1.0.2", + "bundled": true, + "dev": true + } + } + }, + "fstream": { + "version": "1.0.11", + "resolved": "https://registry.npmjs.org/fstream/-/fstream-1.0.11.tgz", + "integrity": "sha1-XB+x8RdHcRTwYyoOtLcbPLD9MXE=", + "dev": true + }, + "function-bind": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.0.tgz", + "integrity": "sha1-FhdnFMgBeY5Ojyz391KUZ7tKV3E=", + "dev": true + }, + "gauge": { + "version": "2.7.4", + "resolved": "https://registry.npmjs.org/gauge/-/gauge-2.7.4.tgz", + "integrity": "sha1-LANAXHU4w51+s3sxcCLjJfsBi/c=", + "dev": true + }, + "gaze": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/gaze/-/gaze-1.1.2.tgz", + "integrity": "sha1-hHIkZ3rbiHDWeSV+0ziP22HkAQU=", + "dev": true + }, + "generate-function": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/generate-function/-/generate-function-2.0.0.tgz", + "integrity": "sha1-aFj+fAlpt9TpCTM3ZHrHn2DfvnQ=", + "dev": true + }, + "generate-object-property": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/generate-object-property/-/generate-object-property-1.2.0.tgz", + "integrity": "sha1-nA4cQDCM6AT0eDYYuTf6iPmdUNA=", + "dev": true + }, + "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=", + "dev": true + }, + "get-stdin": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/get-stdin/-/get-stdin-4.0.1.tgz", + "integrity": "sha1-uWjGsKBDhDJJAui/Gl3zJXmkUP4=", + "dev": true + }, + "getpass": { + "version": "0.1.7", + "resolved": "https://registry.npmjs.org/getpass/-/getpass-0.1.7.tgz", + "integrity": "sha1-Xv+OPmhNVprkyysSgmBOi6YhSfo=", + "dev": true, + "dependencies": { + "assert-plus": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/assert-plus/-/assert-plus-1.0.0.tgz", + "integrity": "sha1-8S4PPF13sLHN2RRpQuTpbB5N1SU=", + "dev": true + } + } + }, + "glob": { + "version": "7.1.2", + "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.2.tgz", + "integrity": "sha512-MJTUg1kjuLeQCJ+ccE4Vpa6kKVXkPYJ2mOCQyUuKLcLQsdrMCpBPUi8qVE6+YuaJkozeA9NusTAw3hLr8Xe5EQ==", + "dev": true + }, + "glob-base": { + "version": "0.3.0", + "resolved": "https://registry.npmjs.org/glob-base/-/glob-base-0.3.0.tgz", + "integrity": "sha1-27Fk9iIbHAscz4Kuoyi0l98Oo8Q=", + "dev": true, + "dependencies": { + "is-extglob": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-1.0.0.tgz", + "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 + } + } + }, + "glob-parent": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-2.0.0.tgz", + "integrity": "sha1-gTg9ctsFT8zPUzbaqQLxgvbtuyg=", + "dev": true, + "dependencies": { + "is-extglob": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-1.0.0.tgz", + "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 + } + } + }, + "globals": { + "version": "9.18.0", + "resolved": "https://registry.npmjs.org/globals/-/globals-9.18.0.tgz", + "integrity": "sha512-S0nG3CLEQiY/ILxqtztTWH/3iRRdyBLw6KMDxnKMchrtbj2OFmehVh0WUCfW3DUrIgx/qFrJPICrq4Z4sTR9UQ==", + "dev": true + }, + "globby": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/globby/-/globby-5.0.0.tgz", + "integrity": "sha1-69hGZ8oNuzMLmbz8aOrCvFQ3Dg0=", + "dev": true + }, + "globule": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/globule/-/globule-1.2.0.tgz", + "integrity": "sha1-HcScaCLdnoovoAuiopUAboZkvQk=", + "dev": true + }, + "graceful-fs": { + "version": "4.1.11", + "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.1.11.tgz", + "integrity": "sha1-Dovf5NHduIVNZOBOp8AOKgJuVlg=", + "dev": true + }, + "graceful-readlink": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/graceful-readlink/-/graceful-readlink-1.0.1.tgz", + "integrity": "sha1-TK+tdrxi8C+gObL5Tpo906ORpyU=", + "dev": true + }, + "growl": { + "version": "1.9.2", + "resolved": "https://registry.npmjs.org/growl/-/growl-1.9.2.tgz", + "integrity": "sha1-Dqd0NxXbjY3ixe3hd14bRayFwC8=", + "dev": true + }, + "handlebars": { + "version": "4.0.10", + "resolved": "https://registry.npmjs.org/handlebars/-/handlebars-4.0.10.tgz", + "integrity": "sha1-PTDHGLCaPZbyPqTMH0A8TTup/08=", + "dev": true, + "dependencies": { + "source-map": { + "version": "0.4.4", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.4.4.tgz", + "integrity": "sha1-66T12pwNyZneaAMti092FzZSA2s=", + "dev": true + }, + "uglify-js": { + "version": "2.8.29", + "resolved": "https://registry.npmjs.org/uglify-js/-/uglify-js-2.8.29.tgz", + "integrity": "sha1-KcVzMUgFe7Th913zW3qcty5qWd0=", + "dev": true, + "optional": true, + "dependencies": { + "source-map": { + "version": "0.5.6", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.5.6.tgz", + "integrity": "sha1-dc449SvwczxafwwRjYEzSiu19BI=", + "dev": true, + "optional": true + } + } + } + } + }, + "har-schema": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/har-schema/-/har-schema-1.0.5.tgz", + "integrity": "sha1-0mMTX0MwfALGAq/I/pWXDAFRNp4=", + "dev": true + }, + "har-validator": { + "version": "4.2.1", + "resolved": "https://registry.npmjs.org/har-validator/-/har-validator-4.2.1.tgz", + "integrity": "sha1-M0gdDxu/9gDdID11gSpqX7oALio=", + "dev": true + }, + "has": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/has/-/has-1.0.1.tgz", + "integrity": "sha1-hGFzP1OLCDfJNh45qauelwTcLyg=", + "dev": true + }, + "has-ansi": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/has-ansi/-/has-ansi-2.0.0.tgz", + "integrity": "sha1-NPUEnOHs3ysGSa8+8k5F7TVBbZE=", + "dev": true + }, + "has-color": { + "version": "0.1.7", + "resolved": "https://registry.npmjs.org/has-color/-/has-color-0.1.7.tgz", + "integrity": "sha1-ZxRKUmDDT8PMpnfQQdr1L+e3iy8=", + "dev": true + }, + "has-flag": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-1.0.0.tgz", + "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=", + "dev": true + }, + "hash-sum": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/hash-sum/-/hash-sum-1.0.2.tgz", + "integrity": "sha1-M7QHd3VMZDJXPBIMw4CLvRDUfwQ=", + "dev": true + }, + "hawk": { + "version": "3.1.3", + "resolved": "https://registry.npmjs.org/hawk/-/hawk-3.1.3.tgz", + "integrity": "sha1-B4REvXwWQLD+VA0sm3PVlnjo4cQ=", + "dev": true + }, + "he": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/he/-/he-1.1.1.tgz", + "integrity": "sha1-k0EP0hsAlzUVH4howvJx80J+I/0=", + "dev": true + }, + "header-case": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/header-case/-/header-case-1.0.1.tgz", + "integrity": "sha1-lTWXMZfBRLCWE81l0xfvGZY70C0=", + "dev": true + }, + "hoek": { + "version": "2.16.3", + "resolved": "https://registry.npmjs.org/hoek/-/hoek-2.16.3.tgz", + "integrity": "sha1-ILt0A9POo5jpHcRxCo/xuCdKJe0=", + "dev": true + }, + "home-or-tmp": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/home-or-tmp/-/home-or-tmp-2.0.0.tgz", + "integrity": "sha1-42w/LSyufXRqhX440Y1fMqeILbg=", + "dev": true + }, + "hosted-git-info": { + "version": "2.4.2", + "resolved": "https://registry.npmjs.org/hosted-git-info/-/hosted-git-info-2.4.2.tgz", + "integrity": "sha1-AHa59GonBQbduq6lZJaJdGBhKmc=", + "dev": true + }, + "html-comment-regex": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/html-comment-regex/-/html-comment-regex-1.1.1.tgz", + "integrity": "sha1-ZouTd26q5V696POtRkswekljYl4=", + "dev": true + }, + "html-entities": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/html-entities/-/html-entities-1.2.1.tgz", + "integrity": "sha1-DfKTUfByEWNRXfueVUPl9u7VFi8=", + "dev": true + }, + "html-minifier": { + "version": "3.5.2", + "resolved": "https://registry.npmjs.org/html-minifier/-/html-minifier-3.5.2.tgz", + "integrity": "sha1-1zvD/0SJQkCIGM5gm/P7DqfvTrc=", + "dev": true + }, + "html-webpack-plugin": { + "version": "2.28.0", + "resolved": "https://registry.npmjs.org/html-webpack-plugin/-/html-webpack-plugin-2.28.0.tgz", + "integrity": "sha1-LnhjtX5f1I/iYzA+L/yTTDBk0Ak=", + "dev": true + }, + "htmlparser2": { + "version": "3.9.2", + "resolved": "https://registry.npmjs.org/htmlparser2/-/htmlparser2-3.9.2.tgz", + "integrity": "sha1-G9+HrMoPP55T+k/M6w9LTLsAszg=", + "dev": true + }, + "http-errors": { + "version": "1.6.1", + "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-1.6.1.tgz", + "integrity": "sha1-X4uO2YrKVFZWv1cplzh/kEpyIlc=", + "dev": true + }, + "http-proxy": { + "version": "1.16.2", + "resolved": "https://registry.npmjs.org/http-proxy/-/http-proxy-1.16.2.tgz", + "integrity": "sha1-Bt/ykpUr9k2+hHH6nfcwZtTzd0I=", + "dev": true + }, + "http-proxy-middleware": { + "version": "0.17.4", + "resolved": "https://registry.npmjs.org/http-proxy-middleware/-/http-proxy-middleware-0.17.4.tgz", + "integrity": "sha1-ZC6ISIUdZvCdTxJJEoRtuutBuDM=", + "dev": true + }, + "http-signature": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/http-signature/-/http-signature-1.1.1.tgz", + "integrity": "sha1-33LiZwZs0Kxn+3at+OE0qPvPkb8=", + "dev": true + }, + "https-browserify": { + "version": "0.0.1", + "resolved": "https://registry.npmjs.org/https-browserify/-/https-browserify-0.0.1.tgz", + "integrity": "sha1-P5E2XKvmC3ftDruiS0VOPgnZWoI=", + "dev": true + }, + "icss-replace-symbols": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/icss-replace-symbols/-/icss-replace-symbols-1.1.0.tgz", + "integrity": "sha1-Bupvg2ead0njhs/h/oEq5dsiPe0=", + "dev": true + }, + "ieee754": { + "version": "1.1.8", + "resolved": "https://registry.npmjs.org/ieee754/-/ieee754-1.1.8.tgz", + "integrity": "sha1-vjPUCsEO8ZJnAfbwii2G+/0a0+Q=", + "dev": true + }, + "ignore": { + "version": "3.3.3", + "resolved": "https://registry.npmjs.org/ignore/-/ignore-3.3.3.tgz", + "integrity": "sha1-QyNS5XrM2HqzEQ6C0/6g5HgSFW0=", + "dev": true + }, + "imurmurhash": { + "version": "0.1.4", + "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", + "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=", + "dev": true + }, + "in-publish": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/in-publish/-/in-publish-2.0.0.tgz", + "integrity": "sha1-4g/146KvwmkDILbcVSaCqcf631E=", + "dev": true + }, + "indent-string": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/indent-string/-/indent-string-2.1.0.tgz", + "integrity": "sha1-ji1INIdCEhtKghi3oTfppSBJ3IA=", + "dev": true + }, + "indexes-of": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/indexes-of/-/indexes-of-1.0.1.tgz", + "integrity": "sha1-8w9xbI4r00bHtn0985FVZqfAVgc=", + "dev": true + }, + "indexof": { + "version": "0.0.1", + "resolved": "https://registry.npmjs.org/indexof/-/indexof-0.0.1.tgz", + "integrity": "sha1-gtwzbSMrkGIXnQWrMpOmYFn9Q10=", + "dev": true + }, + "inflight": { + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", + "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", + "dev": true + }, + "inherits": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz", + "integrity": "sha1-Yzwsg+PaQqUC9SRmAiSA9CCCYd4=", + "dev": true + }, + "ini": { + "version": "1.3.4", + "resolved": "https://registry.npmjs.org/ini/-/ini-1.3.4.tgz", + "integrity": "sha1-BTfLedr1m1mhpRff9wbIbsA5Fi4=", + "dev": true + }, + "inject-loader": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/inject-loader/-/inject-loader-2.0.1.tgz", + "integrity": "sha1-GntF1gqBYQRZrHYHnDziplTQ38c=", + "dev": true + }, + "inquirer": { + "version": "0.12.0", + "resolved": "https://registry.npmjs.org/inquirer/-/inquirer-0.12.0.tgz", + "integrity": "sha1-HvK/1jUE3wvHV4X/+MLEHfEvB34=", + "dev": true + }, + "interpret": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/interpret/-/interpret-1.0.3.tgz", + "integrity": "sha1-y8NcYu7uc/Gat7EKgBURQBr8D5A=", + "dev": true + }, + "invariant": { + "version": "2.2.2", + "resolved": "https://registry.npmjs.org/invariant/-/invariant-2.2.2.tgz", + "integrity": "sha1-nh9WrArNtr8wMwbzOL47IErmA2A=", + "dev": true + }, + "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=", + "dev": true + }, + "ipaddr.js": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-1.3.0.tgz", + "integrity": "sha1-HgOlL9rYOou7KyXL9JmLTP/NPew=", + "dev": true + }, + "is-absolute-url": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/is-absolute-url/-/is-absolute-url-2.1.0.tgz", + "integrity": "sha1-UFMN+4T8yap9vnhS6Do3uTufKqY=", + "dev": true + }, + "is-arrayish": { + "version": "0.2.1", + "resolved": "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.2.1.tgz", + "integrity": "sha1-d8mYQFJ6qOyxqLppe4BkWnqSap0=", + "dev": true + }, + "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 + }, + "is-buffer": { + "version": "1.1.5", + "resolved": "https://registry.npmjs.org/is-buffer/-/is-buffer-1.1.5.tgz", + "integrity": "sha1-Hzsm72E7IUuIy8ojzGwB2Hlh7sw=", + "dev": true + }, + "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=", + "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=", + "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 + }, + "is-extendable": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/is-extendable/-/is-extendable-0.1.1.tgz", + "integrity": "sha1-YrEQ4omkcUGOPsNqYX1HLjAd/Ik=", + "dev": true + }, + "is-extglob": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", + "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=", + "dev": true + }, + "is-finite": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/is-finite/-/is-finite-1.0.2.tgz", + "integrity": "sha1-zGZ3aVYCvlUO8R6LSqYwU0K20Ko=", + "dev": true + }, + "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=", + "dev": true + }, + "is-glob": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-3.1.0.tgz", + "integrity": "sha1-e6WuJCF4BKxwcHuWkiVnSGzD6Eo=", + "dev": true + }, + "is-lower-case": { + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/is-lower-case/-/is-lower-case-1.1.3.tgz", + "integrity": "sha1-fhR75HaNxGbbO/shzGCzHmrWk5M=", + "dev": true + }, + "is-my-json-valid": { + "version": "2.16.0", + "resolved": "https://registry.npmjs.org/is-my-json-valid/-/is-my-json-valid-2.16.0.tgz", + "integrity": "sha1-8Hndm/2uZe4gOKrorLyGqxCeNpM=", + "dev": true + }, + "is-number": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/is-number/-/is-number-2.1.0.tgz", + "integrity": "sha1-Afy7s5NGOlSPL0ZszhbezknbkI8=", + "dev": true + }, + "is-path-cwd": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-path-cwd/-/is-path-cwd-1.0.0.tgz", + "integrity": "sha1-0iXsIxMuie3Tj9p2dHLmLmXxEG0=", + "dev": true + }, + "is-path-in-cwd": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-path-in-cwd/-/is-path-in-cwd-1.0.0.tgz", + "integrity": "sha1-ZHdYK4IU1gI0YJRWcAO+ip6sBNw=", + "dev": true + }, + "is-path-inside": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-path-inside/-/is-path-inside-1.0.0.tgz", + "integrity": "sha1-/AbloWg/vaE95mev9xe7wQpI838=", + "dev": true + }, + "is-plain-obj": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/is-plain-obj/-/is-plain-obj-1.1.0.tgz", + "integrity": "sha1-caUMhCnfync8kqOQpKA7OfzVHT4=", + "dev": true + }, + "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=", + "dev": true + }, + "is-primitive": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/is-primitive/-/is-primitive-2.0.0.tgz", + "integrity": "sha1-IHurkWOEmcB7Kt8kCkGochADRXU=", + "dev": true + }, + "is-promise": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/is-promise/-/is-promise-2.1.0.tgz", + "integrity": "sha1-eaKp7OfwlugPNtKy87wWwf9L8/o=", + "dev": true + }, + "is-property": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/is-property/-/is-property-1.0.2.tgz", + "integrity": "sha1-V/4cTkhHTt1lsJkR8msc1Ald2oQ=", + "dev": true + }, + "is-resolvable": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-resolvable/-/is-resolvable-1.0.0.tgz", + "integrity": "sha1-jfV8YeouPFAUCNEA+wE8+NbgzGI=", + "dev": true + }, + "is-svg": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/is-svg/-/is-svg-2.1.0.tgz", + "integrity": "sha1-z2EJDaDZ77yrhyLeum8DIgjbsOk=", + "dev": true + }, + "is-typedarray": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-typedarray/-/is-typedarray-1.0.0.tgz", + "integrity": "sha1-5HnICFjfDBsR3dppQPlgEfzaSpo=", + "dev": true + }, + "is-upper-case": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/is-upper-case/-/is-upper-case-1.1.2.tgz", + "integrity": "sha1-jQsfp+eTOh5YSDYA7H2WYcuvdW8=", + "dev": true + }, + "is-utf8": { + "version": "0.2.1", + "resolved": "https://registry.npmjs.org/is-utf8/-/is-utf8-0.2.1.tgz", + "integrity": "sha1-Sw2hRCEE0bM2NA6AeX6GXPOffXI=", + "dev": true + }, + "isarray": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", + "integrity": "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE=", + "dev": true + }, + "isexe": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", + "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=", + "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 + }, + "isparta": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/isparta/-/isparta-4.0.0.tgz", + "integrity": "sha1-HekZlvSAsi3LGsqFECVbrhV0RG4=", + "dev": true + }, + "isparta-loader": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/isparta-loader/-/isparta-loader-2.0.0.tgz", + "integrity": "sha1-RCX0lsk/dlu8603ZOFdtowdWbtE=", + "dev": true + }, + "isstream": { + "version": "0.1.2", + "resolved": "https://registry.npmjs.org/isstream/-/isstream-0.1.2.tgz", + "integrity": "sha1-R+Y/evVa+m+S4VAOaQ64uFKcCZo=", + "dev": true + }, + "istanbul": { + "version": "0.4.5", + "resolved": "https://registry.npmjs.org/istanbul/-/istanbul-0.4.5.tgz", + "integrity": "sha1-ZcfXPUxNqE1POsMQuRj7C4Azczs=", + "dev": true, + "dependencies": { + "glob": { + "version": "5.0.15", + "resolved": "https://registry.npmjs.org/glob/-/glob-5.0.15.tgz", + "integrity": "sha1-G8k2ueAvSmA/zCIuz3Yz0wuLk7E=", + "dev": true + }, + "resolve": { + "version": "1.1.7", + "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.1.7.tgz", + "integrity": "sha1-IDEU2CrSxe2ejgQRs5ModeiJ6Xs=", + "dev": true + }, + "supports-color": { + "version": "3.2.3", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-3.2.3.tgz", + "integrity": "sha1-ZawFBLOVQXHYpklGsq48u4pfVPY=", + "dev": true + } + } + }, + "jade": { + "version": "1.11.0", + "resolved": "https://registry.npmjs.org/jade/-/jade-1.11.0.tgz", + "integrity": "sha1-nIDlOMEtP7lcjZu5VZ+gzAQEBf0=", + "dev": true, + "dependencies": { + "clean-css": { + "version": "3.4.27", + "resolved": "https://registry.npmjs.org/clean-css/-/clean-css-3.4.27.tgz", + "integrity": "sha1-re91sxwWD/pdcvTeZ5ZuJmDBolU=", + "dev": true, + "dependencies": { + "commander": { + "version": "2.8.1", + "resolved": "https://registry.npmjs.org/commander/-/commander-2.8.1.tgz", + "integrity": "sha1-Br42f+v9oMMwqh4qBy09yXYkJdQ=", + "dev": true + } + } + }, + "commander": { + "version": "2.6.0", + "resolved": "https://registry.npmjs.org/commander/-/commander-2.6.0.tgz", + "integrity": "sha1-nfflL7Kgyw+4kFjugMMQQiXzfh0=", + "dev": true + }, + "source-map": { + "version": "0.4.4", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.4.4.tgz", + "integrity": "sha1-66T12pwNyZneaAMti092FzZSA2s=", + "dev": true + }, + "uglify-js": { + "version": "2.8.29", + "resolved": "https://registry.npmjs.org/uglify-js/-/uglify-js-2.8.29.tgz", + "integrity": "sha1-KcVzMUgFe7Th913zW3qcty5qWd0=", + "dev": true, + "dependencies": { + "source-map": { + "version": "0.5.6", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.5.6.tgz", + "integrity": "sha1-dc449SvwczxafwwRjYEzSiu19BI=", + "dev": true + } + } + } + } + }, + "js-base64": { + "version": "2.1.9", + "resolved": "https://registry.npmjs.org/js-base64/-/js-base64-2.1.9.tgz", + "integrity": "sha1-8OgK4DmkvWVLXygfyT8EqRSn/M4=", + "dev": true + }, + "js-beautify": { + "version": "1.6.14", + "resolved": "https://registry.npmjs.org/js-beautify/-/js-beautify-1.6.14.tgz", + "integrity": "sha1-07j3Mi0CuSd9WL0jgmTDJ+WARM0=", + "dev": true + }, + "js-tokens": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-3.0.1.tgz", + "integrity": "sha1-COnxMkhKLEWjCQfp3E1VZ7fxFNc=", + "dev": true + }, + "js-yaml": { + "version": "3.7.0", + "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.7.0.tgz", + "integrity": "sha1-XJZ93YN6m/3KXy3oQlOr6KHAO4A=", + "dev": true + }, + "jsbn": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/jsbn/-/jsbn-0.1.1.tgz", + "integrity": "sha1-peZUwuWi3rXyAdls77yoDA7y9RM=", + "dev": true, + "optional": true + }, + "jsesc": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-1.3.0.tgz", + "integrity": "sha1-RsP+yMGJKxKwgz25vHYiF226s0s=", + "dev": true + }, + "json-schema": { + "version": "0.2.3", + "resolved": "https://registry.npmjs.org/json-schema/-/json-schema-0.2.3.tgz", + "integrity": "sha1-tIDIkuWaLwWVTOcnvT8qTogvnhM=", + "dev": true + }, + "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=", + "dev": true + }, + "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=", + "dev": true + }, + "json3": { + "version": "3.3.2", + "resolved": "https://registry.npmjs.org/json3/-/json3-3.3.2.tgz", + "integrity": "sha1-PAQ0dD35Pi9cQq7nsZvLSDV19OE=", + "dev": true + }, + "json5": { + "version": "0.5.1", + "resolved": "https://registry.npmjs.org/json5/-/json5-0.5.1.tgz", + "integrity": "sha1-Hq3nrMASA0rYTiOWdn6tn6VJWCE=", + "dev": true + }, + "jsonify": { + "version": "0.0.0", + "resolved": "https://registry.npmjs.org/jsonify/-/jsonify-0.0.0.tgz", + "integrity": "sha1-LHS27kHZPKUbe1qu6PUDYx0lKnM=", + "dev": true + }, + "jsonpointer": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/jsonpointer/-/jsonpointer-4.0.1.tgz", + "integrity": "sha1-T9kss04OnbPInIYi7PUfm5eMbLk=", + "dev": true + }, + "jsprim": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/jsprim/-/jsprim-1.4.0.tgz", + "integrity": "sha1-o7h+QCmNjDgFUtjMdiigu5WiKRg=", + "dev": true, + "dependencies": { + "assert-plus": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/assert-plus/-/assert-plus-1.0.0.tgz", + "integrity": "sha1-8S4PPF13sLHN2RRpQuTpbB5N1SU=", + "dev": true + } + } + }, + "jstransformer": { + "version": "0.0.2", + "resolved": "https://registry.npmjs.org/jstransformer/-/jstransformer-0.0.2.tgz", + "integrity": "sha1-eq4pqQPRls+glz2IXT5HlH7Ndqs=", + "dev": true + }, + "kind-of": { + "version": "3.2.2", + "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", + "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", + "dev": true + }, + "lazy-cache": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/lazy-cache/-/lazy-cache-1.0.4.tgz", + "integrity": "sha1-odePw6UEdMuAhF07O24dpJpEbo4=", + "dev": true + }, + "lcid": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/lcid/-/lcid-1.0.0.tgz", + "integrity": "sha1-MIrMr6C8SDo4Z7S28rlQYlHRuDU=", + "dev": true + }, + "levn": { + "version": "0.3.0", + "resolved": "https://registry.npmjs.org/levn/-/levn-0.3.0.tgz", + "integrity": "sha1-OwmSTt+fCDwEkP3UwLxEIeBHZO4=", + "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=", + "dev": true, + "dependencies": { + "strip-bom": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-2.0.0.tgz", + "integrity": "sha1-YhmoVhZSBJHzV4i9vxRHqZx+aw4=", + "dev": true + } + } + }, + "loader-fs-cache": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/loader-fs-cache/-/loader-fs-cache-1.0.1.tgz", + "integrity": "sha1-VuC/CL2XCLJqdltoUJhAyN7J/bw=", + "dev": true + }, + "loader-utils": { + "version": "0.2.17", + "resolved": "https://registry.npmjs.org/loader-utils/-/loader-utils-0.2.17.tgz", + "integrity": "sha1-+G5jdNQyBabmxg6RlvF8Apm/s0g=", + "dev": true + }, + "lodash": { + "version": "4.17.4", + "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.4.tgz", + "integrity": "sha1-eCA6TRwyiuHYbcpkYONptX9AVa4=", + "dev": true + }, + "lodash._arraycopy": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/lodash._arraycopy/-/lodash._arraycopy-3.0.0.tgz", + "integrity": "sha1-due3wfH7klRzdIeKVi7Qaj5Q9uE=", + "dev": true + }, + "lodash._arrayeach": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/lodash._arrayeach/-/lodash._arrayeach-3.0.0.tgz", + "integrity": "sha1-urFWsqkNPxu9XGU0AzSeXlkz754=", + "dev": true + }, + "lodash._baseassign": { + "version": "3.2.0", + "resolved": "https://registry.npmjs.org/lodash._baseassign/-/lodash._baseassign-3.2.0.tgz", + "integrity": "sha1-jDigmVAPIVrQnlnxci/QxSv+Ck4=", + "dev": true + }, + "lodash._basecallback": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/lodash._basecallback/-/lodash._basecallback-3.3.1.tgz", + "integrity": "sha1-t7K7Q9whYEJKIczybFfkQ3cqjic=", + "dev": true + }, + "lodash._basecopy": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/lodash._basecopy/-/lodash._basecopy-3.0.1.tgz", + "integrity": "sha1-jaDmqHbPNEwK2KVIghEd08XHyjY=", + "dev": true + }, + "lodash._basecreate": { + "version": "3.0.3", + "resolved": "https://registry.npmjs.org/lodash._basecreate/-/lodash._basecreate-3.0.3.tgz", + "integrity": "sha1-G8ZhYU2qf8MRt9A78WgGoCE8+CE=", + "dev": true + }, + "lodash._baseeach": { + "version": "3.0.4", + "resolved": "https://registry.npmjs.org/lodash._baseeach/-/lodash._baseeach-3.0.4.tgz", + "integrity": "sha1-z4cGVyyhROjZ11InyZDamC+TKvM=", + "dev": true + }, + "lodash._basefind": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/lodash._basefind/-/lodash._basefind-3.0.0.tgz", + "integrity": "sha1-srugXMZF+XLeLPkl+iv2Og9gyK4=", + "dev": true + }, + "lodash._basefindindex": { + "version": "3.6.0", + "resolved": "https://registry.npmjs.org/lodash._basefindindex/-/lodash._basefindindex-3.6.0.tgz", + "integrity": "sha1-8IM2ChsCJBjtgbyJm+sxLiHnSk8=", + "dev": true + }, + "lodash._basefor": { + "version": "3.0.3", + "resolved": "https://registry.npmjs.org/lodash._basefor/-/lodash._basefor-3.0.3.tgz", + "integrity": "sha1-dVC06SGO8J+tJDQ7YSAhx5tMIMI=", + "dev": true + }, + "lodash._baseisequal": { + "version": "3.0.7", + "resolved": "https://registry.npmjs.org/lodash._baseisequal/-/lodash._baseisequal-3.0.7.tgz", + "integrity": "sha1-2AJfdjOdKTQnZ9zIh85cuVpbUfE=", + "dev": true + }, + "lodash._bindcallback": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/lodash._bindcallback/-/lodash._bindcallback-3.0.1.tgz", + "integrity": "sha1-5THCdkTPi1epnhftlbNcdIeJOS4=", + "dev": true + }, + "lodash._createassigner": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/lodash._createassigner/-/lodash._createassigner-3.1.1.tgz", + "integrity": "sha1-g4pbri/aymOsIt7o4Z+k5taXCxE=", + "dev": true + }, + "lodash._createcompounder": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/lodash._createcompounder/-/lodash._createcompounder-3.0.0.tgz", + "integrity": "sha1-XdLLVTctbnDg4jkvsjBNZjEJEHU=", + "dev": true + }, + "lodash._getnative": { + "version": "3.9.1", + "resolved": "https://registry.npmjs.org/lodash._getnative/-/lodash._getnative-3.9.1.tgz", + "integrity": "sha1-VwvH3t5G1hzc3mh9ZdPuy6o6r/U=", + "dev": true + }, + "lodash._isiterateecall": { + "version": "3.0.9", + "resolved": "https://registry.npmjs.org/lodash._isiterateecall/-/lodash._isiterateecall-3.0.9.tgz", + "integrity": "sha1-UgOte6Ql+uhCRg5pbbnPPmqsBXw=", + "dev": true + }, + "lodash._root": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/lodash._root/-/lodash._root-3.0.1.tgz", + "integrity": "sha1-+6HEUkwZ7ppfgTa0YJ8BfPTe1pI=", + "dev": true + }, + "lodash.assign": { + "version": "4.2.0", + "resolved": "https://registry.npmjs.org/lodash.assign/-/lodash.assign-4.2.0.tgz", + "integrity": "sha1-DZnzzNem0mHRm9rrkkUAXShYCOc=", + "dev": true + }, + "lodash.camelcase": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/lodash.camelcase/-/lodash.camelcase-3.0.1.tgz", + "integrity": "sha1-kyyLh/ikN3iXxnGXUzKC+Xrqwpg=", + "dev": true + }, + "lodash.clonedeep": { + "version": "4.5.0", + "resolved": "https://registry.npmjs.org/lodash.clonedeep/-/lodash.clonedeep-4.5.0.tgz", + "integrity": "sha1-4j8/nE+Pvd6HJSnBBxhXoIblzO8=", + "dev": true + }, + "lodash.create": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/lodash.create/-/lodash.create-3.1.1.tgz", + "integrity": "sha1-1/KEnw29p+BGgruM1yqwIkYd6+c=", + "dev": true + }, + "lodash.deburr": { + "version": "3.2.0", + "resolved": "https://registry.npmjs.org/lodash.deburr/-/lodash.deburr-3.2.0.tgz", + "integrity": "sha1-baj1QzSjZqfPTEx2742Aqhs2XtU=", + "dev": true + }, + "lodash.find": { + "version": "3.2.1", + "resolved": "https://registry.npmjs.org/lodash.find/-/lodash.find-3.2.1.tgz", + "integrity": "sha1-BG4xnzrOkSrGySRsf2g8XsB7Nq0=", + "dev": true + }, + "lodash.isarguments": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/lodash.isarguments/-/lodash.isarguments-3.1.0.tgz", + "integrity": "sha1-L1c9hcaiQon/AGY7SRwdM4/zRYo=", + "dev": true + }, + "lodash.isarray": { + "version": "3.0.4", + "resolved": "https://registry.npmjs.org/lodash.isarray/-/lodash.isarray-3.0.4.tgz", + "integrity": "sha1-eeTriMNqgSKvhvhEqpvNhRtfu1U=", + "dev": true + }, + "lodash.isequal": { + "version": "4.5.0", + "resolved": "https://registry.npmjs.org/lodash.isequal/-/lodash.isequal-4.5.0.tgz", + "integrity": "sha1-QVxEePK8wwEgwizhDtMib30+GOA=", + "dev": true + }, + "lodash.isplainobject": { + "version": "3.2.0", + "resolved": "https://registry.npmjs.org/lodash.isplainobject/-/lodash.isplainobject-3.2.0.tgz", + "integrity": "sha1-moI4rhayAEMpYM1zRlEtASP79MU=", + "dev": true + }, + "lodash.istypedarray": { + "version": "3.0.6", + "resolved": "https://registry.npmjs.org/lodash.istypedarray/-/lodash.istypedarray-3.0.6.tgz", + "integrity": "sha1-yaR3SYYHUB2OhJTSg7h8OSgc72I=", + "dev": true + }, + "lodash.keys": { + "version": "3.1.2", + "resolved": "https://registry.npmjs.org/lodash.keys/-/lodash.keys-3.1.2.tgz", + "integrity": "sha1-TbwEcrFWvlCgsoaFXRvQsMZWCYo=", + "dev": true + }, + "lodash.keysin": { + "version": "3.0.8", + "resolved": "https://registry.npmjs.org/lodash.keysin/-/lodash.keysin-3.0.8.tgz", + "integrity": "sha1-IsRJPrvtsUJ5YqVLRFssinZ/tH8=", + "dev": true + }, + "lodash.memoize": { + "version": "4.1.2", + "resolved": "https://registry.npmjs.org/lodash.memoize/-/lodash.memoize-4.1.2.tgz", + "integrity": "sha1-vMbEmkKihA7Zl/Mj6tpezRguC/4=", + "dev": true + }, + "lodash.merge": { + "version": "3.3.2", + "resolved": "https://registry.npmjs.org/lodash.merge/-/lodash.merge-3.3.2.tgz", + "integrity": "sha1-DZDZPtY3sYeEN7s+IWASYNev6ZQ=", + "dev": true + }, + "lodash.pairs": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/lodash.pairs/-/lodash.pairs-3.0.1.tgz", + "integrity": "sha1-u+CNV4bu6qCaFckevw3LfSvjJqk=", + "dev": true + }, + "lodash.restparam": { + "version": "3.6.1", + "resolved": "https://registry.npmjs.org/lodash.restparam/-/lodash.restparam-3.6.1.tgz", + "integrity": "sha1-k2pOMJ7zMKdkXtQUWYbIWuWyCAU=", + "dev": true + }, + "lodash.toplainobject": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/lodash.toplainobject/-/lodash.toplainobject-3.0.0.tgz", + "integrity": "sha1-KHkK2ULSk9eKpmOgfs9/UsoEGY0=", + "dev": true + }, + "lodash.uniq": { + "version": "4.5.0", + "resolved": "https://registry.npmjs.org/lodash.uniq/-/lodash.uniq-4.5.0.tgz", + "integrity": "sha1-0CJTc662Uq3BvILklFM5qEJ1R3M=", + "dev": true + }, + "lodash.words": { + "version": "3.2.0", + "resolved": "https://registry.npmjs.org/lodash.words/-/lodash.words-3.2.0.tgz", + "integrity": "sha1-TiqGSbwIdFsXxpWxo86P7llmI7M=", + "dev": true + }, + "longest": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/longest/-/longest-1.0.1.tgz", + "integrity": "sha1-MKCy2jj3N3DoKUoNIuZiXtd9AJc=", + "dev": true + }, + "loose-envify": { + "version": "1.3.1", + "resolved": "https://registry.npmjs.org/loose-envify/-/loose-envify-1.3.1.tgz", + "integrity": "sha1-0aitM/qc4OcT1l/dCsi3SNR4yEg=", + "dev": true + }, + "loud-rejection": { + "version": "1.6.0", + "resolved": "https://registry.npmjs.org/loud-rejection/-/loud-rejection-1.6.0.tgz", + "integrity": "sha1-W0b4AUft7leIcPCG0Eghz5mOVR8=", + "dev": true + }, + "lower-case": { + "version": "1.1.4", + "resolved": "https://registry.npmjs.org/lower-case/-/lower-case-1.1.4.tgz", + "integrity": "sha1-miyr0bno4K6ZOkv31YdcOcQujqw=", + "dev": true + }, + "lower-case-first": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/lower-case-first/-/lower-case-first-1.0.2.tgz", + "integrity": "sha1-5dp8JvKacHO+AtUrrJmA5ZIq36E=", + "dev": true + }, + "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==", + "dev": true + }, + "macaddress": { + "version": "0.2.8", + "resolved": "https://registry.npmjs.org/macaddress/-/macaddress-0.2.8.tgz", + "integrity": "sha1-WQTcU3w57G2+/q6QIycTX6hRHxI=", + "dev": true + }, + "map-obj": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/map-obj/-/map-obj-1.0.1.tgz", + "integrity": "sha1-2TPOuSBdgr3PSIb2dCvcK03qFG0=", + "dev": true + }, + "math-expression-evaluator": { + "version": "1.2.17", + "resolved": "https://registry.npmjs.org/math-expression-evaluator/-/math-expression-evaluator-1.2.17.tgz", + "integrity": "sha1-3oGf282E3M2PrlnGrreWFbnSZqw=", + "dev": true + }, + "media-typer": { + "version": "0.3.0", + "resolved": "https://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz", + "integrity": "sha1-hxDXrwqmJvj/+hzgAWhUUmMlV0g=", + "dev": true + }, + "memory-fs": { + "version": "0.3.0", + "resolved": "https://registry.npmjs.org/memory-fs/-/memory-fs-0.3.0.tgz", + "integrity": "sha1-e8xrYp46Q+hx1+Kaymrop/FcuyA=", + "dev": true + }, + "meow": { + "version": "3.7.0", + "resolved": "https://registry.npmjs.org/meow/-/meow-3.7.0.tgz", + "integrity": "sha1-cstmi0JSKCkKu/qFaJJYcwioAfs=", + "dev": true, + "dependencies": { + "minimist": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.0.tgz", + "integrity": "sha1-o1AIsg9BOD7sH7kU9M1d95omQoQ=", + "dev": true + } + } + }, + "merge-descriptors": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/merge-descriptors/-/merge-descriptors-1.0.1.tgz", + "integrity": "sha1-sAqqVW3YtEVoFQ7J0blT8/kMu2E=", + "dev": true + }, + "methods": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/methods/-/methods-1.1.2.tgz", + "integrity": "sha1-VSmk1nZUE07cxSZmVoNbD4Ua/O4=", + "dev": true + }, + "micromatch": { + "version": "2.3.11", + "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-2.3.11.tgz", + "integrity": "sha1-hmd8l9FyCzY0MdBNDRUpO9OMFWU=", + "dev": true, + "dependencies": { + "is-extglob": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-1.0.0.tgz", + "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 + } + } + }, + "mime": { + "version": "1.3.4", + "resolved": "https://registry.npmjs.org/mime/-/mime-1.3.4.tgz", + "integrity": "sha1-EV+eO2s9rylZmDyzjxSaLUDrXVM=", + "dev": true + }, + "mime-db": { + "version": "1.27.0", + "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.27.0.tgz", + "integrity": "sha1-gg9XIpa70g7CXtVeW13oaeVDbrE=", + "dev": true + }, + "mime-types": { + "version": "2.1.15", + "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.15.tgz", + "integrity": "sha1-pOv1BkCUVpI3uM9wBGd20J/JKu0=", + "dev": true + }, + "minimatch": { + "version": "3.0.4", + "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", + "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", + "dev": true + }, + "minimist": { + "version": "0.0.8", + "resolved": "https://registry.npmjs.org/minimist/-/minimist-0.0.8.tgz", + "integrity": "sha1-hX/Kv8M5fSYluCKCYuhqp6ARsF0=", + "dev": true + }, + "mkdirp": { + "version": "0.5.1", + "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.1.tgz", + "integrity": "sha1-MAV0OOrGz3+MR2fzhkjWaX11yQM=", + "dev": true + }, + "mocha": { + "version": "3.4.2", + "resolved": "https://registry.npmjs.org/mocha/-/mocha-3.4.2.tgz", + "integrity": "sha1-0O9NMyEm2/GNDWQMmzgt1IvpdZQ=", + "dev": true, + "dependencies": { + "debug": { + "version": "2.6.0", + "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.0.tgz", + "integrity": "sha1-vFlryr52F/Edn6FTYe3tVgi4SZs=", + "dev": true + }, + "glob": { + "version": "7.1.1", + "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.1.tgz", + "integrity": "sha1-gFIR3wT6rxxjo2ADBs31reULLsg=", + "dev": true + }, + "ms": { + "version": "0.7.2", + "resolved": "https://registry.npmjs.org/ms/-/ms-0.7.2.tgz", + "integrity": "sha1-riXPJRKziFodldfwN4aNhDESR2U=", + "dev": true + }, + "supports-color": { + "version": "3.1.2", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-3.1.2.tgz", + "integrity": "sha1-cqJiiU2dQIuVbKBf83su2KbiotU=", + "dev": true + } + } + }, + "ms": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", + "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=", + "dev": true + }, + "mute-stream": { + "version": "0.0.5", + "resolved": "https://registry.npmjs.org/mute-stream/-/mute-stream-0.0.5.tgz", + "integrity": "sha1-j7+rsKmKJT0xhDMfno3rc3L6xsA=", + "dev": true + }, + "nan": { + "version": "2.6.2", + "resolved": "https://registry.npmjs.org/nan/-/nan-2.6.2.tgz", + "integrity": "sha1-5P805slf37WuzAjeZZb0NgWn20U=", + "dev": true + }, + "natural-compare": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", + "integrity": "sha1-Sr6/7tdUHywnrPspvbvRXI1bpPc=", + "dev": true + }, + "ncname": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/ncname/-/ncname-1.0.0.tgz", + "integrity": "sha1-W1etGLHKCShk72Kwse2BlPODtxw=", + "dev": true + }, + "negotiator": { + "version": "0.6.1", + "resolved": "https://registry.npmjs.org/negotiator/-/negotiator-0.6.1.tgz", + "integrity": "sha1-KzJxhOiZIQEXeyhWP7XnECrNDKk=", + "dev": true + }, + "no-case": { + "version": "2.3.1", + "resolved": "https://registry.npmjs.org/no-case/-/no-case-2.3.1.tgz", + "integrity": "sha1-euuhxzpSGEJlVUt9wDuvcg34AIE=", + "dev": true + }, + "node-gyp": { + "version": "3.6.2", + "resolved": "https://registry.npmjs.org/node-gyp/-/node-gyp-3.6.2.tgz", + "integrity": "sha1-m/vlRWIoYoSDjnUOrAUpWFP6HGA=", + "dev": true + }, + "node-libs-browser": { + "version": "0.7.0", + "resolved": "https://registry.npmjs.org/node-libs-browser/-/node-libs-browser-0.7.0.tgz", + "integrity": "sha1-PicsCBnjCJNeJmdECNevDhSRuDs=", + "dev": true, + "dependencies": { + "string_decoder": { + "version": "0.10.31", + "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-0.10.31.tgz", + "integrity": "sha1-YuIDvEF2bGwoyfyEMB2rHFMQ+pQ=", + "dev": true + } + } + }, + "node-sass": { + "version": "3.13.1", + "resolved": "https://registry.npmjs.org/node-sass/-/node-sass-3.13.1.tgz", + "integrity": "sha1-ckD7v/I5YwS0IjUn7TAgWJwAT8I=", + "dev": true + }, + "nomnomnomnom": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/nomnomnomnom/-/nomnomnomnom-2.0.1.tgz", + "integrity": "sha1-siOfAxyNBNpn4yg24eMZnhL3qOI=", + "dev": true, + "dependencies": { + "ansi-styles": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-1.0.0.tgz", + "integrity": "sha1-yxAt8cVvUSPquLZ817mAJ6AnkXg=", + "dev": true + }, + "chalk": { + "version": "0.4.0", + "resolved": "https://registry.npmjs.org/chalk/-/chalk-0.4.0.tgz", + "integrity": "sha1-UZmj3c0MHv4jvAjBsCewYXbgxk8=", + "dev": true + }, + "strip-ansi": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-0.1.1.tgz", + "integrity": "sha1-OeipjQRNFQZgq+SmgIrPcLt7yZE=", + "dev": true + } + } + }, + "nopt": { + "version": "3.0.6", + "resolved": "https://registry.npmjs.org/nopt/-/nopt-3.0.6.tgz", + "integrity": "sha1-xkZdvwirzU2zWTF/eaxopkayj/k=", + "dev": true + }, + "normalize-package-data": { + "version": "2.3.8", + "resolved": "https://registry.npmjs.org/normalize-package-data/-/normalize-package-data-2.3.8.tgz", + "integrity": "sha1-2Bntoqne29H/pWPqQHHZNngilbs=", + "dev": 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 + }, + "normalize-range": { + "version": "0.1.2", + "resolved": "https://registry.npmjs.org/normalize-range/-/normalize-range-0.1.2.tgz", + "integrity": "sha1-LRDAa9/TEuqXd2laTShDlFa3WUI=", + "dev": true + }, + "normalize-url": { + "version": "1.9.1", + "resolved": "https://registry.npmjs.org/normalize-url/-/normalize-url-1.9.1.tgz", + "integrity": "sha1-LMDWazHqIwNkWENuNiDYWVTGbDw=", + "dev": true + }, + "npmlog": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/npmlog/-/npmlog-4.1.0.tgz", + "integrity": "sha512-ocolIkZYZt8UveuiDS0yAkkIjid1o7lPG8cYm05yNYzBn8ykQtaiPMEGp8fY9tKdDgm8okpdKzkvu1y9hUYugA==", + "dev": true + }, + "nth-check": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/nth-check/-/nth-check-1.0.1.tgz", + "integrity": "sha1-mSms32KPwsQQmN6rgqxYDPFJquQ=", + "dev": true + }, + "num2fraction": { + "version": "1.2.2", + "resolved": "https://registry.npmjs.org/num2fraction/-/num2fraction-1.2.2.tgz", + "integrity": "sha1-b2gragJ6Tp3fpFZM0lidHU5mnt4=", + "dev": true + }, + "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=", + "dev": true + }, + "oauth-sign": { + "version": "0.8.2", + "resolved": "https://registry.npmjs.org/oauth-sign/-/oauth-sign-0.8.2.tgz", + "integrity": "sha1-Rqarfwrq2N6unsBWV4C31O/rnUM=", + "dev": true + }, + "object-assign": { + "version": "4.1.1", + "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", + "integrity": "sha1-IQmtx5ZYh8/AXLvUQsrIv7s2CGM=", + "dev": true + }, + "object-hash": { + "version": "1.1.8", + "resolved": "https://registry.npmjs.org/object-hash/-/object-hash-1.1.8.tgz", + "integrity": "sha1-KKZZz5h9lqTavnhgKJ87UybEoDw=", + "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 + }, + "on-finished": { + "version": "2.3.0", + "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.3.0.tgz", + "integrity": "sha1-IPEzZIGwg811M3mSoWlxqi2QaUc=", + "dev": true + }, + "once": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", + "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", + "dev": true + }, + "onetime": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/onetime/-/onetime-1.1.0.tgz", + "integrity": "sha1-ofeDj4MUxRbwXs78vEzP4EtO14k=", + "dev": true + }, + "optimist": { + "version": "0.6.1", + "resolved": "https://registry.npmjs.org/optimist/-/optimist-0.6.1.tgz", + "integrity": "sha1-2j6nRob6IaGaERwybpDrFaAZZoY=", + "dev": true, + "dependencies": { + "wordwrap": { + "version": "0.0.3", + "resolved": "https://registry.npmjs.org/wordwrap/-/wordwrap-0.0.3.tgz", + "integrity": "sha1-o9XabNXAvAAI03I0u68b7WMFkQc=", + "dev": true + } + } + }, + "optionator": { + "version": "0.8.2", + "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.8.2.tgz", + "integrity": "sha1-NkxeQJ0/TWMB1sC0wFu6UBgK62Q=", + "dev": true + }, + "os-browserify": { + "version": "0.2.1", + "resolved": "https://registry.npmjs.org/os-browserify/-/os-browserify-0.2.1.tgz", + "integrity": "sha1-Y/xMzuXS13Y9Jrv4YBB45sLgBE8=", + "dev": true + }, + "os-homedir": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/os-homedir/-/os-homedir-1.0.2.tgz", + "integrity": "sha1-/7xJiDNuDoM94MFox+8VISGqf7M=", + "dev": true + }, + "os-locale": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/os-locale/-/os-locale-1.4.0.tgz", + "integrity": "sha1-IPnxeuKe00XoveWDsT0gCYA8FNk=", + "dev": true + }, + "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=", + "dev": true + }, + "osenv": { + "version": "0.1.4", + "resolved": "https://registry.npmjs.org/osenv/-/osenv-0.1.4.tgz", + "integrity": "sha1-Qv5tWVPfBsgGS+bxdsPQWqqjRkQ=", + "dev": true + }, + "pako": { + "version": "0.2.9", + "resolved": "https://registry.npmjs.org/pako/-/pako-0.2.9.tgz", + "integrity": "sha1-8/dSL073gjSNqBYbrZ7P1Rv4OnU=", + "dev": true + }, + "param-case": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/param-case/-/param-case-2.1.1.tgz", + "integrity": "sha1-35T9jPZTHs915r75oIWPvHK+Ikc=", + "dev": true + }, + "parse-glob": { + "version": "3.0.4", + "resolved": "https://registry.npmjs.org/parse-glob/-/parse-glob-3.0.4.tgz", + "integrity": "sha1-ssN2z7EfNVE7rdFz7wu246OIORw=", + "dev": true, + "dependencies": { + "is-extglob": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-1.0.0.tgz", + "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 + } + } + }, + "parse-json": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-2.2.0.tgz", + "integrity": "sha1-9ID0BDTvgHQfhGkJn43qGPVaTck=", + "dev": true + }, + "parseurl": { + "version": "1.3.1", + "resolved": "https://registry.npmjs.org/parseurl/-/parseurl-1.3.1.tgz", + "integrity": "sha1-yKuMkiO6NIiKpkopeyiFO+wY2lY=", + "dev": true + }, + "pascal-case": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/pascal-case/-/pascal-case-2.0.1.tgz", + "integrity": "sha1-LVeNNFX2YNpl7KGO+VtODekSdh4=", + "dev": true + }, + "path-browserify": { + "version": "0.0.0", + "resolved": "https://registry.npmjs.org/path-browserify/-/path-browserify-0.0.0.tgz", + "integrity": "sha1-oLhwcpquIUAFt9UDLsLLuw+0RRo=", + "dev": true + }, + "path-case": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/path-case/-/path-case-2.1.1.tgz", + "integrity": "sha1-lLgDfDctP+KQbkZbtF4l0ibo7qU=", + "dev": true + }, + "path-exists": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-2.1.0.tgz", + "integrity": "sha1-D+tsZPD8UY2adU3V77YscCJ2H0s=", + "dev": true + }, + "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=", + "dev": true + }, + "path-is-inside": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/path-is-inside/-/path-is-inside-1.0.2.tgz", + "integrity": "sha1-NlQX3t5EQw0cEa9hAn+s8HS9/FM=", + "dev": true + }, + "path-parse": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.5.tgz", + "integrity": "sha1-PBrfhx6pzWyUMbbqK9dKD/BVxME=", + "dev": true + }, + "path-to-regexp": { + "version": "0.1.7", + "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-0.1.7.tgz", + "integrity": "sha1-32BBeABfUi8V60SQ5yR6G/qmf4w=", + "dev": true + }, + "path-type": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/path-type/-/path-type-1.1.0.tgz", + "integrity": "sha1-WcRPfuSR2nBNpBXaWkBwuk+P5EE=", + "dev": true + }, + "pbkdf2-compat": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/pbkdf2-compat/-/pbkdf2-compat-2.0.1.tgz", + "integrity": "sha1-tuDI+plJTZTgURV1gCpZpcFC8og=", + "dev": true + }, + "performance-now": { + "version": "0.2.0", + "resolved": "https://registry.npmjs.org/performance-now/-/performance-now-0.2.0.tgz", + "integrity": "sha1-M+8wxcd9TqIcWlOGnZG1bY8lVeU=", + "dev": true + }, + "pify": { + "version": "2.3.0", + "resolved": "https://registry.npmjs.org/pify/-/pify-2.3.0.tgz", + "integrity": "sha1-7RQaasBDqEnqWISY59yosVMw6Qw=", + "dev": true + }, + "pinkie": { + "version": "2.0.4", + "resolved": "https://registry.npmjs.org/pinkie/-/pinkie-2.0.4.tgz", + "integrity": "sha1-clVrgM+g1IqXToDnckjoDtT3+HA=", + "dev": true + }, + "pinkie-promise": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/pinkie-promise/-/pinkie-promise-2.0.1.tgz", + "integrity": "sha1-ITXW36ejWMBprJsXh3YogihFD/o=", + "dev": true + }, + "pkg-dir": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/pkg-dir/-/pkg-dir-1.0.0.tgz", + "integrity": "sha1-ektQio1bstYp1EcFb/TpyTFM89Q=", + "dev": true + }, + "pluralize": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/pluralize/-/pluralize-1.2.1.tgz", + "integrity": "sha1-0aIUg/0iu0HlihL6NCGCMUCJfEU=", + "dev": true + }, + "postcss": { + "version": "5.2.17", + "resolved": "https://registry.npmjs.org/postcss/-/postcss-5.2.17.tgz", + "integrity": "sha1-z09Ze4ZNZcikkrLqvp1wbIecOIs=", + "dev": true, + "dependencies": { + "supports-color": { + "version": "3.2.3", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-3.2.3.tgz", + "integrity": "sha1-ZawFBLOVQXHYpklGsq48u4pfVPY=", + "dev": true + } + } + }, + "postcss-calc": { + "version": "5.3.1", + "resolved": "https://registry.npmjs.org/postcss-calc/-/postcss-calc-5.3.1.tgz", + "integrity": "sha1-d7rnypKK2FcW4v2kLyYb98HWW14=", + "dev": true + }, + "postcss-colormin": { + "version": "2.2.2", + "resolved": "https://registry.npmjs.org/postcss-colormin/-/postcss-colormin-2.2.2.tgz", + "integrity": "sha1-ZjFBfV8OkJo9fsJrJMio0eT5bks=", + "dev": true + }, + "postcss-convert-values": { + "version": "2.6.1", + "resolved": "https://registry.npmjs.org/postcss-convert-values/-/postcss-convert-values-2.6.1.tgz", + "integrity": "sha1-u9hZPFwf0uPRwyK7kl3K6Nrk1i0=", + "dev": true + }, + "postcss-discard-comments": { + "version": "2.0.4", + "resolved": "https://registry.npmjs.org/postcss-discard-comments/-/postcss-discard-comments-2.0.4.tgz", + "integrity": "sha1-vv6J+v1bPazlzM5Rt2uBUUvgDj0=", + "dev": true + }, + "postcss-discard-duplicates": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/postcss-discard-duplicates/-/postcss-discard-duplicates-2.1.0.tgz", + "integrity": "sha1-uavye4isGIFYpesSq8riAmO5GTI=", + "dev": true + }, + "postcss-discard-empty": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/postcss-discard-empty/-/postcss-discard-empty-2.1.0.tgz", + "integrity": "sha1-0rS9nVztXr2Nyt52QMfXzX9PkrU=", + "dev": true + }, + "postcss-discard-overridden": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/postcss-discard-overridden/-/postcss-discard-overridden-0.1.1.tgz", + "integrity": "sha1-ix6vVU9ob7KIzYdMVWZ7CqNmjVg=", + "dev": true + }, + "postcss-discard-unused": { + "version": "2.2.3", + "resolved": "https://registry.npmjs.org/postcss-discard-unused/-/postcss-discard-unused-2.2.3.tgz", + "integrity": "sha1-vOMLLMWR/8Y0Mitfs0ZLbZNPRDM=", + "dev": true + }, + "postcss-filter-plugins": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/postcss-filter-plugins/-/postcss-filter-plugins-2.0.2.tgz", + "integrity": "sha1-bYWGJTTXNaxCDkqFgG4fXUKG2Ew=", + "dev": true + }, + "postcss-merge-idents": { + "version": "2.1.7", + "resolved": "https://registry.npmjs.org/postcss-merge-idents/-/postcss-merge-idents-2.1.7.tgz", + "integrity": "sha1-TFUwMTwI4dWzu/PSu8dH4njuonA=", + "dev": true + }, + "postcss-merge-longhand": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/postcss-merge-longhand/-/postcss-merge-longhand-2.0.2.tgz", + "integrity": "sha1-I9kM0Sewp3mUkVMyc5A0oaTz1lg=", + "dev": true + }, + "postcss-merge-rules": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/postcss-merge-rules/-/postcss-merge-rules-2.1.2.tgz", + "integrity": "sha1-0d9d+qexrMO+VT8OnhDofGG19yE=", + "dev": true + }, + "postcss-message-helpers": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/postcss-message-helpers/-/postcss-message-helpers-2.0.0.tgz", + "integrity": "sha1-pPL0+rbk/gAvCu0ABHjN9S+bpg4=", + "dev": true + }, + "postcss-minify-font-values": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/postcss-minify-font-values/-/postcss-minify-font-values-1.0.5.tgz", + "integrity": "sha1-S1jttWZB66fIR0qzUmyv17vey2k=", + "dev": true + }, + "postcss-minify-gradients": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/postcss-minify-gradients/-/postcss-minify-gradients-1.0.5.tgz", + "integrity": "sha1-Xb2hE3NwP4PPtKPqOIHY11/15uE=", + "dev": true + }, + "postcss-minify-params": { + "version": "1.2.2", + "resolved": "https://registry.npmjs.org/postcss-minify-params/-/postcss-minify-params-1.2.2.tgz", + "integrity": "sha1-rSzgcTc7lDs9kwo/pZo1jCjW8fM=", + "dev": true + }, + "postcss-minify-selectors": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/postcss-minify-selectors/-/postcss-minify-selectors-2.1.1.tgz", + "integrity": "sha1-ssapjAByz5G5MtGkllCBFDEXNb8=", + "dev": true + }, + "postcss-modules-extract-imports": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/postcss-modules-extract-imports/-/postcss-modules-extract-imports-1.1.0.tgz", + "integrity": "sha1-thTJcgvmgW6u41+zpfqh26agXds=", + "dev": true, + "dependencies": { + "postcss": { + "version": "6.0.2", + "resolved": "https://registry.npmjs.org/postcss/-/postcss-6.0.2.tgz", + "integrity": "sha1-XE/qWJ8Kw7AMqnWxy8OihBlbfl0=", + "dev": true + }, + "supports-color": { + "version": "3.2.3", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-3.2.3.tgz", + "integrity": "sha1-ZawFBLOVQXHYpklGsq48u4pfVPY=", + "dev": true + } + } + }, + "postcss-modules-local-by-default": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/postcss-modules-local-by-default/-/postcss-modules-local-by-default-1.2.0.tgz", + "integrity": "sha1-99gMOYxaOT+nlkRmvRlQCn1hwGk=", + "dev": true, + "dependencies": { + "css-selector-tokenizer": { + "version": "0.7.0", + "resolved": "https://registry.npmjs.org/css-selector-tokenizer/-/css-selector-tokenizer-0.7.0.tgz", + "integrity": "sha1-5piEdK6MlTR3v15+/s/OzNnPTIY=", + "dev": true + }, + "postcss": { + "version": "6.0.2", + "resolved": "https://registry.npmjs.org/postcss/-/postcss-6.0.2.tgz", + "integrity": "sha1-XE/qWJ8Kw7AMqnWxy8OihBlbfl0=", + "dev": true + }, + "regexpu-core": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/regexpu-core/-/regexpu-core-1.0.0.tgz", + "integrity": "sha1-hqdj9Y7k18L2sQLkdkBQ3n7ZDGs=", + "dev": true + }, + "supports-color": { + "version": "3.2.3", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-3.2.3.tgz", + "integrity": "sha1-ZawFBLOVQXHYpklGsq48u4pfVPY=", + "dev": true + } + } + }, + "postcss-modules-scope": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/postcss-modules-scope/-/postcss-modules-scope-1.1.0.tgz", + "integrity": "sha1-1upkmUx5+XtipytCb75gVqGUu5A=", + "dev": true, + "dependencies": { + "css-selector-tokenizer": { + "version": "0.7.0", + "resolved": "https://registry.npmjs.org/css-selector-tokenizer/-/css-selector-tokenizer-0.7.0.tgz", + "integrity": "sha1-5piEdK6MlTR3v15+/s/OzNnPTIY=", + "dev": true + }, + "postcss": { + "version": "6.0.2", + "resolved": "https://registry.npmjs.org/postcss/-/postcss-6.0.2.tgz", + "integrity": "sha1-XE/qWJ8Kw7AMqnWxy8OihBlbfl0=", + "dev": true + }, + "regexpu-core": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/regexpu-core/-/regexpu-core-1.0.0.tgz", + "integrity": "sha1-hqdj9Y7k18L2sQLkdkBQ3n7ZDGs=", + "dev": true + }, + "supports-color": { + "version": "3.2.3", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-3.2.3.tgz", + "integrity": "sha1-ZawFBLOVQXHYpklGsq48u4pfVPY=", + "dev": true + } + } + }, + "postcss-modules-values": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/postcss-modules-values/-/postcss-modules-values-1.3.0.tgz", + "integrity": "sha1-7P+p1+GSUYOJ9CrQ6D9yrsRW6iA=", + "dev": true, + "dependencies": { + "postcss": { + "version": "6.0.2", + "resolved": "https://registry.npmjs.org/postcss/-/postcss-6.0.2.tgz", + "integrity": "sha1-XE/qWJ8Kw7AMqnWxy8OihBlbfl0=", + "dev": true + }, + "supports-color": { + "version": "3.2.3", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-3.2.3.tgz", + "integrity": "sha1-ZawFBLOVQXHYpklGsq48u4pfVPY=", + "dev": true + } + } + }, + "postcss-normalize-charset": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/postcss-normalize-charset/-/postcss-normalize-charset-1.1.1.tgz", + "integrity": "sha1-757nEhLX/nWceO0WL2HtYrXLk/E=", + "dev": true + }, + "postcss-normalize-url": { + "version": "3.0.8", + "resolved": "https://registry.npmjs.org/postcss-normalize-url/-/postcss-normalize-url-3.0.8.tgz", + "integrity": "sha1-EI90s/L82viRov+j6kWSJ5/HgiI=", + "dev": true + }, + "postcss-ordered-values": { + "version": "2.2.3", + "resolved": "https://registry.npmjs.org/postcss-ordered-values/-/postcss-ordered-values-2.2.3.tgz", + "integrity": "sha1-7sbCpntsQSqNsgQud/6NpD+VwR0=", + "dev": true + }, + "postcss-reduce-idents": { + "version": "2.4.0", + "resolved": "https://registry.npmjs.org/postcss-reduce-idents/-/postcss-reduce-idents-2.4.0.tgz", + "integrity": "sha1-wsbSDMlYKE9qv75j92Cb9AkFmtM=", + "dev": true + }, + "postcss-reduce-initial": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/postcss-reduce-initial/-/postcss-reduce-initial-1.0.1.tgz", + "integrity": "sha1-aPgGlfBF0IJjqHmtJA343WT2ROo=", + "dev": true + }, + "postcss-reduce-transforms": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/postcss-reduce-transforms/-/postcss-reduce-transforms-1.0.4.tgz", + "integrity": "sha1-/3b02CEkN7McKYpC0uFEQCV3GuE=", + "dev": true + }, + "postcss-selector-parser": { + "version": "2.2.3", + "resolved": "https://registry.npmjs.org/postcss-selector-parser/-/postcss-selector-parser-2.2.3.tgz", + "integrity": "sha1-+UN3iGBsPJrO4W/+jYsWKX8nu5A=", + "dev": true + }, + "postcss-svgo": { + "version": "2.1.6", + "resolved": "https://registry.npmjs.org/postcss-svgo/-/postcss-svgo-2.1.6.tgz", + "integrity": "sha1-tt8YqmE7Zm4TPwittSGcJoSsEI0=", + "dev": true + }, + "postcss-unique-selectors": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/postcss-unique-selectors/-/postcss-unique-selectors-2.0.2.tgz", + "integrity": "sha1-mB1X0p3csz57Hf4f1DuGSfkzyh0=", + "dev": true + }, + "postcss-value-parser": { + "version": "3.3.0", + "resolved": "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-3.3.0.tgz", + "integrity": "sha1-h/OPnxj3dKSrTIojL1xc6IcqnRU=", + "dev": true + }, + "postcss-zindex": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/postcss-zindex/-/postcss-zindex-2.2.0.tgz", + "integrity": "sha1-0hCd3AVbka9n/EyzsCWUZjnSryI=", + "dev": true + }, + "prelude-ls": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.1.2.tgz", + "integrity": "sha1-IZMqVJ9eUv/ZqCf1cOBL5iqX2lQ=", + "dev": true + }, + "prepend-http": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/prepend-http/-/prepend-http-1.0.4.tgz", + "integrity": "sha1-1PRWKwzjaW5BrFLQ4ALlemNdxtw=", + "dev": true + }, + "preserve": { + "version": "0.2.0", + "resolved": "https://registry.npmjs.org/preserve/-/preserve-0.2.0.tgz", + "integrity": "sha1-gV7R9uvGWSb4ZbMQwHE7yzMVzks=", + "dev": true + }, + "pretty-error": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/pretty-error/-/pretty-error-2.1.0.tgz", + "integrity": "sha1-h/Tp1waiTIfWy+6fq+wAH8+Mddg=", + "dev": true + }, + "private": { + "version": "0.1.7", + "resolved": "https://registry.npmjs.org/private/-/private-0.1.7.tgz", + "integrity": "sha1-aM5eih7woju1cMwoU3tTMqumPvE=", + "dev": true + }, + "process": { + "version": "0.11.10", + "resolved": "https://registry.npmjs.org/process/-/process-0.11.10.tgz", + "integrity": "sha1-czIwDoQBYb2j5podHZGn1LwW8YI=", + "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=", + "dev": true + }, + "progress": { + "version": "1.1.8", + "resolved": "https://registry.npmjs.org/progress/-/progress-1.1.8.tgz", + "integrity": "sha1-4mDHj2Fhzdmw5WzD4Khd4Xx6V74=", + "dev": true + }, + "promise": { + "version": "6.1.0", + "resolved": "https://registry.npmjs.org/promise/-/promise-6.1.0.tgz", + "integrity": "sha1-LOcp9rlLRcJoka0GAsXJDgTG7vY=", + "dev": true + }, + "proto-list": { + "version": "1.2.4", + "resolved": "https://registry.npmjs.org/proto-list/-/proto-list-1.2.4.tgz", + "integrity": "sha1-IS1b/hMYMGpCD2QCuOJv85ZHqEk=", + "dev": true + }, + "proxy-addr": { + "version": "1.1.4", + "resolved": "https://registry.npmjs.org/proxy-addr/-/proxy-addr-1.1.4.tgz", + "integrity": "sha1-J+VF9pYKRKYn2bREZ+NcG2tM4vM=", + "dev": true + }, + "prr": { + "version": "0.0.0", + "resolved": "https://registry.npmjs.org/prr/-/prr-0.0.0.tgz", + "integrity": "sha1-GoS4WQgyVQFBGFPQCB7j+obikmo=", + "dev": true + }, + "pseudomap": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/pseudomap/-/pseudomap-1.0.2.tgz", + "integrity": "sha1-8FKijacOYYkX7wqKw0wa5aaChrM=", + "dev": true + }, + "punycode": { + "version": "1.4.1", + "resolved": "https://registry.npmjs.org/punycode/-/punycode-1.4.1.tgz", + "integrity": "sha1-wNWmOycYgArY4esPpSachN1BhF4=", + "dev": true + }, + "q": { + "version": "1.5.0", + "resolved": "https://registry.npmjs.org/q/-/q-1.5.0.tgz", + "integrity": "sha1-3QG6ydBtMObyGa7LglPunr3DCPE=", + "dev": true + }, + "qs": { + "version": "6.4.0", + "resolved": "https://registry.npmjs.org/qs/-/qs-6.4.0.tgz", + "integrity": "sha1-E+JtKK1rD/qpExLNO/cI7TUecjM=", + "dev": true + }, + "query-string": { + "version": "4.3.4", + "resolved": "https://registry.npmjs.org/query-string/-/query-string-4.3.4.tgz", + "integrity": "sha1-u7aTucqRXCMlFbIosaArYJBD2+s=", + "dev": true + }, + "querystring": { + "version": "0.2.0", + "resolved": "https://registry.npmjs.org/querystring/-/querystring-0.2.0.tgz", + "integrity": "sha1-sgmEkgO7Jd+CDadW50cAWHhSFiA=", + "dev": true + }, + "querystring-es3": { + "version": "0.2.1", + "resolved": "https://registry.npmjs.org/querystring-es3/-/querystring-es3-0.2.1.tgz", + "integrity": "sha1-nsYfeQSYdXB9aUFFlv2Qek1xHnM=", + "dev": true + }, + "randomatic": { + "version": "1.1.7", + "resolved": "https://registry.npmjs.org/randomatic/-/randomatic-1.1.7.tgz", + "integrity": "sha512-D5JUjPyJbaJDkuAazpVnSfVkLlpeO3wDlPROTMLGKG1zMFNFRgrciKo1ltz/AzNTkqE0HzDx655QOL51N06how==", + "dev": true, + "dependencies": { + "is-number": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/is-number/-/is-number-3.0.0.tgz", + "integrity": "sha1-JP1iAaR4LPUFYcgQJ2r8fRLXEZU=", + "dev": true, + "dependencies": { + "kind-of": { + "version": "3.2.2", + "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", + "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", + "dev": true + } + } + }, + "kind-of": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-4.0.0.tgz", + "integrity": "sha1-IIE989cSkosgc3hpGkUGb65y3Vc=", + "dev": true + } + } + }, + "range-parser": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/range-parser/-/range-parser-1.2.0.tgz", + "integrity": "sha1-9JvmtIeJTdxA3MlKMi9hEJLgDV4=", + "dev": true + }, + "read-pkg": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/read-pkg/-/read-pkg-1.1.0.tgz", + "integrity": "sha1-9f+qXs0pyzHAR0vKfXVra7KePyg=", + "dev": true + }, + "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=", + "dev": true + }, + "readable-stream": { + "version": "2.2.11", + "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.2.11.tgz", + "integrity": "sha512-h+8+r3MKEhkiVrwdKL8aWs1oc1VvBu33ueshOvS26RsZQ3Amhx/oO3TKe4lApSV9ueY6as8EAh7mtuFjdlhg9Q==", + "dev": true + }, + "readdirp": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-2.1.0.tgz", + "integrity": "sha1-TtCtBg3zBzMAxIRANz9y0cxkLXg=", + "dev": true + }, + "readline2": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/readline2/-/readline2-1.0.1.tgz", + "integrity": "sha1-QQWWCP/BVHV7cV2ZidGZ/783LjU=", + "dev": true + }, + "recast": { + "version": "0.11.23", + "resolved": "https://registry.npmjs.org/recast/-/recast-0.11.23.tgz", + "integrity": "sha1-RR/TAEqx5N+bTktmN2sqIZEkYtM=", + "dev": true, + "dependencies": { + "esprima": { + "version": "3.1.3", + "resolved": "https://registry.npmjs.org/esprima/-/esprima-3.1.3.tgz", + "integrity": "sha1-/cpRzuYTOJXjyI1TXOSdv/YqRjM=", + "dev": true + } + } + }, + "rechoir": { + "version": "0.6.2", + "resolved": "https://registry.npmjs.org/rechoir/-/rechoir-0.6.2.tgz", + "integrity": "sha1-hSBLVNuoLVdC4oyWdW70OvUOM4Q=", + "dev": true + }, + "redent": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/redent/-/redent-1.0.0.tgz", + "integrity": "sha1-z5Fqsf1fHxbfsggi3W7H9zDCr94=", + "dev": true + }, + "reduce-css-calc": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/reduce-css-calc/-/reduce-css-calc-1.3.0.tgz", + "integrity": "sha1-dHyRTgSWFKTJz7umKYca0dKSdxY=", + "dev": true, + "dependencies": { + "balanced-match": { + "version": "0.4.2", + "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-0.4.2.tgz", + "integrity": "sha1-yz8+PHMtwPAe5wtAPzAuYddwmDg=", + "dev": true + } + } + }, + "reduce-function-call": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/reduce-function-call/-/reduce-function-call-1.0.2.tgz", + "integrity": "sha1-WiAL+S4ON3UXUv5FsKszD9S2vpk=", + "dev": true, + "dependencies": { + "balanced-match": { + "version": "0.4.2", + "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-0.4.2.tgz", + "integrity": "sha1-yz8+PHMtwPAe5wtAPzAuYddwmDg=", + "dev": true + } + } + }, + "regenerate": { + "version": "1.3.2", + "resolved": "https://registry.npmjs.org/regenerate/-/regenerate-1.3.2.tgz", + "integrity": "sha1-0ZQcZ7rUN+G+dkM63Vs4X5WxkmA=", + "dev": true + }, + "regenerator-runtime": { + "version": "0.10.5", + "resolved": "https://registry.npmjs.org/regenerator-runtime/-/regenerator-runtime-0.10.5.tgz", + "integrity": "sha1-M2w+/BIgrc7dosn6tntaeVWjNlg=", + "dev": true + }, + "regenerator-transform": { + "version": "0.9.11", + "resolved": "https://registry.npmjs.org/regenerator-transform/-/regenerator-transform-0.9.11.tgz", + "integrity": "sha1-On0GdSDLe3F2dp61/4aGkb7+EoM=", + "dev": true + }, + "regex-cache": { + "version": "0.4.3", + "resolved": "https://registry.npmjs.org/regex-cache/-/regex-cache-0.4.3.tgz", + "integrity": "sha1-mxpsNdTQ3871cRrmUejp09cRQUU=", + "dev": true + }, + "regexpu-core": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/regexpu-core/-/regexpu-core-2.0.0.tgz", + "integrity": "sha1-SdA4g3uNz4v6W5pCE5k45uoq4kA=", + "dev": true + }, + "regjsgen": { + "version": "0.2.0", + "resolved": "https://registry.npmjs.org/regjsgen/-/regjsgen-0.2.0.tgz", + "integrity": "sha1-bAFq3qxVT3WCP+N6wFuS1aTtsfc=", + "dev": true + }, + "regjsparser": { + "version": "0.1.5", + "resolved": "https://registry.npmjs.org/regjsparser/-/regjsparser-0.1.5.tgz", + "integrity": "sha1-fuj4Tcb6eS0/0K4ijSS9lJ6tIFw=", + "dev": true, + "dependencies": { + "jsesc": { + "version": "0.5.0", + "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-0.5.0.tgz", + "integrity": "sha1-597mbjXW/Bb3EP6R1c9p9w8IkR0=", + "dev": true + } + } + }, + "relateurl": { + "version": "0.2.7", + "resolved": "https://registry.npmjs.org/relateurl/-/relateurl-0.2.7.tgz", + "integrity": "sha1-VNvzd+UUQKypCkzSdGANP/LYiKk=", + "dev": true + }, + "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=", + "dev": true + }, + "renderkid": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/renderkid/-/renderkid-2.0.1.tgz", + "integrity": "sha1-iYyr/Ivt5Le5ETWj/9Mj5YwNsxk=", + "dev": true, + "dependencies": { + "domhandler": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/domhandler/-/domhandler-2.1.0.tgz", + "integrity": "sha1-0mRvXlf2w7qxHPbLBdPArPdBJZQ=", + "dev": true + }, + "domutils": { + "version": "1.1.6", + "resolved": "https://registry.npmjs.org/domutils/-/domutils-1.1.6.tgz", + "integrity": "sha1-vdw94Jm5ou+sxRxiPyj0FuzFdIU=", + "dev": true + }, + "htmlparser2": { + "version": "3.3.0", + "resolved": "https://registry.npmjs.org/htmlparser2/-/htmlparser2-3.3.0.tgz", + "integrity": "sha1-zHDQWln2VC5D8OaFyYLhTJJKnv4=", + "dev": true + }, + "isarray": { + "version": "0.0.1", + "resolved": "https://registry.npmjs.org/isarray/-/isarray-0.0.1.tgz", + "integrity": "sha1-ihis/Kmo9Bd+Cav8YDiTmwXR7t8=", + "dev": true + }, + "readable-stream": { + "version": "1.0.34", + "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-1.0.34.tgz", + "integrity": "sha1-Elgg40vIQtLyqq+v5MKRbuMsFXw=", + "dev": true + }, + "string_decoder": { + "version": "0.10.31", + "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-0.10.31.tgz", + "integrity": "sha1-YuIDvEF2bGwoyfyEMB2rHFMQ+pQ=", + "dev": true + }, + "utila": { + "version": "0.3.3", + "resolved": "https://registry.npmjs.org/utila/-/utila-0.3.3.tgz", + "integrity": "sha1-1+jn1+MJEHCSsF+NloiCTWM6QiY=", + "dev": true + } + } + }, + "repeat-element": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/repeat-element/-/repeat-element-1.1.2.tgz", + "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=", + "dev": true + }, + "repeating": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/repeating/-/repeating-2.0.1.tgz", + "integrity": "sha1-UhTFOpJtNVJwdSf7q0FdvAjQbdo=", + "dev": true + }, + "request": { + "version": "2.81.0", + "resolved": "https://registry.npmjs.org/request/-/request-2.81.0.tgz", + "integrity": "sha1-xpKJRqDgbF+Nb4qTM0af/aRimKA=", + "dev": true + }, + "require-directory": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz", + "integrity": "sha1-jGStX9MNqxyXbiNE/+f3kqam30I=", + "dev": true + }, + "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=", + "dev": true + }, + "require-uncached": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/require-uncached/-/require-uncached-1.0.3.tgz", + "integrity": "sha1-Tg1W1slmL9MeQwEcS5WqSZVUIdM=", + "dev": true + }, + "requires-port": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/requires-port/-/requires-port-1.0.0.tgz", + "integrity": "sha1-kl0mAdOaxIXgkc8NpcbmlNw9yv8=", + "dev": true + }, + "resolve": { + "version": "1.3.3", + "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.3.3.tgz", + "integrity": "sha1-ZVkHw0aahoDcLeOidaj91paR8OU=", + "dev": true + }, + "resolve-from": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-1.0.1.tgz", + "integrity": "sha1-Jsv+k10a7uq7Kbw/5a6wHpPUQiY=", + "dev": true + }, + "restore-cursor": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/restore-cursor/-/restore-cursor-1.0.1.tgz", + "integrity": "sha1-NGYfRohjJ/7SmRR5FSJS35LapUE=", + "dev": true + }, + "right-align": { + "version": "0.1.3", + "resolved": "https://registry.npmjs.org/right-align/-/right-align-0.1.3.tgz", + "integrity": "sha1-YTObci/mo1FWiSENJOFMlhSGE+8=", + "dev": true + }, + "rimraf": { + "version": "2.6.1", + "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.6.1.tgz", + "integrity": "sha1-wjOOxkPfeht/5cVPqG9XQopV8z0=", + "dev": true + }, + "ripemd160": { + "version": "0.2.0", + "resolved": "https://registry.npmjs.org/ripemd160/-/ripemd160-0.2.0.tgz", + "integrity": "sha1-K/GYveFnys+lHAqSjoS2i74XH84=", + "dev": true + }, + "run-async": { + "version": "0.1.0", + "resolved": "https://registry.npmjs.org/run-async/-/run-async-0.1.0.tgz", + "integrity": "sha1-yK1KXhEGYeQCp9IbUw4AnyX444k=", + "dev": true + }, + "rx-lite": { + "version": "3.1.2", + "resolved": "https://registry.npmjs.org/rx-lite/-/rx-lite-3.1.2.tgz", + "integrity": "sha1-Gc5QLKVyZl87ZHsQk5+X/RYV8QI=", + "dev": true + }, + "safe-buffer": { + "version": "5.0.1", + "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.0.1.tgz", + "integrity": "sha1-0mPKVGls2KMGtcplUekt5XkY++c=", + "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=", + "dev": true, + "dependencies": { + "camelcase": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-3.0.0.tgz", + "integrity": "sha1-MvxLn82vhF/N9+c7uXysImHwqwo=", + "dev": true + }, + "cliui": { + "version": "3.2.0", + "resolved": "https://registry.npmjs.org/cliui/-/cliui-3.2.0.tgz", + "integrity": "sha1-EgYBU3qRbSmUD5NNo7SNWFo5IT0=", + "dev": true + }, + "yargs": { + "version": "7.1.0", + "resolved": "https://registry.npmjs.org/yargs/-/yargs-7.1.0.tgz", + "integrity": "sha1-a6MY6xaWFyf10oT46gA+jWFU0Mg=", + "dev": true + } + } + }, + "sass-loader": { + "version": "4.1.1", + "resolved": "https://registry.npmjs.org/sass-loader/-/sass-loader-4.1.1.tgz", + "integrity": "sha1-ee+UaM8L9kbClSnh8sumvW5Rx7w=", + "dev": true, + "dependencies": { + "async": { + "version": "2.4.1", + "resolved": "https://registry.npmjs.org/async/-/async-2.4.1.tgz", + "integrity": "sha1-YqVrJ5yYoR0JhwlqAcw+6463u9c=", + "dev": true + } + } + }, + "sax": { + "version": "1.2.2", + "resolved": "https://registry.npmjs.org/sax/-/sax-1.2.2.tgz", + "integrity": "sha1-/YYxojvHgmvvXYcb24c3jJVkeCg=", + "dev": true + }, + "scss-tokenizer": { + "version": "0.2.3", + "resolved": "https://registry.npmjs.org/scss-tokenizer/-/scss-tokenizer-0.2.3.tgz", + "integrity": "sha1-jrBtualyMzOCTT9VMGQRSYR85dE=", + "dev": true, + "dependencies": { + "source-map": { + "version": "0.4.4", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.4.4.tgz", + "integrity": "sha1-66T12pwNyZneaAMti092FzZSA2s=", + "dev": true + } + } + }, + "semver": { + "version": "5.3.0", + "resolved": "https://registry.npmjs.org/semver/-/semver-5.3.0.tgz", + "integrity": "sha1-myzl094C0XxgEq0yaqa00M9U+U8=", + "dev": true + }, + "send": { + "version": "0.15.3", + "resolved": "https://registry.npmjs.org/send/-/send-0.15.3.tgz", + "integrity": "sha1-UBP5+ZAj31DRvZiSwZ4979HVMwk=", + "dev": true, + "dependencies": { + "debug": { + "version": "2.6.7", + "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.7.tgz", + "integrity": "sha1-krrR9tBbu2u6Isyoi80OyJTChh4=", + "dev": true + } + } + }, + "sentence-case": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/sentence-case/-/sentence-case-2.1.1.tgz", + "integrity": "sha1-H24t2jnBaL+S0T+G1KkYkz9mftQ=", + "dev": true + }, + "serve-static": { + "version": "1.12.3", + "resolved": "https://registry.npmjs.org/serve-static/-/serve-static-1.12.3.tgz", + "integrity": "sha1-n0uhni8wMMVH+K+ZEHg47DjVseI=", + "dev": true + }, + "set-blocking": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/set-blocking/-/set-blocking-2.0.0.tgz", + "integrity": "sha1-BF+XgtARrppoA93TgrJDkrPYkPc=", + "dev": true + }, + "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=", + "dev": true + }, + "setimmediate": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/setimmediate/-/setimmediate-1.0.5.tgz", + "integrity": "sha1-KQy7Iy4waULX1+qbg3Mqt4VvgoU=", + "dev": true + }, + "setprototypeof": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.0.3.tgz", + "integrity": "sha1-ZlZ+NwQ+608E2RvWWMDL77VbjgQ=", + "dev": true + }, + "sha.js": { + "version": "2.2.6", + "resolved": "https://registry.npmjs.org/sha.js/-/sha.js-2.2.6.tgz", + "integrity": "sha1-F93t3F9yL7ZlAWWIlUYZd4ZzFbo=", + "dev": true + }, + "shelljs": { + "version": "0.7.8", + "resolved": "https://registry.npmjs.org/shelljs/-/shelljs-0.7.8.tgz", + "integrity": "sha1-3svPh0sNHl+3LhSxZKloMEjprLM=", + "dev": true + }, + "sigmund": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/sigmund/-/sigmund-1.0.1.tgz", + "integrity": "sha1-P/IfGYytIXX587eBhT/ZTQ0ZtZA=", + "dev": true + }, + "signal-exit": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.2.tgz", + "integrity": "sha1-tf3AjxKH6hF4Yo5BXiUTK3NkbG0=", + "dev": true + }, + "slash": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/slash/-/slash-1.0.0.tgz", + "integrity": "sha1-xB8vbDn8FtHNF61LXYlhFK5HDVU=", + "dev": true + }, + "slice-ansi": { + "version": "0.0.4", + "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-0.0.4.tgz", + "integrity": "sha1-7b+JA/ZvfOL46v1s7tZeJkyDGzU=", + "dev": true + }, + "snake-case": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/snake-case/-/snake-case-2.1.0.tgz", + "integrity": "sha1-Qb2xtz8w7GagTU4srRt2OH1NbZ8=", + "dev": true + }, + "sntp": { + "version": "1.0.9", + "resolved": "https://registry.npmjs.org/sntp/-/sntp-1.0.9.tgz", + "integrity": "sha1-ZUEYTMkK7qbG57NeJlkIJEPGYZg=", + "dev": true + }, + "sort-keys": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/sort-keys/-/sort-keys-1.1.2.tgz", + "integrity": "sha1-RBttTTRnmPG05J6JIK37oOVD+a0=", + "dev": true + }, + "source-list-map": { + "version": "0.1.8", + "resolved": "https://registry.npmjs.org/source-list-map/-/source-list-map-0.1.8.tgz", + "integrity": "sha1-xVCyq1Qn9rPyH1r+rYjE9Vh7IQY=", + "dev": true + }, + "source-map": { + "version": "0.5.6", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.5.6.tgz", + "integrity": "sha1-dc449SvwczxafwwRjYEzSiu19BI=", + "dev": true + }, + "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=", + "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=", + "dev": true + }, + "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=", + "dev": true + }, + "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=", + "dev": true + }, + "sprintf-js": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz", + "integrity": "sha1-BOaSb2YolTVPPdAVIDYzuFcpfiw=", + "dev": true + }, + "sshpk": { + "version": "1.13.1", + "resolved": "https://registry.npmjs.org/sshpk/-/sshpk-1.13.1.tgz", + "integrity": "sha1-US322mKHFEMW3EwY/hzx2UBzm+M=", + "dev": true, + "dependencies": { + "assert-plus": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/assert-plus/-/assert-plus-1.0.0.tgz", + "integrity": "sha1-8S4PPF13sLHN2RRpQuTpbB5N1SU=", + "dev": true + } + } + }, + "statuses": { + "version": "1.3.1", + "resolved": "https://registry.npmjs.org/statuses/-/statuses-1.3.1.tgz", + "integrity": "sha1-+vUbnrdKrvOzrPStX2Gr8ky3uT4=", + "dev": true + }, + "stream-browserify": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/stream-browserify/-/stream-browserify-2.0.1.tgz", + "integrity": "sha1-ZiZu5fm9uZQKTkUUyvtDu3Hlyds=", + "dev": true + }, + "stream-http": { + "version": "2.7.2", + "resolved": "https://registry.npmjs.org/stream-http/-/stream-http-2.7.2.tgz", + "integrity": "sha512-c0yTD2rbQzXtSsFSVhtpvY/vS6u066PcXOX9kBB3mSO76RiUQzL340uJkGBWnlBg4/HZzqiUXtaVA7wcRcJgEw==", + "dev": true + }, + "strict-uri-encode": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/strict-uri-encode/-/strict-uri-encode-1.1.0.tgz", + "integrity": "sha1-J5siXfHVgrH1TmWt3UNS4Y+qBxM=", + "dev": true + }, + "string_decoder": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.0.2.tgz", + "integrity": "sha1-sp4fThEl+pehA4K4pTNze3SR4Xk=", + "dev": true + }, + "string-width": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/string-width/-/string-width-1.0.2.tgz", + "integrity": "sha1-EYvfW4zcUaKn5w0hHgfisLmxB9M=", + "dev": true + }, + "stringstream": { + "version": "0.0.5", + "resolved": "https://registry.npmjs.org/stringstream/-/stringstream-0.0.5.tgz", + "integrity": "sha1-TkhM1N5aC7vuGORjB3EKioFiGHg=", + "dev": true + }, + "strip-ansi": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-3.0.1.tgz", + "integrity": "sha1-ajhfuIU9lS1f8F0Oiq+UJ43GPc8=", + "dev": true + }, + "strip-bom": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-3.0.0.tgz", + "integrity": "sha1-IzTBjpx1n3vdVv3vfprj1YjmjtM=", + "dev": true + }, + "strip-indent": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/strip-indent/-/strip-indent-1.0.1.tgz", + "integrity": "sha1-DHlipq3vp7vUrDZkYKY4VSrhoKI=", + "dev": true + }, + "strip-json-comments": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-2.0.1.tgz", + "integrity": "sha1-PFMZQukIwml8DsNEhYwobHygpgo=", + "dev": true + }, + "stylus": { + "version": "0.54.5", + "resolved": "https://registry.npmjs.org/stylus/-/stylus-0.54.5.tgz", + "integrity": "sha1-QrlWCTHKcJDOhRWnmLqeaqPW3Hk=", + "dev": true, + "dependencies": { + "css-parse": { + "version": "1.7.0", + "resolved": "https://registry.npmjs.org/css-parse/-/css-parse-1.7.0.tgz", + "integrity": "sha1-Mh9s9zeCpv91ERE5D8BeLGV9jJs=", + "dev": true + }, + "glob": { + "version": "7.0.6", + "resolved": "https://registry.npmjs.org/glob/-/glob-7.0.6.tgz", + "integrity": "sha1-IRuvr0nlJbjNkyYNFKsTYVKz9Xo=", + "dev": true + }, + "sax": { + "version": "0.5.8", + "resolved": "https://registry.npmjs.org/sax/-/sax-0.5.8.tgz", + "integrity": "sha1-1HLbIo6zMcJQaw6MFVJK25OdEsE=", + "dev": true + }, + "source-map": { + "version": "0.1.43", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.1.43.tgz", + "integrity": "sha1-wkvBRspRfBRx9drL4lcbK3+eM0Y=", + "dev": true + } + } + }, + "stylus-loader": { + "version": "2.5.1", + "resolved": "https://registry.npmjs.org/stylus-loader/-/stylus-loader-2.5.1.tgz", + "integrity": "sha1-1a2KfglYrcErhYHnuxabmmHVQhY=", + "dev": true + }, + "supports-color": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-2.0.0.tgz", + "integrity": "sha1-U10EXOa2Nj+kARcIRimZXp3zJMc=", + "dev": true + }, + "svgo": { + "version": "0.7.2", + "resolved": "https://registry.npmjs.org/svgo/-/svgo-0.7.2.tgz", + "integrity": "sha1-n1dyQTlSE1xv779Ar+ak+qiLS7U=", + "dev": true + }, + "swap-case": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/swap-case/-/swap-case-1.1.2.tgz", + "integrity": "sha1-w5IDpFhzhfrTyFCgvRvK+ggZdOM=", + "dev": true + }, + "table": { + "version": "3.8.3", + "resolved": "https://registry.npmjs.org/table/-/table-3.8.3.tgz", + "integrity": "sha1-K7xULw/amGGnVdOUf+/Ys/UThV8=", + "dev": true, + "dependencies": { + "is-fullwidth-code-point": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", + "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=", + "dev": true + }, + "string-width": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/string-width/-/string-width-2.0.0.tgz", + "integrity": "sha1-Y1xUNsxypuDDh87KJ41OLuxSaH4=", + "dev": true + } + } + }, + "tapable": { + "version": "0.1.10", + "resolved": "https://registry.npmjs.org/tapable/-/tapable-0.1.10.tgz", + "integrity": "sha1-KcNXB8K3DlDQdIK10gLo7URtr9Q=", + "dev": true + }, + "tar": { + "version": "2.2.1", + "resolved": "https://registry.npmjs.org/tar/-/tar-2.2.1.tgz", + "integrity": "sha1-jk0qJWwOIYXGsYrWlK7JaLg8sdE=", + "dev": true + }, + "text-table": { + "version": "0.2.0", + "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz", + "integrity": "sha1-f17oI66AUgfACvLfSoTsP8+lcLQ=", + "dev": true + }, + "through": { + "version": "2.3.8", + "resolved": "https://registry.npmjs.org/through/-/through-2.3.8.tgz", + "integrity": "sha1-DdTJ/6q8NXlgsbckEV1+Doai4fU=", + "dev": true + }, + "timers-browserify": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/timers-browserify/-/timers-browserify-2.0.2.tgz", + "integrity": "sha1-q0iDz1l9zVCvIRNJoA+8pWrIa4Y=", + "dev": true + }, + "title-case": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/title-case/-/title-case-2.1.1.tgz", + "integrity": "sha1-PhJyFtpY0rxb7PE3q5Ha46fNj6o=", + "dev": true + }, + "to-arraybuffer": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/to-arraybuffer/-/to-arraybuffer-1.0.1.tgz", + "integrity": "sha1-fSKbH8xjfkZsoIEYCDanqr/4P0M=", + "dev": true + }, + "to-fast-properties": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/to-fast-properties/-/to-fast-properties-1.0.3.tgz", + "integrity": "sha1-uDVx+k2MJbguIxsG46MFXeTKGkc=", + "dev": true + }, + "toposort": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/toposort/-/toposort-1.0.3.tgz", + "integrity": "sha1-8CzYp0vYvi/A6YYRw7rLlaFxhpw=", + "dev": true + }, + "tough-cookie": { + "version": "2.3.2", + "resolved": "https://registry.npmjs.org/tough-cookie/-/tough-cookie-2.3.2.tgz", + "integrity": "sha1-8IH3bkyFcg5sN6X6ztc3FQ2EByo=", + "dev": true + }, + "transformers": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/transformers/-/transformers-2.1.0.tgz", + "integrity": "sha1-XSPLNVYd2F3Gf7hIIwm0fVPM6ac=", + "dev": true, + "dependencies": { + "is-promise": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/is-promise/-/is-promise-1.0.1.tgz", + "integrity": "sha1-MVc3YcBX4zwukaq56W2gjO++duU=", + "dev": true + }, + "optimist": { + "version": "0.3.7", + "resolved": "https://registry.npmjs.org/optimist/-/optimist-0.3.7.tgz", + "integrity": "sha1-yQlBrVnkJzMokjB00s8ufLxuwNk=", + "dev": true + }, + "promise": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/promise/-/promise-2.0.0.tgz", + "integrity": "sha1-RmSKqdYFr10ucMMCS/WUNtoCuA4=", + "dev": true + }, + "source-map": { + "version": "0.1.43", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.1.43.tgz", + "integrity": "sha1-wkvBRspRfBRx9drL4lcbK3+eM0Y=", + "dev": true + }, + "uglify-js": { + "version": "2.2.5", + "resolved": "https://registry.npmjs.org/uglify-js/-/uglify-js-2.2.5.tgz", + "integrity": "sha1-puAqcNg5eSuXgEiLe4sYTAlcmcc=", + "dev": true + }, + "wordwrap": { + "version": "0.0.3", + "resolved": "https://registry.npmjs.org/wordwrap/-/wordwrap-0.0.3.tgz", + "integrity": "sha1-o9XabNXAvAAI03I0u68b7WMFkQc=", + "dev": true + } + } + }, + "trim-newlines": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/trim-newlines/-/trim-newlines-1.0.0.tgz", + "integrity": "sha1-WIeWa7WCpFA6QetST301ARgVphM=", + "dev": true + }, + "trim-right": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/trim-right/-/trim-right-1.0.1.tgz", + "integrity": "sha1-yy4SAwZ+DI3h9hQJS5/kVwTqYAM=", + "dev": true + }, + "tryit": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/tryit/-/tryit-1.0.3.tgz", + "integrity": "sha1-OTvnMKlEb9Hq1tpZoBQwjzbCics=", + "dev": true + }, + "tty-browserify": { + "version": "0.0.0", + "resolved": "https://registry.npmjs.org/tty-browserify/-/tty-browserify-0.0.0.tgz", + "integrity": "sha1-oVe6QC2iTpv5V/mqadUk7tQpAaY=", + "dev": true + }, + "tunnel-agent": { + "version": "0.6.0", + "resolved": "https://registry.npmjs.org/tunnel-agent/-/tunnel-agent-0.6.0.tgz", + "integrity": "sha1-J6XeoGs2sEoKmWZ3SykIaPD8QP0=", + "dev": true + }, + "tweetnacl": { + "version": "0.14.5", + "resolved": "https://registry.npmjs.org/tweetnacl/-/tweetnacl-0.14.5.tgz", + "integrity": "sha1-WuaBd/GS1EViadEIr6k/+HQ/T2Q=", + "dev": true, + "optional": true + }, + "type-check": { + "version": "0.3.2", + "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.3.2.tgz", + "integrity": "sha1-WITKtRLPHTVeP7eE8wgEsrUg23I=", + "dev": true + }, + "type-is": { + "version": "1.6.15", + "resolved": "https://registry.npmjs.org/type-is/-/type-is-1.6.15.tgz", + "integrity": "sha1-yrEPtJCeRByChC6v4a1kbIGARBA=", + "dev": true + }, + "typedarray": { + "version": "0.0.6", + "resolved": "https://registry.npmjs.org/typedarray/-/typedarray-0.0.6.tgz", + "integrity": "sha1-hnrHTjhkGHsdPUfZlqeOxciDB3c=", + "dev": true + }, + "uglify-js": { + "version": "3.0.16", + "resolved": "https://registry.npmjs.org/uglify-js/-/uglify-js-3.0.16.tgz", + "integrity": "sha1-/jlMZwinn/vyHKFdZZGxYzRQGuw=", + "dev": true + }, + "uglify-to-browserify": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/uglify-to-browserify/-/uglify-to-browserify-1.0.2.tgz", + "integrity": "sha1-bgkk1r2mta/jSeOabWMoUKD4grc=", + "dev": true + }, + "underscore": { + "version": "1.6.0", + "resolved": "https://registry.npmjs.org/underscore/-/underscore-1.6.0.tgz", + "integrity": "sha1-izixDKze9jM3uLJOT/htRa6lKag=", + "dev": true + }, + "uniq": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/uniq/-/uniq-1.0.1.tgz", + "integrity": "sha1-sxxa6CVIRKOoKBVBzisEuGWnNP8=", + "dev": true + }, + "uniqid": { + "version": "4.1.1", + "resolved": "https://registry.npmjs.org/uniqid/-/uniqid-4.1.1.tgz", + "integrity": "sha1-iSIN32t1GuUrX3JISGNShZa7hME=", + "dev": true + }, + "uniqs": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/uniqs/-/uniqs-2.0.0.tgz", + "integrity": "sha1-/+3ks2slKQaW5uFl1KWe25mOawI=", + "dev": true + }, + "unpipe": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz", + "integrity": "sha1-sr9O6FFKrmFltIF4KdIbLvSZBOw=", + "dev": true + }, + "upper-case": { + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/upper-case/-/upper-case-1.1.3.tgz", + "integrity": "sha1-9rRQHC7EzdJrp4vnIilh3ndiFZg=", + "dev": true + }, + "upper-case-first": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/upper-case-first/-/upper-case-first-1.1.2.tgz", + "integrity": "sha1-XXm+3P8UQZUY/S7bCgUHybaFkRU=", + "dev": true + }, + "url": { + "version": "0.11.0", + "resolved": "https://registry.npmjs.org/url/-/url-0.11.0.tgz", + "integrity": "sha1-ODjpfPxgUh63PFJajlW/3Z4uKPE=", + "dev": true, + "dependencies": { + "punycode": { + "version": "1.3.2", + "resolved": "https://registry.npmjs.org/punycode/-/punycode-1.3.2.tgz", + "integrity": "sha1-llOgNvt8HuQjQvIyXM7v6jkmxI0=", + "dev": true + } + } + }, + "url-loader": { + "version": "0.5.9", + "resolved": "https://registry.npmjs.org/url-loader/-/url-loader-0.5.9.tgz", + "integrity": "sha512-B7QYFyvv+fOBqBVeefsxv6koWWtjmHaMFT6KZWti4KRw8YUD/hOU+3AECvXuzyVawIBx3z7zQRejXCDSO5kk1Q==", + "dev": true, + "dependencies": { + "loader-utils": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/loader-utils/-/loader-utils-1.1.0.tgz", + "integrity": "sha1-yYrvSIvM7aL/teLeZG1qdUQp9c0=", + "dev": true + } + } + }, + "user-home": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/user-home/-/user-home-2.0.0.tgz", + "integrity": "sha1-nHC/2Babwdy/SGBODwS4tJzenp8=", + "dev": true + }, + "util": { + "version": "0.10.3", + "resolved": "https://registry.npmjs.org/util/-/util-0.10.3.tgz", + "integrity": "sha1-evsa/lCAUkZInj23/g7TeTNqwPk=", + "dev": true, + "dependencies": { + "inherits": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.1.tgz", + "integrity": "sha1-sX0I0ya0Qj5Wjv9xn5GwscvfafE=", + "dev": true + } + } + }, + "util-deprecate": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", + "integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8=", + "dev": true + }, + "utila": { + "version": "0.4.0", + "resolved": "https://registry.npmjs.org/utila/-/utila-0.4.0.tgz", + "integrity": "sha1-ihagXURWV6Oupe7MWxKk+lN5dyw=", + "dev": true + }, + "utils-merge": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/utils-merge/-/utils-merge-1.0.0.tgz", + "integrity": "sha1-ApT7kiu5N1FTVBxPcJYjHyh8ivg=", + "dev": true + }, + "uuid": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/uuid/-/uuid-3.0.1.tgz", + "integrity": "sha1-ZUS7ot/ajBzxfmKaOjBeK7H+5sE=", + "dev": true + }, + "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=", + "dev": true + }, + "vary": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/vary/-/vary-1.1.1.tgz", + "integrity": "sha1-Z1Neu2lMHVIldFeYRmUyP1h+jTc=", + "dev": true + }, + "vendors": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/vendors/-/vendors-1.0.1.tgz", + "integrity": "sha1-N61zyO5Bf7PVgOeFMSMH0nSEfyI=", + "dev": true + }, + "verror": { + "version": "1.3.6", + "resolved": "https://registry.npmjs.org/verror/-/verror-1.3.6.tgz", + "integrity": "sha1-z/XfEpRtKX0rqu+qJoniW+AcAFw=", + "dev": true + }, + "vm-browserify": { + "version": "0.0.4", + "resolved": "https://registry.npmjs.org/vm-browserify/-/vm-browserify-0.0.4.tgz", + "integrity": "sha1-XX6kW7755Kb/ZflUOOCofDV9WnM=", + "dev": true + }, + "void-elements": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/void-elements/-/void-elements-2.0.1.tgz", + "integrity": "sha1-wGavtYK7HLQSjWDqkjkulNXp2+w=", + "dev": true + }, + "vue": { + "version": "2.3.4", + "resolved": "https://registry.npmjs.org/vue/-/vue-2.3.4.tgz", + "integrity": "sha512-oLCxuVcVQ2inwSbS7B+zfjB6CSjgQ0yyCOzPcg7S5CXeOCbtkaiN5frR6MtwvrveqbG86OsGd9jWf6JsGyQkLw==", + "dev": true + }, + "vue-hot-reload-api": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/vue-hot-reload-api/-/vue-hot-reload-api-2.1.0.tgz", + "integrity": "sha1-nKWKbg35B4VUzhcIaItleHVNht4=", + "dev": true + }, + "vue-html-loader": { + "version": "1.2.4", + "resolved": "https://registry.npmjs.org/vue-html-loader/-/vue-html-loader-1.2.4.tgz", + "integrity": "sha1-VM5Im+BgZckdwqEXMSLz4ATgolM=", + "dev": true, + "dependencies": { + "async": { + "version": "0.2.10", + "resolved": "https://registry.npmjs.org/async/-/async-0.2.10.tgz", + "integrity": "sha1-trvgsGdLnXGXCMo43owjfLUmw9E=", + "dev": true + }, + "clean-css": { + "version": "3.4.27", + "resolved": "https://registry.npmjs.org/clean-css/-/clean-css-3.4.27.tgz", + "integrity": "sha1-re91sxwWD/pdcvTeZ5ZuJmDBolU=", + "dev": true, + "dependencies": { + "commander": { + "version": "2.8.1", + "resolved": "https://registry.npmjs.org/commander/-/commander-2.8.1.tgz", + "integrity": "sha1-Br42f+v9oMMwqh4qBy09yXYkJdQ=", + "dev": true + } + } + }, + "html-minifier": { + "version": "2.1.7", + "resolved": "https://registry.npmjs.org/html-minifier/-/html-minifier-2.1.7.tgz", + "integrity": "sha1-kFHW/LvPIU7TB+GtdPQyu5rWVcw=", + "dev": true + }, + "loader-utils": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/loader-utils/-/loader-utils-1.1.0.tgz", + "integrity": "sha1-yYrvSIvM7aL/teLeZG1qdUQp9c0=", + "dev": true + }, + "source-map": { + "version": "0.4.4", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.4.4.tgz", + "integrity": "sha1-66T12pwNyZneaAMti092FzZSA2s=", + "dev": true + }, + "uglify-js": { + "version": "2.6.4", + "resolved": "https://registry.npmjs.org/uglify-js/-/uglify-js-2.6.4.tgz", + "integrity": "sha1-ZeovswWck5RpLxX+2HwrNsFrmt8=", + "dev": true, + "dependencies": { + "source-map": { + "version": "0.5.6", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.5.6.tgz", + "integrity": "sha1-dc449SvwczxafwwRjYEzSiu19BI=", + "dev": true + } + } + } + } + }, + "vue-loader": { + "version": "9.9.5", + "resolved": "https://registry.npmjs.org/vue-loader/-/vue-loader-9.9.5.tgz", + "integrity": "sha1-CJPjCT6QyPvoUgU7Kw9IVKO/RlE=", + "dev": true + }, + "vue-router": { + "version": "2.5.3", + "resolved": "https://registry.npmjs.org/vue-router/-/vue-router-2.5.3.tgz", + "integrity": "sha1-BzeD9WS2rs5silnGPimNwqq/tRs=", + "dev": true + }, + "vue-style-loader": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/vue-style-loader/-/vue-style-loader-1.0.0.tgz", + "integrity": "sha1-q+t70PRjEwg3QSRNMHnU8URJ4Ek=", + "dev": true + }, + "vue-template-compiler": { + "version": "2.3.4", + "resolved": "https://registry.npmjs.org/vue-template-compiler/-/vue-template-compiler-2.3.4.tgz", + "integrity": "sha512-GezvHn6bw053zIo0TQIjimRpyELjCEOrc5hGHtHUeadbVSdKB9yqY6By9WiYvbFwOZiuMmFpSfjD8VzVibWGtQ==", + "dev": true + }, + "vue-template-es2015-compiler": { + "version": "1.5.2", + "resolved": "https://registry.npmjs.org/vue-template-es2015-compiler/-/vue-template-es2015-compiler-1.5.2.tgz", + "integrity": "sha1-oKbFDJQdKkq9qWPy9CwzesRQ7pU=", + "dev": true + }, + "watchpack": { + "version": "0.2.9", + "resolved": "https://registry.npmjs.org/watchpack/-/watchpack-0.2.9.tgz", + "integrity": "sha1-Yuqkq15bo1/fwBgnVibjwPXj+ws=", + "dev": true, + "dependencies": { + "async": { + "version": "0.9.2", + "resolved": "https://registry.npmjs.org/async/-/async-0.9.2.tgz", + "integrity": "sha1-rqdNXmHB+JlhO/ZL2mbUx48v0X0=", + "dev": true + } + } + }, + "webpack": { + "version": "1.15.0", + "resolved": "https://registry.npmjs.org/webpack/-/webpack-1.15.0.tgz", + "integrity": "sha1-T/MfU9sDM55VFkqdRo7gMklo/pg=", + "dev": true, + "dependencies": { + "acorn": { + "version": "3.3.0", + "resolved": "https://registry.npmjs.org/acorn/-/acorn-3.3.0.tgz", + "integrity": "sha1-ReN/s56No/JbruP/U2niu18iAXo=", + "dev": true + }, + "interpret": { + "version": "0.6.6", + "resolved": "https://registry.npmjs.org/interpret/-/interpret-0.6.6.tgz", + "integrity": "sha1-/s16GOfOXKar+5U+H4YhOknxYls=", + "dev": true + }, + "supports-color": { + "version": "3.2.3", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-3.2.3.tgz", + "integrity": "sha1-ZawFBLOVQXHYpklGsq48u4pfVPY=", + "dev": true + }, + "uglify-js": { + "version": "2.7.5", + "resolved": "https://registry.npmjs.org/uglify-js/-/uglify-js-2.7.5.tgz", + "integrity": "sha1-RhLAx7qu4rp8SH3kkErhIgefLKg=", + "dev": true, + "dependencies": { + "async": { + "version": "0.2.10", + "resolved": "https://registry.npmjs.org/async/-/async-0.2.10.tgz", + "integrity": "sha1-trvgsGdLnXGXCMo43owjfLUmw9E=", + "dev": true + } + } + } + } + }, + "webpack-core": { + "version": "0.6.9", + "resolved": "https://registry.npmjs.org/webpack-core/-/webpack-core-0.6.9.tgz", + "integrity": "sha1-/FcViMhVjad76e+23r3Fo7FyvcI=", + "dev": true, + "dependencies": { + "source-map": { + "version": "0.4.4", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.4.4.tgz", + "integrity": "sha1-66T12pwNyZneaAMti092FzZSA2s=", + "dev": true + } + } + }, + "webpack-dev-middleware": { + "version": "1.10.2", + "resolved": "https://registry.npmjs.org/webpack-dev-middleware/-/webpack-dev-middleware-1.10.2.tgz", + "integrity": "sha1-LiUs4d+wINvaHMs33ybzCrAU29E=", + "dev": true, + "dependencies": { + "memory-fs": { + "version": "0.4.1", + "resolved": "https://registry.npmjs.org/memory-fs/-/memory-fs-0.4.1.tgz", + "integrity": "sha1-OpoguEYlI+RHz7x+i7gO1me/xVI=", + "dev": true + } + } + }, + "webpack-hot-middleware": { + "version": "2.18.0", + "resolved": "https://registry.npmjs.org/webpack-hot-middleware/-/webpack-hot-middleware-2.18.0.tgz", + "integrity": "sha1-oWu1Nbg6aslKeKxevOTzBZ6CdNM=", + "dev": true + }, + "webpack-merge": { + "version": "0.14.1", + "resolved": "https://registry.npmjs.org/webpack-merge/-/webpack-merge-0.14.1.tgz", + "integrity": "sha1-1r/m2TYKAk4ef45jg65zXxc3zSM=", + "dev": true + }, + "webpack-sources": { + "version": "0.1.5", + "resolved": "https://registry.npmjs.org/webpack-sources/-/webpack-sources-0.1.5.tgz", + "integrity": "sha1-qh86vw8NdNtxEcQOUAuE+WZkB1A=", + "dev": true + }, + "when": { + "version": "3.6.4", + "resolved": "https://registry.npmjs.org/when/-/when-3.6.4.tgz", + "integrity": "sha1-RztRfsFZ4rhQBUl6E5g/CVQS404=", + "dev": true + }, + "whet.extend": { + "version": "0.9.9", + "resolved": "https://registry.npmjs.org/whet.extend/-/whet.extend-0.9.9.tgz", + "integrity": "sha1-+HfVv2SMl+WqVC+twW1qJZucEaE=", + "dev": true + }, + "which": { + "version": "1.2.14", + "resolved": "https://registry.npmjs.org/which/-/which-1.2.14.tgz", + "integrity": "sha1-mofEN48D6CfOyvGs31bHNsAcFOU=", + "dev": true + }, + "which-module": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/which-module/-/which-module-1.0.0.tgz", + "integrity": "sha1-u6Y8qGGUiZT/MHc2CJ47lgJsKk8=", + "dev": true + }, + "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==", + "dev": true + }, + "window-size": { + "version": "0.1.0", + "resolved": "https://registry.npmjs.org/window-size/-/window-size-0.1.0.tgz", + "integrity": "sha1-VDjNLqk7IC76Ohn+iIeu58lPnJ0=", + "dev": true + }, + "with": { + "version": "4.0.3", + "resolved": "https://registry.npmjs.org/with/-/with-4.0.3.tgz", + "integrity": "sha1-7v0VTp550sjTQXtkeo8U2f7M4U4=", + "dev": true, + "dependencies": { + "acorn": { + "version": "1.2.2", + "resolved": "https://registry.npmjs.org/acorn/-/acorn-1.2.2.tgz", + "integrity": "sha1-yM4n3grMdtiW0rH6099YjZ6C8BQ=", + "dev": true + } + } + }, + "wordwrap": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/wordwrap/-/wordwrap-1.0.0.tgz", + "integrity": "sha1-J1hIEIkUVqQXHI0CJkQa3pDLyus=", + "dev": true + }, + "wrap-ansi": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-2.1.0.tgz", + "integrity": "sha1-2Pw9KE3QV5T+hJc8rs3Rz4JP3YU=", + "dev": true + }, + "wrappy": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", + "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=", + "dev": true + }, + "write": { + "version": "0.2.1", + "resolved": "https://registry.npmjs.org/write/-/write-0.2.1.tgz", + "integrity": "sha1-X8A4KOJkzqP+kUVUdvejxWbLB1c=", + "dev": true + }, + "xml-char-classes": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/xml-char-classes/-/xml-char-classes-1.0.0.tgz", + "integrity": "sha1-ZGV4SKIP/F31g6Qq2KJ3tFErvE0=", + "dev": true + }, + "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=", + "dev": true + }, + "yallist": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/yallist/-/yallist-2.1.2.tgz", + "integrity": "sha1-HBH5IY8HYImkfdUS+TxmmaaoHVI=", + "dev": true + }, + "yargs": { + "version": "3.10.0", + "resolved": "https://registry.npmjs.org/yargs/-/yargs-3.10.0.tgz", + "integrity": "sha1-9+572FfdfB0tOMDnTvvWgdFDH9E=", + "dev": true + }, + "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=", + "dev": true, + "dependencies": { + "camelcase": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-3.0.0.tgz", + "integrity": "sha1-MvxLn82vhF/N9+c7uXysImHwqwo=", + "dev": true + } + } + } + } +} diff --git a/framework-examples/vue/package.json b/framework-examples/vue/package.json index 318633588f4..97e4c45b125 100644 --- a/framework-examples/vue/package.json +++ b/framework-examples/vue/package.json @@ -57,6 +57,7 @@ "@material/icon-toggle": "^0.1.0", "@material/list": "^0.1.0", "@material/ripple": "^0.1.0", + "@material/slider": "^0.1.0", "@material/snackbar": "^0.1.0", "@material/theme": "^0.1.0", "@material/typography": "^0.1.0" diff --git a/framework-examples/vue/src/App.vue b/framework-examples/vue/src/App.vue index 5d3c0dfbff9..c14237b1964 100644 --- a/framework-examples/vue/src/App.vue +++ b/framework-examples/vue/src/App.vue @@ -46,13 +46,13 @@

{{label}}

- +
- + @@ -65,7 +65,7 @@

- +

@@ -82,6 +82,21 @@

Favorited?: {{favorited}}

+ +
+

Continuous Slider

+
+

Select Value: {{slideValue}}

+
+ +
+
+ + + + + +
@@ -94,6 +109,7 @@ import IconToggle from './v-mdc-icon-toggle/IconToggle'; import CheckboxLabel from './v-mdc-checkbox/CheckboxLabel'; import FormField from './v-mdc-form-field/FormField'; import TemporaryDrawer from './v-mdc-drawer/TemporaryDrawer'; +import Slider from './v-mdc-slider/Slider'; export default { data () { @@ -105,10 +121,12 @@ export default { favorited: true, favoritedLabel: 'Remove from favorites', showIcon: true, - showLabel: 'Hide icon toggle' + showLabel: 'Hide icon toggle', + slideValue: 50, + sliderDisabled: false } }, - components: { FormField, Checkbox, CheckboxLabel, IconToggle, Snackbar, TemporaryDrawer }, + components: { FormField, Checkbox, CheckboxLabel, IconToggle, Slider, Snackbar, TemporaryDrawer }, directives: { Ripple }, watch: { checked () { @@ -168,4 +186,8 @@ export default { main { padding: 12px; } +section.example { + margin: 24px; + padding: 24px; +} diff --git a/framework-examples/vue/src/v-mdc-checkbox/Checkbox.vue b/framework-examples/vue/src/v-mdc-checkbox/Checkbox.vue index 387927ae2e0..e0ab65868c9 100644 --- a/framework-examples/vue/src/v-mdc-checkbox/Checkbox.vue +++ b/framework-examples/vue/src/v-mdc-checkbox/Checkbox.vue @@ -24,7 +24,7 @@ import { MDCCheckboxFoundation } from '@material/checkbox'; const { ANIM_END_EVENT_NAME } = MDCCheckboxFoundation.strings; export default { - props: ['id', 'labelId', 'value'], + props: ['id', 'value'], data () { return { classes: {}, diff --git a/framework-examples/vue/src/v-mdc-slider/Slider.vue b/framework-examples/vue/src/v-mdc-slider/Slider.vue new file mode 100644 index 00000000000..6aeb5dba801 --- /dev/null +++ b/framework-examples/vue/src/v-mdc-slider/Slider.vue @@ -0,0 +1,148 @@ + + + + + From 78946c4e03b5fa0425fe720fb81ad5e47cf75076 Mon Sep 17 00:00:00 2001 From: Dominic Carretto Date: Thu, 6 Jul 2017 17:27:20 -0400 Subject: [PATCH 06/12] fix(toolbar): Increase fixed toolbar's z-index from 1 to 4(#897) Fixes #834 --- packages/mdc-toolbar/mdc-toolbar.scss | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/packages/mdc-toolbar/mdc-toolbar.scss b/packages/mdc-toolbar/mdc-toolbar.scss index ad210f68394..d05e8e3c24a 100644 --- a/packages/mdc-toolbar/mdc-toolbar.scss +++ b/packages/mdc-toolbar/mdc-toolbar.scss @@ -127,7 +127,7 @@ position: fixed; top: 0; left: 0; - z-index: 1; + z-index: 4; @include mdc-elevation(4); } From 28bf7a9f28b3c22209b099289e62c34396ad57da Mon Sep 17 00:00:00 2001 From: Lynn Jepsen Date: Thu, 6 Jul 2017 15:14:58 -0700 Subject: [PATCH 07/12] chore(package): update testdouble to version 3.2.0 (#865) --- package.json | 2 +- test/unit/mdc-animation/mdc-animation.test.js | 33 +++++++++---------- test/unit/mdc-base/component.test.js | 5 +-- 3 files changed, 19 insertions(+), 21 deletions(-) diff --git a/package.json b/package.json index ca6c4b2d46f..e6e337209ea 100644 --- a/package.json +++ b/package.json @@ -85,7 +85,7 @@ "stylelint-order": "^0.5.0", "stylelint-scss": "^1.4.1", "stylelint-selector-bem-pattern": "^1.0.0", - "testdouble": "3.0.0", + "testdouble": "3.2.0", "to-slug-case": "^1.0.0", "query-ast": "^1.0.1", "validate-commit-msg": "^2.6.1", diff --git a/test/unit/mdc-animation/mdc-animation.test.js b/test/unit/mdc-animation/mdc-animation.test.js index 3fd7884bd1d..a182328b390 100644 --- a/test/unit/mdc-animation/mdc-animation.test.js +++ b/test/unit/mdc-animation/mdc-animation.test.js @@ -22,12 +22,11 @@ import {getCorrectPropertyName} from '../../../packages/mdc-animation'; // Has no properties without a prefix const legacyWindowObj = td.object({ - document: { - createElement: () => ({ - style: { - 'webkitTransform': 'nah', - }, - }), + document: {}, +}); +legacyWindowObj.document.createElement = () => ({ + style: { + 'webkitTransform': 'nah', }, }); @@ -35,12 +34,11 @@ suite('MDCAnimation'); test('#getCorrectEventName does not prefix events when not necessary', () => { const windowObj = td.object({ - document: { - createElement: () => ({ - style: { - animation: 'none', - }, - }), + document: {}, + }); + windowObj.document.createElement = () => ({ + style: { + animation: 'none', }, }); @@ -53,12 +51,11 @@ test('#getCorrectEventName does not prefix events when not necessary', () => { test('#getCorrectPropertyName does not prefix events when not necessary', () => { const windowObj = td.object({ - document: { - createElement: () => ({ - style: { - animation: 'none', - }, - }), + document: {}, + }); + windowObj.document.createElement = () => ({ + style: { + animation: 'none', }, }); diff --git a/test/unit/mdc-base/component.test.js b/test/unit/mdc-base/component.test.js index 984a998a3ce..b4c129c6971 100644 --- a/test/unit/mdc-base/component.test.js +++ b/test/unit/mdc-base/component.test.js @@ -30,11 +30,12 @@ class FakeComponent extends MDCComponent { } getDefaultFoundation() { - return td.object({ + const defaultFoundation = td.object({ isDefaultFoundation: true, init: () => {}, - rootElementAtTimeOfCall: this.root_, }); + defaultFoundation.rootElementAtTimeOfCall = this.root_; + return defaultFoundation; } initialize(...args) { From 4be947f66af60c3c6e28158f5353ac302c18498e Mon Sep 17 00:00:00 2001 From: Alex Sheehan Date: Fri, 7 Jul 2017 11:09:45 -0400 Subject: [PATCH 08/12] feat(snackbar): Implement full-featured Snackbar component (#852) BREAKING CHANGE: Adds adapter methods to capture blur, focus, and interaction events --- demos/snackbar.html | 126 ++++++++++++--- packages/mdc-snackbar/README.md | 63 +++++++- packages/mdc-snackbar/_variables.scss | 1 + packages/mdc-snackbar/foundation.js | 135 ++++++++++++---- packages/mdc-snackbar/index.js | 10 ++ packages/mdc-snackbar/mdc-snackbar.scss | 47 +++++- test/unit/mdc-snackbar/foundation.test.js | 165 ++++++++++++++++++-- test/unit/mdc-snackbar/mdc-snackbar.test.js | 85 +++++++++- 8 files changed, 555 insertions(+), 77 deletions(-) diff --git a/demos/snackbar.html b/demos/snackbar.html index 3d0185f96f7..d1e8c0b673a 100644 --- a/demos/snackbar.html +++ b/demos/snackbar.html @@ -27,7 +27,15 @@ @@ -88,33 +99,26 @@

Basic Example

+
-
-
-
- -
+
+
+ +
+ d="M1.73,12.91 8.1,19.28 22.79,4.59"/>
+
-
-
+
- +
Basic Example
+
-
- - + +
+ +
+ +
+
-
- - +
+ +
+
- - + + + +
Basic Example
+ +
+ +
@@ -171,28 +205,52 @@

Basic Example

var MDCSnackbar = global.mdc.snackbar.MDCSnackbar; var snackbar = new MDCSnackbar(document.getElementById('mdc-js-snackbar')); var rtlSnackbar = new MDCSnackbar(document.getElementById('mdc-rtl-js-snackbar')); + var alignStartSnackbar = new MDCSnackbar(document.getElementById('mdc-align-start-js-snackbar')); + var alignStartRTLSnackbar = new MDCSnackbar(document.getElementById('mdc-align-start-rtl-js-snackbar')); var messageInput = document.getElementById('message'); var actionInput = document.getElementById('action'); var multilineInput = document.getElementById('multiline'); var actionOnBottomInput = document.getElementById('action-on-bottom'); + var actionOnBottomCheckbox = document.getElementById('action-on-bottom-checkbox'); var dismissOnActionInput = document.getElementById('dismiss-on-action'); + var textFields = document.querySelectorAll('.mdc-textfield'); + + // Since Action on Bottom cannot be checked if Multi-line Input + // is not, we start with a disabled Action on Bottom option + actionOnBottomCheckbox.classList.add('mdc-checkbox--disabled'); + actionOnBottomInput.disabled = true; + actionOnBottomInput.checked = false; var show = function(sb) { snackbar.dismissesOnAction = dismissOnActionInput.checked; var data = { message: messageInput.value, actionOnBottom: actionOnBottomInput.checked, - multiline: multilineInput.checked + multiline: multilineInput.checked, + timeout: 2750 }; + if (actionInput.value) { data.actionText = actionInput.value; data.actionHandler = function() { console.log(data); } } + sb.show(data); }; + multilineInput.addEventListener('click', function () { + if (!multilineInput.checked) { + actionOnBottomCheckbox.classList.add('mdc-checkbox--disabled'); + actionOnBottomInput.disabled = true; + actionOnBottomInput.checked = false; + } else { + actionOnBottomCheckbox.classList.remove('mdc-checkbox--disabled'); + actionOnBottomInput.disabled = false; + } + }); + document.getElementById('show-snackbar').addEventListener('click', function() { show(snackbar); }); @@ -201,6 +259,22 @@

Basic Example

show(rtlSnackbar); }); + document.getElementById('show-start-aligned-snackbar').addEventListener('click', function() { + show(alignStartSnackbar); + }); + + document.getElementById('show-start-aligned-rtl-snackbar').addEventListener('click', function() { + show(alignStartRTLSnackbar); + }); + + document.getElementById('toggle-dark-theme').addEventListener('click', function(evt) { + document.body.classList.contains('mdc-theme--dark') ? document.body.classList.remove('mdc-theme--dark') : document.body.classList.add('mdc-theme--dark'); + }); + + textFields.forEach(function(tf) { + mdc.textfield.MDCTextfield.attachTo(tf); + }) + // Remove any element hiding after loading. window.onload = function() { document.body.className = ''; }; })(this); diff --git a/packages/mdc-snackbar/README.md b/packages/mdc-snackbar/README.md index 1cc9b36cb20..96589ae83bd 100644 --- a/packages/mdc-snackbar/README.md +++ b/packages/mdc-snackbar/README.md @@ -18,7 +18,7 @@ path: /catalog/snackbars/ The MDC Snackbar component is a spec-aligned snackbar/toast component adhering to the [Material Design snackbars & toasts requirements](https://material.io/guidelines/components/snackbars-toasts.html#snackbars-toasts-specs). -It requires JavaScript the trigger the display and hide of the snackbar. +It requires JavaScript to show and hide itself. ## Design & API Documentation @@ -53,6 +53,23 @@ npm install --save @material/snackbar
``` +### Start Aligned Snackbars (tablet and desktop only) + +MDC Snackbar can be start aligned (including in RTL contexts). To create a start-aligned +snackbar, add the `mdc-snackbar--align-start` modifier class to the root element. + +```html + +``` + ### Using the JS Component MDC Snackbar ships with a Component / Foundation combo which provides the API for showing snackbar @@ -125,6 +142,38 @@ properties and their usage. | multiline | Whether to show the snackbar with space for multiple lines of text | Optional | Boolean | | actionOnBottom | Whether to show the action below the multiple lines of text | Optional, applies when multiline is true | Boolean | +### Responding to a Snackbar Action + +To respond to a snackbar action, assign a function to the optional `actionHandler` property in the object that gets passed to the `show` method. If you choose to set this property, you *must _also_* set the `actionText` property. + +```html + +``` + +```js +import {MDCSnackbar} from 'mdc-snackbar'; + +const snackbar = new MDCSnackbar(document.querySelector('.mdc-snackbar')); +const dataObj = { + message: messageInput.value, + actionText: 'Undo', + actionHandler: function () { + console.log('my cool function'); + } +}; + +snackbar.show(dataObj); +``` + + ### Keep snackbar when the action button is pressed By default the snackbar will be dimissed when the user presses the action button. @@ -149,10 +198,18 @@ The adapter for snackbars must provide the following functions, with correct sig | `removeClass(className: string) => void` | Removes a class from the root element. | | `setAriaHidden() => void` | Sets `aria-hidden="true"` on the root element. | | `unsetAriaHidden() => void` | Removes the `aria-hidden` attribute from the root element. | -| `setMessageText(message: string) => void` | Set the text content of the message element. | -| `setActionText(actionText: string) => void` | Set the text content of the action element. | | `setActionAriaHidden() => void` | Sets `aria-hidden="true"` on the action element. | | `unsetActionAriaHidden() => void` | Removes the `aria-hidden` attribute from the action element. | +| `setActionText(actionText: string) => void` | Set the text content of the action element. | +| `setMessageText(message: string) => void` | Set the text content of the message element. | +| `setFocus() => void` | Sets focus on the action button. | +| `visibilityIsHidden() => boolean` | Returns document.hidden property. | +| `registerBlurHandler(handler: EventListener) => void` | Registers an event handler to be called when a `blur` event is triggered on the action button | +| `deregisterBlurHandler(handler: EventListener) => void` | Deregisters a `blur` event handler from the actionButton | +| `registerVisibilityChangeHandler(handler: EventListener) => void` | Registers an event handler to be called when a 'visibilitychange' event occurs | +| `deregisterVisibilityChangeHandler(handler: EventListener) => void` | Deregisters an event handler to be called when a 'visibilitychange' event occurs | +| `registerCapturedInteractionHandler(evtType: string, handler: EventListener) => void` | Registers an event handler to be called when the given event type is triggered on the `body` | +| `deregisterCapturedInteractionHandler(evtType: string, handler: EventListener) => void` | Deregisters an event handler from the `body` | | `registerActionClickHandler(handler: EventListener) => void` | Registers an event handler to be called when a `click` event is triggered on the action element. | | `deregisterActionClickHandler(handler: EventListener) => void` | Deregisters an event handler from a `click` event on the action element. This will only be called with handlers that have previously been passed to `registerActionClickHandler` calls. | | `registerTransitionEndHandler(handler: EventListener) => void` | Registers an event handler to be called when an `transitionend` event is triggered on the root element. Note that you must account for vendor prefixes in order for this to work correctly. | diff --git a/packages/mdc-snackbar/_variables.scss b/packages/mdc-snackbar/_variables.scss index 86e25edab04..163c7396f36 100644 --- a/packages/mdc-snackbar/_variables.scss +++ b/packages/mdc-snackbar/_variables.scss @@ -16,6 +16,7 @@ // Hard coded since the color is not present in any palette. $mdc-snackbar-background-color: #323232; +$mdc-snackbar-background-color-on-dark: #fafafa; $mdc-snackbar-foreground-color: white; // TODO: Better spot to pull this breakpoint? //$snackbar-tablet-breakpoint: $grid-tablet-breakpoint; diff --git a/packages/mdc-snackbar/foundation.js b/packages/mdc-snackbar/foundation.js index 2f4f48f2bf5..3b02f8a8f9e 100644 --- a/packages/mdc-snackbar/foundation.js +++ b/packages/mdc-snackbar/foundation.js @@ -32,10 +32,18 @@ export default class MDCSnackbarFoundation extends MDCFoundation { removeClass: (/* className: string */) => {}, setAriaHidden: () => {}, unsetAriaHidden: () => {}, - setMessageText: (/* message: string */) => {}, - setActionText: (/* actionText: string */) => {}, setActionAriaHidden: () => {}, unsetActionAriaHidden: () => {}, + setActionText: (/* actionText: string */) => {}, + setMessageText: (/* message: string */) => {}, + setFocus: () => {}, + visibilityIsHidden: () => /* boolean */ false, + registerCapturedBlurHandler: (/* handler: EventListener */) => {}, + deregisterCapturedBlurHandler: (/* handler: EventListener */) => {}, + registerVisibilityChangeHandler: (/* handler: EventListener */) => {}, + deregisterVisibilityChangeHandler: (/* handler: EventListener */) => {}, + registerCapturedInteractionHandler: (/* evtType: string, handler: EventListener */) => {}, + deregisterCapturedInteractionHandler: (/* evtType: string, handler: EventListener */) => {}, registerActionClickHandler: (/* handler: EventListener */) => {}, deregisterActionClickHandler: (/* handler: EventListener */) => {}, registerTransitionEndHandler: (/* handler: EventListener */) => {}, @@ -51,9 +59,40 @@ export default class MDCSnackbarFoundation extends MDCFoundation { super(Object.assign(MDCSnackbarFoundation.defaultAdapter, adapter)); this.active_ = false; + this.actionWasClicked_ = false; this.dismissOnAction_ = true; + this.firstFocus_ = true; + this.pointerDownRecognized_ = false; + this.snackbarHasFocus_ = false; + this.snackbarData_ = null; this.queue_ = []; - this.actionClickHandler_ = () => this.invokeAction_(); + this.actionClickHandler_ = () => { + this.actionWasClicked_ = true; + this.invokeAction_(); + }; + this.visibilitychangeHandler_ = () => { + clearTimeout(this.timeoutId_); + this.snackbarHasFocus_ = true; + + if (!this.adapter_.visibilityIsHidden()) { + setTimeout(this.cleanup_.bind(this), this.snackbarData_.timeout || numbers.MESSAGE_TIMEOUT); + } + }; + this.interactionHandler_ = (evt) => { + if (evt.type == 'touchstart' || evt.type == 'mousedown') { + this.pointerDownRecognized_ = true; + } + this.handlePossibleTabKeyboardFocus_(evt); + + if (evt.type == 'focus') { + this.pointerDownRecognized_ = false; + } + }; + this.blurHandler_ = () => { + clearTimeout(this.timeoutId_); + this.snackbarHasFocus_ = false; + this.timeoutId_ = setTimeout(this.cleanup_.bind(this), this.snackbarData_.timeout || numbers.MESSAGE_TIMEOUT); + }; } init() { @@ -64,6 +103,11 @@ export default class MDCSnackbarFoundation extends MDCFoundation { destroy() { this.adapter_.deregisterActionClickHandler(this.actionClickHandler_); + this.adapter_.deregisterCapturedBlurHandler(this.blurHandler_); + this.adapter_.deregisterVisibilityChangeHandler(this.visibilitychangeHandler_); + ['touchstart', 'mousedown', 'focus'].forEach((evtType) => { + this.adapter_.deregisterCapturedInteractionHandler(evtType, this.interactionHandler_); + }); } dismissesOnAction() { @@ -75,37 +119,43 @@ export default class MDCSnackbarFoundation extends MDCFoundation { } show(data) { - if (!data) { + clearTimeout(this.timeoutId_); + this.snackbarData_ = data; + this.firstFocus_ = true; + this.adapter_.registerVisibilityChangeHandler(this.visibilitychangeHandler_); + this.adapter_.registerCapturedBlurHandler(this.blurHandler_); + ['touchstart', 'mousedown', 'focus'].forEach((evtType) => { + this.adapter_.registerCapturedInteractionHandler(evtType, this.interactionHandler_); + }); + + if (!this.snackbarData_) { throw new Error( 'Please provide a data object with at least a message to display.'); } - if (!data.message) { + if (!this.snackbarData_.message) { throw new Error('Please provide a message to be displayed.'); } - if (data.actionHandler && !data.actionText) { + if (this.snackbarData_.actionHandler && !this.snackbarData_.actionText) { throw new Error('Please provide action text with the handler.'); } - if (this.active) { - this.queue_.push(data); - return; + this.queue_.push(this.snackbarData_); } const {ACTIVE, MULTILINE, ACTION_ON_BOTTOM} = cssClasses; - const {MESSAGE_TIMEOUT} = numbers; - this.adapter_.setMessageText(data.message); + this.adapter_.setMessageText(this.snackbarData_.message); - if (data.multiline) { + if (this.snackbarData_.multiline) { this.adapter_.addClass(MULTILINE); - if (data.actionOnBottom) { + if (this.snackbarData_.actionOnBottom) { this.adapter_.addClass(ACTION_ON_BOTTOM); } } - if (data.actionHandler) { - this.adapter_.setActionText(data.actionText); - this.actionHandler_ = data.actionHandler; + if (this.snackbarData_.actionHandler) { + this.adapter_.setActionText(this.snackbarData_.actionText); + this.actionHandler_ = this.snackbarData_.actionHandler; this.setActionHidden_(false); } else { this.setActionHidden_(true); @@ -117,7 +167,24 @@ export default class MDCSnackbarFoundation extends MDCFoundation { this.adapter_.addClass(ACTIVE); this.adapter_.unsetAriaHidden(); - this.timeoutId_ = setTimeout(this.cleanup_.bind(this), data.timeout || MESSAGE_TIMEOUT); + this.timeoutId_ = setTimeout(this.cleanup_.bind(this), this.snackbarData_.timeout || numbers.MESSAGE_TIMEOUT); + } + + handlePossibleTabKeyboardFocus_() { + const hijackFocus = + this.firstFocus_ && !this.pointerDownRecognized_; + + if (hijackFocus) { + this.setFocusOnAction_(); + } + + this.firstFocus_ = false; + } + + setFocusOnAction_() { + this.adapter_.setFocus(); + this.snackbarHasFocus_ = true; + this.firstFocus_ = false; } invokeAction_() { @@ -129,37 +196,39 @@ export default class MDCSnackbarFoundation extends MDCFoundation { this.actionHandler_(); } finally { if (this.dismissOnAction_) { - clearTimeout(this.timeoutId_); this.cleanup_(); } } } cleanup_() { - const {ACTIVE, MULTILINE, ACTION_ON_BOTTOM} = cssClasses; + const allowDismissal = !this.snackbarHasFocus_ || this.actionWasClicked_; - this.adapter_.removeClass(ACTIVE); + if (allowDismissal) { + const {ACTIVE, MULTILINE, ACTION_ON_BOTTOM} = cssClasses; - const handler = () => { - this.adapter_.deregisterTransitionEndHandler(handler); - this.adapter_.removeClass(MULTILINE); - this.adapter_.removeClass(ACTION_ON_BOTTOM); - this.setActionHidden_(true); - this.adapter_.setMessageText(null); - this.adapter_.setActionText(null); - this.adapter_.setAriaHidden(); - this.active_ = false; - this.showNext_(); - }; + this.adapter_.removeClass(ACTIVE); - this.adapter_.registerTransitionEndHandler(handler); + const handler = () => { + clearTimeout(this.timeoutId_); + this.adapter_.deregisterTransitionEndHandler(handler); + this.adapter_.removeClass(MULTILINE); + this.adapter_.removeClass(ACTION_ON_BOTTOM); + this.setActionHidden_(true); + this.adapter_.setAriaHidden(); + this.active_ = false; + this.snackbarHasFocus_ = false; + this.showNext_(); + }; + + this.adapter_.registerTransitionEndHandler(handler); + } } showNext_() { if (!this.queue_.length) { return; } - this.show(this.queue_.shift()); } diff --git a/packages/mdc-snackbar/index.js b/packages/mdc-snackbar/index.js index 6121f08cf59..7fe7d3da567 100644 --- a/packages/mdc-snackbar/index.js +++ b/packages/mdc-snackbar/index.js @@ -47,6 +47,16 @@ export class MDCSnackbar extends MDCComponent { unsetActionAriaHidden: () => getActionButton().removeAttribute('aria-hidden'), setActionText: (text) => { getActionButton().textContent = text; }, setMessageText: (text) => { getText().textContent = text; }, + setFocus: () => getActionButton().focus(), + visibilityIsHidden: () => document.hidden, + registerCapturedBlurHandler: (handler) => getActionButton().addEventListener('blur', handler, true), + deregisterCapturedBlurHandler: (handler) => getActionButton().removeEventListener('blur', handler, true), + registerVisibilityChangeHandler: (handler) => document.addEventListener('visibilitychange', handler), + deregisterVisibilityChangeHandler: (handler) => document.removeEventListener('visibilitychange', handler), + registerCapturedInteractionHandler: (evt, handler) => + document.body.addEventListener(evt, handler, true), + deregisterCapturedInteractionHandler: (evt, handler) => + document.body.removeEventListener(evt, handler, true), registerActionClickHandler: (handler) => getActionButton().addEventListener('click', handler), deregisterActionClickHandler: (handler) => getActionButton().removeEventListener('click', handler), registerTransitionEndHandler: diff --git a/packages/mdc-snackbar/mdc-snackbar.scss b/packages/mdc-snackbar/mdc-snackbar.scss index b7ccf0ff3b2..9a2034094c5 100644 --- a/packages/mdc-snackbar/mdc-snackbar.scss +++ b/packages/mdc-snackbar/mdc-snackbar.scss @@ -30,31 +30,60 @@ justify-content: flex-start; padding-right: 24px; padding-left: 24px; - transform: translate(0, 100%); + transform: translate(-50%, 100%); transition: mdc-animation-exit(transform, .25s); background-color: $mdc-snackbar-background-color; + + @include mdc-theme-dark(".mdc-snackbar") { + background-color: $mdc-snackbar-background-color-on-dark; + } + will-change: transform; pointer-events: none; @media (max-width: ($mdc-snackbar-tablet-breakpoint - 1)) { left: 0; width: calc(100% - 48px); + transform: translate(0, 100%); } @media (min-width: $mdc-snackbar-tablet-breakpoint) { min-width: 288px; max-width: 568px; - transform: translate(-50%, 100%); border-radius: 2px; } + &--align-start { + @media (min-width: $mdc-snackbar-tablet-breakpoint) { + bottom: 24px; + + @include mdc-rtl-reflexive-position(left, 24px); + + transform: translate(0, 200%); + } + + @media (max-width: ($mdc-snackbar-tablet-breakpoint - 1)) { + bottom: 0; + left: 0; + width: calc(100% - 48px); + transform: translate(0, 100%); + } + } + &--active { - transform: translate(0, 0); + transform: translate(0); pointer-events: auto; transition: mdc-animation-enter(transform, .25s); - @media (min-width: $mdc-snackbar-tablet-breakpoint) { + &:not(.mdc-snackbar--align-start) { transform: translate(-50%, 0); + + @media (max-width: ($mdc-snackbar-tablet-breakpoint - 1)) { + bottom: 0; + left: 0; + width: calc(100% - 48px); + transform: translate(0); + } } } @@ -84,6 +113,11 @@ height: 48px; transition: mdc-animation-exit(opacity, .3s); color: $mdc-snackbar-foreground-color; + + @include mdc-theme-dark(".mdc-snackbar") { + @include mdc-theme-prop(color, text-primary-on-light); + } + opacity: 0; } @@ -99,6 +133,11 @@ &__action-button { @include mdc-theme-prop(color, accent); + + @include mdc-theme-dark(".mdc-snackbar") { + @include mdc-theme-prop(color, primary); + } + @include mdc-rtl-reflexive-box(margin, right, -16px, ".mdc-snackbar"); min-width: auto; diff --git a/test/unit/mdc-snackbar/foundation.test.js b/test/unit/mdc-snackbar/foundation.test.js index b98acf9cec6..51241b58e2d 100644 --- a/test/unit/mdc-snackbar/foundation.test.js +++ b/test/unit/mdc-snackbar/foundation.test.js @@ -43,16 +43,19 @@ test('defaultAdapter returns a complete adapter implementation', () => { assert.equal(methods.length, Object.keys(defaultAdapter).length, 'Every adapter key must be a function'); assert.deepEqual(methods, [ - 'addClass', 'removeClass', 'setAriaHidden', 'unsetAriaHidden', 'setMessageText', - 'setActionText', 'setActionAriaHidden', 'unsetActionAriaHidden', - 'registerActionClickHandler', 'deregisterActionClickHandler', - 'registerTransitionEndHandler', 'deregisterTransitionEndHandler', + 'addClass', 'removeClass', 'setAriaHidden', 'unsetAriaHidden', 'setActionAriaHidden', + 'unsetActionAriaHidden', 'setActionText', 'setMessageText', 'setFocus', 'visibilityIsHidden', + 'registerCapturedBlurHandler', 'deregisterCapturedBlurHandler', 'registerVisibilityChangeHandler', + 'deregisterVisibilityChangeHandler', 'registerCapturedInteractionHandler', + 'deregisterCapturedInteractionHandler', 'registerActionClickHandler', + 'deregisterActionClickHandler', 'registerTransitionEndHandler', + 'deregisterTransitionEndHandler', ]); // Test default methods methods.forEach((m) => assert.doesNotThrow(defaultAdapter[m])); }); -test('#init calls adapter.registerActionClickHandler() with a action click handler function', () => { +test('#init calls adapter.registerActionClickHandler() with an action click handler function', () => { const {foundation, mockAdapter} = setupTest(); const {isA} = td.matchers; @@ -74,6 +77,30 @@ test('#destroy calls adapter.deregisterActionClickHandler() with a registerActio td.verify(mockAdapter.deregisterActionClickHandler(changeHandler)); }); +test('#destroy calls adapter.deregisterVisibilityChangeHandler() with a function', () => { + const {foundation, mockAdapter} = setupTest(); + const {isA} = td.matchers; + + foundation.destroy(); + td.verify(mockAdapter.deregisterVisibilityChangeHandler(isA(Function))); +}); + +test('#destroy calls adapter.deregisterCapturedBlurHandler() with a function', () => { + const {foundation, mockAdapter} = setupTest(); + const {isA} = td.matchers; + + foundation.destroy(); + td.verify(mockAdapter.deregisterCapturedBlurHandler(isA(Function))); +}); + +test('#destroy calls adapter.deregisterCapturedInteractionHandler() with an event type and function 3 times', () => { + const {foundation, mockAdapter} = setupTest(); + const {isA} = td.matchers; + + foundation.destroy(); + td.verify(mockAdapter.deregisterCapturedInteractionHandler(isA(String), isA(Function)), {times: 3}); +}); + test('#init calls adapter.setAriaHidden to ensure snackbar starts hidden', () => { const {foundation, mockAdapter} = setupTest(); @@ -216,7 +243,8 @@ test('#show while snackbar is already showing will queue the data object.', () = message: 'Message Archived', }); - td.verify(mockAdapter.setMessageText('Message Archived'), {times: 0}); + td.verify(mockAdapter.setMessageText('Message Deleted')); + td.verify(mockAdapter.setMessageText('Message Archived')); }); test('#show while snackbar is already showing will show after the timeout and transition end', () => { @@ -224,14 +252,13 @@ test('#show while snackbar is already showing will show after the timeout and tr const {foundation, mockAdapter} = setupTest(); const {isA} = td.matchers; - foundation.init(); - let transEndHandler; td.when(mockAdapter.registerTransitionEndHandler(isA(Function))) .thenDo((handler) => { transEndHandler = handler; }); + foundation.init(); foundation.show({ message: 'Message Deleted', }); @@ -304,8 +331,6 @@ test('#show will clean up snackbar after the timeout and transition end', () => clock.tick(numbers.MESSAGE_TIMEOUT); transEndHandler(); - td.verify(mockAdapter.setMessageText(null)); - td.verify(mockAdapter.setActionText(null)); td.verify(mockAdapter.removeClass(cssClasses.MULTILINE)); td.verify(mockAdapter.removeClass(cssClasses.ACTION_ON_BOTTOM)); td.verify(mockAdapter.deregisterTransitionEndHandler(transEndHandler)); @@ -313,6 +338,30 @@ test('#show will clean up snackbar after the timeout and transition end', () => clock.uninstall(); }); +test('#show calls adapter.registerVisibilityChangeHandler() with a function', () => { + const {foundation, mockAdapter} = setupTest(); + const {isA} = td.matchers; + + foundation.show({message: 'foo'}); + td.verify(mockAdapter.registerVisibilityChangeHandler(isA(Function))); +}); + +test('#show calls adapter.registerCapturedBlurHandler() with a function', () => { + const {foundation, mockAdapter} = setupTest(); + const {isA} = td.matchers; + + foundation.show({message: 'foo'}); + td.verify(mockAdapter.registerCapturedBlurHandler(isA(Function))); +}); + +test('#show calls adapter.registerCapturedInteractionHandler() with an event type and function 3 times', () => { + const {foundation, mockAdapter} = setupTest(); + const {isA} = td.matchers; + + foundation.show({message: 'foo'}); + td.verify(mockAdapter.registerCapturedInteractionHandler(isA(String), isA(Function)), {times: 3}); +}); + test('snackbar is dismissed after action button is pressed', () => { const {foundation, mockAdapter} = setupTest(); const {isA} = td.matchers; @@ -363,3 +412,99 @@ test('snackbar is not dismissed after action button is pressed if setDismissOnAc td.verify(mockAdapter.removeClass(cssClasses.ACTIVE), {times: 0}); }); + +test('snackbar is not dismissed if action button gets focus', () => { + const {foundation, mockAdapter} = setupTest(); + const evtType = 'focus'; + const mockEvent = {type: 'focus'}; + let focusEvent; + + td.when(mockAdapter.registerCapturedInteractionHandler(evtType, td.matchers.isA(Function))) + .thenDo((evtType, handler) => { + focusEvent = handler; + }); + + foundation.init(); + foundation.show({message: 'foo'}); + focusEvent(mockEvent); + + foundation.show({message: 'foo'}); + + td.verify(mockAdapter.removeClass(cssClasses.ACTIVE), {times: 0}); +}); + +test('focus hijacks the snackbar timeout if no click or touchstart occurs', () => { + const {foundation, mockAdapter} = setupTest(); + const mockEvent = {type: 'focus'}; + let tabEvent; + + td.when(mockAdapter.registerCapturedInteractionHandler(mockEvent.type, td.matchers.isA(Function))) + .thenDo((evt, handler) => { + tabEvent = handler; + }); + + foundation.init(); + foundation.show({message: 'foo'}); + tabEvent(mockEvent); + + td.verify(mockAdapter.removeClass(cssClasses.ACTIVE), {times: 0}); +}); + +test('focus does not hijack the snackbar timeout if it occurs as a result' + + 'of a mousedown or touchstart', () => { + const clock = lolex.install(); + const {foundation, mockAdapter} = setupTest(); + const mockFocusEvent = {type: 'focus'}; + const mockMouseEvent = {type: 'mousedown'}; + let focusEvent; + let mouseEvent; + + td.when(mockAdapter.registerCapturedInteractionHandler(mockFocusEvent.type, td.matchers.isA(Function))) + .thenDo((evt, handler) => { + focusEvent = handler; + }); + td.when(mockAdapter.registerCapturedInteractionHandler(mockMouseEvent.type, td.matchers.isA(Function))) + .thenDo((evt, handler) => { + mouseEvent = handler; + }); + + foundation.init(); + foundation.show({message: 'foo'}); + mouseEvent(mockMouseEvent); + focusEvent(mockFocusEvent); + clock.tick(numbers.MESSAGE_TIMEOUT); + + td.verify(mockAdapter.removeClass(cssClasses.ACTIVE)); + clock.uninstall(); +}); + +test('blur resets the snackbar timeout', () => { + const clock = lolex.install(); + const {foundation, mockAdapter} = setupTest(); + const {isA} = td.matchers; + const mockBlurEvent = {type: 'blur'}; + const mockFocusEvent = {type: 'focus'}; + let focusEvent; + let blurEvent; + + td.when(mockAdapter.registerCapturedInteractionHandler(mockFocusEvent.type, td.matchers.isA(Function))) + .thenDo((evt, handler) => { + focusEvent = handler; + }); + td.when(mockAdapter.registerCapturedBlurHandler(isA(Function))) + .thenDo((handler) => { + blurEvent = handler; + }); + + foundation.init(); + foundation.show({message: 'foo'}); + focusEvent(mockFocusEvent); + // Sanity Check + td.verify(mockAdapter.removeClass(cssClasses.ACTIVE), {times: 0}); + + blurEvent(mockBlurEvent); + clock.tick(numbers.MESSAGE_TIMEOUT); + td.verify(mockAdapter.removeClass(cssClasses.ACTIVE)); + + clock.uninstall(); +}); diff --git a/test/unit/mdc-snackbar/mdc-snackbar.test.js b/test/unit/mdc-snackbar/mdc-snackbar.test.js index 4cf5978f9b3..18054db97f1 100644 --- a/test/unit/mdc-snackbar/mdc-snackbar.test.js +++ b/test/unit/mdc-snackbar/mdc-snackbar.test.js @@ -36,8 +36,9 @@ function getFixture() { function setupTest() { const root = getFixture(); + const actionButton = root.querySelector(strings.ACTION_BUTTON_SELECTOR); const component = new MDCSnackbar(root); - return {root, component}; + return {root, actionButton, component}; } suite('MDCSnackbar'); @@ -117,6 +118,88 @@ test('foundationAdapter#unsetActionAriaHidden removes "aria-hidden" from the act assert.isNotOk(actionButton.getAttribute('aria-hidden')); }); +test('adapter#setFocus sets focus on the action button', () => { + const {root, actionButton, component} = setupTest(); + const handler = td.func('fixture focus handler'); + root.addEventListener('focus', handler); + document.body.appendChild(root); + + component.getDefaultFoundation().adapter_.setFocus(); + + assert.equal(document.activeElement, actionButton); + document.body.removeChild(root); +}); + +test('adapter#visibilityIsHidden returns the document.hidden property', () => { + const {component} = setupTest(); + assert.equal(component.getDefaultFoundation().adapter_.visibilityIsHidden(), document.hidden); +}); + +test('adapter#registerCapturedBlurHandler adds a handler to be called on a blur event', () => { + const {actionButton, component} = setupTest(); + const handler = td.func('blurHandler'); + + component.getDefaultFoundation().adapter_.registerCapturedBlurHandler(handler); + domEvents.emit(actionButton, 'blur'); + + td.verify(handler(td.matchers.anything())); +}); + +test('adapter#deregisterCapturedBlurHandler removes a handler to be called on a blur event', () => { + const {actionButton, component} = setupTest(); + const handler = td.func('blurHandler'); + + actionButton.addEventListener('blur', handler, true); + component.getDefaultFoundation().adapter_.deregisterCapturedBlurHandler(handler); + domEvents.emit(actionButton, 'blur'); + + td.verify(handler(td.matchers.anything()), {times: 0}); +}); + +test('adapter#registerVisibilityChangeHandler adds a handler to be called on a visibilitychange event', () => { + const {component} = setupTest(); + const handler = td.func('visibilitychangeHandler'); + + component.getDefaultFoundation().adapter_.registerVisibilityChangeHandler(handler); + domEvents.emit(document, 'visibilitychange'); + + td.verify(handler(td.matchers.anything())); +}); + +test('adapter#deregisterVisibilityChangeHandler removes a handler to be called on a visibilitychange event', () => { + const {component} = setupTest(); + const handler = td.func('visibilitychangeHandler'); + + document.addEventListener('visibilitychange', handler); + component.getDefaultFoundation().adapter_.deregisterVisibilityChangeHandler(handler); + domEvents.emit(document, 'visibilitychange'); + + td.verify(handler(td.matchers.anything()), {times: 0}); +}); + +test('adapter#registerCapturedInteractionHandler adds a handler to be called when a given event occurs', () => { + const {component} = setupTest(); + const handler = td.func('interactionHandler'); + const mockEvent = 'click'; + + component.getDefaultFoundation().adapter_.registerCapturedInteractionHandler(mockEvent, handler); + domEvents.emit(document.body, mockEvent); + + td.verify(handler(td.matchers.anything())); +}); + +test('adapter#deregisterCapturedInteractionHandler removes a handler to be called when a given event occurs', () => { + const {component} = setupTest(); + const handler = td.func('interactionHandler'); + const mockEvent = 'click'; + + document.body.addEventListener(mockEvent, handler, true); + component.getDefaultFoundation().adapter_.deregisterCapturedInteractionHandler(mockEvent, handler); + domEvents.emit(document.body, mockEvent); + + td.verify(handler(td.matchers.anything()), {times: 0}); +}); + test('foundationAdapter#registerActionClickHandler adds the handler to be called when action is clicked', () => { const {root, component} = setupTest(); const handler = td.func('clickHandler'); From 5b104784707e380e197ec4a1056d7ecc6dc871a3 Mon Sep 17 00:00:00 2001 From: Lynn Jepsen Date: Fri, 7 Jul 2017 10:44:06 -0700 Subject: [PATCH 09/12] fix(infrastructure): Downgrade closure-compiler (#915) --- package.json | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/package.json b/package.json index e6e337209ea..39dcab93d6d 100644 --- a/package.json +++ b/package.json @@ -50,7 +50,7 @@ "eslint-plugin-mocha": "^4.8.0", "extract-text-webpack-plugin": "^2.1.2", "glob": "^7.1.1", - "google-closure-compiler": "^20170626.0.0", + "google-closure-compiler": "^20170521.0.0", "husky": "^0.14.0", "istanbul": "^0.4.4", "istanbul-instrumenter-loader": "^2.0.0", From c38c4c6538aad454bbe5a81c72b701370e47ffff Mon Sep 17 00:00:00 2001 From: "greenkeeper[bot]" Date: Sat, 24 Jun 2017 01:40:13 +0000 Subject: [PATCH 10/12] chore(package): update eslint to version 4.1.0 --- package.json | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/package.json b/package.json index 39dcab93d6d..d4358bc4a4f 100644 --- a/package.json +++ b/package.json @@ -45,7 +45,7 @@ "cz-conventional-changelog": "^2.0.0", "del-cli": "^1.0.0", "dom-events": "^0.1.1", - "eslint": "^3.6.1", + "eslint": "^4.1.0", "eslint-config-google": "^0.7.1", "eslint-plugin-mocha": "^4.8.0", "extract-text-webpack-plugin": "^2.1.2", From 028238f6a0925c25a6b91807005c336ef127ad44 Mon Sep 17 00:00:00 2001 From: Alex Sheehan Date: Thu, 29 Jun 2017 14:03:43 -0400 Subject: [PATCH 11/12] chore: Update eslint and fix lines that break the rules --- packages/mdc-base/component.js | 1 - packages/mdc-base/foundation.js | 1 - packages/mdc-checkbox/foundation.js | 6 +- packages/mdc-drawer/persistent/index.js | 16 +- packages/mdc-drawer/slidable/constants.js | 4 +- packages/mdc-drawer/slidable/foundation.js | 1 - packages/mdc-drawer/temporary/index.js | 10 +- packages/mdc-menu/simple/foundation.js | 4 +- packages/mdc-ripple/index.js | 4 +- packages/mdc-tabs/index.js | 6 +- packages/mdc-toolbar/foundation.js | 2 +- ...ewrite-decl-statements-for-closure-test.js | 2 +- ...rite-sass-import-statements-for-closure.js | 2 +- .../mdc-drawer/slidable.foundation.test.js | 1 - test/unit/mdc-menu/simple.foundation.test.js | 272 ++++++------ .../mdc-ripple/foundation-activation.test.js | 324 +++++++------- .../foundation-deactivation.test.js | 420 +++++++++--------- test/unit/mdc-ripple/foundation.test.js | 162 +++---- .../mdc-tabs/mdc-tab-bar-foundation.test.js | 4 +- .../mdc-tab-bar-scroller-foundation.test.js | 6 +- webpack.config.js | 2 +- 21 files changed, 625 insertions(+), 625 deletions(-) diff --git a/packages/mdc-base/component.js b/packages/mdc-base/component.js index 6ff445cd36a..6f1af644e19 100644 --- a/packages/mdc-base/component.js +++ b/packages/mdc-base/component.js @@ -20,7 +20,6 @@ import MDCFoundation from './foundation'; * @template F */ export default class MDCComponent { - /** * @param {!Element} root * @return {!MDCComponent} diff --git a/packages/mdc-base/foundation.js b/packages/mdc-base/foundation.js index 303821ca0b8..af0b7e8d55d 100644 --- a/packages/mdc-base/foundation.js +++ b/packages/mdc-base/foundation.js @@ -18,7 +18,6 @@ * @template A */ export default class MDCFoundation { - /** @return enum{cssClasses} */ static get cssClasses() { // Classes extending MDCFoundation should implement this method to return an object which exports every diff --git a/packages/mdc-checkbox/foundation.js b/packages/mdc-checkbox/foundation.js index cc720341f13..c8c029443e6 100644 --- a/packages/mdc-checkbox/foundation.js +++ b/packages/mdc-checkbox/foundation.js @@ -246,15 +246,15 @@ export default class MDCCheckboxFoundation extends MDCFoundation { if (newState === TRANSITION_STATE_UNCHECKED) { return ''; } - // fallthrough + // fallthrough case TRANSITION_STATE_UNCHECKED: return newState === TRANSITION_STATE_CHECKED ? ANIM_UNCHECKED_CHECKED : ANIM_UNCHECKED_INDETERMINATE; case TRANSITION_STATE_CHECKED: return newState === TRANSITION_STATE_UNCHECKED ? ANIM_CHECKED_UNCHECKED : ANIM_CHECKED_INDETERMINATE; - // TRANSITION_STATE_INDETERMINATE + // TRANSITION_STATE_INDETERMINATE default: return newState === TRANSITION_STATE_CHECKED ? - ANIM_INDETERMINATE_CHECKED : ANIM_INDETERMINATE_UNCHECKED; + ANIM_INDETERMINATE_CHECKED : ANIM_INDETERMINATE_UNCHECKED; } } diff --git a/packages/mdc-drawer/persistent/index.js b/packages/mdc-drawer/persistent/index.js index e18a8c7b92b..dc15b746c17 100644 --- a/packages/mdc-drawer/persistent/index.js +++ b/packages/mdc-drawer/persistent/index.js @@ -38,7 +38,7 @@ export class MDCPersistentDrawer extends MDCComponent { } } - /* Return the drawer element inside the component. */ + // Return the drawer element inside the component. get drawer() { return this.root_.querySelector(MDCPersistentDrawerFoundation.strings.DRAWER_SELECTOR); } @@ -52,22 +52,22 @@ export class MDCPersistentDrawer extends MDCComponent { hasClass: (className) => this.root_.classList.contains(className), hasNecessaryDom: () => Boolean(this.drawer), registerInteractionHandler: (evt, handler) => - this.root_.addEventListener(util.remapEvent(evt), handler, util.applyPassive()), + this.root_.addEventListener(util.remapEvent(evt), handler, util.applyPassive()), deregisterInteractionHandler: (evt, handler) => - this.root_.removeEventListener(util.remapEvent(evt), handler, util.applyPassive()), + this.root_.removeEventListener(util.remapEvent(evt), handler, util.applyPassive()), registerDrawerInteractionHandler: (evt, handler) => - this.drawer.addEventListener(util.remapEvent(evt), handler), + this.drawer.addEventListener(util.remapEvent(evt), handler), deregisterDrawerInteractionHandler: (evt, handler) => - this.drawer.removeEventListener(util.remapEvent(evt), handler), + this.drawer.removeEventListener(util.remapEvent(evt), handler), registerTransitionEndHandler: (handler) => - this.root_.addEventListener('transitionend', handler), + this.root_.addEventListener('transitionend', handler), deregisterTransitionEndHandler: (handler) => - this.root_.removeEventListener('transitionend', handler), + this.root_.removeEventListener('transitionend', handler), registerDocumentKeydownHandler: (handler) => document.addEventListener('keydown', handler), deregisterDocumentKeydownHandler: (handler) => document.removeEventListener('keydown', handler), getDrawerWidth: () => this.drawer.offsetWidth, setTranslateX: (value) => this.drawer.style.setProperty( - util.getTransformPropertyName(), value === null ? null : `translateX(${value}px)`), + util.getTransformPropertyName(), value === null ? null : `translateX(${value}px)`), getFocusableElements: () => this.drawer.querySelectorAll(FOCUSABLE_ELEMENTS), saveElementTabState: (el) => util.saveElementTabState(el), restoreElementTabState: (el) => util.restoreElementTabState(el), diff --git a/packages/mdc-drawer/slidable/constants.js b/packages/mdc-drawer/slidable/constants.js index cc46f00850c..d69bfc5e238 100644 --- a/packages/mdc-drawer/slidable/constants.js +++ b/packages/mdc-drawer/slidable/constants.js @@ -15,5 +15,5 @@ */ export const FOCUSABLE_ELEMENTS = - 'a[href], area[href], input:not([disabled]), select:not([disabled]), textarea:not([disabled]), ' + - 'button:not([disabled]), iframe, object, embed, [tabindex], [contenteditable]'; + 'a[href], area[href], input:not([disabled]), select:not([disabled]), textarea:not([disabled]), ' + + 'button:not([disabled]), iframe, object, embed, [tabindex], [contenteditable]'; diff --git a/packages/mdc-drawer/slidable/foundation.js b/packages/mdc-drawer/slidable/foundation.js index 7a1507708d0..200b3a47f16 100644 --- a/packages/mdc-drawer/slidable/foundation.js +++ b/packages/mdc-drawer/slidable/foundation.js @@ -17,7 +17,6 @@ import {MDCFoundation} from '@material/base'; export class MDCSlidableDrawerFoundation extends MDCFoundation { - static get defaultAdapter() { return { addClass: (/* className: string */) => {}, diff --git a/packages/mdc-drawer/temporary/index.js b/packages/mdc-drawer/temporary/index.js index 1e4bab081c4..8e2d1e61736 100644 --- a/packages/mdc-drawer/temporary/index.js +++ b/packages/mdc-drawer/temporary/index.js @@ -54,20 +54,20 @@ export class MDCTemporaryDrawer extends MDCComponent { removeBodyClass: (className) => document.body.classList.remove(className), hasNecessaryDom: () => Boolean(this.drawer), registerInteractionHandler: (evt, handler) => - this.root_.addEventListener(util.remapEvent(evt), handler, util.applyPassive()), + this.root_.addEventListener(util.remapEvent(evt), handler, util.applyPassive()), deregisterInteractionHandler: (evt, handler) => - this.root_.removeEventListener(util.remapEvent(evt), handler, util.applyPassive()), + this.root_.removeEventListener(util.remapEvent(evt), handler, util.applyPassive()), registerDrawerInteractionHandler: (evt, handler) => - this.drawer.addEventListener(util.remapEvent(evt), handler), + this.drawer.addEventListener(util.remapEvent(evt), handler), deregisterDrawerInteractionHandler: (evt, handler) => - this.drawer.removeEventListener(util.remapEvent(evt), handler), + this.drawer.removeEventListener(util.remapEvent(evt), handler), registerTransitionEndHandler: (handler) => this.drawer.addEventListener('transitionend', handler), deregisterTransitionEndHandler: (handler) => this.drawer.removeEventListener('transitionend', handler), registerDocumentKeydownHandler: (handler) => document.addEventListener('keydown', handler), deregisterDocumentKeydownHandler: (handler) => document.removeEventListener('keydown', handler), getDrawerWidth: () => this.drawer.offsetWidth, setTranslateX: (value) => this.drawer.style.setProperty( - util.getTransformPropertyName(), value === null ? null : `translateX(${value}px)`), + util.getTransformPropertyName(), value === null ? null : `translateX(${value}px)`), updateCssVariable: (value) => { if (util.supportsCssCustomProperties()) { this.root_.style.setProperty(OPACITY_VAR_NAME, value); diff --git a/packages/mdc-menu/simple/foundation.js b/packages/mdc-menu/simple/foundation.js index 479dd4d42c9..738f5b957b6 100644 --- a/packages/mdc-menu/simple/foundation.js +++ b/packages/mdc-menu/simple/foundation.js @@ -192,7 +192,7 @@ export default class MDCSimpleMenuFoundation extends MDCFoundation { animationLoop_() { const time = this.adapter_.getAccurateTime(); const {TRANSITION_DURATION_MS, TRANSITION_X1, TRANSITION_Y1, TRANSITION_X2, TRANSITION_Y2, - TRANSITION_SCALE_ADJUSTMENT_X, TRANSITION_SCALE_ADJUSTMENT_Y} = MDCSimpleMenuFoundation.numbers; + TRANSITION_SCALE_ADJUSTMENT_X, TRANSITION_SCALE_ADJUSTMENT_Y} = MDCSimpleMenuFoundation.numbers; const currentTime = clamp((time - this.startTime_) / TRANSITION_DURATION_MS); // Animate X axis very slowly, so that only the Y axis animation is visible during fade-out. @@ -477,5 +477,3 @@ export default class MDCSimpleMenuFoundation extends MDCFoundation { return this.isOpen_; } } - - diff --git a/packages/mdc-ripple/index.js b/packages/mdc-ripple/index.js index 3a304d5bdd2..56e5aecce10 100644 --- a/packages/mdc-ripple/index.js +++ b/packages/mdc-ripple/index.js @@ -66,9 +66,9 @@ export class MDCRipple extends MDCComponent { addClass: (className) => instance.root_.classList.add(className), removeClass: (className) => instance.root_.classList.remove(className), registerInteractionHandler: (evtType, handler) => - instance.root_.addEventListener(evtType, handler, util.applyPassive()), + instance.root_.addEventListener(evtType, handler, util.applyPassive()), deregisterInteractionHandler: (evtType, handler) => - instance.root_.removeEventListener(evtType, handler, util.applyPassive()), + instance.root_.removeEventListener(evtType, handler, util.applyPassive()), registerResizeHandler: (handler) => window.addEventListener('resize', handler), deregisterResizeHandler: (handler) => window.removeEventListener('resize', handler), updateCssVariable: (varName, value) => instance.root_.style.setProperty(varName, value), diff --git a/packages/mdc-tabs/index.js b/packages/mdc-tabs/index.js index 45ef07500a1..511fb84607f 100644 --- a/packages/mdc-tabs/index.js +++ b/packages/mdc-tabs/index.js @@ -14,6 +14,6 @@ * limitations under the License. */ - export {MDCTabFoundation, MDCTab} from './tab'; - export {MDCTabBarFoundation, MDCTabBar} from './tab-bar'; - export {MDCTabBarScrollerFoundation, MDCTabBarScroller} from './tab-bar-scroller'; +export {MDCTabFoundation, MDCTab} from './tab'; +export {MDCTabBarFoundation, MDCTabBar} from './tab-bar'; +export {MDCTabBarScrollerFoundation, MDCTabBarScroller} from './tab-bar-scroller'; diff --git a/packages/mdc-toolbar/foundation.js b/packages/mdc-toolbar/foundation.js index 3fe71e7853c..e1afd5358bb 100644 --- a/packages/mdc-toolbar/foundation.js +++ b/packages/mdc-toolbar/foundation.js @@ -61,7 +61,7 @@ export default class MDCToolbarFoundation extends MDCFoundation { this.calculations_ = { toolbarRowHeight: 0, // Calculated Height ratio. We use ratio to calculate corresponding heights in resize event. - toolbarRatio: 0, // The ratio of toolbar height to row height + toolbarRatio: 0, // The ratio of toolbar height to row height flexibleExpansionRatio: 0, // The ratio of flexible space height to row height maxTranslateYRatio: 0, // The ratio of max toolbar move up distance to row height scrollThresholdRatio: 0, // The ratio of max scrollTop that we should listen to to row height diff --git a/scripts/rewrite-decl-statements-for-closure-test.js b/scripts/rewrite-decl-statements-for-closure-test.js index de57e1d87e3..17cdb318192 100644 --- a/scripts/rewrite-decl-statements-for-closure-test.js +++ b/scripts/rewrite-decl-statements-for-closure-test.js @@ -121,7 +121,7 @@ function rewriteDeclarationSource(node, srcFile, rootDir) { const pathParts = source.split('/'); const isMDCImport = pathParts[0] === '@material'; if (isMDCImport) { - const modName = pathParts[1]; // @material/ + const modName = pathParts[1]; // @material/ const atMaterialReplacementPath = `${rootDir}/mdc-${modName}`; const rewrittenSource = [atMaterialReplacementPath].concat(pathParts.slice(2)).join('/'); source = rewrittenSource; diff --git a/scripts/rewrite-sass-import-statements-for-closure.js b/scripts/rewrite-sass-import-statements-for-closure.js index d9d32ff9403..6f0e8392f43 100644 --- a/scripts/rewrite-sass-import-statements-for-closure.js +++ b/scripts/rewrite-sass-import-statements-for-closure.js @@ -73,7 +73,7 @@ function rewriteImportDeclaration(importSource, srcFile, rootDir) { const pathParts = importSource.split('/'); const isMDCImport = pathParts[0] === '@material'; if (isMDCImport) { - const modName = pathParts[1]; // @material/ + const modName = pathParts[1]; // @material/ const atMaterialReplacementPath = `${rootDir}/${modName}`; const rewrittenImportSource = [atMaterialReplacementPath].concat(pathParts.slice(2)).join('/'); importSource = rewrittenImportSource; diff --git a/test/unit/mdc-drawer/slidable.foundation.test.js b/test/unit/mdc-drawer/slidable.foundation.test.js index a16ba706b22..0abf4e0a4a9 100644 --- a/test/unit/mdc-drawer/slidable.foundation.test.js +++ b/test/unit/mdc-drawer/slidable.foundation.test.js @@ -25,7 +25,6 @@ function setupTest(isRootTransitioningEventTarget) { const mockAdapter = td.object(MDCSlidableDrawerFoundation.defaultAdapter); class MDCFakeSlideableDrawerFoundation extends MDCSlidableDrawerFoundation { - isRootTransitioningEventTarget_() { return isRootTransitioningEventTarget; } diff --git a/test/unit/mdc-menu/simple.foundation.test.js b/test/unit/mdc-menu/simple.foundation.test.js index 45c88349fb8..c50b81170e0 100644 --- a/test/unit/mdc-menu/simple.foundation.test.js +++ b/test/unit/mdc-menu/simple.foundation.test.js @@ -105,20 +105,20 @@ testFoundation('#open adds the open class to the menu', ({foundation, mockAdapte }); testFoundation('#open removes the animation class at the end of the animation', - ({foundation, mockAdapter, mockRaf}) => { - td.when(mockAdapter.getAccurateTime()).thenReturn(0); - td.when(mockAdapter.hasClass('mdc-simple-menu--open-from-top-right')).thenReturn(true); - - foundation.open(); - mockRaf.flush(); - mockRaf.flush(); - td.verify(mockAdapter.addClass('mdc-simple-menu--animating')); - - td.when(mockAdapter.getAccurateTime()).thenReturn(500); - mockRaf.flush(); - mockRaf.flush(); - td.verify(mockAdapter.removeClass('mdc-simple-menu--animating')); - }); + ({foundation, mockAdapter, mockRaf}) => { + td.when(mockAdapter.getAccurateTime()).thenReturn(0); + td.when(mockAdapter.hasClass('mdc-simple-menu--open-from-top-right')).thenReturn(true); + + foundation.open(); + mockRaf.flush(); + mockRaf.flush(); + td.verify(mockAdapter.addClass('mdc-simple-menu--animating')); + + td.when(mockAdapter.getAccurateTime()).thenReturn(500); + mockRaf.flush(); + mockRaf.flush(); + td.verify(mockAdapter.removeClass('mdc-simple-menu--animating')); + }); testFoundation('#open focuses the menu at the end of the animation', ({foundation, mockAdapter, mockRaf}) => { td.when(mockAdapter.getAccurateTime()).thenReturn(0); @@ -146,130 +146,130 @@ testFoundation('#open on a not focused menu does not focust at index 0', ({found }); testFoundation('#open anchors the menu on the top left in LTR, given enough room', - ({foundation, mockAdapter, mockRaf}) => { - td.when(mockAdapter.hasAnchor()).thenReturn(true); - td.when(mockAdapter.isRtl()).thenReturn(false); - td.when(mockAdapter.getInnerDimensions()).thenReturn({height: 200, width: 100}); - td.when(mockAdapter.getWindowDimensions()).thenReturn({height: 1000, width: 1000}); - td.when(mockAdapter.getAnchorDimensions()).thenReturn({ - height: 20, width: 40, top: 20, bottom: 40, left: 20, right: 60, - }); - td.when(mockAdapter.getAccurateTime()).thenReturn(0); - - foundation.open(); - mockRaf.flush(); - mockRaf.flush(); - - td.when(mockAdapter.getAccurateTime()).thenReturn(500); - mockRaf.flush(); - td.verify(mockAdapter.setTransformOrigin('top left')); - td.verify(mockAdapter.setPosition({left: '0', top: '0'})); + ({foundation, mockAdapter, mockRaf}) => { + td.when(mockAdapter.hasAnchor()).thenReturn(true); + td.when(mockAdapter.isRtl()).thenReturn(false); + td.when(mockAdapter.getInnerDimensions()).thenReturn({height: 200, width: 100}); + td.when(mockAdapter.getWindowDimensions()).thenReturn({height: 1000, width: 1000}); + td.when(mockAdapter.getAnchorDimensions()).thenReturn({ + height: 20, width: 40, top: 20, bottom: 40, left: 20, right: 60, }); + td.when(mockAdapter.getAccurateTime()).thenReturn(0); + + foundation.open(); + mockRaf.flush(); + mockRaf.flush(); + + td.when(mockAdapter.getAccurateTime()).thenReturn(500); + mockRaf.flush(); + td.verify(mockAdapter.setTransformOrigin('top left')); + td.verify(mockAdapter.setPosition({left: '0', top: '0'})); + }); testFoundation('#open anchors the menu on the top right in LTR when close to the right edge', - ({foundation, mockAdapter, mockRaf}) => { - td.when(mockAdapter.hasAnchor()).thenReturn(true); - td.when(mockAdapter.isRtl()).thenReturn(false); - td.when(mockAdapter.getInnerDimensions()).thenReturn({height: 200, width: 100}); - td.when(mockAdapter.getWindowDimensions()).thenReturn({height: 1000, width: 1000}); - td.when(mockAdapter.getAnchorDimensions()).thenReturn({ - height: 20, width: 40, top: 20, bottom: 40, left: 950, right: 990, - }); - td.when(mockAdapter.getAccurateTime()).thenReturn(0); - - foundation.open(); - mockRaf.flush(); - mockRaf.flush(); - - td.when(mockAdapter.getAccurateTime()).thenReturn(500); - mockRaf.flush(); - td.verify(mockAdapter.setTransformOrigin('top right')); - td.verify(mockAdapter.setPosition({right: '0', top: '0'})); + ({foundation, mockAdapter, mockRaf}) => { + td.when(mockAdapter.hasAnchor()).thenReturn(true); + td.when(mockAdapter.isRtl()).thenReturn(false); + td.when(mockAdapter.getInnerDimensions()).thenReturn({height: 200, width: 100}); + td.when(mockAdapter.getWindowDimensions()).thenReturn({height: 1000, width: 1000}); + td.when(mockAdapter.getAnchorDimensions()).thenReturn({ + height: 20, width: 40, top: 20, bottom: 40, left: 950, right: 990, }); + td.when(mockAdapter.getAccurateTime()).thenReturn(0); + + foundation.open(); + mockRaf.flush(); + mockRaf.flush(); + + td.when(mockAdapter.getAccurateTime()).thenReturn(500); + mockRaf.flush(); + td.verify(mockAdapter.setTransformOrigin('top right')); + td.verify(mockAdapter.setPosition({right: '0', top: '0'})); + }); testFoundation('#open anchors the menu on the top right in RTL, given enough room', - ({foundation, mockAdapter, mockRaf}) => { - td.when(mockAdapter.hasAnchor()).thenReturn(true); - td.when(mockAdapter.isRtl()).thenReturn(true); - td.when(mockAdapter.getInnerDimensions()).thenReturn({height: 200, width: 100}); - td.when(mockAdapter.getWindowDimensions()).thenReturn({height: 1000, width: 1000}); - td.when(mockAdapter.getAnchorDimensions()).thenReturn({ - height: 20, width: 40, top: 20, bottom: 40, left: 500, right: 540, - }); - td.when(mockAdapter.getAccurateTime()).thenReturn(0); - - foundation.open(); - mockRaf.flush(); - mockRaf.flush(); - - td.when(mockAdapter.getAccurateTime()).thenReturn(500); - mockRaf.flush(); - td.verify(mockAdapter.setTransformOrigin('top right')); - td.verify(mockAdapter.setPosition({right: '0', top: '0'})); + ({foundation, mockAdapter, mockRaf}) => { + td.when(mockAdapter.hasAnchor()).thenReturn(true); + td.when(mockAdapter.isRtl()).thenReturn(true); + td.when(mockAdapter.getInnerDimensions()).thenReturn({height: 200, width: 100}); + td.when(mockAdapter.getWindowDimensions()).thenReturn({height: 1000, width: 1000}); + td.when(mockAdapter.getAnchorDimensions()).thenReturn({ + height: 20, width: 40, top: 20, bottom: 40, left: 500, right: 540, }); + td.when(mockAdapter.getAccurateTime()).thenReturn(0); + + foundation.open(); + mockRaf.flush(); + mockRaf.flush(); + + td.when(mockAdapter.getAccurateTime()).thenReturn(500); + mockRaf.flush(); + td.verify(mockAdapter.setTransformOrigin('top right')); + td.verify(mockAdapter.setPosition({right: '0', top: '0'})); + }); testFoundation('#open anchors the menu on the top left in RTL when close to the left edge', - ({foundation, mockAdapter, mockRaf}) => { - td.when(mockAdapter.hasAnchor()).thenReturn(true); - td.when(mockAdapter.isRtl()).thenReturn(true); - td.when(mockAdapter.getInnerDimensions()).thenReturn({height: 200, width: 100}); - td.when(mockAdapter.getWindowDimensions()).thenReturn({height: 1000, width: 1000}); - td.when(mockAdapter.getAnchorDimensions()).thenReturn({ - height: 20, width: 40, top: 20, bottom: 40, left: 10, right: 50, - }); - td.when(mockAdapter.getAccurateTime()).thenReturn(0); - - foundation.open(); - mockRaf.flush(); - mockRaf.flush(); - - td.when(mockAdapter.getAccurateTime()).thenReturn(500); - mockRaf.flush(); - td.verify(mockAdapter.setTransformOrigin('top left')); - td.verify(mockAdapter.setPosition({left: '0', top: '0'})); + ({foundation, mockAdapter, mockRaf}) => { + td.when(mockAdapter.hasAnchor()).thenReturn(true); + td.when(mockAdapter.isRtl()).thenReturn(true); + td.when(mockAdapter.getInnerDimensions()).thenReturn({height: 200, width: 100}); + td.when(mockAdapter.getWindowDimensions()).thenReturn({height: 1000, width: 1000}); + td.when(mockAdapter.getAnchorDimensions()).thenReturn({ + height: 20, width: 40, top: 20, bottom: 40, left: 10, right: 50, }); + td.when(mockAdapter.getAccurateTime()).thenReturn(0); + + foundation.open(); + mockRaf.flush(); + mockRaf.flush(); + + td.when(mockAdapter.getAccurateTime()).thenReturn(500); + mockRaf.flush(); + td.verify(mockAdapter.setTransformOrigin('top left')); + td.verify(mockAdapter.setPosition({left: '0', top: '0'})); + }); testFoundation('#open anchors the menu on the bottom left in LTR when close to the bottom edge', - ({foundation, mockAdapter, mockRaf}) => { - td.when(mockAdapter.hasAnchor()).thenReturn(true); - td.when(mockAdapter.isRtl()).thenReturn(false); - td.when(mockAdapter.getInnerDimensions()).thenReturn({height: 200, width: 100}); - td.when(mockAdapter.getWindowDimensions()).thenReturn({height: 1000, width: 1000}); - td.when(mockAdapter.getAnchorDimensions()).thenReturn({ - height: 20, width: 40, top: 900, bottom: 920, left: 10, right: 50, - }); - td.when(mockAdapter.getAccurateTime()).thenReturn(0); - - foundation.open(); - mockRaf.flush(); - mockRaf.flush(); - - td.when(mockAdapter.getAccurateTime()).thenReturn(500); - mockRaf.flush(); - td.verify(mockAdapter.setTransformOrigin('bottom left')); - td.verify(mockAdapter.setPosition({left: '0', bottom: '0'})); + ({foundation, mockAdapter, mockRaf}) => { + td.when(mockAdapter.hasAnchor()).thenReturn(true); + td.when(mockAdapter.isRtl()).thenReturn(false); + td.when(mockAdapter.getInnerDimensions()).thenReturn({height: 200, width: 100}); + td.when(mockAdapter.getWindowDimensions()).thenReturn({height: 1000, width: 1000}); + td.when(mockAdapter.getAnchorDimensions()).thenReturn({ + height: 20, width: 40, top: 900, bottom: 920, left: 10, right: 50, }); + td.when(mockAdapter.getAccurateTime()).thenReturn(0); + + foundation.open(); + mockRaf.flush(); + mockRaf.flush(); + + td.when(mockAdapter.getAccurateTime()).thenReturn(500); + mockRaf.flush(); + td.verify(mockAdapter.setTransformOrigin('bottom left')); + td.verify(mockAdapter.setPosition({left: '0', bottom: '0'})); + }); testFoundation('#open anchors the menu on the top left in LTR when not close to the bottom edge', - ({foundation, mockAdapter, mockRaf}) => { - td.when(mockAdapter.hasAnchor()).thenReturn(true); - td.when(mockAdapter.isRtl()).thenReturn(false); - td.when(mockAdapter.getInnerDimensions()).thenReturn({height: 200, width: 100}); - td.when(mockAdapter.getWindowDimensions()).thenReturn({height: 1000, width: 1000}); - td.when(mockAdapter.getAnchorDimensions()).thenReturn({ - height: 20, width: 40, top: 900, bottom: 20, left: 10, right: 50, - }); - td.when(mockAdapter.getAccurateTime()).thenReturn(0); - - foundation.open(); - mockRaf.flush(); - mockRaf.flush(); - - td.when(mockAdapter.getAccurateTime()).thenReturn(500); - mockRaf.flush(); - td.verify(mockAdapter.setTransformOrigin('top left')); - td.verify(mockAdapter.setPosition({left: '0', top: '0'})); + ({foundation, mockAdapter, mockRaf}) => { + td.when(mockAdapter.hasAnchor()).thenReturn(true); + td.when(mockAdapter.isRtl()).thenReturn(false); + td.when(mockAdapter.getInnerDimensions()).thenReturn({height: 200, width: 100}); + td.when(mockAdapter.getWindowDimensions()).thenReturn({height: 1000, width: 1000}); + td.when(mockAdapter.getAnchorDimensions()).thenReturn({ + height: 20, width: 40, top: 900, bottom: 20, left: 10, right: 50, }); + td.when(mockAdapter.getAccurateTime()).thenReturn(0); + + foundation.open(); + mockRaf.flush(); + mockRaf.flush(); + + td.when(mockAdapter.getAccurateTime()).thenReturn(500); + mockRaf.flush(); + td.verify(mockAdapter.setTransformOrigin('top left')); + td.verify(mockAdapter.setPosition({left: '0', top: '0'})); + }); testFoundation('#close does nothing if event target has aria-disabled set to true', ({foundation, mockAdapter}) => { @@ -304,20 +304,20 @@ testFoundation('#close removes the open class from the menu', ({foundation, mock }); testFoundation('#close removes the animation class at the end of the animation', - ({foundation, mockAdapter, mockRaf}) => { - td.when(mockAdapter.getAccurateTime()).thenReturn(0); - td.when(mockAdapter.hasClass('mdc-simple-menu--open')).thenReturn(true); - td.when(mockAdapter.hasClass('mdc-simple-menu--open-from-bottom-right')).thenReturn(true); - - foundation.close(); - mockRaf.flush(); - mockRaf.flush(); - td.verify(mockAdapter.addClass('mdc-simple-menu--animating')); - - td.when(mockAdapter.getAccurateTime()).thenReturn(500); - mockRaf.flush(); - td.verify(mockAdapter.removeClass('mdc-simple-menu--animating')); - }); + ({foundation, mockAdapter, mockRaf}) => { + td.when(mockAdapter.getAccurateTime()).thenReturn(0); + td.when(mockAdapter.hasClass('mdc-simple-menu--open')).thenReturn(true); + td.when(mockAdapter.hasClass('mdc-simple-menu--open-from-bottom-right')).thenReturn(true); + + foundation.close(); + mockRaf.flush(); + mockRaf.flush(); + td.verify(mockAdapter.addClass('mdc-simple-menu--animating')); + + td.when(mockAdapter.getAccurateTime()).thenReturn(500); + mockRaf.flush(); + td.verify(mockAdapter.removeClass('mdc-simple-menu--animating')); + }); test('#isOpen returns true when the menu is open', () => { const {foundation} = setupTest(); diff --git a/test/unit/mdc-ripple/foundation-activation.test.js b/test/unit/mdc-ripple/foundation-activation.test.js index 5621233a1d7..480e31c8073 100644 --- a/test/unit/mdc-ripple/foundation-activation.test.js +++ b/test/unit/mdc-ripple/foundation-activation.test.js @@ -47,39 +47,41 @@ testFoundation('adds activation classes on mousedown', ({foundation, adapter, mo }); testFoundation('sets FG position from the coords to the center within surface on mousedown', - ({foundation, adapter, mockRaf}) => { - const handlers = captureHandlers(adapter); - const left = 50; - const top = 50; - const width = 200; - const height = 100; - const maxSize = Math.max(width, height); - const initialSize = maxSize * numbers.INITIAL_ORIGIN_SCALE; - const pageX = 100; - const pageY = 75; - - td.when(adapter.computeBoundingRect()).thenReturn({width, height, left, top}); - foundation.init(); - mockRaf.flush(); - - handlers.mousedown({pageX, pageY}); - mockRaf.flush(); - - const startPosition = { - x: pageX - left - (initialSize / 2), - y: pageY - top - (initialSize / 2), - }; - - const endPosition = { - x: (width / 2) - (initialSize / 2), - y: (height / 2) - (initialSize / 2), - }; - - td.verify(adapter.updateCssVariable(strings.VAR_FG_TRANSLATE_START, - `${startPosition.x}px, ${startPosition.y}px`)); - td.verify(adapter.updateCssVariable(strings.VAR_FG_TRANSLATE_END, - `${endPosition.x}px, ${endPosition.y}px`)); - }); + ({foundation, adapter, mockRaf}) => { + const handlers = captureHandlers(adapter); + const left = 50; + const top = 50; + const width = 200; + const height = 100; + const maxSize = Math.max(width, height); + const initialSize = maxSize * numbers.INITIAL_ORIGIN_SCALE; + const pageX = 100; + const pageY = 75; + + td.when(adapter.computeBoundingRect()).thenReturn({width, height, left, top}); + foundation.init(); + mockRaf.flush(); + + handlers.mousedown({pageX, pageY}); + mockRaf.flush(); + + const startPosition = { + x: pageX - left - (initialSize / 2), + y: pageY - top - (initialSize / 2), + }; + + const endPosition = { + x: (width / 2) - (initialSize / 2), + y: (height / 2) - (initialSize / 2), + }; + + td.verify(adapter.updateCssVariable( + strings.VAR_FG_TRANSLATE_START, `${startPosition.x}px, ${startPosition.y}px` + )); + td.verify(adapter.updateCssVariable( + strings.VAR_FG_TRANSLATE_END, `${endPosition.x}px, ${endPosition.y}px` + )); + }); testFoundation('adds activation classes on touchstart', ({foundation, adapter, mockRaf}) => { const handlers = captureHandlers(adapter); @@ -93,39 +95,41 @@ testFoundation('adds activation classes on touchstart', ({foundation, adapter, m }); testFoundation('sets FG position from the coords to the center within surface on touchstart', - ({foundation, adapter, mockRaf}) => { - const handlers = captureHandlers(adapter); - const left = 50; - const top = 50; - const width = 200; - const height = 100; - const maxSize = Math.max(width, height); - const initialSize = maxSize * numbers.INITIAL_ORIGIN_SCALE; - const pageX = 100; - const pageY = 75; - - td.when(adapter.computeBoundingRect()).thenReturn({width, height, left, top}); - foundation.init(); - mockRaf.flush(); - - handlers.touchstart({changedTouches: [{pageX, pageY}]}); - mockRaf.flush(); - - const startPosition = { - x: pageX - left - (initialSize / 2), - y: pageY - top - (initialSize / 2), - }; - - const endPosition = { - x: (width / 2) - (initialSize / 2), - y: (height / 2) - (initialSize / 2), - }; - - td.verify(adapter.updateCssVariable(strings.VAR_FG_TRANSLATE_START, - `${startPosition.x}px, ${startPosition.y}px`)); - td.verify(adapter.updateCssVariable(strings.VAR_FG_TRANSLATE_END, - `${endPosition.x}px, ${endPosition.y}px`)); - }); + ({foundation, adapter, mockRaf}) => { + const handlers = captureHandlers(adapter); + const left = 50; + const top = 50; + const width = 200; + const height = 100; + const maxSize = Math.max(width, height); + const initialSize = maxSize * numbers.INITIAL_ORIGIN_SCALE; + const pageX = 100; + const pageY = 75; + + td.when(adapter.computeBoundingRect()).thenReturn({width, height, left, top}); + foundation.init(); + mockRaf.flush(); + + handlers.touchstart({changedTouches: [{pageX, pageY}]}); + mockRaf.flush(); + + const startPosition = { + x: pageX - left - (initialSize / 2), + y: pageY - top - (initialSize / 2), + }; + + const endPosition = { + x: (width / 2) - (initialSize / 2), + y: (height / 2) - (initialSize / 2), + }; + + td.verify( + adapter.updateCssVariable(strings.VAR_FG_TRANSLATE_START, `${startPosition.x}px, ${startPosition.y}px`) + ); + td.verify( + adapter.updateCssVariable(strings.VAR_FG_TRANSLATE_END, `${endPosition.x}px, ${endPosition.y}px`) + ); + }); testFoundation('adds activation classes on pointerdown', ({foundation, adapter, mockRaf}) => { const handlers = captureHandlers(adapter); @@ -139,53 +143,55 @@ testFoundation('adds activation classes on pointerdown', ({foundation, adapter, }); testFoundation('sets FG position from the coords to the center within surface on pointerdown', - ({foundation, adapter, mockRaf}) => { - const handlers = captureHandlers(adapter); - const left = 50; - const top = 50; - const width = 200; - const height = 100; - const maxSize = Math.max(width, height); - const initialSize = maxSize * numbers.INITIAL_ORIGIN_SCALE; - const pageX = 100; - const pageY = 75; - - td.when(adapter.computeBoundingRect()).thenReturn({width, height, left, top}); - foundation.init(); - mockRaf.flush(); - - handlers.pointerdown({pageX, pageY}); - mockRaf.flush(); - - const startPosition = { - x: pageX - left - (initialSize / 2), - y: pageY - top - (initialSize / 2), - }; - - const endPosition = { - x: (width / 2) - (initialSize / 2), - y: (height / 2) - (initialSize / 2), - }; - - td.verify(adapter.updateCssVariable(strings.VAR_FG_TRANSLATE_START, - `${startPosition.x}px, ${startPosition.y}px`)); - td.verify(adapter.updateCssVariable(strings.VAR_FG_TRANSLATE_END, - `${endPosition.x}px, ${endPosition.y}px`)); - }); + ({foundation, adapter, mockRaf}) => { + const handlers = captureHandlers(adapter); + const left = 50; + const top = 50; + const width = 200; + const height = 100; + const maxSize = Math.max(width, height); + const initialSize = maxSize * numbers.INITIAL_ORIGIN_SCALE; + const pageX = 100; + const pageY = 75; + + td.when(adapter.computeBoundingRect()).thenReturn({width, height, left, top}); + foundation.init(); + mockRaf.flush(); + + handlers.pointerdown({pageX, pageY}); + mockRaf.flush(); + + const startPosition = { + x: pageX - left - (initialSize / 2), + y: pageY - top - (initialSize / 2), + }; + + const endPosition = { + x: (width / 2) - (initialSize / 2), + y: (height / 2) - (initialSize / 2), + }; + + td.verify(adapter.updateCssVariable( + strings.VAR_FG_TRANSLATE_START, `${startPosition.x}px, ${startPosition.y}px` + )); + td.verify(adapter.updateCssVariable( + strings.VAR_FG_TRANSLATE_END, `${endPosition.x}px, ${endPosition.y}px` + )); + }); testFoundation('adds activation classes on keydown when surface is made active', - ({foundation, adapter, mockRaf}) => { - const handlers = captureHandlers(adapter); - td.when(adapter.isSurfaceActive()).thenReturn(true); - foundation.init(); - mockRaf.flush(); + ({foundation, adapter, mockRaf}) => { + const handlers = captureHandlers(adapter); + td.when(adapter.isSurfaceActive()).thenReturn(true); + foundation.init(); + mockRaf.flush(); - handlers.keydown(); - mockRaf.flush(); + handlers.keydown(); + mockRaf.flush(); - td.verify(adapter.addClass(cssClasses.BG_ACTIVE_FILL)); - td.verify(adapter.addClass(cssClasses.FG_ACTIVATION)); - }); + td.verify(adapter.addClass(cssClasses.BG_ACTIVE_FILL)); + td.verify(adapter.addClass(cssClasses.FG_ACTIVATION)); + }); testFoundation('sets FG position to center on non-pointer activation', ({foundation, adapter, mockRaf}) => { const handlers = captureHandlers(adapter); @@ -210,9 +216,9 @@ testFoundation('sets FG position to center on non-pointer activation', ({foundat }; td.verify(adapter.updateCssVariable(strings.VAR_FG_TRANSLATE_START, - `${position.x}px, ${position.y}px`)); + `${position.x}px, ${position.y}px`)); td.verify(adapter.updateCssVariable(strings.VAR_FG_TRANSLATE_END, - `${position.x}px, ${position.y}px`)); + `${position.x}px, ${position.y}px`)); }); testFoundation('adds activation classes on programmatic activation', ({foundation, adapter, mockRaf}) => { @@ -250,54 +256,54 @@ testFoundation('sets FG position to center on non-pointer activation', ({foundat }; td.verify(adapter.updateCssVariable(strings.VAR_FG_TRANSLATE_START, - `${position.x}px, ${position.y}px`)); + `${position.x}px, ${position.y}px`)); td.verify(adapter.updateCssVariable(strings.VAR_FG_TRANSLATE_END, - `${position.x}px, ${position.y}px`)); + `${position.x}px, ${position.y}px`)); }); testFoundation('does not redundantly add classes on touchstart followed by mousedown', - ({foundation, adapter, mockRaf}) => { - const handlers = captureHandlers(adapter); - foundation.init(); - mockRaf.flush(); - - handlers.touchstart({changedTouches: [{pageX: 0, pageY: 0}]}); - mockRaf.flush(); - handlers.mousedown(); - mockRaf.flush(); - td.verify(adapter.addClass(cssClasses.BG_ACTIVE_FILL), {times: 1}); - td.verify(adapter.addClass(cssClasses.FG_ACTIVATION), {times: 1}); - }); + ({foundation, adapter, mockRaf}) => { + const handlers = captureHandlers(adapter); + foundation.init(); + mockRaf.flush(); + + handlers.touchstart({changedTouches: [{pageX: 0, pageY: 0}]}); + mockRaf.flush(); + handlers.mousedown(); + mockRaf.flush(); + td.verify(adapter.addClass(cssClasses.BG_ACTIVE_FILL), {times: 1}); + td.verify(adapter.addClass(cssClasses.FG_ACTIVATION), {times: 1}); + }); testFoundation('does not redundantly add classes on touchstart followed by pointerstart', - ({foundation, adapter, mockRaf}) => { - const handlers = captureHandlers(adapter); - foundation.init(); - mockRaf.flush(); - - handlers.touchstart({changedTouches: [{pageX: 0, pageY: 0}]}); - mockRaf.flush(); - handlers.pointerdown(); - mockRaf.flush(); - td.verify(adapter.addClass(cssClasses.BG_ACTIVE_FILL), {times: 1}); - td.verify(adapter.addClass(cssClasses.FG_ACTIVATION), {times: 1}); - }); + ({foundation, adapter, mockRaf}) => { + const handlers = captureHandlers(adapter); + foundation.init(); + mockRaf.flush(); + + handlers.touchstart({changedTouches: [{pageX: 0, pageY: 0}]}); + mockRaf.flush(); + handlers.pointerdown(); + mockRaf.flush(); + td.verify(adapter.addClass(cssClasses.BG_ACTIVE_FILL), {times: 1}); + td.verify(adapter.addClass(cssClasses.FG_ACTIVATION), {times: 1}); + }); testFoundation('removes deactivation classes on activate to ensure ripples can be retriggered', - ({foundation, adapter, mockRaf}) => { - const handlers = captureHandlers(adapter); - foundation.init(); - mockRaf.flush(); + ({foundation, adapter, mockRaf}) => { + const handlers = captureHandlers(adapter); + foundation.init(); + mockRaf.flush(); - handlers.mousedown(); - mockRaf.flush(); - handlers.mouseup(); - mockRaf.flush(); - handlers.mousedown(); - mockRaf.flush(); + handlers.mousedown(); + mockRaf.flush(); + handlers.mouseup(); + mockRaf.flush(); + handlers.mousedown(); + mockRaf.flush(); - td.verify(adapter.removeClass(cssClasses.FG_DEACTIVATION)); - }); + td.verify(adapter.removeClass(cssClasses.FG_DEACTIVATION)); + }); testFoundation('displays the foreground ripple on activation when unbounded', ({foundation, adapter, mockRaf}) => { const handlers = captureHandlers(adapter); @@ -313,16 +319,16 @@ testFoundation('displays the foreground ripple on activation when unbounded', ({ }); testFoundation('clears translation custom properties when unbounded in case ripple was switched from bounded', - ({foundation, adapter, mockRaf}) => { - const handlers = captureHandlers(adapter); + ({foundation, adapter, mockRaf}) => { + const handlers = captureHandlers(adapter); - td.when(adapter.isUnbounded()).thenReturn(true); - foundation.init(); - mockRaf.flush(); + td.when(adapter.isUnbounded()).thenReturn(true); + foundation.init(); + mockRaf.flush(); - handlers.pointerdown({pageX: 100, pageY: 75}); - mockRaf.flush(); + handlers.pointerdown({pageX: 100, pageY: 75}); + mockRaf.flush(); - td.verify(adapter.updateCssVariable(strings.VAR_FG_TRANSLATE_START, '')); - td.verify(adapter.updateCssVariable(strings.VAR_FG_TRANSLATE_END, '')); - }); + td.verify(adapter.updateCssVariable(strings.VAR_FG_TRANSLATE_START, '')); + td.verify(adapter.updateCssVariable(strings.VAR_FG_TRANSLATE_END, '')); + }); diff --git a/test/unit/mdc-ripple/foundation-deactivation.test.js b/test/unit/mdc-ripple/foundation-deactivation.test.js index 4f579ac5507..3e66a6e15a4 100644 --- a/test/unit/mdc-ripple/foundation-deactivation.test.js +++ b/test/unit/mdc-ripple/foundation-deactivation.test.js @@ -100,56 +100,56 @@ testFoundation('runs deactivation UX on mouseup after mousedown', ({foundation, }); testFoundation('runs deactivation on keyup after keydown when keydown makes surface active', - ({foundation, adapter, mockRaf}) => { - const handlers = captureHandlers(adapter); - const clock = lolex.install(); - td.when(adapter.isSurfaceActive()).thenReturn(true); + ({foundation, adapter, mockRaf}) => { + const handlers = captureHandlers(adapter); + const clock = lolex.install(); + td.when(adapter.isSurfaceActive()).thenReturn(true); - foundation.init(); - mockRaf.flush(); + foundation.init(); + mockRaf.flush(); - handlers.keydown({key: 'Space'}); - mockRaf.flush(); + handlers.keydown({key: 'Space'}); + mockRaf.flush(); - handlers.keyup({key: 'Space'}); - mockRaf.flush(); - clock.tick(DEACTIVATION_TIMEOUT_MS); + handlers.keyup({key: 'Space'}); + mockRaf.flush(); + clock.tick(DEACTIVATION_TIMEOUT_MS); - td.verify(adapter.removeClass(cssClasses.BG_FOCUSED)); - td.verify(adapter.removeClass(cssClasses.BG_ACTIVE_FILL), {times: 2}); - td.verify(adapter.removeClass(cssClasses.FG_ACTIVATION), {times: 2}); - td.verify(adapter.addClass(cssClasses.FG_DEACTIVATION)); + td.verify(adapter.removeClass(cssClasses.BG_FOCUSED)); + td.verify(adapter.removeClass(cssClasses.BG_ACTIVE_FILL), {times: 2}); + td.verify(adapter.removeClass(cssClasses.FG_ACTIVATION), {times: 2}); + td.verify(adapter.addClass(cssClasses.FG_DEACTIVATION)); - clock.tick(numbers.FG_DEACTIVATION_MS); - td.verify(adapter.removeClass(cssClasses.FG_DEACTIVATION)); + clock.tick(numbers.FG_DEACTIVATION_MS); + td.verify(adapter.removeClass(cssClasses.FG_DEACTIVATION)); - clock.uninstall(); - }); + clock.uninstall(); + }); testFoundation('does not run deactivation on keyup after keydown if keydown did not make surface active', - ({foundation, adapter, mockRaf}) => { - const handlers = captureHandlers(adapter); - const clock = lolex.install(); - td.when(adapter.isSurfaceActive()).thenReturn(false); - - foundation.init(); - mockRaf.flush(); - - handlers.keydown({key: 'Space'}); - mockRaf.flush(); - - handlers.keyup({key: 'Space'}); - mockRaf.flush(); - clock.tick(DEACTIVATION_TIMEOUT_MS); - - // Note that all of these should be called 0 times since a keydown that does not make a surface active should never - // activate it in the first place. - td.verify(adapter.removeClass(cssClasses.BG_FOCUSED), {times: 0}); - td.verify(adapter.removeClass(cssClasses.BG_ACTIVE_FILL), {times: 0}); - td.verify(adapter.removeClass(cssClasses.FG_ACTIVATION), {times: 0}); - td.verify(adapter.addClass(cssClasses.FG_DEACTIVATION), {times: 0}); - clock.uninstall(); - }); + ({foundation, adapter, mockRaf}) => { + const handlers = captureHandlers(adapter); + const clock = lolex.install(); + td.when(adapter.isSurfaceActive()).thenReturn(false); + + foundation.init(); + mockRaf.flush(); + + handlers.keydown({key: 'Space'}); + mockRaf.flush(); + + handlers.keyup({key: 'Space'}); + mockRaf.flush(); + clock.tick(DEACTIVATION_TIMEOUT_MS); + + // Note that all of these should be called 0 times since a keydown that does not make a surface active should never + // activate it in the first place. + td.verify(adapter.removeClass(cssClasses.BG_FOCUSED), {times: 0}); + td.verify(adapter.removeClass(cssClasses.BG_ACTIVE_FILL), {times: 0}); + td.verify(adapter.removeClass(cssClasses.FG_ACTIVATION), {times: 0}); + td.verify(adapter.addClass(cssClasses.FG_DEACTIVATION), {times: 0}); + clock.uninstall(); + }); testFoundation('runs deactivation UX on public deactivate() call', ({foundation, adapter, mockRaf}) => { const clock = lolex.install(); @@ -176,29 +176,29 @@ testFoundation('runs deactivation UX on public deactivate() call', ({foundation, }); testFoundation('runs deactivation UX when activation UX timer finishes first (activation held for a long time)', - ({foundation, adapter, mockRaf}) => { - const handlers = captureHandlers(adapter); - const clock = lolex.install(); - foundation.init(); - mockRaf.flush(); + ({foundation, adapter, mockRaf}) => { + const handlers = captureHandlers(adapter); + const clock = lolex.install(); + foundation.init(); + mockRaf.flush(); - handlers.mousedown({pageX: 0, pageY: 0}); - mockRaf.flush(); + handlers.mousedown({pageX: 0, pageY: 0}); + mockRaf.flush(); - clock.tick(DEACTIVATION_TIMEOUT_MS); - handlers.mouseup(); - mockRaf.flush(); + clock.tick(DEACTIVATION_TIMEOUT_MS); + handlers.mouseup(); + mockRaf.flush(); - td.verify(adapter.removeClass(cssClasses.BG_FOCUSED)); - td.verify(adapter.removeClass(cssClasses.BG_ACTIVE_FILL), {times: 2}); - td.verify(adapter.removeClass(cssClasses.FG_ACTIVATION), {times: 2}); - td.verify(adapter.addClass(cssClasses.FG_DEACTIVATION)); + td.verify(adapter.removeClass(cssClasses.BG_FOCUSED)); + td.verify(adapter.removeClass(cssClasses.BG_ACTIVE_FILL), {times: 2}); + td.verify(adapter.removeClass(cssClasses.FG_ACTIVATION), {times: 2}); + td.verify(adapter.addClass(cssClasses.FG_DEACTIVATION)); - clock.tick(numbers.FG_DEACTIVATION_MS); - td.verify(adapter.removeClass(cssClasses.FG_DEACTIVATION)); + clock.tick(numbers.FG_DEACTIVATION_MS); + td.verify(adapter.removeClass(cssClasses.FG_DEACTIVATION)); - clock.uninstall(); - }); + clock.uninstall(); + }); testFoundation('clears any pending deactivation UX timers when re-triggered', ({foundation, adapter, mockRaf}) => { const handlers = captureHandlers(adapter); @@ -236,176 +236,176 @@ testFoundation('clears any pending deactivation UX timers when re-triggered', ({ }); testFoundation('clears any pending foreground deactivation class removal timers when re-triggered', - ({foundation, adapter, mockRaf}) => { - const handlers = captureHandlers(adapter); - const clock = lolex.install(); - foundation.init(); - mockRaf.flush(); - - // Trigger the first interaction - handlers.mousedown({pageX: 0, pageY: 0}); - mockRaf.flush(); - handlers.mouseup(); - mockRaf.flush(); - - // Tick the clock such that the deactivation UX gets run, but _not_ so the foreground deactivation removal - // timer gets run - clock.tick(DEACTIVATION_TIMEOUT_MS); - - // Sanity check that the foreground deactivation class removal was only called once within - // the activation code. - td.verify(adapter.removeClass(cssClasses.FG_DEACTIVATION), {times: 1}); - - // Trigger another activation - handlers.mousedown({pageX: 0, pageY: 0}); - mockRaf.flush(); - - // Tick the clock past the time when the initial foreground deactivation timer would have ran. - clock.tick(numbers.FG_DEACTIVATION_MS); - - // Verify that the foreground deactivation class removal was only called twice: once within the - // original activation, and again within this subsequent activation; NOT by means of any timers firing. - td.verify(adapter.removeClass(cssClasses.FG_DEACTIVATION), {times: 2}); - }); + ({foundation, adapter, mockRaf}) => { + const handlers = captureHandlers(adapter); + const clock = lolex.install(); + foundation.init(); + mockRaf.flush(); + + // Trigger the first interaction + handlers.mousedown({pageX: 0, pageY: 0}); + mockRaf.flush(); + handlers.mouseup(); + mockRaf.flush(); + + // Tick the clock such that the deactivation UX gets run, but _not_ so the foreground deactivation removal + // timer gets run + clock.tick(DEACTIVATION_TIMEOUT_MS); + + // Sanity check that the foreground deactivation class removal was only called once within + // the activation code. + td.verify(adapter.removeClass(cssClasses.FG_DEACTIVATION), {times: 1}); + + // Trigger another activation + handlers.mousedown({pageX: 0, pageY: 0}); + mockRaf.flush(); + + // Tick the clock past the time when the initial foreground deactivation timer would have ran. + clock.tick(numbers.FG_DEACTIVATION_MS); + + // Verify that the foreground deactivation class removal was only called twice: once within the + // original activation, and again within this subsequent activation; NOT by means of any timers firing. + td.verify(adapter.removeClass(cssClasses.FG_DEACTIVATION), {times: 2}); + }); testFoundation('waits until activation UX timer runs before removing active fill classes', - ({foundation, adapter, mockRaf}) => { - const handlers = captureHandlers(adapter); - const clock = lolex.install(); + ({foundation, adapter, mockRaf}) => { + const handlers = captureHandlers(adapter); + const clock = lolex.install(); - foundation.init(); - mockRaf.flush(); + foundation.init(); + mockRaf.flush(); - handlers.mousedown({pageX: 0, pageY: 0}); - mockRaf.flush(); + handlers.mousedown({pageX: 0, pageY: 0}); + mockRaf.flush(); - handlers.mouseup(); - mockRaf.flush(); - clock.tick(DEACTIVATION_TIMEOUT_MS - 1); + handlers.mouseup(); + mockRaf.flush(); + clock.tick(DEACTIVATION_TIMEOUT_MS - 1); - td.verify(adapter.removeClass(cssClasses.BG_ACTIVE_FILL), {times: 1}); - td.verify(adapter.removeClass(cssClasses.FG_ACTIVATION), {times: 1}); - td.verify(adapter.addClass(cssClasses.FG_DEACTIVATION), {times: 0}); - clock.uninstall(); - }); + td.verify(adapter.removeClass(cssClasses.BG_ACTIVE_FILL), {times: 1}); + td.verify(adapter.removeClass(cssClasses.FG_ACTIVATION), {times: 1}); + td.verify(adapter.addClass(cssClasses.FG_DEACTIVATION), {times: 0}); + clock.uninstall(); + }); testFoundation('waits until actual deactivation UX is needed if animation finishes before deactivating', - ({foundation, adapter, mockRaf}) => { - const handlers = captureHandlers(adapter); - const clock = lolex.install(); + ({foundation, adapter, mockRaf}) => { + const handlers = captureHandlers(adapter); + const clock = lolex.install(); - foundation.init(); - mockRaf.flush(); + foundation.init(); + mockRaf.flush(); - handlers.mousedown({pageX: 0, pageY: 0}); - mockRaf.flush(); - clock.tick(DEACTIVATION_TIMEOUT_MS); + handlers.mousedown({pageX: 0, pageY: 0}); + mockRaf.flush(); + clock.tick(DEACTIVATION_TIMEOUT_MS); - td.verify(adapter.removeClass(cssClasses.BG_ACTIVE_FILL), {times: 1}); - td.verify(adapter.removeClass(cssClasses.FG_ACTIVATION), {times: 1}); - td.verify(adapter.addClass(cssClasses.FG_DEACTIVATION), {times: 0}); - clock.uninstall(); - }); + td.verify(adapter.removeClass(cssClasses.BG_ACTIVE_FILL), {times: 1}); + td.verify(adapter.removeClass(cssClasses.FG_ACTIVATION), {times: 1}); + td.verify(adapter.addClass(cssClasses.FG_DEACTIVATION), {times: 0}); + clock.uninstall(); + }); testFoundation('removes BG_FOCUSED class immediately without waiting for animationend event', - ({foundation, adapter, mockRaf}) => { - const handlers = captureHandlers(adapter); - const clock = lolex.install(); + ({foundation, adapter, mockRaf}) => { + const handlers = captureHandlers(adapter); + const clock = lolex.install(); - foundation.init(); - mockRaf.flush(); + foundation.init(); + mockRaf.flush(); - handlers.mousedown({pageX: 0, pageY: 0}); - mockRaf.flush(); + handlers.mousedown({pageX: 0, pageY: 0}); + mockRaf.flush(); - handlers.mouseup(); - mockRaf.flush(); + handlers.mouseup(); + mockRaf.flush(); - td.verify(adapter.removeClass(cssClasses.BG_FOCUSED)); - clock.uninstall(); - }); + td.verify(adapter.removeClass(cssClasses.BG_FOCUSED)); + clock.uninstall(); + }); testFoundation('only re-activates when there are no additional pointer events to be processed', - ({foundation, adapter, mockRaf}) => { - const handlers = captureHandlers(adapter); - const clock = lolex.install(); - foundation.init(); - mockRaf.flush(); - - // Simulate Android 6 / Chrome latest event flow. - handlers.pointerdown({pageX: 0, pageY: 0}); - mockRaf.flush(); - handlers.touchstart({changedTouches: [{pageX: 0, pageY: 0}]}); - mockRaf.flush(); - - clock.tick(DEACTIVATION_TIMEOUT_MS); - handlers.pointerup(); - mockRaf.flush(); - - // At this point, the deactivation UX should have run, since the initial activation was triggered by - // a pointerdown event. - td.verify(adapter.removeClass(cssClasses.BG_ACTIVE_FILL), {times: 2}); - td.verify(adapter.removeClass(cssClasses.FG_ACTIVATION), {times: 2}); - td.verify(adapter.addClass(cssClasses.FG_DEACTIVATION), {times: 1}); - - handlers.touchend(); - mockRaf.flush(); - - // Verify that deactivation UX has not been run redundantly - td.verify(adapter.removeClass(cssClasses.BG_FOCUSED), {times: 1}); - td.verify(adapter.removeClass(cssClasses.BG_ACTIVE_FILL), {times: 2}); - td.verify(adapter.removeClass(cssClasses.FG_ACTIVATION), {times: 2}); - td.verify(adapter.addClass(cssClasses.FG_DEACTIVATION), {times: 1}); - - handlers.mousedown({pageX: 0, pageY: 0}); - mockRaf.flush(); - - // Verify that activation only happened once, at pointerdown - td.verify(adapter.addClass(cssClasses.BG_ACTIVE_FILL), {times: 1}); - td.verify(adapter.addClass(cssClasses.FG_ACTIVATION), {times: 1}); - - handlers.mouseup(); - mockRaf.flush(); - clock.tick(DEACTIVATION_TIMEOUT_MS); - - // Finally, verify that since mouseup happened, we can re-activate the ripple. - handlers.mousedown({pageX: 0, pageY: 0}); - mockRaf.flush(); - td.verify(adapter.addClass(cssClasses.BG_ACTIVE_FILL), {times: 2}); - td.verify(adapter.addClass(cssClasses.FG_ACTIVATION), {times: 2}); - clock.uninstall(); - }); + ({foundation, adapter, mockRaf}) => { + const handlers = captureHandlers(adapter); + const clock = lolex.install(); + foundation.init(); + mockRaf.flush(); + + // Simulate Android 6 / Chrome latest event flow. + handlers.pointerdown({pageX: 0, pageY: 0}); + mockRaf.flush(); + handlers.touchstart({changedTouches: [{pageX: 0, pageY: 0}]}); + mockRaf.flush(); + + clock.tick(DEACTIVATION_TIMEOUT_MS); + handlers.pointerup(); + mockRaf.flush(); + + // At this point, the deactivation UX should have run, since the initial activation was triggered by + // a pointerdown event. + td.verify(adapter.removeClass(cssClasses.BG_ACTIVE_FILL), {times: 2}); + td.verify(adapter.removeClass(cssClasses.FG_ACTIVATION), {times: 2}); + td.verify(adapter.addClass(cssClasses.FG_DEACTIVATION), {times: 1}); + + handlers.touchend(); + mockRaf.flush(); + + // Verify that deactivation UX has not been run redundantly + td.verify(adapter.removeClass(cssClasses.BG_FOCUSED), {times: 1}); + td.verify(adapter.removeClass(cssClasses.BG_ACTIVE_FILL), {times: 2}); + td.verify(adapter.removeClass(cssClasses.FG_ACTIVATION), {times: 2}); + td.verify(adapter.addClass(cssClasses.FG_DEACTIVATION), {times: 1}); + + handlers.mousedown({pageX: 0, pageY: 0}); + mockRaf.flush(); + + // Verify that activation only happened once, at pointerdown + td.verify(adapter.addClass(cssClasses.BG_ACTIVE_FILL), {times: 1}); + td.verify(adapter.addClass(cssClasses.FG_ACTIVATION), {times: 1}); + + handlers.mouseup(); + mockRaf.flush(); + clock.tick(DEACTIVATION_TIMEOUT_MS); + + // Finally, verify that since mouseup happened, we can re-activate the ripple. + handlers.mousedown({pageX: 0, pageY: 0}); + mockRaf.flush(); + td.verify(adapter.addClass(cssClasses.BG_ACTIVE_FILL), {times: 2}); + td.verify(adapter.addClass(cssClasses.FG_ACTIVATION), {times: 2}); + clock.uninstall(); + }); testFoundation('ensures pointer event deactivation occurs even if activation rAF not run', - ({foundation, adapter, mockRaf}) => { - const handlers = captureHandlers(adapter); - const clock = lolex.install(); - foundation.init(); - mockRaf.flush(); - - handlers.mousedown({pageX: 0, pageY: 0}); - mockRaf.pendingFrames.shift(); - handlers.mouseup(); - mockRaf.flush(); - clock.tick(DEACTIVATION_TIMEOUT_MS); - - td.verify(adapter.removeClass(cssClasses.BG_FOCUSED), {times: 1}); - clock.uninstall(); - }); + ({foundation, adapter, mockRaf}) => { + const handlers = captureHandlers(adapter); + const clock = lolex.install(); + foundation.init(); + mockRaf.flush(); + + handlers.mousedown({pageX: 0, pageY: 0}); + mockRaf.pendingFrames.shift(); + handlers.mouseup(); + mockRaf.flush(); + clock.tick(DEACTIVATION_TIMEOUT_MS); + + td.verify(adapter.removeClass(cssClasses.BG_FOCUSED), {times: 1}); + clock.uninstall(); + }); testFoundation('ensures non-pointer event deactivation does not occurs even if activation rAF not run', - ({foundation, adapter, mockRaf}) => { - const handlers = captureHandlers(adapter); - const clock = lolex.install(); - foundation.init(); - mockRaf.flush(); - - handlers.keydown({key: 'Space'}); - mockRaf.pendingFrames.shift(); - handlers.keyup({key: 'Space'}); - mockRaf.flush(); - clock.tick(DEACTIVATION_TIMEOUT_MS); - - td.verify(adapter.removeClass(cssClasses.BG_FOCUSED), {times: 0}); - clock.uninstall(); - }); + ({foundation, adapter, mockRaf}) => { + const handlers = captureHandlers(adapter); + const clock = lolex.install(); + foundation.init(); + mockRaf.flush(); + + handlers.keydown({key: 'Space'}); + mockRaf.pendingFrames.shift(); + handlers.keyup({key: 'Space'}); + mockRaf.flush(); + clock.tick(DEACTIVATION_TIMEOUT_MS); + + td.verify(adapter.removeClass(cssClasses.BG_FOCUSED), {times: 0}); + clock.uninstall(); + }); diff --git a/test/unit/mdc-ripple/foundation.test.js b/test/unit/mdc-ripple/foundation.test.js index 07e89cfcbdc..d72b685e2b4 100644 --- a/test/unit/mdc-ripple/foundation.test.js +++ b/test/unit/mdc-ripple/foundation.test.js @@ -62,67 +62,67 @@ testFoundation('#init adds unbounded class when adapter indicates unbounded', ({ }); testFoundation('#init does not add unbounded class when adapter does not indicate unbounded (default)', - ({adapter, foundation, mockRaf}) => { - foundation.init(); - mockRaf.flush(); + ({adapter, foundation, mockRaf}) => { + foundation.init(); + mockRaf.flush(); - td.verify(adapter.addClass(cssClasses.UNBOUNDED), {times: 0}); - }); + td.verify(adapter.addClass(cssClasses.UNBOUNDED), {times: 0}); + }); testFoundation('#init gracefully exits when css variables are not supported', false, - ({foundation, adapter, mockRaf}) => { - foundation.init(); - mockRaf.flush(); + ({foundation, adapter, mockRaf}) => { + foundation.init(); + mockRaf.flush(); - td.verify(adapter.addClass(cssClasses.ROOT), {times: 0}); - }); + td.verify(adapter.addClass(cssClasses.ROOT), {times: 0}); + }); testFoundation(`#init sets ${strings.VAR_SURFACE_WIDTH} css variable to the clientRect's width`, - ({foundation, adapter, mockRaf}) => { - td.when(adapter.computeBoundingRect()).thenReturn({width: 200, height: 100}); - foundation.init(); - mockRaf.flush(); + ({foundation, adapter, mockRaf}) => { + td.when(adapter.computeBoundingRect()).thenReturn({width: 200, height: 100}); + foundation.init(); + mockRaf.flush(); - td.verify(adapter.updateCssVariable(strings.VAR_SURFACE_WIDTH, '200px')); - }); + td.verify(adapter.updateCssVariable(strings.VAR_SURFACE_WIDTH, '200px')); + }); testFoundation(`#init sets ${strings.VAR_SURFACE_HEIGHT} css variable to the clientRect's height`, - ({foundation, adapter, mockRaf}) => { - td.when(adapter.computeBoundingRect()).thenReturn({width: 200, height: 100}); - foundation.init(); - mockRaf.flush(); + ({foundation, adapter, mockRaf}) => { + td.when(adapter.computeBoundingRect()).thenReturn({width: 200, height: 100}); + foundation.init(); + mockRaf.flush(); - td.verify(adapter.updateCssVariable(strings.VAR_SURFACE_HEIGHT, '100px')); - }); + td.verify(adapter.updateCssVariable(strings.VAR_SURFACE_HEIGHT, '100px')); + }); testFoundation(`#init sets ${strings.VAR_FG_SIZE} to the circumscribing circle's diameter`, - ({foundation, adapter, mockRaf}) => { - const size = 200; - td.when(adapter.computeBoundingRect()).thenReturn({width: size, height: size / 2}); - foundation.init(); - mockRaf.flush(); - const initialSize = size * numbers.INITIAL_ORIGIN_SCALE; - - td.verify(adapter.updateCssVariable(strings.VAR_FG_SIZE, `${initialSize}px`)); - }); + ({foundation, adapter, mockRaf}) => { + const size = 200; + td.when(adapter.computeBoundingRect()).thenReturn({width: size, height: size / 2}); + foundation.init(); + mockRaf.flush(); + const initialSize = size * numbers.INITIAL_ORIGIN_SCALE; + + td.verify(adapter.updateCssVariable(strings.VAR_FG_SIZE, `${initialSize}px`)); + }); testFoundation(`#init centers via ${strings.VAR_LEFT} and ${strings.VAR_TOP} when unbounded`, - ({foundation, adapter, mockRaf}) => { - const width = 200; - const height = 100; - const maxSize = Math.max(width, height); - const initialSize = maxSize * numbers.INITIAL_ORIGIN_SCALE; - - td.when(adapter.computeBoundingRect()).thenReturn({width, height}); - td.when(adapter.isUnbounded()).thenReturn(true); - foundation.init(); - mockRaf.flush(); - - td.verify(adapter.updateCssVariable(strings.VAR_LEFT, + ({foundation, adapter, mockRaf}) => { + const width = 200; + const height = 100; + const maxSize = Math.max(width, height); + const initialSize = maxSize * numbers.INITIAL_ORIGIN_SCALE; + + td.when(adapter.computeBoundingRect()).thenReturn({width, height}); + td.when(adapter.isUnbounded()).thenReturn(true); + foundation.init(); + mockRaf.flush(); + + td.verify(adapter.updateCssVariable(strings.VAR_LEFT, `${Math.round((width / 2) - (initialSize / 2))}px`)); - td.verify(adapter.updateCssVariable(strings.VAR_TOP, + td.verify(adapter.updateCssVariable(strings.VAR_TOP, `${Math.round((height / 2) - (initialSize / 2))}px`)); - }); + }); testFoundation('#init registers events for all types of common interactions', ({foundation, adapter}) => { const expectedEvents = [ @@ -211,36 +211,36 @@ testFoundation('#destroy removes all CSS variables', ({foundation, adapter, mock }); testFoundation(`#layout sets ${strings.VAR_SURFACE_WIDTH} css variable to the clientRect's width`, - ({foundation, adapter, mockRaf}) => { - td.when(adapter.computeBoundingRect()).thenReturn({width: 200, height: 100}); - foundation.layout(); - mockRaf.flush(); + ({foundation, adapter, mockRaf}) => { + td.when(adapter.computeBoundingRect()).thenReturn({width: 200, height: 100}); + foundation.layout(); + mockRaf.flush(); - td.verify(adapter.updateCssVariable(strings.VAR_SURFACE_WIDTH, '200px')); - }); + td.verify(adapter.updateCssVariable(strings.VAR_SURFACE_WIDTH, '200px')); + }); testFoundation(`#layout sets ${strings.VAR_SURFACE_HEIGHT} css variable to the clientRect's height`, - ({foundation, adapter, mockRaf}) => { - td.when(adapter.computeBoundingRect()).thenReturn({width: 200, height: 100}); - foundation.layout(); - mockRaf.flush(); + ({foundation, adapter, mockRaf}) => { + td.when(adapter.computeBoundingRect()).thenReturn({width: 200, height: 100}); + foundation.layout(); + mockRaf.flush(); - td.verify(adapter.updateCssVariable(strings.VAR_SURFACE_HEIGHT, '100px')); - }); + td.verify(adapter.updateCssVariable(strings.VAR_SURFACE_HEIGHT, '100px')); + }); testFoundation(`#layout sets ${strings.VAR_FG_SIZE} to the circumscribing circle's diameter`, - ({foundation, adapter, mockRaf}) => { - const width = 200; - const height = 100; - const maxSize = Math.max(width, height); - const initialSize = maxSize * numbers.INITIAL_ORIGIN_SCALE; + ({foundation, adapter, mockRaf}) => { + const width = 200; + const height = 100; + const maxSize = Math.max(width, height); + const initialSize = maxSize * numbers.INITIAL_ORIGIN_SCALE; - td.when(adapter.computeBoundingRect()).thenReturn({width, height}); - foundation.layout(); - mockRaf.flush(); + td.when(adapter.computeBoundingRect()).thenReturn({width, height}); + foundation.layout(); + mockRaf.flush(); - td.verify(adapter.updateCssVariable(strings.VAR_FG_SIZE, `${initialSize}px`)); - }); + td.verify(adapter.updateCssVariable(strings.VAR_FG_SIZE, `${initialSize}px`)); + }); testFoundation(`#layout sets ${strings.VAR_FG_SCALE} based on the difference between the ` + 'proportion of the max radius and the initial size', ({foundation, adapter, mockRaf}) => { @@ -261,22 +261,22 @@ testFoundation(`#layout sets ${strings.VAR_FG_SCALE} based on the difference bet }); testFoundation(`#layout centers via ${strings.VAR_LEFT} and ${strings.VAR_TOP} when unbounded`, - ({foundation, adapter, mockRaf}) => { - const width = 200; - const height = 100; - const maxSize = Math.max(width, height); - const initialSize = maxSize * numbers.INITIAL_ORIGIN_SCALE; - - td.when(adapter.computeBoundingRect()).thenReturn({width, height}); - td.when(adapter.isUnbounded()).thenReturn(true); - foundation.layout(); - mockRaf.flush(); - - td.verify(adapter.updateCssVariable(strings.VAR_LEFT, + ({foundation, adapter, mockRaf}) => { + const width = 200; + const height = 100; + const maxSize = Math.max(width, height); + const initialSize = maxSize * numbers.INITIAL_ORIGIN_SCALE; + + td.when(adapter.computeBoundingRect()).thenReturn({width, height}); + td.when(adapter.isUnbounded()).thenReturn(true); + foundation.layout(); + mockRaf.flush(); + + td.verify(adapter.updateCssVariable(strings.VAR_LEFT, `${Math.round((width / 2) - (initialSize / 2))}px`)); - td.verify(adapter.updateCssVariable(strings.VAR_TOP, + td.verify(adapter.updateCssVariable(strings.VAR_TOP, `${Math.round((height / 2) - (initialSize / 2))}px`)); - }); + }); testFoundation('#layout debounces calls within the same frame', ({foundation, mockRaf}) => { foundation.layout(); diff --git a/test/unit/mdc-tabs/mdc-tab-bar-foundation.test.js b/test/unit/mdc-tabs/mdc-tab-bar-foundation.test.js index f7108fdf7f3..9c969b4aa69 100644 --- a/test/unit/mdc-tabs/mdc-tab-bar-foundation.test.js +++ b/test/unit/mdc-tabs/mdc-tab-bar-foundation.test.js @@ -118,8 +118,8 @@ test('#switchToTabAtIndex does nothing if the currently active tab is clicked', foundation.switchToTabAtIndex(0, true); td.verify(mockAdapter.setTabActiveAtIndex( - td.matchers.anything(), td.matchers.isA(Boolean) - ), {times: 0}); + td.matchers.anything(), td.matchers.isA(Boolean) + ), {times: 0}); td.verify(mockAdapter.notifyChange(td.matchers.anything()), {times: 0}); }); diff --git a/test/unit/mdc-tabs/mdc-tab-bar-scroller-foundation.test.js b/test/unit/mdc-tabs/mdc-tab-bar-scroller-foundation.test.js index cbaf64373cb..f1161baf610 100644 --- a/test/unit/mdc-tabs/mdc-tab-bar-scroller-foundation.test.js +++ b/test/unit/mdc-tabs/mdc-tab-bar-scroller-foundation.test.js @@ -496,9 +496,9 @@ test('focus in RTL context scrolls forward if distance between the right edge of const tabBarWidth = 900; td.when(mockAdapter.registerCapturedInteractionHandler(evtType, td.matchers.isA(Function))) - .thenDo((evtType, handler) => { - tabEvent = handler; - }); + .thenDo((evtType, handler) => { + tabEvent = handler; + }); td.when(mockAdapter.eventTargetHasClass(td.matchers.anything(), td.matchers.anything())).thenReturn(true); td.when(mockAdapter.isRTL()).thenReturn(true); diff --git a/webpack.config.js b/webpack.config.js index 5368addd463..cc2afae4e23 100644 --- a/webpack.config.js +++ b/webpack.config.js @@ -150,7 +150,7 @@ module.exports = [{ name: 'css', entry: { 'material-components-web': path.resolve( - './packages/material-components-web/material-components-web.scss'), + './packages/material-components-web/material-components-web.scss'), 'mdc.animation': path.resolve('./packages/mdc-animation/mdc-animation.scss'), 'mdc.button': path.resolve('./packages/mdc-button/mdc-button.scss'), 'mdc.card': path.resolve('./packages/mdc-card/mdc-card.scss'), From 9387ea4edb27f53fd424780c1aa600b664e77c58 Mon Sep 17 00:00:00 2001 From: Alex Sheehan Date: Thu, 29 Jun 2017 14:03:43 -0400 Subject: [PATCH 12/12] chore: Update eslint and fix lines that break the rules --- packages/mdc-base/index.js | 6 ++++-- packages/mdc-checkbox/adapter.js | 2 -- packages/mdc-checkbox/foundation.js | 2 +- packages/mdc-checkbox/index.js | 2 +- packages/mdc-ripple/adapter.js | 2 -- 5 files changed, 6 insertions(+), 8 deletions(-) diff --git a/packages/mdc-base/index.js b/packages/mdc-base/index.js index 0cb487501a9..1cdb2b43f6d 100644 --- a/packages/mdc-base/index.js +++ b/packages/mdc-base/index.js @@ -14,5 +14,7 @@ * limitations under the License. */ -export {default as MDCFoundation} from './foundation'; -export {default as MDCComponent} from './component'; +import MDCFoundation from './foundation'; +import MDCComponent from './component'; + +export {MDCFoundation, MDCComponent}; diff --git a/packages/mdc-checkbox/adapter.js b/packages/mdc-checkbox/adapter.js index 50c8685ed09..105b47e7449 100644 --- a/packages/mdc-checkbox/adapter.js +++ b/packages/mdc-checkbox/adapter.js @@ -34,7 +34,6 @@ */ export default class MDCCheckboxAdapter { - /** @param {string} className */ addClass(className) {} @@ -60,7 +59,6 @@ export default class MDCCheckboxAdapter { /** @return {boolean} */ isAttachedToDOM() {} - } /** diff --git a/packages/mdc-checkbox/foundation.js b/packages/mdc-checkbox/foundation.js index c8c029443e6..d98a33c5286 100644 --- a/packages/mdc-checkbox/foundation.js +++ b/packages/mdc-checkbox/foundation.js @@ -164,7 +164,7 @@ export default class MDCCheckboxFoundation extends MDCFoundation { CB_PROTO_PROPS.forEach((controlState) => { const desc = /** @type {!ObjectPropertyDescriptor} */ ( - Object.getOwnPropertyDescriptor(cbProto, controlState)); + Object.getOwnPropertyDescriptor(cbProto, controlState)); if (validDescriptor(desc)) { Object.defineProperty(nativeCb, controlState, desc); } diff --git a/packages/mdc-checkbox/index.js b/packages/mdc-checkbox/index.js index f0318407257..a05f28a3e78 100644 --- a/packages/mdc-checkbox/index.js +++ b/packages/mdc-checkbox/index.js @@ -40,7 +40,7 @@ export class MDCCheckbox extends MDCComponent { get nativeCb_() { const {NATIVE_CONTROL_SELECTOR} = MDCCheckboxFoundation.strings; const cbEl = /** @type {InputElementState|undefined} */ ( - this.root_.querySelector(NATIVE_CONTROL_SELECTOR)); + this.root_.querySelector(NATIVE_CONTROL_SELECTOR)); return cbEl; } diff --git a/packages/mdc-ripple/adapter.js b/packages/mdc-ripple/adapter.js index 367dfb8732f..4993d2cebfc 100644 --- a/packages/mdc-ripple/adapter.js +++ b/packages/mdc-ripple/adapter.js @@ -38,7 +38,6 @@ * @record */ export default class MDCRippleAdapter { - /** @return {boolean} */ browserSupportsCssVars() {} @@ -90,5 +89,4 @@ export default class MDCRippleAdapter { /** @return {{x: number, y: number}} */ getWindowPageOffset() {} - }