diff --git a/CHANGELOG.md b/CHANGELOG.md index 20732486..3b9aa2ba 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,5 +1,10 @@ # Changelog +## 2.1.11 (Jan 5, 2018) + +* Fixed issue with multiple grids on same vm (#134) (thanks [Suen](https://github.com/sunzongzheng)) +* Fixed issue with layout update on reassignment (#130) (thanks [daizengyu](https://github.com/daizengyu123)) + ## 2.1.10 (Dec 15, 2017) * Fixed possible bug related with #119 diff --git a/README.md b/README.md index 7f62c265..a0ed850a 100644 --- a/README.md +++ b/README.md @@ -2,7 +2,7 @@ vue-grid-layout is a grid layout system, like [Gridster](http://dsmorse.github.io/gridster.js/), for Vue.js. **Heavily inspired in [React-Grid-Layout](https://github.com/STRML/react-grid-layout)** -### **Current version:** 2.1.10 (Supports Vue 2.2+) +### **Current version:** 2.1.11 (Supports Vue 2.2+) ### **For Vue 2.1.10 and below use version [2.1.3](https://github.com/jbaysolutions/vue-grid-layout/tree/2.1.3)** ### **For Vue 1 use version [1.0.3](https://github.com/jbaysolutions/vue-grid-layout/tree/1.0.3)** diff --git a/dist/vue-grid-layout.js b/dist/vue-grid-layout.js index 333b3b30..8398b1dc 100644 --- a/dist/vue-grid-layout.js +++ b/dist/vue-grid-layout.js @@ -7,7 +7,7 @@ exports["VueGridLayout"] = factory(); else root["VueGridLayout"] = factory(); -})(typeof self !== 'undefined' ? self : this, function() { +})(this, function() { return /******/ (function(modules) { // webpackBootstrap /******/ // The module cache /******/ var installedModules = {}; @@ -70,7 +70,7 @@ return /******/ (function(modules) { // webpackBootstrap /******/ __webpack_require__.p = ""; /******/ /******/ // Load entry module and return exports -/******/ return __webpack_require__(__webpack_require__.s = 10); +/******/ return __webpack_require__(__webpack_require__.s = 9); /******/ }) /************************************************************************/ /******/ ([ @@ -78,13 +78,13 @@ return /******/ (function(modules) { // webpackBootstrap /***/ (function(module, exports, __webpack_require__) { "use strict"; -eval("/* WEBPACK VAR INJECTION */(function(process) {\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.bottom = bottom;\nexports.cloneLayout = cloneLayout;\nexports.cloneLayoutItem = cloneLayoutItem;\nexports.collides = collides;\nexports.compact = compact;\nexports.compactItem = compactItem;\nexports.correctBounds = correctBounds;\nexports.getLayoutItem = getLayoutItem;\nexports.getFirstCollision = getFirstCollision;\nexports.getAllCollisions = getAllCollisions;\nexports.getStatics = getStatics;\nexports.moveElement = moveElement;\nexports.moveElementAwayFromCollision = moveElementAwayFromCollision;\nexports.perc = perc;\nexports.setTransform = setTransform;\nexports.setTransformRtl = setTransformRtl;\nexports.setTopLeft = setTopLeft;\nexports.setTopRight = setTopRight;\nexports.sortLayoutItemsByRowCol = sortLayoutItemsByRowCol;\nexports.validateLayout = validateLayout;\nexports.autoBindHandlers = autoBindHandlers;\nexports.createMarkup = createMarkup;\nexports.addPx = addPx;\nexports.hyphenate = hyphenate;\nexports.findItemInArray = findItemInArray;\nexports.findAndRemove = findAndRemove;\n// @flow\n/*:: export type LayoutItemRequired = {w: number, h: number, x: number, y: number, i: string};*/\n/*:: export type LayoutItem = LayoutItemRequired &\n {minW?: number, minH?: number, maxW?: number, maxH?: number,\n moved?: boolean, static?: boolean,\n isDraggable?: ?boolean, isResizable?: ?boolean};*/\n/*:: export type Layout = Array;*/\n/*:: export type Position = {left: number, top: number, width: number, height: number};*/\n/*:: export type DragCallbackData = {\n node: HTMLElement,\n x: number, y: number,\n deltaX: number, deltaY: number,\n lastX: number, lastY: number\n};*/\n/*:: export type DragEvent = {e: Event} & DragCallbackData;*/\n/*:: export type Size = {width: number, height: number};*/\n/*:: export type ResizeEvent = {e: Event, node: HTMLElement, size: Size};*/\n\n\nvar isProduction = process.env.NODE_ENV === 'production';\n/**\n * Return the bottom coordinate of the layout.\n *\n * @param {Array} layout Layout array.\n * @return {Number} Bottom coordinate.\n */\nfunction bottom(layout /*: Layout*/) /*: number*/ {\n var max = 0,\n bottomY = void 0;\n for (var _i = 0, len = layout.length; _i < len; _i++) {\n bottomY = layout[_i].y + layout[_i].h;\n if (bottomY > max) max = bottomY;\n }\n return max;\n}\n\nfunction cloneLayout(layout /*: Layout*/) /*: Layout*/ {\n var newLayout = Array(layout.length);\n for (var _i2 = 0, len = layout.length; _i2 < len; _i2++) {\n newLayout[_i2] = cloneLayoutItem(layout[_i2]);\n }\n return newLayout;\n}\n\n// Fast path to cloning, since this is monomorphic\nfunction cloneLayoutItem(layoutItem /*: LayoutItem*/) /*: LayoutItem*/ {\n /*return {\n w: layoutItem.w, h: layoutItem.h, x: layoutItem.x, y: layoutItem.y, i: layoutItem.i,\n minW: layoutItem.minW, maxW: layoutItem.maxW, minH: layoutItem.minH, maxH: layoutItem.maxH,\n moved: Boolean(layoutItem.moved), static: Boolean(layoutItem.static),\n // These can be null\n isDraggable: layoutItem.isDraggable, isResizable: layoutItem.isResizable\n };*/\n return JSON.parse(JSON.stringify(layoutItem));\n}\n\n/**\n * Given two layoutitems, check if they collide.\n *\n * @return {Boolean} True if colliding.\n */\nfunction collides(l1 /*: LayoutItem*/, l2 /*: LayoutItem*/) /*: boolean*/ {\n if (l1 === l2) return false; // same element\n if (l1.x + l1.w <= l2.x) return false; // l1 is left of l2\n if (l1.x >= l2.x + l2.w) return false; // l1 is right of l2\n if (l1.y + l1.h <= l2.y) return false; // l1 is above l2\n if (l1.y >= l2.y + l2.h) return false; // l1 is below l2\n return true; // boxes overlap\n}\n\n/**\n * Given a layout, compact it. This involves going down each y coordinate and removing gaps\n * between items.\n *\n * @param {Array} layout Layout.\n * @param {Boolean} verticalCompact Whether or not to compact the layout\n * vertically.\n * @return {Array} Compacted Layout.\n */\nfunction compact(layout /*: Layout*/, verticalCompact /*: Boolean*/) /*: Layout*/ {\n // Statics go in the compareWith array right away so items flow around them.\n var compareWith = getStatics(layout);\n // We go through the items by row and column.\n var sorted = sortLayoutItemsByRowCol(layout);\n // Holding for new items.\n var out = Array(layout.length);\n\n for (var _i3 = 0, len = sorted.length; _i3 < len; _i3++) {\n var l = sorted[_i3];\n\n // Don't move static elements\n if (!l.static) {\n l = compactItem(compareWith, l, verticalCompact);\n\n // Add to comparison array. We only collide with items before this one.\n // Statics are already in this array.\n compareWith.push(l);\n }\n\n // Add to output array to make sure they still come out in the right order.\n out[layout.indexOf(l)] = l;\n\n // Clear moved flag, if it exists.\n l.moved = false;\n }\n\n return out;\n}\n\n/**\n * Compact an item in the layout.\n */\nfunction compactItem(compareWith /*: Layout*/, l /*: LayoutItem*/, verticalCompact /*: boolean*/) /*: LayoutItem*/ {\n if (verticalCompact) {\n // Move the element up as far as it can go without colliding.\n while (l.y > 0 && !getFirstCollision(compareWith, l)) {\n l.y--;\n }\n }\n\n // Move it down, and keep moving it down if it's colliding.\n var collides = void 0;\n while (collides = getFirstCollision(compareWith, l)) {\n l.y = collides.y + collides.h;\n }\n return l;\n}\n\n/**\n * Given a layout, make sure all elements fit within its bounds.\n *\n * @param {Array} layout Layout array.\n * @param {Number} bounds Number of columns.\n */\nfunction correctBounds(layout /*: Layout*/, bounds /*: {cols: number}*/) /*: Layout*/ {\n var collidesWith = getStatics(layout);\n for (var _i4 = 0, len = layout.length; _i4 < len; _i4++) {\n var l = layout[_i4];\n // Overflows right\n if (l.x + l.w > bounds.cols) l.x = bounds.cols - l.w;\n // Overflows left\n if (l.x < 0) {\n l.x = 0;\n l.w = bounds.cols;\n }\n if (!l.static) collidesWith.push(l);else {\n // If this is static and collides with other statics, we must move it down.\n // We have to do something nicer than just letting them overlap.\n while (getFirstCollision(collidesWith, l)) {\n l.y++;\n }\n }\n }\n return layout;\n}\n\n/**\n * Get a layout item by ID. Used so we can override later on if necessary.\n *\n * @param {Array} layout Layout array.\n * @param {String} id ID\n * @return {LayoutItem} Item at ID.\n */\nfunction getLayoutItem(layout /*: Layout*/, id /*: string*/) /*: ?LayoutItem*/ {\n for (var _i5 = 0, len = layout.length; _i5 < len; _i5++) {\n if (layout[_i5].i === id) return layout[_i5];\n }\n}\n\n/**\n * Returns the first item this layout collides with.\n * It doesn't appear to matter which order we approach this from, although\n * perhaps that is the wrong thing to do.\n *\n * @param {Object} layoutItem Layout item.\n * @return {Object|undefined} A colliding layout item, or undefined.\n */\nfunction getFirstCollision(layout /*: Layout*/, layoutItem /*: LayoutItem*/) /*: ?LayoutItem*/ {\n for (var _i6 = 0, len = layout.length; _i6 < len; _i6++) {\n if (collides(layout[_i6], layoutItem)) return layout[_i6];\n }\n}\n\nfunction getAllCollisions(layout /*: Layout*/, layoutItem /*: LayoutItem*/) /*: Array*/ {\n return layout.filter(function (l) {\n return collides(l, layoutItem);\n });\n}\n\n/**\n * Get all static elements.\n * @param {Array} layout Array of layout objects.\n * @return {Array} Array of static layout items..\n */\nfunction getStatics(layout /*: Layout*/) /*: Array*/ {\n //return [];\n return layout.filter(function (l) {\n return l.static;\n });\n}\n\n/**\n * Move an element. Responsible for doing cascading movements of other elements.\n *\n * @param {Array} layout Full layout to modify.\n * @param {LayoutItem} l element to move.\n * @param {Number} [x] X position in grid units.\n * @param {Number} [y] Y position in grid units.\n * @param {Boolean} [isUserAction] If true, designates that the item we're moving is\n * being dragged/resized by th euser.\n */\nfunction moveElement(layout /*: Layout*/, l /*: LayoutItem*/, x /*: Number*/, y /*: Number*/, isUserAction /*: Boolean*/) /*: Layout*/ {\n if (l.static) return layout;\n\n // Short-circuit if nothing to do.\n //if (l.y === y && l.x === x) return layout;\n\n var movingUp = y && l.y > y;\n // This is quite a bit faster than extending the object\n if (typeof x === 'number') l.x = x;\n if (typeof y === 'number') l.y = y;\n l.moved = true;\n\n // If this collides with anything, move it.\n // When doing this comparison, we have to sort the items we compare with\n // to ensure, in the case of multiple collisions, that we're getting the\n // nearest collision.\n var sorted = sortLayoutItemsByRowCol(layout);\n if (movingUp) sorted = sorted.reverse();\n var collisions = getAllCollisions(sorted, l);\n\n // Move each item that collides away from this element.\n for (var _i7 = 0, len = collisions.length; _i7 < len; _i7++) {\n var collision = collisions[_i7];\n // console.log('resolving collision between', l.i, 'at', l.y, 'and', collision.i, 'at', collision.y);\n\n // Short circuit so we can't infinite loop\n if (collision.moved) continue;\n\n // This makes it feel a bit more precise by waiting to swap for just a bit when moving up.\n if (l.y > collision.y && l.y - collision.y > collision.h / 4) continue;\n\n // Don't move static items - we have to move *this* element away\n if (collision.static) {\n layout = moveElementAwayFromCollision(layout, collision, l, isUserAction);\n } else {\n layout = moveElementAwayFromCollision(layout, l, collision, isUserAction);\n }\n }\n\n return layout;\n}\n\n/**\n * This is where the magic needs to happen - given a collision, move an element away from the collision.\n * We attempt to move it up if there's room, otherwise it goes below.\n *\n * @param {Array} layout Full layout to modify.\n * @param {LayoutItem} collidesWith Layout item we're colliding with.\n * @param {LayoutItem} itemToMove Layout item we're moving.\n * @param {Boolean} [isUserAction] If true, designates that the item we're moving is being dragged/resized\n * by the user.\n */\nfunction moveElementAwayFromCollision(layout /*: Layout*/, collidesWith /*: LayoutItem*/, itemToMove /*: LayoutItem*/, isUserAction /*: ?boolean*/) /*: Layout*/ {\n\n // If there is enough space above the collision to put this element, move it there.\n // We only do this on the main collision as this can get funky in cascades and cause\n // unwanted swapping behavior.\n if (isUserAction) {\n // Make a mock item so we don't modify the item here, only modify in moveElement.\n var fakeItem /*: LayoutItem*/ = {\n x: itemToMove.x,\n y: itemToMove.y,\n w: itemToMove.w,\n h: itemToMove.h,\n i: '-1'\n };\n fakeItem.y = Math.max(collidesWith.y - itemToMove.h, 0);\n if (!getFirstCollision(layout, fakeItem)) {\n return moveElement(layout, itemToMove, undefined, fakeItem.y);\n }\n }\n\n // Previously this was optimized to move below the collision directly, but this can cause problems\n // with cascading moves, as an item may actually leapflog a collision and cause a reversal in order.\n return moveElement(layout, itemToMove, undefined, itemToMove.y + 1);\n}\n\n/**\n * Helper to convert a number to a percentage string.\n *\n * @param {Number} num Any number\n * @return {String} That number as a percentage.\n */\nfunction perc(num /*: number*/) /*: string*/ {\n return num * 100 + '%';\n}\n\nfunction setTransform(top, left, width, height) /*: Object*/ {\n // Replace unitless items with px\n var translate = \"translate3d(\" + left + \"px,\" + top + \"px, 0)\";\n return {\n transform: translate,\n WebkitTransform: translate,\n MozTransform: translate,\n msTransform: translate,\n OTransform: translate,\n width: width + \"px\",\n height: height + \"px\",\n position: 'absolute'\n };\n}\n/**\n * Just like the setTransform method, but instead it will return a negative value of right.\n *\n * @param top\n * @param right\n * @param width\n * @param height\n * @returns {{transform: string, WebkitTransform: string, MozTransform: string, msTransform: string, OTransform: string, width: string, height: string, position: string}}\n */\nfunction setTransformRtl(top, right, width, height) /*: Object*/ {\n // Replace unitless items with px\n var translate = \"translate3d(\" + right * -1 + \"px,\" + top + \"px, 0)\";\n return {\n transform: translate,\n WebkitTransform: translate,\n MozTransform: translate,\n msTransform: translate,\n OTransform: translate,\n width: width + \"px\",\n height: height + \"px\",\n position: 'absolute'\n };\n}\n\nfunction setTopLeft(top, left, width, height) /*: Object*/ {\n return {\n top: top + \"px\",\n left: left + \"px\",\n width: width + \"px\",\n height: height + \"px\",\n position: 'absolute'\n };\n}\n/**\n * Just like the setTopLeft method, but instead, it will return a right property instead of left.\n *\n * @param top\n * @param right\n * @param width\n * @param height\n * @returns {{top: string, right: string, width: string, height: string, position: string}}\n */\nfunction setTopRight(top, right, width, height) /*: Object*/ {\n return {\n top: top + \"px\",\n right: right + \"px\",\n width: width + \"px\",\n height: height + \"px\",\n position: 'absolute'\n };\n}\n\n/**\n * Get layout items sorted from top left to right and down.\n *\n * @return {Array} Array of layout objects.\n * @return {Array} Layout, sorted static items first.\n */\nfunction sortLayoutItemsByRowCol(layout /*: Layout*/) /*: Layout*/ {\n return [].concat(layout).sort(function (a, b) {\n if (a.y > b.y || a.y === b.y && a.x > b.x) {\n return 1;\n }\n return -1;\n });\n}\n\n/**\n * Generate a layout using the initialLayout and children as a template.\n * Missing entries will be added, extraneous ones will be truncated.\n *\n * @param {Array} initialLayout Layout passed in through props.\n * @param {String} breakpoint Current responsive breakpoint.\n * @param {Boolean} verticalCompact Whether or not to compact the layout vertically.\n * @return {Array} Working layout.\n */\n/*\nexport function synchronizeLayoutWithChildren(initialLayout: Layout, children: Array|React.Element,\n cols: number, verticalCompact: boolean): Layout {\n // ensure 'children' is always an array\n if (!Array.isArray(children)) {\n children = [children];\n }\n initialLayout = initialLayout || [];\n\n // Generate one layout item per child.\n let layout: Layout = [];\n for (let i = 0, len = children.length; i < len; i++) {\n let newItem;\n const child = children[i];\n\n // Don't overwrite if it already exists.\n const exists = getLayoutItem(initialLayout, child.key || \"1\" /!* FIXME satisfies Flow *!/);\n if (exists) {\n newItem = exists;\n } else {\n const g = child.props._grid;\n\n // Hey, this item has a _grid property, use it.\n if (g) {\n if (!isProduction) {\n validateLayout([g], 'ReactGridLayout.children');\n }\n // Validated; add it to the layout. Bottom 'y' possible is the bottom of the layout.\n // This allows you to do nice stuff like specify {y: Infinity}\n if (verticalCompact) {\n newItem = cloneLayoutItem({...g, y: Math.min(bottom(layout), g.y), i: child.key});\n } else {\n newItem = cloneLayoutItem({...g, y: g.y, i: child.key});\n }\n }\n // Nothing provided: ensure this is added to the bottom\n else {\n newItem = cloneLayoutItem({w: 1, h: 1, x: 0, y: bottom(layout), i: child.key || \"1\"});\n }\n }\n layout[i] = newItem;\n }\n\n // Correct the layout.\n layout = correctBounds(layout, {cols: cols});\n layout = compact(layout, verticalCompact);\n\n return layout;\n}\n*/\n\n/**\n * Validate a layout. Throws errors.\n *\n * @param {Array} layout Array of layout items.\n * @param {String} [contextName] Context name for errors.\n * @throw {Error} Validation error.\n */\nfunction validateLayout(layout /*: Layout*/, contextName /*: string*/) /*: void*/ {\n contextName = contextName || \"Layout\";\n var subProps = ['x', 'y', 'w', 'h'];\n if (!Array.isArray(layout)) throw new Error(contextName + \" must be an array!\");\n for (var _i8 = 0, len = layout.length; _i8 < len; _i8++) {\n var item = layout[_i8];\n for (var j = 0; j < subProps.length; j++) {\n if (typeof item[subProps[j]] !== 'number') {\n throw new Error('VueGridLayout: ' + contextName + '[' + _i8 + '].' + subProps[j] + ' must be a number!');\n }\n }\n if (item.i && typeof item.i !== 'string') {\n throw new Error('VueGridLayout: ' + contextName + '[' + _i8 + '].i must be a string!');\n }\n if (item.static !== undefined && typeof item.static !== 'boolean') {\n throw new Error('VueGridLayout: ' + contextName + '[' + _i8 + '].static must be a boolean!');\n }\n }\n}\n\n// Flow can't really figure this out, so we just use Object\nfunction autoBindHandlers(el /*: Object*/, fns /*: Array*/) /*: void*/ {\n fns.forEach(function (key) {\n return el[key] = el[key].bind(el);\n });\n}\n\n/**\n * Convert a JS object to CSS string. Similar to React's output of CSS.\n * @param obj\n * @returns {string}\n */\nfunction createMarkup(obj) {\n var keys = Object.keys(obj);\n if (!keys.length) return '';\n var i,\n len = keys.length;\n var result = '';\n\n for (i = 0; i < len; i++) {\n var key = keys[i];\n var val = obj[key];\n result += hyphenate(key) + ':' + addPx(key, val) + ';';\n }\n\n return result;\n}\n\n/* The following list is defined in React's core */\nvar IS_UNITLESS = exports.IS_UNITLESS = {\n animationIterationCount: true,\n boxFlex: true,\n boxFlexGroup: true,\n boxOrdinalGroup: true,\n columnCount: true,\n flex: true,\n flexGrow: true,\n flexPositive: true,\n flexShrink: true,\n flexNegative: true,\n flexOrder: true,\n gridRow: true,\n gridColumn: true,\n fontWeight: true,\n lineClamp: true,\n lineHeight: true,\n opacity: true,\n order: true,\n orphans: true,\n tabSize: true,\n widows: true,\n zIndex: true,\n zoom: true,\n\n // SVG-related properties\n fillOpacity: true,\n stopOpacity: true,\n strokeDashoffset: true,\n strokeOpacity: true,\n strokeWidth: true\n};\n\n/**\n * Will add px to the end of style values which are Numbers.\n * @param name\n * @param value\n * @returns {*}\n */\nfunction addPx(name, value) {\n if (typeof value === 'number' && !IS_UNITLESS[name]) {\n return value + 'px';\n } else {\n return value;\n }\n}\n\n/**\n * Hyphenate a camelCase string.\n *\n * @param {String} str\n * @return {String}\n */\n\nvar hyphenateRE = exports.hyphenateRE = /([a-z\\d])([A-Z])/g;\n\nfunction hyphenate(str) {\n return str.replace(hyphenateRE, '$1-$2').toLowerCase();\n}\n\nfunction findItemInArray(array, property, value) {\n for (var i = 0; i < array.length; i++) {\n if (array[i][property] == value) return true;\n }return false;\n}\n\nfunction findAndRemove(array, property, value) {\n array.forEach(function (result, index) {\n if (result[property] === value) {\n //Remove from array\n array.splice(index, 1);\n }\n });\n}\n/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(5)))\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack:///./src/utils.js?2ff8"],"names":["bottom","cloneLayout","cloneLayoutItem","collides","compact","compactItem","correctBounds","getLayoutItem","getFirstCollision","getAllCollisions","getStatics","moveElement","moveElementAwayFromCollision","perc","setTransform","setTransformRtl","setTopLeft","setTopRight","sortLayoutItemsByRowCol","validateLayout","autoBindHandlers","createMarkup","addPx","hyphenate","findItemInArray","findAndRemove","isProduction","process","env","NODE_ENV","layout","max","bottomY","i","len","length","y","h","newLayout","Array","layoutItem","JSON","parse","stringify","l1","l2","x","w","verticalCompact","compareWith","sorted","out","l","static","push","indexOf","moved","bounds","collidesWith","cols","id","filter","isUserAction","movingUp","reverse","collisions","collision","itemToMove","fakeItem","Math","undefined","num","top","left","width","height","translate","transform","WebkitTransform","MozTransform","msTransform","OTransform","position","right","concat","sort","a","b","contextName","subProps","isArray","Error","item","j","el","fns","forEach","key","bind","obj","keys","Object","result","val","IS_UNITLESS","animationIterationCount","boxFlex","boxFlexGroup","boxOrdinalGroup","columnCount","flex","flexGrow","flexPositive","flexShrink","flexNegative","flexOrder","gridRow","gridColumn","fontWeight","lineClamp","lineHeight","opacity","order","orphans","tabSize","widows","zIndex","zoom","fillOpacity","stopOpacity","strokeDashoffset","strokeOpacity","strokeWidth","name","value","hyphenateRE","str","replace","toLowerCase","array","property","index","splice"],"mappings":";;;;;QAyBgBA,M,GAAAA,M;QASAC,W,GAAAA,W;QASAC,e,GAAAA,e;QAgBAC,Q,GAAAA,Q;QAkBAC,O,GAAAA,O;QAiCAC,W,GAAAA,W;QAsBAC,a,GAAAA,a;QA8BAC,a,GAAAA,a;QAcAC,iB,GAAAA,iB;QAMAC,gB,GAAAA,gB;QASAC,U,GAAAA,U;QAeAC,W,GAAAA,W;QAoDAC,4B,GAAAA,4B;QAgCAC,I,GAAAA,I;QAIAC,Y,GAAAA,Y;QAuBAC,e,GAAAA,e;QAeAC,U,GAAAA,U;QAkBAC,W,GAAAA,W;QAiBAC,uB,GAAAA,uB;QA4EAC,c,GAAAA,c;QAqBAC,gB,GAAAA,gB;QAWAC,Y,GAAAA,Y;QAyDAC,K,GAAAA,K;QAkBAC,S,GAAAA,S;QAKAC,e,GAAAA,e;QAQAC,a,GAAAA,a;AAnjBhB;;;;;;;;;;;;;;;;;;;AAkBA,IAAMC,eAAeC,QAAQC,GAAR,CAAYC,QAAZ,KAAyB,YAA9C;AACA;;;;;;AAMO,SAAS7B,MAAT,CAAgB8B,MAAhB,4BAAwC;AAC7C,MAAIC,MAAM,CAAV;AAAA,MAAaC,gBAAb;AACA,OAAK,IAAIC,KAAI,CAAR,EAAWC,MAAMJ,OAAOK,MAA7B,EAAqCF,KAAIC,GAAzC,EAA8CD,IAA9C,EAAmD;AACjDD,cAAUF,OAAOG,EAAP,EAAWG,CAAX,GAAeN,OAAOG,EAAP,EAAUI,CAAnC;AACA,QAAIL,UAAUD,GAAd,EAAmBA,MAAMC,OAAN;AACpB;AACD,SAAOD,GAAP;AACD;;AAEM,SAAS9B,WAAT,CAAqB6B,MAArB,4BAA6C;AAClD,MAAMQ,YAAYC,MAAMT,OAAOK,MAAb,CAAlB;AACA,OAAK,IAAIF,MAAI,CAAR,EAAWC,MAAMJ,OAAOK,MAA7B,EAAqCF,MAAIC,GAAzC,EAA8CD,KAA9C,EAAmD;AACjDK,cAAUL,GAAV,IAAe/B,gBAAgB4B,OAAOG,GAAP,CAAhB,CAAf;AACD;AACD,SAAOK,SAAP;AACD;;AAED;AACO,SAASpC,eAAT,CAAyBsC,UAAzB,oCAA6D;AAClE;;;;;;;AAOE,SAAOC,KAAKC,KAAL,CAAWD,KAAKE,SAAL,CAAeH,UAAf,CAAX,CAAP;AACH;;AAED;;;;;AAKO,SAASrC,QAAT,CAAkByC,EAAlB,mBAAkCC,EAAlC,iCAA2D;AAChE,MAAID,OAAOC,EAAX,EAAe,OAAO,KAAP,CADiD,CACnC;AAC7B,MAAID,GAAGE,CAAH,GAAOF,GAAGG,CAAV,IAAeF,GAAGC,CAAtB,EAAyB,OAAO,KAAP,CAFuC,CAEzB;AACvC,MAAIF,GAAGE,CAAH,IAAQD,GAAGC,CAAH,GAAOD,GAAGE,CAAtB,EAAyB,OAAO,KAAP,CAHuC,CAGzB;AACvC,MAAIH,GAAGR,CAAH,GAAOQ,GAAGP,CAAV,IAAeQ,GAAGT,CAAtB,EAAyB,OAAO,KAAP,CAJuC,CAIzB;AACvC,MAAIQ,GAAGR,CAAH,IAAQS,GAAGT,CAAH,GAAOS,GAAGR,CAAtB,EAAyB,OAAO,KAAP,CALuC,CAKzB;AACvC,SAAO,IAAP,CANgE,CAMnD;AACd;;AAED;;;;;;;;;AASO,SAASjC,OAAT,CAAiB0B,MAAjB,eAAiCkB,eAAjC,6BAAmE;AACtE;AACF,MAAMC,cAAcvC,WAAWoB,MAAX,CAApB;AACA;AACA,MAAMoB,SAAShC,wBAAwBY,MAAxB,CAAf;AACA;AACA,MAAMqB,MAAMZ,MAAMT,OAAOK,MAAb,CAAZ;;AAEA,OAAK,IAAIF,MAAI,CAAR,EAAWC,MAAMgB,OAAOf,MAA7B,EAAqCF,MAAIC,GAAzC,EAA8CD,KAA9C,EAAmD;AACjD,QAAImB,IAAIF,OAAOjB,GAAP,CAAR;;AAEA;AACA,QAAI,CAACmB,EAAEC,MAAP,EAAe;AACbD,UAAI/C,YAAY4C,WAAZ,EAAyBG,CAAzB,EAA4BJ,eAA5B,CAAJ;;AAEA;AACA;AACAC,kBAAYK,IAAZ,CAAiBF,CAAjB;AACD;;AAED;AACAD,QAAIrB,OAAOyB,OAAP,CAAeH,CAAf,CAAJ,IAAyBA,CAAzB;;AAEA;AACAA,MAAEI,KAAF,GAAU,KAAV;AACD;;AAED,SAAOL,GAAP;AACD;;AAED;;;AAGO,SAAS9C,WAAT,CAAqB4C,WAArB,eAA0CG,CAA1C,mBAAyDJ,eAAzD,iCAA+F;AACpG,MAAIA,eAAJ,EAAqB;AACnB;AACA,WAAOI,EAAEhB,CAAF,GAAM,CAAN,IAAW,CAAC5B,kBAAkByC,WAAlB,EAA+BG,CAA/B,CAAnB,EAAsD;AACpDA,QAAEhB,CAAF;AACD;AACF;;AAED;AACA,MAAIjC,iBAAJ;AACA,SAAOA,WAAWK,kBAAkByC,WAAlB,EAA+BG,CAA/B,CAAlB,EAAsD;AACpDA,MAAEhB,CAAF,GAAMjC,SAASiC,CAAT,GAAajC,SAASkC,CAA5B;AACD;AACD,SAAOe,CAAP;AACD;;AAED;;;;;;AAMO,SAAS9C,aAAT,CAAuBwB,MAAvB,eAAuC2B,MAAvC,oCAAuE;AAC5E,MAAMC,eAAehD,WAAWoB,MAAX,CAArB;AACA,OAAK,IAAIG,MAAI,CAAR,EAAWC,MAAMJ,OAAOK,MAA7B,EAAqCF,MAAIC,GAAzC,EAA8CD,KAA9C,EAAmD;AACjD,QAAMmB,IAAItB,OAAOG,GAAP,CAAV;AACA;AACA,QAAImB,EAAEN,CAAF,GAAMM,EAAEL,CAAR,GAAYU,OAAOE,IAAvB,EAA6BP,EAAEN,CAAF,GAAMW,OAAOE,IAAP,GAAcP,EAAEL,CAAtB;AAC7B;AACA,QAAIK,EAAEN,CAAF,GAAM,CAAV,EAAa;AACXM,QAAEN,CAAF,GAAM,CAAN;AACAM,QAAEL,CAAF,GAAMU,OAAOE,IAAb;AACD;AACD,QAAI,CAACP,EAAEC,MAAP,EAAeK,aAAaJ,IAAb,CAAkBF,CAAlB,EAAf,KACK;AACH;AACA;AACA,aAAM5C,kBAAkBkD,YAAlB,EAAgCN,CAAhC,CAAN,EAA0C;AACxCA,UAAEhB,CAAF;AACD;AACF;AACF;AACD,SAAON,MAAP;AACD;;AAED;;;;;;;AAOO,SAASvB,aAAT,CAAuBuB,MAAvB,eAAuC8B,EAAvC,iCAAgE;AACrE,OAAK,IAAI3B,MAAI,CAAR,EAAWC,MAAMJ,OAAOK,MAA7B,EAAqCF,MAAIC,GAAzC,EAA8CD,KAA9C,EAAmD;AACjD,QAAIH,OAAOG,GAAP,EAAUA,CAAV,KAAgB2B,EAApB,EAAwB,OAAO9B,OAAOG,GAAP,CAAP;AACzB;AACF;;AAED;;;;;;;;AAQO,SAASzB,iBAAT,CAA2BsB,MAA3B,eAA2CU,UAA3C,qCAAgF;AACrF,OAAK,IAAIP,MAAI,CAAR,EAAWC,MAAMJ,OAAOK,MAA7B,EAAqCF,MAAIC,GAAzC,EAA8CD,KAA9C,EAAmD;AACjD,QAAI9B,SAAS2B,OAAOG,GAAP,CAAT,EAAoBO,UAApB,CAAJ,EAAqC,OAAOV,OAAOG,GAAP,CAAP;AACtC;AACF;;AAEM,SAASxB,gBAAT,CAA0BqB,MAA1B,eAA0CU,UAA1C,2CAAqF;AAC1F,SAAOV,OAAO+B,MAAP,CAAc,UAACT,CAAD;AAAA,WAAOjD,SAASiD,CAAT,EAAYZ,UAAZ,CAAP;AAAA,GAAd,CAAP;AACD;;AAED;;;;;AAKO,SAAS9B,UAAT,CAAoBoB,MAApB,uCAAuD;AAC1D;AACA,SAAOA,OAAO+B,MAAP,CAAc,UAACT,CAAD;AAAA,WAAOA,EAAEC,MAAT;AAAA,GAAd,CAAP;AACH;;AAED;;;;;;;;;;AAUO,SAAS1C,WAAT,CAAqBmB,MAArB,eAAqCsB,CAArC,mBAAoDN,CAApD,eAA+DV,CAA/D,eAA0E0B,YAA1E,6BAAyG;AAC9G,MAAIV,EAAEC,MAAN,EAAc,OAAOvB,MAAP;;AAEd;AACA;;AAEA,MAAMiC,WAAW3B,KAAKgB,EAAEhB,CAAF,GAAMA,CAA5B;AACA;AACA,MAAI,OAAOU,CAAP,KAAa,QAAjB,EAA2BM,EAAEN,CAAF,GAAMA,CAAN;AAC3B,MAAI,OAAOV,CAAP,KAAa,QAAjB,EAA2BgB,EAAEhB,CAAF,GAAMA,CAAN;AAC3BgB,IAAEI,KAAF,GAAU,IAAV;;AAEA;AACA;AACA;AACA;AACA,MAAIN,SAAShC,wBAAwBY,MAAxB,CAAb;AACA,MAAIiC,QAAJ,EAAcb,SAASA,OAAOc,OAAP,EAAT;AACd,MAAMC,aAAaxD,iBAAiByC,MAAjB,EAAyBE,CAAzB,CAAnB;;AAEA;AACA,OAAK,IAAInB,MAAI,CAAR,EAAWC,MAAM+B,WAAW9B,MAAjC,EAAyCF,MAAIC,GAA7C,EAAkDD,KAAlD,EAAuD;AACrD,QAAMiC,YAAYD,WAAWhC,GAAX,CAAlB;AACA;;AAEA;AACA,QAAIiC,UAAUV,KAAd,EAAqB;;AAErB;AACA,QAAIJ,EAAEhB,CAAF,GAAM8B,UAAU9B,CAAhB,IAAqBgB,EAAEhB,CAAF,GAAM8B,UAAU9B,CAAhB,GAAoB8B,UAAU7B,CAAV,GAAc,CAA3D,EAA8D;;AAE9D;AACA,QAAI6B,UAAUb,MAAd,EAAsB;AACpBvB,eAASlB,6BAA6BkB,MAA7B,EAAqCoC,SAArC,EAAgDd,CAAhD,EAAmDU,YAAnD,CAAT;AACD,KAFD,MAEO;AACLhC,eAASlB,6BAA6BkB,MAA7B,EAAqCsB,CAArC,EAAwCc,SAAxC,EAAmDJ,YAAnD,CAAT;AACD;AACF;;AAED,SAAOhC,MAAP;AACD;;AAED;;;;;;;;;;AAUO,SAASlB,4BAAT,CAAsCkB,MAAtC,eAAsD4B,YAAtD,mBACsCS,UADtC,mBAC8DL,YAD9D,8BAC8F;;AAEnG;AACA;AACA;AACA,MAAIA,YAAJ,EAAkB;AAChB;AACA,QAAMM,4BAAuB;AAC3BtB,SAAGqB,WAAWrB,CADa;AAE3BV,SAAG+B,WAAW/B,CAFa;AAG3BW,SAAGoB,WAAWpB,CAHa;AAI3BV,SAAG8B,WAAW9B,CAJa;AAK3BJ,SAAG;AALwB,KAA7B;AAOAmC,aAAShC,CAAT,GAAaiC,KAAKtC,GAAL,CAAS2B,aAAatB,CAAb,GAAiB+B,WAAW9B,CAArC,EAAwC,CAAxC,CAAb;AACA,QAAI,CAAC7B,kBAAkBsB,MAAlB,EAA0BsC,QAA1B,CAAL,EAA0C;AACxC,aAAOzD,YAAYmB,MAAZ,EAAoBqC,UAApB,EAAgCG,SAAhC,EAA2CF,SAAShC,CAApD,CAAP;AACD;AACF;;AAED;AACA;AACA,SAAOzB,YAAYmB,MAAZ,EAAoBqC,UAApB,EAAgCG,SAAhC,EAA2CH,WAAW/B,CAAX,GAAe,CAA1D,CAAP;AACD;;AAED;;;;;;AAMO,SAASvB,IAAT,CAAc0D,GAAd,4BAAmC;AACxC,SAAOA,MAAM,GAAN,GAAY,GAAnB;AACD;;AAEM,SAASzD,YAAT,CAAsB0D,GAAtB,EAA2BC,IAA3B,EAAiCC,KAAjC,EAAwCC,MAAxC,eAAwD;AAC7D;AACA,MAAMC,YAAY,iBAAiBH,IAAjB,GAAwB,KAAxB,GAAgCD,GAAhC,GAAsC,QAAxD;AACA,SAAO;AACLK,eAAWD,SADN;AAELE,qBAAiBF,SAFZ;AAGLG,kBAAcH,SAHT;AAILI,iBAAaJ,SAJR;AAKLK,gBAAYL,SALP;AAMLF,WAAOA,QAAQ,IANV;AAOLC,YAAQA,SAAS,IAPZ;AAQLO,cAAU;AARL,GAAP;AAUD;AACD;;;;;;;;;AASO,SAASnE,eAAT,CAAyByD,GAAzB,EAA8BW,KAA9B,EAAqCT,KAArC,EAA4CC,MAA5C,eAA4D;AAC/D;AACA,MAAMC,YAAY,iBAAiBO,QAAQ,CAAC,CAA1B,GAA8B,KAA9B,GAAsCX,GAAtC,GAA4C,QAA9D;AACA,SAAO;AACHK,eAAWD,SADR;AAEHE,qBAAiBF,SAFd;AAGHG,kBAAcH,SAHX;AAIHI,iBAAaJ,SAJV;AAKHK,gBAAYL,SALT;AAMHF,WAAOA,QAAQ,IANZ;AAOHC,YAAQA,SAAS,IAPd;AAQHO,cAAU;AARP,GAAP;AAUH;;AAEM,SAASlE,UAAT,CAAoBwD,GAApB,EAAyBC,IAAzB,EAA+BC,KAA/B,EAAsCC,MAAtC,eAAsD;AACzD,SAAO;AACHH,SAAKA,MAAM,IADR;AAEHC,UAAMA,OAAO,IAFV;AAGHC,WAAOA,QAAQ,IAHZ;AAIHC,YAAQA,SAAS,IAJd;AAKHO,cAAU;AALP,GAAP;AAOH;AACD;;;;;;;;;AASO,SAASjE,WAAT,CAAqBuD,GAArB,EAA0BW,KAA1B,EAAiCT,KAAjC,EAAwCC,MAAxC,eAAwD;AAC3D,SAAO;AACHH,SAAKA,MAAM,IADR;AAEHW,WAAOA,QAAO,IAFX;AAGHT,WAAOA,QAAQ,IAHZ;AAIHC,YAAQA,SAAS,IAJd;AAKHO,cAAU;AALP,GAAP;AAOH;;AAGD;;;;;;AAMO,SAAShE,uBAAT,CAAiCY,MAAjC,4BAAyD;AAC9D,SAAO,GAAGsD,MAAH,CAAUtD,MAAV,EAAkBuD,IAAlB,CAAuB,UAASC,CAAT,EAAYC,CAAZ,EAAe;AAC3C,QAAID,EAAElD,CAAF,GAAMmD,EAAEnD,CAAR,IAAckD,EAAElD,CAAF,KAAQmD,EAAEnD,CAAV,IAAekD,EAAExC,CAAF,GAAMyC,EAAEzC,CAAzC,EAA6C;AAC3C,aAAO,CAAP;AACD;AACD,WAAO,CAAC,CAAR;AACD,GALM,CAAP;AAMD;;AAED;;;;;;;;;AASA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAmDA;;;;;;;AAOO,SAAS3B,cAAT,CAAwBW,MAAxB,eAAwC0D,WAAxC,0BAAmE;AACxEA,gBAAcA,eAAe,QAA7B;AACA,MAAMC,WAAW,CAAC,GAAD,EAAM,GAAN,EAAW,GAAX,EAAgB,GAAhB,CAAjB;AACA,MAAI,CAAClD,MAAMmD,OAAN,CAAc5D,MAAd,CAAL,EAA4B,MAAM,IAAI6D,KAAJ,CAAUH,cAAc,oBAAxB,CAAN;AAC5B,OAAK,IAAIvD,MAAI,CAAR,EAAWC,MAAMJ,OAAOK,MAA7B,EAAqCF,MAAIC,GAAzC,EAA8CD,KAA9C,EAAmD;AACjD,QAAM2D,OAAO9D,OAAOG,GAAP,CAAb;AACA,SAAK,IAAI4D,IAAI,CAAb,EAAgBA,IAAIJ,SAAStD,MAA7B,EAAqC0D,GAArC,EAA0C;AACxC,UAAI,OAAOD,KAAKH,SAASI,CAAT,CAAL,CAAP,KAA6B,QAAjC,EAA2C;AACzC,cAAM,IAAIF,KAAJ,CAAU,oBAAoBH,WAApB,GAAkC,GAAlC,GAAwCvD,GAAxC,GAA4C,IAA5C,GAAmDwD,SAASI,CAAT,CAAnD,GAAiE,oBAA3E,CAAN;AACD;AACF;AACD,QAAID,KAAK3D,CAAL,IAAU,OAAO2D,KAAK3D,CAAZ,KAAkB,QAAhC,EAA0C;AACxC,YAAM,IAAI0D,KAAJ,CAAU,oBAAoBH,WAApB,GAAkC,GAAlC,GAAwCvD,GAAxC,GAA4C,uBAAtD,CAAN;AACD;AACD,QAAI2D,KAAKvC,MAAL,KAAgBiB,SAAhB,IAA6B,OAAOsB,KAAKvC,MAAZ,KAAuB,SAAxD,EAAmE;AACjE,YAAM,IAAIsC,KAAJ,CAAU,oBAAoBH,WAApB,GAAkC,GAAlC,GAAwCvD,GAAxC,GAA4C,6BAAtD,CAAN;AACD;AACF;AACF;;AAED;AACO,SAASb,gBAAT,CAA0B0E,EAA1B,eAAsCC,GAAtC,iCAAgE;AACrEA,MAAIC,OAAJ,CAAY,UAACC,GAAD;AAAA,WAASH,GAAGG,GAAH,IAAUH,GAAGG,GAAH,EAAQC,IAAR,CAAaJ,EAAb,CAAnB;AAAA,GAAZ;AACD;;AAID;;;;;AAKO,SAASzE,YAAT,CAAsB8E,GAAtB,EAA2B;AAC9B,MAAIC,OAAOC,OAAOD,IAAP,CAAYD,GAAZ,CAAX;AACA,MAAI,CAACC,KAAKjE,MAAV,EAAkB,OAAO,EAAP;AAClB,MAAIF,CAAJ;AAAA,MAAOC,MAAMkE,KAAKjE,MAAlB;AACA,MAAImE,SAAS,EAAb;;AAEA,OAAKrE,IAAI,CAAT,EAAYA,IAAIC,GAAhB,EAAqBD,GAArB,EAA0B;AACtB,QAAIgE,MAAMG,KAAKnE,CAAL,CAAV;AACA,QAAIsE,MAAMJ,IAAIF,GAAJ,CAAV;AACAK,cAAU/E,UAAU0E,GAAV,IAAiB,GAAjB,GAAuB3E,MAAM2E,GAAN,EAAWM,GAAX,CAAvB,GAAyC,GAAnD;AACH;;AAED,SAAOD,MAAP;AACH;;AAGD;AACO,IAAIE,oCAAc;AACrBC,2BAAyB,IADJ;AAErBC,WAAS,IAFY;AAGrBC,gBAAc,IAHO;AAIrBC,mBAAiB,IAJI;AAKrBC,eAAa,IALQ;AAMrBC,QAAM,IANe;AAOrBC,YAAU,IAPW;AAQrBC,gBAAc,IARO;AASrBC,cAAY,IATS;AAUrBC,gBAAc,IAVO;AAWrBC,aAAW,IAXU;AAYrBC,WAAS,IAZY;AAarBC,cAAY,IAbS;AAcrBC,cAAY,IAdS;AAerBC,aAAW,IAfU;AAgBrBC,cAAY,IAhBS;AAiBrBC,WAAS,IAjBY;AAkBrBC,SAAO,IAlBc;AAmBrBC,WAAS,IAnBY;AAoBrBC,WAAS,IApBY;AAqBrBC,UAAQ,IArBa;AAsBrBC,UAAQ,IAtBa;AAuBrBC,QAAM,IAvBe;;AAyBrB;AACAC,eAAa,IA1BQ;AA2BrBC,eAAa,IA3BQ;AA4BrBC,oBAAkB,IA5BG;AA6BrBC,iBAAe,IA7BM;AA8BrBC,eAAa;AA9BQ,CAAlB;;AAkCP;;;;;;AAMO,SAAS9G,KAAT,CAAe+G,IAAf,EAAqBC,KAArB,EAA4B;AAC/B,MAAG,OAAOA,KAAP,KAAiB,QAAjB,IAA6B,CAAC9B,YAAa6B,IAAb,CAAjC,EAAsD;AAClD,WAAOC,QAAQ,IAAf;AACH,GAFD,MAEO;AACH,WAAOA,KAAP;AACH;AACJ;;AAGD;;;;;;;AAOO,IAAIC,oCAAc,mBAAlB;;AAEA,SAAShH,SAAT,CAAmBiH,GAAnB,EAAwB;AAC3B,SAAOA,IAAIC,OAAJ,CAAYF,WAAZ,EAAyB,OAAzB,EAAkCG,WAAlC,EAAP;AACH;;AAGM,SAASlH,eAAT,CAAyBmH,KAAzB,EAAgCC,QAAhC,EAA0CN,KAA1C,EAAiD;AACpD,OAAK,IAAIrG,IAAE,CAAX,EAAcA,IAAI0G,MAAMxG,MAAxB,EAAgCF,GAAhC;AACI,QAAI0G,MAAM1G,CAAN,EAAS2G,QAAT,KAAsBN,KAA1B,EACI,OAAO,IAAP;AAFR,GAIA,OAAO,KAAP;AACH;;AAEM,SAAS7G,aAAT,CAAuBkH,KAAvB,EAA8BC,QAA9B,EAAwCN,KAAxC,EAA+C;AAClDK,QAAM3C,OAAN,CAAc,UAAUM,MAAV,EAAkBuC,KAAlB,EAAyB;AACnC,QAAIvC,OAAOsC,QAAP,MAAqBN,KAAzB,EAAgC;AAC5B;AACAK,YAAMG,MAAN,CAAaD,KAAb,EAAoB,CAApB;AACH;AACJ,GALD;AAMH,C","file":"0.js","sourcesContent":["// @flow\nexport type LayoutItemRequired = {w: number, h: number, x: number, y: number, i: string};\nexport type LayoutItem = LayoutItemRequired &\n                         {minW?: number, minH?: number, maxW?: number, maxH?: number,\n                          moved?: boolean, static?: boolean,\n                          isDraggable?: ?boolean, isResizable?: ?boolean};\nexport type Layout = Array<LayoutItem>;\nexport type Position = {left: number, top: number, width: number, height: number};\nexport type DragCallbackData = {\n  node: HTMLElement,\n  x: number, y: number,\n  deltaX: number, deltaY: number,\n  lastX: number, lastY: number\n};\nexport type DragEvent = {e: Event} & DragCallbackData;\nexport type Size = {width: number, height: number};\nexport type ResizeEvent = {e: Event, node: HTMLElement, size: Size};\n\nconst isProduction = process.env.NODE_ENV === 'production';\n/**\n * Return the bottom coordinate of the layout.\n *\n * @param  {Array} layout Layout array.\n * @return {Number}       Bottom coordinate.\n */\nexport function bottom(layout: Layout): number {\n  let max = 0, bottomY;\n  for (let i = 0, len = layout.length; i < len; i++) {\n    bottomY = layout[i]. y + layout[i].h;\n    if (bottomY > max) max = bottomY;\n  }\n  return max;\n}\n\nexport function cloneLayout(layout: Layout): Layout {\n  const newLayout = Array(layout.length);\n  for (let i = 0, len = layout.length; i < len; i++) {\n    newLayout[i] = cloneLayoutItem(layout[i]);\n  }\n  return newLayout;\n}\n\n// Fast path to cloning, since this is monomorphic\nexport function cloneLayoutItem(layoutItem: LayoutItem): LayoutItem {\n  /*return {\n    w: layoutItem.w, h: layoutItem.h, x: layoutItem.x, y: layoutItem.y, i: layoutItem.i,\n    minW: layoutItem.minW, maxW: layoutItem.maxW, minH: layoutItem.minH, maxH: layoutItem.maxH,\n    moved: Boolean(layoutItem.moved), static: Boolean(layoutItem.static),\n    // These can be null\n    isDraggable: layoutItem.isDraggable, isResizable: layoutItem.isResizable\n  };*/\n    return JSON.parse(JSON.stringify(layoutItem));\n}\n\n/**\n * Given two layoutitems, check if they collide.\n *\n * @return {Boolean}   True if colliding.\n */\nexport function collides(l1: LayoutItem, l2: LayoutItem): boolean {\n  if (l1 === l2) return false; // same element\n  if (l1.x + l1.w <= l2.x) return false; // l1 is left of l2\n  if (l1.x >= l2.x + l2.w) return false; // l1 is right of l2\n  if (l1.y + l1.h <= l2.y) return false; // l1 is above l2\n  if (l1.y >= l2.y + l2.h) return false; // l1 is below l2\n  return true; // boxes overlap\n}\n\n/**\n * Given a layout, compact it. This involves going down each y coordinate and removing gaps\n * between items.\n *\n * @param  {Array} layout Layout.\n * @param  {Boolean} verticalCompact Whether or not to compact the layout\n *   vertically.\n * @return {Array}       Compacted Layout.\n */\nexport function compact(layout: Layout, verticalCompact: Boolean): Layout {\n    // Statics go in the compareWith array right away so items flow around them.\n  const compareWith = getStatics(layout);\n  // We go through the items by row and column.\n  const sorted = sortLayoutItemsByRowCol(layout);\n  // Holding for new items.\n  const out = Array(layout.length);\n\n  for (let i = 0, len = sorted.length; i < len; i++) {\n    let l = sorted[i];\n\n    // Don't move static elements\n    if (!l.static) {\n      l = compactItem(compareWith, l, verticalCompact);\n\n      // Add to comparison array. We only collide with items before this one.\n      // Statics are already in this array.\n      compareWith.push(l);\n    }\n\n    // Add to output array to make sure they still come out in the right order.\n    out[layout.indexOf(l)] = l;\n\n    // Clear moved flag, if it exists.\n    l.moved = false;\n  }\n\n  return out;\n}\n\n/**\n * Compact an item in the layout.\n */\nexport function compactItem(compareWith: Layout, l: LayoutItem, verticalCompact: boolean): LayoutItem {\n  if (verticalCompact) {\n    // Move the element up as far as it can go without colliding.\n    while (l.y > 0 && !getFirstCollision(compareWith, l)) {\n      l.y--;\n    }\n  }\n\n  // Move it down, and keep moving it down if it's colliding.\n  let collides;\n  while((collides = getFirstCollision(compareWith, l))) {\n    l.y = collides.y + collides.h;\n  }\n  return l;\n}\n\n/**\n * Given a layout, make sure all elements fit within its bounds.\n *\n * @param  {Array} layout Layout array.\n * @param  {Number} bounds Number of columns.\n */\nexport function correctBounds(layout: Layout, bounds: {cols: number}): Layout {\n  const collidesWith = getStatics(layout);\n  for (let i = 0, len = layout.length; i < len; i++) {\n    const l = layout[i];\n    // Overflows right\n    if (l.x + l.w > bounds.cols) l.x = bounds.cols - l.w;\n    // Overflows left\n    if (l.x < 0) {\n      l.x = 0;\n      l.w = bounds.cols;\n    }\n    if (!l.static) collidesWith.push(l);\n    else {\n      // If this is static and collides with other statics, we must move it down.\n      // We have to do something nicer than just letting them overlap.\n      while(getFirstCollision(collidesWith, l)) {\n        l.y++;\n      }\n    }\n  }\n  return layout;\n}\n\n/**\n * Get a layout item by ID. Used so we can override later on if necessary.\n *\n * @param  {Array}  layout Layout array.\n * @param  {String} id     ID\n * @return {LayoutItem}    Item at ID.\n */\nexport function getLayoutItem(layout: Layout, id: string): ?LayoutItem {\n  for (let i = 0, len = layout.length; i < len; i++) {\n    if (layout[i].i === id) return layout[i];\n  }\n}\n\n/**\n * Returns the first item this layout collides with.\n * It doesn't appear to matter which order we approach this from, although\n * perhaps that is the wrong thing to do.\n *\n * @param  {Object} layoutItem Layout item.\n * @return {Object|undefined}  A colliding layout item, or undefined.\n */\nexport function getFirstCollision(layout: Layout, layoutItem: LayoutItem): ?LayoutItem {\n  for (let i = 0, len = layout.length; i < len; i++) {\n    if (collides(layout[i], layoutItem)) return layout[i];\n  }\n}\n\nexport function getAllCollisions(layout: Layout, layoutItem: LayoutItem): Array<LayoutItem> {\n  return layout.filter((l) => collides(l, layoutItem));\n}\n\n/**\n * Get all static elements.\n * @param  {Array} layout Array of layout objects.\n * @return {Array}        Array of static layout items..\n */\nexport function getStatics(layout: Layout): Array<LayoutItem> {\n    //return [];\n    return layout.filter((l) => l.static);\n}\n\n/**\n * Move an element. Responsible for doing cascading movements of other elements.\n *\n * @param  {Array}      layout Full layout to modify.\n * @param  {LayoutItem} l      element to move.\n * @param  {Number}     [x]    X position in grid units.\n * @param  {Number}     [y]    Y position in grid units.\n * @param  {Boolean}    [isUserAction] If true, designates that the item we're moving is\n *                                     being dragged/resized by th euser.\n */\nexport function moveElement(layout: Layout, l: LayoutItem, x: Number, y: Number, isUserAction: Boolean): Layout {\n  if (l.static) return layout;\n\n  // Short-circuit if nothing to do.\n  //if (l.y === y && l.x === x) return layout;\n\n  const movingUp = y && l.y > y;\n  // This is quite a bit faster than extending the object\n  if (typeof x === 'number') l.x = x;\n  if (typeof y === 'number') l.y = y;\n  l.moved = true;\n\n  // If this collides with anything, move it.\n  // When doing this comparison, we have to sort the items we compare with\n  // to ensure, in the case of multiple collisions, that we're getting the\n  // nearest collision.\n  let sorted = sortLayoutItemsByRowCol(layout);\n  if (movingUp) sorted = sorted.reverse();\n  const collisions = getAllCollisions(sorted, l);\n\n  // Move each item that collides away from this element.\n  for (let i = 0, len = collisions.length; i < len; i++) {\n    const collision = collisions[i];\n    // console.log('resolving collision between', l.i, 'at', l.y, 'and', collision.i, 'at', collision.y);\n\n    // Short circuit so we can't infinite loop\n    if (collision.moved) continue;\n\n    // This makes it feel a bit more precise by waiting to swap for just a bit when moving up.\n    if (l.y > collision.y && l.y - collision.y > collision.h / 4) continue;\n\n    // Don't move static items - we have to move *this* element away\n    if (collision.static) {\n      layout = moveElementAwayFromCollision(layout, collision, l, isUserAction);\n    } else {\n      layout = moveElementAwayFromCollision(layout, l, collision, isUserAction);\n    }\n  }\n\n  return layout;\n}\n\n/**\n * This is where the magic needs to happen - given a collision, move an element away from the collision.\n * We attempt to move it up if there's room, otherwise it goes below.\n *\n * @param  {Array} layout            Full layout to modify.\n * @param  {LayoutItem} collidesWith Layout item we're colliding with.\n * @param  {LayoutItem} itemToMove   Layout item we're moving.\n * @param  {Boolean} [isUserAction]  If true, designates that the item we're moving is being dragged/resized\n *                                   by the user.\n */\nexport function moveElementAwayFromCollision(layout: Layout, collidesWith: LayoutItem,\n                                             itemToMove: LayoutItem, isUserAction: ?boolean): Layout {\n\n  // If there is enough space above the collision to put this element, move it there.\n  // We only do this on the main collision as this can get funky in cascades and cause\n  // unwanted swapping behavior.\n  if (isUserAction) {\n    // Make a mock item so we don't modify the item here, only modify in moveElement.\n    const fakeItem: LayoutItem = {\n      x: itemToMove.x,\n      y: itemToMove.y,\n      w: itemToMove.w,\n      h: itemToMove.h,\n      i: '-1'\n    };\n    fakeItem.y = Math.max(collidesWith.y - itemToMove.h, 0);\n    if (!getFirstCollision(layout, fakeItem)) {\n      return moveElement(layout, itemToMove, undefined, fakeItem.y);\n    }\n  }\n\n  // Previously this was optimized to move below the collision directly, but this can cause problems\n  // with cascading moves, as an item may actually leapflog a collision and cause a reversal in order.\n  return moveElement(layout, itemToMove, undefined, itemToMove.y + 1);\n}\n\n/**\n * Helper to convert a number to a percentage string.\n *\n * @param  {Number} num Any number\n * @return {String}     That number as a percentage.\n */\nexport function perc(num: number): string {\n  return num * 100 + '%';\n}\n\nexport function setTransform(top, left, width, height): Object {\n  // Replace unitless items with px\n  const translate = \"translate3d(\" + left + \"px,\" + top + \"px, 0)\";\n  return {\n    transform: translate,\n    WebkitTransform: translate,\n    MozTransform: translate,\n    msTransform: translate,\n    OTransform: translate,\n    width: width + \"px\",\n    height: height + \"px\",\n    position: 'absolute'\n  };\n}\n/**\n * Just like the setTransform method, but instead it will return a negative value of right.\n *\n * @param top\n * @param right\n * @param width\n * @param height\n * @returns {{transform: string, WebkitTransform: string, MozTransform: string, msTransform: string, OTransform: string, width: string, height: string, position: string}}\n */\nexport function setTransformRtl(top, right, width, height): Object {\n    // Replace unitless items with px\n    const translate = \"translate3d(\" + right * -1 + \"px,\" + top + \"px, 0)\";\n    return {\n        transform: translate,\n        WebkitTransform: translate,\n        MozTransform: translate,\n        msTransform: translate,\n        OTransform: translate,\n        width: width + \"px\",\n        height: height + \"px\",\n        position: 'absolute'\n    };\n}\n\nexport function setTopLeft(top, left, width, height): Object {\n    return {\n        top: top + \"px\",\n        left: left + \"px\",\n        width: width + \"px\",\n        height: height + \"px\",\n        position: 'absolute'\n    };\n}\n/**\n * Just like the setTopLeft method, but instead, it will return a right property instead of left.\n *\n * @param top\n * @param right\n * @param width\n * @param height\n * @returns {{top: string, right: string, width: string, height: string, position: string}}\n */\nexport function setTopRight(top, right, width, height): Object {\n    return {\n        top: top + \"px\",\n        right: right+ \"px\",\n        width: width + \"px\",\n        height: height + \"px\",\n        position: 'absolute'\n    };\n}\n\n\n/**\n * Get layout items sorted from top left to right and down.\n *\n * @return {Array} Array of layout objects.\n * @return {Array}        Layout, sorted static items first.\n */\nexport function sortLayoutItemsByRowCol(layout: Layout): Layout {\n  return [].concat(layout).sort(function(a, b) {\n    if (a.y > b.y || (a.y === b.y && a.x > b.x)) {\n      return 1;\n    }\n    return -1;\n  });\n}\n\n/**\n * Generate a layout using the initialLayout and children as a template.\n * Missing entries will be added, extraneous ones will be truncated.\n *\n * @param  {Array}  initialLayout Layout passed in through props.\n * @param  {String} breakpoint    Current responsive breakpoint.\n * @param  {Boolean} verticalCompact Whether or not to compact the layout vertically.\n * @return {Array}                Working layout.\n */\n/*\nexport function synchronizeLayoutWithChildren(initialLayout: Layout, children: Array<React.Element>|React.Element,\n                                              cols: number, verticalCompact: boolean): Layout {\n  // ensure 'children' is always an array\n  if (!Array.isArray(children)) {\n    children = [children];\n  }\n  initialLayout = initialLayout || [];\n\n  // Generate one layout item per child.\n  let layout: Layout = [];\n  for (let i = 0, len = children.length; i < len; i++) {\n    let newItem;\n    const child = children[i];\n\n    // Don't overwrite if it already exists.\n    const exists = getLayoutItem(initialLayout, child.key || \"1\" /!* FIXME satisfies Flow *!/);\n    if (exists) {\n      newItem = exists;\n    } else {\n      const g = child.props._grid;\n\n      // Hey, this item has a _grid property, use it.\n      if (g) {\n        if (!isProduction) {\n          validateLayout([g], 'ReactGridLayout.children');\n        }\n        // Validated; add it to the layout. Bottom 'y' possible is the bottom of the layout.\n        // This allows you to do nice stuff like specify {y: Infinity}\n        if (verticalCompact) {\n          newItem = cloneLayoutItem({...g, y: Math.min(bottom(layout), g.y), i: child.key});\n        } else {\n          newItem = cloneLayoutItem({...g, y: g.y, i: child.key});\n        }\n      }\n      // Nothing provided: ensure this is added to the bottom\n      else {\n        newItem = cloneLayoutItem({w: 1, h: 1, x: 0, y: bottom(layout), i: child.key || \"1\"});\n      }\n    }\n    layout[i] = newItem;\n  }\n\n  // Correct the layout.\n  layout = correctBounds(layout, {cols: cols});\n  layout = compact(layout, verticalCompact);\n\n  return layout;\n}\n*/\n\n/**\n * Validate a layout. Throws errors.\n *\n * @param  {Array}  layout        Array of layout items.\n * @param  {String} [contextName] Context name for errors.\n * @throw  {Error}                Validation error.\n */\nexport function validateLayout(layout: Layout, contextName: string): void {\n  contextName = contextName || \"Layout\";\n  const subProps = ['x', 'y', 'w', 'h'];\n  if (!Array.isArray(layout)) throw new Error(contextName + \" must be an array!\");\n  for (let i = 0, len = layout.length; i < len; i++) {\n    const item = layout[i];\n    for (let j = 0; j < subProps.length; j++) {\n      if (typeof item[subProps[j]] !== 'number') {\n        throw new Error('VueGridLayout: ' + contextName + '[' + i + '].' + subProps[j] + ' must be a number!');\n      }\n    }\n    if (item.i && typeof item.i !== 'string') {\n      throw new Error('VueGridLayout: ' + contextName + '[' + i + '].i must be a string!');\n    }\n    if (item.static !== undefined && typeof item.static !== 'boolean') {\n      throw new Error('VueGridLayout: ' + contextName + '[' + i + '].static must be a boolean!');\n    }\n  }\n}\n\n// Flow can't really figure this out, so we just use Object\nexport function autoBindHandlers(el: Object, fns: Array<string>): void {\n  fns.forEach((key) => el[key] = el[key].bind(el));\n}\n\n\n\n/**\n * Convert a JS object to CSS string. Similar to React's output of CSS.\n * @param obj\n * @returns {string}\n */\nexport function createMarkup(obj) {\n    var keys = Object.keys(obj);\n    if (!keys.length) return '';\n    var i, len = keys.length;\n    var result = '';\n\n    for (i = 0; i < len; i++) {\n        var key = keys[i];\n        var val = obj[key];\n        result += hyphenate(key) + ':' + addPx(key, val) + ';';\n    }\n\n    return result;\n}\n\n\n/* The following list is defined in React's core */\nexport var IS_UNITLESS = {\n    animationIterationCount: true,\n    boxFlex: true,\n    boxFlexGroup: true,\n    boxOrdinalGroup: true,\n    columnCount: true,\n    flex: true,\n    flexGrow: true,\n    flexPositive: true,\n    flexShrink: true,\n    flexNegative: true,\n    flexOrder: true,\n    gridRow: true,\n    gridColumn: true,\n    fontWeight: true,\n    lineClamp: true,\n    lineHeight: true,\n    opacity: true,\n    order: true,\n    orphans: true,\n    tabSize: true,\n    widows: true,\n    zIndex: true,\n    zoom: true,\n\n    // SVG-related properties\n    fillOpacity: true,\n    stopOpacity: true,\n    strokeDashoffset: true,\n    strokeOpacity: true,\n    strokeWidth: true\n};\n\n\n/**\n * Will add px to the end of style values which are Numbers.\n * @param name\n * @param value\n * @returns {*}\n */\nexport function addPx(name, value) {\n    if(typeof value === 'number' && !IS_UNITLESS[ name ]) {\n        return value + 'px';\n    } else {\n        return value;\n    }\n}\n\n\n/**\n * Hyphenate a camelCase string.\n *\n * @param {String} str\n * @return {String}\n */\n\nexport var hyphenateRE = /([a-z\\d])([A-Z])/g;\n\nexport function hyphenate(str) {\n    return str.replace(hyphenateRE, '$1-$2').toLowerCase();\n}\n\n\nexport function findItemInArray(array, property, value) {\n    for (var i=0; i < array.length; i++)\n        if (array[i][property] == value)\n            return true;\n\n    return false;\n}\n\nexport function findAndRemove(array, property, value) {\n    array.forEach(function (result, index) {\n        if (result[property] === value) {\n            //Remove from array\n            array.splice(index, 1);\n        }\n    });\n}\n\n\n\n// WEBPACK FOOTER //\n// ./src/utils.js"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///0\n"); +eval("/* WEBPACK VAR INJECTION */(function(process) {\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.bottom = bottom;\nexports.cloneLayout = cloneLayout;\nexports.cloneLayoutItem = cloneLayoutItem;\nexports.collides = collides;\nexports.compact = compact;\nexports.compactItem = compactItem;\nexports.correctBounds = correctBounds;\nexports.getLayoutItem = getLayoutItem;\nexports.getFirstCollision = getFirstCollision;\nexports.getAllCollisions = getAllCollisions;\nexports.getStatics = getStatics;\nexports.moveElement = moveElement;\nexports.moveElementAwayFromCollision = moveElementAwayFromCollision;\nexports.perc = perc;\nexports.setTransform = setTransform;\nexports.setTransformRtl = setTransformRtl;\nexports.setTopLeft = setTopLeft;\nexports.setTopRight = setTopRight;\nexports.sortLayoutItemsByRowCol = sortLayoutItemsByRowCol;\nexports.validateLayout = validateLayout;\nexports.autoBindHandlers = autoBindHandlers;\nexports.createMarkup = createMarkup;\nexports.addPx = addPx;\nexports.hyphenate = hyphenate;\nexports.findItemInArray = findItemInArray;\nexports.findAndRemove = findAndRemove;\n// @flow\n/*:: export type LayoutItemRequired = {w: number, h: number, x: number, y: number, i: string};*/\n/*:: export type LayoutItem = LayoutItemRequired &\r\n {minW?: number, minH?: number, maxW?: number, maxH?: number,\r\n moved?: boolean, static?: boolean,\r\n isDraggable?: ?boolean, isResizable?: ?boolean};*/\n/*:: export type Layout = Array;*/\n/*:: export type Position = {left: number, top: number, width: number, height: number};*/\n/*:: export type DragCallbackData = {\r\n node: HTMLElement,\r\n x: number, y: number,\r\n deltaX: number, deltaY: number,\r\n lastX: number, lastY: number\r\n};*/\n/*:: export type DragEvent = {e: Event} & DragCallbackData;*/\n/*:: export type Size = {width: number, height: number};*/\n/*:: export type ResizeEvent = {e: Event, node: HTMLElement, size: Size};*/\n\n\nvar isProduction = process.env.NODE_ENV === 'production';\n/**\r\n * Return the bottom coordinate of the layout.\r\n *\r\n * @param {Array} layout Layout array.\r\n * @return {Number} Bottom coordinate.\r\n */\nfunction bottom(layout /*: Layout*/) /*: number*/ {\n var max = 0,\n bottomY = void 0;\n for (var _i = 0, len = layout.length; _i < len; _i++) {\n bottomY = layout[_i].y + layout[_i].h;\n if (bottomY > max) max = bottomY;\n }\n return max;\n}\n\nfunction cloneLayout(layout /*: Layout*/) /*: Layout*/ {\n var newLayout = Array(layout.length);\n for (var _i2 = 0, len = layout.length; _i2 < len; _i2++) {\n newLayout[_i2] = cloneLayoutItem(layout[_i2]);\n }\n return newLayout;\n}\n\n// Fast path to cloning, since this is monomorphic\nfunction cloneLayoutItem(layoutItem /*: LayoutItem*/) /*: LayoutItem*/ {\n /*return {\r\n w: layoutItem.w, h: layoutItem.h, x: layoutItem.x, y: layoutItem.y, i: layoutItem.i,\r\n minW: layoutItem.minW, maxW: layoutItem.maxW, minH: layoutItem.minH, maxH: layoutItem.maxH,\r\n moved: Boolean(layoutItem.moved), static: Boolean(layoutItem.static),\r\n // These can be null\r\n isDraggable: layoutItem.isDraggable, isResizable: layoutItem.isResizable\r\n };*/\n return JSON.parse(JSON.stringify(layoutItem));\n}\n\n/**\r\n * Given two layoutitems, check if they collide.\r\n *\r\n * @return {Boolean} True if colliding.\r\n */\nfunction collides(l1 /*: LayoutItem*/, l2 /*: LayoutItem*/) /*: boolean*/ {\n if (l1 === l2) return false; // same element\n if (l1.x + l1.w <= l2.x) return false; // l1 is left of l2\n if (l1.x >= l2.x + l2.w) return false; // l1 is right of l2\n if (l1.y + l1.h <= l2.y) return false; // l1 is above l2\n if (l1.y >= l2.y + l2.h) return false; // l1 is below l2\n return true; // boxes overlap\n}\n\n/**\r\n * Given a layout, compact it. This involves going down each y coordinate and removing gaps\r\n * between items.\r\n *\r\n * @param {Array} layout Layout.\r\n * @param {Boolean} verticalCompact Whether or not to compact the layout\r\n * vertically.\r\n * @return {Array} Compacted Layout.\r\n */\nfunction compact(layout /*: Layout*/, verticalCompact /*: Boolean*/) /*: Layout*/ {\n // Statics go in the compareWith array right away so items flow around them.\n var compareWith = getStatics(layout);\n // We go through the items by row and column.\n var sorted = sortLayoutItemsByRowCol(layout);\n // Holding for new items.\n var out = Array(layout.length);\n\n for (var _i3 = 0, len = sorted.length; _i3 < len; _i3++) {\n var l = sorted[_i3];\n\n // Don't move static elements\n if (!l.static) {\n l = compactItem(compareWith, l, verticalCompact);\n\n // Add to comparison array. We only collide with items before this one.\n // Statics are already in this array.\n compareWith.push(l);\n }\n\n // Add to output array to make sure they still come out in the right order.\n out[layout.indexOf(l)] = l;\n\n // Clear moved flag, if it exists.\n l.moved = false;\n }\n\n return out;\n}\n\n/**\r\n * Compact an item in the layout.\r\n */\nfunction compactItem(compareWith /*: Layout*/, l /*: LayoutItem*/, verticalCompact /*: boolean*/) /*: LayoutItem*/ {\n if (verticalCompact) {\n // Move the element up as far as it can go without colliding.\n while (l.y > 0 && !getFirstCollision(compareWith, l)) {\n l.y--;\n }\n }\n\n // Move it down, and keep moving it down if it's colliding.\n var collides = void 0;\n while (collides = getFirstCollision(compareWith, l)) {\n l.y = collides.y + collides.h;\n }\n return l;\n}\n\n/**\r\n * Given a layout, make sure all elements fit within its bounds.\r\n *\r\n * @param {Array} layout Layout array.\r\n * @param {Number} bounds Number of columns.\r\n */\nfunction correctBounds(layout /*: Layout*/, bounds /*: {cols: number}*/) /*: Layout*/ {\n var collidesWith = getStatics(layout);\n for (var _i4 = 0, len = layout.length; _i4 < len; _i4++) {\n var l = layout[_i4];\n // Overflows right\n if (l.x + l.w > bounds.cols) l.x = bounds.cols - l.w;\n // Overflows left\n if (l.x < 0) {\n l.x = 0;\n l.w = bounds.cols;\n }\n if (!l.static) collidesWith.push(l);else {\n // If this is static and collides with other statics, we must move it down.\n // We have to do something nicer than just letting them overlap.\n while (getFirstCollision(collidesWith, l)) {\n l.y++;\n }\n }\n }\n return layout;\n}\n\n/**\r\n * Get a layout item by ID. Used so we can override later on if necessary.\r\n *\r\n * @param {Array} layout Layout array.\r\n * @param {String} id ID\r\n * @return {LayoutItem} Item at ID.\r\n */\nfunction getLayoutItem(layout /*: Layout*/, id /*: string*/) /*: ?LayoutItem*/ {\n for (var _i5 = 0, len = layout.length; _i5 < len; _i5++) {\n if (layout[_i5].i === id) return layout[_i5];\n }\n}\n\n/**\r\n * Returns the first item this layout collides with.\r\n * It doesn't appear to matter which order we approach this from, although\r\n * perhaps that is the wrong thing to do.\r\n *\r\n * @param {Object} layoutItem Layout item.\r\n * @return {Object|undefined} A colliding layout item, or undefined.\r\n */\nfunction getFirstCollision(layout /*: Layout*/, layoutItem /*: LayoutItem*/) /*: ?LayoutItem*/ {\n for (var _i6 = 0, len = layout.length; _i6 < len; _i6++) {\n if (collides(layout[_i6], layoutItem)) return layout[_i6];\n }\n}\n\nfunction getAllCollisions(layout /*: Layout*/, layoutItem /*: LayoutItem*/) /*: Array*/ {\n return layout.filter(function (l) {\n return collides(l, layoutItem);\n });\n}\n\n/**\r\n * Get all static elements.\r\n * @param {Array} layout Array of layout objects.\r\n * @return {Array} Array of static layout items..\r\n */\nfunction getStatics(layout /*: Layout*/) /*: Array*/ {\n //return [];\n return layout.filter(function (l) {\n return l.static;\n });\n}\n\n/**\r\n * Move an element. Responsible for doing cascading movements of other elements.\r\n *\r\n * @param {Array} layout Full layout to modify.\r\n * @param {LayoutItem} l element to move.\r\n * @param {Number} [x] X position in grid units.\r\n * @param {Number} [y] Y position in grid units.\r\n * @param {Boolean} [isUserAction] If true, designates that the item we're moving is\r\n * being dragged/resized by th euser.\r\n */\nfunction moveElement(layout /*: Layout*/, l /*: LayoutItem*/, x /*: Number*/, y /*: Number*/, isUserAction /*: Boolean*/) /*: Layout*/ {\n if (l.static) return layout;\n\n // Short-circuit if nothing to do.\n //if (l.y === y && l.x === x) return layout;\n\n var movingUp = y && l.y > y;\n // This is quite a bit faster than extending the object\n if (typeof x === 'number') l.x = x;\n if (typeof y === 'number') l.y = y;\n l.moved = true;\n\n // If this collides with anything, move it.\n // When doing this comparison, we have to sort the items we compare with\n // to ensure, in the case of multiple collisions, that we're getting the\n // nearest collision.\n var sorted = sortLayoutItemsByRowCol(layout);\n if (movingUp) sorted = sorted.reverse();\n var collisions = getAllCollisions(sorted, l);\n\n // Move each item that collides away from this element.\n for (var _i7 = 0, len = collisions.length; _i7 < len; _i7++) {\n var collision = collisions[_i7];\n // console.log('resolving collision between', l.i, 'at', l.y, 'and', collision.i, 'at', collision.y);\n\n // Short circuit so we can't infinite loop\n if (collision.moved) continue;\n\n // This makes it feel a bit more precise by waiting to swap for just a bit when moving up.\n if (l.y > collision.y && l.y - collision.y > collision.h / 4) continue;\n\n // Don't move static items - we have to move *this* element away\n if (collision.static) {\n layout = moveElementAwayFromCollision(layout, collision, l, isUserAction);\n } else {\n layout = moveElementAwayFromCollision(layout, l, collision, isUserAction);\n }\n }\n\n return layout;\n}\n\n/**\r\n * This is where the magic needs to happen - given a collision, move an element away from the collision.\r\n * We attempt to move it up if there's room, otherwise it goes below.\r\n *\r\n * @param {Array} layout Full layout to modify.\r\n * @param {LayoutItem} collidesWith Layout item we're colliding with.\r\n * @param {LayoutItem} itemToMove Layout item we're moving.\r\n * @param {Boolean} [isUserAction] If true, designates that the item we're moving is being dragged/resized\r\n * by the user.\r\n */\nfunction moveElementAwayFromCollision(layout /*: Layout*/, collidesWith /*: LayoutItem*/, itemToMove /*: LayoutItem*/, isUserAction /*: ?boolean*/) /*: Layout*/ {\n\n // If there is enough space above the collision to put this element, move it there.\n // We only do this on the main collision as this can get funky in cascades and cause\n // unwanted swapping behavior.\n if (isUserAction) {\n // Make a mock item so we don't modify the item here, only modify in moveElement.\n var fakeItem /*: LayoutItem*/ = {\n x: itemToMove.x,\n y: itemToMove.y,\n w: itemToMove.w,\n h: itemToMove.h,\n i: '-1'\n };\n fakeItem.y = Math.max(collidesWith.y - itemToMove.h, 0);\n if (!getFirstCollision(layout, fakeItem)) {\n return moveElement(layout, itemToMove, undefined, fakeItem.y);\n }\n }\n\n // Previously this was optimized to move below the collision directly, but this can cause problems\n // with cascading moves, as an item may actually leapflog a collision and cause a reversal in order.\n return moveElement(layout, itemToMove, undefined, itemToMove.y + 1);\n}\n\n/**\r\n * Helper to convert a number to a percentage string.\r\n *\r\n * @param {Number} num Any number\r\n * @return {String} That number as a percentage.\r\n */\nfunction perc(num /*: number*/) /*: string*/ {\n return num * 100 + '%';\n}\n\nfunction setTransform(top, left, width, height) /*: Object*/ {\n // Replace unitless items with px\n var translate = \"translate3d(\" + left + \"px,\" + top + \"px, 0)\";\n return {\n transform: translate,\n WebkitTransform: translate,\n MozTransform: translate,\n msTransform: translate,\n OTransform: translate,\n width: width + \"px\",\n height: height + \"px\",\n position: 'absolute'\n };\n}\n/**\r\n * Just like the setTransform method, but instead it will return a negative value of right.\r\n *\r\n * @param top\r\n * @param right\r\n * @param width\r\n * @param height\r\n * @returns {{transform: string, WebkitTransform: string, MozTransform: string, msTransform: string, OTransform: string, width: string, height: string, position: string}}\r\n */\nfunction setTransformRtl(top, right, width, height) /*: Object*/ {\n // Replace unitless items with px\n var translate = \"translate3d(\" + right * -1 + \"px,\" + top + \"px, 0)\";\n return {\n transform: translate,\n WebkitTransform: translate,\n MozTransform: translate,\n msTransform: translate,\n OTransform: translate,\n width: width + \"px\",\n height: height + \"px\",\n position: 'absolute'\n };\n}\n\nfunction setTopLeft(top, left, width, height) /*: Object*/ {\n return {\n top: top + \"px\",\n left: left + \"px\",\n width: width + \"px\",\n height: height + \"px\",\n position: 'absolute'\n };\n}\n/**\r\n * Just like the setTopLeft method, but instead, it will return a right property instead of left.\r\n *\r\n * @param top\r\n * @param right\r\n * @param width\r\n * @param height\r\n * @returns {{top: string, right: string, width: string, height: string, position: string}}\r\n */\nfunction setTopRight(top, right, width, height) /*: Object*/ {\n return {\n top: top + \"px\",\n right: right + \"px\",\n width: width + \"px\",\n height: height + \"px\",\n position: 'absolute'\n };\n}\n\n/**\r\n * Get layout items sorted from top left to right and down.\r\n *\r\n * @return {Array} Array of layout objects.\r\n * @return {Array} Layout, sorted static items first.\r\n */\nfunction sortLayoutItemsByRowCol(layout /*: Layout*/) /*: Layout*/ {\n return [].concat(layout).sort(function (a, b) {\n if (a.y > b.y || a.y === b.y && a.x > b.x) {\n return 1;\n }\n return -1;\n });\n}\n\n/**\r\n * Generate a layout using the initialLayout and children as a template.\r\n * Missing entries will be added, extraneous ones will be truncated.\r\n *\r\n * @param {Array} initialLayout Layout passed in through props.\r\n * @param {String} breakpoint Current responsive breakpoint.\r\n * @param {Boolean} verticalCompact Whether or not to compact the layout vertically.\r\n * @return {Array} Working layout.\r\n */\n/*\r\nexport function synchronizeLayoutWithChildren(initialLayout: Layout, children: Array|React.Element,\r\n cols: number, verticalCompact: boolean): Layout {\r\n // ensure 'children' is always an array\r\n if (!Array.isArray(children)) {\r\n children = [children];\r\n }\r\n initialLayout = initialLayout || [];\r\n\r\n // Generate one layout item per child.\r\n let layout: Layout = [];\r\n for (let i = 0, len = children.length; i < len; i++) {\r\n let newItem;\r\n const child = children[i];\r\n\r\n // Don't overwrite if it already exists.\r\n const exists = getLayoutItem(initialLayout, child.key || \"1\" /!* FIXME satisfies Flow *!/);\r\n if (exists) {\r\n newItem = exists;\r\n } else {\r\n const g = child.props._grid;\r\n\r\n // Hey, this item has a _grid property, use it.\r\n if (g) {\r\n if (!isProduction) {\r\n validateLayout([g], 'ReactGridLayout.children');\r\n }\r\n // Validated; add it to the layout. Bottom 'y' possible is the bottom of the layout.\r\n // This allows you to do nice stuff like specify {y: Infinity}\r\n if (verticalCompact) {\r\n newItem = cloneLayoutItem({...g, y: Math.min(bottom(layout), g.y), i: child.key});\r\n } else {\r\n newItem = cloneLayoutItem({...g, y: g.y, i: child.key});\r\n }\r\n }\r\n // Nothing provided: ensure this is added to the bottom\r\n else {\r\n newItem = cloneLayoutItem({w: 1, h: 1, x: 0, y: bottom(layout), i: child.key || \"1\"});\r\n }\r\n }\r\n layout[i] = newItem;\r\n }\r\n\r\n // Correct the layout.\r\n layout = correctBounds(layout, {cols: cols});\r\n layout = compact(layout, verticalCompact);\r\n\r\n return layout;\r\n}\r\n*/\n\n/**\r\n * Validate a layout. Throws errors.\r\n *\r\n * @param {Array} layout Array of layout items.\r\n * @param {String} [contextName] Context name for errors.\r\n * @throw {Error} Validation error.\r\n */\nfunction validateLayout(layout /*: Layout*/, contextName /*: string*/) /*: void*/ {\n contextName = contextName || \"Layout\";\n var subProps = ['x', 'y', 'w', 'h'];\n if (!Array.isArray(layout)) throw new Error(contextName + \" must be an array!\");\n for (var _i8 = 0, len = layout.length; _i8 < len; _i8++) {\n var item = layout[_i8];\n for (var j = 0; j < subProps.length; j++) {\n if (typeof item[subProps[j]] !== 'number') {\n throw new Error('VueGridLayout: ' + contextName + '[' + _i8 + '].' + subProps[j] + ' must be a number!');\n }\n }\n if (item.i && typeof item.i !== 'string') {\n throw new Error('VueGridLayout: ' + contextName + '[' + _i8 + '].i must be a string!');\n }\n if (item.static !== undefined && typeof item.static !== 'boolean') {\n throw new Error('VueGridLayout: ' + contextName + '[' + _i8 + '].static must be a boolean!');\n }\n }\n}\n\n// Flow can't really figure this out, so we just use Object\nfunction autoBindHandlers(el /*: Object*/, fns /*: Array*/) /*: void*/ {\n fns.forEach(function (key) {\n return el[key] = el[key].bind(el);\n });\n}\n\n/**\r\n * Convert a JS object to CSS string. Similar to React's output of CSS.\r\n * @param obj\r\n * @returns {string}\r\n */\nfunction createMarkup(obj) {\n var keys = Object.keys(obj);\n if (!keys.length) return '';\n var i,\n len = keys.length;\n var result = '';\n\n for (i = 0; i < len; i++) {\n var key = keys[i];\n var val = obj[key];\n result += hyphenate(key) + ':' + addPx(key, val) + ';';\n }\n\n return result;\n}\n\n/* The following list is defined in React's core */\nvar IS_UNITLESS = exports.IS_UNITLESS = {\n animationIterationCount: true,\n boxFlex: true,\n boxFlexGroup: true,\n boxOrdinalGroup: true,\n columnCount: true,\n flex: true,\n flexGrow: true,\n flexPositive: true,\n flexShrink: true,\n flexNegative: true,\n flexOrder: true,\n gridRow: true,\n gridColumn: true,\n fontWeight: true,\n lineClamp: true,\n lineHeight: true,\n opacity: true,\n order: true,\n orphans: true,\n tabSize: true,\n widows: true,\n zIndex: true,\n zoom: true,\n\n // SVG-related properties\n fillOpacity: true,\n stopOpacity: true,\n strokeDashoffset: true,\n strokeOpacity: true,\n strokeWidth: true\n};\n\n/**\r\n * Will add px to the end of style values which are Numbers.\r\n * @param name\r\n * @param value\r\n * @returns {*}\r\n */\nfunction addPx(name, value) {\n if (typeof value === 'number' && !IS_UNITLESS[name]) {\n return value + 'px';\n } else {\n return value;\n }\n}\n\n/**\r\n * Hyphenate a camelCase string.\r\n *\r\n * @param {String} str\r\n * @return {String}\r\n */\n\nvar hyphenateRE = exports.hyphenateRE = /([a-z\\d])([A-Z])/g;\n\nfunction hyphenate(str) {\n return str.replace(hyphenateRE, '$1-$2').toLowerCase();\n}\n\nfunction findItemInArray(array, property, value) {\n for (var i = 0; i < array.length; i++) {\n if (array[i][property] == value) return true;\n }return false;\n}\n\nfunction findAndRemove(array, property, value) {\n array.forEach(function (result, index) {\n if (result[property] === value) {\n //Remove from array\n array.splice(index, 1);\n }\n });\n}\n/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(5)))\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack:///./src/utils.js?2ff8"],"names":["bottom","cloneLayout","cloneLayoutItem","collides","compact","compactItem","correctBounds","getLayoutItem","getFirstCollision","getAllCollisions","getStatics","moveElement","moveElementAwayFromCollision","perc","setTransform","setTransformRtl","setTopLeft","setTopRight","sortLayoutItemsByRowCol","validateLayout","autoBindHandlers","createMarkup","addPx","hyphenate","findItemInArray","findAndRemove","isProduction","process","env","NODE_ENV","layout","max","bottomY","i","len","length","y","h","newLayout","Array","layoutItem","JSON","parse","stringify","l1","l2","x","w","verticalCompact","compareWith","sorted","out","l","static","push","indexOf","moved","bounds","collidesWith","cols","id","filter","isUserAction","movingUp","reverse","collisions","collision","itemToMove","fakeItem","Math","undefined","num","top","left","width","height","translate","transform","WebkitTransform","MozTransform","msTransform","OTransform","position","right","concat","sort","a","b","contextName","subProps","isArray","Error","item","j","el","fns","forEach","key","bind","obj","keys","Object","result","val","IS_UNITLESS","animationIterationCount","boxFlex","boxFlexGroup","boxOrdinalGroup","columnCount","flex","flexGrow","flexPositive","flexShrink","flexNegative","flexOrder","gridRow","gridColumn","fontWeight","lineClamp","lineHeight","opacity","order","orphans","tabSize","widows","zIndex","zoom","fillOpacity","stopOpacity","strokeDashoffset","strokeOpacity","strokeWidth","name","value","hyphenateRE","str","replace","toLowerCase","array","property","index","splice"],"mappings":";;;;;QAyBgBA,M,GAAAA,M;QASAC,W,GAAAA,W;QASAC,e,GAAAA,e;QAgBAC,Q,GAAAA,Q;QAkBAC,O,GAAAA,O;QAiCAC,W,GAAAA,W;QAsBAC,a,GAAAA,a;QA8BAC,a,GAAAA,a;QAcAC,iB,GAAAA,iB;QAMAC,gB,GAAAA,gB;QASAC,U,GAAAA,U;QAeAC,W,GAAAA,W;QAoDAC,4B,GAAAA,4B;QAgCAC,I,GAAAA,I;QAIAC,Y,GAAAA,Y;QAuBAC,e,GAAAA,e;QAeAC,U,GAAAA,U;QAkBAC,W,GAAAA,W;QAiBAC,uB,GAAAA,uB;QA4EAC,c,GAAAA,c;QAqBAC,gB,GAAAA,gB;QAWAC,Y,GAAAA,Y;QAyDAC,K,GAAAA,K;QAkBAC,S,GAAAA,S;QAKAC,e,GAAAA,e;QAQAC,a,GAAAA,a;AAnjBhB;;;;;;;;;;;;;;;;;;;AAkBA,IAAMC,eAAeC,QAAQC,GAAR,CAAYC,QAAZ,KAAyB,YAA9C;AACA;;;;;;AAMO,SAAS7B,MAAT,CAAgB8B,MAAhB,4BAAwC;AAC7C,MAAIC,MAAM,CAAV;AAAA,MAAaC,gBAAb;AACA,OAAK,IAAIC,KAAI,CAAR,EAAWC,MAAMJ,OAAOK,MAA7B,EAAqCF,KAAIC,GAAzC,EAA8CD,IAA9C,EAAmD;AACjDD,cAAUF,OAAOG,EAAP,EAAWG,CAAX,GAAeN,OAAOG,EAAP,EAAUI,CAAnC;AACA,QAAIL,UAAUD,GAAd,EAAmBA,MAAMC,OAAN;AACpB;AACD,SAAOD,GAAP;AACD;;AAEM,SAAS9B,WAAT,CAAqB6B,MAArB,4BAA6C;AAClD,MAAMQ,YAAYC,MAAMT,OAAOK,MAAb,CAAlB;AACA,OAAK,IAAIF,MAAI,CAAR,EAAWC,MAAMJ,OAAOK,MAA7B,EAAqCF,MAAIC,GAAzC,EAA8CD,KAA9C,EAAmD;AACjDK,cAAUL,GAAV,IAAe/B,gBAAgB4B,OAAOG,GAAP,CAAhB,CAAf;AACD;AACD,SAAOK,SAAP;AACD;;AAED;AACO,SAASpC,eAAT,CAAyBsC,UAAzB,oCAA6D;AAClE;;;;;;;AAOE,SAAOC,KAAKC,KAAL,CAAWD,KAAKE,SAAL,CAAeH,UAAf,CAAX,CAAP;AACH;;AAED;;;;;AAKO,SAASrC,QAAT,CAAkByC,EAAlB,mBAAkCC,EAAlC,iCAA2D;AAChE,MAAID,OAAOC,EAAX,EAAe,OAAO,KAAP,CADiD,CACnC;AAC7B,MAAID,GAAGE,CAAH,GAAOF,GAAGG,CAAV,IAAeF,GAAGC,CAAtB,EAAyB,OAAO,KAAP,CAFuC,CAEzB;AACvC,MAAIF,GAAGE,CAAH,IAAQD,GAAGC,CAAH,GAAOD,GAAGE,CAAtB,EAAyB,OAAO,KAAP,CAHuC,CAGzB;AACvC,MAAIH,GAAGR,CAAH,GAAOQ,GAAGP,CAAV,IAAeQ,GAAGT,CAAtB,EAAyB,OAAO,KAAP,CAJuC,CAIzB;AACvC,MAAIQ,GAAGR,CAAH,IAAQS,GAAGT,CAAH,GAAOS,GAAGR,CAAtB,EAAyB,OAAO,KAAP,CALuC,CAKzB;AACvC,SAAO,IAAP,CANgE,CAMnD;AACd;;AAED;;;;;;;;;AASO,SAASjC,OAAT,CAAiB0B,MAAjB,eAAiCkB,eAAjC,6BAAmE;AACtE;AACF,MAAMC,cAAcvC,WAAWoB,MAAX,CAApB;AACA;AACA,MAAMoB,SAAShC,wBAAwBY,MAAxB,CAAf;AACA;AACA,MAAMqB,MAAMZ,MAAMT,OAAOK,MAAb,CAAZ;;AAEA,OAAK,IAAIF,MAAI,CAAR,EAAWC,MAAMgB,OAAOf,MAA7B,EAAqCF,MAAIC,GAAzC,EAA8CD,KAA9C,EAAmD;AACjD,QAAImB,IAAIF,OAAOjB,GAAP,CAAR;;AAEA;AACA,QAAI,CAACmB,EAAEC,MAAP,EAAe;AACbD,UAAI/C,YAAY4C,WAAZ,EAAyBG,CAAzB,EAA4BJ,eAA5B,CAAJ;;AAEA;AACA;AACAC,kBAAYK,IAAZ,CAAiBF,CAAjB;AACD;;AAED;AACAD,QAAIrB,OAAOyB,OAAP,CAAeH,CAAf,CAAJ,IAAyBA,CAAzB;;AAEA;AACAA,MAAEI,KAAF,GAAU,KAAV;AACD;;AAED,SAAOL,GAAP;AACD;;AAED;;;AAGO,SAAS9C,WAAT,CAAqB4C,WAArB,eAA0CG,CAA1C,mBAAyDJ,eAAzD,iCAA+F;AACpG,MAAIA,eAAJ,EAAqB;AACnB;AACA,WAAOI,EAAEhB,CAAF,GAAM,CAAN,IAAW,CAAC5B,kBAAkByC,WAAlB,EAA+BG,CAA/B,CAAnB,EAAsD;AACpDA,QAAEhB,CAAF;AACD;AACF;;AAED;AACA,MAAIjC,iBAAJ;AACA,SAAOA,WAAWK,kBAAkByC,WAAlB,EAA+BG,CAA/B,CAAlB,EAAsD;AACpDA,MAAEhB,CAAF,GAAMjC,SAASiC,CAAT,GAAajC,SAASkC,CAA5B;AACD;AACD,SAAOe,CAAP;AACD;;AAED;;;;;;AAMO,SAAS9C,aAAT,CAAuBwB,MAAvB,eAAuC2B,MAAvC,oCAAuE;AAC5E,MAAMC,eAAehD,WAAWoB,MAAX,CAArB;AACA,OAAK,IAAIG,MAAI,CAAR,EAAWC,MAAMJ,OAAOK,MAA7B,EAAqCF,MAAIC,GAAzC,EAA8CD,KAA9C,EAAmD;AACjD,QAAMmB,IAAItB,OAAOG,GAAP,CAAV;AACA;AACA,QAAImB,EAAEN,CAAF,GAAMM,EAAEL,CAAR,GAAYU,OAAOE,IAAvB,EAA6BP,EAAEN,CAAF,GAAMW,OAAOE,IAAP,GAAcP,EAAEL,CAAtB;AAC7B;AACA,QAAIK,EAAEN,CAAF,GAAM,CAAV,EAAa;AACXM,QAAEN,CAAF,GAAM,CAAN;AACAM,QAAEL,CAAF,GAAMU,OAAOE,IAAb;AACD;AACD,QAAI,CAACP,EAAEC,MAAP,EAAeK,aAAaJ,IAAb,CAAkBF,CAAlB,EAAf,KACK;AACH;AACA;AACA,aAAM5C,kBAAkBkD,YAAlB,EAAgCN,CAAhC,CAAN,EAA0C;AACxCA,UAAEhB,CAAF;AACD;AACF;AACF;AACD,SAAON,MAAP;AACD;;AAED;;;;;;;AAOO,SAASvB,aAAT,CAAuBuB,MAAvB,eAAuC8B,EAAvC,iCAAgE;AACrE,OAAK,IAAI3B,MAAI,CAAR,EAAWC,MAAMJ,OAAOK,MAA7B,EAAqCF,MAAIC,GAAzC,EAA8CD,KAA9C,EAAmD;AACjD,QAAIH,OAAOG,GAAP,EAAUA,CAAV,KAAgB2B,EAApB,EAAwB,OAAO9B,OAAOG,GAAP,CAAP;AACzB;AACF;;AAED;;;;;;;;AAQO,SAASzB,iBAAT,CAA2BsB,MAA3B,eAA2CU,UAA3C,qCAAgF;AACrF,OAAK,IAAIP,MAAI,CAAR,EAAWC,MAAMJ,OAAOK,MAA7B,EAAqCF,MAAIC,GAAzC,EAA8CD,KAA9C,EAAmD;AACjD,QAAI9B,SAAS2B,OAAOG,GAAP,CAAT,EAAoBO,UAApB,CAAJ,EAAqC,OAAOV,OAAOG,GAAP,CAAP;AACtC;AACF;;AAEM,SAASxB,gBAAT,CAA0BqB,MAA1B,eAA0CU,UAA1C,2CAAqF;AAC1F,SAAOV,OAAO+B,MAAP,CAAc,UAACT,CAAD;AAAA,WAAOjD,SAASiD,CAAT,EAAYZ,UAAZ,CAAP;AAAA,GAAd,CAAP;AACD;;AAED;;;;;AAKO,SAAS9B,UAAT,CAAoBoB,MAApB,uCAAuD;AAC1D;AACA,SAAOA,OAAO+B,MAAP,CAAc,UAACT,CAAD;AAAA,WAAOA,EAAEC,MAAT;AAAA,GAAd,CAAP;AACH;;AAED;;;;;;;;;;AAUO,SAAS1C,WAAT,CAAqBmB,MAArB,eAAqCsB,CAArC,mBAAoDN,CAApD,eAA+DV,CAA/D,eAA0E0B,YAA1E,6BAAyG;AAC9G,MAAIV,EAAEC,MAAN,EAAc,OAAOvB,MAAP;;AAEd;AACA;;AAEA,MAAMiC,WAAW3B,KAAKgB,EAAEhB,CAAF,GAAMA,CAA5B;AACA;AACA,MAAI,OAAOU,CAAP,KAAa,QAAjB,EAA2BM,EAAEN,CAAF,GAAMA,CAAN;AAC3B,MAAI,OAAOV,CAAP,KAAa,QAAjB,EAA2BgB,EAAEhB,CAAF,GAAMA,CAAN;AAC3BgB,IAAEI,KAAF,GAAU,IAAV;;AAEA;AACA;AACA;AACA;AACA,MAAIN,SAAShC,wBAAwBY,MAAxB,CAAb;AACA,MAAIiC,QAAJ,EAAcb,SAASA,OAAOc,OAAP,EAAT;AACd,MAAMC,aAAaxD,iBAAiByC,MAAjB,EAAyBE,CAAzB,CAAnB;;AAEA;AACA,OAAK,IAAInB,MAAI,CAAR,EAAWC,MAAM+B,WAAW9B,MAAjC,EAAyCF,MAAIC,GAA7C,EAAkDD,KAAlD,EAAuD;AACrD,QAAMiC,YAAYD,WAAWhC,GAAX,CAAlB;AACA;;AAEA;AACA,QAAIiC,UAAUV,KAAd,EAAqB;;AAErB;AACA,QAAIJ,EAAEhB,CAAF,GAAM8B,UAAU9B,CAAhB,IAAqBgB,EAAEhB,CAAF,GAAM8B,UAAU9B,CAAhB,GAAoB8B,UAAU7B,CAAV,GAAc,CAA3D,EAA8D;;AAE9D;AACA,QAAI6B,UAAUb,MAAd,EAAsB;AACpBvB,eAASlB,6BAA6BkB,MAA7B,EAAqCoC,SAArC,EAAgDd,CAAhD,EAAmDU,YAAnD,CAAT;AACD,KAFD,MAEO;AACLhC,eAASlB,6BAA6BkB,MAA7B,EAAqCsB,CAArC,EAAwCc,SAAxC,EAAmDJ,YAAnD,CAAT;AACD;AACF;;AAED,SAAOhC,MAAP;AACD;;AAED;;;;;;;;;;AAUO,SAASlB,4BAAT,CAAsCkB,MAAtC,eAAsD4B,YAAtD,mBACsCS,UADtC,mBAC8DL,YAD9D,8BAC8F;;AAEnG;AACA;AACA;AACA,MAAIA,YAAJ,EAAkB;AAChB;AACA,QAAMM,4BAAuB;AAC3BtB,SAAGqB,WAAWrB,CADa;AAE3BV,SAAG+B,WAAW/B,CAFa;AAG3BW,SAAGoB,WAAWpB,CAHa;AAI3BV,SAAG8B,WAAW9B,CAJa;AAK3BJ,SAAG;AALwB,KAA7B;AAOAmC,aAAShC,CAAT,GAAaiC,KAAKtC,GAAL,CAAS2B,aAAatB,CAAb,GAAiB+B,WAAW9B,CAArC,EAAwC,CAAxC,CAAb;AACA,QAAI,CAAC7B,kBAAkBsB,MAAlB,EAA0BsC,QAA1B,CAAL,EAA0C;AACxC,aAAOzD,YAAYmB,MAAZ,EAAoBqC,UAApB,EAAgCG,SAAhC,EAA2CF,SAAShC,CAApD,CAAP;AACD;AACF;;AAED;AACA;AACA,SAAOzB,YAAYmB,MAAZ,EAAoBqC,UAApB,EAAgCG,SAAhC,EAA2CH,WAAW/B,CAAX,GAAe,CAA1D,CAAP;AACD;;AAED;;;;;;AAMO,SAASvB,IAAT,CAAc0D,GAAd,4BAAmC;AACxC,SAAOA,MAAM,GAAN,GAAY,GAAnB;AACD;;AAEM,SAASzD,YAAT,CAAsB0D,GAAtB,EAA2BC,IAA3B,EAAiCC,KAAjC,EAAwCC,MAAxC,eAAwD;AAC7D;AACA,MAAMC,YAAY,iBAAiBH,IAAjB,GAAwB,KAAxB,GAAgCD,GAAhC,GAAsC,QAAxD;AACA,SAAO;AACLK,eAAWD,SADN;AAELE,qBAAiBF,SAFZ;AAGLG,kBAAcH,SAHT;AAILI,iBAAaJ,SAJR;AAKLK,gBAAYL,SALP;AAMLF,WAAOA,QAAQ,IANV;AAOLC,YAAQA,SAAS,IAPZ;AAQLO,cAAU;AARL,GAAP;AAUD;AACD;;;;;;;;;AASO,SAASnE,eAAT,CAAyByD,GAAzB,EAA8BW,KAA9B,EAAqCT,KAArC,EAA4CC,MAA5C,eAA4D;AAC/D;AACA,MAAMC,YAAY,iBAAiBO,QAAQ,CAAC,CAA1B,GAA8B,KAA9B,GAAsCX,GAAtC,GAA4C,QAA9D;AACA,SAAO;AACHK,eAAWD,SADR;AAEHE,qBAAiBF,SAFd;AAGHG,kBAAcH,SAHX;AAIHI,iBAAaJ,SAJV;AAKHK,gBAAYL,SALT;AAMHF,WAAOA,QAAQ,IANZ;AAOHC,YAAQA,SAAS,IAPd;AAQHO,cAAU;AARP,GAAP;AAUH;;AAEM,SAASlE,UAAT,CAAoBwD,GAApB,EAAyBC,IAAzB,EAA+BC,KAA/B,EAAsCC,MAAtC,eAAsD;AACzD,SAAO;AACHH,SAAKA,MAAM,IADR;AAEHC,UAAMA,OAAO,IAFV;AAGHC,WAAOA,QAAQ,IAHZ;AAIHC,YAAQA,SAAS,IAJd;AAKHO,cAAU;AALP,GAAP;AAOH;AACD;;;;;;;;;AASO,SAASjE,WAAT,CAAqBuD,GAArB,EAA0BW,KAA1B,EAAiCT,KAAjC,EAAwCC,MAAxC,eAAwD;AAC3D,SAAO;AACHH,SAAKA,MAAM,IADR;AAEHW,WAAOA,QAAO,IAFX;AAGHT,WAAOA,QAAQ,IAHZ;AAIHC,YAAQA,SAAS,IAJd;AAKHO,cAAU;AALP,GAAP;AAOH;;AAGD;;;;;;AAMO,SAAShE,uBAAT,CAAiCY,MAAjC,4BAAyD;AAC9D,SAAO,GAAGsD,MAAH,CAAUtD,MAAV,EAAkBuD,IAAlB,CAAuB,UAASC,CAAT,EAAYC,CAAZ,EAAe;AAC3C,QAAID,EAAElD,CAAF,GAAMmD,EAAEnD,CAAR,IAAckD,EAAElD,CAAF,KAAQmD,EAAEnD,CAAV,IAAekD,EAAExC,CAAF,GAAMyC,EAAEzC,CAAzC,EAA6C;AAC3C,aAAO,CAAP;AACD;AACD,WAAO,CAAC,CAAR;AACD,GALM,CAAP;AAMD;;AAED;;;;;;;;;AASA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAmDA;;;;;;;AAOO,SAAS3B,cAAT,CAAwBW,MAAxB,eAAwC0D,WAAxC,0BAAmE;AACxEA,gBAAcA,eAAe,QAA7B;AACA,MAAMC,WAAW,CAAC,GAAD,EAAM,GAAN,EAAW,GAAX,EAAgB,GAAhB,CAAjB;AACA,MAAI,CAAClD,MAAMmD,OAAN,CAAc5D,MAAd,CAAL,EAA4B,MAAM,IAAI6D,KAAJ,CAAUH,cAAc,oBAAxB,CAAN;AAC5B,OAAK,IAAIvD,MAAI,CAAR,EAAWC,MAAMJ,OAAOK,MAA7B,EAAqCF,MAAIC,GAAzC,EAA8CD,KAA9C,EAAmD;AACjD,QAAM2D,OAAO9D,OAAOG,GAAP,CAAb;AACA,SAAK,IAAI4D,IAAI,CAAb,EAAgBA,IAAIJ,SAAStD,MAA7B,EAAqC0D,GAArC,EAA0C;AACxC,UAAI,OAAOD,KAAKH,SAASI,CAAT,CAAL,CAAP,KAA6B,QAAjC,EAA2C;AACzC,cAAM,IAAIF,KAAJ,CAAU,oBAAoBH,WAApB,GAAkC,GAAlC,GAAwCvD,GAAxC,GAA4C,IAA5C,GAAmDwD,SAASI,CAAT,CAAnD,GAAiE,oBAA3E,CAAN;AACD;AACF;AACD,QAAID,KAAK3D,CAAL,IAAU,OAAO2D,KAAK3D,CAAZ,KAAkB,QAAhC,EAA0C;AACxC,YAAM,IAAI0D,KAAJ,CAAU,oBAAoBH,WAApB,GAAkC,GAAlC,GAAwCvD,GAAxC,GAA4C,uBAAtD,CAAN;AACD;AACD,QAAI2D,KAAKvC,MAAL,KAAgBiB,SAAhB,IAA6B,OAAOsB,KAAKvC,MAAZ,KAAuB,SAAxD,EAAmE;AACjE,YAAM,IAAIsC,KAAJ,CAAU,oBAAoBH,WAApB,GAAkC,GAAlC,GAAwCvD,GAAxC,GAA4C,6BAAtD,CAAN;AACD;AACF;AACF;;AAED;AACO,SAASb,gBAAT,CAA0B0E,EAA1B,eAAsCC,GAAtC,iCAAgE;AACrEA,MAAIC,OAAJ,CAAY,UAACC,GAAD;AAAA,WAASH,GAAGG,GAAH,IAAUH,GAAGG,GAAH,EAAQC,IAAR,CAAaJ,EAAb,CAAnB;AAAA,GAAZ;AACD;;AAID;;;;;AAKO,SAASzE,YAAT,CAAsB8E,GAAtB,EAA2B;AAC9B,MAAIC,OAAOC,OAAOD,IAAP,CAAYD,GAAZ,CAAX;AACA,MAAI,CAACC,KAAKjE,MAAV,EAAkB,OAAO,EAAP;AAClB,MAAIF,CAAJ;AAAA,MAAOC,MAAMkE,KAAKjE,MAAlB;AACA,MAAImE,SAAS,EAAb;;AAEA,OAAKrE,IAAI,CAAT,EAAYA,IAAIC,GAAhB,EAAqBD,GAArB,EAA0B;AACtB,QAAIgE,MAAMG,KAAKnE,CAAL,CAAV;AACA,QAAIsE,MAAMJ,IAAIF,GAAJ,CAAV;AACAK,cAAU/E,UAAU0E,GAAV,IAAiB,GAAjB,GAAuB3E,MAAM2E,GAAN,EAAWM,GAAX,CAAvB,GAAyC,GAAnD;AACH;;AAED,SAAOD,MAAP;AACH;;AAGD;AACO,IAAIE,oCAAc;AACrBC,2BAAyB,IADJ;AAErBC,WAAS,IAFY;AAGrBC,gBAAc,IAHO;AAIrBC,mBAAiB,IAJI;AAKrBC,eAAa,IALQ;AAMrBC,QAAM,IANe;AAOrBC,YAAU,IAPW;AAQrBC,gBAAc,IARO;AASrBC,cAAY,IATS;AAUrBC,gBAAc,IAVO;AAWrBC,aAAW,IAXU;AAYrBC,WAAS,IAZY;AAarBC,cAAY,IAbS;AAcrBC,cAAY,IAdS;AAerBC,aAAW,IAfU;AAgBrBC,cAAY,IAhBS;AAiBrBC,WAAS,IAjBY;AAkBrBC,SAAO,IAlBc;AAmBrBC,WAAS,IAnBY;AAoBrBC,WAAS,IApBY;AAqBrBC,UAAQ,IArBa;AAsBrBC,UAAQ,IAtBa;AAuBrBC,QAAM,IAvBe;;AAyBrB;AACAC,eAAa,IA1BQ;AA2BrBC,eAAa,IA3BQ;AA4BrBC,oBAAkB,IA5BG;AA6BrBC,iBAAe,IA7BM;AA8BrBC,eAAa;AA9BQ,CAAlB;;AAkCP;;;;;;AAMO,SAAS9G,KAAT,CAAe+G,IAAf,EAAqBC,KAArB,EAA4B;AAC/B,MAAG,OAAOA,KAAP,KAAiB,QAAjB,IAA6B,CAAC9B,YAAa6B,IAAb,CAAjC,EAAsD;AAClD,WAAOC,QAAQ,IAAf;AACH,GAFD,MAEO;AACH,WAAOA,KAAP;AACH;AACJ;;AAGD;;;;;;;AAOO,IAAIC,oCAAc,mBAAlB;;AAEA,SAAShH,SAAT,CAAmBiH,GAAnB,EAAwB;AAC3B,SAAOA,IAAIC,OAAJ,CAAYF,WAAZ,EAAyB,OAAzB,EAAkCG,WAAlC,EAAP;AACH;;AAGM,SAASlH,eAAT,CAAyBmH,KAAzB,EAAgCC,QAAhC,EAA0CN,KAA1C,EAAiD;AACpD,OAAK,IAAIrG,IAAE,CAAX,EAAcA,IAAI0G,MAAMxG,MAAxB,EAAgCF,GAAhC;AACI,QAAI0G,MAAM1G,CAAN,EAAS2G,QAAT,KAAsBN,KAA1B,EACI,OAAO,IAAP;AAFR,GAIA,OAAO,KAAP;AACH;;AAEM,SAAS7G,aAAT,CAAuBkH,KAAvB,EAA8BC,QAA9B,EAAwCN,KAAxC,EAA+C;AAClDK,QAAM3C,OAAN,CAAc,UAAUM,MAAV,EAAkBuC,KAAlB,EAAyB;AACnC,QAAIvC,OAAOsC,QAAP,MAAqBN,KAAzB,EAAgC;AAC5B;AACAK,YAAMG,MAAN,CAAaD,KAAb,EAAoB,CAApB;AACH;AACJ,GALD;AAMH,C","file":"0.js","sourcesContent":["// @flow\r\nexport type LayoutItemRequired = {w: number, h: number, x: number, y: number, i: string};\r\nexport type LayoutItem = LayoutItemRequired &\r\n                         {minW?: number, minH?: number, maxW?: number, maxH?: number,\r\n                          moved?: boolean, static?: boolean,\r\n                          isDraggable?: ?boolean, isResizable?: ?boolean};\r\nexport type Layout = Array<LayoutItem>;\r\nexport type Position = {left: number, top: number, width: number, height: number};\r\nexport type DragCallbackData = {\r\n  node: HTMLElement,\r\n  x: number, y: number,\r\n  deltaX: number, deltaY: number,\r\n  lastX: number, lastY: number\r\n};\r\nexport type DragEvent = {e: Event} & DragCallbackData;\r\nexport type Size = {width: number, height: number};\r\nexport type ResizeEvent = {e: Event, node: HTMLElement, size: Size};\r\n\r\nconst isProduction = process.env.NODE_ENV === 'production';\r\n/**\r\n * Return the bottom coordinate of the layout.\r\n *\r\n * @param  {Array} layout Layout array.\r\n * @return {Number}       Bottom coordinate.\r\n */\r\nexport function bottom(layout: Layout): number {\r\n  let max = 0, bottomY;\r\n  for (let i = 0, len = layout.length; i < len; i++) {\r\n    bottomY = layout[i]. y + layout[i].h;\r\n    if (bottomY > max) max = bottomY;\r\n  }\r\n  return max;\r\n}\r\n\r\nexport function cloneLayout(layout: Layout): Layout {\r\n  const newLayout = Array(layout.length);\r\n  for (let i = 0, len = layout.length; i < len; i++) {\r\n    newLayout[i] = cloneLayoutItem(layout[i]);\r\n  }\r\n  return newLayout;\r\n}\r\n\r\n// Fast path to cloning, since this is monomorphic\r\nexport function cloneLayoutItem(layoutItem: LayoutItem): LayoutItem {\r\n  /*return {\r\n    w: layoutItem.w, h: layoutItem.h, x: layoutItem.x, y: layoutItem.y, i: layoutItem.i,\r\n    minW: layoutItem.minW, maxW: layoutItem.maxW, minH: layoutItem.minH, maxH: layoutItem.maxH,\r\n    moved: Boolean(layoutItem.moved), static: Boolean(layoutItem.static),\r\n    // These can be null\r\n    isDraggable: layoutItem.isDraggable, isResizable: layoutItem.isResizable\r\n  };*/\r\n    return JSON.parse(JSON.stringify(layoutItem));\r\n}\r\n\r\n/**\r\n * Given two layoutitems, check if they collide.\r\n *\r\n * @return {Boolean}   True if colliding.\r\n */\r\nexport function collides(l1: LayoutItem, l2: LayoutItem): boolean {\r\n  if (l1 === l2) return false; // same element\r\n  if (l1.x + l1.w <= l2.x) return false; // l1 is left of l2\r\n  if (l1.x >= l2.x + l2.w) return false; // l1 is right of l2\r\n  if (l1.y + l1.h <= l2.y) return false; // l1 is above l2\r\n  if (l1.y >= l2.y + l2.h) return false; // l1 is below l2\r\n  return true; // boxes overlap\r\n}\r\n\r\n/**\r\n * Given a layout, compact it. This involves going down each y coordinate and removing gaps\r\n * between items.\r\n *\r\n * @param  {Array} layout Layout.\r\n * @param  {Boolean} verticalCompact Whether or not to compact the layout\r\n *   vertically.\r\n * @return {Array}       Compacted Layout.\r\n */\r\nexport function compact(layout: Layout, verticalCompact: Boolean): Layout {\r\n    // Statics go in the compareWith array right away so items flow around them.\r\n  const compareWith = getStatics(layout);\r\n  // We go through the items by row and column.\r\n  const sorted = sortLayoutItemsByRowCol(layout);\r\n  // Holding for new items.\r\n  const out = Array(layout.length);\r\n\r\n  for (let i = 0, len = sorted.length; i < len; i++) {\r\n    let l = sorted[i];\r\n\r\n    // Don't move static elements\r\n    if (!l.static) {\r\n      l = compactItem(compareWith, l, verticalCompact);\r\n\r\n      // Add to comparison array. We only collide with items before this one.\r\n      // Statics are already in this array.\r\n      compareWith.push(l);\r\n    }\r\n\r\n    // Add to output array to make sure they still come out in the right order.\r\n    out[layout.indexOf(l)] = l;\r\n\r\n    // Clear moved flag, if it exists.\r\n    l.moved = false;\r\n  }\r\n\r\n  return out;\r\n}\r\n\r\n/**\r\n * Compact an item in the layout.\r\n */\r\nexport function compactItem(compareWith: Layout, l: LayoutItem, verticalCompact: boolean): LayoutItem {\r\n  if (verticalCompact) {\r\n    // Move the element up as far as it can go without colliding.\r\n    while (l.y > 0 && !getFirstCollision(compareWith, l)) {\r\n      l.y--;\r\n    }\r\n  }\r\n\r\n  // Move it down, and keep moving it down if it's colliding.\r\n  let collides;\r\n  while((collides = getFirstCollision(compareWith, l))) {\r\n    l.y = collides.y + collides.h;\r\n  }\r\n  return l;\r\n}\r\n\r\n/**\r\n * Given a layout, make sure all elements fit within its bounds.\r\n *\r\n * @param  {Array} layout Layout array.\r\n * @param  {Number} bounds Number of columns.\r\n */\r\nexport function correctBounds(layout: Layout, bounds: {cols: number}): Layout {\r\n  const collidesWith = getStatics(layout);\r\n  for (let i = 0, len = layout.length; i < len; i++) {\r\n    const l = layout[i];\r\n    // Overflows right\r\n    if (l.x + l.w > bounds.cols) l.x = bounds.cols - l.w;\r\n    // Overflows left\r\n    if (l.x < 0) {\r\n      l.x = 0;\r\n      l.w = bounds.cols;\r\n    }\r\n    if (!l.static) collidesWith.push(l);\r\n    else {\r\n      // If this is static and collides with other statics, we must move it down.\r\n      // We have to do something nicer than just letting them overlap.\r\n      while(getFirstCollision(collidesWith, l)) {\r\n        l.y++;\r\n      }\r\n    }\r\n  }\r\n  return layout;\r\n}\r\n\r\n/**\r\n * Get a layout item by ID. Used so we can override later on if necessary.\r\n *\r\n * @param  {Array}  layout Layout array.\r\n * @param  {String} id     ID\r\n * @return {LayoutItem}    Item at ID.\r\n */\r\nexport function getLayoutItem(layout: Layout, id: string): ?LayoutItem {\r\n  for (let i = 0, len = layout.length; i < len; i++) {\r\n    if (layout[i].i === id) return layout[i];\r\n  }\r\n}\r\n\r\n/**\r\n * Returns the first item this layout collides with.\r\n * It doesn't appear to matter which order we approach this from, although\r\n * perhaps that is the wrong thing to do.\r\n *\r\n * @param  {Object} layoutItem Layout item.\r\n * @return {Object|undefined}  A colliding layout item, or undefined.\r\n */\r\nexport function getFirstCollision(layout: Layout, layoutItem: LayoutItem): ?LayoutItem {\r\n  for (let i = 0, len = layout.length; i < len; i++) {\r\n    if (collides(layout[i], layoutItem)) return layout[i];\r\n  }\r\n}\r\n\r\nexport function getAllCollisions(layout: Layout, layoutItem: LayoutItem): Array<LayoutItem> {\r\n  return layout.filter((l) => collides(l, layoutItem));\r\n}\r\n\r\n/**\r\n * Get all static elements.\r\n * @param  {Array} layout Array of layout objects.\r\n * @return {Array}        Array of static layout items..\r\n */\r\nexport function getStatics(layout: Layout): Array<LayoutItem> {\r\n    //return [];\r\n    return layout.filter((l) => l.static);\r\n}\r\n\r\n/**\r\n * Move an element. Responsible for doing cascading movements of other elements.\r\n *\r\n * @param  {Array}      layout Full layout to modify.\r\n * @param  {LayoutItem} l      element to move.\r\n * @param  {Number}     [x]    X position in grid units.\r\n * @param  {Number}     [y]    Y position in grid units.\r\n * @param  {Boolean}    [isUserAction] If true, designates that the item we're moving is\r\n *                                     being dragged/resized by th euser.\r\n */\r\nexport function moveElement(layout: Layout, l: LayoutItem, x: Number, y: Number, isUserAction: Boolean): Layout {\r\n  if (l.static) return layout;\r\n\r\n  // Short-circuit if nothing to do.\r\n  //if (l.y === y && l.x === x) return layout;\r\n\r\n  const movingUp = y && l.y > y;\r\n  // This is quite a bit faster than extending the object\r\n  if (typeof x === 'number') l.x = x;\r\n  if (typeof y === 'number') l.y = y;\r\n  l.moved = true;\r\n\r\n  // If this collides with anything, move it.\r\n  // When doing this comparison, we have to sort the items we compare with\r\n  // to ensure, in the case of multiple collisions, that we're getting the\r\n  // nearest collision.\r\n  let sorted = sortLayoutItemsByRowCol(layout);\r\n  if (movingUp) sorted = sorted.reverse();\r\n  const collisions = getAllCollisions(sorted, l);\r\n\r\n  // Move each item that collides away from this element.\r\n  for (let i = 0, len = collisions.length; i < len; i++) {\r\n    const collision = collisions[i];\r\n    // console.log('resolving collision between', l.i, 'at', l.y, 'and', collision.i, 'at', collision.y);\r\n\r\n    // Short circuit so we can't infinite loop\r\n    if (collision.moved) continue;\r\n\r\n    // This makes it feel a bit more precise by waiting to swap for just a bit when moving up.\r\n    if (l.y > collision.y && l.y - collision.y > collision.h / 4) continue;\r\n\r\n    // Don't move static items - we have to move *this* element away\r\n    if (collision.static) {\r\n      layout = moveElementAwayFromCollision(layout, collision, l, isUserAction);\r\n    } else {\r\n      layout = moveElementAwayFromCollision(layout, l, collision, isUserAction);\r\n    }\r\n  }\r\n\r\n  return layout;\r\n}\r\n\r\n/**\r\n * This is where the magic needs to happen - given a collision, move an element away from the collision.\r\n * We attempt to move it up if there's room, otherwise it goes below.\r\n *\r\n * @param  {Array} layout            Full layout to modify.\r\n * @param  {LayoutItem} collidesWith Layout item we're colliding with.\r\n * @param  {LayoutItem} itemToMove   Layout item we're moving.\r\n * @param  {Boolean} [isUserAction]  If true, designates that the item we're moving is being dragged/resized\r\n *                                   by the user.\r\n */\r\nexport function moveElementAwayFromCollision(layout: Layout, collidesWith: LayoutItem,\r\n                                             itemToMove: LayoutItem, isUserAction: ?boolean): Layout {\r\n\r\n  // If there is enough space above the collision to put this element, move it there.\r\n  // We only do this on the main collision as this can get funky in cascades and cause\r\n  // unwanted swapping behavior.\r\n  if (isUserAction) {\r\n    // Make a mock item so we don't modify the item here, only modify in moveElement.\r\n    const fakeItem: LayoutItem = {\r\n      x: itemToMove.x,\r\n      y: itemToMove.y,\r\n      w: itemToMove.w,\r\n      h: itemToMove.h,\r\n      i: '-1'\r\n    };\r\n    fakeItem.y = Math.max(collidesWith.y - itemToMove.h, 0);\r\n    if (!getFirstCollision(layout, fakeItem)) {\r\n      return moveElement(layout, itemToMove, undefined, fakeItem.y);\r\n    }\r\n  }\r\n\r\n  // Previously this was optimized to move below the collision directly, but this can cause problems\r\n  // with cascading moves, as an item may actually leapflog a collision and cause a reversal in order.\r\n  return moveElement(layout, itemToMove, undefined, itemToMove.y + 1);\r\n}\r\n\r\n/**\r\n * Helper to convert a number to a percentage string.\r\n *\r\n * @param  {Number} num Any number\r\n * @return {String}     That number as a percentage.\r\n */\r\nexport function perc(num: number): string {\r\n  return num * 100 + '%';\r\n}\r\n\r\nexport function setTransform(top, left, width, height): Object {\r\n  // Replace unitless items with px\r\n  const translate = \"translate3d(\" + left + \"px,\" + top + \"px, 0)\";\r\n  return {\r\n    transform: translate,\r\n    WebkitTransform: translate,\r\n    MozTransform: translate,\r\n    msTransform: translate,\r\n    OTransform: translate,\r\n    width: width + \"px\",\r\n    height: height + \"px\",\r\n    position: 'absolute'\r\n  };\r\n}\r\n/**\r\n * Just like the setTransform method, but instead it will return a negative value of right.\r\n *\r\n * @param top\r\n * @param right\r\n * @param width\r\n * @param height\r\n * @returns {{transform: string, WebkitTransform: string, MozTransform: string, msTransform: string, OTransform: string, width: string, height: string, position: string}}\r\n */\r\nexport function setTransformRtl(top, right, width, height): Object {\r\n    // Replace unitless items with px\r\n    const translate = \"translate3d(\" + right * -1 + \"px,\" + top + \"px, 0)\";\r\n    return {\r\n        transform: translate,\r\n        WebkitTransform: translate,\r\n        MozTransform: translate,\r\n        msTransform: translate,\r\n        OTransform: translate,\r\n        width: width + \"px\",\r\n        height: height + \"px\",\r\n        position: 'absolute'\r\n    };\r\n}\r\n\r\nexport function setTopLeft(top, left, width, height): Object {\r\n    return {\r\n        top: top + \"px\",\r\n        left: left + \"px\",\r\n        width: width + \"px\",\r\n        height: height + \"px\",\r\n        position: 'absolute'\r\n    };\r\n}\r\n/**\r\n * Just like the setTopLeft method, but instead, it will return a right property instead of left.\r\n *\r\n * @param top\r\n * @param right\r\n * @param width\r\n * @param height\r\n * @returns {{top: string, right: string, width: string, height: string, position: string}}\r\n */\r\nexport function setTopRight(top, right, width, height): Object {\r\n    return {\r\n        top: top + \"px\",\r\n        right: right+ \"px\",\r\n        width: width + \"px\",\r\n        height: height + \"px\",\r\n        position: 'absolute'\r\n    };\r\n}\r\n\r\n\r\n/**\r\n * Get layout items sorted from top left to right and down.\r\n *\r\n * @return {Array} Array of layout objects.\r\n * @return {Array}        Layout, sorted static items first.\r\n */\r\nexport function sortLayoutItemsByRowCol(layout: Layout): Layout {\r\n  return [].concat(layout).sort(function(a, b) {\r\n    if (a.y > b.y || (a.y === b.y && a.x > b.x)) {\r\n      return 1;\r\n    }\r\n    return -1;\r\n  });\r\n}\r\n\r\n/**\r\n * Generate a layout using the initialLayout and children as a template.\r\n * Missing entries will be added, extraneous ones will be truncated.\r\n *\r\n * @param  {Array}  initialLayout Layout passed in through props.\r\n * @param  {String} breakpoint    Current responsive breakpoint.\r\n * @param  {Boolean} verticalCompact Whether or not to compact the layout vertically.\r\n * @return {Array}                Working layout.\r\n */\r\n/*\r\nexport function synchronizeLayoutWithChildren(initialLayout: Layout, children: Array<React.Element>|React.Element,\r\n                                              cols: number, verticalCompact: boolean): Layout {\r\n  // ensure 'children' is always an array\r\n  if (!Array.isArray(children)) {\r\n    children = [children];\r\n  }\r\n  initialLayout = initialLayout || [];\r\n\r\n  // Generate one layout item per child.\r\n  let layout: Layout = [];\r\n  for (let i = 0, len = children.length; i < len; i++) {\r\n    let newItem;\r\n    const child = children[i];\r\n\r\n    // Don't overwrite if it already exists.\r\n    const exists = getLayoutItem(initialLayout, child.key || \"1\" /!* FIXME satisfies Flow *!/);\r\n    if (exists) {\r\n      newItem = exists;\r\n    } else {\r\n      const g = child.props._grid;\r\n\r\n      // Hey, this item has a _grid property, use it.\r\n      if (g) {\r\n        if (!isProduction) {\r\n          validateLayout([g], 'ReactGridLayout.children');\r\n        }\r\n        // Validated; add it to the layout. Bottom 'y' possible is the bottom of the layout.\r\n        // This allows you to do nice stuff like specify {y: Infinity}\r\n        if (verticalCompact) {\r\n          newItem = cloneLayoutItem({...g, y: Math.min(bottom(layout), g.y), i: child.key});\r\n        } else {\r\n          newItem = cloneLayoutItem({...g, y: g.y, i: child.key});\r\n        }\r\n      }\r\n      // Nothing provided: ensure this is added to the bottom\r\n      else {\r\n        newItem = cloneLayoutItem({w: 1, h: 1, x: 0, y: bottom(layout), i: child.key || \"1\"});\r\n      }\r\n    }\r\n    layout[i] = newItem;\r\n  }\r\n\r\n  // Correct the layout.\r\n  layout = correctBounds(layout, {cols: cols});\r\n  layout = compact(layout, verticalCompact);\r\n\r\n  return layout;\r\n}\r\n*/\r\n\r\n/**\r\n * Validate a layout. Throws errors.\r\n *\r\n * @param  {Array}  layout        Array of layout items.\r\n * @param  {String} [contextName] Context name for errors.\r\n * @throw  {Error}                Validation error.\r\n */\r\nexport function validateLayout(layout: Layout, contextName: string): void {\r\n  contextName = contextName || \"Layout\";\r\n  const subProps = ['x', 'y', 'w', 'h'];\r\n  if (!Array.isArray(layout)) throw new Error(contextName + \" must be an array!\");\r\n  for (let i = 0, len = layout.length; i < len; i++) {\r\n    const item = layout[i];\r\n    for (let j = 0; j < subProps.length; j++) {\r\n      if (typeof item[subProps[j]] !== 'number') {\r\n        throw new Error('VueGridLayout: ' + contextName + '[' + i + '].' + subProps[j] + ' must be a number!');\r\n      }\r\n    }\r\n    if (item.i && typeof item.i !== 'string') {\r\n      throw new Error('VueGridLayout: ' + contextName + '[' + i + '].i must be a string!');\r\n    }\r\n    if (item.static !== undefined && typeof item.static !== 'boolean') {\r\n      throw new Error('VueGridLayout: ' + contextName + '[' + i + '].static must be a boolean!');\r\n    }\r\n  }\r\n}\r\n\r\n// Flow can't really figure this out, so we just use Object\r\nexport function autoBindHandlers(el: Object, fns: Array<string>): void {\r\n  fns.forEach((key) => el[key] = el[key].bind(el));\r\n}\r\n\r\n\r\n\r\n/**\r\n * Convert a JS object to CSS string. Similar to React's output of CSS.\r\n * @param obj\r\n * @returns {string}\r\n */\r\nexport function createMarkup(obj) {\r\n    var keys = Object.keys(obj);\r\n    if (!keys.length) return '';\r\n    var i, len = keys.length;\r\n    var result = '';\r\n\r\n    for (i = 0; i < len; i++) {\r\n        var key = keys[i];\r\n        var val = obj[key];\r\n        result += hyphenate(key) + ':' + addPx(key, val) + ';';\r\n    }\r\n\r\n    return result;\r\n}\r\n\r\n\r\n/* The following list is defined in React's core */\r\nexport var IS_UNITLESS = {\r\n    animationIterationCount: true,\r\n    boxFlex: true,\r\n    boxFlexGroup: true,\r\n    boxOrdinalGroup: true,\r\n    columnCount: true,\r\n    flex: true,\r\n    flexGrow: true,\r\n    flexPositive: true,\r\n    flexShrink: true,\r\n    flexNegative: true,\r\n    flexOrder: true,\r\n    gridRow: true,\r\n    gridColumn: true,\r\n    fontWeight: true,\r\n    lineClamp: true,\r\n    lineHeight: true,\r\n    opacity: true,\r\n    order: true,\r\n    orphans: true,\r\n    tabSize: true,\r\n    widows: true,\r\n    zIndex: true,\r\n    zoom: true,\r\n\r\n    // SVG-related properties\r\n    fillOpacity: true,\r\n    stopOpacity: true,\r\n    strokeDashoffset: true,\r\n    strokeOpacity: true,\r\n    strokeWidth: true\r\n};\r\n\r\n\r\n/**\r\n * Will add px to the end of style values which are Numbers.\r\n * @param name\r\n * @param value\r\n * @returns {*}\r\n */\r\nexport function addPx(name, value) {\r\n    if(typeof value === 'number' && !IS_UNITLESS[ name ]) {\r\n        return value + 'px';\r\n    } else {\r\n        return value;\r\n    }\r\n}\r\n\r\n\r\n/**\r\n * Hyphenate a camelCase string.\r\n *\r\n * @param {String} str\r\n * @return {String}\r\n */\r\n\r\nexport var hyphenateRE = /([a-z\\d])([A-Z])/g;\r\n\r\nexport function hyphenate(str) {\r\n    return str.replace(hyphenateRE, '$1-$2').toLowerCase();\r\n}\r\n\r\n\r\nexport function findItemInArray(array, property, value) {\r\n    for (var i=0; i < array.length; i++)\r\n        if (array[i][property] == value)\r\n            return true;\r\n\r\n    return false;\r\n}\r\n\r\nexport function findAndRemove(array, property, value) {\r\n    array.forEach(function (result, index) {\r\n        if (result[property] === value) {\r\n            //Remove from array\r\n            array.splice(index, 1);\r\n        }\r\n    });\r\n}\r\n\n\n\n// WEBPACK FOOTER //\n// ./src/utils.js"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///0\n"); /***/ }), /* 1 */ /***/ (function(module, exports, __webpack_require__) { -eval("\n/* styles */\n__webpack_require__(11)\n\nvar Component = __webpack_require__(4)(\n /* script */\n __webpack_require__(14),\n /* template */\n __webpack_require__(17),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\nComponent.options.__file = \"/Users/sunzongzheng/work/vue-grid-layout/src/GridItem.vue\"\nif (Component.esModule && Object.keys(Component.esModule).some(function (key) {return key !== \"default\" && key !== \"__esModule\"})) {console.error(\"named exports are not supported in *.vue files.\")}\nif (Component.options.functional) {console.error(\"[vue-loader] GridItem.vue: functional components are not supported with templates, they should use render functions.\")}\n\n/* hot reload */\nif (false) {(function () {\n var hotAPI = require(\"vue-hot-reload-api\")\n hotAPI.install(require(\"vue\"), false)\n if (!hotAPI.compatible) return\n module.hot.accept()\n if (!module.hot.data) {\n hotAPI.createRecord(\"data-v-f2ef9cd2\", Component.options)\n } else {\n hotAPI.reload(\"data-v-f2ef9cd2\", Component.options)\n }\n})()}\n\nmodule.exports = Component.exports\n\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vLi9zcmMvR3JpZEl0ZW0udnVlP2RlNjMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUNBO0FBQ0Esc0JBQTRLOztBQUU1SztBQUNBO0FBQ0E7QUFDQTtBQUNBLHdCQUFnRztBQUNoRztBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSwrRUFBK0UsaURBQWlELElBQUk7QUFDcEksbUNBQW1DOztBQUVuQztBQUNBLFlBQWlCO0FBQ2pCO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLEdBQUc7QUFDSDtBQUNBO0FBQ0EsQ0FBQzs7QUFFRCIsImZpbGUiOiIxLmpzIiwic291cmNlc0NvbnRlbnQiOlsiXG4vKiBzdHlsZXMgKi9cbnJlcXVpcmUoXCIhIXZ1ZS1zdHlsZS1sb2FkZXIhY3NzLWxvYWRlcj9zb3VyY2VNYXAhLi4vbm9kZV9tb2R1bGVzL3Z1ZS1sb2FkZXIvbGliL3N0eWxlLWNvbXBpbGVyL2luZGV4P3tcXFwiaWRcXFwiOlxcXCJkYXRhLXYtZjJlZjljZDJcXFwiLFxcXCJzY29wZWRcXFwiOmZhbHNlLFxcXCJoYXNJbmxpbmVDb25maWdcXFwiOmZhbHNlfSEuLi9ub2RlX21vZHVsZXMvdnVlLWxvYWRlci9saWIvc2VsZWN0b3I/dHlwZT1zdHlsZXMmaW5kZXg9MCEuL0dyaWRJdGVtLnZ1ZVwiKVxuXG52YXIgQ29tcG9uZW50ID0gcmVxdWlyZShcIiEuLi9ub2RlX21vZHVsZXMvdnVlLWxvYWRlci9saWIvY29tcG9uZW50LW5vcm1hbGl6ZXJcIikoXG4gIC8qIHNjcmlwdCAqL1xuICByZXF1aXJlKFwiISFiYWJlbC1sb2FkZXIhLi4vbm9kZV9tb2R1bGVzL3Z1ZS1sb2FkZXIvbGliL3NlbGVjdG9yP3R5cGU9c2NyaXB0JmluZGV4PTAhLi9HcmlkSXRlbS52dWVcIiksXG4gIC8qIHRlbXBsYXRlICovXG4gIHJlcXVpcmUoXCIhIS4uL25vZGVfbW9kdWxlcy92dWUtbG9hZGVyL2xpYi90ZW1wbGF0ZS1jb21waWxlci9pbmRleD97XFxcImlkXFxcIjpcXFwiZGF0YS12LWYyZWY5Y2QyXFxcIn0hLi4vbm9kZV9tb2R1bGVzL3Z1ZS1sb2FkZXIvbGliL3NlbGVjdG9yP3R5cGU9dGVtcGxhdGUmaW5kZXg9MCEuL0dyaWRJdGVtLnZ1ZVwiKSxcbiAgLyogc2NvcGVJZCAqL1xuICBudWxsLFxuICAvKiBjc3NNb2R1bGVzICovXG4gIG51bGxcbilcbkNvbXBvbmVudC5vcHRpb25zLl9fZmlsZSA9IFwiL1VzZXJzL3N1bnpvbmd6aGVuZy93b3JrL3Z1ZS1ncmlkLWxheW91dC9zcmMvR3JpZEl0ZW0udnVlXCJcbmlmIChDb21wb25lbnQuZXNNb2R1bGUgJiYgT2JqZWN0LmtleXMoQ29tcG9uZW50LmVzTW9kdWxlKS5zb21lKGZ1bmN0aW9uIChrZXkpIHtyZXR1cm4ga2V5ICE9PSBcImRlZmF1bHRcIiAmJiBrZXkgIT09IFwiX19lc01vZHVsZVwifSkpIHtjb25zb2xlLmVycm9yKFwibmFtZWQgZXhwb3J0cyBhcmUgbm90IHN1cHBvcnRlZCBpbiAqLnZ1ZSBmaWxlcy5cIil9XG5pZiAoQ29tcG9uZW50Lm9wdGlvbnMuZnVuY3Rpb25hbCkge2NvbnNvbGUuZXJyb3IoXCJbdnVlLWxvYWRlcl0gR3JpZEl0ZW0udnVlOiBmdW5jdGlvbmFsIGNvbXBvbmVudHMgYXJlIG5vdCBzdXBwb3J0ZWQgd2l0aCB0ZW1wbGF0ZXMsIHRoZXkgc2hvdWxkIHVzZSByZW5kZXIgZnVuY3Rpb25zLlwiKX1cblxuLyogaG90IHJlbG9hZCAqL1xuaWYgKG1vZHVsZS5ob3QpIHsoZnVuY3Rpb24gKCkge1xuICB2YXIgaG90QVBJID0gcmVxdWlyZShcInZ1ZS1ob3QtcmVsb2FkLWFwaVwiKVxuICBob3RBUEkuaW5zdGFsbChyZXF1aXJlKFwidnVlXCIpLCBmYWxzZSlcbiAgaWYgKCFob3RBUEkuY29tcGF0aWJsZSkgcmV0dXJuXG4gIG1vZHVsZS5ob3QuYWNjZXB0KClcbiAgaWYgKCFtb2R1bGUuaG90LmRhdGEpIHtcbiAgICBob3RBUEkuY3JlYXRlUmVjb3JkKFwiZGF0YS12LWYyZWY5Y2QyXCIsIENvbXBvbmVudC5vcHRpb25zKVxuICB9IGVsc2Uge1xuICAgIGhvdEFQSS5yZWxvYWQoXCJkYXRhLXYtZjJlZjljZDJcIiwgQ29tcG9uZW50Lm9wdGlvbnMpXG4gIH1cbn0pKCl9XG5cbm1vZHVsZS5leHBvcnRzID0gQ29tcG9uZW50LmV4cG9ydHNcblxuXG5cbi8vLy8vLy8vLy8vLy8vLy8vL1xuLy8gV0VCUEFDSyBGT09URVJcbi8vIC4vc3JjL0dyaWRJdGVtLnZ1ZVxuLy8gbW9kdWxlIGlkID0gMVxuLy8gbW9kdWxlIGNodW5rcyA9IDAiXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///1\n"); +eval("\n/* styles */\n__webpack_require__(10)\n\nvar Component = __webpack_require__(4)(\n /* script */\n __webpack_require__(13),\n /* template */\n __webpack_require__(16),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\nComponent.options.__file = \"C:\\\\projects\\\\JBAY\\\\vue-grid-layout\\\\src\\\\GridItem.vue\"\nif (Component.esModule && Object.keys(Component.esModule).some(function (key) {return key !== \"default\" && key !== \"__esModule\"})) {console.error(\"named exports are not supported in *.vue files.\")}\nif (Component.options.functional) {console.error(\"[vue-loader] GridItem.vue: functional components are not supported with templates, they should use render functions.\")}\n\n/* hot reload */\nif (false) {(function () {\n var hotAPI = require(\"vue-hot-reload-api\")\n hotAPI.install(require(\"vue\"), false)\n if (!hotAPI.compatible) return\n module.hot.accept()\n if (!module.hot.data) {\n hotAPI.createRecord(\"data-v-f2ef9cd2\", Component.options)\n } else {\n hotAPI.reload(\"data-v-f2ef9cd2\", Component.options)\n }\n})()}\n\nmodule.exports = Component.exports\n\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vLi9zcmMvR3JpZEl0ZW0udnVlP2RlNjMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUNBO0FBQ0Esc0JBQTRLOztBQUU1SztBQUNBO0FBQ0E7QUFDQTtBQUNBLHdCQUFnRztBQUNoRztBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSwrRUFBK0UsaURBQWlELElBQUk7QUFDcEksbUNBQW1DOztBQUVuQztBQUNBLFlBQWlCO0FBQ2pCO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLEdBQUc7QUFDSDtBQUNBO0FBQ0EsQ0FBQzs7QUFFRCIsImZpbGUiOiIxLmpzIiwic291cmNlc0NvbnRlbnQiOlsiXG4vKiBzdHlsZXMgKi9cbnJlcXVpcmUoXCIhIXZ1ZS1zdHlsZS1sb2FkZXIhY3NzLWxvYWRlcj9zb3VyY2VNYXAhLi4vbm9kZV9tb2R1bGVzL3Z1ZS1sb2FkZXIvbGliL3N0eWxlLWNvbXBpbGVyL2luZGV4P3tcXFwiaWRcXFwiOlxcXCJkYXRhLXYtZjJlZjljZDJcXFwiLFxcXCJzY29wZWRcXFwiOmZhbHNlLFxcXCJoYXNJbmxpbmVDb25maWdcXFwiOmZhbHNlfSEuLi9ub2RlX21vZHVsZXMvdnVlLWxvYWRlci9saWIvc2VsZWN0b3I/dHlwZT1zdHlsZXMmaW5kZXg9MCEuL0dyaWRJdGVtLnZ1ZVwiKVxuXG52YXIgQ29tcG9uZW50ID0gcmVxdWlyZShcIiEuLi9ub2RlX21vZHVsZXMvdnVlLWxvYWRlci9saWIvY29tcG9uZW50LW5vcm1hbGl6ZXJcIikoXG4gIC8qIHNjcmlwdCAqL1xuICByZXF1aXJlKFwiISFiYWJlbC1sb2FkZXIhLi4vbm9kZV9tb2R1bGVzL3Z1ZS1sb2FkZXIvbGliL3NlbGVjdG9yP3R5cGU9c2NyaXB0JmluZGV4PTAhLi9HcmlkSXRlbS52dWVcIiksXG4gIC8qIHRlbXBsYXRlICovXG4gIHJlcXVpcmUoXCIhIS4uL25vZGVfbW9kdWxlcy92dWUtbG9hZGVyL2xpYi90ZW1wbGF0ZS1jb21waWxlci9pbmRleD97XFxcImlkXFxcIjpcXFwiZGF0YS12LWYyZWY5Y2QyXFxcIn0hLi4vbm9kZV9tb2R1bGVzL3Z1ZS1sb2FkZXIvbGliL3NlbGVjdG9yP3R5cGU9dGVtcGxhdGUmaW5kZXg9MCEuL0dyaWRJdGVtLnZ1ZVwiKSxcbiAgLyogc2NvcGVJZCAqL1xuICBudWxsLFxuICAvKiBjc3NNb2R1bGVzICovXG4gIG51bGxcbilcbkNvbXBvbmVudC5vcHRpb25zLl9fZmlsZSA9IFwiQzpcXFxccHJvamVjdHNcXFxcSkJBWVxcXFx2dWUtZ3JpZC1sYXlvdXRcXFxcc3JjXFxcXEdyaWRJdGVtLnZ1ZVwiXG5pZiAoQ29tcG9uZW50LmVzTW9kdWxlICYmIE9iamVjdC5rZXlzKENvbXBvbmVudC5lc01vZHVsZSkuc29tZShmdW5jdGlvbiAoa2V5KSB7cmV0dXJuIGtleSAhPT0gXCJkZWZhdWx0XCIgJiYga2V5ICE9PSBcIl9fZXNNb2R1bGVcIn0pKSB7Y29uc29sZS5lcnJvcihcIm5hbWVkIGV4cG9ydHMgYXJlIG5vdCBzdXBwb3J0ZWQgaW4gKi52dWUgZmlsZXMuXCIpfVxuaWYgKENvbXBvbmVudC5vcHRpb25zLmZ1bmN0aW9uYWwpIHtjb25zb2xlLmVycm9yKFwiW3Z1ZS1sb2FkZXJdIEdyaWRJdGVtLnZ1ZTogZnVuY3Rpb25hbCBjb21wb25lbnRzIGFyZSBub3Qgc3VwcG9ydGVkIHdpdGggdGVtcGxhdGVzLCB0aGV5IHNob3VsZCB1c2UgcmVuZGVyIGZ1bmN0aW9ucy5cIil9XG5cbi8qIGhvdCByZWxvYWQgKi9cbmlmIChtb2R1bGUuaG90KSB7KGZ1bmN0aW9uICgpIHtcbiAgdmFyIGhvdEFQSSA9IHJlcXVpcmUoXCJ2dWUtaG90LXJlbG9hZC1hcGlcIilcbiAgaG90QVBJLmluc3RhbGwocmVxdWlyZShcInZ1ZVwiKSwgZmFsc2UpXG4gIGlmICghaG90QVBJLmNvbXBhdGlibGUpIHJldHVyblxuICBtb2R1bGUuaG90LmFjY2VwdCgpXG4gIGlmICghbW9kdWxlLmhvdC5kYXRhKSB7XG4gICAgaG90QVBJLmNyZWF0ZVJlY29yZChcImRhdGEtdi1mMmVmOWNkMlwiLCBDb21wb25lbnQub3B0aW9ucylcbiAgfSBlbHNlIHtcbiAgICBob3RBUEkucmVsb2FkKFwiZGF0YS12LWYyZWY5Y2QyXCIsIENvbXBvbmVudC5vcHRpb25zKVxuICB9XG59KSgpfVxuXG5tb2R1bGUuZXhwb3J0cyA9IENvbXBvbmVudC5leHBvcnRzXG5cblxuXG4vLy8vLy8vLy8vLy8vLy8vLy9cbi8vIFdFQlBBQ0sgRk9PVEVSXG4vLyAuL3NyYy9HcmlkSXRlbS52dWVcbi8vIG1vZHVsZSBpZCA9IDFcbi8vIG1vZHVsZSBjaHVua3MgPSAwIl0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///1\n"); /***/ }), /* 2 */ @@ -96,7 +96,7 @@ eval("/*\r\n\tMIT License http://www.opensource.org/licenses/mit-license.php\r\n /* 3 */ /***/ (function(module, exports, __webpack_require__) { -eval("/*\n MIT License http://www.opensource.org/licenses/mit-license.php\n Author Tobias Koppers @sokra\n Modified by Evan You @yyx990803\n*/\n\nvar hasDocument = typeof document !== 'undefined'\n\nif (typeof DEBUG !== 'undefined' && DEBUG) {\n if (!hasDocument) {\n throw new Error(\n 'vue-style-loader cannot be used in a non-browser environment. ' +\n \"Use { target: 'node' } in your Webpack config to indicate a server-rendering environment.\"\n ) }\n}\n\nvar listToStyles = __webpack_require__(13)\n\n/*\ntype StyleObject = {\n id: number;\n parts: Array\n}\n\ntype StyleObjectPart = {\n css: string;\n media: string;\n sourceMap: ?string\n}\n*/\n\nvar stylesInDom = {/*\n [id: number]: {\n id: number,\n refs: number,\n parts: Array<(obj?: StyleObjectPart) => void>\n }\n*/}\n\nvar head = hasDocument && (document.head || document.getElementsByTagName('head')[0])\nvar singletonElement = null\nvar singletonCounter = 0\nvar isProduction = false\nvar noop = function () {}\n\n// Force single-tag solution on IE6-9, which has a hard limit on the # of \\r\\n\\r\\n\"],\"sourceRoot\":\"webpack://\"}]);\n\n// exports\n\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack:///./src/GridItem.vue?b790"],"names":[],"mappings":"AAAA;AACA;;;AAGA;AACA,2CAA4C,iCAAiC,4CAA4C,gCAAgC,gCAAgC,qCAAqC,cAAc,kBAAkB,GAAG,2CAA2C,iBAAiB,eAAe,GAAG,2BAA2B,mBAAmB,iBAAiB,GAAG,yCAAyC,sBAAsB,iBAAiB,GAAG,uCAAuC,sBAAsB,mBAAmB,iCAAiC,iBAAiB,gCAAgC,6BAA6B,4BAA4B,2BAA2B,wBAAwB,GAAG,0CAA0C,yBAAyB,kBAAkB,mBAAmB,gBAAgB,eAAe,0CAA0C,k1BAAk1B,wCAAwC,2BAA2B,mCAAmC,qCAAqC,6BAA6B,wBAAwB,GAAG,8CAA8C,gBAAgB,cAAc,yCAAyC,67CAA67C,uCAAuC,wBAAwB,mCAAmC,qCAAqC,wBAAwB,kBAAkB,GAAG,UAAU,+EAA+E,KAAK,WAAW,WAAW,WAAW,KAAK,KAAK,WAAW,UAAU,UAAU,KAAK,KAAK,UAAU,UAAU,KAAK,KAAK,UAAU,UAAU,KAAK,KAAK,WAAW,UAAU,KAAK,KAAK,WAAW,UAAU,WAAW,UAAU,WAAW,WAAW,WAAW,WAAW,WAAW,KAAK,KAAK,WAAW,UAAU,UAAU,UAAU,UAAU,YAAY,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,KAAK,KAAK,UAAU,UAAU,YAAY,WAAW,WAAW,WAAW,WAAW,WAAW,UAAU,6IAA6I,4JAA4J,iUAAiU,uCAAuC,kDAAkD,4CAA4C,0CAA0C,2CAA2C,oBAAoB,wBAAwB,SAAS,qDAAqD,uBAAuB,qBAAqB,SAAS,qCAAqC,yBAAyB,uBAAuB,SAAS,mDAAmD,4BAA4B,uBAAuB,SAAS,iDAAiD,4BAA4B,yBAAyB,uCAAuC,uBAAuB,sCAAsC,mCAAmC,kCAAkC,iCAAiC,8BAA8B,SAAS,oDAAoD,+BAA+B,wBAAwB,yBAAyB,sBAAsB,qBAAqB,gDAAgD,k1BAAk1B,8CAA8C,iCAAiC,yCAAyC,2CAA2C,mCAAmC,8BAA8B,SAAS,wDAAwD,sBAAsB,oBAAoB,+CAA+C,67CAA67C,6CAA6C,8BAA8B,yCAAyC,2CAA2C,8BAA8B,wBAAwB,SAAS,wCAAwC,oFAAoF,gBAAgB,gBAAgB,yDAAyD,yBAAyB,mDAAmD,mDAAmD,4BAA4B,mDAAmD,yBAAyB,+EAA+E,sCAAsC,mFAAmF,8BAA8B,+EAA+E,2BAA2B,8EAA8E,4BAA4B,+EAA+E,iCAAiC,wHAAwH,+BAA+B,wHAAwH,sCAAsC,gFAAgF,2BAA2B,iHAAiH,2CAA2C,oHAAoH,wBAAwB,oHAAoH,wBAAwB,2HAA2H,wBAAwB,2HAA2H,qBAAqB,oFAAoF,qBAAqB,oFAAoF,qBAAqB,oFAAoF,qBAAqB,oFAAoF,qBAAqB,mDAAmD,kCAAkC,8HAA8H,iCAAiC,uHAAuH,oCAAoC,8HAA8H,cAAc,mEAAmE,wBAAwB,mlBAAmlB,2RAA2R,aAAa,yBAAyB,gCAAgC,kJAAkJ,4CAA4C,kBAAkB,6DAA6D,yCAAyC,kBAAkB,uEAAuE,oDAAoD,qDAAqD,qBAAqB,kBAAkB,uEAAuE,oDAAoD,qDAAqD,qBAAqB,kBAAkB,qEAAqE,+CAA+C,kBAAkB,kEAAkE,iMAAiM,uDAAuD,mCAAmC,kBAAkB,8EAA8E,kEAAkE,4EAA4E,4EAA4E,4EAA4E,kFAAkF,uEAAuE,oCAAoC,kBAAkB,EAAE,uLAAuL,mDAAmD,aAAa,uCAAuC,gCAAgC,6GAA6G,mEAAmE,6EAA6E,6EAA6E,6EAA6E,mFAAmF,aAAa,mCAAmC,gDAAgD,wDAAwD,6FAA6F,iGAAiG,oDAAoD,gDAAgD,8DAA8D,iBAAiB,OAAO,sDAAsD,iBAAiB,gDAAgD,8DAA8D,iBAAiB,OAAO,sDAAsD,iBAAiB,sEAAsE,mCAAmC,aAAa,qBAAqB,0CAA0C,sDAAsD,iBAAiB,yCAAyC,oCAAoC,sFAAsF,qEAAqE,qBAAqB,yCAAyC,oCAAoC,8IAA8I,yDAAyD,sDAAsD,mCAAmC,EAAE,mDAAmD,qDAAqD,gGAAgG,uDAAuD,6BAA6B,EAAE,yBAAyB,qBAAqB,OAAO,oDAAoD,mEAAmE,EAAE,qBAAqB,iBAAiB,2CAA2C,sDAAsD,iBAAiB,yCAAyC,oCAAoC,sFAAsF,qEAAqE,qBAAqB,yCAAyC,oCAAoC,2FAA2F,mDAAmD,wFAAwF,iFAAiF,mDAAmD,uDAAuD,sIAAsI,6DAA6D,iCAAiC,EAAE,yBAAyB,qBAAqB,OAAO,oDAAoD,mEAAmE,EAAE,qBAAqB,iBAAiB,yCAAyC,uCAAuC,iBAAiB,oCAAoC,uCAAuC,iBAAiB,8CAA8C,uCAAuC,iBAAiB,iCAAiC,uCAAuC,iBAAiB,iCAAiC,uCAAuC,iBAAiB,iCAAiC,uCAAuC,iBAAiB,iCAAiC,uCAAuC,iBAAiB,yCAAyC,uCAAuC,iBAAiB,aAAa,wBAAwB,6BAA6B,4EAA4E,iBAAiB,yCAAyC,yCAAyC,+EAA+E,qBAAqB,OAAO,sDAAsD,qBAAqB,iBAAiB,aAAa,uBAAuB,0CAA0C,sDAAsD,mCAAmC,2CAA2C,qBAAqB,oFAAoF,8CAA8C,oDAAoD,sFAAsF,2DAA2D,yBAAyB,OAAO,0DAA0D,yBAAyB,qBAAqB,0CAA0C,wDAAwD,0DAA0D,qBAAqB,kCAAkC,uGAAuG,sFAAsF,+FAA+F,yBAAyB,OAAO,2FAA2F,yBAAyB,yBAAyB,OAAO,yGAAyG,2FAA2F,yBAAyB,OAAO,yFAAyF,yBAAyB,qBAAqB,uCAAuC,qBAAqB,iDAAiD,+DAA+D,8IAA8I,8DAA8D,KAAK,YAAY,yCAAyC,qBAAqB,yCAAyC,iGAAiG,oDAAoD,wFAAwF,sDAAsD,wDAAwD,oDAAoD,mDAAmD,kCAAkC,+KAA+K,2FAA2F,iDAAiD,uFAAuF,6BAA6B,OAAO,uFAAuF,6BAA6B,qFAAqF,sJAAsJ,oDAAoD,kCAAkC,gLAAgL,wFAAwF,sDAAsD,wDAAwD,4FAA4F,iDAAiD,oDAAoD,kCAAkC,qBAAqB,8GAA8G,4CAA4C,0CAA0C,qBAAqB,4CAA4C,0CAA0C,qBAAqB,4CAA4C,0CAA0C,qBAAqB,4CAA4C,0CAA0C,qBAAqB,wCAAwC,kCAAkC,qBAAqB,oCAAoC,kCAAkC,qBAAqB,uCAAuC,mCAAmC,mEAAmE,qEAAqE,qBAAqB,mHAAmH,qGAAqG,qBAAqB,2GAA2G,iBAAiB,oCAAoC,gDAAgD,mEAAmE,mJAAmJ,8DAA8D,KAAK,YAAY,iDAAiD,yCAAyC,iBAAiB,yCAAyC,+FAA+F,oDAAoD,mGAAmG,kFAAkF,iDAAiD,8FAA8F,6BAA6B,OAAO,qFAAqF,6BAA6B,8EAA8E,wDAAwD,mDAAmD,kCAAkC,kGAAkG,2FAA2F,8EAA8E,8FAA8F,8FAA8F,6BAA6B,OAAO,qFAAqF,6BAA6B,8EAA8E,8FAA8F,wFAAwF,iDAAiD,oDAAoD,gDAAgD,kCAAkC,qIAAqI,8FAA8F,yFAAyF,6BAA6B,OAAO,yFAAyF,6BAA6B,mFAAmF,uGAAuG,+IAA+I,8FAA8F,wDAAwD,kCAAkC,qBAAqB,8EAA8E,iFAAiF,qBAAqB,OAAO,iFAAiF,qBAAqB,uCAAuC,mCAAmC,mEAAmE,mEAAmE,qBAAqB,iHAAiH,oEAAoE,qBAAqB,yGAAyG,iBAAiB,sDAAsD,yDAAyD,+EAA+E,mCAAmC,qRAAqR,gbAAgb,qBAAqB,OAAO,mCAAmC,oRAAoR,gbAAgb,qBAAqB,uCAAuC,iBAAiB,2HAA2H,OAAO,8EAA8E,OAAO,+EAA+E,OAAO,iKAAiK,yDAAyD,qaAAqa,mGAAmG,uGAAuG,wEAAwE,gCAAgC,MAAM,iBAAiB,sFAAsF,0GAA0G,0FAA0F,oCAAoC,iBAAiB,sIAAsI,OAAO,qDAAqD,OAAO,oDAAoD,OAAO,8EAA8E,yDAAyD,8PAA8P,sGAAsG,uGAAuG,wEAAwE,4BAA4B,MAAM,iBAAiB,wDAAwD,gDAAgD,kEAAkE,2CAA2C,qBAAqB,iBAAiB,uCAAuC,uCAAuC,iBAAiB,aAAa,UAAU,8CAA8C;;AAEhvkC","file":"11.js","sourcesContent":["exports = module.exports = require(\"../node_modules/css-loader/lib/css-base.js\")();\n// imports\n\n\n// module\nexports.push([module.id, \"\\n.vue-grid-item {\\n    transition: all 200ms ease;\\n    transition-property: left, top, right;\\n    /* add right for rtl */\\n}\\n.vue-grid-item.cssTransforms {\\n    transition-property: transform;\\n    left: 0;\\n    right: auto;\\n}\\n.vue-grid-item.cssTransforms.render-rtl {\\n    left: auto;\\n    right: 0;\\n}\\n.vue-grid-item.resizing {\\n    opacity: 0.6;\\n    z-index: 3;\\n}\\n.vue-grid-item.vue-draggable-dragging {\\n    transition:none;\\n    z-index: 3;\\n}\\n.vue-grid-item.vue-grid-placeholder {\\n    background: red;\\n    opacity: 0.2;\\n    transition-duration: 100ms;\\n    z-index: 2;\\n    -webkit-user-select: none;\\n    -moz-user-select: none;\\n    -ms-user-select: none;\\n    -o-user-select: none;\\n    user-select: none;\\n}\\n.vue-grid-item > .vue-resizable-handle {\\n    position: absolute;\\n    width: 20px;\\n    height: 20px;\\n    bottom: 0;\\n    right: 0;\\n    background: url('data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBzdGFuZGFsb25lPSJubyI/Pg08IS0tIEdlbmVyYXRvcjogQWRvYmUgRmlyZXdvcmtzIENTNiwgRXhwb3J0IFNWRyBFeHRlbnNpb24gYnkgQWFyb24gQmVhbGwgKGh0dHA6Ly9maXJld29ya3MuYWJlYWxsLmNvbSkgLiBWZXJzaW9uOiAwLjYuMSAgLS0+DTwhRE9DVFlQRSBzdmcgUFVCTElDICItLy9XM0MvL0RURCBTVkcgMS4xLy9FTiIgImh0dHA6Ly93d3cudzMub3JnL0dyYXBoaWNzL1NWRy8xLjEvRFREL3N2ZzExLmR0ZCI+DTxzdmcgaWQ9IlVudGl0bGVkLVBhZ2UlMjAxIiB2aWV3Qm94PSIwIDAgNiA2IiBzdHlsZT0iYmFja2dyb3VuZC1jb2xvcjojZmZmZmZmMDAiIHZlcnNpb249IjEuMSINCXhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIHhtbDpzcGFjZT0icHJlc2VydmUiDQl4PSIwcHgiIHk9IjBweCIgd2lkdGg9IjZweCIgaGVpZ2h0PSI2cHgiDT4NCTxnIG9wYWNpdHk9IjAuMzAyIj4NCQk8cGF0aCBkPSJNIDYgNiBMIDAgNiBMIDAgNC4yIEwgNCA0LjIgTCA0LjIgNC4yIEwgNC4yIDAgTCA2IDAgTCA2IDYgTCA2IDYgWiIgZmlsbD0iIzAwMDAwMCIvPg0JPC9nPg08L3N2Zz4=');\\n    background-position: bottom right;\\n    padding: 0 3px 3px 0;\\n    background-repeat: no-repeat;\\n    background-origin: content-box;\\n    box-sizing: border-box;\\n    cursor: se-resize;\\n}\\n.vue-grid-item > .vue-rtl-resizable-handle {\\n    bottom: 0;\\n    left: 0;\\n    background: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMTAuMDAwMDAwMDAwMDAwMDAyIiBoZWlnaHQ9IjEwLjAwMDAwMDAwMDAwMDAwMiIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KIDwhLS0gQ3JlYXRlZCB3aXRoIE1ldGhvZCBEcmF3IC0gaHR0cDovL2dpdGh1Yi5jb20vZHVvcGl4ZWwvTWV0aG9kLURyYXcvIC0tPgogPGc+CiAgPHRpdGxlPmJhY2tncm91bmQ8L3RpdGxlPgogIDxyZWN0IGZpbGw9Im5vbmUiIGlkPSJjYW52YXNfYmFja2dyb3VuZCIgaGVpZ2h0PSIxMiIgd2lkdGg9IjEyIiB5PSItMSIgeD0iLTEiLz4KICA8ZyBkaXNwbGF5PSJub25lIiBvdmVyZmxvdz0idmlzaWJsZSIgeT0iMCIgeD0iMCIgaGVpZ2h0PSIxMDAlIiB3aWR0aD0iMTAwJSIgaWQ9ImNhbnZhc0dyaWQiPgogICA8cmVjdCBmaWxsPSJ1cmwoI2dyaWRwYXR0ZXJuKSIgc3Ryb2tlLXdpZHRoPSIwIiB5PSIwIiB4PSIwIiBoZWlnaHQ9IjEwMCUiIHdpZHRoPSIxMDAlIi8+CiAgPC9nPgogPC9nPgogPGc+CiAgPHRpdGxlPkxheWVyIDE8L3RpdGxlPgogIDxsaW5lIGNhbnZhcz0iI2ZmZmZmZiIgY2FudmFzLW9wYWNpdHk9IjEiIHN0cm9rZS1saW5lY2FwPSJ1bmRlZmluZWQiIHN0cm9rZS1saW5lam9pbj0idW5kZWZpbmVkIiBpZD0ic3ZnXzEiIHkyPSItNzAuMTc4NDA3IiB4Mj0iMTI0LjQ2NDE3NSIgeTE9Ii0zOC4zOTI3MzciIHgxPSIxNDQuODIxMjg5IiBzdHJva2Utd2lkdGg9IjEuNSIgc3Ryb2tlPSIjMDAwIiBmaWxsPSJub25lIi8+CiAgPGxpbmUgc3Ryb2tlPSIjNjY2NjY2IiBzdHJva2UtbGluZWNhcD0idW5kZWZpbmVkIiBzdHJva2UtbGluZWpvaW49InVuZGVmaW5lZCIgaWQ9InN2Z181IiB5Mj0iOS4xMDY5NTciIHgyPSIwLjk0NzI0NyIgeTE9Ii0wLjAxODEyOCIgeDE9IjAuOTQ3MjQ3IiBzdHJva2Utd2lkdGg9IjIiIGZpbGw9Im5vbmUiLz4KICA8bGluZSBzdHJva2UtbGluZWNhcD0idW5kZWZpbmVkIiBzdHJva2UtbGluZWpvaW49InVuZGVmaW5lZCIgaWQ9InN2Z183IiB5Mj0iOSIgeDI9IjEwLjA3MzUyOSIgeTE9IjkiIHgxPSItMC42NTU2NCIgc3Ryb2tlLXdpZHRoPSIyIiBzdHJva2U9IiM2NjY2NjYiIGZpbGw9Im5vbmUiLz4KIDwvZz4KPC9zdmc+);\\n    background-position: bottom left;\\n    padding-left: 3px;\\n    background-repeat: no-repeat;\\n    background-origin: content-box;\\n    cursor: sw-resize;\\n    right: auto;\\n}\\n\", \"\", {\"version\":3,\"sources\":[\"/./src/GridItem.vue?bc3f11b4\"],\"names\":[],\"mappings\":\";AAYA;IACA,2BAAA;IACA,sCAAA;IACA,uBAAA;CACA;AAEA;IACA,+BAAA;IACA,QAAA;IACA,YAAA;CACA;AAEA;IACA,WAAA;IACA,SAAA;CACA;AAEA;IACA,aAAA;IACA,WAAA;CACA;AAEA;IACA,gBAAA;IACA,WAAA;CACA;AAEA;IACA,gBAAA;IACA,aAAA;IACA,2BAAA;IACA,WAAA;IACA,0BAAA;IACA,uBAAA;IACA,sBAAA;IACA,qBAAA;IACA,kBAAA;CACA;AAEA;IACA,mBAAA;IACA,YAAA;IACA,aAAA;IACA,UAAA;IACA,SAAA;IACA,s3BAAA;IACA,kCAAA;IACA,qBAAA;IACA,6BAAA;IACA,+BAAA;IACA,uBAAA;IACA,kBAAA;CACA;AAEA;IACA,UAAA;IACA,QAAA;IACA,g+CAAA;IACA,iCAAA;IACA,kBAAA;IACA,6BAAA;IACA,+BAAA;IACA,kBAAA;IACA,YAAA;CACA\",\"file\":\"GridItem.vue\",\"sourcesContent\":[\"<template>\\r\\n    <div ref=\\\"item\\\"\\r\\n         class=\\\"vue-grid-item\\\"\\r\\n         :class=\\\"{ 'vue-resizable' : resizable, 'resizing' : isResizing, 'vue-draggable-dragging' : isDragging, 'cssTransforms' : useCssTransforms, 'render-rtl' : renderRtl }\\\"\\r\\n         :style=\\\"style\\\"\\r\\n    >\\r\\n        <slot></slot>\\r\\n        <span v-if=\\\"resizable\\\" ref=\\\"handle\\\" :class=\\\"resizableHandleClass\\\"></span>\\r\\n        <!--<span v-if=\\\"draggable\\\" ref=\\\"dragHandle\\\" class=\\\"vue-draggable-handle\\\"></span>-->\\r\\n    </div>\\r\\n</template>\\r\\n<style>\\r\\n    .vue-grid-item {\\r\\n        transition: all 200ms ease;\\r\\n        transition-property: left, top, right;\\r\\n        /* add right for rtl */\\r\\n    }\\r\\n\\r\\n    .vue-grid-item.cssTransforms {\\r\\n        transition-property: transform;\\r\\n        left: 0;\\r\\n        right: auto;\\r\\n    }\\r\\n\\r\\n    .vue-grid-item.cssTransforms.render-rtl {\\r\\n        left: auto;\\r\\n        right: 0;\\r\\n    }\\r\\n\\r\\n    .vue-grid-item.resizing {\\r\\n        opacity: 0.6;\\r\\n        z-index: 3;\\r\\n    }\\r\\n\\r\\n    .vue-grid-item.vue-draggable-dragging {\\r\\n        transition:none;\\r\\n        z-index: 3;\\r\\n    }\\r\\n\\r\\n    .vue-grid-item.vue-grid-placeholder {\\r\\n        background: red;\\r\\n        opacity: 0.2;\\r\\n        transition-duration: 100ms;\\r\\n        z-index: 2;\\r\\n        -webkit-user-select: none;\\r\\n        -moz-user-select: none;\\r\\n        -ms-user-select: none;\\r\\n        -o-user-select: none;\\r\\n        user-select: none;\\r\\n    }\\r\\n\\r\\n    .vue-grid-item > .vue-resizable-handle {\\r\\n        position: absolute;\\r\\n        width: 20px;\\r\\n        height: 20px;\\r\\n        bottom: 0;\\r\\n        right: 0;\\r\\n        background: url('data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBzdGFuZGFsb25lPSJubyI/Pg08IS0tIEdlbmVyYXRvcjogQWRvYmUgRmlyZXdvcmtzIENTNiwgRXhwb3J0IFNWRyBFeHRlbnNpb24gYnkgQWFyb24gQmVhbGwgKGh0dHA6Ly9maXJld29ya3MuYWJlYWxsLmNvbSkgLiBWZXJzaW9uOiAwLjYuMSAgLS0+DTwhRE9DVFlQRSBzdmcgUFVCTElDICItLy9XM0MvL0RURCBTVkcgMS4xLy9FTiIgImh0dHA6Ly93d3cudzMub3JnL0dyYXBoaWNzL1NWRy8xLjEvRFREL3N2ZzExLmR0ZCI+DTxzdmcgaWQ9IlVudGl0bGVkLVBhZ2UlMjAxIiB2aWV3Qm94PSIwIDAgNiA2IiBzdHlsZT0iYmFja2dyb3VuZC1jb2xvcjojZmZmZmZmMDAiIHZlcnNpb249IjEuMSINCXhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIHhtbDpzcGFjZT0icHJlc2VydmUiDQl4PSIwcHgiIHk9IjBweCIgd2lkdGg9IjZweCIgaGVpZ2h0PSI2cHgiDT4NCTxnIG9wYWNpdHk9IjAuMzAyIj4NCQk8cGF0aCBkPSJNIDYgNiBMIDAgNiBMIDAgNC4yIEwgNCA0LjIgTCA0LjIgNC4yIEwgNC4yIDAgTCA2IDAgTCA2IDYgTCA2IDYgWiIgZmlsbD0iIzAwMDAwMCIvPg0JPC9nPg08L3N2Zz4=');\\r\\n        background-position: bottom right;\\r\\n        padding: 0 3px 3px 0;\\r\\n        background-repeat: no-repeat;\\r\\n        background-origin: content-box;\\r\\n        box-sizing: border-box;\\r\\n        cursor: se-resize;\\r\\n    }\\r\\n\\r\\n    .vue-grid-item > .vue-rtl-resizable-handle {\\r\\n        bottom: 0;\\r\\n        left: 0;\\r\\n        background: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMTAuMDAwMDAwMDAwMDAwMDAyIiBoZWlnaHQ9IjEwLjAwMDAwMDAwMDAwMDAwMiIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KIDwhLS0gQ3JlYXRlZCB3aXRoIE1ldGhvZCBEcmF3IC0gaHR0cDovL2dpdGh1Yi5jb20vZHVvcGl4ZWwvTWV0aG9kLURyYXcvIC0tPgogPGc+CiAgPHRpdGxlPmJhY2tncm91bmQ8L3RpdGxlPgogIDxyZWN0IGZpbGw9Im5vbmUiIGlkPSJjYW52YXNfYmFja2dyb3VuZCIgaGVpZ2h0PSIxMiIgd2lkdGg9IjEyIiB5PSItMSIgeD0iLTEiLz4KICA8ZyBkaXNwbGF5PSJub25lIiBvdmVyZmxvdz0idmlzaWJsZSIgeT0iMCIgeD0iMCIgaGVpZ2h0PSIxMDAlIiB3aWR0aD0iMTAwJSIgaWQ9ImNhbnZhc0dyaWQiPgogICA8cmVjdCBmaWxsPSJ1cmwoI2dyaWRwYXR0ZXJuKSIgc3Ryb2tlLXdpZHRoPSIwIiB5PSIwIiB4PSIwIiBoZWlnaHQ9IjEwMCUiIHdpZHRoPSIxMDAlIi8+CiAgPC9nPgogPC9nPgogPGc+CiAgPHRpdGxlPkxheWVyIDE8L3RpdGxlPgogIDxsaW5lIGNhbnZhcz0iI2ZmZmZmZiIgY2FudmFzLW9wYWNpdHk9IjEiIHN0cm9rZS1saW5lY2FwPSJ1bmRlZmluZWQiIHN0cm9rZS1saW5lam9pbj0idW5kZWZpbmVkIiBpZD0ic3ZnXzEiIHkyPSItNzAuMTc4NDA3IiB4Mj0iMTI0LjQ2NDE3NSIgeTE9Ii0zOC4zOTI3MzciIHgxPSIxNDQuODIxMjg5IiBzdHJva2Utd2lkdGg9IjEuNSIgc3Ryb2tlPSIjMDAwIiBmaWxsPSJub25lIi8+CiAgPGxpbmUgc3Ryb2tlPSIjNjY2NjY2IiBzdHJva2UtbGluZWNhcD0idW5kZWZpbmVkIiBzdHJva2UtbGluZWpvaW49InVuZGVmaW5lZCIgaWQ9InN2Z181IiB5Mj0iOS4xMDY5NTciIHgyPSIwLjk0NzI0NyIgeTE9Ii0wLjAxODEyOCIgeDE9IjAuOTQ3MjQ3IiBzdHJva2Utd2lkdGg9IjIiIGZpbGw9Im5vbmUiLz4KICA8bGluZSBzdHJva2UtbGluZWNhcD0idW5kZWZpbmVkIiBzdHJva2UtbGluZWpvaW49InVuZGVmaW5lZCIgaWQ9InN2Z183IiB5Mj0iOSIgeDI9IjEwLjA3MzUyOSIgeTE9IjkiIHgxPSItMC42NTU2NCIgc3Ryb2tlLXdpZHRoPSIyIiBzdHJva2U9IiM2NjY2NjYiIGZpbGw9Im5vbmUiLz4KIDwvZz4KPC9zdmc+);\\r\\n        background-position: bottom left;\\r\\n        padding-left: 3px;\\r\\n        background-repeat: no-repeat;\\r\\n        background-origin: content-box;\\r\\n        cursor: sw-resize;\\r\\n        right: auto;\\r\\n    }\\r\\n</style>\\r\\n<script>\\r\\n    import {setTopLeft, setTopRight, setTransformRtl, setTransform, createMarkup, getLayoutItem} from './utils';\\r\\n    import {getControlPosition, offsetXYFromParentOf, createCoreData} from './draggableUtils';\\r\\n    //    var eventBus = require('./eventBus');\\r\\n\\r\\n    var interact = require(\\\"interactjs\\\");\\r\\n\\r\\n    export default {\\r\\n        name: \\\"GridItem\\\",\\r\\n        props: {\\r\\n            /*cols: {\\r\\n             type: Number,\\r\\n             required: true\\r\\n             },*/\\r\\n            /*containerWidth: {\\r\\n             type: Number,\\r\\n             required: true\\r\\n\\r\\n             },\\r\\n             rowHeight: {\\r\\n             type: Number,\\r\\n             required: true\\r\\n             },\\r\\n             margin: {\\r\\n             type: Array,\\r\\n             required: true\\r\\n             },\\r\\n             maxRows: {\\r\\n             type: Number,\\r\\n             required: true\\r\\n             },*/\\r\\n            isDraggable: {\\r\\n                type: Boolean,\\r\\n                required: false,\\r\\n                default: null\\r\\n            },\\r\\n            isResizable: {\\r\\n                type: Boolean,\\r\\n                required: false,\\r\\n                default: null\\r\\n            },\\r\\n            /*useCssTransforms: {\\r\\n             type: Boolean,\\r\\n             required: true\\r\\n             },\\r\\n             static: {\\r\\n             type: Boolean,\\r\\n             required: false,\\r\\n             default: false\\r\\n             },\\r\\n             */\\r\\n            minH: {\\r\\n                type: Number,\\r\\n                required: false,\\r\\n                default: 1\\r\\n            },\\r\\n            minW: {\\r\\n                type: Number,\\r\\n                required: false,\\r\\n                default: 1\\r\\n            },\\r\\n            maxH: {\\r\\n                type: Number,\\r\\n                required: false,\\r\\n                default: Infinity\\r\\n            },\\r\\n            maxW: {\\r\\n                type: Number,\\r\\n                required: false,\\r\\n                default: Infinity\\r\\n            },\\r\\n            x: {\\r\\n                type: Number,\\r\\n                required: true\\r\\n            },\\r\\n            y: {\\r\\n                type: Number,\\r\\n                required: true\\r\\n            },\\r\\n            w: {\\r\\n                type: Number,\\r\\n                required: true\\r\\n            },\\r\\n            h: {\\r\\n                type: Number,\\r\\n                required: true\\r\\n            },\\r\\n            i: {\\r\\n                required: true\\r\\n            },\\r\\n            dragIgnoreFrom: {\\r\\n                type: String,\\r\\n                required: false,\\r\\n                default: 'a, button'\\r\\n            },\\r\\n            dragAllowFrom: {\\r\\n                type: String,\\r\\n                required: false,\\r\\n                default: null\\r\\n            },\\r\\n            resizeIgnoreFrom: {\\r\\n                type: String,\\r\\n                required: false,\\r\\n                default: 'a, button'\\r\\n            },\\r\\n        },\\r\\n        inject: [\\\"eventBus\\\"],\\r\\n        data: function () {\\r\\n            return {\\r\\n                cols: 1,\\r\\n                containerWidth: 100,\\r\\n                rowHeight: 30,\\r\\n                margin: [10, 10],\\r\\n                maxRows: Infinity,\\r\\n                draggable: null,\\r\\n                resizable: null,\\r\\n                useCssTransforms: true,\\r\\n\\r\\n                isDragging: false,\\r\\n                dragging: null,\\r\\n                isResizing: false,\\r\\n                resizing: null,\\r\\n                lastX: NaN,\\r\\n                lastY: NaN,\\r\\n                lastW: NaN,\\r\\n                lastH: NaN,\\r\\n                style: {},\\r\\n                rtl: false,\\r\\n\\r\\n                dragEventSet: false,\\r\\n                resizeEventSet: false,\\r\\n\\r\\n                previousW: null,\\r\\n                previousH: null,\\r\\n                previousX: null,\\r\\n                previousY: null,\\r\\n            }\\r\\n        },\\r\\n        created () {\\r\\n            var self = this;\\r\\n\\r\\n            // Accessible refernces of functions for removing in beforeDestroy\\r\\n            self.updateWidthHandler = function (width) {\\r\\n                self.updateWidth(width);\\r\\n            };\\r\\n\\r\\n            self.compactHandler = function (layout) {\\r\\n                self.compact(layout);\\r\\n            };\\r\\n\\r\\n            self.setDraggableHandler = function (isDraggable) {\\r\\n                if (self.isDraggable === null) {\\r\\n                    self.draggable = isDraggable;\\r\\n                }\\r\\n            };\\r\\n\\r\\n            self.setResizableHandler = function (isResizable) {\\r\\n                if (self.isResizable === null) {\\r\\n                    self.resizable = isResizable;\\r\\n                }\\r\\n            };\\r\\n\\r\\n            self.setRowHeightHandler = function (rowHeight) {\\r\\n                self.rowHeight = rowHeight;\\r\\n            };\\r\\n\\r\\n            self.directionchangeHandler = (direction) => {\\r\\n                var direction = (document.dir !== undefined) ?\\r\\n                    document.dir :\\r\\n                    document.getElementsByTagName(\\\"html\\\")[0].getAttribute(\\\"dir\\\");\\r\\n                this.rtl = (direction === \\\"rtl\\\");\\r\\n                this.compact();\\r\\n            };\\r\\n\\r\\n            this.eventBus.$on('updateWidth', self.updateWidthHandler);\\r\\n            this.eventBus.$on('compact', self.compactHandler);\\r\\n            this.eventBus.$on('setDraggable', self.setDraggableHandler);\\r\\n            this.eventBus.$on('setResizable', self.setResizableHandler);\\r\\n            this.eventBus.$on('setRowHeight', self.setRowHeightHandler);\\r\\n            this.eventBus.$on('directionchange', self.directionchangeHandler);\\r\\n\\r\\n            /*this.eventBus.$on('setColNum', function(colNum) {\\r\\n             self.cols = colNum;\\r\\n             });*/\\r\\n            var direction = (document.dir !== undefined) ?\\r\\n                document.dir :\\r\\n                document.getElementsByTagName(\\\"html\\\")[0].getAttribute(\\\"dir\\\");\\r\\n            this.rtl = (direction === \\\"rtl\\\");\\r\\n        },\\r\\n        beforeDestroy: function(){\\r\\n            var self = this;\\r\\n            //Remove listeners\\r\\n            this.eventBus.$off('updateWidth', self.updateWidthHandler);\\r\\n            this.eventBus.$off('compact', self.compactHandler);\\r\\n            this.eventBus.$off('setDraggable', self.setDraggableHandler);\\r\\n            this.eventBus.$off('setResizable', self.setResizableHandler);\\r\\n            this.eventBus.$off('setRowHeight', self.setRowHeightHandler);\\r\\n            this.eventBus.$off('directionchange', self.directionchangeHandler);\\r\\n        },\\r\\n        mounted: function () {\\r\\n            this.cols = this.$parent.colNum;\\r\\n            this.rowHeight = this.$parent.rowHeight;\\r\\n            this.containerWidth = this.$parent.width !== null ? this.$parent.width : 100;\\r\\n            this.margin = this.$parent.margin !== undefined ? this.$parent.margin : [10, 10];\\r\\n            this.maxRows = this.$parent.maxRows;\\r\\n            if (this.isDraggable === null) {\\r\\n                this.draggable = this.$parent.isDraggable;\\r\\n            } else {\\r\\n                this.draggable = this.isDraggable;\\r\\n            }\\r\\n            if (this.isResizable === null) {\\r\\n                this.resizable = this.$parent.isResizable;\\r\\n            } else {\\r\\n                this.resizable = this.isResizable;\\r\\n            }\\r\\n            this.useCssTransforms = this.$parent.useCssTransforms;\\r\\n            this.createStyle();\\r\\n        },\\r\\n        watch: {\\r\\n            isDraggable: function () {\\r\\n                this.draggable = this.isDraggable;\\r\\n            },\\r\\n            draggable: function () {\\r\\n                var self = this;\\r\\n                if (this.interactObj === null || this.interactObj === undefined) {\\r\\n                    this.interactObj = interact(this.$refs.item);\\r\\n                }\\r\\n                if (this.draggable) {\\r\\n                    var opts = {\\r\\n                        ignoreFrom: this.dragIgnoreFrom,\\r\\n                        allowFrom: this.dragAllowFrom\\r\\n                    }\\r\\n                    this.interactObj.draggable(opts);\\r\\n                    /*this.interactObj.draggable({allowFrom: '.vue-draggable-handle'});*/\\r\\n                    if (!this.dragEventSet) {\\r\\n                        this.dragEventSet = true;\\r\\n                        this.interactObj.on('dragstart dragmove dragend', function (event) {\\r\\n                            self.handleDrag(event);\\r\\n                        });\\r\\n                    }\\r\\n                } else {\\r\\n                    this.interactObj.draggable({\\r\\n                        enabled: false\\r\\n                    });\\r\\n                }\\r\\n            },\\r\\n            isResizable: function () {\\r\\n                this.resizable = this.isResizable;\\r\\n            },\\r\\n            resizable: function () {\\r\\n                var self = this;\\r\\n                if (this.interactObj === null || this.interactObj === undefined) {\\r\\n                    this.interactObj = interact(this.$refs.item);\\r\\n                }\\r\\n                if (this.resizable) {\\r\\n                    var opts = {\\r\\n                        preserveAspectRatio: false,\\r\\n                        edges: {left: false, right: true, bottom: true, top: false},\\r\\n                        ignoreFrom: this.resizeIgnoreFrom\\r\\n                    };\\r\\n                    \\r\\n                    this.interactObj.resizable(opts);\\r\\n                    if (!this.resizeEventSet) {\\r\\n                        this.resizeEventSet = true;\\r\\n                        this.interactObj\\r\\n                            .on('resizestart resizemove resizeend', function (event) {\\r\\n                                self.handleResize(event);\\r\\n                            });\\r\\n                    }\\r\\n                } else {\\r\\n                    this.interactObj.resizable({\\r\\n                        enabled: false\\r\\n                    });\\r\\n                }\\r\\n            },\\r\\n            rowHeight: function () {\\r\\n                this.createStyle();\\r\\n            },\\r\\n            cols: function () {\\r\\n                this.createStyle();\\r\\n            },\\r\\n            containerWidth: function () {\\r\\n                this.createStyle();\\r\\n            },\\r\\n            x: function () {\\r\\n                this.createStyle();\\r\\n            },\\r\\n            y: function () {\\r\\n                this.createStyle();\\r\\n            },\\r\\n            h: function () {\\r\\n                this.createStyle();\\r\\n            },\\r\\n            w: function () {\\r\\n                this.createStyle();\\r\\n            },\\r\\n            renderRtl: function () {\\r\\n                this.createStyle();\\r\\n            }\\r\\n        },\\r\\n        computed: {\\r\\n            renderRtl() {\\r\\n                return (this.$parent.isMirrored) ? !this.rtl : this.rtl;\\r\\n            },\\r\\n            resizableHandleClass() {\\r\\n                if (this.renderRtl) {\\r\\n                    return 'vue-resizable-handle vue-rtl-resizable-handle';\\r\\n                } else {\\r\\n                    return 'vue-resizable-handle';\\r\\n                }\\r\\n            }\\r\\n        },\\r\\n        methods: {\\r\\n            createStyle: function () {\\r\\n                if (this.x + this.w > this.cols) {\\r\\n                    this.x = 0;\\r\\n                    this.w = this.cols;\\r\\n                }\\r\\n\\r\\n                var pos = this.calcPosition(this.x, this.y, this.w, this.h);\\r\\n\\r\\n                if (this.isDragging) {\\r\\n                    pos.top = this.dragging.top;\\r\\n//                    Add rtl support\\r\\n                    if (this.renderRtl) {\\r\\n                        pos.right = this.dragging.left;\\r\\n                    } else {\\r\\n                        pos.left = this.dragging.left;\\r\\n                    }\\r\\n                }\\r\\n                if (this.isResizing) {\\r\\n                    pos.width = this.resizing.width;\\r\\n                    pos.height = this.resizing.height;\\r\\n                }\\r\\n\\r\\n                let style;\\r\\n                // CSS Transforms support (default)\\r\\n                if (this.useCssTransforms) {\\r\\n//                    Add rtl support\\r\\n                    if (this.renderRtl) {\\r\\n                        style = setTransformRtl(pos.top, pos.right, pos.width, pos.height);\\r\\n                    } else {\\r\\n                        style = setTransform(pos.top, pos.left, pos.width, pos.height);\\r\\n                    }\\r\\n\\r\\n                } else { // top,left (slow)\\r\\n//                    Add rtl support\\r\\n                    if (this.renderRtl) {\\r\\n                        style = setTopRight(pos.top, pos.right, pos.width, pos.height);\\r\\n                    } else {\\r\\n                        style = setTopLeft(pos.top, pos.left, pos.width, pos.height);\\r\\n                    }\\r\\n                }\\r\\n                this.style = style;\\r\\n\\r\\n            },\\r\\n            handleResize: function (event) {\\r\\n                const position = getControlPosition(event);\\r\\n                // Get the current drag point from the event. This is used as the offset.\\r\\n                if (position == null) return; // not possible but satisfies flow\\r\\n                const {x, y} = position;\\r\\n\\r\\n                const newSize = {width: 0, height: 0};\\r\\n                switch (event.type) {\\r\\n                    case \\\"resizestart\\\":\\r\\n                        this.previousW = this.w;\\r\\n                        this.previousH = this.h;\\r\\n                        var pos = this.calcPosition(this.x, this.y, this.w, this.h);\\r\\n                        newSize.width = pos.width;\\r\\n                        newSize.height = pos.height;\\r\\n                        this.resizing = newSize;\\r\\n                        this.isResizing = true;\\r\\n                        break;\\r\\n                    case \\\"resizemove\\\":\\r\\n//                        console.log(\\\"### resize => \\\" + event.type + \\\", lastW=\\\" + this.lastW + \\\", lastH=\\\" + this.lastH);\\r\\n                        const coreEvent = createCoreData(this.lastW, this.lastH, x, y);\\r\\n                        if (this.renderRtl) {\\r\\n                            newSize.width = this.resizing.width - coreEvent.deltaX;\\r\\n                        } else {\\r\\n                            newSize.width = this.resizing.width + coreEvent.deltaX;\\r\\n                        }\\r\\n                        newSize.height = this.resizing.height + coreEvent.deltaY;\\r\\n\\r\\n                        ///console.log(\\\"### resize => \\\" + event.type + \\\", deltaX=\\\" + coreEvent.deltaX + \\\", deltaY=\\\" + coreEvent.deltaY);\\r\\n                        this.resizing = newSize;\\r\\n                        break;\\r\\n                    case \\\"resizeend\\\":\\r\\n                        //console.log(\\\"### resize end => x=\\\" +this.x + \\\" y=\\\" + this.y + \\\" w=\\\" + this.w + \\\" h=\\\" + this.h);\\r\\n                        var pos = this.calcPosition(this.x, this.y, this.w, this.h);\\r\\n                        newSize.width = pos.width;\\r\\n                        newSize.height = pos.height;\\r\\n//                        console.log(\\\"### resize end => \\\" + JSON.stringify(newSize));\\r\\n                        this.resizing = null;\\r\\n                        this.isResizing = false;\\r\\n                        break;\\r\\n                }\\r\\n\\r\\n                // Get new WH\\r\\n                var pos = this.calcWH(newSize.height, newSize.width);\\r\\n                if (pos.w < this.minW) {\\r\\n                    pos.w = this.minW;\\r\\n                }\\r\\n                if (pos.w > this.maxW) {\\r\\n                    pos.w = this.maxW;\\r\\n                }\\r\\n                if (pos.h < this.minH) {\\r\\n                    pos.h = this.minH;\\r\\n                }\\r\\n                if (pos.h > this.maxH) {\\r\\n                    pos.h = this.maxH;\\r\\n                }\\r\\n\\r\\n                if (pos.h < 1) {\\r\\n                    pos.h = 1;\\r\\n                }\\r\\n                if (pos.w < 1) {\\r\\n                    pos.w = 1;\\r\\n                }\\r\\n\\r\\n                this.lastW = x;\\r\\n                this.lastH = y;\\r\\n\\r\\n                if (this.w !== pos.w || this.h !== pos.h) {\\r\\n                    this.$emit(\\\"resize\\\", this.i, pos.h, pos.w);\\r\\n                }\\r\\n                if (event.type === \\\"resizeend\\\" && (this.previousW !== this.w || this.previousH !== this.h)) {\\r\\n                    this.$emit(\\\"resized\\\", this.i, pos.h, pos.w, newSize.height, newSize.width);\\r\\n                }\\r\\n                this.eventBus.$emit(\\\"resizeEvent\\\", event.type, this.i, this.x, this.y, pos.h, pos.w);\\r\\n            },\\r\\n            handleDrag(event) {\\r\\n                if (this.isResizing) return;\\r\\n\\r\\n                const position = getControlPosition(event);\\r\\n\\r\\n                // Get the current drag point from the event. This is used as the offset.\\r\\n                if (position === null) return; // not possible but satisfies flow\\r\\n                const {x, y} = position;\\r\\n\\r\\n                var shouldUpdate = false;\\r\\n                const newPosition = {top: 0, left: 0};\\r\\n                switch (event.type) {\\r\\n                    case \\\"dragstart\\\":\\r\\n                        this.previousX = this.x;\\r\\n                        this.previousY = this.y;\\r\\n\\r\\n                        var parentRect = event.target.offsetParent.getBoundingClientRect();\\r\\n                        var clientRect = event.target.getBoundingClientRect();\\r\\n                        if (this.renderRtl) {\\r\\n                            newPosition.left = (clientRect.right - parentRect.right) * -1;\\r\\n                        } else {\\r\\n                            newPosition.left = clientRect.left - parentRect.left;\\r\\n                        }\\r\\n                        newPosition.top = clientRect.top - parentRect.top;\\r\\n                        this.dragging = newPosition;\\r\\n                        this.isDragging = true;\\r\\n                        break;\\r\\n                    case \\\"dragend\\\":\\r\\n                        if (!this.isDragging) return;\\r\\n                        parentRect = event.target.offsetParent.getBoundingClientRect();\\r\\n                        clientRect = event.target.getBoundingClientRect();\\r\\n//                        Add rtl support\\r\\n                        if (this.renderRtl) {\\r\\n                            newPosition.left = (clientRect.right - parentRect.right) * -1;\\r\\n                        } else {\\r\\n                            newPosition.left = clientRect.left - parentRect.left;\\r\\n                        }\\r\\n                        newPosition.top = clientRect.top - parentRect.top;\\r\\n//                        console.log(\\\"### drag end => \\\" + JSON.stringify(newPosition));\\r\\n//                        console.log(\\\"### DROP: \\\" + JSON.stringify(newPosition));\\r\\n                        this.dragging = null;\\r\\n                        this.isDragging = false;\\r\\n                        shouldUpdate = true;\\r\\n                        break;\\r\\n                    case \\\"dragmove\\\":\\r\\n                        const coreEvent = createCoreData(this.lastX, this.lastY, x, y);\\r\\n//                        Add rtl support\\r\\n                        if (this.renderRtl) {\\r\\n                            newPosition.left = this.dragging.left - coreEvent.deltaX;\\r\\n                        } else {\\r\\n                            newPosition.left = this.dragging.left + coreEvent.deltaX;\\r\\n                        }\\r\\n                        newPosition.top = this.dragging.top + coreEvent.deltaY;\\r\\n//                        console.log(\\\"### drag => \\\" + event.type + \\\", x=\\\" + x + \\\", y=\\\" + y);\\r\\n//                        console.log(\\\"### drag => \\\" + event.type + \\\", deltaX=\\\" + coreEvent.deltaX + \\\", deltaY=\\\" + coreEvent.deltaY);\\r\\n//                        console.log(\\\"### drag end => \\\" + JSON.stringify(newPosition));\\r\\n                        this.dragging = newPosition;\\r\\n                        break;\\r\\n                }\\r\\n\\r\\n                // Get new XY\\r\\n                if (this.renderRtl) {\\r\\n                    var pos = this.calcXY(newPosition.top, newPosition.left);\\r\\n                } else {\\r\\n                    var pos = this.calcXY(newPosition.top, newPosition.left);\\r\\n                }\\r\\n\\r\\n                this.lastX = x;\\r\\n                this.lastY = y;\\r\\n\\r\\n                if (this.x !== pos.x || this.y !== pos.y) {\\r\\n                    this.$emit(\\\"move\\\", this.i, pos.x, pos.y);\\r\\n                }\\r\\n                if (event.type === \\\"dragend\\\" && (this.previousX !== this.x || this.previousY !== this.y)) {\\r\\n                    this.$emit(\\\"moved\\\", this.i, pos.x, pos.y);\\r\\n                }\\r\\n                this.eventBus.$emit(\\\"dragEvent\\\", event.type, this.i, pos.x, pos.y, this.h, this.w);\\r\\n            },\\r\\n            calcPosition: function (x, y, w, h) {\\r\\n                const colWidth = this.calcColWidth();\\r\\n                // add rtl support\\r\\n                if (this.renderRtl) {\\r\\n                    var out = {\\r\\n                        right: Math.round(colWidth * x + (x + 1) * this.margin[0]),\\r\\n                        top: Math.round(this.rowHeight * y + (y + 1) * this.margin[1]),\\r\\n                        // 0 * Infinity === NaN, which causes problems with resize constriants;\\r\\n                        // Fix this if it occurs.\\r\\n                        // Note we do it here rather than later because Math.round(Infinity) causes deopt\\r\\n                        width: w === Infinity ? w : Math.round(colWidth * w + Math.max(0, w - 1) * this.margin[0]),\\r\\n                        height: h === Infinity ? h : Math.round(this.rowHeight * h + Math.max(0, h - 1) * this.margin[1])\\r\\n                    };\\r\\n                } else {\\r\\n                    var out = {\\r\\n                        left: Math.round(colWidth * x + (x + 1) * this.margin[0]),\\r\\n                        top: Math.round(this.rowHeight * y + (y + 1) * this.margin[1]),\\r\\n                        // 0 * Infinity === NaN, which causes problems with resize constriants;\\r\\n                        // Fix this if it occurs.\\r\\n                        // Note we do it here rather than later because Math.round(Infinity) causes deopt\\r\\n                        width: w === Infinity ? w : Math.round(colWidth * w + Math.max(0, w - 1) * this.margin[0]),\\r\\n                        height: h === Infinity ? h : Math.round(this.rowHeight * h + Math.max(0, h - 1) * this.margin[1])\\r\\n                    };\\r\\n                }\\r\\n\\r\\n\\r\\n                return out;\\r\\n            },\\r\\n            /**\\r\\n             * Translate x and y coordinates from pixels to grid units.\\r\\n             * @param  {Number} top  Top position (relative to parent) in pixels.\\r\\n             * @param  {Number} left Left position (relative to parent) in pixels.\\r\\n             * @return {Object} x and y in grid units.\\r\\n             */\\r\\n            // TODO check if this function needs change in order to support rtl.\\r\\n            calcXY(top, left) {\\r\\n                const colWidth = this.calcColWidth();\\r\\n\\r\\n                // left = colWidth * x + margin * (x + 1)\\r\\n                // l = cx + m(x+1)\\r\\n                // l = cx + mx + m\\r\\n                // l - m = cx + mx\\r\\n                // l - m = x(c + m)\\r\\n                // (l - m) / (c + m) = x\\r\\n                // x = (left - margin) / (coldWidth + margin)\\r\\n                let x = Math.round((left - this.margin[0]) / (colWidth + this.margin[0]));\\r\\n                let y = Math.round((top - this.margin[1]) / (this.rowHeight + this.margin[1]));\\r\\n\\r\\n                // Capping\\r\\n                x = Math.max(Math.min(x, this.cols - this.w), 0);\\r\\n                y = Math.max(Math.min(y, this.maxRows - this.h), 0);\\r\\n\\r\\n                return {x, y};\\r\\n            },\\r\\n            // Helper for generating column width\\r\\n            calcColWidth() {\\r\\n                var colWidth = (this.containerWidth - (this.margin[0] * (this.cols + 1))) / this.cols;\\r\\n//                console.log(\\\"### COLS=\\\" + this.cols + \\\" COL WIDTH=\\\" + colWidth);\\r\\n                return colWidth;\\r\\n            },\\r\\n\\r\\n            /**\\r\\n             * Given a height and width in pixel values, calculate grid units.\\r\\n             * @param  {Number} height Height in pixels.\\r\\n             * @param  {Number} width  Width in pixels.\\r\\n             * @return {Object} w, h as grid units.\\r\\n             */\\r\\n            calcWH(height, width) {\\r\\n                const colWidth = this.calcColWidth();\\r\\n\\r\\n                // width = colWidth * w - (margin * (w - 1))\\r\\n                // ...\\r\\n                // w = (width + margin) / (colWidth + margin)\\r\\n                let w = Math.round((width + this.margin[0]) / (colWidth + this.margin[0]));\\r\\n                let h = Math.round((height + this.margin[1]) / (this.rowHeight + this.margin[1]));\\r\\n\\r\\n                // Capping\\r\\n                w = Math.max(Math.min(w, this.cols - this.x), 0);\\r\\n                h = Math.max(Math.min(h, this.maxRows - this.y), 0);\\r\\n                return {w, h};\\r\\n            },\\r\\n            updateWidth: function (width, colNum) {\\r\\n                this.containerWidth = width;\\r\\n                if (colNum !== undefined && colNum !== null) {\\r\\n                    this.cols = colNum;\\r\\n                }\\r\\n            },\\r\\n            compact: function () {\\r\\n                this.createStyle();\\r\\n            }\\r\\n        },\\r\\n    }\\r\\n</script>\\r\\n\"],\"sourceRoot\":\"webpack://\"}]);\n\n// exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/css-loader?sourceMap!./node_modules/vue-loader/lib/style-compiler?{\"id\":\"data-v-f2ef9cd2\",\"scoped\":false,\"hasInlineConfig\":false}!./node_modules/vue-loader/lib/selector.js?type=styles&index=0!./src/GridItem.vue\n// module id = 11\n// module chunks = 0"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///11\n"); /***/ }), /* 12 */ -/***/ (function(module, exports, __webpack_require__) { +/***/ (function(module, exports) { -eval("exports = module.exports = __webpack_require__(2)();\n// imports\n\n\n// module\nexports.push([module.i, \"\\n.vue-grid-item {\\n transition: all 200ms ease;\\n transition-property: left, top, right;\\n /* add right for rtl */\\n}\\n.vue-grid-item.cssTransforms {\\n transition-property: transform;\\n left: 0;\\n right: auto;\\n}\\n.vue-grid-item.cssTransforms.render-rtl {\\n left: auto;\\n right: 0;\\n}\\n.vue-grid-item.resizing {\\n opacity: 0.6;\\n z-index: 3;\\n}\\n.vue-grid-item.vue-draggable-dragging {\\n transition:none;\\n z-index: 3;\\n}\\n.vue-grid-item.vue-grid-placeholder {\\n background: red;\\n opacity: 0.2;\\n transition-duration: 100ms;\\n z-index: 2;\\n -webkit-user-select: none;\\n -moz-user-select: none;\\n -ms-user-select: none;\\n -o-user-select: none;\\n user-select: none;\\n}\\n.vue-grid-item > .vue-resizable-handle {\\n position: absolute;\\n width: 20px;\\n height: 20px;\\n bottom: 0;\\n right: 0;\\n background: url('data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBzdGFuZGFsb25lPSJubyI/Pg08IS0tIEdlbmVyYXRvcjogQWRvYmUgRmlyZXdvcmtzIENTNiwgRXhwb3J0IFNWRyBFeHRlbnNpb24gYnkgQWFyb24gQmVhbGwgKGh0dHA6Ly9maXJld29ya3MuYWJlYWxsLmNvbSkgLiBWZXJzaW9uOiAwLjYuMSAgLS0+DTwhRE9DVFlQRSBzdmcgUFVCTElDICItLy9XM0MvL0RURCBTVkcgMS4xLy9FTiIgImh0dHA6Ly93d3cudzMub3JnL0dyYXBoaWNzL1NWRy8xLjEvRFREL3N2ZzExLmR0ZCI+DTxzdmcgaWQ9IlVudGl0bGVkLVBhZ2UlMjAxIiB2aWV3Qm94PSIwIDAgNiA2IiBzdHlsZT0iYmFja2dyb3VuZC1jb2xvcjojZmZmZmZmMDAiIHZlcnNpb249IjEuMSINCXhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIHhtbDpzcGFjZT0icHJlc2VydmUiDQl4PSIwcHgiIHk9IjBweCIgd2lkdGg9IjZweCIgaGVpZ2h0PSI2cHgiDT4NCTxnIG9wYWNpdHk9IjAuMzAyIj4NCQk8cGF0aCBkPSJNIDYgNiBMIDAgNiBMIDAgNC4yIEwgNCA0LjIgTCA0LjIgNC4yIEwgNC4yIDAgTCA2IDAgTCA2IDYgTCA2IDYgWiIgZmlsbD0iIzAwMDAwMCIvPg0JPC9nPg08L3N2Zz4=');\\n background-position: bottom right;\\n padding: 0 3px 3px 0;\\n background-repeat: no-repeat;\\n background-origin: content-box;\\n box-sizing: border-box;\\n cursor: se-resize;\\n}\\n.vue-grid-item > .vue-rtl-resizable-handle {\\n bottom: 0;\\n left: 0;\\n background: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMTAuMDAwMDAwMDAwMDAwMDAyIiBoZWlnaHQ9IjEwLjAwMDAwMDAwMDAwMDAwMiIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KIDwhLS0gQ3JlYXRlZCB3aXRoIE1ldGhvZCBEcmF3IC0gaHR0cDovL2dpdGh1Yi5jb20vZHVvcGl4ZWwvTWV0aG9kLURyYXcvIC0tPgogPGc+CiAgPHRpdGxlPmJhY2tncm91bmQ8L3RpdGxlPgogIDxyZWN0IGZpbGw9Im5vbmUiIGlkPSJjYW52YXNfYmFja2dyb3VuZCIgaGVpZ2h0PSIxMiIgd2lkdGg9IjEyIiB5PSItMSIgeD0iLTEiLz4KICA8ZyBkaXNwbGF5PSJub25lIiBvdmVyZmxvdz0idmlzaWJsZSIgeT0iMCIgeD0iMCIgaGVpZ2h0PSIxMDAlIiB3aWR0aD0iMTAwJSIgaWQ9ImNhbnZhc0dyaWQiPgogICA8cmVjdCBmaWxsPSJ1cmwoI2dyaWRwYXR0ZXJuKSIgc3Ryb2tlLXdpZHRoPSIwIiB5PSIwIiB4PSIwIiBoZWlnaHQ9IjEwMCUiIHdpZHRoPSIxMDAlIi8+CiAgPC9nPgogPC9nPgogPGc+CiAgPHRpdGxlPkxheWVyIDE8L3RpdGxlPgogIDxsaW5lIGNhbnZhcz0iI2ZmZmZmZiIgY2FudmFzLW9wYWNpdHk9IjEiIHN0cm9rZS1saW5lY2FwPSJ1bmRlZmluZWQiIHN0cm9rZS1saW5lam9pbj0idW5kZWZpbmVkIiBpZD0ic3ZnXzEiIHkyPSItNzAuMTc4NDA3IiB4Mj0iMTI0LjQ2NDE3NSIgeTE9Ii0zOC4zOTI3MzciIHgxPSIxNDQuODIxMjg5IiBzdHJva2Utd2lkdGg9IjEuNSIgc3Ryb2tlPSIjMDAwIiBmaWxsPSJub25lIi8+CiAgPGxpbmUgc3Ryb2tlPSIjNjY2NjY2IiBzdHJva2UtbGluZWNhcD0idW5kZWZpbmVkIiBzdHJva2UtbGluZWpvaW49InVuZGVmaW5lZCIgaWQ9InN2Z181IiB5Mj0iOS4xMDY5NTciIHgyPSIwLjk0NzI0NyIgeTE9Ii0wLjAxODEyOCIgeDE9IjAuOTQ3MjQ3IiBzdHJva2Utd2lkdGg9IjIiIGZpbGw9Im5vbmUiLz4KICA8bGluZSBzdHJva2UtbGluZWNhcD0idW5kZWZpbmVkIiBzdHJva2UtbGluZWpvaW49InVuZGVmaW5lZCIgaWQ9InN2Z183IiB5Mj0iOSIgeDI9IjEwLjA3MzUyOSIgeTE9IjkiIHgxPSItMC42NTU2NCIgc3Ryb2tlLXdpZHRoPSIyIiBzdHJva2U9IiM2NjY2NjYiIGZpbGw9Im5vbmUiLz4KIDwvZz4KPC9zdmc+);\\n background-position: bottom left;\\n padding-left: 3px;\\n background-repeat: no-repeat;\\n background-origin: content-box;\\n cursor: sw-resize;\\n right: auto;\\n}\\n\", \"\", {\"version\":3,\"sources\":[\"/./src/GridItem.vue?37fa2adb\"],\"names\":[],\"mappings\":\";AAYA;IACA,2BAAA;IACA,sCAAA;IACA,uBAAA;CACA;AAEA;IACA,+BAAA;IACA,QAAA;IACA,YAAA;CACA;AAEA;IACA,WAAA;IACA,SAAA;CACA;AAEA;IACA,aAAA;IACA,WAAA;CACA;AAEA;IACA,gBAAA;IACA,WAAA;CACA;AAEA;IACA,gBAAA;IACA,aAAA;IACA,2BAAA;IACA,WAAA;IACA,0BAAA;IACA,uBAAA;IACA,sBAAA;IACA,qBAAA;IACA,kBAAA;CACA;AAEA;IACA,mBAAA;IACA,YAAA;IACA,aAAA;IACA,UAAA;IACA,SAAA;IACA,s3BAAA;IACA,kCAAA;IACA,qBAAA;IACA,6BAAA;IACA,+BAAA;IACA,uBAAA;IACA,kBAAA;CACA;AAEA;IACA,UAAA;IACA,QAAA;IACA,g+CAAA;IACA,iCAAA;IACA,kBAAA;IACA,6BAAA;IACA,+BAAA;IACA,kBAAA;IACA,YAAA;CACA\",\"file\":\"GridItem.vue\",\"sourcesContent\":[\"\\n\\n\\n\"],\"sourceRoot\":\"webpack://\"}]);\n\n// exports\n\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack:///./src/GridItem.vue?b790"],"names":[],"mappings":"AAAA;AACA;;;AAGA;AACA,2CAA4C,iCAAiC,4CAA4C,gCAAgC,gCAAgC,qCAAqC,cAAc,kBAAkB,GAAG,2CAA2C,iBAAiB,eAAe,GAAG,2BAA2B,mBAAmB,iBAAiB,GAAG,yCAAyC,sBAAsB,iBAAiB,GAAG,uCAAuC,sBAAsB,mBAAmB,iCAAiC,iBAAiB,gCAAgC,6BAA6B,4BAA4B,2BAA2B,wBAAwB,GAAG,0CAA0C,yBAAyB,kBAAkB,mBAAmB,gBAAgB,eAAe,0CAA0C,k1BAAk1B,wCAAwC,2BAA2B,mCAAmC,qCAAqC,6BAA6B,wBAAwB,GAAG,8CAA8C,gBAAgB,cAAc,yCAAyC,67CAA67C,uCAAuC,wBAAwB,mCAAmC,qCAAqC,wBAAwB,kBAAkB,GAAG,UAAU,+EAA+E,KAAK,WAAW,WAAW,WAAW,KAAK,KAAK,WAAW,UAAU,UAAU,KAAK,KAAK,UAAU,UAAU,KAAK,KAAK,UAAU,UAAU,KAAK,KAAK,WAAW,UAAU,KAAK,KAAK,WAAW,UAAU,WAAW,UAAU,WAAW,WAAW,WAAW,WAAW,WAAW,KAAK,KAAK,WAAW,UAAU,UAAU,UAAU,UAAU,YAAY,WAAW,WAAW,WAAW,WAAW,WAAW,WAAW,KAAK,KAAK,UAAU,UAAU,YAAY,WAAW,WAAW,WAAW,WAAW,WAAW,UAAU,uIAAuI,4JAA4J,+SAA+S,qCAAqC,gDAAgD,wCAAwC,sCAAsC,yCAAyC,kBAAkB,sBAAsB,OAAO,iDAAiD,qBAAqB,mBAAmB,OAAO,iCAAiC,uBAAuB,qBAAqB,OAAO,+CAA+C,0BAA0B,qBAAqB,OAAO,6CAA6C,0BAA0B,uBAAuB,qCAAqC,qBAAqB,oCAAoC,iCAAiC,gCAAgC,+BAA+B,4BAA4B,OAAO,gDAAgD,6BAA6B,sBAAsB,uBAAuB,oBAAoB,mBAAmB,8CAA8C,k1BAAk1B,4CAA4C,+BAA+B,uCAAuC,yCAAyC,iCAAiC,4BAA4B,OAAO,oDAAoD,oBAAoB,kBAAkB,6CAA6C,67CAA67C,2CAA2C,4BAA4B,uCAAuC,yCAAyC,4BAA4B,sBAAsB,OAAO,kCAAkC,oFAAoF,gBAAgB,cAAc,yDAAyD,yBAAyB,iDAAiD,+CAA+C,wBAAwB,+CAA+C,uBAAuB,yEAAyE,oCAAoC,2EAA2E,4BAA4B,yEAAyE,yBAAyB,wEAAwE,0BAA0B,yEAAyE,+BAA+B,gHAAgH,6BAA6B,gHAAgH,oCAAoC,0EAA0E,yBAAyB,yGAAyG,uCAAuC,4GAA4G,sBAAsB,4GAA4G,sBAAsB,mHAAmH,sBAAsB,mHAAmH,mBAAmB,8EAA8E,mBAAmB,8EAA8E,mBAAmB,8EAA8E,mBAAmB,8EAA8E,mBAAmB,+CAA+C,gCAAgC,sHAAsH,+BAA+B,+GAA+G,kCAAkC,sHAAsH,YAAY,+DAA+D,sBAAsB,+iBAA+iB,uQAAuQ,WAAW,uBAAuB,8BAA8B,4IAA4I,0CAA0C,gBAAgB,yDAAyD,uCAAuC,gBAAgB,mEAAmE,kDAAkD,mDAAmD,mBAAmB,gBAAgB,mEAAmE,kDAAkD,mDAAmD,mBAAmB,gBAAgB,iEAAiE,6CAA6C,gBAAgB,8DAA8D,2LAA2L,qDAAqD,iCAAiC,gBAAgB,0EAA0E,gEAAgE,0EAA0E,0EAA0E,0EAA0E,gFAAgF,mEAAmE,kCAAkC,gBAAgB,EAAE,iLAAiL,iDAAiD,WAAW,qCAAqC,8BAA8B,yGAAyG,iEAAiE,2EAA2E,2EAA2E,2EAA2E,iFAAiF,WAAW,iCAAiC,8CAA8C,sDAAsD,2FAA2F,+FAA+F,kDAAkD,8CAA8C,4DAA4D,eAAe,OAAO,oDAAoD,eAAe,8CAA8C,4DAA4D,eAAe,OAAO,oDAAoD,eAAe,oEAAoE,iCAAiC,WAAW,mBAAmB,wCAAwC,oDAAoD,eAAe,uCAAuC,kCAAkC,oFAAoF,mEAAmE,mBAAmB,uCAAuC,kCAAkC,wIAAwI,uDAAuD,oDAAoD,mCAAmC,EAAE,iDAAiD,mDAAmD,8FAA8F,qDAAqD,2BAA2B,EAAE,uBAAuB,mBAAmB,OAAO,kDAAkD,+DAA+D,EAAE,mBAAmB,eAAe,yCAAyC,oDAAoD,eAAe,uCAAuC,kCAAkC,oFAAoF,mEAAmE,mBAAmB,uCAAuC,kCAAkC,uFAAuF,mDAAmD,oFAAoF,6EAA6E,iDAAiD,qDAAqD,kIAAkI,2DAA2D,+BAA+B,EAAE,uBAAuB,mBAAmB,OAAO,kDAAkD,+DAA+D,EAAE,mBAAmB,eAAe,uCAAuC,qCAAqC,eAAe,kCAAkC,qCAAqC,eAAe,4CAA4C,qCAAqC,eAAe,+BAA+B,qCAAqC,eAAe,+BAA+B,qCAAqC,eAAe,+BAA+B,qCAAqC,eAAe,+BAA+B,qCAAqC,eAAe,uCAAuC,qCAAqC,eAAe,WAAW,sBAAsB,2BAA2B,0EAA0E,eAAe,uCAAuC,uCAAuC,6EAA6E,mBAAmB,OAAO,oDAAoD,mBAAmB,eAAe,WAAW,qBAAqB,wCAAwC,oDAAoD,iCAAiC,yCAAyC,mBAAmB,gFAAgF,0CAA0C,kDAAkD,kFAAkF,yDAAyD,uBAAuB,OAAO,wDAAwD,uBAAuB,mBAAmB,wCAAwC,sDAAsD,wDAAwD,mBAAmB,8BAA8B,mGAAmG,kFAAkF,6FAA6F,uBAAuB,OAAO,yFAAyF,uBAAuB,qBAAqB,OAAO,qGAAqG,yFAAyF,uBAAuB,OAAO,uFAAuF,uBAAuB,mBAAmB,qCAAqC,iBAAiB,+CAA+C,6DAA6D,0IAA0I,4DAA4D,KAAK,YAAY,qCAAqC,qBAAqB,uCAAuC,6FAA6F,kDAAkD,sFAAsF,oDAAoD,sDAAsD,kDAAkD,iDAAiD,gCAAgC,2KAA2K,yFAAyF,+CAA+C,qFAAqF,2BAA2B,OAAO,qFAAqF,2BAA2B,mFAAmF,kJAAkJ,kDAAkD,gCAAgC,4KAA4K,sFAAsF,oDAAoD,sDAAsD,0FAA0F,+CAA+C,kDAAkD,gCAAgC,mBAAmB,wGAAwG,0CAA0C,wCAAwC,mBAAmB,0CAA0C,wCAAwC,mBAAmB,0CAA0C,wCAAwC,mBAAmB,0CAA0C,wCAAwC,mBAAmB,oCAAoC,gCAAgC,mBAAmB,kCAAkC,gCAAgC,mBAAmB,mCAAmC,iCAAiC,+DAA+D,mEAAmE,mBAAmB,iHAAiH,mGAAmG,mBAAmB,yGAAyG,eAAe,kCAAkC,8CAA8C,+DAA+D,6IAA6I,4DAA4D,KAAK,YAAY,6CAA6C,uCAAuC,iBAAiB,uCAAuC,2FAA2F,kDAAkD,+FAA+F,gFAAgF,+CAA+C,4FAA4F,2BAA2B,OAAO,mFAAmF,2BAA2B,4EAA4E,sDAAsD,iDAAiD,gCAAgC,8FAA8F,yFAAyF,4EAA4E,0FAA0F,4FAA4F,2BAA2B,OAAO,mFAAmF,2BAA2B,4EAA4E,4FAA4F,sFAAsF,+CAA+C,kDAAkD,8CAA8C,gCAAgC,iIAAiI,0FAA0F,uFAAuF,2BAA2B,OAAO,uFAAuF,2BAA2B,iFAAiF,qGAAqG,6IAA6I,4FAA4F,sDAAsD,gCAAgC,mBAAmB,wEAAwE,+EAA+E,mBAAmB,OAAO,+EAA+E,mBAAmB,mCAAmC,iCAAiC,+DAA+D,iEAAiE,mBAAmB,+GAA+G,kEAAkE,mBAAmB,uGAAuG,eAAe,oDAAoD,uDAAuD,2EAA2E,iCAAiC,+QAA+Q,saAAsa,mBAAmB,OAAO,iCAAiC,8QAA8Q,saAAsa,mBAAmB,iCAAiC,eAAe,qHAAqH,OAAO,4EAA4E,OAAO,6EAA6E,OAAO,2JAA2J,uDAAuD,mZAAmZ,iGAAiG,iGAAiG,sEAAsE,4BAA4B,MAAM,eAAe,kFAAkF,wGAAwG,wFAAwF,kCAAkC,eAAe,8HAA8H,OAAO,mDAAmD,OAAO,kDAAkD,OAAO,0EAA0E,uDAAuD,oPAAoP,oGAAoG,iGAAiG,sEAAsE,0BAA0B,MAAM,eAAe,sDAAsD,8CAA8C,gEAAgE,yCAAyC,mBAAmB,eAAe,qCAAqC,qCAAqC,eAAe,WAAW,QAAQ,0CAA0C;;AAEl6hC","file":"12.js","sourcesContent":["exports = module.exports = require(\"../node_modules/css-loader/lib/css-base.js\")();\n// imports\n\n\n// module\nexports.push([module.id, \"\\n.vue-grid-item {\\n    transition: all 200ms ease;\\n    transition-property: left, top, right;\\n    /* add right for rtl */\\n}\\n.vue-grid-item.cssTransforms {\\n    transition-property: transform;\\n    left: 0;\\n    right: auto;\\n}\\n.vue-grid-item.cssTransforms.render-rtl {\\n    left: auto;\\n    right: 0;\\n}\\n.vue-grid-item.resizing {\\n    opacity: 0.6;\\n    z-index: 3;\\n}\\n.vue-grid-item.vue-draggable-dragging {\\n    transition:none;\\n    z-index: 3;\\n}\\n.vue-grid-item.vue-grid-placeholder {\\n    background: red;\\n    opacity: 0.2;\\n    transition-duration: 100ms;\\n    z-index: 2;\\n    -webkit-user-select: none;\\n    -moz-user-select: none;\\n    -ms-user-select: none;\\n    -o-user-select: none;\\n    user-select: none;\\n}\\n.vue-grid-item > .vue-resizable-handle {\\n    position: absolute;\\n    width: 20px;\\n    height: 20px;\\n    bottom: 0;\\n    right: 0;\\n    background: url('data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBzdGFuZGFsb25lPSJubyI/Pg08IS0tIEdlbmVyYXRvcjogQWRvYmUgRmlyZXdvcmtzIENTNiwgRXhwb3J0IFNWRyBFeHRlbnNpb24gYnkgQWFyb24gQmVhbGwgKGh0dHA6Ly9maXJld29ya3MuYWJlYWxsLmNvbSkgLiBWZXJzaW9uOiAwLjYuMSAgLS0+DTwhRE9DVFlQRSBzdmcgUFVCTElDICItLy9XM0MvL0RURCBTVkcgMS4xLy9FTiIgImh0dHA6Ly93d3cudzMub3JnL0dyYXBoaWNzL1NWRy8xLjEvRFREL3N2ZzExLmR0ZCI+DTxzdmcgaWQ9IlVudGl0bGVkLVBhZ2UlMjAxIiB2aWV3Qm94PSIwIDAgNiA2IiBzdHlsZT0iYmFja2dyb3VuZC1jb2xvcjojZmZmZmZmMDAiIHZlcnNpb249IjEuMSINCXhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIHhtbDpzcGFjZT0icHJlc2VydmUiDQl4PSIwcHgiIHk9IjBweCIgd2lkdGg9IjZweCIgaGVpZ2h0PSI2cHgiDT4NCTxnIG9wYWNpdHk9IjAuMzAyIj4NCQk8cGF0aCBkPSJNIDYgNiBMIDAgNiBMIDAgNC4yIEwgNCA0LjIgTCA0LjIgNC4yIEwgNC4yIDAgTCA2IDAgTCA2IDYgTCA2IDYgWiIgZmlsbD0iIzAwMDAwMCIvPg0JPC9nPg08L3N2Zz4=');\\n    background-position: bottom right;\\n    padding: 0 3px 3px 0;\\n    background-repeat: no-repeat;\\n    background-origin: content-box;\\n    box-sizing: border-box;\\n    cursor: se-resize;\\n}\\n.vue-grid-item > .vue-rtl-resizable-handle {\\n    bottom: 0;\\n    left: 0;\\n    background: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMTAuMDAwMDAwMDAwMDAwMDAyIiBoZWlnaHQ9IjEwLjAwMDAwMDAwMDAwMDAwMiIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KIDwhLS0gQ3JlYXRlZCB3aXRoIE1ldGhvZCBEcmF3IC0gaHR0cDovL2dpdGh1Yi5jb20vZHVvcGl4ZWwvTWV0aG9kLURyYXcvIC0tPgogPGc+CiAgPHRpdGxlPmJhY2tncm91bmQ8L3RpdGxlPgogIDxyZWN0IGZpbGw9Im5vbmUiIGlkPSJjYW52YXNfYmFja2dyb3VuZCIgaGVpZ2h0PSIxMiIgd2lkdGg9IjEyIiB5PSItMSIgeD0iLTEiLz4KICA8ZyBkaXNwbGF5PSJub25lIiBvdmVyZmxvdz0idmlzaWJsZSIgeT0iMCIgeD0iMCIgaGVpZ2h0PSIxMDAlIiB3aWR0aD0iMTAwJSIgaWQ9ImNhbnZhc0dyaWQiPgogICA8cmVjdCBmaWxsPSJ1cmwoI2dyaWRwYXR0ZXJuKSIgc3Ryb2tlLXdpZHRoPSIwIiB5PSIwIiB4PSIwIiBoZWlnaHQ9IjEwMCUiIHdpZHRoPSIxMDAlIi8+CiAgPC9nPgogPC9nPgogPGc+CiAgPHRpdGxlPkxheWVyIDE8L3RpdGxlPgogIDxsaW5lIGNhbnZhcz0iI2ZmZmZmZiIgY2FudmFzLW9wYWNpdHk9IjEiIHN0cm9rZS1saW5lY2FwPSJ1bmRlZmluZWQiIHN0cm9rZS1saW5lam9pbj0idW5kZWZpbmVkIiBpZD0ic3ZnXzEiIHkyPSItNzAuMTc4NDA3IiB4Mj0iMTI0LjQ2NDE3NSIgeTE9Ii0zOC4zOTI3MzciIHgxPSIxNDQuODIxMjg5IiBzdHJva2Utd2lkdGg9IjEuNSIgc3Ryb2tlPSIjMDAwIiBmaWxsPSJub25lIi8+CiAgPGxpbmUgc3Ryb2tlPSIjNjY2NjY2IiBzdHJva2UtbGluZWNhcD0idW5kZWZpbmVkIiBzdHJva2UtbGluZWpvaW49InVuZGVmaW5lZCIgaWQ9InN2Z181IiB5Mj0iOS4xMDY5NTciIHgyPSIwLjk0NzI0NyIgeTE9Ii0wLjAxODEyOCIgeDE9IjAuOTQ3MjQ3IiBzdHJva2Utd2lkdGg9IjIiIGZpbGw9Im5vbmUiLz4KICA8bGluZSBzdHJva2UtbGluZWNhcD0idW5kZWZpbmVkIiBzdHJva2UtbGluZWpvaW49InVuZGVmaW5lZCIgaWQ9InN2Z183IiB5Mj0iOSIgeDI9IjEwLjA3MzUyOSIgeTE9IjkiIHgxPSItMC42NTU2NCIgc3Ryb2tlLXdpZHRoPSIyIiBzdHJva2U9IiM2NjY2NjYiIGZpbGw9Im5vbmUiLz4KIDwvZz4KPC9zdmc+);\\n    background-position: bottom left;\\n    padding-left: 3px;\\n    background-repeat: no-repeat;\\n    background-origin: content-box;\\n    cursor: sw-resize;\\n    right: auto;\\n}\\n\", \"\", {\"version\":3,\"sources\":[\"/./src/GridItem.vue?37fa2adb\"],\"names\":[],\"mappings\":\";AAYA;IACA,2BAAA;IACA,sCAAA;IACA,uBAAA;CACA;AAEA;IACA,+BAAA;IACA,QAAA;IACA,YAAA;CACA;AAEA;IACA,WAAA;IACA,SAAA;CACA;AAEA;IACA,aAAA;IACA,WAAA;CACA;AAEA;IACA,gBAAA;IACA,WAAA;CACA;AAEA;IACA,gBAAA;IACA,aAAA;IACA,2BAAA;IACA,WAAA;IACA,0BAAA;IACA,uBAAA;IACA,sBAAA;IACA,qBAAA;IACA,kBAAA;CACA;AAEA;IACA,mBAAA;IACA,YAAA;IACA,aAAA;IACA,UAAA;IACA,SAAA;IACA,s3BAAA;IACA,kCAAA;IACA,qBAAA;IACA,6BAAA;IACA,+BAAA;IACA,uBAAA;IACA,kBAAA;CACA;AAEA;IACA,UAAA;IACA,QAAA;IACA,g+CAAA;IACA,iCAAA;IACA,kBAAA;IACA,6BAAA;IACA,+BAAA;IACA,kBAAA;IACA,YAAA;CACA\",\"file\":\"GridItem.vue\",\"sourcesContent\":[\"<template>\\n    <div ref=\\\"item\\\"\\n         class=\\\"vue-grid-item\\\"\\n         :class=\\\"{ 'vue-resizable' : resizable, 'resizing' : isResizing, 'vue-draggable-dragging' : isDragging, 'cssTransforms' : useCssTransforms, 'render-rtl' : renderRtl }\\\"\\n         :style=\\\"style\\\"\\n    >\\n        <slot></slot>\\n        <span v-if=\\\"resizable\\\" ref=\\\"handle\\\" :class=\\\"resizableHandleClass\\\"></span>\\n        <!--<span v-if=\\\"draggable\\\" ref=\\\"dragHandle\\\" class=\\\"vue-draggable-handle\\\"></span>-->\\n    </div>\\n</template>\\n<style>\\n    .vue-grid-item {\\n        transition: all 200ms ease;\\n        transition-property: left, top, right;\\n        /* add right for rtl */\\n    }\\n\\n    .vue-grid-item.cssTransforms {\\n        transition-property: transform;\\n        left: 0;\\n        right: auto;\\n    }\\n\\n    .vue-grid-item.cssTransforms.render-rtl {\\n        left: auto;\\n        right: 0;\\n    }\\n\\n    .vue-grid-item.resizing {\\n        opacity: 0.6;\\n        z-index: 3;\\n    }\\n\\n    .vue-grid-item.vue-draggable-dragging {\\n        transition:none;\\n        z-index: 3;\\n    }\\n\\n    .vue-grid-item.vue-grid-placeholder {\\n        background: red;\\n        opacity: 0.2;\\n        transition-duration: 100ms;\\n        z-index: 2;\\n        -webkit-user-select: none;\\n        -moz-user-select: none;\\n        -ms-user-select: none;\\n        -o-user-select: none;\\n        user-select: none;\\n    }\\n\\n    .vue-grid-item > .vue-resizable-handle {\\n        position: absolute;\\n        width: 20px;\\n        height: 20px;\\n        bottom: 0;\\n        right: 0;\\n        background: url('data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBzdGFuZGFsb25lPSJubyI/Pg08IS0tIEdlbmVyYXRvcjogQWRvYmUgRmlyZXdvcmtzIENTNiwgRXhwb3J0IFNWRyBFeHRlbnNpb24gYnkgQWFyb24gQmVhbGwgKGh0dHA6Ly9maXJld29ya3MuYWJlYWxsLmNvbSkgLiBWZXJzaW9uOiAwLjYuMSAgLS0+DTwhRE9DVFlQRSBzdmcgUFVCTElDICItLy9XM0MvL0RURCBTVkcgMS4xLy9FTiIgImh0dHA6Ly93d3cudzMub3JnL0dyYXBoaWNzL1NWRy8xLjEvRFREL3N2ZzExLmR0ZCI+DTxzdmcgaWQ9IlVudGl0bGVkLVBhZ2UlMjAxIiB2aWV3Qm94PSIwIDAgNiA2IiBzdHlsZT0iYmFja2dyb3VuZC1jb2xvcjojZmZmZmZmMDAiIHZlcnNpb249IjEuMSINCXhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIHhtbDpzcGFjZT0icHJlc2VydmUiDQl4PSIwcHgiIHk9IjBweCIgd2lkdGg9IjZweCIgaGVpZ2h0PSI2cHgiDT4NCTxnIG9wYWNpdHk9IjAuMzAyIj4NCQk8cGF0aCBkPSJNIDYgNiBMIDAgNiBMIDAgNC4yIEwgNCA0LjIgTCA0LjIgNC4yIEwgNC4yIDAgTCA2IDAgTCA2IDYgTCA2IDYgWiIgZmlsbD0iIzAwMDAwMCIvPg0JPC9nPg08L3N2Zz4=');\\n        background-position: bottom right;\\n        padding: 0 3px 3px 0;\\n        background-repeat: no-repeat;\\n        background-origin: content-box;\\n        box-sizing: border-box;\\n        cursor: se-resize;\\n    }\\n\\n    .vue-grid-item > .vue-rtl-resizable-handle {\\n        bottom: 0;\\n        left: 0;\\n        background: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMTAuMDAwMDAwMDAwMDAwMDAyIiBoZWlnaHQ9IjEwLjAwMDAwMDAwMDAwMDAwMiIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KIDwhLS0gQ3JlYXRlZCB3aXRoIE1ldGhvZCBEcmF3IC0gaHR0cDovL2dpdGh1Yi5jb20vZHVvcGl4ZWwvTWV0aG9kLURyYXcvIC0tPgogPGc+CiAgPHRpdGxlPmJhY2tncm91bmQ8L3RpdGxlPgogIDxyZWN0IGZpbGw9Im5vbmUiIGlkPSJjYW52YXNfYmFja2dyb3VuZCIgaGVpZ2h0PSIxMiIgd2lkdGg9IjEyIiB5PSItMSIgeD0iLTEiLz4KICA8ZyBkaXNwbGF5PSJub25lIiBvdmVyZmxvdz0idmlzaWJsZSIgeT0iMCIgeD0iMCIgaGVpZ2h0PSIxMDAlIiB3aWR0aD0iMTAwJSIgaWQ9ImNhbnZhc0dyaWQiPgogICA8cmVjdCBmaWxsPSJ1cmwoI2dyaWRwYXR0ZXJuKSIgc3Ryb2tlLXdpZHRoPSIwIiB5PSIwIiB4PSIwIiBoZWlnaHQ9IjEwMCUiIHdpZHRoPSIxMDAlIi8+CiAgPC9nPgogPC9nPgogPGc+CiAgPHRpdGxlPkxheWVyIDE8L3RpdGxlPgogIDxsaW5lIGNhbnZhcz0iI2ZmZmZmZiIgY2FudmFzLW9wYWNpdHk9IjEiIHN0cm9rZS1saW5lY2FwPSJ1bmRlZmluZWQiIHN0cm9rZS1saW5lam9pbj0idW5kZWZpbmVkIiBpZD0ic3ZnXzEiIHkyPSItNzAuMTc4NDA3IiB4Mj0iMTI0LjQ2NDE3NSIgeTE9Ii0zOC4zOTI3MzciIHgxPSIxNDQuODIxMjg5IiBzdHJva2Utd2lkdGg9IjEuNSIgc3Ryb2tlPSIjMDAwIiBmaWxsPSJub25lIi8+CiAgPGxpbmUgc3Ryb2tlPSIjNjY2NjY2IiBzdHJva2UtbGluZWNhcD0idW5kZWZpbmVkIiBzdHJva2UtbGluZWpvaW49InVuZGVmaW5lZCIgaWQ9InN2Z181IiB5Mj0iOS4xMDY5NTciIHgyPSIwLjk0NzI0NyIgeTE9Ii0wLjAxODEyOCIgeDE9IjAuOTQ3MjQ3IiBzdHJva2Utd2lkdGg9IjIiIGZpbGw9Im5vbmUiLz4KICA8bGluZSBzdHJva2UtbGluZWNhcD0idW5kZWZpbmVkIiBzdHJva2UtbGluZWpvaW49InVuZGVmaW5lZCIgaWQ9InN2Z183IiB5Mj0iOSIgeDI9IjEwLjA3MzUyOSIgeTE9IjkiIHgxPSItMC42NTU2NCIgc3Ryb2tlLXdpZHRoPSIyIiBzdHJva2U9IiM2NjY2NjYiIGZpbGw9Im5vbmUiLz4KIDwvZz4KPC9zdmc+);\\n        background-position: bottom left;\\n        padding-left: 3px;\\n        background-repeat: no-repeat;\\n        background-origin: content-box;\\n        cursor: sw-resize;\\n        right: auto;\\n    }\\n</style>\\n<script>\\n    import {setTopLeft, setTopRight, setTransformRtl, setTransform, createMarkup, getLayoutItem} from './utils';\\n    import {getControlPosition, offsetXYFromParentOf, createCoreData} from './draggableUtils';\\n    //    var eventBus = require('./eventBus');\\n\\n    var interact = require(\\\"interactjs\\\");\\n\\n    export default {\\n        name: \\\"GridItem\\\",\\n        props: {\\n            /*cols: {\\n             type: Number,\\n             required: true\\n             },*/\\n            /*containerWidth: {\\n             type: Number,\\n             required: true\\n\\n             },\\n             rowHeight: {\\n             type: Number,\\n             required: true\\n             },\\n             margin: {\\n             type: Array,\\n             required: true\\n             },\\n             maxRows: {\\n             type: Number,\\n             required: true\\n             },*/\\n            isDraggable: {\\n                type: Boolean,\\n                required: false,\\n                default: null\\n            },\\n            isResizable: {\\n                type: Boolean,\\n                required: false,\\n                default: null\\n            },\\n            /*useCssTransforms: {\\n             type: Boolean,\\n             required: true\\n             },\\n             static: {\\n             type: Boolean,\\n             required: false,\\n             default: false\\n             },\\n             */\\n            minH: {\\n                type: Number,\\n                required: false,\\n                default: 1\\n            },\\n            minW: {\\n                type: Number,\\n                required: false,\\n                default: 1\\n            },\\n            maxH: {\\n                type: Number,\\n                required: false,\\n                default: Infinity\\n            },\\n            maxW: {\\n                type: Number,\\n                required: false,\\n                default: Infinity\\n            },\\n            x: {\\n                type: Number,\\n                required: true\\n            },\\n            y: {\\n                type: Number,\\n                required: true\\n            },\\n            w: {\\n                type: Number,\\n                required: true\\n            },\\n            h: {\\n                type: Number,\\n                required: true\\n            },\\n            i: {\\n                required: true\\n            },\\n            dragIgnoreFrom: {\\n                type: String,\\n                required: false,\\n                default: 'a, button'\\n            },\\n            dragAllowFrom: {\\n                type: String,\\n                required: false,\\n                default: null\\n            },\\n            resizeIgnoreFrom: {\\n                type: String,\\n                required: false,\\n                default: 'a, button'\\n            },\\n        },\\n        inject: [\\\"eventBus\\\"],\\n        data: function () {\\n            return {\\n                cols: 1,\\n                containerWidth: 100,\\n                rowHeight: 30,\\n                margin: [10, 10],\\n                maxRows: Infinity,\\n                draggable: null,\\n                resizable: null,\\n                useCssTransforms: true,\\n\\n                isDragging: false,\\n                dragging: null,\\n                isResizing: false,\\n                resizing: null,\\n                lastX: NaN,\\n                lastY: NaN,\\n                lastW: NaN,\\n                lastH: NaN,\\n                style: {},\\n                rtl: false,\\n\\n                dragEventSet: false,\\n                resizeEventSet: false,\\n\\n                previousW: null,\\n                previousH: null,\\n                previousX: null,\\n                previousY: null,\\n            }\\n        },\\n        created () {\\n            var self = this;\\n\\n            // Accessible refernces of functions for removing in beforeDestroy\\n            self.updateWidthHandler = function (width) {\\n                self.updateWidth(width);\\n            };\\n\\n            self.compactHandler = function (layout) {\\n                self.compact(layout);\\n            };\\n\\n            self.setDraggableHandler = function (isDraggable) {\\n                if (self.isDraggable === null) {\\n                    self.draggable = isDraggable;\\n                }\\n            };\\n\\n            self.setResizableHandler = function (isResizable) {\\n                if (self.isResizable === null) {\\n                    self.resizable = isResizable;\\n                }\\n            };\\n\\n            self.setRowHeightHandler = function (rowHeight) {\\n                self.rowHeight = rowHeight;\\n            };\\n\\n            self.directionchangeHandler = (direction) => {\\n                var direction = (document.dir !== undefined) ?\\n                    document.dir :\\n                    document.getElementsByTagName(\\\"html\\\")[0].getAttribute(\\\"dir\\\");\\n                this.rtl = (direction === \\\"rtl\\\");\\n                this.compact();\\n            };\\n\\n            this.eventBus.$on('updateWidth', self.updateWidthHandler);\\n            this.eventBus.$on('compact', self.compactHandler);\\n            this.eventBus.$on('setDraggable', self.setDraggableHandler);\\n            this.eventBus.$on('setResizable', self.setResizableHandler);\\n            this.eventBus.$on('setRowHeight', self.setRowHeightHandler);\\n            this.eventBus.$on('directionchange', self.directionchangeHandler);\\n\\n            /*this.eventBus.$on('setColNum', function(colNum) {\\n             self.cols = colNum;\\n             });*/\\n            var direction = (document.dir !== undefined) ?\\n                document.dir :\\n                document.getElementsByTagName(\\\"html\\\")[0].getAttribute(\\\"dir\\\");\\n            this.rtl = (direction === \\\"rtl\\\");\\n        },\\n        beforeDestroy: function(){\\n            var self = this;\\n            //Remove listeners\\n            this.eventBus.$off('updateWidth', self.updateWidthHandler);\\n            this.eventBus.$off('compact', self.compactHandler);\\n            this.eventBus.$off('setDraggable', self.setDraggableHandler);\\n            this.eventBus.$off('setResizable', self.setResizableHandler);\\n            this.eventBus.$off('setRowHeight', self.setRowHeightHandler);\\n            this.eventBus.$off('directionchange', self.directionchangeHandler);\\n        },\\n        mounted: function () {\\n            this.cols = this.$parent.colNum;\\n            this.rowHeight = this.$parent.rowHeight;\\n            this.containerWidth = this.$parent.width !== null ? this.$parent.width : 100;\\n            this.margin = this.$parent.margin !== undefined ? this.$parent.margin : [10, 10];\\n            this.maxRows = this.$parent.maxRows;\\n            if (this.isDraggable === null) {\\n                this.draggable = this.$parent.isDraggable;\\n            } else {\\n                this.draggable = this.isDraggable;\\n            }\\n            if (this.isResizable === null) {\\n                this.resizable = this.$parent.isResizable;\\n            } else {\\n                this.resizable = this.isResizable;\\n            }\\n            this.useCssTransforms = this.$parent.useCssTransforms;\\n            this.createStyle();\\n        },\\n        watch: {\\n            isDraggable: function () {\\n                this.draggable = this.isDraggable;\\n            },\\n            draggable: function () {\\n                var self = this;\\n                if (this.interactObj === null || this.interactObj === undefined) {\\n                    this.interactObj = interact(this.$refs.item);\\n                }\\n                if (this.draggable) {\\n                    var opts = {\\n                        ignoreFrom: this.dragIgnoreFrom,\\n                        allowFrom: this.dragAllowFrom\\n                    }\\n                    this.interactObj.draggable(opts);\\n                    /*this.interactObj.draggable({allowFrom: '.vue-draggable-handle'});*/\\n                    if (!this.dragEventSet) {\\n                        this.dragEventSet = true;\\n                        this.interactObj.on('dragstart dragmove dragend', function (event) {\\n                            self.handleDrag(event);\\n                        });\\n                    }\\n                } else {\\n                    this.interactObj.draggable({\\n                        enabled: false\\n                    });\\n                }\\n            },\\n            isResizable: function () {\\n                this.resizable = this.isResizable;\\n            },\\n            resizable: function () {\\n                var self = this;\\n                if (this.interactObj === null || this.interactObj === undefined) {\\n                    this.interactObj = interact(this.$refs.item);\\n                }\\n                if (this.resizable) {\\n                    var opts = {\\n                        preserveAspectRatio: false,\\n                        edges: {left: false, right: true, bottom: true, top: false},\\n                        ignoreFrom: this.resizeIgnoreFrom\\n                    };\\n                    \\n                    this.interactObj.resizable(opts);\\n                    if (!this.resizeEventSet) {\\n                        this.resizeEventSet = true;\\n                        this.interactObj\\n                            .on('resizestart resizemove resizeend', function (event) {\\n                                self.handleResize(event);\\n                            });\\n                    }\\n                } else {\\n                    this.interactObj.resizable({\\n                        enabled: false\\n                    });\\n                }\\n            },\\n            rowHeight: function () {\\n                this.createStyle();\\n            },\\n            cols: function () {\\n                this.createStyle();\\n            },\\n            containerWidth: function () {\\n                this.createStyle();\\n            },\\n            x: function () {\\n                this.createStyle();\\n            },\\n            y: function () {\\n                this.createStyle();\\n            },\\n            h: function () {\\n                this.createStyle();\\n            },\\n            w: function () {\\n                this.createStyle();\\n            },\\n            renderRtl: function () {\\n                this.createStyle();\\n            }\\n        },\\n        computed: {\\n            renderRtl() {\\n                return (this.$parent.isMirrored) ? !this.rtl : this.rtl;\\n            },\\n            resizableHandleClass() {\\n                if (this.renderRtl) {\\n                    return 'vue-resizable-handle vue-rtl-resizable-handle';\\n                } else {\\n                    return 'vue-resizable-handle';\\n                }\\n            }\\n        },\\n        methods: {\\n            createStyle: function () {\\n                if (this.x + this.w > this.cols) {\\n                    this.x = 0;\\n                    this.w = this.cols;\\n                }\\n\\n                var pos = this.calcPosition(this.x, this.y, this.w, this.h);\\n\\n                if (this.isDragging) {\\n                    pos.top = this.dragging.top;\\n//                    Add rtl support\\n                    if (this.renderRtl) {\\n                        pos.right = this.dragging.left;\\n                    } else {\\n                        pos.left = this.dragging.left;\\n                    }\\n                }\\n                if (this.isResizing) {\\n                    pos.width = this.resizing.width;\\n                    pos.height = this.resizing.height;\\n                }\\n\\n                let style;\\n                // CSS Transforms support (default)\\n                if (this.useCssTransforms) {\\n//                    Add rtl support\\n                    if (this.renderRtl) {\\n                        style = setTransformRtl(pos.top, pos.right, pos.width, pos.height);\\n                    } else {\\n                        style = setTransform(pos.top, pos.left, pos.width, pos.height);\\n                    }\\n\\n                } else { // top,left (slow)\\n//                    Add rtl support\\n                    if (this.renderRtl) {\\n                        style = setTopRight(pos.top, pos.right, pos.width, pos.height);\\n                    } else {\\n                        style = setTopLeft(pos.top, pos.left, pos.width, pos.height);\\n                    }\\n                }\\n                this.style = style;\\n\\n            },\\n            handleResize: function (event) {\\n                const position = getControlPosition(event);\\n                // Get the current drag point from the event. This is used as the offset.\\n                if (position == null) return; // not possible but satisfies flow\\n                const {x, y} = position;\\n\\n                const newSize = {width: 0, height: 0};\\n                switch (event.type) {\\n                    case \\\"resizestart\\\":\\n                        this.previousW = this.w;\\n                        this.previousH = this.h;\\n                        var pos = this.calcPosition(this.x, this.y, this.w, this.h);\\n                        newSize.width = pos.width;\\n                        newSize.height = pos.height;\\n                        this.resizing = newSize;\\n                        this.isResizing = true;\\n                        break;\\n                    case \\\"resizemove\\\":\\n//                        console.log(\\\"### resize => \\\" + event.type + \\\", lastW=\\\" + this.lastW + \\\", lastH=\\\" + this.lastH);\\n                        const coreEvent = createCoreData(this.lastW, this.lastH, x, y);\\n                        if (this.renderRtl) {\\n                            newSize.width = this.resizing.width - coreEvent.deltaX;\\n                        } else {\\n                            newSize.width = this.resizing.width + coreEvent.deltaX;\\n                        }\\n                        newSize.height = this.resizing.height + coreEvent.deltaY;\\n\\n                        ///console.log(\\\"### resize => \\\" + event.type + \\\", deltaX=\\\" + coreEvent.deltaX + \\\", deltaY=\\\" + coreEvent.deltaY);\\n                        this.resizing = newSize;\\n                        break;\\n                    case \\\"resizeend\\\":\\n                        //console.log(\\\"### resize end => x=\\\" +this.x + \\\" y=\\\" + this.y + \\\" w=\\\" + this.w + \\\" h=\\\" + this.h);\\n                        var pos = this.calcPosition(this.x, this.y, this.w, this.h);\\n                        newSize.width = pos.width;\\n                        newSize.height = pos.height;\\n//                        console.log(\\\"### resize end => \\\" + JSON.stringify(newSize));\\n                        this.resizing = null;\\n                        this.isResizing = false;\\n                        break;\\n                }\\n\\n                // Get new WH\\n                var pos = this.calcWH(newSize.height, newSize.width);\\n                if (pos.w < this.minW) {\\n                    pos.w = this.minW;\\n                }\\n                if (pos.w > this.maxW) {\\n                    pos.w = this.maxW;\\n                }\\n                if (pos.h < this.minH) {\\n                    pos.h = this.minH;\\n                }\\n                if (pos.h > this.maxH) {\\n                    pos.h = this.maxH;\\n                }\\n\\n                if (pos.h < 1) {\\n                    pos.h = 1;\\n                }\\n                if (pos.w < 1) {\\n                    pos.w = 1;\\n                }\\n\\n                this.lastW = x;\\n                this.lastH = y;\\n\\n                if (this.w !== pos.w || this.h !== pos.h) {\\n                    this.$emit(\\\"resize\\\", this.i, pos.h, pos.w);\\n                }\\n                if (event.type === \\\"resizeend\\\" && (this.previousW !== this.w || this.previousH !== this.h)) {\\n                    this.$emit(\\\"resized\\\", this.i, pos.h, pos.w, newSize.height, newSize.width);\\n                }\\n                this.eventBus.$emit(\\\"resizeEvent\\\", event.type, this.i, this.x, this.y, pos.h, pos.w);\\n            },\\n            handleDrag(event) {\\n                if (this.isResizing) return;\\n\\n                const position = getControlPosition(event);\\n\\n                // Get the current drag point from the event. This is used as the offset.\\n                if (position === null) return; // not possible but satisfies flow\\n                const {x, y} = position;\\n\\n                var shouldUpdate = false;\\n                const newPosition = {top: 0, left: 0};\\n                switch (event.type) {\\n                    case \\\"dragstart\\\":\\n                        this.previousX = this.x;\\n                        this.previousY = this.y;\\n\\n                        var parentRect = event.target.offsetParent.getBoundingClientRect();\\n                        var clientRect = event.target.getBoundingClientRect();\\n                        if (this.renderRtl) {\\n                            newPosition.left = (clientRect.right - parentRect.right) * -1;\\n                        } else {\\n                            newPosition.left = clientRect.left - parentRect.left;\\n                        }\\n                        newPosition.top = clientRect.top - parentRect.top;\\n                        this.dragging = newPosition;\\n                        this.isDragging = true;\\n                        break;\\n                    case \\\"dragend\\\":\\n                        if (!this.isDragging) return;\\n                        parentRect = event.target.offsetParent.getBoundingClientRect();\\n                        clientRect = event.target.getBoundingClientRect();\\n//                        Add rtl support\\n                        if (this.renderRtl) {\\n                            newPosition.left = (clientRect.right - parentRect.right) * -1;\\n                        } else {\\n                            newPosition.left = clientRect.left - parentRect.left;\\n                        }\\n                        newPosition.top = clientRect.top - parentRect.top;\\n//                        console.log(\\\"### drag end => \\\" + JSON.stringify(newPosition));\\n//                        console.log(\\\"### DROP: \\\" + JSON.stringify(newPosition));\\n                        this.dragging = null;\\n                        this.isDragging = false;\\n                        shouldUpdate = true;\\n                        break;\\n                    case \\\"dragmove\\\":\\n                        const coreEvent = createCoreData(this.lastX, this.lastY, x, y);\\n//                        Add rtl support\\n                        if (this.renderRtl) {\\n                            newPosition.left = this.dragging.left - coreEvent.deltaX;\\n                        } else {\\n                            newPosition.left = this.dragging.left + coreEvent.deltaX;\\n                        }\\n                        newPosition.top = this.dragging.top + coreEvent.deltaY;\\n//                        console.log(\\\"### drag => \\\" + event.type + \\\", x=\\\" + x + \\\", y=\\\" + y);\\n//                        console.log(\\\"### drag => \\\" + event.type + \\\", deltaX=\\\" + coreEvent.deltaX + \\\", deltaY=\\\" + coreEvent.deltaY);\\n//                        console.log(\\\"### drag end => \\\" + JSON.stringify(newPosition));\\n                        this.dragging = newPosition;\\n                        break;\\n                }\\n\\n                // Get new XY\\n                if (this.renderRtl) {\\n                    var pos = this.calcXY(newPosition.top, newPosition.left);\\n                } else {\\n                    var pos = this.calcXY(newPosition.top, newPosition.left);\\n                }\\n\\n                this.lastX = x;\\n                this.lastY = y;\\n\\n                if (this.x !== pos.x || this.y !== pos.y) {\\n                    this.$emit(\\\"move\\\", this.i, pos.x, pos.y);\\n                }\\n                if (event.type === \\\"dragend\\\" && (this.previousX !== this.x || this.previousY !== this.y)) {\\n                    this.$emit(\\\"moved\\\", this.i, pos.x, pos.y);\\n                }\\n                this.eventBus.$emit(\\\"dragEvent\\\", event.type, this.i, pos.x, pos.y, this.h, this.w);\\n            },\\n            calcPosition: function (x, y, w, h) {\\n                const colWidth = this.calcColWidth();\\n                // add rtl support\\n                if (this.renderRtl) {\\n                    var out = {\\n                        right: Math.round(colWidth * x + (x + 1) * this.margin[0]),\\n                        top: Math.round(this.rowHeight * y + (y + 1) * this.margin[1]),\\n                        // 0 * Infinity === NaN, which causes problems with resize constriants;\\n                        // Fix this if it occurs.\\n                        // Note we do it here rather than later because Math.round(Infinity) causes deopt\\n                        width: w === Infinity ? w : Math.round(colWidth * w + Math.max(0, w - 1) * this.margin[0]),\\n                        height: h === Infinity ? h : Math.round(this.rowHeight * h + Math.max(0, h - 1) * this.margin[1])\\n                    };\\n                } else {\\n                    var out = {\\n                        left: Math.round(colWidth * x + (x + 1) * this.margin[0]),\\n                        top: Math.round(this.rowHeight * y + (y + 1) * this.margin[1]),\\n                        // 0 * Infinity === NaN, which causes problems with resize constriants;\\n                        // Fix this if it occurs.\\n                        // Note we do it here rather than later because Math.round(Infinity) causes deopt\\n                        width: w === Infinity ? w : Math.round(colWidth * w + Math.max(0, w - 1) * this.margin[0]),\\n                        height: h === Infinity ? h : Math.round(this.rowHeight * h + Math.max(0, h - 1) * this.margin[1])\\n                    };\\n                }\\n\\n\\n                return out;\\n            },\\n            /**\\n             * Translate x and y coordinates from pixels to grid units.\\n             * @param  {Number} top  Top position (relative to parent) in pixels.\\n             * @param  {Number} left Left position (relative to parent) in pixels.\\n             * @return {Object} x and y in grid units.\\n             */\\n            // TODO check if this function needs change in order to support rtl.\\n            calcXY(top, left) {\\n                const colWidth = this.calcColWidth();\\n\\n                // left = colWidth * x + margin * (x + 1)\\n                // l = cx + m(x+1)\\n                // l = cx + mx + m\\n                // l - m = cx + mx\\n                // l - m = x(c + m)\\n                // (l - m) / (c + m) = x\\n                // x = (left - margin) / (coldWidth + margin)\\n                let x = Math.round((left - this.margin[0]) / (colWidth + this.margin[0]));\\n                let y = Math.round((top - this.margin[1]) / (this.rowHeight + this.margin[1]));\\n\\n                // Capping\\n                x = Math.max(Math.min(x, this.cols - this.w), 0);\\n                y = Math.max(Math.min(y, this.maxRows - this.h), 0);\\n\\n                return {x, y};\\n            },\\n            // Helper for generating column width\\n            calcColWidth() {\\n                var colWidth = (this.containerWidth - (this.margin[0] * (this.cols + 1))) / this.cols;\\n//                console.log(\\\"### COLS=\\\" + this.cols + \\\" COL WIDTH=\\\" + colWidth);\\n                return colWidth;\\n            },\\n\\n            /**\\n             * Given a height and width in pixel values, calculate grid units.\\n             * @param  {Number} height Height in pixels.\\n             * @param  {Number} width  Width in pixels.\\n             * @return {Object} w, h as grid units.\\n             */\\n            calcWH(height, width) {\\n                const colWidth = this.calcColWidth();\\n\\n                // width = colWidth * w - (margin * (w - 1))\\n                // ...\\n                // w = (width + margin) / (colWidth + margin)\\n                let w = Math.round((width + this.margin[0]) / (colWidth + this.margin[0]));\\n                let h = Math.round((height + this.margin[1]) / (this.rowHeight + this.margin[1]));\\n\\n                // Capping\\n                w = Math.max(Math.min(w, this.cols - this.x), 0);\\n                h = Math.max(Math.min(h, this.maxRows - this.y), 0);\\n                return {w, h};\\n            },\\n            updateWidth: function (width, colNum) {\\n                this.containerWidth = width;\\n                if (colNum !== undefined && colNum !== null) {\\n                    this.cols = colNum;\\n                }\\n            },\\n            compact: function () {\\n                this.createStyle();\\n            }\\n        },\\n    }\\n</script>\\n\"],\"sourceRoot\":\"webpack://\"}]);\n\n// exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/css-loader?sourceMap!./node_modules/vue-loader/lib/style-compiler?{\"id\":\"data-v-f2ef9cd2\",\"scoped\":false,\"hasInlineConfig\":false}!./node_modules/vue-loader/lib/selector.js?type=styles&index=0!./src/GridItem.vue\n// module id = 12\n// module chunks = 0"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///12\n"); +eval("/**\n * Translates the list format produced by css-loader into something\n * easier to manipulate.\n */\nmodule.exports = function listToStyles (parentId, list) {\n var styles = []\n var newStyles = {}\n for (var i = 0; i < list.length; i++) {\n var item = list[i]\n var id = item[0]\n var css = item[1]\n var media = item[2]\n var sourceMap = item[3]\n var part = {\n id: parentId + ':' + i,\n css: css,\n media: media,\n sourceMap: sourceMap\n }\n if (!newStyles[id]) {\n styles.push(newStyles[id] = { id: id, parts: [part] })\n } else {\n newStyles[id].parts.push(part)\n }\n }\n return styles\n}\n\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vLi9ub2RlX21vZHVsZXMvdnVlLXN0eWxlLWxvYWRlci9saWIvbGlzdFRvU3R5bGVzLmpzP2I1MzUiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxpQkFBaUIsaUJBQWlCO0FBQ2xDO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLG1DQUFtQyx3QkFBd0I7QUFDM0QsS0FBSztBQUNMO0FBQ0E7QUFDQTtBQUNBO0FBQ0EiLCJmaWxlIjoiMTIuanMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIFRyYW5zbGF0ZXMgdGhlIGxpc3QgZm9ybWF0IHByb2R1Y2VkIGJ5IGNzcy1sb2FkZXIgaW50byBzb21ldGhpbmdcbiAqIGVhc2llciB0byBtYW5pcHVsYXRlLlxuICovXG5tb2R1bGUuZXhwb3J0cyA9IGZ1bmN0aW9uIGxpc3RUb1N0eWxlcyAocGFyZW50SWQsIGxpc3QpIHtcbiAgdmFyIHN0eWxlcyA9IFtdXG4gIHZhciBuZXdTdHlsZXMgPSB7fVxuICBmb3IgKHZhciBpID0gMDsgaSA8IGxpc3QubGVuZ3RoOyBpKyspIHtcbiAgICB2YXIgaXRlbSA9IGxpc3RbaV1cbiAgICB2YXIgaWQgPSBpdGVtWzBdXG4gICAgdmFyIGNzcyA9IGl0ZW1bMV1cbiAgICB2YXIgbWVkaWEgPSBpdGVtWzJdXG4gICAgdmFyIHNvdXJjZU1hcCA9IGl0ZW1bM11cbiAgICB2YXIgcGFydCA9IHtcbiAgICAgIGlkOiBwYXJlbnRJZCArICc6JyArIGksXG4gICAgICBjc3M6IGNzcyxcbiAgICAgIG1lZGlhOiBtZWRpYSxcbiAgICAgIHNvdXJjZU1hcDogc291cmNlTWFwXG4gICAgfVxuICAgIGlmICghbmV3U3R5bGVzW2lkXSkge1xuICAgICAgc3R5bGVzLnB1c2gobmV3U3R5bGVzW2lkXSA9IHsgaWQ6IGlkLCBwYXJ0czogW3BhcnRdIH0pXG4gICAgfSBlbHNlIHtcbiAgICAgIG5ld1N0eWxlc1tpZF0ucGFydHMucHVzaChwYXJ0KVxuICAgIH1cbiAgfVxuICByZXR1cm4gc3R5bGVzXG59XG5cblxuXG4vLy8vLy8vLy8vLy8vLy8vLy9cbi8vIFdFQlBBQ0sgRk9PVEVSXG4vLyAuL25vZGVfbW9kdWxlcy92dWUtc3R5bGUtbG9hZGVyL2xpYi9saXN0VG9TdHlsZXMuanNcbi8vIG1vZHVsZSBpZCA9IDEyXG4vLyBtb2R1bGUgY2h1bmtzID0gMCJdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///12\n"); /***/ }), /* 13 */ -/***/ (function(module, exports) { +/***/ (function(module, exports, __webpack_require__) { -eval("/**\n * Translates the list format produced by css-loader into something\n * easier to manipulate.\n */\nmodule.exports = function listToStyles (parentId, list) {\n var styles = []\n var newStyles = {}\n for (var i = 0; i < list.length; i++) {\n var item = list[i]\n var id = item[0]\n var css = item[1]\n var media = item[2]\n var sourceMap = item[3]\n var part = {\n id: parentId + ':' + i,\n css: css,\n media: media,\n sourceMap: sourceMap\n }\n if (!newStyles[id]) {\n styles.push(newStyles[id] = { id: id, parts: [part] })\n } else {\n newStyles[id].parts.push(part)\n }\n }\n return styles\n}\n\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vLi9ub2RlX21vZHVsZXMvdnVlLXN0eWxlLWxvYWRlci9saWIvbGlzdFRvU3R5bGVzLmpzP2I1MzUiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSxpQkFBaUIsaUJBQWlCO0FBQ2xDO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLG1DQUFtQyx3QkFBd0I7QUFDM0QsS0FBSztBQUNMO0FBQ0E7QUFDQTtBQUNBO0FBQ0EiLCJmaWxlIjoiMTMuanMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIFRyYW5zbGF0ZXMgdGhlIGxpc3QgZm9ybWF0IHByb2R1Y2VkIGJ5IGNzcy1sb2FkZXIgaW50byBzb21ldGhpbmdcbiAqIGVhc2llciB0byBtYW5pcHVsYXRlLlxuICovXG5tb2R1bGUuZXhwb3J0cyA9IGZ1bmN0aW9uIGxpc3RUb1N0eWxlcyAocGFyZW50SWQsIGxpc3QpIHtcbiAgdmFyIHN0eWxlcyA9IFtdXG4gIHZhciBuZXdTdHlsZXMgPSB7fVxuICBmb3IgKHZhciBpID0gMDsgaSA8IGxpc3QubGVuZ3RoOyBpKyspIHtcbiAgICB2YXIgaXRlbSA9IGxpc3RbaV1cbiAgICB2YXIgaWQgPSBpdGVtWzBdXG4gICAgdmFyIGNzcyA9IGl0ZW1bMV1cbiAgICB2YXIgbWVkaWEgPSBpdGVtWzJdXG4gICAgdmFyIHNvdXJjZU1hcCA9IGl0ZW1bM11cbiAgICB2YXIgcGFydCA9IHtcbiAgICAgIGlkOiBwYXJlbnRJZCArICc6JyArIGksXG4gICAgICBjc3M6IGNzcyxcbiAgICAgIG1lZGlhOiBtZWRpYSxcbiAgICAgIHNvdXJjZU1hcDogc291cmNlTWFwXG4gICAgfVxuICAgIGlmICghbmV3U3R5bGVzW2lkXSkge1xuICAgICAgc3R5bGVzLnB1c2gobmV3U3R5bGVzW2lkXSA9IHsgaWQ6IGlkLCBwYXJ0czogW3BhcnRdIH0pXG4gICAgfSBlbHNlIHtcbiAgICAgIG5ld1N0eWxlc1tpZF0ucGFydHMucHVzaChwYXJ0KVxuICAgIH1cbiAgfVxuICByZXR1cm4gc3R5bGVzXG59XG5cblxuXG4vLy8vLy8vLy8vLy8vLy8vLy9cbi8vIFdFQlBBQ0sgRk9PVEVSXG4vLyAuL25vZGVfbW9kdWxlcy92dWUtc3R5bGUtbG9hZGVyL2xpYi9saXN0VG9TdHlsZXMuanNcbi8vIG1vZHVsZSBpZCA9IDEzXG4vLyBtb2R1bGUgY2h1bmtzID0gMCJdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///13\n"); +"use strict"; +eval("\n\nexports.__esModule = true;\n\nvar _utils = __webpack_require__(0);\n\nvar _draggableUtils = __webpack_require__(14);\n\n// var eventBus = require('./eventBus');\n\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n\nvar interact = __webpack_require__(15);\n\nexports.default = {\n name: \"GridItem\",\n props: {\n /*cols: {\n type: Number,\n required: true\n },*/\n /*containerWidth: {\n type: Number,\n required: true\n },\n rowHeight: {\n type: Number,\n required: true\n },\n margin: {\n type: Array,\n required: true\n },\n maxRows: {\n type: Number,\n required: true\n },*/\n isDraggable: {\n type: Boolean,\n required: false,\n default: null\n },\n isResizable: {\n type: Boolean,\n required: false,\n default: null\n },\n /*useCssTransforms: {\n type: Boolean,\n required: true\n },\n static: {\n type: Boolean,\n required: false,\n default: false\n },\n */\n minH: {\n type: Number,\n required: false,\n default: 1\n },\n minW: {\n type: Number,\n required: false,\n default: 1\n },\n maxH: {\n type: Number,\n required: false,\n default: Infinity\n },\n maxW: {\n type: Number,\n required: false,\n default: Infinity\n },\n x: {\n type: Number,\n required: true\n },\n y: {\n type: Number,\n required: true\n },\n w: {\n type: Number,\n required: true\n },\n h: {\n type: Number,\n required: true\n },\n i: {\n required: true\n },\n dragIgnoreFrom: {\n type: String,\n required: false,\n default: 'a, button'\n },\n dragAllowFrom: {\n type: String,\n required: false,\n default: null\n },\n resizeIgnoreFrom: {\n type: String,\n required: false,\n default: 'a, button'\n }\n },\n inject: [\"eventBus\"],\n data: function data() {\n return {\n cols: 1,\n containerWidth: 100,\n rowHeight: 30,\n margin: [10, 10],\n maxRows: Infinity,\n draggable: null,\n resizable: null,\n useCssTransforms: true,\n\n isDragging: false,\n dragging: null,\n isResizing: false,\n resizing: null,\n lastX: NaN,\n lastY: NaN,\n lastW: NaN,\n lastH: NaN,\n style: {},\n rtl: false,\n\n dragEventSet: false,\n resizeEventSet: false,\n\n previousW: null,\n previousH: null,\n previousX: null,\n previousY: null\n };\n },\n created: function created() {\n var _this = this;\n\n var self = this;\n\n // Accessible refernces of functions for removing in beforeDestroy\n self.updateWidthHandler = function (width) {\n self.updateWidth(width);\n };\n\n self.compactHandler = function (layout) {\n self.compact(layout);\n };\n\n self.setDraggableHandler = function (isDraggable) {\n if (self.isDraggable === null) {\n self.draggable = isDraggable;\n }\n };\n\n self.setResizableHandler = function (isResizable) {\n if (self.isResizable === null) {\n self.resizable = isResizable;\n }\n };\n\n self.setRowHeightHandler = function (rowHeight) {\n self.rowHeight = rowHeight;\n };\n\n self.directionchangeHandler = function (direction) {\n var direction = document.dir !== undefined ? document.dir : document.getElementsByTagName(\"html\")[0].getAttribute(\"dir\");\n _this.rtl = direction === \"rtl\";\n _this.compact();\n };\n\n this.eventBus.$on('updateWidth', self.updateWidthHandler);\n this.eventBus.$on('compact', self.compactHandler);\n this.eventBus.$on('setDraggable', self.setDraggableHandler);\n this.eventBus.$on('setResizable', self.setResizableHandler);\n this.eventBus.$on('setRowHeight', self.setRowHeightHandler);\n this.eventBus.$on('directionchange', self.directionchangeHandler);\n\n /*this.eventBus.$on('setColNum', function(colNum) {\n self.cols = colNum;\n });*/\n var direction = document.dir !== undefined ? document.dir : document.getElementsByTagName(\"html\")[0].getAttribute(\"dir\");\n this.rtl = direction === \"rtl\";\n },\n\n beforeDestroy: function beforeDestroy() {\n var self = this;\n //Remove listeners\n this.eventBus.$off('updateWidth', self.updateWidthHandler);\n this.eventBus.$off('compact', self.compactHandler);\n this.eventBus.$off('setDraggable', self.setDraggableHandler);\n this.eventBus.$off('setResizable', self.setResizableHandler);\n this.eventBus.$off('setRowHeight', self.setRowHeightHandler);\n this.eventBus.$off('directionchange', self.directionchangeHandler);\n },\n mounted: function mounted() {\n this.cols = this.$parent.colNum;\n this.rowHeight = this.$parent.rowHeight;\n this.containerWidth = this.$parent.width !== null ? this.$parent.width : 100;\n this.margin = this.$parent.margin !== undefined ? this.$parent.margin : [10, 10];\n this.maxRows = this.$parent.maxRows;\n if (this.isDraggable === null) {\n this.draggable = this.$parent.isDraggable;\n } else {\n this.draggable = this.isDraggable;\n }\n if (this.isResizable === null) {\n this.resizable = this.$parent.isResizable;\n } else {\n this.resizable = this.isResizable;\n }\n this.useCssTransforms = this.$parent.useCssTransforms;\n this.createStyle();\n },\n watch: {\n isDraggable: function isDraggable() {\n this.draggable = this.isDraggable;\n },\n draggable: function draggable() {\n var self = this;\n if (this.interactObj === null || this.interactObj === undefined) {\n this.interactObj = interact(this.$refs.item);\n }\n if (this.draggable) {\n var opts = {\n ignoreFrom: this.dragIgnoreFrom,\n allowFrom: this.dragAllowFrom\n };\n this.interactObj.draggable(opts);\n /*this.interactObj.draggable({allowFrom: '.vue-draggable-handle'});*/\n if (!this.dragEventSet) {\n this.dragEventSet = true;\n this.interactObj.on('dragstart dragmove dragend', function (event) {\n self.handleDrag(event);\n });\n }\n } else {\n this.interactObj.draggable({\n enabled: false\n });\n }\n },\n isResizable: function isResizable() {\n this.resizable = this.isResizable;\n },\n resizable: function resizable() {\n var self = this;\n if (this.interactObj === null || this.interactObj === undefined) {\n this.interactObj = interact(this.$refs.item);\n }\n if (this.resizable) {\n var opts = {\n preserveAspectRatio: false,\n edges: { left: false, right: true, bottom: true, top: false },\n ignoreFrom: this.resizeIgnoreFrom\n };\n\n this.interactObj.resizable(opts);\n if (!this.resizeEventSet) {\n this.resizeEventSet = true;\n this.interactObj.on('resizestart resizemove resizeend', function (event) {\n self.handleResize(event);\n });\n }\n } else {\n this.interactObj.resizable({\n enabled: false\n });\n }\n },\n rowHeight: function rowHeight() {\n this.createStyle();\n },\n cols: function cols() {\n this.createStyle();\n },\n containerWidth: function containerWidth() {\n this.createStyle();\n },\n x: function x() {\n this.createStyle();\n },\n y: function y() {\n this.createStyle();\n },\n h: function h() {\n this.createStyle();\n },\n w: function w() {\n this.createStyle();\n },\n renderRtl: function renderRtl() {\n this.createStyle();\n }\n },\n computed: {\n renderRtl: function renderRtl() {\n return this.$parent.isMirrored ? !this.rtl : this.rtl;\n },\n resizableHandleClass: function resizableHandleClass() {\n if (this.renderRtl) {\n return 'vue-resizable-handle vue-rtl-resizable-handle';\n } else {\n return 'vue-resizable-handle';\n }\n }\n },\n methods: {\n createStyle: function createStyle() {\n if (this.x + this.w > this.cols) {\n this.x = 0;\n this.w = this.cols;\n }\n\n var pos = this.calcPosition(this.x, this.y, this.w, this.h);\n\n if (this.isDragging) {\n pos.top = this.dragging.top;\n // Add rtl support\n if (this.renderRtl) {\n pos.right = this.dragging.left;\n } else {\n pos.left = this.dragging.left;\n }\n }\n if (this.isResizing) {\n pos.width = this.resizing.width;\n pos.height = this.resizing.height;\n }\n\n var style = void 0;\n // CSS Transforms support (default)\n if (this.useCssTransforms) {\n // Add rtl support\n if (this.renderRtl) {\n style = (0, _utils.setTransformRtl)(pos.top, pos.right, pos.width, pos.height);\n } else {\n style = (0, _utils.setTransform)(pos.top, pos.left, pos.width, pos.height);\n }\n } else {\n // top,left (slow)\n // Add rtl support\n if (this.renderRtl) {\n style = (0, _utils.setTopRight)(pos.top, pos.right, pos.width, pos.height);\n } else {\n style = (0, _utils.setTopLeft)(pos.top, pos.left, pos.width, pos.height);\n }\n }\n this.style = style;\n },\n handleResize: function handleResize(event) {\n var position = (0, _draggableUtils.getControlPosition)(event);\n // Get the current drag point from the event. This is used as the offset.\n if (position == null) return; // not possible but satisfies flow\n var x = position.x,\n y = position.y;\n\n\n var newSize = { width: 0, height: 0 };\n switch (event.type) {\n case \"resizestart\":\n this.previousW = this.w;\n this.previousH = this.h;\n var pos = this.calcPosition(this.x, this.y, this.w, this.h);\n newSize.width = pos.width;\n newSize.height = pos.height;\n this.resizing = newSize;\n this.isResizing = true;\n break;\n case \"resizemove\":\n // console.log(\"### resize => \" + event.type + \", lastW=\" + this.lastW + \", lastH=\" + this.lastH);\n var coreEvent = (0, _draggableUtils.createCoreData)(this.lastW, this.lastH, x, y);\n if (this.renderRtl) {\n newSize.width = this.resizing.width - coreEvent.deltaX;\n } else {\n newSize.width = this.resizing.width + coreEvent.deltaX;\n }\n newSize.height = this.resizing.height + coreEvent.deltaY;\n\n ///console.log(\"### resize => \" + event.type + \", deltaX=\" + coreEvent.deltaX + \", deltaY=\" + coreEvent.deltaY);\n this.resizing = newSize;\n break;\n case \"resizeend\":\n //console.log(\"### resize end => x=\" +this.x + \" y=\" + this.y + \" w=\" + this.w + \" h=\" + this.h);\n var pos = this.calcPosition(this.x, this.y, this.w, this.h);\n newSize.width = pos.width;\n newSize.height = pos.height;\n // console.log(\"### resize end => \" + JSON.stringify(newSize));\n this.resizing = null;\n this.isResizing = false;\n break;\n }\n\n // Get new WH\n var pos = this.calcWH(newSize.height, newSize.width);\n if (pos.w < this.minW) {\n pos.w = this.minW;\n }\n if (pos.w > this.maxW) {\n pos.w = this.maxW;\n }\n if (pos.h < this.minH) {\n pos.h = this.minH;\n }\n if (pos.h > this.maxH) {\n pos.h = this.maxH;\n }\n\n if (pos.h < 1) {\n pos.h = 1;\n }\n if (pos.w < 1) {\n pos.w = 1;\n }\n\n this.lastW = x;\n this.lastH = y;\n\n if (this.w !== pos.w || this.h !== pos.h) {\n this.$emit(\"resize\", this.i, pos.h, pos.w);\n }\n if (event.type === \"resizeend\" && (this.previousW !== this.w || this.previousH !== this.h)) {\n this.$emit(\"resized\", this.i, pos.h, pos.w, newSize.height, newSize.width);\n }\n this.eventBus.$emit(\"resizeEvent\", event.type, this.i, this.x, this.y, pos.h, pos.w);\n },\n handleDrag: function handleDrag(event) {\n if (this.isResizing) return;\n\n var position = (0, _draggableUtils.getControlPosition)(event);\n\n // Get the current drag point from the event. This is used as the offset.\n if (position === null) return; // not possible but satisfies flow\n var x = position.x,\n y = position.y;\n\n\n var shouldUpdate = false;\n var newPosition = { top: 0, left: 0 };\n switch (event.type) {\n case \"dragstart\":\n this.previousX = this.x;\n this.previousY = this.y;\n\n var parentRect = event.target.offsetParent.getBoundingClientRect();\n var clientRect = event.target.getBoundingClientRect();\n if (this.renderRtl) {\n newPosition.left = (clientRect.right - parentRect.right) * -1;\n } else {\n newPosition.left = clientRect.left - parentRect.left;\n }\n newPosition.top = clientRect.top - parentRect.top;\n this.dragging = newPosition;\n this.isDragging = true;\n break;\n case \"dragend\":\n if (!this.isDragging) return;\n parentRect = event.target.offsetParent.getBoundingClientRect();\n clientRect = event.target.getBoundingClientRect();\n // Add rtl support\n if (this.renderRtl) {\n newPosition.left = (clientRect.right - parentRect.right) * -1;\n } else {\n newPosition.left = clientRect.left - parentRect.left;\n }\n newPosition.top = clientRect.top - parentRect.top;\n // console.log(\"### drag end => \" + JSON.stringify(newPosition));\n // console.log(\"### DROP: \" + JSON.stringify(newPosition));\n this.dragging = null;\n this.isDragging = false;\n shouldUpdate = true;\n break;\n case \"dragmove\":\n var coreEvent = (0, _draggableUtils.createCoreData)(this.lastX, this.lastY, x, y);\n // Add rtl support\n if (this.renderRtl) {\n newPosition.left = this.dragging.left - coreEvent.deltaX;\n } else {\n newPosition.left = this.dragging.left + coreEvent.deltaX;\n }\n newPosition.top = this.dragging.top + coreEvent.deltaY;\n // console.log(\"### drag => \" + event.type + \", x=\" + x + \", y=\" + y);\n // console.log(\"### drag => \" + event.type + \", deltaX=\" + coreEvent.deltaX + \", deltaY=\" + coreEvent.deltaY);\n // console.log(\"### drag end => \" + JSON.stringify(newPosition));\n this.dragging = newPosition;\n break;\n }\n\n // Get new XY\n if (this.renderRtl) {\n var pos = this.calcXY(newPosition.top, newPosition.left);\n } else {\n var pos = this.calcXY(newPosition.top, newPosition.left);\n }\n\n this.lastX = x;\n this.lastY = y;\n\n if (this.x !== pos.x || this.y !== pos.y) {\n this.$emit(\"move\", this.i, pos.x, pos.y);\n }\n if (event.type === \"dragend\" && (this.previousX !== this.x || this.previousY !== this.y)) {\n this.$emit(\"moved\", this.i, pos.x, pos.y);\n }\n this.eventBus.$emit(\"dragEvent\", event.type, this.i, pos.x, pos.y, this.h, this.w);\n },\n\n calcPosition: function calcPosition(x, y, w, h) {\n var colWidth = this.calcColWidth();\n // add rtl support\n if (this.renderRtl) {\n var out = {\n right: Math.round(colWidth * x + (x + 1) * this.margin[0]),\n top: Math.round(this.rowHeight * y + (y + 1) * this.margin[1]),\n // 0 * Infinity === NaN, which causes problems with resize constriants;\n // Fix this if it occurs.\n // Note we do it here rather than later because Math.round(Infinity) causes deopt\n width: w === Infinity ? w : Math.round(colWidth * w + Math.max(0, w - 1) * this.margin[0]),\n height: h === Infinity ? h : Math.round(this.rowHeight * h + Math.max(0, h - 1) * this.margin[1])\n };\n } else {\n var out = {\n left: Math.round(colWidth * x + (x + 1) * this.margin[0]),\n top: Math.round(this.rowHeight * y + (y + 1) * this.margin[1]),\n // 0 * Infinity === NaN, which causes problems with resize constriants;\n // Fix this if it occurs.\n // Note we do it here rather than later because Math.round(Infinity) causes deopt\n width: w === Infinity ? w : Math.round(colWidth * w + Math.max(0, w - 1) * this.margin[0]),\n height: h === Infinity ? h : Math.round(this.rowHeight * h + Math.max(0, h - 1) * this.margin[1])\n };\n }\n\n return out;\n },\n /**\n * Translate x and y coordinates from pixels to grid units.\n * @param {Number} top Top position (relative to parent) in pixels.\n * @param {Number} left Left position (relative to parent) in pixels.\n * @return {Object} x and y in grid units.\n */\n // TODO check if this function needs change in order to support rtl.\n calcXY: function calcXY(top, left) {\n var colWidth = this.calcColWidth();\n\n // left = colWidth * x + margin * (x + 1)\n // l = cx + m(x+1)\n // l = cx + mx + m\n // l - m = cx + mx\n // l - m = x(c + m)\n // (l - m) / (c + m) = x\n // x = (left - margin) / (coldWidth + margin)\n var x = Math.round((left - this.margin[0]) / (colWidth + this.margin[0]));\n var y = Math.round((top - this.margin[1]) / (this.rowHeight + this.margin[1]));\n\n // Capping\n x = Math.max(Math.min(x, this.cols - this.w), 0);\n y = Math.max(Math.min(y, this.maxRows - this.h), 0);\n\n return { x: x, y: y };\n },\n\n // Helper for generating column width\n calcColWidth: function calcColWidth() {\n var colWidth = (this.containerWidth - this.margin[0] * (this.cols + 1)) / this.cols;\n // console.log(\"### COLS=\" + this.cols + \" COL WIDTH=\" + colWidth);\n return colWidth;\n },\n\n\n /**\n * Given a height and width in pixel values, calculate grid units.\n * @param {Number} height Height in pixels.\n * @param {Number} width Width in pixels.\n * @return {Object} w, h as grid units.\n */\n calcWH: function calcWH(height, width) {\n var colWidth = this.calcColWidth();\n\n // width = colWidth * w - (margin * (w - 1))\n // ...\n // w = (width + margin) / (colWidth + margin)\n var w = Math.round((width + this.margin[0]) / (colWidth + this.margin[0]));\n var h = Math.round((height + this.margin[1]) / (this.rowHeight + this.margin[1]));\n\n // Capping\n w = Math.max(Math.min(w, this.cols - this.x), 0);\n h = Math.max(Math.min(h, this.maxRows - this.y), 0);\n return { w: w, h: h };\n },\n\n updateWidth: function updateWidth(width, colNum) {\n this.containerWidth = width;\n if (colNum !== undefined && colNum !== null) {\n this.cols = colNum;\n }\n },\n compact: function compact() {\n this.createStyle();\n }\n }\n};\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack:///GridItem.vue?7a16"],"names":[],"mappings":";;;;AAgFA;;AACA;;AAEA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAJA;;mCAMA;;;UAEA;;AAKA;;;;AAiBA;;;;;;;;;;;;;;;;;kBAEA;sBACA;qBAEA;AAJA;;kBAMA;sBACA;qBAEA;AAJA;AAcA;;;;;;;;;;;kBAEA;sBACA;qBAEA;AAJA;;kBAMA;sBACA;qBAEA;AAJA;;kBAMA;sBACA;qBAEA;AAJA;;kBAMA;sBACA;qBAEA;AAJA;;kBAMA;sBAEA;AAHA;;kBAKA;sBAEA;AAHA;;kBAKA;sBAEA;AAHA;;kBAKA;sBAEA;AAHA;;sBAMA;AAFA;;kBAIA;sBACA;qBAEA;AAJA;;kBAMA;sBACA;qBAEA;AAJA;;kBAMA;sBACA;qBAGA;AALA;AA3FA;aAiGA;0BACA;;kBAEA;4BACA;uBACA;yBACA;qBACA;uBACA;uBACA;8BAEA;;wBACA;sBACA;wBACA;sBACA;mBACA;mBACA;mBACA;mBACA;mBACA;iBAEA;;0BACA;4BAEA;;uBACA;uBACA;uBACA;uBAEA;AA5BA;AA6BA;;AACA;;mBAEA;;AACA;mDACA;6BACA;AAEA;;gDACA;yBACA;AAEA;;0DACA;2CACA;iCACA;AACA;AAEA;;0DACA;2CACA;iCACA;AACA;AAEA;;wDACA;6BACA;AAEA;;2DACA;6CACA,qBACA,4DACA;sCACA;kBACA;AAEA;;8CACA;0CACA;+CACA;+CACA;+CACA;kDAEA;;AAGA;;;yCACA,qBACA,4DACA;iCACA;AACA;;4CACA;mBACA;AACA;+CACA;2CACA;gDACA;gDACA;gDACA;mDACA;AACA;gCACA;iCACA;sCACA;iFACA;qFACA;oCACA;uCACA;0CACA;eACA;kCACA;AACA;uCACA;0CACA;eACA;kCACA;AACA;6CACA;aACA;AACA;;4CAEA;kCACA;AACA;wCACA;uBACA;6EACA;uDACA;AACA;gCACA;;qCAEA;oCAEA;AAHA;2CAIA;AACA;wCACA;wCACA;uFACA;wCACA;AACA;AACA;mBACA;;6BAGA;AAFA;AAGA;AACA;4CACA;kCACA;AACA;wCACA;uBACA;6EACA;uDACA;AACA;gCACA;;yCAEA;0EACA;qCAGA;AALA;;2CAMA;0CACA;0CACA;yBACA,oEACA;0CACA;AACA;AACA;mBACA;;6BAGA;AAFA;AAGA;AACA;wCACA;iBACA;AACA;8BACA;iBACA;AACA;kDACA;iBACA;AACA;wBACA;iBACA;AACA;wBACA;iBACA;AACA;wBACA;iBACA;AACA;wBACA;iBACA;AACA;wCACA;iBACA;AAEA;AAjFA;;wCAmFA;8DACA;AACA;8DACA;gCACA;uBACA;mBACA;uBACA;AACA;AAEA;AAXA;;4CAaA;6CACA;yBACA;8BACA;AAEA;;qEAEA;;iCACA;;AAEA;oCACA;8CACA;uBACA;6CACA;AACA;AACA;iCACA;0CACA;2CACA;AAEA;;gBACA;AACA;;AAEA;oCACA;2FACA;uBACA;uFACA;AAEA;;;AAEA;oCACA;uFACA;uBACA;qFACA;AACA;AACA;yBAEA;AACA;;mEAEA;AACA;0CACA;AAHA,oBAKA;;;;8CACA;0BACA;qBACA;0CACA;0CACA;6EACA;wCACA;yCACA;oCACA;sCACA;AACA;;AAEA;mGACA;wCACA;wEACA;2BACA;wEACA;AACA;sEAEA;;AACA;oCACA;AACA;qBACA;AACA;6EACA;wCACA;;AAEA;oCACA;sCACA;AAGA;;;AACA;0DACA;mCACA;6BACA;AACA;mCACA;6BACA;AACA;mCACA;6BACA;AACA;mCACA;6BACA;AAEA;;2BACA;wBACA;AACA;2BACA;wBACA;AAEA;;yBACA;yBAEA;;sDACA;wDACA;AACA;wGACA;oFACA;AACA;8FACA;AACA;;iCAGA;;mEAEA;;AACA;2CACA;AANA,oBAQA;;;;+BACA;8CACA;0BACA;qBACA;0CACA;0CAEA;;+DACA;kDACA;wCACA;oFACA;2BACA;wEACA;AACA;kEACA;oCACA;sCACA;AACA;qBACA;0CACA;2DACA;;AAEA;wCACA;oFACA;2BACA;wEACA;AACA;;AACA;AAEA;oCACA;sCACA;mCACA;AACA;qBACA;;AAEA;wCACA;0EACA;2BACA;0EACA;AACA;;AACA;AACA;AAEA;oCACA;AAGA;;;AACA;gCACA;mEACA;mBACA;mEACA;AAEA;;yBACA;yBAEA;;sDACA;sDACA;AACA;sGACA;uDACA;AACA;4FACA;AACA;;wDACA;gCACA;AACA;gCACA;;2EAEA;+EACA;AACA;AACA;AACA;2GACA;kHAEA;AARA;mBASA;;0EAEA;+EACA;AACA;AACA;AACA;2GACA;kHAEA;AARA;AAWA;;mBACA;AACA;AAMA;;;;;;AACA;2CACA;gCAEA;;AACA;AACA;AACA;AACA;AACA;AACA;AACA;iFACA;sFAEA;;AACA;0DACA;6DAEA;;2BACA;AACA;;AACA;8CACA;;AAEA;mBACA;AAEA;;;AAMA;;;;;;+CACA;gCAEA;;AACA;AACA;AACA;kFACA;yFAEA;;AACA;0DACA;6DACA;2BACA;AACA;;yDACA;kCACA;yDACA;4BACA;AACA;AACA;oCACA;iBACA;AAEA;AA9RA;AAjTA","file":"13.js","sourcesContent":["<template>\r\n    <div ref=\"item\"\r\n         class=\"vue-grid-item\"\r\n         :class=\"{ 'vue-resizable' : resizable, 'resizing' : isResizing, 'vue-draggable-dragging' : isDragging, 'cssTransforms' : useCssTransforms, 'render-rtl' : renderRtl }\"\r\n         :style=\"style\"\r\n    >\r\n        <slot></slot>\r\n        <span v-if=\"resizable\" ref=\"handle\" :class=\"resizableHandleClass\"></span>\r\n        <!--<span v-if=\"draggable\" ref=\"dragHandle\" class=\"vue-draggable-handle\"></span>-->\r\n    </div>\r\n</template>\r\n<style>\r\n    .vue-grid-item {\r\n        transition: all 200ms ease;\r\n        transition-property: left, top, right;\r\n        /* add right for rtl */\r\n    }\r\n\r\n    .vue-grid-item.cssTransforms {\r\n        transition-property: transform;\r\n        left: 0;\r\n        right: auto;\r\n    }\r\n\r\n    .vue-grid-item.cssTransforms.render-rtl {\r\n        left: auto;\r\n        right: 0;\r\n    }\r\n\r\n    .vue-grid-item.resizing {\r\n        opacity: 0.6;\r\n        z-index: 3;\r\n    }\r\n\r\n    .vue-grid-item.vue-draggable-dragging {\r\n        transition:none;\r\n        z-index: 3;\r\n    }\r\n\r\n    .vue-grid-item.vue-grid-placeholder {\r\n        background: red;\r\n        opacity: 0.2;\r\n        transition-duration: 100ms;\r\n        z-index: 2;\r\n        -webkit-user-select: none;\r\n        -moz-user-select: none;\r\n        -ms-user-select: none;\r\n        -o-user-select: none;\r\n        user-select: none;\r\n    }\r\n\r\n    .vue-grid-item > .vue-resizable-handle {\r\n        position: absolute;\r\n        width: 20px;\r\n        height: 20px;\r\n        bottom: 0;\r\n        right: 0;\r\n        background: url('data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBzdGFuZGFsb25lPSJubyI/Pg08IS0tIEdlbmVyYXRvcjogQWRvYmUgRmlyZXdvcmtzIENTNiwgRXhwb3J0IFNWRyBFeHRlbnNpb24gYnkgQWFyb24gQmVhbGwgKGh0dHA6Ly9maXJld29ya3MuYWJlYWxsLmNvbSkgLiBWZXJzaW9uOiAwLjYuMSAgLS0+DTwhRE9DVFlQRSBzdmcgUFVCTElDICItLy9XM0MvL0RURCBTVkcgMS4xLy9FTiIgImh0dHA6Ly93d3cudzMub3JnL0dyYXBoaWNzL1NWRy8xLjEvRFREL3N2ZzExLmR0ZCI+DTxzdmcgaWQ9IlVudGl0bGVkLVBhZ2UlMjAxIiB2aWV3Qm94PSIwIDAgNiA2IiBzdHlsZT0iYmFja2dyb3VuZC1jb2xvcjojZmZmZmZmMDAiIHZlcnNpb249IjEuMSINCXhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIHhtbDpzcGFjZT0icHJlc2VydmUiDQl4PSIwcHgiIHk9IjBweCIgd2lkdGg9IjZweCIgaGVpZ2h0PSI2cHgiDT4NCTxnIG9wYWNpdHk9IjAuMzAyIj4NCQk8cGF0aCBkPSJNIDYgNiBMIDAgNiBMIDAgNC4yIEwgNCA0LjIgTCA0LjIgNC4yIEwgNC4yIDAgTCA2IDAgTCA2IDYgTCA2IDYgWiIgZmlsbD0iIzAwMDAwMCIvPg0JPC9nPg08L3N2Zz4=');\r\n        background-position: bottom right;\r\n        padding: 0 3px 3px 0;\r\n        background-repeat: no-repeat;\r\n        background-origin: content-box;\r\n        box-sizing: border-box;\r\n        cursor: se-resize;\r\n    }\r\n\r\n    .vue-grid-item > .vue-rtl-resizable-handle {\r\n        bottom: 0;\r\n        left: 0;\r\n        background: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMTAuMDAwMDAwMDAwMDAwMDAyIiBoZWlnaHQ9IjEwLjAwMDAwMDAwMDAwMDAwMiIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KIDwhLS0gQ3JlYXRlZCB3aXRoIE1ldGhvZCBEcmF3IC0gaHR0cDovL2dpdGh1Yi5jb20vZHVvcGl4ZWwvTWV0aG9kLURyYXcvIC0tPgogPGc+CiAgPHRpdGxlPmJhY2tncm91bmQ8L3RpdGxlPgogIDxyZWN0IGZpbGw9Im5vbmUiIGlkPSJjYW52YXNfYmFja2dyb3VuZCIgaGVpZ2h0PSIxMiIgd2lkdGg9IjEyIiB5PSItMSIgeD0iLTEiLz4KICA8ZyBkaXNwbGF5PSJub25lIiBvdmVyZmxvdz0idmlzaWJsZSIgeT0iMCIgeD0iMCIgaGVpZ2h0PSIxMDAlIiB3aWR0aD0iMTAwJSIgaWQ9ImNhbnZhc0dyaWQiPgogICA8cmVjdCBmaWxsPSJ1cmwoI2dyaWRwYXR0ZXJuKSIgc3Ryb2tlLXdpZHRoPSIwIiB5PSIwIiB4PSIwIiBoZWlnaHQ9IjEwMCUiIHdpZHRoPSIxMDAlIi8+CiAgPC9nPgogPC9nPgogPGc+CiAgPHRpdGxlPkxheWVyIDE8L3RpdGxlPgogIDxsaW5lIGNhbnZhcz0iI2ZmZmZmZiIgY2FudmFzLW9wYWNpdHk9IjEiIHN0cm9rZS1saW5lY2FwPSJ1bmRlZmluZWQiIHN0cm9rZS1saW5lam9pbj0idW5kZWZpbmVkIiBpZD0ic3ZnXzEiIHkyPSItNzAuMTc4NDA3IiB4Mj0iMTI0LjQ2NDE3NSIgeTE9Ii0zOC4zOTI3MzciIHgxPSIxNDQuODIxMjg5IiBzdHJva2Utd2lkdGg9IjEuNSIgc3Ryb2tlPSIjMDAwIiBmaWxsPSJub25lIi8+CiAgPGxpbmUgc3Ryb2tlPSIjNjY2NjY2IiBzdHJva2UtbGluZWNhcD0idW5kZWZpbmVkIiBzdHJva2UtbGluZWpvaW49InVuZGVmaW5lZCIgaWQ9InN2Z181IiB5Mj0iOS4xMDY5NTciIHgyPSIwLjk0NzI0NyIgeTE9Ii0wLjAxODEyOCIgeDE9IjAuOTQ3MjQ3IiBzdHJva2Utd2lkdGg9IjIiIGZpbGw9Im5vbmUiLz4KICA8bGluZSBzdHJva2UtbGluZWNhcD0idW5kZWZpbmVkIiBzdHJva2UtbGluZWpvaW49InVuZGVmaW5lZCIgaWQ9InN2Z183IiB5Mj0iOSIgeDI9IjEwLjA3MzUyOSIgeTE9IjkiIHgxPSItMC42NTU2NCIgc3Ryb2tlLXdpZHRoPSIyIiBzdHJva2U9IiM2NjY2NjYiIGZpbGw9Im5vbmUiLz4KIDwvZz4KPC9zdmc+);\r\n        background-position: bottom left;\r\n        padding-left: 3px;\r\n        background-repeat: no-repeat;\r\n        background-origin: content-box;\r\n        cursor: sw-resize;\r\n        right: auto;\r\n    }\r\n</style>\r\n<script>\r\n    import {setTopLeft, setTopRight, setTransformRtl, setTransform, createMarkup, getLayoutItem} from './utils';\r\n    import {getControlPosition, offsetXYFromParentOf, createCoreData} from './draggableUtils';\r\n    //    var eventBus = require('./eventBus');\r\n\r\n    var interact = require(\"interactjs\");\r\n\r\n    export default {\r\n        name: \"GridItem\",\r\n        props: {\r\n            /*cols: {\r\n             type: Number,\r\n             required: true\r\n             },*/\r\n            /*containerWidth: {\r\n             type: Number,\r\n             required: true\r\n\r\n             },\r\n             rowHeight: {\r\n             type: Number,\r\n             required: true\r\n             },\r\n             margin: {\r\n             type: Array,\r\n             required: true\r\n             },\r\n             maxRows: {\r\n             type: Number,\r\n             required: true\r\n             },*/\r\n            isDraggable: {\r\n                type: Boolean,\r\n                required: false,\r\n                default: null\r\n            },\r\n            isResizable: {\r\n                type: Boolean,\r\n                required: false,\r\n                default: null\r\n            },\r\n            /*useCssTransforms: {\r\n             type: Boolean,\r\n             required: true\r\n             },\r\n             static: {\r\n             type: Boolean,\r\n             required: false,\r\n             default: false\r\n             },\r\n             */\r\n            minH: {\r\n                type: Number,\r\n                required: false,\r\n                default: 1\r\n            },\r\n            minW: {\r\n                type: Number,\r\n                required: false,\r\n                default: 1\r\n            },\r\n            maxH: {\r\n                type: Number,\r\n                required: false,\r\n                default: Infinity\r\n            },\r\n            maxW: {\r\n                type: Number,\r\n                required: false,\r\n                default: Infinity\r\n            },\r\n            x: {\r\n                type: Number,\r\n                required: true\r\n            },\r\n            y: {\r\n                type: Number,\r\n                required: true\r\n            },\r\n            w: {\r\n                type: Number,\r\n                required: true\r\n            },\r\n            h: {\r\n                type: Number,\r\n                required: true\r\n            },\r\n            i: {\r\n                required: true\r\n            },\r\n            dragIgnoreFrom: {\r\n                type: String,\r\n                required: false,\r\n                default: 'a, button'\r\n            },\r\n            dragAllowFrom: {\r\n                type: String,\r\n                required: false,\r\n                default: null\r\n            },\r\n            resizeIgnoreFrom: {\r\n                type: String,\r\n                required: false,\r\n                default: 'a, button'\r\n            },\r\n        },\r\n        inject: [\"eventBus\"],\r\n        data: function () {\r\n            return {\r\n                cols: 1,\r\n                containerWidth: 100,\r\n                rowHeight: 30,\r\n                margin: [10, 10],\r\n                maxRows: Infinity,\r\n                draggable: null,\r\n                resizable: null,\r\n                useCssTransforms: true,\r\n\r\n                isDragging: false,\r\n                dragging: null,\r\n                isResizing: false,\r\n                resizing: null,\r\n                lastX: NaN,\r\n                lastY: NaN,\r\n                lastW: NaN,\r\n                lastH: NaN,\r\n                style: {},\r\n                rtl: false,\r\n\r\n                dragEventSet: false,\r\n                resizeEventSet: false,\r\n\r\n                previousW: null,\r\n                previousH: null,\r\n                previousX: null,\r\n                previousY: null,\r\n            }\r\n        },\r\n        created () {\r\n            var self = this;\r\n\r\n            // Accessible refernces of functions for removing in beforeDestroy\r\n            self.updateWidthHandler = function (width) {\r\n                self.updateWidth(width);\r\n            };\r\n\r\n            self.compactHandler = function (layout) {\r\n                self.compact(layout);\r\n            };\r\n\r\n            self.setDraggableHandler = function (isDraggable) {\r\n                if (self.isDraggable === null) {\r\n                    self.draggable = isDraggable;\r\n                }\r\n            };\r\n\r\n            self.setResizableHandler = function (isResizable) {\r\n                if (self.isResizable === null) {\r\n                    self.resizable = isResizable;\r\n                }\r\n            };\r\n\r\n            self.setRowHeightHandler = function (rowHeight) {\r\n                self.rowHeight = rowHeight;\r\n            };\r\n\r\n            self.directionchangeHandler = (direction) => {\r\n                var direction = (document.dir !== undefined) ?\r\n                    document.dir :\r\n                    document.getElementsByTagName(\"html\")[0].getAttribute(\"dir\");\r\n                this.rtl = (direction === \"rtl\");\r\n                this.compact();\r\n            };\r\n\r\n            this.eventBus.$on('updateWidth', self.updateWidthHandler);\r\n            this.eventBus.$on('compact', self.compactHandler);\r\n            this.eventBus.$on('setDraggable', self.setDraggableHandler);\r\n            this.eventBus.$on('setResizable', self.setResizableHandler);\r\n            this.eventBus.$on('setRowHeight', self.setRowHeightHandler);\r\n            this.eventBus.$on('directionchange', self.directionchangeHandler);\r\n\r\n            /*this.eventBus.$on('setColNum', function(colNum) {\r\n             self.cols = colNum;\r\n             });*/\r\n            var direction = (document.dir !== undefined) ?\r\n                document.dir :\r\n                document.getElementsByTagName(\"html\")[0].getAttribute(\"dir\");\r\n            this.rtl = (direction === \"rtl\");\r\n        },\r\n        beforeDestroy: function(){\r\n            var self = this;\r\n            //Remove listeners\r\n            this.eventBus.$off('updateWidth', self.updateWidthHandler);\r\n            this.eventBus.$off('compact', self.compactHandler);\r\n            this.eventBus.$off('setDraggable', self.setDraggableHandler);\r\n            this.eventBus.$off('setResizable', self.setResizableHandler);\r\n            this.eventBus.$off('setRowHeight', self.setRowHeightHandler);\r\n            this.eventBus.$off('directionchange', self.directionchangeHandler);\r\n        },\r\n        mounted: function () {\r\n            this.cols = this.$parent.colNum;\r\n            this.rowHeight = this.$parent.rowHeight;\r\n            this.containerWidth = this.$parent.width !== null ? this.$parent.width : 100;\r\n            this.margin = this.$parent.margin !== undefined ? this.$parent.margin : [10, 10];\r\n            this.maxRows = this.$parent.maxRows;\r\n            if (this.isDraggable === null) {\r\n                this.draggable = this.$parent.isDraggable;\r\n            } else {\r\n                this.draggable = this.isDraggable;\r\n            }\r\n            if (this.isResizable === null) {\r\n                this.resizable = this.$parent.isResizable;\r\n            } else {\r\n                this.resizable = this.isResizable;\r\n            }\r\n            this.useCssTransforms = this.$parent.useCssTransforms;\r\n            this.createStyle();\r\n        },\r\n        watch: {\r\n            isDraggable: function () {\r\n                this.draggable = this.isDraggable;\r\n            },\r\n            draggable: function () {\r\n                var self = this;\r\n                if (this.interactObj === null || this.interactObj === undefined) {\r\n                    this.interactObj = interact(this.$refs.item);\r\n                }\r\n                if (this.draggable) {\r\n                    var opts = {\r\n                        ignoreFrom: this.dragIgnoreFrom,\r\n                        allowFrom: this.dragAllowFrom\r\n                    }\r\n                    this.interactObj.draggable(opts);\r\n                    /*this.interactObj.draggable({allowFrom: '.vue-draggable-handle'});*/\r\n                    if (!this.dragEventSet) {\r\n                        this.dragEventSet = true;\r\n                        this.interactObj.on('dragstart dragmove dragend', function (event) {\r\n                            self.handleDrag(event);\r\n                        });\r\n                    }\r\n                } else {\r\n                    this.interactObj.draggable({\r\n                        enabled: false\r\n                    });\r\n                }\r\n            },\r\n            isResizable: function () {\r\n                this.resizable = this.isResizable;\r\n            },\r\n            resizable: function () {\r\n                var self = this;\r\n                if (this.interactObj === null || this.interactObj === undefined) {\r\n                    this.interactObj = interact(this.$refs.item);\r\n                }\r\n                if (this.resizable) {\r\n                    var opts = {\r\n                        preserveAspectRatio: false,\r\n                        edges: {left: false, right: true, bottom: true, top: false},\r\n                        ignoreFrom: this.resizeIgnoreFrom\r\n                    };\r\n                    \r\n                    this.interactObj.resizable(opts);\r\n                    if (!this.resizeEventSet) {\r\n                        this.resizeEventSet = true;\r\n                        this.interactObj\r\n                            .on('resizestart resizemove resizeend', function (event) {\r\n                                self.handleResize(event);\r\n                            });\r\n                    }\r\n                } else {\r\n                    this.interactObj.resizable({\r\n                        enabled: false\r\n                    });\r\n                }\r\n            },\r\n            rowHeight: function () {\r\n                this.createStyle();\r\n            },\r\n            cols: function () {\r\n                this.createStyle();\r\n            },\r\n            containerWidth: function () {\r\n                this.createStyle();\r\n            },\r\n            x: function () {\r\n                this.createStyle();\r\n            },\r\n            y: function () {\r\n                this.createStyle();\r\n            },\r\n            h: function () {\r\n                this.createStyle();\r\n            },\r\n            w: function () {\r\n                this.createStyle();\r\n            },\r\n            renderRtl: function () {\r\n                this.createStyle();\r\n            }\r\n        },\r\n        computed: {\r\n            renderRtl() {\r\n                return (this.$parent.isMirrored) ? !this.rtl : this.rtl;\r\n            },\r\n            resizableHandleClass() {\r\n                if (this.renderRtl) {\r\n                    return 'vue-resizable-handle vue-rtl-resizable-handle';\r\n                } else {\r\n                    return 'vue-resizable-handle';\r\n                }\r\n            }\r\n        },\r\n        methods: {\r\n            createStyle: function () {\r\n                if (this.x + this.w > this.cols) {\r\n                    this.x = 0;\r\n                    this.w = this.cols;\r\n                }\r\n\r\n                var pos = this.calcPosition(this.x, this.y, this.w, this.h);\r\n\r\n                if (this.isDragging) {\r\n                    pos.top = this.dragging.top;\r\n//                    Add rtl support\r\n                    if (this.renderRtl) {\r\n                        pos.right = this.dragging.left;\r\n                    } else {\r\n                        pos.left = this.dragging.left;\r\n                    }\r\n                }\r\n                if (this.isResizing) {\r\n                    pos.width = this.resizing.width;\r\n                    pos.height = this.resizing.height;\r\n                }\r\n\r\n                let style;\r\n                // CSS Transforms support (default)\r\n                if (this.useCssTransforms) {\r\n//                    Add rtl support\r\n                    if (this.renderRtl) {\r\n                        style = setTransformRtl(pos.top, pos.right, pos.width, pos.height);\r\n                    } else {\r\n                        style = setTransform(pos.top, pos.left, pos.width, pos.height);\r\n                    }\r\n\r\n                } else { // top,left (slow)\r\n//                    Add rtl support\r\n                    if (this.renderRtl) {\r\n                        style = setTopRight(pos.top, pos.right, pos.width, pos.height);\r\n                    } else {\r\n                        style = setTopLeft(pos.top, pos.left, pos.width, pos.height);\r\n                    }\r\n                }\r\n                this.style = style;\r\n\r\n            },\r\n            handleResize: function (event) {\r\n                const position = getControlPosition(event);\r\n                // Get the current drag point from the event. This is used as the offset.\r\n                if (position == null) return; // not possible but satisfies flow\r\n                const {x, y} = position;\r\n\r\n                const newSize = {width: 0, height: 0};\r\n                switch (event.type) {\r\n                    case \"resizestart\":\r\n                        this.previousW = this.w;\r\n                        this.previousH = this.h;\r\n                        var pos = this.calcPosition(this.x, this.y, this.w, this.h);\r\n                        newSize.width = pos.width;\r\n                        newSize.height = pos.height;\r\n                        this.resizing = newSize;\r\n                        this.isResizing = true;\r\n                        break;\r\n                    case \"resizemove\":\r\n//                        console.log(\"### resize => \" + event.type + \", lastW=\" + this.lastW + \", lastH=\" + this.lastH);\r\n                        const coreEvent = createCoreData(this.lastW, this.lastH, x, y);\r\n                        if (this.renderRtl) {\r\n                            newSize.width = this.resizing.width - coreEvent.deltaX;\r\n                        } else {\r\n                            newSize.width = this.resizing.width + coreEvent.deltaX;\r\n                        }\r\n                        newSize.height = this.resizing.height + coreEvent.deltaY;\r\n\r\n                        ///console.log(\"### resize => \" + event.type + \", deltaX=\" + coreEvent.deltaX + \", deltaY=\" + coreEvent.deltaY);\r\n                        this.resizing = newSize;\r\n                        break;\r\n                    case \"resizeend\":\r\n                        //console.log(\"### resize end => x=\" +this.x + \" y=\" + this.y + \" w=\" + this.w + \" h=\" + this.h);\r\n                        var pos = this.calcPosition(this.x, this.y, this.w, this.h);\r\n                        newSize.width = pos.width;\r\n                        newSize.height = pos.height;\r\n//                        console.log(\"### resize end => \" + JSON.stringify(newSize));\r\n                        this.resizing = null;\r\n                        this.isResizing = false;\r\n                        break;\r\n                }\r\n\r\n                // Get new WH\r\n                var pos = this.calcWH(newSize.height, newSize.width);\r\n                if (pos.w < this.minW) {\r\n                    pos.w = this.minW;\r\n                }\r\n                if (pos.w > this.maxW) {\r\n                    pos.w = this.maxW;\r\n                }\r\n                if (pos.h < this.minH) {\r\n                    pos.h = this.minH;\r\n                }\r\n                if (pos.h > this.maxH) {\r\n                    pos.h = this.maxH;\r\n                }\r\n\r\n                if (pos.h < 1) {\r\n                    pos.h = 1;\r\n                }\r\n                if (pos.w < 1) {\r\n                    pos.w = 1;\r\n                }\r\n\r\n                this.lastW = x;\r\n                this.lastH = y;\r\n\r\n                if (this.w !== pos.w || this.h !== pos.h) {\r\n                    this.$emit(\"resize\", this.i, pos.h, pos.w);\r\n                }\r\n                if (event.type === \"resizeend\" && (this.previousW !== this.w || this.previousH !== this.h)) {\r\n                    this.$emit(\"resized\", this.i, pos.h, pos.w, newSize.height, newSize.width);\r\n                }\r\n                this.eventBus.$emit(\"resizeEvent\", event.type, this.i, this.x, this.y, pos.h, pos.w);\r\n            },\r\n            handleDrag(event) {\r\n                if (this.isResizing) return;\r\n\r\n                const position = getControlPosition(event);\r\n\r\n                // Get the current drag point from the event. This is used as the offset.\r\n                if (position === null) return; // not possible but satisfies flow\r\n                const {x, y} = position;\r\n\r\n                var shouldUpdate = false;\r\n                const newPosition = {top: 0, left: 0};\r\n                switch (event.type) {\r\n                    case \"dragstart\":\r\n                        this.previousX = this.x;\r\n                        this.previousY = this.y;\r\n\r\n                        var parentRect = event.target.offsetParent.getBoundingClientRect();\r\n                        var clientRect = event.target.getBoundingClientRect();\r\n                        if (this.renderRtl) {\r\n                            newPosition.left = (clientRect.right - parentRect.right) * -1;\r\n                        } else {\r\n                            newPosition.left = clientRect.left - parentRect.left;\r\n                        }\r\n                        newPosition.top = clientRect.top - parentRect.top;\r\n                        this.dragging = newPosition;\r\n                        this.isDragging = true;\r\n                        break;\r\n                    case \"dragend\":\r\n                        if (!this.isDragging) return;\r\n                        parentRect = event.target.offsetParent.getBoundingClientRect();\r\n                        clientRect = event.target.getBoundingClientRect();\r\n//                        Add rtl support\r\n                        if (this.renderRtl) {\r\n                            newPosition.left = (clientRect.right - parentRect.right) * -1;\r\n                        } else {\r\n                            newPosition.left = clientRect.left - parentRect.left;\r\n                        }\r\n                        newPosition.top = clientRect.top - parentRect.top;\r\n//                        console.log(\"### drag end => \" + JSON.stringify(newPosition));\r\n//                        console.log(\"### DROP: \" + JSON.stringify(newPosition));\r\n                        this.dragging = null;\r\n                        this.isDragging = false;\r\n                        shouldUpdate = true;\r\n                        break;\r\n                    case \"dragmove\":\r\n                        const coreEvent = createCoreData(this.lastX, this.lastY, x, y);\r\n//                        Add rtl support\r\n                        if (this.renderRtl) {\r\n                            newPosition.left = this.dragging.left - coreEvent.deltaX;\r\n                        } else {\r\n                            newPosition.left = this.dragging.left + coreEvent.deltaX;\r\n                        }\r\n                        newPosition.top = this.dragging.top + coreEvent.deltaY;\r\n//                        console.log(\"### drag => \" + event.type + \", x=\" + x + \", y=\" + y);\r\n//                        console.log(\"### drag => \" + event.type + \", deltaX=\" + coreEvent.deltaX + \", deltaY=\" + coreEvent.deltaY);\r\n//                        console.log(\"### drag end => \" + JSON.stringify(newPosition));\r\n                        this.dragging = newPosition;\r\n                        break;\r\n                }\r\n\r\n                // Get new XY\r\n                if (this.renderRtl) {\r\n                    var pos = this.calcXY(newPosition.top, newPosition.left);\r\n                } else {\r\n                    var pos = this.calcXY(newPosition.top, newPosition.left);\r\n                }\r\n\r\n                this.lastX = x;\r\n                this.lastY = y;\r\n\r\n                if (this.x !== pos.x || this.y !== pos.y) {\r\n                    this.$emit(\"move\", this.i, pos.x, pos.y);\r\n                }\r\n                if (event.type === \"dragend\" && (this.previousX !== this.x || this.previousY !== this.y)) {\r\n                    this.$emit(\"moved\", this.i, pos.x, pos.y);\r\n                }\r\n                this.eventBus.$emit(\"dragEvent\", event.type, this.i, pos.x, pos.y, this.h, this.w);\r\n            },\r\n            calcPosition: function (x, y, w, h) {\r\n                const colWidth = this.calcColWidth();\r\n                // add rtl support\r\n                if (this.renderRtl) {\r\n                    var out = {\r\n                        right: Math.round(colWidth * x + (x + 1) * this.margin[0]),\r\n                        top: Math.round(this.rowHeight * y + (y + 1) * this.margin[1]),\r\n                        // 0 * Infinity === NaN, which causes problems with resize constriants;\r\n                        // Fix this if it occurs.\r\n                        // Note we do it here rather than later because Math.round(Infinity) causes deopt\r\n                        width: w === Infinity ? w : Math.round(colWidth * w + Math.max(0, w - 1) * this.margin[0]),\r\n                        height: h === Infinity ? h : Math.round(this.rowHeight * h + Math.max(0, h - 1) * this.margin[1])\r\n                    };\r\n                } else {\r\n                    var out = {\r\n                        left: Math.round(colWidth * x + (x + 1) * this.margin[0]),\r\n                        top: Math.round(this.rowHeight * y + (y + 1) * this.margin[1]),\r\n                        // 0 * Infinity === NaN, which causes problems with resize constriants;\r\n                        // Fix this if it occurs.\r\n                        // Note we do it here rather than later because Math.round(Infinity) causes deopt\r\n                        width: w === Infinity ? w : Math.round(colWidth * w + Math.max(0, w - 1) * this.margin[0]),\r\n                        height: h === Infinity ? h : Math.round(this.rowHeight * h + Math.max(0, h - 1) * this.margin[1])\r\n                    };\r\n                }\r\n\r\n\r\n                return out;\r\n            },\r\n            /**\r\n             * Translate x and y coordinates from pixels to grid units.\r\n             * @param  {Number} top  Top position (relative to parent) in pixels.\r\n             * @param  {Number} left Left position (relative to parent) in pixels.\r\n             * @return {Object} x and y in grid units.\r\n             */\r\n            // TODO check if this function needs change in order to support rtl.\r\n            calcXY(top, left) {\r\n                const colWidth = this.calcColWidth();\r\n\r\n                // left = colWidth * x + margin * (x + 1)\r\n                // l = cx + m(x+1)\r\n                // l = cx + mx + m\r\n                // l - m = cx + mx\r\n                // l - m = x(c + m)\r\n                // (l - m) / (c + m) = x\r\n                // x = (left - margin) / (coldWidth + margin)\r\n                let x = Math.round((left - this.margin[0]) / (colWidth + this.margin[0]));\r\n                let y = Math.round((top - this.margin[1]) / (this.rowHeight + this.margin[1]));\r\n\r\n                // Capping\r\n                x = Math.max(Math.min(x, this.cols - this.w), 0);\r\n                y = Math.max(Math.min(y, this.maxRows - this.h), 0);\r\n\r\n                return {x, y};\r\n            },\r\n            // Helper for generating column width\r\n            calcColWidth() {\r\n                var colWidth = (this.containerWidth - (this.margin[0] * (this.cols + 1))) / this.cols;\r\n//                console.log(\"### COLS=\" + this.cols + \" COL WIDTH=\" + colWidth);\r\n                return colWidth;\r\n            },\r\n\r\n            /**\r\n             * Given a height and width in pixel values, calculate grid units.\r\n             * @param  {Number} height Height in pixels.\r\n             * @param  {Number} width  Width in pixels.\r\n             * @return {Object} w, h as grid units.\r\n             */\r\n            calcWH(height, width) {\r\n                const colWidth = this.calcColWidth();\r\n\r\n                // width = colWidth * w - (margin * (w - 1))\r\n                // ...\r\n                // w = (width + margin) / (colWidth + margin)\r\n                let w = Math.round((width + this.margin[0]) / (colWidth + this.margin[0]));\r\n                let h = Math.round((height + this.margin[1]) / (this.rowHeight + this.margin[1]));\r\n\r\n                // Capping\r\n                w = Math.max(Math.min(w, this.cols - this.x), 0);\r\n                h = Math.max(Math.min(h, this.maxRows - this.y), 0);\r\n                return {w, h};\r\n            },\r\n            updateWidth: function (width, colNum) {\r\n                this.containerWidth = width;\r\n                if (colNum !== undefined && colNum !== null) {\r\n                    this.cols = colNum;\r\n                }\r\n            },\r\n            compact: function () {\r\n                this.createStyle();\r\n            }\r\n        },\r\n    }\r\n</script>\r\n\n\n\n// WEBPACK FOOTER //\n// GridItem.vue?bc3f11b4"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///13\n"); /***/ }), /* 14 */ /***/ (function(module, exports, __webpack_require__) { "use strict"; -eval("\n\nexports.__esModule = true;\n\nvar _utils = __webpack_require__(0);\n\nvar _draggableUtils = __webpack_require__(15);\n\n// var eventBus = require('./eventBus');\n\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n\nvar interact = __webpack_require__(16);\n\nexports.default = {\n name: \"GridItem\",\n props: {\n /*cols: {\n type: Number,\n required: true\n },*/\n /*containerWidth: {\n type: Number,\n required: true\n },\n rowHeight: {\n type: Number,\n required: true\n },\n margin: {\n type: Array,\n required: true\n },\n maxRows: {\n type: Number,\n required: true\n },*/\n isDraggable: {\n type: Boolean,\n required: false,\n default: null\n },\n isResizable: {\n type: Boolean,\n required: false,\n default: null\n },\n /*useCssTransforms: {\n type: Boolean,\n required: true\n },\n static: {\n type: Boolean,\n required: false,\n default: false\n },\n */\n minH: {\n type: Number,\n required: false,\n default: 1\n },\n minW: {\n type: Number,\n required: false,\n default: 1\n },\n maxH: {\n type: Number,\n required: false,\n default: Infinity\n },\n maxW: {\n type: Number,\n required: false,\n default: Infinity\n },\n x: {\n type: Number,\n required: true\n },\n y: {\n type: Number,\n required: true\n },\n w: {\n type: Number,\n required: true\n },\n h: {\n type: Number,\n required: true\n },\n i: {\n required: true\n },\n dragIgnoreFrom: {\n type: String,\n required: false,\n default: 'a, button'\n },\n dragAllowFrom: {\n type: String,\n required: false,\n default: null\n },\n resizeIgnoreFrom: {\n type: String,\n required: false,\n default: 'a, button'\n }\n },\n inject: [\"eventBus\"],\n data: function data() {\n return {\n cols: 1,\n containerWidth: 100,\n rowHeight: 30,\n margin: [10, 10],\n maxRows: Infinity,\n draggable: null,\n resizable: null,\n useCssTransforms: true,\n\n isDragging: false,\n dragging: null,\n isResizing: false,\n resizing: null,\n lastX: NaN,\n lastY: NaN,\n lastW: NaN,\n lastH: NaN,\n style: {},\n rtl: false,\n\n dragEventSet: false,\n resizeEventSet: false,\n\n previousW: null,\n previousH: null,\n previousX: null,\n previousY: null\n };\n },\n created: function created() {\n var _this = this;\n\n var self = this;\n\n // Accessible refernces of functions for removing in beforeDestroy\n self.updateWidthHandler = function (width) {\n self.updateWidth(width);\n };\n\n self.compactHandler = function (layout) {\n self.compact(layout);\n };\n\n self.setDraggableHandler = function (isDraggable) {\n if (self.isDraggable === null) {\n self.draggable = isDraggable;\n }\n };\n\n self.setResizableHandler = function (isResizable) {\n if (self.isResizable === null) {\n self.resizable = isResizable;\n }\n };\n\n self.setRowHeightHandler = function (rowHeight) {\n self.rowHeight = rowHeight;\n };\n\n self.directionchangeHandler = function (direction) {\n var direction = document.dir !== undefined ? document.dir : document.getElementsByTagName(\"html\")[0].getAttribute(\"dir\");\n _this.rtl = direction === \"rtl\";\n _this.compact();\n };\n\n this.eventBus.$on('updateWidth', self.updateWidthHandler);\n this.eventBus.$on('compact', self.compactHandler);\n this.eventBus.$on('setDraggable', self.setDraggableHandler);\n this.eventBus.$on('setResizable', self.setResizableHandler);\n this.eventBus.$on('setRowHeight', self.setRowHeightHandler);\n this.eventBus.$on('directionchange', self.directionchangeHandler);\n\n /*this.eventBus.$on('setColNum', function(colNum) {\n self.cols = colNum;\n });*/\n var direction = document.dir !== undefined ? document.dir : document.getElementsByTagName(\"html\")[0].getAttribute(\"dir\");\n this.rtl = direction === \"rtl\";\n },\n\n beforeDestroy: function beforeDestroy() {\n var self = this;\n //Remove listeners\n this.eventBus.$off('updateWidth', self.updateWidthHandler);\n this.eventBus.$off('compact', self.compactHandler);\n this.eventBus.$off('setDraggable', self.setDraggableHandler);\n this.eventBus.$off('setResizable', self.setResizableHandler);\n this.eventBus.$off('setRowHeight', self.setRowHeightHandler);\n this.eventBus.$off('directionchange', self.directionchangeHandler);\n },\n mounted: function mounted() {\n this.cols = this.$parent.colNum;\n this.rowHeight = this.$parent.rowHeight;\n this.containerWidth = this.$parent.width !== null ? this.$parent.width : 100;\n this.margin = this.$parent.margin !== undefined ? this.$parent.margin : [10, 10];\n this.maxRows = this.$parent.maxRows;\n if (this.isDraggable === null) {\n this.draggable = this.$parent.isDraggable;\n } else {\n this.draggable = this.isDraggable;\n }\n if (this.isResizable === null) {\n this.resizable = this.$parent.isResizable;\n } else {\n this.resizable = this.isResizable;\n }\n this.useCssTransforms = this.$parent.useCssTransforms;\n this.createStyle();\n },\n watch: {\n isDraggable: function isDraggable() {\n this.draggable = this.isDraggable;\n },\n draggable: function draggable() {\n var self = this;\n if (this.interactObj === null || this.interactObj === undefined) {\n this.interactObj = interact(this.$refs.item);\n }\n if (this.draggable) {\n var opts = {\n ignoreFrom: this.dragIgnoreFrom,\n allowFrom: this.dragAllowFrom\n };\n this.interactObj.draggable(opts);\n /*this.interactObj.draggable({allowFrom: '.vue-draggable-handle'});*/\n if (!this.dragEventSet) {\n this.dragEventSet = true;\n this.interactObj.on('dragstart dragmove dragend', function (event) {\n self.handleDrag(event);\n });\n }\n } else {\n this.interactObj.draggable({\n enabled: false\n });\n }\n },\n isResizable: function isResizable() {\n this.resizable = this.isResizable;\n },\n resizable: function resizable() {\n var self = this;\n if (this.interactObj === null || this.interactObj === undefined) {\n this.interactObj = interact(this.$refs.item);\n }\n if (this.resizable) {\n var opts = {\n preserveAspectRatio: false,\n edges: { left: false, right: true, bottom: true, top: false },\n ignoreFrom: this.resizeIgnoreFrom\n };\n\n this.interactObj.resizable(opts);\n if (!this.resizeEventSet) {\n this.resizeEventSet = true;\n this.interactObj.on('resizestart resizemove resizeend', function (event) {\n self.handleResize(event);\n });\n }\n } else {\n this.interactObj.resizable({\n enabled: false\n });\n }\n },\n rowHeight: function rowHeight() {\n this.createStyle();\n },\n cols: function cols() {\n this.createStyle();\n },\n containerWidth: function containerWidth() {\n this.createStyle();\n },\n x: function x() {\n this.createStyle();\n },\n y: function y() {\n this.createStyle();\n },\n h: function h() {\n this.createStyle();\n },\n w: function w() {\n this.createStyle();\n },\n renderRtl: function renderRtl() {\n this.createStyle();\n }\n },\n computed: {\n renderRtl: function renderRtl() {\n return this.$parent.isMirrored ? !this.rtl : this.rtl;\n },\n resizableHandleClass: function resizableHandleClass() {\n if (this.renderRtl) {\n return 'vue-resizable-handle vue-rtl-resizable-handle';\n } else {\n return 'vue-resizable-handle';\n }\n }\n },\n methods: {\n createStyle: function createStyle() {\n if (this.x + this.w > this.cols) {\n this.x = 0;\n this.w = this.cols;\n }\n\n var pos = this.calcPosition(this.x, this.y, this.w, this.h);\n\n if (this.isDragging) {\n pos.top = this.dragging.top;\n // Add rtl support\n if (this.renderRtl) {\n pos.right = this.dragging.left;\n } else {\n pos.left = this.dragging.left;\n }\n }\n if (this.isResizing) {\n pos.width = this.resizing.width;\n pos.height = this.resizing.height;\n }\n\n var style = void 0;\n // CSS Transforms support (default)\n if (this.useCssTransforms) {\n // Add rtl support\n if (this.renderRtl) {\n style = (0, _utils.setTransformRtl)(pos.top, pos.right, pos.width, pos.height);\n } else {\n style = (0, _utils.setTransform)(pos.top, pos.left, pos.width, pos.height);\n }\n } else {\n // top,left (slow)\n // Add rtl support\n if (this.renderRtl) {\n style = (0, _utils.setTopRight)(pos.top, pos.right, pos.width, pos.height);\n } else {\n style = (0, _utils.setTopLeft)(pos.top, pos.left, pos.width, pos.height);\n }\n }\n this.style = style;\n },\n handleResize: function handleResize(event) {\n var position = (0, _draggableUtils.getControlPosition)(event);\n // Get the current drag point from the event. This is used as the offset.\n if (position == null) return; // not possible but satisfies flow\n var x = position.x,\n y = position.y;\n\n\n var newSize = { width: 0, height: 0 };\n switch (event.type) {\n case \"resizestart\":\n this.previousW = this.w;\n this.previousH = this.h;\n var pos = this.calcPosition(this.x, this.y, this.w, this.h);\n newSize.width = pos.width;\n newSize.height = pos.height;\n this.resizing = newSize;\n this.isResizing = true;\n break;\n case \"resizemove\":\n // console.log(\"### resize => \" + event.type + \", lastW=\" + this.lastW + \", lastH=\" + this.lastH);\n var coreEvent = (0, _draggableUtils.createCoreData)(this.lastW, this.lastH, x, y);\n if (this.renderRtl) {\n newSize.width = this.resizing.width - coreEvent.deltaX;\n } else {\n newSize.width = this.resizing.width + coreEvent.deltaX;\n }\n newSize.height = this.resizing.height + coreEvent.deltaY;\n\n ///console.log(\"### resize => \" + event.type + \", deltaX=\" + coreEvent.deltaX + \", deltaY=\" + coreEvent.deltaY);\n this.resizing = newSize;\n break;\n case \"resizeend\":\n //console.log(\"### resize end => x=\" +this.x + \" y=\" + this.y + \" w=\" + this.w + \" h=\" + this.h);\n var pos = this.calcPosition(this.x, this.y, this.w, this.h);\n newSize.width = pos.width;\n newSize.height = pos.height;\n // console.log(\"### resize end => \" + JSON.stringify(newSize));\n this.resizing = null;\n this.isResizing = false;\n break;\n }\n\n // Get new WH\n var pos = this.calcWH(newSize.height, newSize.width);\n if (pos.w < this.minW) {\n pos.w = this.minW;\n }\n if (pos.w > this.maxW) {\n pos.w = this.maxW;\n }\n if (pos.h < this.minH) {\n pos.h = this.minH;\n }\n if (pos.h > this.maxH) {\n pos.h = this.maxH;\n }\n\n if (pos.h < 1) {\n pos.h = 1;\n }\n if (pos.w < 1) {\n pos.w = 1;\n }\n\n this.lastW = x;\n this.lastH = y;\n\n if (this.w !== pos.w || this.h !== pos.h) {\n this.$emit(\"resize\", this.i, pos.h, pos.w);\n }\n if (event.type === \"resizeend\" && (this.previousW !== this.w || this.previousH !== this.h)) {\n this.$emit(\"resized\", this.i, pos.h, pos.w, newSize.height, newSize.width);\n }\n this.eventBus.$emit(\"resizeEvent\", event.type, this.i, this.x, this.y, pos.h, pos.w);\n },\n handleDrag: function handleDrag(event) {\n if (this.isResizing) return;\n\n var position = (0, _draggableUtils.getControlPosition)(event);\n\n // Get the current drag point from the event. This is used as the offset.\n if (position === null) return; // not possible but satisfies flow\n var x = position.x,\n y = position.y;\n\n\n var shouldUpdate = false;\n var newPosition = { top: 0, left: 0 };\n switch (event.type) {\n case \"dragstart\":\n this.previousX = this.x;\n this.previousY = this.y;\n\n var parentRect = event.target.offsetParent.getBoundingClientRect();\n var clientRect = event.target.getBoundingClientRect();\n if (this.renderRtl) {\n newPosition.left = (clientRect.right - parentRect.right) * -1;\n } else {\n newPosition.left = clientRect.left - parentRect.left;\n }\n newPosition.top = clientRect.top - parentRect.top;\n this.dragging = newPosition;\n this.isDragging = true;\n break;\n case \"dragend\":\n if (!this.isDragging) return;\n parentRect = event.target.offsetParent.getBoundingClientRect();\n clientRect = event.target.getBoundingClientRect();\n // Add rtl support\n if (this.renderRtl) {\n newPosition.left = (clientRect.right - parentRect.right) * -1;\n } else {\n newPosition.left = clientRect.left - parentRect.left;\n }\n newPosition.top = clientRect.top - parentRect.top;\n // console.log(\"### drag end => \" + JSON.stringify(newPosition));\n // console.log(\"### DROP: \" + JSON.stringify(newPosition));\n this.dragging = null;\n this.isDragging = false;\n shouldUpdate = true;\n break;\n case \"dragmove\":\n var coreEvent = (0, _draggableUtils.createCoreData)(this.lastX, this.lastY, x, y);\n // Add rtl support\n if (this.renderRtl) {\n newPosition.left = this.dragging.left - coreEvent.deltaX;\n } else {\n newPosition.left = this.dragging.left + coreEvent.deltaX;\n }\n newPosition.top = this.dragging.top + coreEvent.deltaY;\n // console.log(\"### drag => \" + event.type + \", x=\" + x + \", y=\" + y);\n // console.log(\"### drag => \" + event.type + \", deltaX=\" + coreEvent.deltaX + \", deltaY=\" + coreEvent.deltaY);\n // console.log(\"### drag end => \" + JSON.stringify(newPosition));\n this.dragging = newPosition;\n break;\n }\n\n // Get new XY\n if (this.renderRtl) {\n var pos = this.calcXY(newPosition.top, newPosition.left);\n } else {\n var pos = this.calcXY(newPosition.top, newPosition.left);\n }\n\n this.lastX = x;\n this.lastY = y;\n\n if (this.x !== pos.x || this.y !== pos.y) {\n this.$emit(\"move\", this.i, pos.x, pos.y);\n }\n if (event.type === \"dragend\" && (this.previousX !== this.x || this.previousY !== this.y)) {\n this.$emit(\"moved\", this.i, pos.x, pos.y);\n }\n this.eventBus.$emit(\"dragEvent\", event.type, this.i, pos.x, pos.y, this.h, this.w);\n },\n\n calcPosition: function calcPosition(x, y, w, h) {\n var colWidth = this.calcColWidth();\n // add rtl support\n if (this.renderRtl) {\n var out = {\n right: Math.round(colWidth * x + (x + 1) * this.margin[0]),\n top: Math.round(this.rowHeight * y + (y + 1) * this.margin[1]),\n // 0 * Infinity === NaN, which causes problems with resize constriants;\n // Fix this if it occurs.\n // Note we do it here rather than later because Math.round(Infinity) causes deopt\n width: w === Infinity ? w : Math.round(colWidth * w + Math.max(0, w - 1) * this.margin[0]),\n height: h === Infinity ? h : Math.round(this.rowHeight * h + Math.max(0, h - 1) * this.margin[1])\n };\n } else {\n var out = {\n left: Math.round(colWidth * x + (x + 1) * this.margin[0]),\n top: Math.round(this.rowHeight * y + (y + 1) * this.margin[1]),\n // 0 * Infinity === NaN, which causes problems with resize constriants;\n // Fix this if it occurs.\n // Note we do it here rather than later because Math.round(Infinity) causes deopt\n width: w === Infinity ? w : Math.round(colWidth * w + Math.max(0, w - 1) * this.margin[0]),\n height: h === Infinity ? h : Math.round(this.rowHeight * h + Math.max(0, h - 1) * this.margin[1])\n };\n }\n\n return out;\n },\n /**\n * Translate x and y coordinates from pixels to grid units.\n * @param {Number} top Top position (relative to parent) in pixels.\n * @param {Number} left Left position (relative to parent) in pixels.\n * @return {Object} x and y in grid units.\n */\n // TODO check if this function needs change in order to support rtl.\n calcXY: function calcXY(top, left) {\n var colWidth = this.calcColWidth();\n\n // left = colWidth * x + margin * (x + 1)\n // l = cx + m(x+1)\n // l = cx + mx + m\n // l - m = cx + mx\n // l - m = x(c + m)\n // (l - m) / (c + m) = x\n // x = (left - margin) / (coldWidth + margin)\n var x = Math.round((left - this.margin[0]) / (colWidth + this.margin[0]));\n var y = Math.round((top - this.margin[1]) / (this.rowHeight + this.margin[1]));\n\n // Capping\n x = Math.max(Math.min(x, this.cols - this.w), 0);\n y = Math.max(Math.min(y, this.maxRows - this.h), 0);\n\n return { x: x, y: y };\n },\n\n // Helper for generating column width\n calcColWidth: function calcColWidth() {\n var colWidth = (this.containerWidth - this.margin[0] * (this.cols + 1)) / this.cols;\n // console.log(\"### COLS=\" + this.cols + \" COL WIDTH=\" + colWidth);\n return colWidth;\n },\n\n\n /**\n * Given a height and width in pixel values, calculate grid units.\n * @param {Number} height Height in pixels.\n * @param {Number} width Width in pixels.\n * @return {Object} w, h as grid units.\n */\n calcWH: function calcWH(height, width) {\n var colWidth = this.calcColWidth();\n\n // width = colWidth * w - (margin * (w - 1))\n // ...\n // w = (width + margin) / (colWidth + margin)\n var w = Math.round((width + this.margin[0]) / (colWidth + this.margin[0]));\n var h = Math.round((height + this.margin[1]) / (this.rowHeight + this.margin[1]));\n\n // Capping\n w = Math.max(Math.min(w, this.cols - this.x), 0);\n h = Math.max(Math.min(h, this.maxRows - this.y), 0);\n return { w: w, h: h };\n },\n\n updateWidth: function updateWidth(width, colNum) {\n this.containerWidth = width;\n if (colNum !== undefined && colNum !== null) {\n this.cols = colNum;\n }\n },\n compact: function compact() {\n this.createStyle();\n }\n }\n};\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack:///GridItem.vue?3a11"],"names":[],"mappings":";;;;AAgFA;;AACA;;AAEA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAJA;;mCAMA;;;UAEA;;AAKA;;;;AAiBA;;;;;;;;;;;;;;;;;kBAEA;sBACA;qBAEA;AAJA;;kBAMA;sBACA;qBAEA;AAJA;AAcA;;;;;;;;;;;kBAEA;sBACA;qBAEA;AAJA;;kBAMA;sBACA;qBAEA;AAJA;;kBAMA;sBACA;qBAEA;AAJA;;kBAMA;sBACA;qBAEA;AAJA;;kBAMA;sBAEA;AAHA;;kBAKA;sBAEA;AAHA;;kBAKA;sBAEA;AAHA;;kBAKA;sBAEA;AAHA;;sBAMA;AAFA;;kBAIA;sBACA;qBAEA;AAJA;;kBAMA;sBACA;qBAEA;AAJA;;kBAMA;sBACA;qBAGA;AALA;AA3FA;aAiGA;0BACA;;kBAEA;4BACA;uBACA;yBACA;qBACA;uBACA;uBACA;8BAEA;;wBACA;sBACA;wBACA;sBACA;mBACA;mBACA;mBACA;mBACA;mBACA;iBAEA;;0BACA;4BAEA;;uBACA;uBACA;uBACA;uBAEA;AA5BA;AA6BA;;AACA;;mBAEA;;AACA;mDACA;6BACA;AAEA;;gDACA;yBACA;AAEA;;0DACA;2CACA;iCACA;AACA;AAEA;;0DACA;2CACA;iCACA;AACA;AAEA;;wDACA;6BACA;AAEA;;2DACA;6CACA,qBACA,4DACA;sCACA;kBACA;AAEA;;8CACA;0CACA;+CACA;+CACA;+CACA;kDAEA;;AAGA;;;yCACA,qBACA,4DACA;iCACA;AACA;;4CACA;mBACA;AACA;+CACA;2CACA;gDACA;gDACA;gDACA;mDACA;AACA;gCACA;iCACA;sCACA;iFACA;qFACA;oCACA;uCACA;0CACA;eACA;kCACA;AACA;uCACA;0CACA;eACA;kCACA;AACA;6CACA;aACA;AACA;;4CAEA;kCACA;AACA;wCACA;uBACA;6EACA;uDACA;AACA;gCACA;;qCAEA;oCAEA;AAHA;2CAIA;AACA;wCACA;wCACA;uFACA;wCACA;AACA;AACA;mBACA;;6BAGA;AAFA;AAGA;AACA;4CACA;kCACA;AACA;wCACA;uBACA;6EACA;uDACA;AACA;gCACA;;yCAEA;0EACA;qCAGA;AALA;;2CAMA;0CACA;0CACA;yBACA,oEACA;0CACA;AACA;AACA;mBACA;;6BAGA;AAFA;AAGA;AACA;wCACA;iBACA;AACA;8BACA;iBACA;AACA;kDACA;iBACA;AACA;wBACA;iBACA;AACA;wBACA;iBACA;AACA;wBACA;iBACA;AACA;wBACA;iBACA;AACA;wCACA;iBACA;AAEA;AAjFA;;wCAmFA;8DACA;AACA;8DACA;gCACA;uBACA;mBACA;uBACA;AACA;AAEA;AAXA;;4CAaA;6CACA;yBACA;8BACA;AAEA;;qEAEA;;iCACA;;AAEA;oCACA;8CACA;uBACA;6CACA;AACA;AACA;iCACA;0CACA;2CACA;AAEA;;gBACA;AACA;;AAEA;oCACA;2FACA;uBACA;uFACA;AAEA;;;AAEA;oCACA;uFACA;uBACA;qFACA;AACA;AACA;yBAEA;AACA;;mEAEA;AACA;0CACA;AAHA,oBAKA;;;;8CACA;0BACA;qBACA;0CACA;0CACA;6EACA;wCACA;yCACA;oCACA;sCACA;AACA;;AAEA;mGACA;wCACA;wEACA;2BACA;wEACA;AACA;sEAEA;;AACA;oCACA;AACA;qBACA;AACA;6EACA;wCACA;;AAEA;oCACA;sCACA;AAGA;;;AACA;0DACA;mCACA;6BACA;AACA;mCACA;6BACA;AACA;mCACA;6BACA;AACA;mCACA;6BACA;AAEA;;2BACA;wBACA;AACA;2BACA;wBACA;AAEA;;yBACA;yBAEA;;sDACA;wDACA;AACA;wGACA;oFACA;AACA;8FACA;AACA;;iCAGA;;mEAEA;;AACA;2CACA;AANA,oBAQA;;;;+BACA;8CACA;0BACA;qBACA;0CACA;0CAEA;;+DACA;kDACA;wCACA;oFACA;2BACA;wEACA;AACA;kEACA;oCACA;sCACA;AACA;qBACA;0CACA;2DACA;;AAEA;wCACA;oFACA;2BACA;wEACA;AACA;;AACA;AAEA;oCACA;sCACA;mCACA;AACA;qBACA;;AAEA;wCACA;0EACA;2BACA;0EACA;AACA;;AACA;AACA;AAEA;oCACA;AAGA;;;AACA;gCACA;mEACA;mBACA;mEACA;AAEA;;yBACA;yBAEA;;sDACA;sDACA;AACA;sGACA;uDACA;AACA;4FACA;AACA;;wDACA;gCACA;AACA;gCACA;;2EAEA;+EACA;AACA;AACA;AACA;2GACA;kHAEA;AARA;mBASA;;0EAEA;+EACA;AACA;AACA;AACA;2GACA;kHAEA;AARA;AAWA;;mBACA;AACA;AAMA;;;;;;AACA;2CACA;gCAEA;;AACA;AACA;AACA;AACA;AACA;AACA;AACA;iFACA;sFAEA;;AACA;0DACA;6DAEA;;2BACA;AACA;;AACA;8CACA;;AAEA;mBACA;AAEA;;;AAMA;;;;;;+CACA;gCAEA;;AACA;AACA;AACA;kFACA;yFAEA;;AACA;0DACA;6DACA;2BACA;AACA;;yDACA;kCACA;yDACA;4BACA;AACA;AACA;oCACA;iBACA;AAEA;AA9RA;AAjTA","file":"14.js","sourcesContent":["<template>\n    <div ref=\"item\"\n         class=\"vue-grid-item\"\n         :class=\"{ 'vue-resizable' : resizable, 'resizing' : isResizing, 'vue-draggable-dragging' : isDragging, 'cssTransforms' : useCssTransforms, 'render-rtl' : renderRtl }\"\n         :style=\"style\"\n    >\n        <slot></slot>\n        <span v-if=\"resizable\" ref=\"handle\" :class=\"resizableHandleClass\"></span>\n        <!--<span v-if=\"draggable\" ref=\"dragHandle\" class=\"vue-draggable-handle\"></span>-->\n    </div>\n</template>\n<style>\n    .vue-grid-item {\n        transition: all 200ms ease;\n        transition-property: left, top, right;\n        /* add right for rtl */\n    }\n\n    .vue-grid-item.cssTransforms {\n        transition-property: transform;\n        left: 0;\n        right: auto;\n    }\n\n    .vue-grid-item.cssTransforms.render-rtl {\n        left: auto;\n        right: 0;\n    }\n\n    .vue-grid-item.resizing {\n        opacity: 0.6;\n        z-index: 3;\n    }\n\n    .vue-grid-item.vue-draggable-dragging {\n        transition:none;\n        z-index: 3;\n    }\n\n    .vue-grid-item.vue-grid-placeholder {\n        background: red;\n        opacity: 0.2;\n        transition-duration: 100ms;\n        z-index: 2;\n        -webkit-user-select: none;\n        -moz-user-select: none;\n        -ms-user-select: none;\n        -o-user-select: none;\n        user-select: none;\n    }\n\n    .vue-grid-item > .vue-resizable-handle {\n        position: absolute;\n        width: 20px;\n        height: 20px;\n        bottom: 0;\n        right: 0;\n        background: url('data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBzdGFuZGFsb25lPSJubyI/Pg08IS0tIEdlbmVyYXRvcjogQWRvYmUgRmlyZXdvcmtzIENTNiwgRXhwb3J0IFNWRyBFeHRlbnNpb24gYnkgQWFyb24gQmVhbGwgKGh0dHA6Ly9maXJld29ya3MuYWJlYWxsLmNvbSkgLiBWZXJzaW9uOiAwLjYuMSAgLS0+DTwhRE9DVFlQRSBzdmcgUFVCTElDICItLy9XM0MvL0RURCBTVkcgMS4xLy9FTiIgImh0dHA6Ly93d3cudzMub3JnL0dyYXBoaWNzL1NWRy8xLjEvRFREL3N2ZzExLmR0ZCI+DTxzdmcgaWQ9IlVudGl0bGVkLVBhZ2UlMjAxIiB2aWV3Qm94PSIwIDAgNiA2IiBzdHlsZT0iYmFja2dyb3VuZC1jb2xvcjojZmZmZmZmMDAiIHZlcnNpb249IjEuMSINCXhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIHhtbDpzcGFjZT0icHJlc2VydmUiDQl4PSIwcHgiIHk9IjBweCIgd2lkdGg9IjZweCIgaGVpZ2h0PSI2cHgiDT4NCTxnIG9wYWNpdHk9IjAuMzAyIj4NCQk8cGF0aCBkPSJNIDYgNiBMIDAgNiBMIDAgNC4yIEwgNCA0LjIgTCA0LjIgNC4yIEwgNC4yIDAgTCA2IDAgTCA2IDYgTCA2IDYgWiIgZmlsbD0iIzAwMDAwMCIvPg0JPC9nPg08L3N2Zz4=');\n        background-position: bottom right;\n        padding: 0 3px 3px 0;\n        background-repeat: no-repeat;\n        background-origin: content-box;\n        box-sizing: border-box;\n        cursor: se-resize;\n    }\n\n    .vue-grid-item > .vue-rtl-resizable-handle {\n        bottom: 0;\n        left: 0;\n        background: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMTAuMDAwMDAwMDAwMDAwMDAyIiBoZWlnaHQ9IjEwLjAwMDAwMDAwMDAwMDAwMiIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KIDwhLS0gQ3JlYXRlZCB3aXRoIE1ldGhvZCBEcmF3IC0gaHR0cDovL2dpdGh1Yi5jb20vZHVvcGl4ZWwvTWV0aG9kLURyYXcvIC0tPgogPGc+CiAgPHRpdGxlPmJhY2tncm91bmQ8L3RpdGxlPgogIDxyZWN0IGZpbGw9Im5vbmUiIGlkPSJjYW52YXNfYmFja2dyb3VuZCIgaGVpZ2h0PSIxMiIgd2lkdGg9IjEyIiB5PSItMSIgeD0iLTEiLz4KICA8ZyBkaXNwbGF5PSJub25lIiBvdmVyZmxvdz0idmlzaWJsZSIgeT0iMCIgeD0iMCIgaGVpZ2h0PSIxMDAlIiB3aWR0aD0iMTAwJSIgaWQ9ImNhbnZhc0dyaWQiPgogICA8cmVjdCBmaWxsPSJ1cmwoI2dyaWRwYXR0ZXJuKSIgc3Ryb2tlLXdpZHRoPSIwIiB5PSIwIiB4PSIwIiBoZWlnaHQ9IjEwMCUiIHdpZHRoPSIxMDAlIi8+CiAgPC9nPgogPC9nPgogPGc+CiAgPHRpdGxlPkxheWVyIDE8L3RpdGxlPgogIDxsaW5lIGNhbnZhcz0iI2ZmZmZmZiIgY2FudmFzLW9wYWNpdHk9IjEiIHN0cm9rZS1saW5lY2FwPSJ1bmRlZmluZWQiIHN0cm9rZS1saW5lam9pbj0idW5kZWZpbmVkIiBpZD0ic3ZnXzEiIHkyPSItNzAuMTc4NDA3IiB4Mj0iMTI0LjQ2NDE3NSIgeTE9Ii0zOC4zOTI3MzciIHgxPSIxNDQuODIxMjg5IiBzdHJva2Utd2lkdGg9IjEuNSIgc3Ryb2tlPSIjMDAwIiBmaWxsPSJub25lIi8+CiAgPGxpbmUgc3Ryb2tlPSIjNjY2NjY2IiBzdHJva2UtbGluZWNhcD0idW5kZWZpbmVkIiBzdHJva2UtbGluZWpvaW49InVuZGVmaW5lZCIgaWQ9InN2Z181IiB5Mj0iOS4xMDY5NTciIHgyPSIwLjk0NzI0NyIgeTE9Ii0wLjAxODEyOCIgeDE9IjAuOTQ3MjQ3IiBzdHJva2Utd2lkdGg9IjIiIGZpbGw9Im5vbmUiLz4KICA8bGluZSBzdHJva2UtbGluZWNhcD0idW5kZWZpbmVkIiBzdHJva2UtbGluZWpvaW49InVuZGVmaW5lZCIgaWQ9InN2Z183IiB5Mj0iOSIgeDI9IjEwLjA3MzUyOSIgeTE9IjkiIHgxPSItMC42NTU2NCIgc3Ryb2tlLXdpZHRoPSIyIiBzdHJva2U9IiM2NjY2NjYiIGZpbGw9Im5vbmUiLz4KIDwvZz4KPC9zdmc+);\n        background-position: bottom left;\n        padding-left: 3px;\n        background-repeat: no-repeat;\n        background-origin: content-box;\n        cursor: sw-resize;\n        right: auto;\n    }\n</style>\n<script>\n    import {setTopLeft, setTopRight, setTransformRtl, setTransform, createMarkup, getLayoutItem} from './utils';\n    import {getControlPosition, offsetXYFromParentOf, createCoreData} from './draggableUtils';\n    //    var eventBus = require('./eventBus');\n\n    var interact = require(\"interactjs\");\n\n    export default {\n        name: \"GridItem\",\n        props: {\n            /*cols: {\n             type: Number,\n             required: true\n             },*/\n            /*containerWidth: {\n             type: Number,\n             required: true\n\n             },\n             rowHeight: {\n             type: Number,\n             required: true\n             },\n             margin: {\n             type: Array,\n             required: true\n             },\n             maxRows: {\n             type: Number,\n             required: true\n             },*/\n            isDraggable: {\n                type: Boolean,\n                required: false,\n                default: null\n            },\n            isResizable: {\n                type: Boolean,\n                required: false,\n                default: null\n            },\n            /*useCssTransforms: {\n             type: Boolean,\n             required: true\n             },\n             static: {\n             type: Boolean,\n             required: false,\n             default: false\n             },\n             */\n            minH: {\n                type: Number,\n                required: false,\n                default: 1\n            },\n            minW: {\n                type: Number,\n                required: false,\n                default: 1\n            },\n            maxH: {\n                type: Number,\n                required: false,\n                default: Infinity\n            },\n            maxW: {\n                type: Number,\n                required: false,\n                default: Infinity\n            },\n            x: {\n                type: Number,\n                required: true\n            },\n            y: {\n                type: Number,\n                required: true\n            },\n            w: {\n                type: Number,\n                required: true\n            },\n            h: {\n                type: Number,\n                required: true\n            },\n            i: {\n                required: true\n            },\n            dragIgnoreFrom: {\n                type: String,\n                required: false,\n                default: 'a, button'\n            },\n            dragAllowFrom: {\n                type: String,\n                required: false,\n                default: null\n            },\n            resizeIgnoreFrom: {\n                type: String,\n                required: false,\n                default: 'a, button'\n            },\n        },\n        inject: [\"eventBus\"],\n        data: function () {\n            return {\n                cols: 1,\n                containerWidth: 100,\n                rowHeight: 30,\n                margin: [10, 10],\n                maxRows: Infinity,\n                draggable: null,\n                resizable: null,\n                useCssTransforms: true,\n\n                isDragging: false,\n                dragging: null,\n                isResizing: false,\n                resizing: null,\n                lastX: NaN,\n                lastY: NaN,\n                lastW: NaN,\n                lastH: NaN,\n                style: {},\n                rtl: false,\n\n                dragEventSet: false,\n                resizeEventSet: false,\n\n                previousW: null,\n                previousH: null,\n                previousX: null,\n                previousY: null,\n            }\n        },\n        created () {\n            var self = this;\n\n            // Accessible refernces of functions for removing in beforeDestroy\n            self.updateWidthHandler = function (width) {\n                self.updateWidth(width);\n            };\n\n            self.compactHandler = function (layout) {\n                self.compact(layout);\n            };\n\n            self.setDraggableHandler = function (isDraggable) {\n                if (self.isDraggable === null) {\n                    self.draggable = isDraggable;\n                }\n            };\n\n            self.setResizableHandler = function (isResizable) {\n                if (self.isResizable === null) {\n                    self.resizable = isResizable;\n                }\n            };\n\n            self.setRowHeightHandler = function (rowHeight) {\n                self.rowHeight = rowHeight;\n            };\n\n            self.directionchangeHandler = (direction) => {\n                var direction = (document.dir !== undefined) ?\n                    document.dir :\n                    document.getElementsByTagName(\"html\")[0].getAttribute(\"dir\");\n                this.rtl = (direction === \"rtl\");\n                this.compact();\n            };\n\n            this.eventBus.$on('updateWidth', self.updateWidthHandler);\n            this.eventBus.$on('compact', self.compactHandler);\n            this.eventBus.$on('setDraggable', self.setDraggableHandler);\n            this.eventBus.$on('setResizable', self.setResizableHandler);\n            this.eventBus.$on('setRowHeight', self.setRowHeightHandler);\n            this.eventBus.$on('directionchange', self.directionchangeHandler);\n\n            /*this.eventBus.$on('setColNum', function(colNum) {\n             self.cols = colNum;\n             });*/\n            var direction = (document.dir !== undefined) ?\n                document.dir :\n                document.getElementsByTagName(\"html\")[0].getAttribute(\"dir\");\n            this.rtl = (direction === \"rtl\");\n        },\n        beforeDestroy: function(){\n            var self = this;\n            //Remove listeners\n            this.eventBus.$off('updateWidth', self.updateWidthHandler);\n            this.eventBus.$off('compact', self.compactHandler);\n            this.eventBus.$off('setDraggable', self.setDraggableHandler);\n            this.eventBus.$off('setResizable', self.setResizableHandler);\n            this.eventBus.$off('setRowHeight', self.setRowHeightHandler);\n            this.eventBus.$off('directionchange', self.directionchangeHandler);\n        },\n        mounted: function () {\n            this.cols = this.$parent.colNum;\n            this.rowHeight = this.$parent.rowHeight;\n            this.containerWidth = this.$parent.width !== null ? this.$parent.width : 100;\n            this.margin = this.$parent.margin !== undefined ? this.$parent.margin : [10, 10];\n            this.maxRows = this.$parent.maxRows;\n            if (this.isDraggable === null) {\n                this.draggable = this.$parent.isDraggable;\n            } else {\n                this.draggable = this.isDraggable;\n            }\n            if (this.isResizable === null) {\n                this.resizable = this.$parent.isResizable;\n            } else {\n                this.resizable = this.isResizable;\n            }\n            this.useCssTransforms = this.$parent.useCssTransforms;\n            this.createStyle();\n        },\n        watch: {\n            isDraggable: function () {\n                this.draggable = this.isDraggable;\n            },\n            draggable: function () {\n                var self = this;\n                if (this.interactObj === null || this.interactObj === undefined) {\n                    this.interactObj = interact(this.$refs.item);\n                }\n                if (this.draggable) {\n                    var opts = {\n                        ignoreFrom: this.dragIgnoreFrom,\n                        allowFrom: this.dragAllowFrom\n                    }\n                    this.interactObj.draggable(opts);\n                    /*this.interactObj.draggable({allowFrom: '.vue-draggable-handle'});*/\n                    if (!this.dragEventSet) {\n                        this.dragEventSet = true;\n                        this.interactObj.on('dragstart dragmove dragend', function (event) {\n                            self.handleDrag(event);\n                        });\n                    }\n                } else {\n                    this.interactObj.draggable({\n                        enabled: false\n                    });\n                }\n            },\n            isResizable: function () {\n                this.resizable = this.isResizable;\n            },\n            resizable: function () {\n                var self = this;\n                if (this.interactObj === null || this.interactObj === undefined) {\n                    this.interactObj = interact(this.$refs.item);\n                }\n                if (this.resizable) {\n                    var opts = {\n                        preserveAspectRatio: false,\n                        edges: {left: false, right: true, bottom: true, top: false},\n                        ignoreFrom: this.resizeIgnoreFrom\n                    };\n                    \n                    this.interactObj.resizable(opts);\n                    if (!this.resizeEventSet) {\n                        this.resizeEventSet = true;\n                        this.interactObj\n                            .on('resizestart resizemove resizeend', function (event) {\n                                self.handleResize(event);\n                            });\n                    }\n                } else {\n                    this.interactObj.resizable({\n                        enabled: false\n                    });\n                }\n            },\n            rowHeight: function () {\n                this.createStyle();\n            },\n            cols: function () {\n                this.createStyle();\n            },\n            containerWidth: function () {\n                this.createStyle();\n            },\n            x: function () {\n                this.createStyle();\n            },\n            y: function () {\n                this.createStyle();\n            },\n            h: function () {\n                this.createStyle();\n            },\n            w: function () {\n                this.createStyle();\n            },\n            renderRtl: function () {\n                this.createStyle();\n            }\n        },\n        computed: {\n            renderRtl() {\n                return (this.$parent.isMirrored) ? !this.rtl : this.rtl;\n            },\n            resizableHandleClass() {\n                if (this.renderRtl) {\n                    return 'vue-resizable-handle vue-rtl-resizable-handle';\n                } else {\n                    return 'vue-resizable-handle';\n                }\n            }\n        },\n        methods: {\n            createStyle: function () {\n                if (this.x + this.w > this.cols) {\n                    this.x = 0;\n                    this.w = this.cols;\n                }\n\n                var pos = this.calcPosition(this.x, this.y, this.w, this.h);\n\n                if (this.isDragging) {\n                    pos.top = this.dragging.top;\n//                    Add rtl support\n                    if (this.renderRtl) {\n                        pos.right = this.dragging.left;\n                    } else {\n                        pos.left = this.dragging.left;\n                    }\n                }\n                if (this.isResizing) {\n                    pos.width = this.resizing.width;\n                    pos.height = this.resizing.height;\n                }\n\n                let style;\n                // CSS Transforms support (default)\n                if (this.useCssTransforms) {\n//                    Add rtl support\n                    if (this.renderRtl) {\n                        style = setTransformRtl(pos.top, pos.right, pos.width, pos.height);\n                    } else {\n                        style = setTransform(pos.top, pos.left, pos.width, pos.height);\n                    }\n\n                } else { // top,left (slow)\n//                    Add rtl support\n                    if (this.renderRtl) {\n                        style = setTopRight(pos.top, pos.right, pos.width, pos.height);\n                    } else {\n                        style = setTopLeft(pos.top, pos.left, pos.width, pos.height);\n                    }\n                }\n                this.style = style;\n\n            },\n            handleResize: function (event) {\n                const position = getControlPosition(event);\n                // Get the current drag point from the event. This is used as the offset.\n                if (position == null) return; // not possible but satisfies flow\n                const {x, y} = position;\n\n                const newSize = {width: 0, height: 0};\n                switch (event.type) {\n                    case \"resizestart\":\n                        this.previousW = this.w;\n                        this.previousH = this.h;\n                        var pos = this.calcPosition(this.x, this.y, this.w, this.h);\n                        newSize.width = pos.width;\n                        newSize.height = pos.height;\n                        this.resizing = newSize;\n                        this.isResizing = true;\n                        break;\n                    case \"resizemove\":\n//                        console.log(\"### resize => \" + event.type + \", lastW=\" + this.lastW + \", lastH=\" + this.lastH);\n                        const coreEvent = createCoreData(this.lastW, this.lastH, x, y);\n                        if (this.renderRtl) {\n                            newSize.width = this.resizing.width - coreEvent.deltaX;\n                        } else {\n                            newSize.width = this.resizing.width + coreEvent.deltaX;\n                        }\n                        newSize.height = this.resizing.height + coreEvent.deltaY;\n\n                        ///console.log(\"### resize => \" + event.type + \", deltaX=\" + coreEvent.deltaX + \", deltaY=\" + coreEvent.deltaY);\n                        this.resizing = newSize;\n                        break;\n                    case \"resizeend\":\n                        //console.log(\"### resize end => x=\" +this.x + \" y=\" + this.y + \" w=\" + this.w + \" h=\" + this.h);\n                        var pos = this.calcPosition(this.x, this.y, this.w, this.h);\n                        newSize.width = pos.width;\n                        newSize.height = pos.height;\n//                        console.log(\"### resize end => \" + JSON.stringify(newSize));\n                        this.resizing = null;\n                        this.isResizing = false;\n                        break;\n                }\n\n                // Get new WH\n                var pos = this.calcWH(newSize.height, newSize.width);\n                if (pos.w < this.minW) {\n                    pos.w = this.minW;\n                }\n                if (pos.w > this.maxW) {\n                    pos.w = this.maxW;\n                }\n                if (pos.h < this.minH) {\n                    pos.h = this.minH;\n                }\n                if (pos.h > this.maxH) {\n                    pos.h = this.maxH;\n                }\n\n                if (pos.h < 1) {\n                    pos.h = 1;\n                }\n                if (pos.w < 1) {\n                    pos.w = 1;\n                }\n\n                this.lastW = x;\n                this.lastH = y;\n\n                if (this.w !== pos.w || this.h !== pos.h) {\n                    this.$emit(\"resize\", this.i, pos.h, pos.w);\n                }\n                if (event.type === \"resizeend\" && (this.previousW !== this.w || this.previousH !== this.h)) {\n                    this.$emit(\"resized\", this.i, pos.h, pos.w, newSize.height, newSize.width);\n                }\n                this.eventBus.$emit(\"resizeEvent\", event.type, this.i, this.x, this.y, pos.h, pos.w);\n            },\n            handleDrag(event) {\n                if (this.isResizing) return;\n\n                const position = getControlPosition(event);\n\n                // Get the current drag point from the event. This is used as the offset.\n                if (position === null) return; // not possible but satisfies flow\n                const {x, y} = position;\n\n                var shouldUpdate = false;\n                const newPosition = {top: 0, left: 0};\n                switch (event.type) {\n                    case \"dragstart\":\n                        this.previousX = this.x;\n                        this.previousY = this.y;\n\n                        var parentRect = event.target.offsetParent.getBoundingClientRect();\n                        var clientRect = event.target.getBoundingClientRect();\n                        if (this.renderRtl) {\n                            newPosition.left = (clientRect.right - parentRect.right) * -1;\n                        } else {\n                            newPosition.left = clientRect.left - parentRect.left;\n                        }\n                        newPosition.top = clientRect.top - parentRect.top;\n                        this.dragging = newPosition;\n                        this.isDragging = true;\n                        break;\n                    case \"dragend\":\n                        if (!this.isDragging) return;\n                        parentRect = event.target.offsetParent.getBoundingClientRect();\n                        clientRect = event.target.getBoundingClientRect();\n//                        Add rtl support\n                        if (this.renderRtl) {\n                            newPosition.left = (clientRect.right - parentRect.right) * -1;\n                        } else {\n                            newPosition.left = clientRect.left - parentRect.left;\n                        }\n                        newPosition.top = clientRect.top - parentRect.top;\n//                        console.log(\"### drag end => \" + JSON.stringify(newPosition));\n//                        console.log(\"### DROP: \" + JSON.stringify(newPosition));\n                        this.dragging = null;\n                        this.isDragging = false;\n                        shouldUpdate = true;\n                        break;\n                    case \"dragmove\":\n                        const coreEvent = createCoreData(this.lastX, this.lastY, x, y);\n//                        Add rtl support\n                        if (this.renderRtl) {\n                            newPosition.left = this.dragging.left - coreEvent.deltaX;\n                        } else {\n                            newPosition.left = this.dragging.left + coreEvent.deltaX;\n                        }\n                        newPosition.top = this.dragging.top + coreEvent.deltaY;\n//                        console.log(\"### drag => \" + event.type + \", x=\" + x + \", y=\" + y);\n//                        console.log(\"### drag => \" + event.type + \", deltaX=\" + coreEvent.deltaX + \", deltaY=\" + coreEvent.deltaY);\n//                        console.log(\"### drag end => \" + JSON.stringify(newPosition));\n                        this.dragging = newPosition;\n                        break;\n                }\n\n                // Get new XY\n                if (this.renderRtl) {\n                    var pos = this.calcXY(newPosition.top, newPosition.left);\n                } else {\n                    var pos = this.calcXY(newPosition.top, newPosition.left);\n                }\n\n                this.lastX = x;\n                this.lastY = y;\n\n                if (this.x !== pos.x || this.y !== pos.y) {\n                    this.$emit(\"move\", this.i, pos.x, pos.y);\n                }\n                if (event.type === \"dragend\" && (this.previousX !== this.x || this.previousY !== this.y)) {\n                    this.$emit(\"moved\", this.i, pos.x, pos.y);\n                }\n                this.eventBus.$emit(\"dragEvent\", event.type, this.i, pos.x, pos.y, this.h, this.w);\n            },\n            calcPosition: function (x, y, w, h) {\n                const colWidth = this.calcColWidth();\n                // add rtl support\n                if (this.renderRtl) {\n                    var out = {\n                        right: Math.round(colWidth * x + (x + 1) * this.margin[0]),\n                        top: Math.round(this.rowHeight * y + (y + 1) * this.margin[1]),\n                        // 0 * Infinity === NaN, which causes problems with resize constriants;\n                        // Fix this if it occurs.\n                        // Note we do it here rather than later because Math.round(Infinity) causes deopt\n                        width: w === Infinity ? w : Math.round(colWidth * w + Math.max(0, w - 1) * this.margin[0]),\n                        height: h === Infinity ? h : Math.round(this.rowHeight * h + Math.max(0, h - 1) * this.margin[1])\n                    };\n                } else {\n                    var out = {\n                        left: Math.round(colWidth * x + (x + 1) * this.margin[0]),\n                        top: Math.round(this.rowHeight * y + (y + 1) * this.margin[1]),\n                        // 0 * Infinity === NaN, which causes problems with resize constriants;\n                        // Fix this if it occurs.\n                        // Note we do it here rather than later because Math.round(Infinity) causes deopt\n                        width: w === Infinity ? w : Math.round(colWidth * w + Math.max(0, w - 1) * this.margin[0]),\n                        height: h === Infinity ? h : Math.round(this.rowHeight * h + Math.max(0, h - 1) * this.margin[1])\n                    };\n                }\n\n\n                return out;\n            },\n            /**\n             * Translate x and y coordinates from pixels to grid units.\n             * @param  {Number} top  Top position (relative to parent) in pixels.\n             * @param  {Number} left Left position (relative to parent) in pixels.\n             * @return {Object} x and y in grid units.\n             */\n            // TODO check if this function needs change in order to support rtl.\n            calcXY(top, left) {\n                const colWidth = this.calcColWidth();\n\n                // left = colWidth * x + margin * (x + 1)\n                // l = cx + m(x+1)\n                // l = cx + mx + m\n                // l - m = cx + mx\n                // l - m = x(c + m)\n                // (l - m) / (c + m) = x\n                // x = (left - margin) / (coldWidth + margin)\n                let x = Math.round((left - this.margin[0]) / (colWidth + this.margin[0]));\n                let y = Math.round((top - this.margin[1]) / (this.rowHeight + this.margin[1]));\n\n                // Capping\n                x = Math.max(Math.min(x, this.cols - this.w), 0);\n                y = Math.max(Math.min(y, this.maxRows - this.h), 0);\n\n                return {x, y};\n            },\n            // Helper for generating column width\n            calcColWidth() {\n                var colWidth = (this.containerWidth - (this.margin[0] * (this.cols + 1))) / this.cols;\n//                console.log(\"### COLS=\" + this.cols + \" COL WIDTH=\" + colWidth);\n                return colWidth;\n            },\n\n            /**\n             * Given a height and width in pixel values, calculate grid units.\n             * @param  {Number} height Height in pixels.\n             * @param  {Number} width  Width in pixels.\n             * @return {Object} w, h as grid units.\n             */\n            calcWH(height, width) {\n                const colWidth = this.calcColWidth();\n\n                // width = colWidth * w - (margin * (w - 1))\n                // ...\n                // w = (width + margin) / (colWidth + margin)\n                let w = Math.round((width + this.margin[0]) / (colWidth + this.margin[0]));\n                let h = Math.round((height + this.margin[1]) / (this.rowHeight + this.margin[1]));\n\n                // Capping\n                w = Math.max(Math.min(w, this.cols - this.x), 0);\n                h = Math.max(Math.min(h, this.maxRows - this.y), 0);\n                return {w, h};\n            },\n            updateWidth: function (width, colNum) {\n                this.containerWidth = width;\n                if (colNum !== undefined && colNum !== null) {\n                    this.cols = colNum;\n                }\n            },\n            compact: function () {\n                this.createStyle();\n            }\n        },\n    }\n</script>\n\n\n\n// WEBPACK FOOTER //\n// GridItem.vue?37fa2adb"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///14\n"); +eval("\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.getControlPosition = getControlPosition;\nexports.offsetXYFromParentOf = offsetXYFromParentOf;\nexports.createCoreData = createCoreData;\n// Get {x, y} positions from event.\nfunction getControlPosition(e) {\n return offsetXYFromParentOf(e);\n}\n\n// Get from offsetParent\nfunction offsetXYFromParentOf(evt) {\n var offsetParent = evt.target.offsetParent || document.body;\n var offsetParentRect = evt.offsetParent === document.body ? { left: 0, top: 0 } : offsetParent.getBoundingClientRect();\n\n var x = evt.clientX + offsetParent.scrollLeft - offsetParentRect.left;\n var y = evt.clientY + offsetParent.scrollTop - offsetParentRect.top;\n\n /*const x = Math.round(evt.clientX + offsetParent.scrollLeft - offsetParentRect.left);\r\n const y = Math.round(evt.clientY + offsetParent.scrollTop - offsetParentRect.top);*/\n\n return { x: x, y: y };\n}\n\n// Create an data object exposed by 's events\nfunction createCoreData(lastX, lastY, x, y) {\n // State changes are often (but not always!) async. We want the latest value.\n var isStart = !isNum(lastX);\n\n if (isStart) {\n // If this is our first move, use the x and y as last coords.\n return {\n deltaX: 0, deltaY: 0,\n lastX: x, lastY: y,\n x: x, y: y\n };\n } else {\n // Otherwise calculate proper values.\n return {\n deltaX: x - lastX, deltaY: y - lastY,\n lastX: lastX, lastY: lastY,\n x: x, y: y\n };\n }\n}\n\nfunction isNum(num) {\n return typeof num === 'number' && !isNaN(num);\n}\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vLi9zcmMvZHJhZ2dhYmxlVXRpbHMuanM/YWQ2NyJdLCJuYW1lcyI6WyJnZXRDb250cm9sUG9zaXRpb24iLCJvZmZzZXRYWUZyb21QYXJlbnRPZiIsImNyZWF0ZUNvcmVEYXRhIiwiZSIsImV2dCIsIm9mZnNldFBhcmVudCIsInRhcmdldCIsImRvY3VtZW50IiwiYm9keSIsIm9mZnNldFBhcmVudFJlY3QiLCJsZWZ0IiwidG9wIiwiZ2V0Qm91bmRpbmdDbGllbnRSZWN0IiwieCIsImNsaWVudFgiLCJzY3JvbGxMZWZ0IiwieSIsImNsaWVudFkiLCJzY3JvbGxUb3AiLCJsYXN0WCIsImxhc3RZIiwiaXNTdGFydCIsImlzTnVtIiwiZGVsdGFYIiwiZGVsdGFZIiwibnVtIiwiaXNOYU4iXSwibWFwcGluZ3MiOiI7Ozs7O1FBQ2dCQSxrQixHQUFBQSxrQjtRQU1BQyxvQixHQUFBQSxvQjtRQWdCQUMsYyxHQUFBQSxjO0FBdkJoQjtBQUNPLFNBQVNGLGtCQUFULENBQTRCRyxDQUE1QixFQUErQjtBQUNsQyxXQUFPRixxQkFBcUJFLENBQXJCLENBQVA7QUFDSDs7QUFHRDtBQUNPLFNBQVNGLG9CQUFULENBQThCRyxHQUE5QixFQUFtQztBQUN0QyxRQUFNQyxlQUFlRCxJQUFJRSxNQUFKLENBQVdELFlBQVgsSUFBMkJFLFNBQVNDLElBQXpEO0FBQ0EsUUFBTUMsbUJBQW1CTCxJQUFJQyxZQUFKLEtBQXFCRSxTQUFTQyxJQUE5QixHQUFxQyxFQUFDRSxNQUFNLENBQVAsRUFBVUMsS0FBSyxDQUFmLEVBQXJDLEdBQXlETixhQUFhTyxxQkFBYixFQUFsRjs7QUFFQSxRQUFNQyxJQUFJVCxJQUFJVSxPQUFKLEdBQWNULGFBQWFVLFVBQTNCLEdBQXdDTixpQkFBaUJDLElBQW5FO0FBQ0EsUUFBTU0sSUFBSVosSUFBSWEsT0FBSixHQUFjWixhQUFhYSxTQUEzQixHQUF1Q1QsaUJBQWlCRSxHQUFsRTs7QUFFQTs7O0FBSUEsV0FBTyxFQUFDRSxJQUFELEVBQUlHLElBQUosRUFBUDtBQUNIOztBQUdEO0FBQ08sU0FBU2QsY0FBVCxDQUF3QmlCLEtBQXhCLEVBQStCQyxLQUEvQixFQUFzQ1AsQ0FBdEMsRUFBeUNHLENBQXpDLEVBQTRDO0FBQy9DO0FBQ0EsUUFBTUssVUFBVSxDQUFDQyxNQUFNSCxLQUFOLENBQWpCOztBQUVBLFFBQUlFLE9BQUosRUFBYTtBQUNUO0FBQ0EsZUFBTztBQUNIRSxvQkFBUSxDQURMLEVBQ1FDLFFBQVEsQ0FEaEI7QUFFSEwsbUJBQU9OLENBRkosRUFFT08sT0FBT0osQ0FGZDtBQUdISCxlQUFHQSxDQUhBLEVBR0dHLEdBQUdBO0FBSE4sU0FBUDtBQUtILEtBUEQsTUFPTztBQUNIO0FBQ0EsZUFBTztBQUNITyxvQkFBUVYsSUFBSU0sS0FEVCxFQUNnQkssUUFBUVIsSUFBSUksS0FENUI7QUFFSEQsbUJBQU9BLEtBRkosRUFFV0MsT0FBT0EsS0FGbEI7QUFHSFAsZUFBR0EsQ0FIQSxFQUdHRyxHQUFHQTtBQUhOLFNBQVA7QUFLSDtBQUNKOztBQUdELFNBQVNNLEtBQVQsQ0FBZUcsR0FBZixFQUFxQjtBQUNqQixXQUFPLE9BQU9BLEdBQVAsS0FBZSxRQUFmLElBQTJCLENBQUNDLE1BQU1ELEdBQU4sQ0FBbkM7QUFDSCIsImZpbGUiOiIxNC5qcyIsInNvdXJjZXNDb250ZW50IjpbIi8vIEdldCB7eCwgeX0gcG9zaXRpb25zIGZyb20gZXZlbnQuXHJcbmV4cG9ydCBmdW5jdGlvbiBnZXRDb250cm9sUG9zaXRpb24oZSkge1xyXG4gICAgcmV0dXJuIG9mZnNldFhZRnJvbVBhcmVudE9mKGUpO1xyXG59XHJcblxyXG5cclxuLy8gR2V0IGZyb20gb2Zmc2V0UGFyZW50XHJcbmV4cG9ydCBmdW5jdGlvbiBvZmZzZXRYWUZyb21QYXJlbnRPZihldnQpIHtcclxuICAgIGNvbnN0IG9mZnNldFBhcmVudCA9IGV2dC50YXJnZXQub2Zmc2V0UGFyZW50IHx8IGRvY3VtZW50LmJvZHk7XHJcbiAgICBjb25zdCBvZmZzZXRQYXJlbnRSZWN0ID0gZXZ0Lm9mZnNldFBhcmVudCA9PT0gZG9jdW1lbnQuYm9keSA/IHtsZWZ0OiAwLCB0b3A6IDB9IDogb2Zmc2V0UGFyZW50LmdldEJvdW5kaW5nQ2xpZW50UmVjdCgpO1xyXG5cclxuICAgIGNvbnN0IHggPSBldnQuY2xpZW50WCArIG9mZnNldFBhcmVudC5zY3JvbGxMZWZ0IC0gb2Zmc2V0UGFyZW50UmVjdC5sZWZ0O1xyXG4gICAgY29uc3QgeSA9IGV2dC5jbGllbnRZICsgb2Zmc2V0UGFyZW50LnNjcm9sbFRvcCAtIG9mZnNldFBhcmVudFJlY3QudG9wO1xyXG5cclxuICAgIC8qY29uc3QgeCA9IE1hdGgucm91bmQoZXZ0LmNsaWVudFggKyBvZmZzZXRQYXJlbnQuc2Nyb2xsTGVmdCAtIG9mZnNldFBhcmVudFJlY3QubGVmdCk7XHJcbiAgICBjb25zdCB5ID0gTWF0aC5yb3VuZChldnQuY2xpZW50WSArIG9mZnNldFBhcmVudC5zY3JvbGxUb3AgLSBvZmZzZXRQYXJlbnRSZWN0LnRvcCk7Ki9cclxuXHJcblxyXG4gICAgcmV0dXJuIHt4LCB5fTtcclxufVxyXG5cclxuXHJcbi8vIENyZWF0ZSBhbiBkYXRhIG9iamVjdCBleHBvc2VkIGJ5IDxEcmFnZ2FibGVDb3JlPidzIGV2ZW50c1xyXG5leHBvcnQgZnVuY3Rpb24gY3JlYXRlQ29yZURhdGEobGFzdFgsIGxhc3RZLCB4LCB5KSB7XHJcbiAgICAvLyBTdGF0ZSBjaGFuZ2VzIGFyZSBvZnRlbiAoYnV0IG5vdCBhbHdheXMhKSBhc3luYy4gV2Ugd2FudCB0aGUgbGF0ZXN0IHZhbHVlLlxyXG4gICAgY29uc3QgaXNTdGFydCA9ICFpc051bShsYXN0WCk7XHJcblxyXG4gICAgaWYgKGlzU3RhcnQpIHtcclxuICAgICAgICAvLyBJZiB0aGlzIGlzIG91ciBmaXJzdCBtb3ZlLCB1c2UgdGhlIHggYW5kIHkgYXMgbGFzdCBjb29yZHMuXHJcbiAgICAgICAgcmV0dXJuIHtcclxuICAgICAgICAgICAgZGVsdGFYOiAwLCBkZWx0YVk6IDAsXHJcbiAgICAgICAgICAgIGxhc3RYOiB4LCBsYXN0WTogeSxcclxuICAgICAgICAgICAgeDogeCwgeTogeVxyXG4gICAgICAgIH07XHJcbiAgICB9IGVsc2Uge1xyXG4gICAgICAgIC8vIE90aGVyd2lzZSBjYWxjdWxhdGUgcHJvcGVyIHZhbHVlcy5cclxuICAgICAgICByZXR1cm4ge1xyXG4gICAgICAgICAgICBkZWx0YVg6IHggLSBsYXN0WCwgZGVsdGFZOiB5IC0gbGFzdFksXHJcbiAgICAgICAgICAgIGxhc3RYOiBsYXN0WCwgbGFzdFk6IGxhc3RZLFxyXG4gICAgICAgICAgICB4OiB4LCB5OiB5XHJcbiAgICAgICAgfTtcclxuICAgIH1cclxufVxyXG5cclxuXHJcbmZ1bmN0aW9uIGlzTnVtKG51bSkgIHtcclxuICAgIHJldHVybiB0eXBlb2YgbnVtID09PSAnbnVtYmVyJyAmJiAhaXNOYU4obnVtKTtcclxufVxyXG5cclxuXG5cblxuLy8gV0VCUEFDSyBGT09URVIgLy9cbi8vIC4vc3JjL2RyYWdnYWJsZVV0aWxzLmpzIl0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///14\n"); /***/ }), /* 15 */ /***/ (function(module, exports, __webpack_require__) { -"use strict"; -eval("\n\nObject.defineProperty(exports, \"__esModule\", {\n value: true\n});\nexports.getControlPosition = getControlPosition;\nexports.offsetXYFromParentOf = offsetXYFromParentOf;\nexports.createCoreData = createCoreData;\n// Get {x, y} positions from event.\nfunction getControlPosition(e) {\n return offsetXYFromParentOf(e);\n}\n\n// Get from offsetParent\nfunction offsetXYFromParentOf(evt) {\n var offsetParent = evt.target.offsetParent || document.body;\n var offsetParentRect = evt.offsetParent === document.body ? { left: 0, top: 0 } : offsetParent.getBoundingClientRect();\n\n var x = evt.clientX + offsetParent.scrollLeft - offsetParentRect.left;\n var y = evt.clientY + offsetParent.scrollTop - offsetParentRect.top;\n\n /*const x = Math.round(evt.clientX + offsetParent.scrollLeft - offsetParentRect.left);\n const y = Math.round(evt.clientY + offsetParent.scrollTop - offsetParentRect.top);*/\n\n return { x: x, y: y };\n}\n\n// Create an data object exposed by 's events\nfunction createCoreData(lastX, lastY, x, y) {\n // State changes are often (but not always!) async. We want the latest value.\n var isStart = !isNum(lastX);\n\n if (isStart) {\n // If this is our first move, use the x and y as last coords.\n return {\n deltaX: 0, deltaY: 0,\n lastX: x, lastY: y,\n x: x, y: y\n };\n } else {\n // Otherwise calculate proper values.\n return {\n deltaX: x - lastX, deltaY: y - lastY,\n lastX: lastX, lastY: lastY,\n x: x, y: y\n };\n }\n}\n\nfunction isNum(num) {\n return typeof num === 'number' && !isNaN(num);\n}\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vLi9zcmMvZHJhZ2dhYmxlVXRpbHMuanM/YWQ2NyJdLCJuYW1lcyI6WyJnZXRDb250cm9sUG9zaXRpb24iLCJvZmZzZXRYWUZyb21QYXJlbnRPZiIsImNyZWF0ZUNvcmVEYXRhIiwiZSIsImV2dCIsIm9mZnNldFBhcmVudCIsInRhcmdldCIsImRvY3VtZW50IiwiYm9keSIsIm9mZnNldFBhcmVudFJlY3QiLCJsZWZ0IiwidG9wIiwiZ2V0Qm91bmRpbmdDbGllbnRSZWN0IiwieCIsImNsaWVudFgiLCJzY3JvbGxMZWZ0IiwieSIsImNsaWVudFkiLCJzY3JvbGxUb3AiLCJsYXN0WCIsImxhc3RZIiwiaXNTdGFydCIsImlzTnVtIiwiZGVsdGFYIiwiZGVsdGFZIiwibnVtIiwiaXNOYU4iXSwibWFwcGluZ3MiOiI7Ozs7O1FBQ2dCQSxrQixHQUFBQSxrQjtRQU1BQyxvQixHQUFBQSxvQjtRQWdCQUMsYyxHQUFBQSxjO0FBdkJoQjtBQUNPLFNBQVNGLGtCQUFULENBQTRCRyxDQUE1QixFQUErQjtBQUNsQyxXQUFPRixxQkFBcUJFLENBQXJCLENBQVA7QUFDSDs7QUFHRDtBQUNPLFNBQVNGLG9CQUFULENBQThCRyxHQUE5QixFQUFtQztBQUN0QyxRQUFNQyxlQUFlRCxJQUFJRSxNQUFKLENBQVdELFlBQVgsSUFBMkJFLFNBQVNDLElBQXpEO0FBQ0EsUUFBTUMsbUJBQW1CTCxJQUFJQyxZQUFKLEtBQXFCRSxTQUFTQyxJQUE5QixHQUFxQyxFQUFDRSxNQUFNLENBQVAsRUFBVUMsS0FBSyxDQUFmLEVBQXJDLEdBQXlETixhQUFhTyxxQkFBYixFQUFsRjs7QUFFQSxRQUFNQyxJQUFJVCxJQUFJVSxPQUFKLEdBQWNULGFBQWFVLFVBQTNCLEdBQXdDTixpQkFBaUJDLElBQW5FO0FBQ0EsUUFBTU0sSUFBSVosSUFBSWEsT0FBSixHQUFjWixhQUFhYSxTQUEzQixHQUF1Q1QsaUJBQWlCRSxHQUFsRTs7QUFFQTs7O0FBSUEsV0FBTyxFQUFDRSxJQUFELEVBQUlHLElBQUosRUFBUDtBQUNIOztBQUdEO0FBQ08sU0FBU2QsY0FBVCxDQUF3QmlCLEtBQXhCLEVBQStCQyxLQUEvQixFQUFzQ1AsQ0FBdEMsRUFBeUNHLENBQXpDLEVBQTRDO0FBQy9DO0FBQ0EsUUFBTUssVUFBVSxDQUFDQyxNQUFNSCxLQUFOLENBQWpCOztBQUVBLFFBQUlFLE9BQUosRUFBYTtBQUNUO0FBQ0EsZUFBTztBQUNIRSxvQkFBUSxDQURMLEVBQ1FDLFFBQVEsQ0FEaEI7QUFFSEwsbUJBQU9OLENBRkosRUFFT08sT0FBT0osQ0FGZDtBQUdISCxlQUFHQSxDQUhBLEVBR0dHLEdBQUdBO0FBSE4sU0FBUDtBQUtILEtBUEQsTUFPTztBQUNIO0FBQ0EsZUFBTztBQUNITyxvQkFBUVYsSUFBSU0sS0FEVCxFQUNnQkssUUFBUVIsSUFBSUksS0FENUI7QUFFSEQsbUJBQU9BLEtBRkosRUFFV0MsT0FBT0EsS0FGbEI7QUFHSFAsZUFBR0EsQ0FIQSxFQUdHRyxHQUFHQTtBQUhOLFNBQVA7QUFLSDtBQUNKOztBQUdELFNBQVNNLEtBQVQsQ0FBZUcsR0FBZixFQUFxQjtBQUNqQixXQUFPLE9BQU9BLEdBQVAsS0FBZSxRQUFmLElBQTJCLENBQUNDLE1BQU1ELEdBQU4sQ0FBbkM7QUFDSCIsImZpbGUiOiIxNS5qcyIsInNvdXJjZXNDb250ZW50IjpbIi8vIEdldCB7eCwgeX0gcG9zaXRpb25zIGZyb20gZXZlbnQuXG5leHBvcnQgZnVuY3Rpb24gZ2V0Q29udHJvbFBvc2l0aW9uKGUpIHtcbiAgICByZXR1cm4gb2Zmc2V0WFlGcm9tUGFyZW50T2YoZSk7XG59XG5cblxuLy8gR2V0IGZyb20gb2Zmc2V0UGFyZW50XG5leHBvcnQgZnVuY3Rpb24gb2Zmc2V0WFlGcm9tUGFyZW50T2YoZXZ0KSB7XG4gICAgY29uc3Qgb2Zmc2V0UGFyZW50ID0gZXZ0LnRhcmdldC5vZmZzZXRQYXJlbnQgfHwgZG9jdW1lbnQuYm9keTtcbiAgICBjb25zdCBvZmZzZXRQYXJlbnRSZWN0ID0gZXZ0Lm9mZnNldFBhcmVudCA9PT0gZG9jdW1lbnQuYm9keSA/IHtsZWZ0OiAwLCB0b3A6IDB9IDogb2Zmc2V0UGFyZW50LmdldEJvdW5kaW5nQ2xpZW50UmVjdCgpO1xuXG4gICAgY29uc3QgeCA9IGV2dC5jbGllbnRYICsgb2Zmc2V0UGFyZW50LnNjcm9sbExlZnQgLSBvZmZzZXRQYXJlbnRSZWN0LmxlZnQ7XG4gICAgY29uc3QgeSA9IGV2dC5jbGllbnRZICsgb2Zmc2V0UGFyZW50LnNjcm9sbFRvcCAtIG9mZnNldFBhcmVudFJlY3QudG9wO1xuXG4gICAgLypjb25zdCB4ID0gTWF0aC5yb3VuZChldnQuY2xpZW50WCArIG9mZnNldFBhcmVudC5zY3JvbGxMZWZ0IC0gb2Zmc2V0UGFyZW50UmVjdC5sZWZ0KTtcbiAgICBjb25zdCB5ID0gTWF0aC5yb3VuZChldnQuY2xpZW50WSArIG9mZnNldFBhcmVudC5zY3JvbGxUb3AgLSBvZmZzZXRQYXJlbnRSZWN0LnRvcCk7Ki9cblxuXG4gICAgcmV0dXJuIHt4LCB5fTtcbn1cblxuXG4vLyBDcmVhdGUgYW4gZGF0YSBvYmplY3QgZXhwb3NlZCBieSA8RHJhZ2dhYmxlQ29yZT4ncyBldmVudHNcbmV4cG9ydCBmdW5jdGlvbiBjcmVhdGVDb3JlRGF0YShsYXN0WCwgbGFzdFksIHgsIHkpIHtcbiAgICAvLyBTdGF0ZSBjaGFuZ2VzIGFyZSBvZnRlbiAoYnV0IG5vdCBhbHdheXMhKSBhc3luYy4gV2Ugd2FudCB0aGUgbGF0ZXN0IHZhbHVlLlxuICAgIGNvbnN0IGlzU3RhcnQgPSAhaXNOdW0obGFzdFgpO1xuXG4gICAgaWYgKGlzU3RhcnQpIHtcbiAgICAgICAgLy8gSWYgdGhpcyBpcyBvdXIgZmlyc3QgbW92ZSwgdXNlIHRoZSB4IGFuZCB5IGFzIGxhc3QgY29vcmRzLlxuICAgICAgICByZXR1cm4ge1xuICAgICAgICAgICAgZGVsdGFYOiAwLCBkZWx0YVk6IDAsXG4gICAgICAgICAgICBsYXN0WDogeCwgbGFzdFk6IHksXG4gICAgICAgICAgICB4OiB4LCB5OiB5XG4gICAgICAgIH07XG4gICAgfSBlbHNlIHtcbiAgICAgICAgLy8gT3RoZXJ3aXNlIGNhbGN1bGF0ZSBwcm9wZXIgdmFsdWVzLlxuICAgICAgICByZXR1cm4ge1xuICAgICAgICAgICAgZGVsdGFYOiB4IC0gbGFzdFgsIGRlbHRhWTogeSAtIGxhc3RZLFxuICAgICAgICAgICAgbGFzdFg6IGxhc3RYLCBsYXN0WTogbGFzdFksXG4gICAgICAgICAgICB4OiB4LCB5OiB5XG4gICAgICAgIH07XG4gICAgfVxufVxuXG5cbmZ1bmN0aW9uIGlzTnVtKG51bSkgIHtcbiAgICByZXR1cm4gdHlwZW9mIG51bSA9PT0gJ251bWJlcicgJiYgIWlzTmFOKG51bSk7XG59XG5cblxuXG5cbi8vIFdFQlBBQ0sgRk9PVEVSIC8vXG4vLyAuL3NyYy9kcmFnZ2FibGVVdGlscy5qcyJdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///15\n"); +eval("var require;var require;/**\r\n * interact.js v1.3.0-alpha.4+sha.7970416-dirty\r\n *\r\n * Copyright (c) 2012-2017 Taye Adeyemi \r\n * Open source under the MIT License.\r\n * https://raw.github.com/taye/interact.js/master/LICENSE\r\n */\r\n(function(f){if(true){module.exports=f()}else if(typeof define===\"function\"&&define.amd){define([],f)}else{var g;if(typeof window!==\"undefined\"){g=window}else if(typeof global!==\"undefined\"){g=global}else if(typeof self!==\"undefined\"){g=self}else{g=this}g.interact = f()}})(function(){var define,module,exports;return (function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require==\"function\"&&require;if(!u&&a)return require(o,!0);if(i)return i(o,!0);var f=new Error(\"Cannot find module '\"+o+\"'\");throw f.code=\"MODULE_NOT_FOUND\",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require==\"function\"&&require;for(var o=0;o 6 && arguments[6] !== undefined ? arguments[6] : false;\r\n\r\n _classCallCheck(this, InteractEvent);\r\n\r\n var target = interaction.target;\r\n var deltaSource = (target && target.options || defaults).deltaSource;\r\n var origin = getOriginXY(target, element, action);\r\n var starting = phase === 'start';\r\n var ending = phase === 'end';\r\n var coords = starting ? interaction.startCoords : interaction.curCoords;\r\n var prevEvent = interaction.prevEvent;\r\n\r\n element = element || interaction.element;\r\n\r\n var page = extend({}, coords.page);\r\n var client = extend({}, coords.client);\r\n\r\n page.x -= origin.x;\r\n page.y -= origin.y;\r\n\r\n client.x -= origin.x;\r\n client.y -= origin.y;\r\n\r\n this.ctrlKey = event.ctrlKey;\r\n this.altKey = event.altKey;\r\n this.shiftKey = event.shiftKey;\r\n this.metaKey = event.metaKey;\r\n this.button = event.button;\r\n this.buttons = event.buttons;\r\n this.target = element;\r\n this.currentTarget = element;\r\n this.relatedTarget = related || null;\r\n this.preEnd = preEnd;\r\n this.type = action + (phase || '');\r\n this.interaction = interaction;\r\n this.interactable = target;\r\n\r\n this.t0 = starting ? interaction.downTimes[interaction.downTimes.length - 1] : prevEvent.t0;\r\n\r\n var signalArg = {\r\n interaction: interaction,\r\n event: event,\r\n action: action,\r\n phase: phase,\r\n element: element,\r\n related: related,\r\n page: page,\r\n client: client,\r\n coords: coords,\r\n starting: starting,\r\n ending: ending,\r\n deltaSource: deltaSource,\r\n iEvent: this\r\n };\r\n\r\n signals.fire('set-xy', signalArg);\r\n\r\n if (ending) {\r\n // use previous coords when ending\r\n this.pageX = prevEvent.pageX;\r\n this.pageY = prevEvent.pageY;\r\n this.clientX = prevEvent.clientX;\r\n this.clientY = prevEvent.clientY;\r\n } else {\r\n this.pageX = page.x;\r\n this.pageY = page.y;\r\n this.clientX = client.x;\r\n this.clientY = client.y;\r\n }\r\n\r\n this.x0 = interaction.startCoords.page.x - origin.x;\r\n this.y0 = interaction.startCoords.page.y - origin.y;\r\n this.clientX0 = interaction.startCoords.client.x - origin.x;\r\n this.clientY0 = interaction.startCoords.client.y - origin.y;\r\n\r\n signals.fire('set-delta', signalArg);\r\n\r\n this.timeStamp = coords.timeStamp;\r\n this.dt = interaction.pointerDelta.timeStamp;\r\n this.duration = this.timeStamp - this.t0;\r\n\r\n // speed and velocity in pixels per second\r\n this.speed = interaction.pointerDelta[deltaSource].speed;\r\n this.velocityX = interaction.pointerDelta[deltaSource].vx;\r\n this.velocityY = interaction.pointerDelta[deltaSource].vy;\r\n\r\n this.swipe = ending || phase === 'inertiastart' ? this.getSwipe() : null;\r\n\r\n signals.fire('new', signalArg);\r\n }\r\n\r\n InteractEvent.prototype.getSwipe = function getSwipe() {\r\n var interaction = this.interaction;\r\n\r\n if (interaction.prevEvent.speed < 600 || this.timeStamp - interaction.prevEvent.timeStamp > 150) {\r\n return null;\r\n }\r\n\r\n var angle = 180 * Math.atan2(interaction.prevEvent.velocityY, interaction.prevEvent.velocityX) / Math.PI;\r\n var overlap = 22.5;\r\n\r\n if (angle < 0) {\r\n angle += 360;\r\n }\r\n\r\n var left = 135 - overlap <= angle && angle < 225 + overlap;\r\n var up = 225 - overlap <= angle && angle < 315 + overlap;\r\n\r\n var right = !left && (315 - overlap <= angle || angle < 45 + overlap);\r\n var down = !up && 45 - overlap <= angle && angle < 135 + overlap;\r\n\r\n return {\r\n up: up,\r\n down: down,\r\n left: left,\r\n right: right,\r\n angle: angle,\r\n speed: interaction.prevEvent.speed,\r\n velocity: {\r\n x: interaction.prevEvent.velocityX,\r\n y: interaction.prevEvent.velocityY\r\n }\r\n };\r\n };\r\n\r\n InteractEvent.prototype.preventDefault = function preventDefault() {};\r\n\r\n InteractEvent.prototype.stopImmediatePropagation = function stopImmediatePropagation() {\r\n this.immediatePropagationStopped = this.propagationStopped = true;\r\n };\r\n\r\n InteractEvent.prototype.stopPropagation = function stopPropagation() {\r\n this.propagationStopped = true;\r\n };\r\n\r\n return InteractEvent;\r\n}();\r\n\r\nsignals.on('set-delta', function (_ref) {\r\n var iEvent = _ref.iEvent,\r\n interaction = _ref.interaction,\r\n starting = _ref.starting,\r\n deltaSource = _ref.deltaSource;\r\n\r\n var prevEvent = starting ? iEvent : interaction.prevEvent;\r\n\r\n if (deltaSource === 'client') {\r\n iEvent.dx = iEvent.clientX - prevEvent.clientX;\r\n iEvent.dy = iEvent.clientY - prevEvent.clientY;\r\n } else {\r\n iEvent.dx = iEvent.pageX - prevEvent.pageX;\r\n iEvent.dy = iEvent.pageY - prevEvent.pageY;\r\n }\r\n});\r\n\r\nInteractEvent.signals = signals;\r\n\r\nmodule.exports = InteractEvent;\r\n\r\n},{\"./defaultOptions\":18,\"./utils/Signals\":35,\"./utils/extend\":41,\"./utils/getOriginXY\":42}],4:[function(require,module,exports){\r\n'use strict';\r\n\r\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\r\n\r\nvar is = require('./utils/is');\r\nvar events = require('./utils/events');\r\nvar extend = require('./utils/extend');\r\nvar actions = require('./actions/base');\r\nvar scope = require('./scope');\r\nvar Eventable = require('./Eventable');\r\nvar defaults = require('./defaultOptions');\r\nvar signals = require('./utils/Signals').new();\r\n\r\nvar _require = require('./utils/domUtils'),\r\n getElementRect = _require.getElementRect,\r\n nodeContains = _require.nodeContains,\r\n trySelector = _require.trySelector;\r\n\r\nvar _require2 = require('./utils/window'),\r\n getWindow = _require2.getWindow;\r\n\r\nvar _require3 = require('./utils/arr'),\r\n indexOf = _require3.indexOf,\r\n contains = _require3.contains;\r\n\r\nvar _require4 = require('./utils/browser'),\r\n wheelEvent = _require4.wheelEvent;\r\n\r\n// all set interactables\r\n\r\n\r\nscope.interactables = [];\r\n\r\n/*\\\r\n * Interactable\r\n [ property ]\r\n **\r\n * Object type returned by @interact\r\n\\*/\r\n\r\nvar Interactable = function () {\r\n function Interactable(target, options) {\r\n _classCallCheck(this, Interactable);\r\n\r\n options = options || {};\r\n\r\n this.target = target;\r\n this.events = new Eventable();\r\n this._context = options.context || scope.document;\r\n this._win = getWindow(trySelector(target) ? this._context : target);\r\n this._doc = this._win.document;\r\n\r\n signals.fire('new', {\r\n target: target,\r\n options: options,\r\n interactable: this,\r\n win: this._win\r\n });\r\n\r\n scope.addDocument(this._doc, this._win);\r\n\r\n scope.interactables.push(this);\r\n\r\n this.set(options);\r\n }\r\n\r\n Interactable.prototype.setOnEvents = function setOnEvents(action, phases) {\r\n var onAction = 'on' + action;\r\n\r\n if (is.function(phases.onstart)) {\r\n this.events[onAction + 'start'] = phases.onstart;\r\n }\r\n if (is.function(phases.onmove)) {\r\n this.events[onAction + 'move'] = phases.onmove;\r\n }\r\n if (is.function(phases.onend)) {\r\n this.events[onAction + 'end'] = phases.onend;\r\n }\r\n if (is.function(phases.oninertiastart)) {\r\n this.events[onAction + 'inertiastart'] = phases.oninertiastart;\r\n }\r\n\r\n return this;\r\n };\r\n\r\n Interactable.prototype.setPerAction = function setPerAction(action, options) {\r\n // for all the default per-action options\r\n for (var option in options) {\r\n // if this option exists for this action\r\n if (option in defaults[action]) {\r\n // if the option in the options arg is an object value\r\n if (is.object(options[option])) {\r\n // duplicate the object\r\n this.options[action][option] = extend(this.options[action][option] || {}, options[option]);\r\n\r\n if (is.object(defaults.perAction[option]) && 'enabled' in defaults.perAction[option]) {\r\n this.options[action][option].enabled = options[option].enabled === false ? false : true;\r\n }\r\n } else if (is.bool(options[option]) && is.object(defaults.perAction[option])) {\r\n this.options[action][option].enabled = options[option];\r\n } else if (options[option] !== undefined) {\r\n // or if it's not undefined, do a plain assignment\r\n this.options[action][option] = options[option];\r\n }\r\n }\r\n }\r\n };\r\n\r\n /*\\\r\n * Interactable.getRect\r\n [ method ]\r\n *\r\n * The default function to get an Interactables bounding rect. Can be\r\n * overridden using @Interactable.rectChecker.\r\n *\r\n - element (Element) #optional The element to measure.\r\n = (object) The object's bounding rectangle.\r\n o {\r\n o top : 0,\r\n o left : 0,\r\n o bottom: 0,\r\n o right : 0,\r\n o width : 0,\r\n o height: 0\r\n o }\r\n \\*/\r\n\r\n\r\n Interactable.prototype.getRect = function getRect(element) {\r\n element = element || this.target;\r\n\r\n if (is.string(this.target) && !is.element(element)) {\r\n element = this._context.querySelector(this.target);\r\n }\r\n\r\n return getElementRect(element);\r\n };\r\n\r\n /*\\\r\n * Interactable.rectChecker\r\n [ method ]\r\n *\r\n * Returns or sets the function used to calculate the interactable's\r\n * element's rectangle\r\n *\r\n - checker (function) #optional A function which returns this Interactable's bounding rectangle. See @Interactable.getRect\r\n = (function | object) The checker function or this Interactable\r\n \\*/\r\n\r\n\r\n Interactable.prototype.rectChecker = function rectChecker(checker) {\r\n if (is.function(checker)) {\r\n this.getRect = checker;\r\n\r\n return this;\r\n }\r\n\r\n if (checker === null) {\r\n delete this.options.getRect;\r\n\r\n return this;\r\n }\r\n\r\n return this.getRect;\r\n };\r\n\r\n Interactable.prototype._backCompatOption = function _backCompatOption(optionName, newValue) {\r\n if (trySelector(newValue) || is.object(newValue)) {\r\n this.options[optionName] = newValue;\r\n\r\n for (var _iterator = actions.names, _isArray = Array.isArray(_iterator), _i = 0, _iterator = _isArray ? _iterator : _iterator[Symbol.iterator]();;) {\r\n var _ref;\r\n\r\n if (_isArray) {\r\n if (_i >= _iterator.length) break;\r\n _ref = _iterator[_i++];\r\n } else {\r\n _i = _iterator.next();\r\n if (_i.done) break;\r\n _ref = _i.value;\r\n }\r\n\r\n var action = _ref;\r\n\r\n this.options[action][optionName] = newValue;\r\n }\r\n\r\n return this;\r\n }\r\n\r\n return this.options[optionName];\r\n };\r\n\r\n /*\\\r\n * Interactable.origin\r\n [ method ]\r\n *\r\n * Gets or sets the origin of the Interactable's element. The x and y\r\n * of the origin will be subtracted from action event coordinates.\r\n *\r\n - origin (object | string) #optional An object eg. { x: 0, y: 0 } or string 'parent', 'self' or any CSS selector\r\n * OR\r\n - origin (Element) #optional An HTML or SVG Element whose rect will be used\r\n **\r\n = (object) The current origin or this Interactable\r\n \\*/\r\n\r\n\r\n Interactable.prototype.origin = function origin(newValue) {\r\n return this._backCompatOption('origin', newValue);\r\n };\r\n\r\n /*\\\r\n * Interactable.deltaSource\r\n [ method ]\r\n *\r\n * Returns or sets the mouse coordinate types used to calculate the\r\n * movement of the pointer.\r\n *\r\n - newValue (string) #optional Use 'client' if you will be scrolling while interacting; Use 'page' if you want autoScroll to work\r\n = (string | object) The current deltaSource or this Interactable\r\n \\*/\r\n\r\n\r\n Interactable.prototype.deltaSource = function deltaSource(newValue) {\r\n if (newValue === 'page' || newValue === 'client') {\r\n this.options.deltaSource = newValue;\r\n\r\n return this;\r\n }\r\n\r\n return this.options.deltaSource;\r\n };\r\n\r\n /*\\\r\n * Interactable.context\r\n [ method ]\r\n *\r\n * Gets the selector context Node of the Interactable. The default is `window.document`.\r\n *\r\n = (Node) The context Node of this Interactable\r\n **\r\n \\*/\r\n\r\n\r\n Interactable.prototype.context = function context() {\r\n return this._context;\r\n };\r\n\r\n Interactable.prototype.inContext = function inContext(element) {\r\n return this._context === element.ownerDocument || nodeContains(this._context, element);\r\n };\r\n\r\n /*\\\r\n * Interactable.fire\r\n [ method ]\r\n *\r\n * Calls listeners for the given InteractEvent type bound globally\r\n * and directly to this Interactable\r\n *\r\n - iEvent (InteractEvent) The InteractEvent object to be fired on this Interactable\r\n = (Interactable) this Interactable\r\n \\*/\r\n\r\n\r\n Interactable.prototype.fire = function fire(iEvent) {\r\n this.events.fire(iEvent);\r\n\r\n return this;\r\n };\r\n\r\n Interactable.prototype._onOffMultiple = function _onOffMultiple(method, eventType, listener, options) {\r\n if (is.string(eventType) && eventType.search(' ') !== -1) {\r\n eventType = eventType.trim().split(/ +/);\r\n }\r\n\r\n if (is.array(eventType)) {\r\n for (var i = 0; i < eventType.length; i++) {\r\n this[method](eventType[i], listener, options);\r\n }\r\n\r\n return true;\r\n }\r\n\r\n if (is.object(eventType)) {\r\n for (var prop in eventType) {\r\n this[method](prop, eventType[prop], listener);\r\n }\r\n\r\n return true;\r\n }\r\n };\r\n\r\n /*\\\r\n * Interactable.on\r\n [ method ]\r\n *\r\n * Binds a listener for an InteractEvent, pointerEvent or DOM event.\r\n *\r\n - eventType (string | array | object) The types of events to listen for\r\n - listener (function) The function event (s)\r\n - options (object | boolean) #optional options object or useCapture flag for addEventListener\r\n = (object) This Interactable\r\n \\*/\r\n\r\n\r\n Interactable.prototype.on = function on(eventType, listener, options) {\r\n if (this._onOffMultiple('on', eventType, listener, options)) {\r\n return this;\r\n }\r\n\r\n if (eventType === 'wheel') {\r\n eventType = wheelEvent;\r\n }\r\n\r\n if (contains(Interactable.eventTypes, eventType)) {\r\n this.events.on(eventType, listener);\r\n }\r\n // delegated event for selector\r\n else if (is.string(this.target)) {\r\n events.addDelegate(this.target, this._context, eventType, listener, options);\r\n } else {\r\n events.add(this.target, eventType, listener, options);\r\n }\r\n\r\n return this;\r\n };\r\n\r\n /*\\\r\n * Interactable.off\r\n [ method ]\r\n *\r\n * Removes an InteractEvent, pointerEvent or DOM event listener\r\n *\r\n - eventType (string | array | object) The types of events that were listened for\r\n - listener (function) The listener function to be removed\r\n - options (object | boolean) #optional options object or useCapture flag for removeEventListener\r\n = (object) This Interactable\r\n \\*/\r\n\r\n\r\n Interactable.prototype.off = function off(eventType, listener, options) {\r\n if (this._onOffMultiple('off', eventType, listener, options)) {\r\n return this;\r\n }\r\n\r\n if (eventType === 'wheel') {\r\n eventType = wheelEvent;\r\n }\r\n\r\n // if it is an action event type\r\n if (contains(Interactable.eventTypes, eventType)) {\r\n this.events.off(eventType, listener);\r\n }\r\n // delegated event\r\n else if (is.string(this.target)) {\r\n events.removeDelegate(this.target, this._context, eventType, listener, options);\r\n }\r\n // remove listener from this Interatable's element\r\n else {\r\n events.remove(this.target, eventType, listener, options);\r\n }\r\n\r\n return this;\r\n };\r\n\r\n /*\\\r\n * Interactable.set\r\n [ method ]\r\n *\r\n * Reset the options of this Interactable\r\n - options (object) The new settings to apply\r\n = (object) This Interactable\r\n \\*/\r\n\r\n\r\n Interactable.prototype.set = function set(options) {\r\n if (!is.object(options)) {\r\n options = {};\r\n }\r\n\r\n this.options = extend({}, defaults.base);\r\n\r\n var perActions = extend({}, defaults.perAction);\r\n\r\n for (var actionName in actions.methodDict) {\r\n var methodName = actions.methodDict[actionName];\r\n\r\n this.options[actionName] = extend({}, defaults[actionName]);\r\n\r\n this.setPerAction(actionName, perActions);\r\n\r\n this[methodName](options[actionName]);\r\n }\r\n\r\n for (var _iterator2 = Interactable.settingsMethods, _isArray2 = Array.isArray(_iterator2), _i2 = 0, _iterator2 = _isArray2 ? _iterator2 : _iterator2[Symbol.iterator]();;) {\r\n var _ref2;\r\n\r\n if (_isArray2) {\r\n if (_i2 >= _iterator2.length) break;\r\n _ref2 = _iterator2[_i2++];\r\n } else {\r\n _i2 = _iterator2.next();\r\n if (_i2.done) break;\r\n _ref2 = _i2.value;\r\n }\r\n\r\n var setting = _ref2;\r\n\r\n this.options[setting] = defaults.base[setting];\r\n\r\n if (setting in options) {\r\n this[setting](options[setting]);\r\n }\r\n }\r\n\r\n signals.fire('set', {\r\n options: options,\r\n interactable: this\r\n });\r\n\r\n return this;\r\n };\r\n\r\n /*\\\r\n * Interactable.unset\r\n [ method ]\r\n *\r\n * Remove this interactable from the list of interactables and remove\r\n * it's action capabilities and event listeners\r\n *\r\n = (object) @interact\r\n \\*/\r\n\r\n\r\n Interactable.prototype.unset = function unset() {\r\n events.remove(this.target, 'all');\r\n\r\n if (is.string(this.target)) {\r\n // remove delegated events\r\n for (var type in events.delegatedEvents) {\r\n var delegated = events.delegatedEvents[type];\r\n\r\n if (delegated.selectors[0] === this.target && delegated.contexts[0] === this._context) {\r\n\r\n delegated.selectors.splice(0, 1);\r\n delegated.contexts.splice(0, 1);\r\n delegated.listeners.splice(0, 1);\r\n\r\n // remove the arrays if they are empty\r\n if (!delegated.selectors.length) {\r\n delegated[type] = null;\r\n }\r\n }\r\n\r\n events.remove(this._context, type, events.delegateListener);\r\n events.remove(this._context, type, events.delegateUseCapture, true);\r\n }\r\n } else {\r\n events.remove(this, 'all');\r\n }\r\n\r\n signals.fire('unset', { interactable: this });\r\n\r\n scope.interactables.splice(indexOf(scope.interactables, this), 1);\r\n\r\n // Stop related interactions when an Interactable is unset\r\n for (var _iterator3 = scope.interactions || [], _isArray3 = Array.isArray(_iterator3), _i3 = 0, _iterator3 = _isArray3 ? _iterator3 : _iterator3[Symbol.iterator]();;) {\r\n var _ref3;\r\n\r\n if (_isArray3) {\r\n if (_i3 >= _iterator3.length) break;\r\n _ref3 = _iterator3[_i3++];\r\n } else {\r\n _i3 = _iterator3.next();\r\n if (_i3.done) break;\r\n _ref3 = _i3.value;\r\n }\r\n\r\n var interaction = _ref3;\r\n\r\n if (interaction.target === this && interaction.interacting()) {\r\n interaction.stop();\r\n }\r\n }\r\n\r\n return scope.interact;\r\n };\r\n\r\n return Interactable;\r\n}();\r\n\r\nscope.interactables.indexOfElement = function indexOfElement(target, context) {\r\n context = context || scope.document;\r\n\r\n for (var i = 0; i < this.length; i++) {\r\n var interactable = this[i];\r\n\r\n if (interactable.target === target && interactable._context === context) {\r\n return i;\r\n }\r\n }\r\n return -1;\r\n};\r\n\r\nscope.interactables.get = function interactableGet(element, options, dontCheckInContext) {\r\n var ret = this[this.indexOfElement(element, options && options.context)];\r\n\r\n return ret && (is.string(element) || dontCheckInContext || ret.inContext(element)) ? ret : null;\r\n};\r\n\r\nscope.interactables.forEachSelector = function (callback, element) {\r\n for (var i = 0; i < this.length; i++) {\r\n var interactable = this[i];\r\n\r\n // skip non CSS selector targets and out of context elements\r\n if (!is.string(interactable.target) || element && !interactable.inContext(element)) {\r\n continue;\r\n }\r\n\r\n var ret = callback(interactable, interactable.target, interactable._context, i, this);\r\n\r\n if (ret !== undefined) {\r\n return ret;\r\n }\r\n }\r\n};\r\n\r\n// all interact.js eventTypes\r\nInteractable.eventTypes = scope.eventTypes = [];\r\n\r\nInteractable.signals = signals;\r\n\r\nInteractable.settingsMethods = ['deltaSource', 'origin', 'preventDefault', 'rectChecker'];\r\n\r\nmodule.exports = Interactable;\r\n\r\n},{\"./Eventable\":2,\"./actions/base\":6,\"./defaultOptions\":18,\"./scope\":34,\"./utils/Signals\":35,\"./utils/arr\":36,\"./utils/browser\":37,\"./utils/domUtils\":39,\"./utils/events\":40,\"./utils/extend\":41,\"./utils/is\":46,\"./utils/window\":52}],5:[function(require,module,exports){\r\n'use strict';\r\n\r\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\r\n\r\nvar scope = require('./scope');\r\nvar utils = require('./utils');\r\nvar events = require('./utils/events');\r\nvar browser = require('./utils/browser');\r\nvar domObjects = require('./utils/domObjects');\r\nvar finder = require('./utils/interactionFinder');\r\nvar signals = require('./utils/Signals').new();\r\n\r\nvar listeners = {};\r\nvar methodNames = ['pointerDown', 'pointerMove', 'pointerUp', 'updatePointer', 'removePointer'];\r\n\r\n// for ignoring browser's simulated mouse events\r\nvar prevTouchTime = 0;\r\n\r\n// all active and idle interactions\r\nscope.interactions = [];\r\n\r\nvar Interaction = function () {\r\n function Interaction(_ref) {\r\n var pointerType = _ref.pointerType;\r\n\r\n _classCallCheck(this, Interaction);\r\n\r\n this.target = null; // current interactable being interacted with\r\n this.element = null; // the target element of the interactable\r\n\r\n this.prepared = { // action that's ready to be fired on next move event\r\n name: null,\r\n axis: null,\r\n edges: null\r\n };\r\n\r\n // keep track of added pointers\r\n this.pointers = [];\r\n this.pointerIds = [];\r\n this.downTargets = [];\r\n this.downTimes = [];\r\n\r\n // Previous native pointer move event coordinates\r\n this.prevCoords = {\r\n page: { x: 0, y: 0 },\r\n client: { x: 0, y: 0 },\r\n timeStamp: 0\r\n };\r\n // current native pointer move event coordinates\r\n this.curCoords = {\r\n page: { x: 0, y: 0 },\r\n client: { x: 0, y: 0 },\r\n timeStamp: 0\r\n };\r\n\r\n // Starting InteractEvent pointer coordinates\r\n this.startCoords = {\r\n page: { x: 0, y: 0 },\r\n client: { x: 0, y: 0 },\r\n timeStamp: 0\r\n };\r\n\r\n // Change in coordinates and time of the pointer\r\n this.pointerDelta = {\r\n page: { x: 0, y: 0, vx: 0, vy: 0, speed: 0 },\r\n client: { x: 0, y: 0, vx: 0, vy: 0, speed: 0 },\r\n timeStamp: 0\r\n };\r\n\r\n this.downEvent = null; // pointerdown/mousedown/touchstart event\r\n this.downPointer = {};\r\n\r\n this._eventTarget = null;\r\n this._curEventTarget = null;\r\n\r\n this.prevEvent = null; // previous action event\r\n\r\n this.pointerIsDown = false;\r\n this.pointerWasMoved = false;\r\n this._interacting = false;\r\n\r\n this.pointerType = pointerType;\r\n\r\n signals.fire('new', this);\r\n\r\n scope.interactions.push(this);\r\n }\r\n\r\n Interaction.prototype.pointerDown = function pointerDown(pointer, event, eventTarget) {\r\n var pointerIndex = this.updatePointer(pointer, event, true);\r\n\r\n signals.fire('down', {\r\n pointer: pointer,\r\n event: event,\r\n eventTarget: eventTarget,\r\n pointerIndex: pointerIndex,\r\n interaction: this\r\n });\r\n };\r\n\r\n /*\\\r\n * Interaction.start\r\n [ method ]\r\n *\r\n * Start an action with the given Interactable and Element as tartgets. The\r\n * action must be enabled for the target Interactable and an appropriate number\r\n * of pointers must be held down - 1 for drag/resize, 2 for gesture.\r\n *\r\n * Use it with `interactable.able({ manualStart: false })` to always\r\n * [start actions manually](https://github.com/taye/interact.js/issues/114)\r\n *\r\n - action (object) The action to be performed - drag, resize, etc.\r\n - target (Interactable) The Interactable to target\r\n - element (Element) The DOM Element to target\r\n = (object) interact\r\n **\r\n | interact(target)\r\n | .draggable({\r\n | // disable the default drag start by down->move\r\n | manualStart: true\r\n | })\r\n | // start dragging after the user holds the pointer down\r\n | .on('hold', function (event) {\r\n | var interaction = event.interaction;\r\n |\r\n | if (!interaction.interacting()) {\r\n | interaction.start({ name: 'drag' },\r\n | event.interactable,\r\n | event.currentTarget);\r\n | }\r\n | });\r\n \\*/\r\n\r\n\r\n Interaction.prototype.start = function start(action, target, element) {\r\n if (this.interacting() || !this.pointerIsDown || this.pointerIds.length < (action.name === 'gesture' ? 2 : 1)) {\r\n return;\r\n }\r\n\r\n // if this interaction had been removed after stopping\r\n // add it back\r\n if (utils.indexOf(scope.interactions, this) === -1) {\r\n scope.interactions.push(this);\r\n }\r\n\r\n utils.copyAction(this.prepared, action);\r\n this.target = target;\r\n this.element = element;\r\n\r\n signals.fire('action-start', {\r\n interaction: this,\r\n event: this.downEvent\r\n });\r\n };\r\n\r\n Interaction.prototype.pointerMove = function pointerMove(pointer, event, eventTarget) {\r\n if (!this.simulation) {\r\n this.updatePointer(pointer);\r\n utils.setCoords(this.curCoords, this.pointers);\r\n }\r\n\r\n var duplicateMove = this.curCoords.page.x === this.prevCoords.page.x && this.curCoords.page.y === this.prevCoords.page.y && this.curCoords.client.x === this.prevCoords.client.x && this.curCoords.client.y === this.prevCoords.client.y;\r\n\r\n var dx = void 0;\r\n var dy = void 0;\r\n\r\n // register movement greater than pointerMoveTolerance\r\n if (this.pointerIsDown && !this.pointerWasMoved) {\r\n dx = this.curCoords.client.x - this.startCoords.client.x;\r\n dy = this.curCoords.client.y - this.startCoords.client.y;\r\n\r\n this.pointerWasMoved = utils.hypot(dx, dy) > Interaction.pointerMoveTolerance;\r\n }\r\n\r\n var signalArg = {\r\n pointer: pointer,\r\n pointerIndex: this.getPointerIndex(pointer),\r\n event: event,\r\n eventTarget: eventTarget,\r\n dx: dx,\r\n dy: dy,\r\n duplicate: duplicateMove,\r\n interaction: this,\r\n interactingBeforeMove: this.interacting()\r\n };\r\n\r\n if (!duplicateMove) {\r\n // set pointer coordinate, time changes and speeds\r\n utils.setCoordDeltas(this.pointerDelta, this.prevCoords, this.curCoords);\r\n }\r\n\r\n signals.fire('move', signalArg);\r\n\r\n if (!duplicateMove) {\r\n // if interacting, fire an 'action-move' signal etc\r\n if (this.interacting()) {\r\n this.doMove(signalArg);\r\n }\r\n\r\n if (this.pointerWasMoved) {\r\n utils.copyCoords(this.prevCoords, this.curCoords);\r\n }\r\n }\r\n };\r\n\r\n /*\\\r\n * Interaction.doMove\r\n [ method ]\r\n *\r\n * Force a move of the current action at the same coordinates. Useful if\r\n * snap/restrict has been changed and you want a movement with the new\r\n * settings.\r\n *\r\n **\r\n | interact(target)\r\n | .draggable(true)\r\n | .on('dragmove', function (event) {\r\n | if (someCondition) {\r\n | // change the snap settings\r\n | event.interactable.draggable({ snap: { targets: [] }});\r\n | // fire another move event with re-calculated snap\r\n | event.interaction.doMove();\r\n | }\r\n | });\r\n \\*/\r\n\r\n\r\n Interaction.prototype.doMove = function doMove(signalArg) {\r\n signalArg = utils.extend({\r\n pointer: this.pointers[0],\r\n event: this.prevEvent,\r\n eventTarget: this._eventTarget,\r\n interaction: this\r\n }, signalArg || {});\r\n\r\n signals.fire('before-action-move', signalArg);\r\n\r\n if (!this._dontFireMove) {\r\n signals.fire('action-move', signalArg);\r\n }\r\n\r\n this._dontFireMove = false;\r\n };\r\n\r\n // End interact move events and stop auto-scroll unless simulation is running\r\n\r\n\r\n Interaction.prototype.pointerUp = function pointerUp(pointer, event, eventTarget, curEventTarget) {\r\n var pointerIndex = this.getPointerIndex(pointer);\r\n\r\n signals.fire(/cancel$/i.test(event.type) ? 'cancel' : 'up', {\r\n pointer: pointer,\r\n pointerIndex: pointerIndex,\r\n event: event,\r\n eventTarget: eventTarget,\r\n curEventTarget: curEventTarget,\r\n interaction: this\r\n });\r\n\r\n if (!this.simulation) {\r\n this.end(event);\r\n }\r\n\r\n this.pointerIsDown = false;\r\n this.removePointer(pointer, event);\r\n };\r\n\r\n /*\\\r\n * Interaction.end\r\n [ method ]\r\n *\r\n * Stop the current action and fire an end event. Inertial movement does\r\n * not happen.\r\n *\r\n - event (PointerEvent) #optional\r\n **\r\n | interact(target)\r\n | .draggable(true)\r\n | .on('move', function (event) {\r\n | if (event.pageX > 1000) {\r\n | // end the current action\r\n | event.interaction.end();\r\n | // stop all further listeners from being called\r\n | event.stopImmediatePropagation();\r\n | }\r\n | });\r\n \\*/\r\n\r\n\r\n Interaction.prototype.end = function end(event) {\r\n event = event || this.prevEvent;\r\n\r\n if (this.interacting()) {\r\n signals.fire('action-end', {\r\n event: event,\r\n interaction: this\r\n });\r\n }\r\n\r\n this.stop();\r\n };\r\n\r\n Interaction.prototype.currentAction = function currentAction() {\r\n return this._interacting ? this.prepared.name : null;\r\n };\r\n\r\n Interaction.prototype.interacting = function interacting() {\r\n return this._interacting;\r\n };\r\n\r\n Interaction.prototype.stop = function stop() {\r\n signals.fire('stop', { interaction: this });\r\n\r\n if (this._interacting) {\r\n signals.fire('stop-active', { interaction: this });\r\n signals.fire('stop-' + this.prepared.name, { interaction: this });\r\n }\r\n\r\n this.target = this.element = null;\r\n\r\n this._interacting = false;\r\n this.prepared.name = this.prevEvent = null;\r\n };\r\n\r\n Interaction.prototype.getPointerIndex = function getPointerIndex(pointer) {\r\n // mouse and pen interactions may have only one pointer\r\n if (this.pointerType === 'mouse' || this.pointerType === 'pen') {\r\n return 0;\r\n }\r\n\r\n return utils.indexOf(this.pointerIds, utils.getPointerId(pointer));\r\n };\r\n\r\n Interaction.prototype.updatePointer = function updatePointer(pointer, event) {\r\n var down = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : event && /(down|start)$/i.test(event.type);\r\n\r\n var id = utils.getPointerId(pointer);\r\n var index = this.getPointerIndex(pointer);\r\n\r\n if (index === -1) {\r\n index = this.pointerIds.length;\r\n this.pointerIds[index] = id;\r\n }\r\n\r\n if (down) {\r\n signals.fire('update-pointer-down', {\r\n pointer: pointer,\r\n event: event,\r\n down: down,\r\n pointerId: id,\r\n pointerIndex: index,\r\n interaction: this\r\n });\r\n }\r\n\r\n this.pointers[index] = pointer;\r\n\r\n return index;\r\n };\r\n\r\n Interaction.prototype.removePointer = function removePointer(pointer, event) {\r\n var index = this.getPointerIndex(pointer);\r\n\r\n if (index === -1) {\r\n return;\r\n }\r\n\r\n signals.fire('remove-pointer', {\r\n pointer: pointer,\r\n event: event,\r\n pointerIndex: index,\r\n interaction: this\r\n });\r\n\r\n this.pointers.splice(index, 1);\r\n this.pointerIds.splice(index, 1);\r\n this.downTargets.splice(index, 1);\r\n this.downTimes.splice(index, 1);\r\n };\r\n\r\n Interaction.prototype._updateEventTargets = function _updateEventTargets(target, currentTarget) {\r\n this._eventTarget = target;\r\n this._curEventTarget = currentTarget;\r\n };\r\n\r\n return Interaction;\r\n}();\r\n\r\nfor (var i = 0, len = methodNames.length; i < len; i++) {\r\n var method = methodNames[i];\r\n\r\n listeners[method] = doOnInteractions(method);\r\n}\r\n\r\nfunction doOnInteractions(method) {\r\n return function (event) {\r\n var pointerType = utils.getPointerType(event);\r\n\r\n var _utils$getEventTarget = utils.getEventTargets(event),\r\n eventTarget = _utils$getEventTarget[0],\r\n curEventTarget = _utils$getEventTarget[1];\r\n\r\n var matches = []; // [ [pointer, interaction], ...]\r\n\r\n if (browser.supportsTouch && /touch/.test(event.type)) {\r\n prevTouchTime = new Date().getTime();\r\n\r\n for (var _i = 0; _i < event.changedTouches.length; _i++) {\r\n var pointer = event.changedTouches[_i];\r\n var interaction = finder.search(pointer, event.type, eventTarget);\r\n\r\n matches.push([pointer, interaction || new Interaction({ pointerType: pointerType })]);\r\n }\r\n } else {\r\n var invalidPointer = false;\r\n\r\n if (!browser.supportsPointerEvent && /mouse/.test(event.type)) {\r\n // ignore mouse events while touch interactions are active\r\n for (var _i2 = 0; _i2 < scope.interactions.length && !invalidPointer; _i2++) {\r\n invalidPointer = scope.interactions[_i2].pointerType !== 'mouse' && scope.interactions[_i2].pointerIsDown;\r\n }\r\n\r\n // try to ignore mouse events that are simulated by the browser\r\n // after a touch event\r\n invalidPointer = invalidPointer || new Date().getTime() - prevTouchTime < 500\r\n // on iOS and Firefox Mobile, MouseEvent.timeStamp is zero if simulated\r\n || event.timeStamp === 0;\r\n }\r\n\r\n if (!invalidPointer) {\r\n var _interaction = finder.search(event, event.type, eventTarget);\r\n\r\n if (!_interaction) {\r\n _interaction = new Interaction({ pointerType: pointerType });\r\n }\r\n\r\n matches.push([event, _interaction]);\r\n }\r\n }\r\n\r\n for (var _iterator = matches, _isArray = Array.isArray(_iterator), _i3 = 0, _iterator = _isArray ? _iterator : _iterator[Symbol.iterator]();;) {\r\n var _ref2;\r\n\r\n if (_isArray) {\r\n if (_i3 >= _iterator.length) break;\r\n _ref2 = _iterator[_i3++];\r\n } else {\r\n _i3 = _iterator.next();\r\n if (_i3.done) break;\r\n _ref2 = _i3.value;\r\n }\r\n\r\n var _ref3 = _ref2,\r\n _pointer = _ref3[0],\r\n _interaction2 = _ref3[1];\r\n\r\n _interaction2._updateEventTargets(eventTarget, curEventTarget);\r\n _interaction2[method](_pointer, event, eventTarget, curEventTarget);\r\n }\r\n };\r\n}\r\n\r\nfunction endAll(event) {\r\n for (var _i4 = 0; _i4 < scope.interactions.length; _i4++) {\r\n var interaction = scope.interactions[_i4];\r\n\r\n interaction.end(event);\r\n signals.fire('endall', { event: event, interaction: interaction });\r\n }\r\n}\r\n\r\nvar docEvents = {/* 'eventType': listenerFunc */};\r\nvar pEventTypes = browser.pEventTypes;\r\n\r\nif (domObjects.PointerEvent) {\r\n docEvents[pEventTypes.down] = listeners.pointerDown;\r\n docEvents[pEventTypes.move] = listeners.pointerMove;\r\n docEvents[pEventTypes.up] = listeners.pointerUp;\r\n docEvents[pEventTypes.cancel] = listeners.pointerUp;\r\n} else {\r\n docEvents.mousedown = listeners.pointerDown;\r\n docEvents.mousemove = listeners.pointerMove;\r\n docEvents.mouseup = listeners.pointerUp;\r\n\r\n docEvents.touchstart = listeners.pointerDown;\r\n docEvents.touchmove = listeners.pointerMove;\r\n docEvents.touchend = listeners.pointerUp;\r\n docEvents.touchcancel = listeners.pointerUp;\r\n}\r\n\r\ndocEvents.blur = endAll;\r\n\r\nfunction onDocSignal(_ref4, signalName) {\r\n var doc = _ref4.doc;\r\n\r\n var eventMethod = signalName.indexOf('add') === 0 ? events.add : events.remove;\r\n\r\n // delegate event listener\r\n for (var eventType in scope.delegatedEvents) {\r\n eventMethod(doc, eventType, events.delegateListener);\r\n eventMethod(doc, eventType, events.delegateUseCapture, true);\r\n }\r\n\r\n for (var _eventType in docEvents) {\r\n eventMethod(doc, _eventType, docEvents[_eventType]);\r\n }\r\n}\r\n\r\nsignals.on('update-pointer-down', function (_ref5) {\r\n var interaction = _ref5.interaction,\r\n pointer = _ref5.pointer,\r\n pointerId = _ref5.pointerId,\r\n pointerIndex = _ref5.pointerIndex,\r\n event = _ref5.event,\r\n eventTarget = _ref5.eventTarget,\r\n down = _ref5.down;\r\n\r\n interaction.pointerIds[pointerIndex] = pointerId;\r\n interaction.pointers[pointerIndex] = pointer;\r\n\r\n if (down) {\r\n interaction.pointerIsDown = true;\r\n }\r\n\r\n if (!interaction.interacting()) {\r\n utils.setCoords(interaction.startCoords, interaction.pointers);\r\n\r\n utils.copyCoords(interaction.curCoords, interaction.startCoords);\r\n utils.copyCoords(interaction.prevCoords, interaction.startCoords);\r\n\r\n interaction.downEvent = event;\r\n interaction.downTimes[pointerIndex] = interaction.curCoords.timeStamp;\r\n interaction.downTargets[pointerIndex] = eventTarget || event && utils.getEventTargets(event)[0];\r\n interaction.pointerWasMoved = false;\r\n\r\n utils.pointerExtend(interaction.downPointer, pointer);\r\n }\r\n});\r\n\r\nscope.signals.on('add-document', onDocSignal);\r\nscope.signals.on('remove-document', onDocSignal);\r\n\r\nInteraction.pointerMoveTolerance = 1;\r\nInteraction.doOnInteractions = doOnInteractions;\r\nInteraction.endAll = endAll;\r\nInteraction.signals = signals;\r\nInteraction.docEvents = docEvents;\r\n\r\nscope.endAllInteractions = endAll;\r\n\r\nmodule.exports = Interaction;\r\n\r\n},{\"./scope\":34,\"./utils\":44,\"./utils/Signals\":35,\"./utils/browser\":37,\"./utils/domObjects\":38,\"./utils/events\":40,\"./utils/interactionFinder\":45}],6:[function(require,module,exports){\r\n'use strict';\r\n\r\nvar Interaction = require('../Interaction');\r\nvar InteractEvent = require('../InteractEvent');\r\n\r\nvar actions = {\r\n firePrepared: firePrepared,\r\n names: [],\r\n methodDict: {}\r\n};\r\n\r\nInteraction.signals.on('action-start', function (_ref) {\r\n var interaction = _ref.interaction,\r\n event = _ref.event;\r\n\r\n interaction._interacting = true;\r\n firePrepared(interaction, event, 'start');\r\n});\r\n\r\nInteraction.signals.on('action-move', function (_ref2) {\r\n var interaction = _ref2.interaction,\r\n event = _ref2.event,\r\n preEnd = _ref2.preEnd;\r\n\r\n firePrepared(interaction, event, 'move', preEnd);\r\n\r\n // if the action was ended in a listener\r\n if (!interaction.interacting()) {\r\n return false;\r\n }\r\n});\r\n\r\nInteraction.signals.on('action-end', function (_ref3) {\r\n var interaction = _ref3.interaction,\r\n event = _ref3.event;\r\n\r\n firePrepared(interaction, event, 'end');\r\n});\r\n\r\nfunction firePrepared(interaction, event, phase, preEnd) {\r\n var actionName = interaction.prepared.name;\r\n\r\n var newEvent = new InteractEvent(interaction, event, actionName, phase, interaction.element, null, preEnd);\r\n\r\n interaction.target.fire(newEvent);\r\n interaction.prevEvent = newEvent;\r\n}\r\n\r\nmodule.exports = actions;\r\n\r\n},{\"../InteractEvent\":3,\"../Interaction\":5}],7:[function(require,module,exports){\r\n'use strict';\r\n\r\nvar actions = require('./base');\r\nvar utils = require('../utils');\r\nvar InteractEvent = require('../InteractEvent');\r\nvar Interactable = require('../Interactable');\r\nvar Interaction = require('../Interaction');\r\nvar defaultOptions = require('../defaultOptions');\r\n\r\nvar drag = {\r\n defaults: {\r\n enabled: false,\r\n mouseButtons: null,\r\n\r\n origin: null,\r\n snap: null,\r\n restrict: null,\r\n inertia: null,\r\n autoScroll: null,\r\n\r\n startAxis: 'xy',\r\n lockAxis: 'xy'\r\n },\r\n\r\n checker: function checker(pointer, event, interactable) {\r\n var dragOptions = interactable.options.drag;\r\n\r\n return dragOptions.enabled ? { name: 'drag', axis: dragOptions.lockAxis === 'start' ? dragOptions.startAxis : dragOptions.lockAxis } : null;\r\n },\r\n\r\n getCursor: function getCursor() {\r\n return 'move';\r\n }\r\n};\r\n\r\nInteraction.signals.on('before-action-move', function (_ref) {\r\n var interaction = _ref.interaction;\r\n\r\n if (interaction.prepared.name !== 'drag') {\r\n return;\r\n }\r\n\r\n var axis = interaction.prepared.axis;\r\n\r\n if (axis === 'x') {\r\n interaction.curCoords.page.y = interaction.startCoords.page.y;\r\n interaction.curCoords.client.y = interaction.startCoords.client.y;\r\n\r\n interaction.pointerDelta.page.speed = Math.abs(interaction.pointerDelta.page.vx);\r\n interaction.pointerDelta.client.speed = Math.abs(interaction.pointerDelta.client.vx);\r\n interaction.pointerDelta.client.vy = 0;\r\n interaction.pointerDelta.page.vy = 0;\r\n } else if (axis === 'y') {\r\n interaction.curCoords.page.x = interaction.startCoords.page.x;\r\n interaction.curCoords.client.x = interaction.startCoords.client.x;\r\n\r\n interaction.pointerDelta.page.speed = Math.abs(interaction.pointerDelta.page.vy);\r\n interaction.pointerDelta.client.speed = Math.abs(interaction.pointerDelta.client.vy);\r\n interaction.pointerDelta.client.vx = 0;\r\n interaction.pointerDelta.page.vx = 0;\r\n }\r\n});\r\n\r\n// dragmove\r\nInteractEvent.signals.on('new', function (_ref2) {\r\n var iEvent = _ref2.iEvent,\r\n interaction = _ref2.interaction;\r\n\r\n if (iEvent.type !== 'dragmove') {\r\n return;\r\n }\r\n\r\n var axis = interaction.prepared.axis;\r\n\r\n if (axis === 'x') {\r\n iEvent.pageY = interaction.startCoords.page.y;\r\n iEvent.clientY = interaction.startCoords.client.y;\r\n iEvent.dy = 0;\r\n } else if (axis === 'y') {\r\n iEvent.pageX = interaction.startCoords.page.x;\r\n iEvent.clientX = interaction.startCoords.client.x;\r\n iEvent.dx = 0;\r\n }\r\n});\r\n\r\n/*\\\r\n * Interactable.draggable\r\n [ method ]\r\n *\r\n * Gets or sets whether drag actions can be performed on the\r\n * Interactable\r\n *\r\n = (boolean) Indicates if this can be the target of drag events\r\n | var isDraggable = interact('ul li').draggable();\r\n * or\r\n - options (boolean | object) #optional true/false or An object with event listeners to be fired on drag events (object makes the Interactable draggable)\r\n = (object) This Interactable\r\n | interact(element).draggable({\r\n | onstart: function (event) {},\r\n | onmove : function (event) {},\r\n | onend : function (event) {},\r\n |\r\n | // the axis in which the first movement must be\r\n | // for the drag sequence to start\r\n | // 'xy' by default - any direction\r\n | startAxis: 'x' || 'y' || 'xy',\r\n |\r\n | // 'xy' by default - don't restrict to one axis (move in any direction)\r\n | // 'x' or 'y' to restrict movement to either axis\r\n | // 'start' to restrict movement to the axis the drag started in\r\n | lockAxis: 'x' || 'y' || 'xy' || 'start',\r\n |\r\n | // max number of drags that can happen concurrently\r\n | // with elements of this Interactable. Infinity by default\r\n | max: Infinity,\r\n |\r\n | // max number of drags that can target the same element+Interactable\r\n | // 1 by default\r\n | maxPerElement: 2\r\n | });\r\n\\*/\r\nInteractable.prototype.draggable = function (options) {\r\n if (utils.is.object(options)) {\r\n this.options.drag.enabled = options.enabled === false ? false : true;\r\n this.setPerAction('drag', options);\r\n this.setOnEvents('drag', options);\r\n\r\n if (/^(xy|x|y|start)$/.test(options.lockAxis)) {\r\n this.options.drag.lockAxis = options.lockAxis;\r\n }\r\n if (/^(xy|x|y)$/.test(options.startAxis)) {\r\n this.options.drag.startAxis = options.startAxis;\r\n }\r\n\r\n return this;\r\n }\r\n\r\n if (utils.is.bool(options)) {\r\n this.options.drag.enabled = options;\r\n\r\n if (!options) {\r\n this.ondragstart = this.ondragstart = this.ondragend = null;\r\n }\r\n\r\n return this;\r\n }\r\n\r\n return this.options.drag;\r\n};\r\n\r\nactions.drag = drag;\r\nactions.names.push('drag');\r\nutils.merge(Interactable.eventTypes, ['dragstart', 'dragmove', 'draginertiastart', 'draginertiaresume', 'dragend']);\r\nactions.methodDict.drag = 'draggable';\r\n\r\ndefaultOptions.drag = drag.defaults;\r\n\r\nmodule.exports = drag;\r\n\r\n},{\"../InteractEvent\":3,\"../Interactable\":4,\"../Interaction\":5,\"../defaultOptions\":18,\"../utils\":44,\"./base\":6}],8:[function(require,module,exports){\r\n'use strict';\r\n\r\nvar actions = require('./base');\r\nvar utils = require('../utils');\r\nvar scope = require('../scope');\r\nvar interact = require('../interact');\r\nvar InteractEvent = require('../InteractEvent');\r\nvar Interactable = require('../Interactable');\r\nvar Interaction = require('../Interaction');\r\nvar defaultOptions = require('../defaultOptions');\r\n\r\nvar drop = {\r\n defaults: {\r\n enabled: false,\r\n accept: null,\r\n overlap: 'pointer'\r\n }\r\n};\r\n\r\nvar dynamicDrop = false;\r\n\r\nInteraction.signals.on('action-start', function (_ref) {\r\n var interaction = _ref.interaction,\r\n event = _ref.event;\r\n\r\n if (interaction.prepared.name !== 'drag') {\r\n return;\r\n }\r\n\r\n // reset active dropzones\r\n interaction.activeDrops.dropzones = [];\r\n interaction.activeDrops.elements = [];\r\n interaction.activeDrops.rects = [];\r\n\r\n interaction.dropEvents = null;\r\n\r\n if (!interaction.dynamicDrop) {\r\n setActiveDrops(interaction, interaction.element);\r\n }\r\n\r\n var dragEvent = interaction.prevEvent;\r\n var dropEvents = getDropEvents(interaction, event, dragEvent);\r\n\r\n if (dropEvents.activate) {\r\n fireActiveDrops(interaction, dropEvents.activate);\r\n }\r\n});\r\n\r\nInteractEvent.signals.on('new', function (_ref2) {\r\n var interaction = _ref2.interaction,\r\n iEvent = _ref2.iEvent,\r\n event = _ref2.event;\r\n\r\n if (iEvent.type !== 'dragmove' && iEvent.type !== 'dragend') {\r\n return;\r\n }\r\n\r\n var draggableElement = interaction.element;\r\n var dragEvent = iEvent;\r\n var dropResult = getDrop(dragEvent, event, draggableElement);\r\n\r\n interaction.dropTarget = dropResult.dropzone;\r\n interaction.dropElement = dropResult.element;\r\n\r\n interaction.dropEvents = getDropEvents(interaction, event, dragEvent);\r\n});\r\n\r\nInteraction.signals.on('action-move', function (_ref3) {\r\n var interaction = _ref3.interaction;\r\n\r\n if (interaction.prepared.name !== 'drag') {\r\n return;\r\n }\r\n\r\n fireDropEvents(interaction, interaction.dropEvents);\r\n});\r\n\r\nInteraction.signals.on('action-end', function (_ref4) {\r\n var interaction = _ref4.interaction;\r\n\r\n if (interaction.prepared.name === 'drag') {\r\n fireDropEvents(interaction, interaction.dropEvents);\r\n }\r\n});\r\n\r\nInteraction.signals.on('stop-drag', function (_ref5) {\r\n var interaction = _ref5.interaction;\r\n\r\n interaction.activeDrops.dropzones = interaction.activeDrops.elements = interaction.activeDrops.rects = interaction.dropEvents = null;\r\n});\r\n\r\nfunction collectDrops(interaction, element) {\r\n var drops = [];\r\n var elements = [];\r\n\r\n element = element || interaction.element;\r\n\r\n // collect all dropzones and their elements which qualify for a drop\r\n for (var _iterator = scope.interactables, _isArray = Array.isArray(_iterator), _i = 0, _iterator = _isArray ? _iterator : _iterator[Symbol.iterator]();;) {\r\n var _ref6;\r\n\r\n if (_isArray) {\r\n if (_i >= _iterator.length) break;\r\n _ref6 = _iterator[_i++];\r\n } else {\r\n _i = _iterator.next();\r\n if (_i.done) break;\r\n _ref6 = _i.value;\r\n }\r\n\r\n var current = _ref6;\r\n\r\n if (!current.options.drop.enabled) {\r\n continue;\r\n }\r\n\r\n var accept = current.options.drop.accept;\r\n\r\n // test the draggable element against the dropzone's accept setting\r\n if (utils.is.element(accept) && accept !== element || utils.is.string(accept) && !utils.matchesSelector(element, accept)) {\r\n\r\n continue;\r\n }\r\n\r\n // query for new elements if necessary\r\n var dropElements = utils.is.string(current.target) ? current._context.querySelectorAll(current.target) : [current.target];\r\n\r\n for (var i = 0; i < dropElements.length; i++) {\r\n var currentElement = dropElements[i];\r\n\r\n if (currentElement !== element) {\r\n drops.push(current);\r\n elements.push(currentElement);\r\n }\r\n }\r\n }\r\n\r\n return {\r\n elements: elements,\r\n dropzones: drops\r\n };\r\n}\r\n\r\nfunction fireActiveDrops(interaction, event) {\r\n var prevElement = void 0;\r\n\r\n // loop through all active dropzones and trigger event\r\n for (var i = 0; i < interaction.activeDrops.dropzones.length; i++) {\r\n var current = interaction.activeDrops.dropzones[i];\r\n var currentElement = interaction.activeDrops.elements[i];\r\n\r\n // prevent trigger of duplicate events on same element\r\n if (currentElement !== prevElement) {\r\n // set current element as event target\r\n event.target = currentElement;\r\n current.fire(event);\r\n }\r\n prevElement = currentElement;\r\n }\r\n}\r\n\r\n// Collect a new set of possible drops and save them in activeDrops.\r\n// setActiveDrops should always be called when a drag has just started or a\r\n// drag event happens while dynamicDrop is true\r\nfunction setActiveDrops(interaction, dragElement) {\r\n // get dropzones and their elements that could receive the draggable\r\n var possibleDrops = collectDrops(interaction, dragElement, true);\r\n\r\n interaction.activeDrops.dropzones = possibleDrops.dropzones;\r\n interaction.activeDrops.elements = possibleDrops.elements;\r\n interaction.activeDrops.rects = [];\r\n\r\n for (var i = 0; i < interaction.activeDrops.dropzones.length; i++) {\r\n interaction.activeDrops.rects[i] = interaction.activeDrops.dropzones[i].getRect(interaction.activeDrops.elements[i]);\r\n }\r\n}\r\n\r\nfunction getDrop(dragEvent, event, dragElement) {\r\n var interaction = dragEvent.interaction;\r\n var validDrops = [];\r\n\r\n if (dynamicDrop) {\r\n setActiveDrops(interaction, dragElement);\r\n }\r\n\r\n // collect all dropzones and their elements which qualify for a drop\r\n for (var j = 0; j < interaction.activeDrops.dropzones.length; j++) {\r\n var current = interaction.activeDrops.dropzones[j];\r\n var currentElement = interaction.activeDrops.elements[j];\r\n var rect = interaction.activeDrops.rects[j];\r\n\r\n validDrops.push(current.dropCheck(dragEvent, event, interaction.target, dragElement, currentElement, rect) ? currentElement : null);\r\n }\r\n\r\n // get the most appropriate dropzone based on DOM depth and order\r\n var dropIndex = utils.indexOfDeepestElement(validDrops);\r\n\r\n return {\r\n dropzone: interaction.activeDrops.dropzones[dropIndex] || null,\r\n element: interaction.activeDrops.elements[dropIndex] || null\r\n };\r\n}\r\n\r\nfunction getDropEvents(interaction, pointerEvent, dragEvent) {\r\n var dropEvents = {\r\n enter: null,\r\n leave: null,\r\n activate: null,\r\n deactivate: null,\r\n move: null,\r\n drop: null\r\n };\r\n\r\n var tmpl = {\r\n dragEvent: dragEvent,\r\n interaction: interaction,\r\n target: interaction.dropElement,\r\n dropzone: interaction.dropTarget,\r\n relatedTarget: dragEvent.target,\r\n draggable: dragEvent.interactable,\r\n timeStamp: dragEvent.timeStamp\r\n };\r\n\r\n if (interaction.dropElement !== interaction.prevDropElement) {\r\n // if there was a prevDropTarget, create a dragleave event\r\n if (interaction.prevDropTarget) {\r\n dropEvents.leave = utils.extend({ type: 'dragleave' }, tmpl);\r\n\r\n dragEvent.dragLeave = dropEvents.leave.target = interaction.prevDropElement;\r\n dragEvent.prevDropzone = dropEvents.leave.dropzone = interaction.prevDropTarget;\r\n }\r\n // if the dropTarget is not null, create a dragenter event\r\n if (interaction.dropTarget) {\r\n dropEvents.enter = {\r\n dragEvent: dragEvent,\r\n interaction: interaction,\r\n target: interaction.dropElement,\r\n dropzone: interaction.dropTarget,\r\n relatedTarget: dragEvent.target,\r\n draggable: dragEvent.interactable,\r\n timeStamp: dragEvent.timeStamp,\r\n type: 'dragenter'\r\n };\r\n\r\n dragEvent.dragEnter = interaction.dropElement;\r\n dragEvent.dropzone = interaction.dropTarget;\r\n }\r\n }\r\n\r\n if (dragEvent.type === 'dragend' && interaction.dropTarget) {\r\n dropEvents.drop = utils.extend({ type: 'drop' }, tmpl);\r\n\r\n dragEvent.dropzone = interaction.dropTarget;\r\n dragEvent.relatedTarget = interaction.dropElement;\r\n }\r\n if (dragEvent.type === 'dragstart') {\r\n dropEvents.activate = utils.extend({ type: 'dropactivate' }, tmpl);\r\n\r\n dropEvents.activate.target = null;\r\n dropEvents.activate.dropzone = null;\r\n }\r\n if (dragEvent.type === 'dragend') {\r\n dropEvents.deactivate = utils.extend({ type: 'dropdeactivate' }, tmpl);\r\n\r\n dropEvents.deactivate.target = null;\r\n dropEvents.deactivate.dropzone = null;\r\n }\r\n if (dragEvent.type === 'dragmove' && interaction.dropTarget) {\r\n dropEvents.move = utils.extend({\r\n dragmove: dragEvent,\r\n type: 'dropmove'\r\n }, tmpl);\r\n\r\n dragEvent.dropzone = interaction.dropTarget;\r\n }\r\n\r\n return dropEvents;\r\n}\r\n\r\nfunction fireDropEvents(interaction, dropEvents) {\r\n if (dropEvents.leave) {\r\n interaction.prevDropTarget.fire(dropEvents.leave);\r\n }\r\n if (dropEvents.move) {\r\n interaction.dropTarget.fire(dropEvents.move);\r\n }\r\n if (dropEvents.enter) {\r\n interaction.dropTarget.fire(dropEvents.enter);\r\n }\r\n if (dropEvents.drop) {\r\n interaction.dropTarget.fire(dropEvents.drop);\r\n }\r\n if (dropEvents.deactivate) {\r\n fireActiveDrops(interaction, dropEvents.deactivate);\r\n }\r\n\r\n interaction.prevDropTarget = interaction.dropTarget;\r\n interaction.prevDropElement = interaction.dropElement;\r\n}\r\n\r\n/*\\\r\n * Interactable.dropzone\r\n [ method ]\r\n *\r\n * Returns or sets whether elements can be dropped onto this\r\n * Interactable to trigger drop events\r\n *\r\n * Dropzones can receive the following events:\r\n * - `dropactivate` and `dropdeactivate` when an acceptable drag starts and ends\r\n * - `dragenter` and `dragleave` when a draggable enters and leaves the dropzone\r\n * - `dragmove` when a draggable that has entered the dropzone is moved\r\n * - `drop` when a draggable is dropped into this dropzone\r\n *\r\n * Use the `accept` option to allow only elements that match the given CSS\r\n * selector or element. The value can be:\r\n *\r\n * - **an Element** - only that element can be dropped into this dropzone.\r\n * - **a string**, - the element being dragged must match it as a CSS selector.\r\n * - **`null`** - accept options is cleared - it accepts any element.\r\n *\r\n * Use the `overlap` option to set how drops are checked for. The allowed\r\n * values are:\r\n *\r\n * - `'pointer'`, the pointer must be over the dropzone (default)\r\n * - `'center'`, the draggable element's center must be over the dropzone\r\n * - a number from 0-1 which is the `(intersection area) / (draggable area)`.\r\n * e.g. `0.5` for drop to happen when half of the area of the draggable is\r\n * over the dropzone\r\n *\r\n * Use the `checker` option to specify a function to check if a dragged\r\n * element is over this Interactable.\r\n *\r\n | interact(target)\r\n | .dropChecker(function(dragEvent, // related dragmove or dragend event\r\n | event, // TouchEvent/PointerEvent/MouseEvent\r\n | dropped, // bool result of the default checker\r\n | dropzone, // dropzone Interactable\r\n | dropElement, // dropzone elemnt\r\n | draggable, // draggable Interactable\r\n | draggableElement) {// draggable element\r\n |\r\n | return dropped && event.target.hasAttribute('allow-drop');\r\n | }\r\n *\r\n *\r\n - options (boolean | object | null) #optional The new value to be set.\r\n | interact('.drop').dropzone({\r\n | accept: '.can-drop' || document.getElementById('single-drop'),\r\n | overlap: 'pointer' || 'center' || zeroToOne\r\n | }\r\n = (boolean | object) The current setting or this Interactable\r\n\\*/\r\nInteractable.prototype.dropzone = function (options) {\r\n if (utils.is.object(options)) {\r\n this.options.drop.enabled = options.enabled === false ? false : true;\r\n\r\n if (utils.is.function(options.ondrop)) {\r\n this.events.ondrop = options.ondrop;\r\n }\r\n if (utils.is.function(options.ondropactivate)) {\r\n this.events.ondropactivate = options.ondropactivate;\r\n }\r\n if (utils.is.function(options.ondropdeactivate)) {\r\n this.events.ondropdeactivate = options.ondropdeactivate;\r\n }\r\n if (utils.is.function(options.ondragenter)) {\r\n this.events.ondragenter = options.ondragenter;\r\n }\r\n if (utils.is.function(options.ondragleave)) {\r\n this.events.ondragleave = options.ondragleave;\r\n }\r\n if (utils.is.function(options.ondropmove)) {\r\n this.events.ondropmove = options.ondropmove;\r\n }\r\n\r\n if (/^(pointer|center)$/.test(options.overlap)) {\r\n this.options.drop.overlap = options.overlap;\r\n } else if (utils.is.number(options.overlap)) {\r\n this.options.drop.overlap = Math.max(Math.min(1, options.overlap), 0);\r\n }\r\n if ('accept' in options) {\r\n this.options.drop.accept = options.accept;\r\n }\r\n if ('checker' in options) {\r\n this.options.drop.checker = options.checker;\r\n }\r\n\r\n return this;\r\n }\r\n\r\n if (utils.is.bool(options)) {\r\n this.options.drop.enabled = options;\r\n\r\n if (!options) {\r\n this.ondragenter = this.ondragleave = this.ondrop = this.ondropactivate = this.ondropdeactivate = null;\r\n }\r\n\r\n return this;\r\n }\r\n\r\n return this.options.drop;\r\n};\r\n\r\nInteractable.prototype.dropCheck = function (dragEvent, event, draggable, draggableElement, dropElement, rect) {\r\n var dropped = false;\r\n\r\n // if the dropzone has no rect (eg. display: none)\r\n // call the custom dropChecker or just return false\r\n if (!(rect = rect || this.getRect(dropElement))) {\r\n return this.options.drop.checker ? this.options.drop.checker(dragEvent, event, dropped, this, dropElement, draggable, draggableElement) : false;\r\n }\r\n\r\n var dropOverlap = this.options.drop.overlap;\r\n\r\n if (dropOverlap === 'pointer') {\r\n var origin = utils.getOriginXY(draggable, draggableElement, 'drag');\r\n var page = utils.getPageXY(dragEvent);\r\n\r\n page.x += origin.x;\r\n page.y += origin.y;\r\n\r\n var horizontal = page.x > rect.left && page.x < rect.right;\r\n var vertical = page.y > rect.top && page.y < rect.bottom;\r\n\r\n dropped = horizontal && vertical;\r\n }\r\n\r\n var dragRect = draggable.getRect(draggableElement);\r\n\r\n if (dragRect && dropOverlap === 'center') {\r\n var cx = dragRect.left + dragRect.width / 2;\r\n var cy = dragRect.top + dragRect.height / 2;\r\n\r\n dropped = cx >= rect.left && cx <= rect.right && cy >= rect.top && cy <= rect.bottom;\r\n }\r\n\r\n if (dragRect && utils.is.number(dropOverlap)) {\r\n var overlapArea = Math.max(0, Math.min(rect.right, dragRect.right) - Math.max(rect.left, dragRect.left)) * Math.max(0, Math.min(rect.bottom, dragRect.bottom) - Math.max(rect.top, dragRect.top));\r\n\r\n var overlapRatio = overlapArea / (dragRect.width * dragRect.height);\r\n\r\n dropped = overlapRatio >= dropOverlap;\r\n }\r\n\r\n if (this.options.drop.checker) {\r\n dropped = this.options.drop.checker(dragEvent, event, dropped, this, dropElement, draggable, draggableElement);\r\n }\r\n\r\n return dropped;\r\n};\r\n\r\nInteractable.signals.on('unset', function (_ref7) {\r\n var interactable = _ref7.interactable;\r\n\r\n interactable.dropzone(false);\r\n});\r\n\r\nInteractable.settingsMethods.push('dropChecker');\r\n\r\nInteraction.signals.on('new', function (interaction) {\r\n interaction.dropTarget = null; // the dropzone a drag target might be dropped into\r\n interaction.dropElement = null; // the element at the time of checking\r\n interaction.prevDropTarget = null; // the dropzone that was recently dragged away from\r\n interaction.prevDropElement = null; // the element at the time of checking\r\n interaction.dropEvents = null; // the dropEvents related to the current drag event\r\n\r\n interaction.activeDrops = {\r\n dropzones: [], // the dropzones that are mentioned below\r\n elements: [], // elements of dropzones that accept the target draggable\r\n rects: [] // the rects of the elements mentioned above\r\n };\r\n});\r\n\r\nInteraction.signals.on('stop', function (_ref8) {\r\n var interaction = _ref8.interaction;\r\n\r\n interaction.dropTarget = interaction.dropElement = interaction.prevDropTarget = interaction.prevDropElement = null;\r\n});\r\n\r\n/*\\\r\n * interact.dynamicDrop\r\n [ method ]\r\n *\r\n * Returns or sets whether the dimensions of dropzone elements are\r\n * calculated on every dragmove or only on dragstart for the default\r\n * dropChecker\r\n *\r\n - newValue (boolean) #optional True to check on each move. False to check only before start\r\n = (boolean | interact) The current setting or interact\r\n\\*/\r\ninteract.dynamicDrop = function (newValue) {\r\n if (utils.is.bool(newValue)) {\r\n //if (dragging && dynamicDrop !== newValue && !newValue) {\r\n //calcRects(dropzones);\r\n //}\r\n\r\n dynamicDrop = newValue;\r\n\r\n return interact;\r\n }\r\n return dynamicDrop;\r\n};\r\n\r\nutils.merge(Interactable.eventTypes, ['dragenter', 'dragleave', 'dropactivate', 'dropdeactivate', 'dropmove', 'drop']);\r\nactions.methodDict.drop = 'dropzone';\r\n\r\ndefaultOptions.drop = drop.defaults;\r\n\r\nmodule.exports = drop;\r\n\r\n},{\"../InteractEvent\":3,\"../Interactable\":4,\"../Interaction\":5,\"../defaultOptions\":18,\"../interact\":21,\"../scope\":34,\"../utils\":44,\"./base\":6}],9:[function(require,module,exports){\r\n'use strict';\r\n\r\nvar actions = require('./base');\r\nvar utils = require('../utils');\r\nvar InteractEvent = require('../InteractEvent');\r\nvar Interactable = require('../Interactable');\r\nvar Interaction = require('../Interaction');\r\nvar defaultOptions = require('../defaultOptions');\r\n\r\nvar gesture = {\r\n defaults: {\r\n enabled: false,\r\n origin: null,\r\n restrict: null\r\n },\r\n\r\n checker: function checker(pointer, event, interactable, element, interaction) {\r\n if (interaction.pointerIds.length >= 2) {\r\n return { name: 'gesture' };\r\n }\r\n\r\n return null;\r\n },\r\n\r\n getCursor: function getCursor() {\r\n return '';\r\n }\r\n};\r\n\r\nInteractEvent.signals.on('new', function (_ref) {\r\n var iEvent = _ref.iEvent,\r\n interaction = _ref.interaction;\r\n\r\n if (iEvent.type !== 'gesturestart') {\r\n return;\r\n }\r\n iEvent.ds = 0;\r\n\r\n interaction.gesture.startDistance = interaction.gesture.prevDistance = iEvent.distance;\r\n interaction.gesture.startAngle = interaction.gesture.prevAngle = iEvent.angle;\r\n interaction.gesture.scale = 1;\r\n});\r\n\r\nInteractEvent.signals.on('new', function (_ref2) {\r\n var iEvent = _ref2.iEvent,\r\n interaction = _ref2.interaction;\r\n\r\n if (iEvent.type !== 'gesturemove') {\r\n return;\r\n }\r\n\r\n iEvent.ds = iEvent.scale - interaction.gesture.scale;\r\n\r\n interaction.target.fire(iEvent);\r\n\r\n interaction.gesture.prevAngle = iEvent.angle;\r\n interaction.gesture.prevDistance = iEvent.distance;\r\n\r\n if (iEvent.scale !== Infinity && iEvent.scale !== null && iEvent.scale !== undefined && !isNaN(iEvent.scale)) {\r\n\r\n interaction.gesture.scale = iEvent.scale;\r\n }\r\n});\r\n\r\n/*\\\r\n * Interactable.gesturable\r\n [ method ]\r\n *\r\n * Gets or sets whether multitouch gestures can be performed on the\r\n * Interactable's element\r\n *\r\n = (boolean) Indicates if this can be the target of gesture events\r\n | var isGestureable = interact(element).gesturable();\r\n * or\r\n - options (boolean | object) #optional true/false or An object with event listeners to be fired on gesture events (makes the Interactable gesturable)\r\n = (object) this Interactable\r\n | interact(element).gesturable({\r\n | onstart: function (event) {},\r\n | onmove : function (event) {},\r\n | onend : function (event) {},\r\n |\r\n | // limit multiple gestures.\r\n | // See the explanation in @Interactable.draggable example\r\n | max: Infinity,\r\n | maxPerElement: 1,\r\n | });\r\n\\*/\r\nInteractable.prototype.gesturable = function (options) {\r\n if (utils.is.object(options)) {\r\n this.options.gesture.enabled = options.enabled === false ? false : true;\r\n this.setPerAction('gesture', options);\r\n this.setOnEvents('gesture', options);\r\n\r\n return this;\r\n }\r\n\r\n if (utils.is.bool(options)) {\r\n this.options.gesture.enabled = options;\r\n\r\n if (!options) {\r\n this.ongesturestart = this.ongesturestart = this.ongestureend = null;\r\n }\r\n\r\n return this;\r\n }\r\n\r\n return this.options.gesture;\r\n};\r\n\r\nInteractEvent.signals.on('set-delta', function (_ref3) {\r\n var interaction = _ref3.interaction,\r\n iEvent = _ref3.iEvent,\r\n action = _ref3.action,\r\n event = _ref3.event,\r\n starting = _ref3.starting,\r\n ending = _ref3.ending,\r\n deltaSource = _ref3.deltaSource;\r\n\r\n if (action !== 'gesture') {\r\n return;\r\n }\r\n\r\n var pointers = interaction.pointers;\r\n\r\n iEvent.touches = [pointers[0], pointers[1]];\r\n\r\n if (starting) {\r\n iEvent.distance = utils.touchDistance(pointers, deltaSource);\r\n iEvent.box = utils.touchBBox(pointers);\r\n iEvent.scale = 1;\r\n iEvent.ds = 0;\r\n iEvent.angle = utils.touchAngle(pointers, undefined, deltaSource);\r\n iEvent.da = 0;\r\n } else if (ending || event instanceof InteractEvent) {\r\n iEvent.distance = interaction.prevEvent.distance;\r\n iEvent.box = interaction.prevEvent.box;\r\n iEvent.scale = interaction.prevEvent.scale;\r\n iEvent.ds = iEvent.scale - 1;\r\n iEvent.angle = interaction.prevEvent.angle;\r\n iEvent.da = iEvent.angle - interaction.gesture.startAngle;\r\n } else {\r\n iEvent.distance = utils.touchDistance(pointers, deltaSource);\r\n iEvent.box = utils.touchBBox(pointers);\r\n iEvent.scale = iEvent.distance / interaction.gesture.startDistance;\r\n iEvent.angle = utils.touchAngle(pointers, interaction.gesture.prevAngle, deltaSource);\r\n\r\n iEvent.ds = iEvent.scale - interaction.gesture.prevScale;\r\n iEvent.da = iEvent.angle - interaction.gesture.prevAngle;\r\n }\r\n});\r\n\r\nInteraction.signals.on('new', function (interaction) {\r\n interaction.gesture = {\r\n start: { x: 0, y: 0 },\r\n\r\n startDistance: 0, // distance between two touches of touchStart\r\n prevDistance: 0,\r\n distance: 0,\r\n\r\n scale: 1, // gesture.distance / gesture.startDistance\r\n\r\n startAngle: 0, // angle of line joining two touches\r\n prevAngle: 0 // angle of the previous gesture event\r\n };\r\n});\r\n\r\nactions.gesture = gesture;\r\nactions.names.push('gesture');\r\nutils.merge(Interactable.eventTypes, ['gesturestart', 'gesturemove', 'gestureend']);\r\nactions.methodDict.gesture = 'gesturable';\r\n\r\ndefaultOptions.gesture = gesture.defaults;\r\n\r\nmodule.exports = gesture;\r\n\r\n},{\"../InteractEvent\":3,\"../Interactable\":4,\"../Interaction\":5,\"../defaultOptions\":18,\"../utils\":44,\"./base\":6}],10:[function(require,module,exports){\r\n'use strict';\r\n\r\nvar actions = require('./base');\r\nvar utils = require('../utils');\r\nvar browser = require('../utils/browser');\r\nvar InteractEvent = require('../InteractEvent');\r\nvar Interactable = require('../Interactable');\r\nvar Interaction = require('../Interaction');\r\nvar defaultOptions = require('../defaultOptions');\r\n\r\n// Less Precision with touch input\r\nvar defaultMargin = browser.supportsTouch || browser.supportsPointerEvent ? 20 : 10;\r\n\r\nvar resize = {\r\n defaults: {\r\n enabled: false,\r\n mouseButtons: null,\r\n\r\n origin: null,\r\n snap: null,\r\n restrict: null,\r\n inertia: null,\r\n autoScroll: null,\r\n\r\n square: false,\r\n preserveAspectRatio: false,\r\n axis: 'xy',\r\n\r\n // use default margin\r\n margin: NaN,\r\n\r\n // object with props left, right, top, bottom which are\r\n // true/false values to resize when the pointer is over that edge,\r\n // CSS selectors to match the handles for each direction\r\n // or the Elements for each handle\r\n edges: null,\r\n\r\n // a value of 'none' will limit the resize rect to a minimum of 0x0\r\n // 'negate' will alow the rect to have negative width/height\r\n // 'reposition' will keep the width/height positive by swapping\r\n // the top and bottom edges and/or swapping the left and right edges\r\n invert: 'none'\r\n },\r\n\r\n checker: function checker(pointer, event, interactable, element, interaction, rect) {\r\n if (!rect) {\r\n return null;\r\n }\r\n\r\n var page = utils.extend({}, interaction.curCoords.page);\r\n var options = interactable.options;\r\n\r\n if (options.resize.enabled) {\r\n var resizeOptions = options.resize;\r\n var resizeEdges = { left: false, right: false, top: false, bottom: false };\r\n\r\n // if using resize.edges\r\n if (utils.is.object(resizeOptions.edges)) {\r\n for (var edge in resizeEdges) {\r\n resizeEdges[edge] = checkResizeEdge(edge, resizeOptions.edges[edge], page, interaction._eventTarget, element, rect, resizeOptions.margin || defaultMargin);\r\n }\r\n\r\n resizeEdges.left = resizeEdges.left && !resizeEdges.right;\r\n resizeEdges.top = resizeEdges.top && !resizeEdges.bottom;\r\n\r\n if (resizeEdges.left || resizeEdges.right || resizeEdges.top || resizeEdges.bottom) {\r\n return {\r\n name: 'resize',\r\n edges: resizeEdges\r\n };\r\n }\r\n } else {\r\n var right = options.resize.axis !== 'y' && page.x > rect.right - defaultMargin;\r\n var bottom = options.resize.axis !== 'x' && page.y > rect.bottom - defaultMargin;\r\n\r\n if (right || bottom) {\r\n return {\r\n name: 'resize',\r\n axes: (right ? 'x' : '') + (bottom ? 'y' : '')\r\n };\r\n }\r\n }\r\n }\r\n\r\n return null;\r\n },\r\n\r\n cursors: browser.isIe9OrOlder ? {\r\n x: 'e-resize',\r\n y: 's-resize',\r\n xy: 'se-resize',\r\n\r\n top: 'n-resize',\r\n left: 'w-resize',\r\n bottom: 's-resize',\r\n right: 'e-resize',\r\n topleft: 'se-resize',\r\n bottomright: 'se-resize',\r\n topright: 'ne-resize',\r\n bottomleft: 'ne-resize'\r\n } : {\r\n x: 'ew-resize',\r\n y: 'ns-resize',\r\n xy: 'nwse-resize',\r\n\r\n top: 'ns-resize',\r\n left: 'ew-resize',\r\n bottom: 'ns-resize',\r\n right: 'ew-resize',\r\n topleft: 'nwse-resize',\r\n bottomright: 'nwse-resize',\r\n topright: 'nesw-resize',\r\n bottomleft: 'nesw-resize'\r\n },\r\n\r\n getCursor: function getCursor(action) {\r\n if (action.axis) {\r\n return resize.cursors[action.name + action.axis];\r\n } else if (action.edges) {\r\n var cursorKey = '';\r\n var edgeNames = ['top', 'bottom', 'left', 'right'];\r\n\r\n for (var i = 0; i < 4; i++) {\r\n if (action.edges[edgeNames[i]]) {\r\n cursorKey += edgeNames[i];\r\n }\r\n }\r\n\r\n return resize.cursors[cursorKey];\r\n }\r\n }\r\n};\r\n\r\n// resizestart\r\nInteractEvent.signals.on('new', function (_ref) {\r\n var iEvent = _ref.iEvent,\r\n interaction = _ref.interaction;\r\n\r\n if (iEvent.type !== 'resizestart' || !interaction.prepared.edges) {\r\n return;\r\n }\r\n\r\n var startRect = interaction.target.getRect(interaction.element);\r\n var resizeOptions = interaction.target.options.resize;\r\n\r\n /*\r\n * When using the `resizable.square` or `resizable.preserveAspectRatio` options, resizing from one edge\r\n * will affect another. E.g. with `resizable.square`, resizing to make the right edge larger will make\r\n * the bottom edge larger by the same amount. We call these 'linked' edges. Any linked edges will depend\r\n * on the active edges and the edge being interacted with.\r\n */\r\n if (resizeOptions.square || resizeOptions.preserveAspectRatio) {\r\n var linkedEdges = utils.extend({}, interaction.prepared.edges);\r\n\r\n linkedEdges.top = linkedEdges.top || linkedEdges.left && !linkedEdges.bottom;\r\n linkedEdges.left = linkedEdges.left || linkedEdges.top && !linkedEdges.right;\r\n linkedEdges.bottom = linkedEdges.bottom || linkedEdges.right && !linkedEdges.top;\r\n linkedEdges.right = linkedEdges.right || linkedEdges.bottom && !linkedEdges.left;\r\n\r\n interaction.prepared._linkedEdges = linkedEdges;\r\n } else {\r\n interaction.prepared._linkedEdges = null;\r\n }\r\n\r\n // if using `resizable.preserveAspectRatio` option, record aspect ratio at the start of the resize\r\n if (resizeOptions.preserveAspectRatio) {\r\n interaction.resizeStartAspectRatio = startRect.width / startRect.height;\r\n }\r\n\r\n interaction.resizeRects = {\r\n start: startRect,\r\n current: utils.extend({}, startRect),\r\n inverted: utils.extend({}, startRect),\r\n previous: utils.extend({}, startRect),\r\n delta: {\r\n left: 0, right: 0, width: 0,\r\n top: 0, bottom: 0, height: 0\r\n }\r\n };\r\n\r\n iEvent.rect = interaction.resizeRects.inverted;\r\n iEvent.deltaRect = interaction.resizeRects.delta;\r\n});\r\n\r\n// resizemove\r\nInteractEvent.signals.on('new', function (_ref2) {\r\n var iEvent = _ref2.iEvent,\r\n phase = _ref2.phase,\r\n interaction = _ref2.interaction;\r\n\r\n if (phase !== 'move' || !interaction.prepared.edges) {\r\n return;\r\n }\r\n\r\n var resizeOptions = interaction.target.options.resize;\r\n var invert = resizeOptions.invert;\r\n var invertible = invert === 'reposition' || invert === 'negate';\r\n\r\n var edges = interaction.prepared.edges;\r\n\r\n var start = interaction.resizeRects.start;\r\n var current = interaction.resizeRects.current;\r\n var inverted = interaction.resizeRects.inverted;\r\n var delta = interaction.resizeRects.delta;\r\n var previous = utils.extend(interaction.resizeRects.previous, inverted);\r\n var originalEdges = edges;\r\n\r\n var dx = iEvent.dx;\r\n var dy = iEvent.dy;\r\n\r\n if (resizeOptions.preserveAspectRatio || resizeOptions.square) {\r\n // `resize.preserveAspectRatio` takes precedence over `resize.square`\r\n var startAspectRatio = resizeOptions.preserveAspectRatio ? interaction.resizeStartAspectRatio : 1;\r\n\r\n edges = interaction.prepared._linkedEdges;\r\n\r\n if (originalEdges.left && originalEdges.bottom || originalEdges.right && originalEdges.top) {\r\n dy = -dx / startAspectRatio;\r\n } else if (originalEdges.left || originalEdges.right) {\r\n dy = dx / startAspectRatio;\r\n } else if (originalEdges.top || originalEdges.bottom) {\r\n dx = dy * startAspectRatio;\r\n }\r\n }\r\n\r\n // update the 'current' rect without modifications\r\n if (edges.top) {\r\n current.top += dy;\r\n }\r\n if (edges.bottom) {\r\n current.bottom += dy;\r\n }\r\n if (edges.left) {\r\n current.left += dx;\r\n }\r\n if (edges.right) {\r\n current.right += dx;\r\n }\r\n\r\n if (invertible) {\r\n // if invertible, copy the current rect\r\n utils.extend(inverted, current);\r\n\r\n if (invert === 'reposition') {\r\n // swap edge values if necessary to keep width/height positive\r\n var swap = void 0;\r\n\r\n if (inverted.top > inverted.bottom) {\r\n swap = inverted.top;\r\n\r\n inverted.top = inverted.bottom;\r\n inverted.bottom = swap;\r\n }\r\n if (inverted.left > inverted.right) {\r\n swap = inverted.left;\r\n\r\n inverted.left = inverted.right;\r\n inverted.right = swap;\r\n }\r\n }\r\n } else {\r\n // if not invertible, restrict to minimum of 0x0 rect\r\n inverted.top = Math.min(current.top, start.bottom);\r\n inverted.bottom = Math.max(current.bottom, start.top);\r\n inverted.left = Math.min(current.left, start.right);\r\n inverted.right = Math.max(current.right, start.left);\r\n }\r\n\r\n inverted.width = inverted.right - inverted.left;\r\n inverted.height = inverted.bottom - inverted.top;\r\n\r\n for (var edge in inverted) {\r\n delta[edge] = inverted[edge] - previous[edge];\r\n }\r\n\r\n iEvent.edges = interaction.prepared.edges;\r\n iEvent.rect = inverted;\r\n iEvent.deltaRect = delta;\r\n});\r\n\r\n/*\\\r\n * Interactable.resizable\r\n [ method ]\r\n *\r\n * Gets or sets whether resize actions can be performed on the\r\n * Interactable\r\n *\r\n = (boolean) Indicates if this can be the target of resize elements\r\n | var isResizeable = interact('input[type=text]').resizable();\r\n * or\r\n - options (boolean | object) #optional true/false or An object with event listeners to be fired on resize events (object makes the Interactable resizable)\r\n = (object) This Interactable\r\n | interact(element).resizable({\r\n | onstart: function (event) {},\r\n | onmove : function (event) {},\r\n | onend : function (event) {},\r\n |\r\n | edges: {\r\n | top : true, // Use pointer coords to check for resize.\r\n | left : false, // Disable resizing from left edge.\r\n | bottom: '.resize-s',// Resize if pointer target matches selector\r\n | right : handleEl // Resize if pointer target is the given Element\r\n | },\r\n |\r\n | // Width and height can be adjusted independently. When `true`, width and\r\n | // height are adjusted at a 1:1 ratio.\r\n | square: false,\r\n |\r\n | // Width and height can be adjusted independently. When `true`, width and\r\n | // height maintain the aspect ratio they had when resizing started.\r\n | preserveAspectRatio: false,\r\n |\r\n | // a value of 'none' will limit the resize rect to a minimum of 0x0\r\n | // 'negate' will allow the rect to have negative width/height\r\n | // 'reposition' will keep the width/height positive by swapping\r\n | // the top and bottom edges and/or swapping the left and right edges\r\n | invert: 'none' || 'negate' || 'reposition'\r\n |\r\n | // limit multiple resizes.\r\n | // See the explanation in the @Interactable.draggable example\r\n | max: Infinity,\r\n | maxPerElement: 1,\r\n | });\r\n \\*/\r\nInteractable.prototype.resizable = function (options) {\r\n if (utils.is.object(options)) {\r\n this.options.resize.enabled = options.enabled === false ? false : true;\r\n this.setPerAction('resize', options);\r\n this.setOnEvents('resize', options);\r\n\r\n if (/^x$|^y$|^xy$/.test(options.axis)) {\r\n this.options.resize.axis = options.axis;\r\n } else if (options.axis === null) {\r\n this.options.resize.axis = defaultOptions.resize.axis;\r\n }\r\n\r\n if (utils.is.bool(options.preserveAspectRatio)) {\r\n this.options.resize.preserveAspectRatio = options.preserveAspectRatio;\r\n } else if (utils.is.bool(options.square)) {\r\n this.options.resize.square = options.square;\r\n }\r\n\r\n return this;\r\n }\r\n if (utils.is.bool(options)) {\r\n this.options.resize.enabled = options;\r\n\r\n if (!options) {\r\n this.onresizestart = this.onresizestart = this.onresizeend = null;\r\n }\r\n\r\n return this;\r\n }\r\n return this.options.resize;\r\n};\r\n\r\nfunction checkResizeEdge(name, value, page, element, interactableElement, rect, margin) {\r\n // false, '', undefined, null\r\n if (!value) {\r\n return false;\r\n }\r\n\r\n // true value, use pointer coords and element rect\r\n if (value === true) {\r\n // if dimensions are negative, \"switch\" edges\r\n var width = utils.is.number(rect.width) ? rect.width : rect.right - rect.left;\r\n var height = utils.is.number(rect.height) ? rect.height : rect.bottom - rect.top;\r\n\r\n if (width < 0) {\r\n if (name === 'left') {\r\n name = 'right';\r\n } else if (name === 'right') {\r\n name = 'left';\r\n }\r\n }\r\n if (height < 0) {\r\n if (name === 'top') {\r\n name = 'bottom';\r\n } else if (name === 'bottom') {\r\n name = 'top';\r\n }\r\n }\r\n\r\n if (name === 'left') {\r\n return page.x < (width >= 0 ? rect.left : rect.right) + margin;\r\n }\r\n if (name === 'top') {\r\n return page.y < (height >= 0 ? rect.top : rect.bottom) + margin;\r\n }\r\n\r\n if (name === 'right') {\r\n return page.x > (width >= 0 ? rect.right : rect.left) - margin;\r\n }\r\n if (name === 'bottom') {\r\n return page.y > (height >= 0 ? rect.bottom : rect.top) - margin;\r\n }\r\n }\r\n\r\n // the remaining checks require an element\r\n if (!utils.is.element(element)) {\r\n return false;\r\n }\r\n\r\n return utils.is.element(value)\r\n // the value is an element to use as a resize handle\r\n ? value === element\r\n // otherwise check if element matches value as selector\r\n : utils.matchesUpTo(element, value, interactableElement);\r\n}\r\n\r\nInteraction.signals.on('new', function (interaction) {\r\n interaction.resizeAxes = 'xy';\r\n});\r\n\r\nInteractEvent.signals.on('set-delta', function (_ref3) {\r\n var interaction = _ref3.interaction,\r\n iEvent = _ref3.iEvent,\r\n action = _ref3.action;\r\n\r\n if (action !== 'resize' || !interaction.resizeAxes) {\r\n return;\r\n }\r\n\r\n var options = interaction.target.options;\r\n\r\n if (options.resize.square) {\r\n if (interaction.resizeAxes === 'y') {\r\n iEvent.dx = iEvent.dy;\r\n } else {\r\n iEvent.dy = iEvent.dx;\r\n }\r\n iEvent.axes = 'xy';\r\n } else {\r\n iEvent.axes = interaction.resizeAxes;\r\n\r\n if (interaction.resizeAxes === 'x') {\r\n iEvent.dy = 0;\r\n } else if (interaction.resizeAxes === 'y') {\r\n iEvent.dx = 0;\r\n }\r\n }\r\n});\r\n\r\nactions.resize = resize;\r\nactions.names.push('resize');\r\nutils.merge(Interactable.eventTypes, ['resizestart', 'resizemove', 'resizeinertiastart', 'resizeinertiaresume', 'resizeend']);\r\nactions.methodDict.resize = 'resizable';\r\n\r\ndefaultOptions.resize = resize.defaults;\r\n\r\nmodule.exports = resize;\r\n\r\n},{\"../InteractEvent\":3,\"../Interactable\":4,\"../Interaction\":5,\"../defaultOptions\":18,\"../utils\":44,\"../utils/browser\":37,\"./base\":6}],11:[function(require,module,exports){\r\n'use strict';\r\n\r\nvar raf = require('./utils/raf');\r\nvar getWindow = require('./utils/window').getWindow;\r\nvar is = require('./utils/is');\r\nvar domUtils = require('./utils/domUtils');\r\nvar Interaction = require('./Interaction');\r\nvar defaultOptions = require('./defaultOptions');\r\n\r\nvar autoScroll = {\r\n defaults: {\r\n enabled: false,\r\n container: null, // the item that is scrolled (Window or HTMLElement)\r\n margin: 60,\r\n speed: 300 // the scroll speed in pixels per second\r\n },\r\n\r\n interaction: null,\r\n i: null, // the handle returned by window.setInterval\r\n x: 0, y: 0, // Direction each pulse is to scroll in\r\n\r\n isScrolling: false,\r\n prevTime: 0,\r\n\r\n start: function start(interaction) {\r\n autoScroll.isScrolling = true;\r\n raf.cancel(autoScroll.i);\r\n\r\n autoScroll.interaction = interaction;\r\n autoScroll.prevTime = new Date().getTime();\r\n autoScroll.i = raf.request(autoScroll.scroll);\r\n },\r\n\r\n stop: function stop() {\r\n autoScroll.isScrolling = false;\r\n raf.cancel(autoScroll.i);\r\n },\r\n\r\n // scroll the window by the values in scroll.x/y\r\n scroll: function scroll() {\r\n var options = autoScroll.interaction.target.options[autoScroll.interaction.prepared.name].autoScroll;\r\n var container = options.container || getWindow(autoScroll.interaction.element);\r\n var now = new Date().getTime();\r\n // change in time in seconds\r\n var dt = (now - autoScroll.prevTime) / 1000;\r\n // displacement\r\n var s = options.speed * dt;\r\n\r\n if (s >= 1) {\r\n if (is.window(container)) {\r\n container.scrollBy(autoScroll.x * s, autoScroll.y * s);\r\n } else if (container) {\r\n container.scrollLeft += autoScroll.x * s;\r\n container.scrollTop += autoScroll.y * s;\r\n }\r\n\r\n autoScroll.prevTime = now;\r\n }\r\n\r\n if (autoScroll.isScrolling) {\r\n raf.cancel(autoScroll.i);\r\n autoScroll.i = raf.request(autoScroll.scroll);\r\n }\r\n },\r\n check: function check(interactable, actionName) {\r\n var options = interactable.options;\r\n\r\n return options[actionName].autoScroll && options[actionName].autoScroll.enabled;\r\n },\r\n onInteractionMove: function onInteractionMove(_ref) {\r\n var interaction = _ref.interaction,\r\n pointer = _ref.pointer;\r\n\r\n if (!(interaction.interacting() && autoScroll.check(interaction.target, interaction.prepared.name))) {\r\n return;\r\n }\r\n\r\n if (interaction.simulation) {\r\n autoScroll.x = autoScroll.y = 0;\r\n return;\r\n }\r\n\r\n var top = void 0;\r\n var right = void 0;\r\n var bottom = void 0;\r\n var left = void 0;\r\n\r\n var options = interaction.target.options[interaction.prepared.name].autoScroll;\r\n var container = options.container || getWindow(interaction.element);\r\n\r\n if (is.window(container)) {\r\n left = pointer.clientX < autoScroll.margin;\r\n top = pointer.clientY < autoScroll.margin;\r\n right = pointer.clientX > container.innerWidth - autoScroll.margin;\r\n bottom = pointer.clientY > container.innerHeight - autoScroll.margin;\r\n } else {\r\n var rect = domUtils.getElementClientRect(container);\r\n\r\n left = pointer.clientX < rect.left + autoScroll.margin;\r\n top = pointer.clientY < rect.top + autoScroll.margin;\r\n right = pointer.clientX > rect.right - autoScroll.margin;\r\n bottom = pointer.clientY > rect.bottom - autoScroll.margin;\r\n }\r\n\r\n autoScroll.x = right ? 1 : left ? -1 : 0;\r\n autoScroll.y = bottom ? 1 : top ? -1 : 0;\r\n\r\n if (!autoScroll.isScrolling) {\r\n // set the autoScroll properties to those of the target\r\n autoScroll.margin = options.margin;\r\n autoScroll.speed = options.speed;\r\n\r\n autoScroll.start(interaction);\r\n }\r\n }\r\n};\r\n\r\nInteraction.signals.on('stop-active', function () {\r\n autoScroll.stop();\r\n});\r\n\r\nInteraction.signals.on('action-move', autoScroll.onInteractionMove);\r\n\r\ndefaultOptions.perAction.autoScroll = autoScroll.defaults;\r\n\r\nmodule.exports = autoScroll;\r\n\r\n},{\"./Interaction\":5,\"./defaultOptions\":18,\"./utils/domUtils\":39,\"./utils/is\":46,\"./utils/raf\":50,\"./utils/window\":52}],12:[function(require,module,exports){\r\n'use strict';\r\n\r\nvar Interactable = require('../Interactable');\r\nvar actions = require('../actions/base');\r\nvar is = require('../utils/is');\r\nvar domUtils = require('../utils/domUtils');\r\n\r\nInteractable.prototype.getAction = function (pointer, event, interaction, element) {\r\n var action = this.defaultActionChecker(pointer, event, interaction, element);\r\n\r\n if (this.options.actionChecker) {\r\n return this.options.actionChecker(pointer, event, action, this, element, interaction);\r\n }\r\n\r\n return action;\r\n};\r\n\r\n/*\\\r\n * Interactable.ignoreFrom\r\n [ method ]\r\n *\r\n * If the target of the `mousedown`, `pointerdown` or `touchstart`\r\n * event or any of it's parents match the given CSS selector or\r\n * Element, no drag/resize/gesture is started.\r\n *\r\n - newValue (string | Element | null) #optional a CSS selector string, an Element or `null` to not ignore any elements\r\n = (string | Element | object) The current ignoreFrom value or this Interactable\r\n **\r\n | interact(element, { ignoreFrom: document.getElementById('no-action') });\r\n | // or\r\n | interact(element).ignoreFrom('input, textarea, a');\r\n\\*/\r\nInteractable.prototype.ignoreFrom = function (newValue) {\r\n return this._backCompatOption('ignoreFrom', newValue);\r\n};\r\n\r\n/*\\\r\n * Interactable.allowFrom\r\n [ method ]\r\n *\r\n * A drag/resize/gesture is started only If the target of the\r\n * `mousedown`, `pointerdown` or `touchstart` event or any of it's\r\n * parents match the given CSS selector or Element.\r\n *\r\n - newValue (string | Element | null) #optional a CSS selector string, an Element or `null` to allow from any element\r\n = (string | Element | object) The current allowFrom value or this Interactable\r\n **\r\n | interact(element, { allowFrom: document.getElementById('drag-handle') });\r\n | // or\r\n | interact(element).allowFrom('.handle');\r\n\\*/\r\nInteractable.prototype.allowFrom = function (newValue) {\r\n return this._backCompatOption('allowFrom', newValue);\r\n};\r\n\r\nInteractable.prototype.testIgnore = function (ignoreFrom, interactableElement, element) {\r\n if (!ignoreFrom || !is.element(element)) {\r\n return false;\r\n }\r\n\r\n if (is.string(ignoreFrom)) {\r\n return domUtils.matchesUpTo(element, ignoreFrom, interactableElement);\r\n } else if (is.element(ignoreFrom)) {\r\n return domUtils.nodeContains(ignoreFrom, element);\r\n }\r\n\r\n return false;\r\n};\r\n\r\nInteractable.prototype.testAllow = function (allowFrom, interactableElement, element) {\r\n if (!allowFrom) {\r\n return true;\r\n }\r\n\r\n if (!is.element(element)) {\r\n return false;\r\n }\r\n\r\n if (is.string(allowFrom)) {\r\n return domUtils.matchesUpTo(element, allowFrom, interactableElement);\r\n } else if (is.element(allowFrom)) {\r\n return domUtils.nodeContains(allowFrom, element);\r\n }\r\n\r\n return false;\r\n};\r\n\r\nInteractable.prototype.testIgnoreAllow = function (options, interactableElement, eventTarget) {\r\n return !this.testIgnore(options.ignoreFrom, interactableElement, eventTarget) && this.testAllow(options.allowFrom, interactableElement, eventTarget);\r\n};\r\n\r\n/*\\\r\n * Interactable.actionChecker\r\n [ method ]\r\n *\r\n * Gets or sets the function used to check action to be performed on\r\n * pointerDown\r\n *\r\n - checker (function | null) #optional A function which takes a pointer event, defaultAction string, interactable, element and interaction as parameters and returns an object with name property 'drag' 'resize' or 'gesture' and optionally an `edges` object with boolean 'top', 'left', 'bottom' and right props.\r\n = (Function | Interactable) The checker function or this Interactable\r\n *\r\n | interact('.resize-drag')\r\n | .resizable(true)\r\n | .draggable(true)\r\n | .actionChecker(function (pointer, event, action, interactable, element, interaction) {\r\n |\r\n | if (interact.matchesSelector(event.target, '.drag-handle') {\r\n | // force drag with handle target\r\n | action.name = drag;\r\n | }\r\n | else {\r\n | // resize from the top and right edges\r\n | action.name = 'resize';\r\n | action.edges = { top: true, right: true };\r\n | }\r\n |\r\n | return action;\r\n | });\r\n\\*/\r\nInteractable.prototype.actionChecker = function (checker) {\r\n if (is.function(checker)) {\r\n this.options.actionChecker = checker;\r\n\r\n return this;\r\n }\r\n\r\n if (checker === null) {\r\n delete this.options.actionChecker;\r\n\r\n return this;\r\n }\r\n\r\n return this.options.actionChecker;\r\n};\r\n\r\n/*\\\r\n * Interactable.styleCursor\r\n [ method ]\r\n *\r\n * Returns or sets whether the the cursor should be changed depending on the\r\n * action that would be performed if the mouse were pressed and dragged.\r\n *\r\n - newValue (boolean) #optional\r\n = (boolean | Interactable) The current setting or this Interactable\r\n\\*/\r\nInteractable.prototype.styleCursor = function (newValue) {\r\n if (is.bool(newValue)) {\r\n this.options.styleCursor = newValue;\r\n\r\n return this;\r\n }\r\n\r\n if (newValue === null) {\r\n delete this.options.styleCursor;\r\n\r\n return this;\r\n }\r\n\r\n return this.options.styleCursor;\r\n};\r\n\r\nInteractable.prototype.defaultActionChecker = function (pointer, event, interaction, element) {\r\n var rect = this.getRect(element);\r\n var action = null;\r\n\r\n for (var _iterator = actions.names, _isArray = Array.isArray(_iterator), _i = 0, _iterator = _isArray ? _iterator : _iterator[Symbol.iterator]();;) {\r\n var _ref;\r\n\r\n if (_isArray) {\r\n if (_i >= _iterator.length) break;\r\n _ref = _iterator[_i++];\r\n } else {\r\n _i = _iterator.next();\r\n if (_i.done) break;\r\n _ref = _i.value;\r\n }\r\n\r\n var actionName = _ref;\r\n\r\n // check mouseButton setting if the pointer is down\r\n if (interaction.pointerIsDown && interaction.mouse && (event.buttons & this.options[actionName].mouseButtons) === 0) {\r\n continue;\r\n }\r\n\r\n action = actions[actionName].checker(pointer, event, this, element, interaction, rect);\r\n\r\n if (action) {\r\n return action;\r\n }\r\n }\r\n};\r\n\r\n},{\"../Interactable\":4,\"../actions/base\":6,\"../utils/domUtils\":39,\"../utils/is\":46}],13:[function(require,module,exports){\r\n'use strict';\r\n\r\nvar interact = require('../interact');\r\nvar Interactable = require('../Interactable');\r\nvar Interaction = require('../Interaction');\r\nvar actions = require('../actions/base');\r\nvar defaultOptions = require('../defaultOptions');\r\nvar browser = require('../utils/browser');\r\nvar scope = require('../scope');\r\nvar utils = require('../utils');\r\nvar signals = require('../utils/Signals').new();\r\n\r\nrequire('./InteractableMethods');\r\n\r\nvar autoStart = {\r\n signals: signals,\r\n withinInteractionLimit: withinInteractionLimit,\r\n // Allow this many interactions to happen simultaneously\r\n maxInteractions: Infinity,\r\n defaults: {\r\n perAction: {\r\n manualStart: false,\r\n max: Infinity,\r\n maxPerElement: 1,\r\n allowFrom: null,\r\n ignoreFrom: null\r\n }\r\n },\r\n setActionDefaults: function setActionDefaults(action) {\r\n utils.extend(action.defaults, autoStart.defaults.perAction);\r\n }\r\n};\r\n\r\n// set cursor style on mousedown\r\nInteraction.signals.on('down', function (_ref) {\r\n var interaction = _ref.interaction,\r\n pointer = _ref.pointer,\r\n event = _ref.event,\r\n eventTarget = _ref.eventTarget;\r\n\r\n if (interaction.interacting()) {\r\n return;\r\n }\r\n\r\n var actionInfo = getActionInfo(interaction, pointer, event, eventTarget);\r\n prepare(interaction, actionInfo);\r\n});\r\n\r\n// set cursor style on mousemove\r\nInteraction.signals.on('move', function (_ref2) {\r\n var interaction = _ref2.interaction,\r\n pointer = _ref2.pointer,\r\n event = _ref2.event,\r\n eventTarget = _ref2.eventTarget;\r\n\r\n if (!interaction.mouse || interaction.pointerIsDown || interaction.interacting()) {\r\n return;\r\n }\r\n\r\n var actionInfo = getActionInfo(interaction, pointer, event, eventTarget);\r\n prepare(interaction, actionInfo);\r\n});\r\n\r\nInteraction.signals.on('move', function (arg) {\r\n var interaction = arg.interaction,\r\n event = arg.event;\r\n\r\n\r\n if (!interaction.pointerIsDown || interaction.interacting() || !interaction.pointerWasMoved || !interaction.prepared.name) {\r\n return;\r\n }\r\n\r\n signals.fire('before-start', arg);\r\n\r\n var target = interaction.target;\r\n\r\n if (interaction.prepared.name && target) {\r\n // check manualStart and interaction limit\r\n if (target.options[interaction.prepared.name].manualStart || !withinInteractionLimit(target, interaction.element, interaction.prepared)) {\r\n interaction.stop(event);\r\n } else {\r\n interaction.start(interaction.prepared, target, interaction.element);\r\n }\r\n }\r\n});\r\n\r\n// Check if the current target supports the action.\r\n// If so, return the validated action. Otherwise, return null\r\nfunction validateAction(action, interactable, element, eventTarget) {\r\n if (utils.is.object(action) && interactable.testIgnoreAllow(interactable.options[action.name], element, eventTarget) && interactable.options[action.name].enabled && withinInteractionLimit(interactable, element, action)) {\r\n return action;\r\n }\r\n\r\n return null;\r\n}\r\n\r\nfunction validateSelector(interaction, pointer, event, matches, matchElements, eventTarget) {\r\n for (var i = 0, len = matches.length; i < len; i++) {\r\n var match = matches[i];\r\n var matchElement = matchElements[i];\r\n var action = validateAction(match.getAction(pointer, event, interaction, matchElement), match, matchElement, eventTarget);\r\n\r\n if (action) {\r\n return {\r\n action: action,\r\n target: match,\r\n element: matchElement\r\n };\r\n }\r\n }\r\n\r\n return {};\r\n}\r\n\r\nfunction getActionInfo(interaction, pointer, event, eventTarget) {\r\n var matches = [];\r\n var matchElements = [];\r\n\r\n var element = eventTarget;\r\n var action = null;\r\n\r\n function pushMatches(interactable, selector, context) {\r\n var elements = browser.useMatchesSelectorPolyfill ? context.querySelectorAll(selector) : undefined;\r\n\r\n if (utils.matchesSelector(element, selector, elements)) {\r\n\r\n matches.push(interactable);\r\n matchElements.push(element);\r\n }\r\n }\r\n\r\n while (utils.is.element(element)) {\r\n matches = [];\r\n matchElements = [];\r\n\r\n var elementInteractable = scope.interactables.get(element);\r\n\r\n if (elementInteractable && (action = validateAction(elementInteractable.getAction(pointer, event, interaction, element, eventTarget), elementInteractable, element, eventTarget)) && !elementInteractable.options[action.name].manualStart) {\r\n return {\r\n element: element,\r\n action: action,\r\n target: elementInteractable\r\n };\r\n } else {\r\n scope.interactables.forEachSelector(pushMatches, element);\r\n\r\n var actionInfo = validateSelector(interaction, pointer, event, matches, matchElements, eventTarget);\r\n\r\n if (actionInfo.action && !actionInfo.target.options[actionInfo.action.name].manualStart) {\r\n return actionInfo;\r\n }\r\n }\r\n\r\n element = utils.parentNode(element);\r\n }\r\n\r\n return {};\r\n}\r\n\r\nfunction prepare(interaction, _ref3) {\r\n var action = _ref3.action,\r\n target = _ref3.target,\r\n element = _ref3.element;\r\n\r\n action = action || {};\r\n\r\n if (interaction.target && interaction.target.options.styleCursor) {\r\n interaction.target._doc.documentElement.style.cursor = '';\r\n }\r\n\r\n interaction.target = target;\r\n interaction.element = element;\r\n utils.copyAction(interaction.prepared, action);\r\n\r\n if (target && target.options.styleCursor) {\r\n var cursor = action ? actions[action.name].getCursor(action) : '';\r\n interaction.target._doc.documentElement.style.cursor = cursor;\r\n }\r\n\r\n signals.fire('prepared', { interaction: interaction });\r\n}\r\n\r\nInteraction.signals.on('stop', function (_ref4) {\r\n var interaction = _ref4.interaction;\r\n\r\n var target = interaction.target;\r\n\r\n if (target && target.options.styleCursor) {\r\n target._doc.documentElement.style.cursor = '';\r\n }\r\n});\r\n\r\nInteractable.prototype.getAction = function (pointer, event, interaction, element) {\r\n var action = this.defaultActionChecker(pointer, event, interaction, element);\r\n\r\n if (this.options.actionChecker) {\r\n return this.options.actionChecker(pointer, event, action, this, element, interaction);\r\n }\r\n\r\n return action;\r\n};\r\n\r\n/*\\\r\n * Interactable.actionChecker\r\n [ method ]\r\n *\r\n * Gets or sets the function used to check action to be performed on\r\n * pointerDown\r\n *\r\n - checker (function | null) #optional A function which takes a pointer event, defaultAction string, interactable, element and interaction as parameters and returns an object with name property 'drag' 'resize' or 'gesture' and optionally an `edges` object with boolean 'top', 'left', 'bottom' and right props.\r\n = (Function | Interactable) The checker function or this Interactable\r\n *\r\n | interact('.resize-drag')\r\n | .resizable(true)\r\n | .draggable(true)\r\n | .actionChecker(function (pointer, event, action, interactable, element, interaction) {\r\n |\r\n | if (interact.matchesSelector(event.target, '.drag-handle') {\r\n | // force drag with handle target\r\n | action.name = drag;\r\n | }\r\n | else {\r\n | // resize from the top and right edges\r\n | action.name = 'resize';\r\n | action.edges = { top: true, right: true };\r\n | }\r\n |\r\n | return action;\r\n | });\r\n\\*/\r\nInteractable.prototype.actionChecker = function (checker) {\r\n if (utils.is.function(checker)) {\r\n this.options.actionChecker = checker;\r\n\r\n return this;\r\n }\r\n\r\n if (checker === null) {\r\n delete this.options.actionChecker;\r\n\r\n return this;\r\n }\r\n\r\n return this.options.actionChecker;\r\n};\r\n\r\n/*\\\r\n * Interactable.styleCursor\r\n [ method ]\r\n *\r\n * Returns or sets whether the the cursor should be changed depending on the\r\n * action that would be performed if the mouse were pressed and dragged.\r\n *\r\n - newValue (boolean) #optional\r\n = (boolean | Interactable) The current setting or this Interactable\r\n\\*/\r\nInteractable.prototype.styleCursor = function (newValue) {\r\n if (utils.is.bool(newValue)) {\r\n this.options.styleCursor = newValue;\r\n\r\n return this;\r\n }\r\n\r\n if (newValue === null) {\r\n delete this.options.styleCursor;\r\n\r\n return this;\r\n }\r\n\r\n return this.options.styleCursor;\r\n};\r\n\r\nInteractable.prototype.defaultActionChecker = function (pointer, event, interaction, element) {\r\n var rect = this.getRect(element);\r\n var buttons = event.buttons || {\r\n 0: 1,\r\n 1: 4,\r\n 3: 8,\r\n 4: 16\r\n }[event.button];\r\n var action = null;\r\n\r\n for (var _iterator = actions.names, _isArray = Array.isArray(_iterator), _i = 0, _iterator = _isArray ? _iterator : _iterator[Symbol.iterator]();;) {\r\n var _ref5;\r\n\r\n if (_isArray) {\r\n if (_i >= _iterator.length) break;\r\n _ref5 = _iterator[_i++];\r\n } else {\r\n _i = _iterator.next();\r\n if (_i.done) break;\r\n _ref5 = _i.value;\r\n }\r\n\r\n var actionName = _ref5;\r\n\r\n // check mouseButton setting if the pointer is down\r\n if (interaction.pointerIsDown && interaction.mouse && (buttons & this.options[actionName].mouseButtons) === 0) {\r\n continue;\r\n }\r\n\r\n action = actions[actionName].checker(pointer, event, this, element, interaction, rect);\r\n\r\n if (action) {\r\n return action;\r\n }\r\n }\r\n};\r\n\r\nfunction withinInteractionLimit(interactable, element, action) {\r\n var options = interactable.options;\r\n var maxActions = options[action.name].max;\r\n var maxPerElement = options[action.name].maxPerElement;\r\n var activeInteractions = 0;\r\n var targetCount = 0;\r\n var targetElementCount = 0;\r\n\r\n // no actions if any of these values == 0\r\n if (!(maxActions && maxPerElement && autoStart.maxInteractions)) {\r\n return;\r\n }\r\n\r\n for (var i = 0, len = scope.interactions.length; i < len; i++) {\r\n var interaction = scope.interactions[i];\r\n var otherAction = interaction.prepared.name;\r\n\r\n if (!interaction.interacting()) {\r\n continue;\r\n }\r\n\r\n activeInteractions++;\r\n\r\n if (activeInteractions >= autoStart.maxInteractions) {\r\n return false;\r\n }\r\n\r\n if (interaction.target !== interactable) {\r\n continue;\r\n }\r\n\r\n targetCount += otherAction === action.name | 0;\r\n\r\n if (targetCount >= maxActions) {\r\n return false;\r\n }\r\n\r\n if (interaction.element === element) {\r\n targetElementCount++;\r\n\r\n if (otherAction !== action.name || targetElementCount >= maxPerElement) {\r\n return false;\r\n }\r\n }\r\n }\r\n\r\n return autoStart.maxInteractions > 0;\r\n}\r\n\r\n/*\\\r\n * interact.maxInteractions\r\n [ method ]\r\n **\r\n * Returns or sets the maximum number of concurrent interactions allowed.\r\n * By default only 1 interaction is allowed at a time (for backwards\r\n * compatibility). To allow multiple interactions on the same Interactables\r\n * and elements, you need to enable it in the draggable, resizable and\r\n * gesturable `'max'` and `'maxPerElement'` options.\r\n **\r\n - newValue (number) #optional Any number. newValue <= 0 means no interactions.\r\n\\*/\r\ninteract.maxInteractions = function (newValue) {\r\n if (utils.is.number(newValue)) {\r\n autoStart.maxInteractions = newValue;\r\n\r\n return this;\r\n }\r\n\r\n return autoStart.maxInteractions;\r\n};\r\n\r\nInteractable.settingsMethods.push('styleCursor');\r\nInteractable.settingsMethods.push('actionChecker');\r\nInteractable.settingsMethods.push('ignoreFrom');\r\nInteractable.settingsMethods.push('allowFrom');\r\n\r\ndefaultOptions.base.actionChecker = null;\r\ndefaultOptions.base.styleCursor = true;\r\n\r\nutils.extend(defaultOptions.perAction, autoStart.defaults.perAction);\r\n\r\nmodule.exports = autoStart;\r\n\r\n},{\"../Interactable\":4,\"../Interaction\":5,\"../actions/base\":6,\"../defaultOptions\":18,\"../interact\":21,\"../scope\":34,\"../utils\":44,\"../utils/Signals\":35,\"../utils/browser\":37,\"./InteractableMethods\":12}],14:[function(require,module,exports){\r\n'use strict';\r\n\r\nvar autoStart = require('./base');\r\nvar Interaction = require('../Interaction');\r\n\r\nInteraction.signals.on('new', function (interaction) {\r\n interaction.delayTimer = null;\r\n});\r\n\r\nautoStart.signals.on('prepared', function (_ref) {\r\n var interaction = _ref.interaction;\r\n\r\n var actionName = interaction.prepared.name;\r\n\r\n if (!actionName) {\r\n return;\r\n }\r\n\r\n var delay = interaction.target.options[actionName].delay;\r\n\r\n if (delay > 0) {\r\n interaction.delayTimer = setTimeout(function () {\r\n interaction.start(interaction.prepared, interaction.target, interaction.element);\r\n }, delay);\r\n }\r\n});\r\n\r\nInteraction.signals.on('move', function (_ref2) {\r\n var interaction = _ref2.interaction,\r\n duplicate = _ref2.duplicate;\r\n\r\n if (interaction.pointerWasMoved && !duplicate) {\r\n clearTimeout(interaction.delayTimer);\r\n }\r\n});\r\n\r\n// prevent regular down->move autoStart\r\nautoStart.signals.on('before-start', function (_ref3) {\r\n var interaction = _ref3.interaction;\r\n\r\n var actionName = interaction.prepared.name;\r\n\r\n if (!actionName) {\r\n return;\r\n }\r\n\r\n var delay = interaction.target.options[actionName].delay;\r\n\r\n if (delay > 0) {\r\n interaction.prepared.name = null;\r\n }\r\n});\r\n\r\n},{\"../Interaction\":5,\"./base\":13}],15:[function(require,module,exports){\r\n'use strict';\r\n\r\nvar autoStart = require('./base');\r\nvar scope = require('../scope');\r\nvar browser = require('../utils/browser');\r\nvar is = require('../utils/is');\r\n\r\nvar _require = require('../utils/domUtils'),\r\n matchesSelector = _require.matchesSelector,\r\n parentNode = _require.parentNode;\r\n\r\nautoStart.setActionDefaults(require('../actions/drag'));\r\n\r\nautoStart.signals.on('before-start', function (_ref) {\r\n var interaction = _ref.interaction,\r\n eventTarget = _ref.eventTarget,\r\n dx = _ref.dx,\r\n dy = _ref.dy;\r\n\r\n if (interaction.prepared.name !== 'drag') {\r\n return;\r\n }\r\n\r\n // check if a drag is in the correct axis\r\n var absX = Math.abs(dx);\r\n var absY = Math.abs(dy);\r\n var options = interaction.target.options.drag;\r\n var startAxis = options.startAxis;\r\n var currentAxis = absX > absY ? 'x' : absX < absY ? 'y' : 'xy';\r\n\r\n interaction.prepared.axis = options.lockAxis === 'start' ? currentAxis[0] // always lock to one axis even if currentAxis === 'xy'\r\n : options.lockAxis;\r\n\r\n // if the movement isn't in the startAxis of the interactable\r\n if (currentAxis !== 'xy' && startAxis !== 'xy' && startAxis !== currentAxis) {\r\n // cancel the prepared action\r\n interaction.prepared.name = null;\r\n\r\n // then try to get a drag from another ineractable\r\n\r\n if (!interaction.prepared.name) {\r\n\r\n var element = eventTarget;\r\n\r\n var getDraggable = function getDraggable(interactable, selector, context) {\r\n var elements = browser.useMatchesSelectorPolyfill ? context.querySelectorAll(selector) : undefined;\r\n\r\n if (interactable === interaction.target) {\r\n return;\r\n }\r\n\r\n if (!options.manualStart && !interactable.testIgnoreAllow(options, element, eventTarget) && matchesSelector(element, selector, elements)) {\r\n\r\n var _action = interactable.getAction(interaction.downPointer, interaction.downEvent, interaction, element);\r\n\r\n if (_action && _action.name === 'drag' && checkStartAxis(currentAxis, interactable) && autoStart.validateAction(_action, interactable, element, eventTarget)) {\r\n\r\n return interactable;\r\n }\r\n }\r\n };\r\n\r\n var action = null;\r\n\r\n // check all interactables\r\n while (is.element(element)) {\r\n var elementInteractable = scope.interactables.get(element);\r\n\r\n if (elementInteractable && elementInteractable !== interaction.target && !elementInteractable.options.drag.manualStart) {\r\n\r\n action = elementInteractable.getAction(interaction.downPointer, interaction.downEvent, interaction, element);\r\n }\r\n if (action && action.name === 'drag' && checkStartAxis(currentAxis, elementInteractable)) {\r\n\r\n interaction.prepared.name = 'drag';\r\n interaction.target = elementInteractable;\r\n interaction.element = element;\r\n break;\r\n }\r\n\r\n var selectorInteractable = scope.interactables.forEachSelector(getDraggable, element);\r\n\r\n if (selectorInteractable) {\r\n interaction.prepared.name = 'drag';\r\n interaction.target = selectorInteractable;\r\n interaction.element = element;\r\n break;\r\n }\r\n\r\n element = parentNode(element);\r\n }\r\n }\r\n }\r\n});\r\n\r\nfunction checkStartAxis(startAxis, interactable) {\r\n if (!interactable) {\r\n return false;\r\n }\r\n\r\n var thisAxis = interactable.options.drag.startAxis;\r\n\r\n return startAxis === 'xy' || thisAxis === 'xy' || thisAxis === startAxis;\r\n}\r\n\r\n},{\"../actions/drag\":7,\"../scope\":34,\"../utils/browser\":37,\"../utils/domUtils\":39,\"../utils/is\":46,\"./base\":13}],16:[function(require,module,exports){\r\n'use strict';\r\n\r\nrequire('./base').setActionDefaults(require('../actions/gesture'));\r\n\r\n},{\"../actions/gesture\":9,\"./base\":13}],17:[function(require,module,exports){\r\n'use strict';\r\n\r\nrequire('./base').setActionDefaults(require('../actions/resize'));\r\n\r\n},{\"../actions/resize\":10,\"./base\":13}],18:[function(require,module,exports){\r\n'use strict';\r\n\r\nmodule.exports = {\r\n base: {\r\n accept: null,\r\n preventDefault: 'auto',\r\n deltaSource: 'page'\r\n },\r\n\r\n perAction: {\r\n origin: { x: 0, y: 0 },\r\n\r\n // only allow left button by default\r\n // see https://developer.mozilla.org/en-US/docs/Web/API/MouseEvent/buttons#Return_value\r\n mouseButtons: 1,\r\n\r\n inertia: {\r\n enabled: false,\r\n resistance: 10, // the lambda in exponential decay\r\n minSpeed: 100, // target speed must be above this for inertia to start\r\n endSpeed: 10, // the speed at which inertia is slow enough to stop\r\n allowResume: true, // allow resuming an action in inertia phase\r\n smoothEndDuration: 300 // animate to snap/restrict endOnly if there's no inertia\r\n }\r\n }\r\n};\r\n\r\n},{}],19:[function(require,module,exports){\r\n'use strict';\r\n\r\n/* browser entry point */\r\n\r\n// Legacy browser support\r\nrequire('./legacyBrowsers');\r\n\r\n// inertia\r\nrequire('./inertia');\r\n\r\n// modifiers\r\nrequire('./modifiers/snap');\r\nrequire('./modifiers/restrict');\r\n\r\n// pointerEvents\r\nrequire('./pointerEvents/base');\r\nrequire('./pointerEvents/holdRepeat');\r\nrequire('./pointerEvents/interactableTargets');\r\n\r\n// delay\r\nrequire('./autoStart/delay');\r\n\r\n// actions\r\nrequire('./actions/gesture');\r\nrequire('./actions/resize');\r\nrequire('./actions/drag');\r\nrequire('./actions/drop');\r\n\r\n// load these modifiers after resize is loaded\r\nrequire('./modifiers/snapSize');\r\nrequire('./modifiers/restrictEdges');\r\nrequire('./modifiers/restrictSize');\r\n\r\n// autoStart actions\r\nrequire('./autoStart/gesture');\r\nrequire('./autoStart/resize');\r\nrequire('./autoStart/drag');\r\n\r\n// Interactable preventDefault setting\r\nrequire('./interactablePreventDefault.js');\r\n\r\n// autoScroll\r\nrequire('./autoScroll');\r\n\r\n// export interact\r\nmodule.exports = require('./interact');\r\n\r\n},{\"./actions/drag\":7,\"./actions/drop\":8,\"./actions/gesture\":9,\"./actions/resize\":10,\"./autoScroll\":11,\"./autoStart/delay\":14,\"./autoStart/drag\":15,\"./autoStart/gesture\":16,\"./autoStart/resize\":17,\"./inertia\":20,\"./interact\":21,\"./interactablePreventDefault.js\":22,\"./legacyBrowsers\":23,\"./modifiers/restrict\":25,\"./modifiers/restrictEdges\":26,\"./modifiers/restrictSize\":27,\"./modifiers/snap\":28,\"./modifiers/snapSize\":29,\"./pointerEvents/base\":31,\"./pointerEvents/holdRepeat\":32,\"./pointerEvents/interactableTargets\":33}],20:[function(require,module,exports){\r\n'use strict';\r\n\r\nvar InteractEvent = require('./InteractEvent');\r\nvar Interaction = require('./Interaction');\r\nvar modifiers = require('./modifiers');\r\nvar utils = require('./utils');\r\nvar animationFrame = require('./utils/raf');\r\n\r\nInteraction.signals.on('new', function (interaction) {\r\n interaction.inertiaStatus = {\r\n active: false,\r\n smoothEnd: false,\r\n allowResume: false,\r\n\r\n startEvent: null,\r\n upCoords: {},\r\n\r\n xe: 0, ye: 0,\r\n sx: 0, sy: 0,\r\n\r\n t0: 0,\r\n vx0: 0, vys: 0,\r\n duration: 0,\r\n\r\n lambda_v0: 0,\r\n one_ve_v0: 0,\r\n i: null\r\n };\r\n\r\n interaction.boundInertiaFrame = function () {\r\n return inertiaFrame.apply(interaction);\r\n };\r\n interaction.boundSmoothEndFrame = function () {\r\n return smoothEndFrame.apply(interaction);\r\n };\r\n});\r\n\r\nInteraction.signals.on('down', function (_ref) {\r\n var interaction = _ref.interaction,\r\n event = _ref.event,\r\n pointer = _ref.pointer,\r\n eventTarget = _ref.eventTarget;\r\n\r\n var status = interaction.inertiaStatus;\r\n\r\n // Check if the down event hits the current inertia target\r\n if (status.active) {\r\n var element = eventTarget;\r\n\r\n // climb up the DOM tree from the event target\r\n while (utils.is.element(element)) {\r\n\r\n // if interaction element is the current inertia target element\r\n if (element === interaction.element) {\r\n // stop inertia\r\n animationFrame.cancel(status.i);\r\n status.active = false;\r\n interaction.simulation = null;\r\n\r\n // update pointers to the down event's coordinates\r\n interaction.updatePointer(pointer);\r\n utils.setCoords(interaction.curCoords, interaction.pointers);\r\n\r\n // fire appropriate signals\r\n var signalArg = { interaction: interaction };\r\n Interaction.signals.fire('before-action-move', signalArg);\r\n Interaction.signals.fire('action-resume', signalArg);\r\n\r\n // fire a reume event\r\n var resumeEvent = new InteractEvent(interaction, event, interaction.prepared.name, 'inertiaresume', interaction.element);\r\n\r\n interaction.target.fire(resumeEvent);\r\n interaction.prevEvent = resumeEvent;\r\n modifiers.resetStatuses(interaction.modifierStatuses);\r\n\r\n utils.copyCoords(interaction.prevCoords, interaction.curCoords);\r\n break;\r\n }\r\n\r\n element = utils.parentNode(element);\r\n }\r\n }\r\n});\r\n\r\nInteraction.signals.on('up', function (_ref2) {\r\n var interaction = _ref2.interaction,\r\n event = _ref2.event;\r\n\r\n var status = interaction.inertiaStatus;\r\n\r\n if (!interaction.interacting() || status.active) {\r\n return;\r\n }\r\n\r\n var target = interaction.target;\r\n var options = target && target.options;\r\n var inertiaOptions = options && interaction.prepared.name && options[interaction.prepared.name].inertia;\r\n\r\n var now = new Date().getTime();\r\n var statuses = {};\r\n var page = utils.extend({}, interaction.curCoords.page);\r\n var pointerSpeed = interaction.pointerDelta.client.speed;\r\n\r\n var smoothEnd = false;\r\n var modifierResult = void 0;\r\n\r\n // check if inertia should be started\r\n var inertiaPossible = inertiaOptions && inertiaOptions.enabled && interaction.prepared.name !== 'gesture' && event !== status.startEvent;\r\n\r\n var inertia = inertiaPossible && now - interaction.curCoords.timeStamp < 50 && pointerSpeed > inertiaOptions.minSpeed && pointerSpeed > inertiaOptions.endSpeed;\r\n\r\n var modifierArg = {\r\n interaction: interaction,\r\n pageCoords: page,\r\n statuses: statuses,\r\n preEnd: true,\r\n requireEndOnly: true\r\n };\r\n\r\n // smoothEnd\r\n if (inertiaPossible && !inertia) {\r\n modifiers.resetStatuses(statuses);\r\n\r\n modifierResult = modifiers.setAll(modifierArg);\r\n\r\n if (modifierResult.shouldMove && modifierResult.locked) {\r\n smoothEnd = true;\r\n }\r\n }\r\n\r\n if (!(inertia || smoothEnd)) {\r\n return;\r\n }\r\n\r\n utils.copyCoords(status.upCoords, interaction.curCoords);\r\n\r\n interaction.pointers[0] = status.startEvent = new InteractEvent(interaction, event, interaction.prepared.name, 'inertiastart', interaction.element);\r\n\r\n status.t0 = now;\r\n\r\n status.active = true;\r\n status.allowResume = inertiaOptions.allowResume;\r\n interaction.simulation = status;\r\n\r\n target.fire(status.startEvent);\r\n\r\n if (inertia) {\r\n status.vx0 = interaction.pointerDelta.client.vx;\r\n status.vy0 = interaction.pointerDelta.client.vy;\r\n status.v0 = pointerSpeed;\r\n\r\n calcInertia(interaction, status);\r\n\r\n utils.extend(page, interaction.curCoords.page);\r\n\r\n page.x += status.xe;\r\n page.y += status.ye;\r\n\r\n modifiers.resetStatuses(statuses);\r\n\r\n modifierResult = modifiers.setAll(modifierArg);\r\n\r\n status.modifiedXe += modifierResult.dx;\r\n status.modifiedYe += modifierResult.dy;\r\n\r\n status.i = animationFrame.request(interaction.boundInertiaFrame);\r\n } else {\r\n status.smoothEnd = true;\r\n status.xe = modifierResult.dx;\r\n status.ye = modifierResult.dy;\r\n\r\n status.sx = status.sy = 0;\r\n\r\n status.i = animationFrame.request(interaction.boundSmoothEndFrame);\r\n }\r\n});\r\n\r\nInteraction.signals.on('stop-active', function (_ref3) {\r\n var interaction = _ref3.interaction;\r\n\r\n var status = interaction.inertiaStatus;\r\n\r\n if (status.active) {\r\n animationFrame.cancel(status.i);\r\n status.active = false;\r\n interaction.simulation = null;\r\n }\r\n});\r\n\r\nfunction calcInertia(interaction, status) {\r\n var inertiaOptions = interaction.target.options[interaction.prepared.name].inertia;\r\n var lambda = inertiaOptions.resistance;\r\n var inertiaDur = -Math.log(inertiaOptions.endSpeed / status.v0) / lambda;\r\n\r\n status.x0 = interaction.prevEvent.pageX;\r\n status.y0 = interaction.prevEvent.pageY;\r\n status.t0 = status.startEvent.timeStamp / 1000;\r\n status.sx = status.sy = 0;\r\n\r\n status.modifiedXe = status.xe = (status.vx0 - inertiaDur) / lambda;\r\n status.modifiedYe = status.ye = (status.vy0 - inertiaDur) / lambda;\r\n status.te = inertiaDur;\r\n\r\n status.lambda_v0 = lambda / status.v0;\r\n status.one_ve_v0 = 1 - inertiaOptions.endSpeed / status.v0;\r\n}\r\n\r\nfunction inertiaFrame() {\r\n updateInertiaCoords(this);\r\n utils.setCoordDeltas(this.pointerDelta, this.prevCoords, this.curCoords);\r\n\r\n var status = this.inertiaStatus;\r\n var options = this.target.options[this.prepared.name].inertia;\r\n var lambda = options.resistance;\r\n var t = new Date().getTime() / 1000 - status.t0;\r\n\r\n if (t < status.te) {\r\n\r\n var progress = 1 - (Math.exp(-lambda * t) - status.lambda_v0) / status.one_ve_v0;\r\n\r\n if (status.modifiedXe === status.xe && status.modifiedYe === status.ye) {\r\n status.sx = status.xe * progress;\r\n status.sy = status.ye * progress;\r\n } else {\r\n var quadPoint = utils.getQuadraticCurvePoint(0, 0, status.xe, status.ye, status.modifiedXe, status.modifiedYe, progress);\r\n\r\n status.sx = quadPoint.x;\r\n status.sy = quadPoint.y;\r\n }\r\n\r\n this.doMove();\r\n\r\n status.i = animationFrame.request(this.boundInertiaFrame);\r\n } else {\r\n status.sx = status.modifiedXe;\r\n status.sy = status.modifiedYe;\r\n\r\n this.doMove();\r\n this.end(status.startEvent);\r\n status.active = false;\r\n this.simulation = null;\r\n }\r\n\r\n utils.copyCoords(this.prevCoords, this.curCoords);\r\n}\r\n\r\nfunction smoothEndFrame() {\r\n updateInertiaCoords(this);\r\n\r\n var status = this.inertiaStatus;\r\n var t = new Date().getTime() - status.t0;\r\n var duration = this.target.options[this.prepared.name].inertia.smoothEndDuration;\r\n\r\n if (t < duration) {\r\n status.sx = utils.easeOutQuad(t, 0, status.xe, duration);\r\n status.sy = utils.easeOutQuad(t, 0, status.ye, duration);\r\n\r\n this.pointerMove(status.startEvent, status.startEvent);\r\n\r\n status.i = animationFrame.request(this.boundSmoothEndFrame);\r\n } else {\r\n status.sx = status.xe;\r\n status.sy = status.ye;\r\n\r\n this.pointerMove(status.startEvent, status.startEvent);\r\n this.end(status.startEvent);\r\n\r\n status.smoothEnd = status.active = false;\r\n this.simulation = null;\r\n }\r\n}\r\n\r\nfunction updateInertiaCoords(interaction) {\r\n var status = interaction.inertiaStatus;\r\n\r\n // return if inertia isn't running\r\n if (!status.active) {\r\n return;\r\n }\r\n\r\n var pageUp = status.upCoords.page;\r\n var clientUp = status.upCoords.client;\r\n\r\n utils.setCoords(interaction.curCoords, [{\r\n pageX: pageUp.x + status.sx,\r\n pageY: pageUp.y + status.sy,\r\n clientX: clientUp.x + status.sx,\r\n clientY: clientUp.y + status.sy\r\n }]);\r\n}\r\n\r\n},{\"./InteractEvent\":3,\"./Interaction\":5,\"./modifiers\":24,\"./utils\":44,\"./utils/raf\":50}],21:[function(require,module,exports){\r\n'use strict';\r\n\r\nvar browser = require('./utils/browser');\r\nvar events = require('./utils/events');\r\nvar utils = require('./utils');\r\nvar scope = require('./scope');\r\nvar Interactable = require('./Interactable');\r\nvar Interaction = require('./Interaction');\r\n\r\nvar globalEvents = {};\r\n\r\n/*\\\r\n * interact\r\n [ method ]\r\n *\r\n * The methods of this variable can be used to set elements as\r\n * interactables and also to change various default settings.\r\n *\r\n * Calling it as a function and passing an element or a valid CSS selector\r\n * string returns an Interactable object which has various methods to\r\n * configure it.\r\n *\r\n - element (Element | string) The HTML or SVG Element to interact with or CSS selector\r\n = (object) An @Interactable\r\n *\r\n > Usage\r\n | interact('#draggable').draggable(true);\r\n |\r\n | var rectables = interact('rect');\r\n | rectables\r\n | .gesturable(true)\r\n | .on('gesturemove', function (event) {\r\n | // ...\r\n | });\r\n\\*/\r\nfunction interact(element, options) {\r\n var interactable = scope.interactables.get(element, options);\r\n\r\n if (!interactable) {\r\n interactable = new Interactable(element, options);\r\n interactable.events.global = globalEvents;\r\n }\r\n\r\n return interactable;\r\n}\r\n\r\n/*\\\r\n * interact.isSet\r\n [ method ]\r\n *\r\n * Check if an element has been set\r\n - element (Element) The Element being searched for\r\n = (boolean) Indicates if the element or CSS selector was previously passed to interact\r\n\\*/\r\ninteract.isSet = function (element, options) {\r\n return scope.interactables.indexOfElement(element, options && options.context) !== -1;\r\n};\r\n\r\n/*\\\r\n * interact.on\r\n [ method ]\r\n *\r\n * Adds a global listener for an InteractEvent or adds a DOM event to\r\n * `document`\r\n *\r\n - type (string | array | object) The types of events to listen for\r\n - listener (function) The function event (s)\r\n - options (object | boolean) #optional options object or useCapture flag for addEventListener\r\n = (object) interact\r\n\\*/\r\ninteract.on = function (type, listener, options) {\r\n if (utils.is.string(type) && type.search(' ') !== -1) {\r\n type = type.trim().split(/ +/);\r\n }\r\n\r\n if (utils.is.array(type)) {\r\n for (var _iterator = type, _isArray = Array.isArray(_iterator), _i = 0, _iterator = _isArray ? _iterator : _iterator[Symbol.iterator]();;) {\r\n var _ref;\r\n\r\n if (_isArray) {\r\n if (_i >= _iterator.length) break;\r\n _ref = _iterator[_i++];\r\n } else {\r\n _i = _iterator.next();\r\n if (_i.done) break;\r\n _ref = _i.value;\r\n }\r\n\r\n var eventType = _ref;\r\n\r\n interact.on(eventType, listener, options);\r\n }\r\n\r\n return interact;\r\n }\r\n\r\n if (utils.is.object(type)) {\r\n for (var prop in type) {\r\n interact.on(prop, type[prop], listener);\r\n }\r\n\r\n return interact;\r\n }\r\n\r\n // if it is an InteractEvent type, add listener to globalEvents\r\n if (utils.contains(Interactable.eventTypes, type)) {\r\n // if this type of event was never bound\r\n if (!globalEvents[type]) {\r\n globalEvents[type] = [listener];\r\n } else {\r\n globalEvents[type].push(listener);\r\n }\r\n }\r\n // If non InteractEvent type, addEventListener to document\r\n else {\r\n events.add(scope.document, type, listener, { options: options });\r\n }\r\n\r\n return interact;\r\n};\r\n\r\n/*\\\r\n * interact.off\r\n [ method ]\r\n *\r\n * Removes a global InteractEvent listener or DOM event from `document`\r\n *\r\n - type (string | array | object) The types of events that were listened for\r\n - listener (function) The listener function to be removed\r\n - options (object | boolean) #optional options object or useCapture flag for removeEventListener\r\n = (object) interact\r\n \\*/\r\ninteract.off = function (type, listener, options) {\r\n if (utils.is.string(type) && type.search(' ') !== -1) {\r\n type = type.trim().split(/ +/);\r\n }\r\n\r\n if (utils.is.array(type)) {\r\n for (var _iterator2 = type, _isArray2 = Array.isArray(_iterator2), _i2 = 0, _iterator2 = _isArray2 ? _iterator2 : _iterator2[Symbol.iterator]();;) {\r\n var _ref2;\r\n\r\n if (_isArray2) {\r\n if (_i2 >= _iterator2.length) break;\r\n _ref2 = _iterator2[_i2++];\r\n } else {\r\n _i2 = _iterator2.next();\r\n if (_i2.done) break;\r\n _ref2 = _i2.value;\r\n }\r\n\r\n var eventType = _ref2;\r\n\r\n interact.off(eventType, listener, options);\r\n }\r\n\r\n return interact;\r\n }\r\n\r\n if (utils.is.object(type)) {\r\n for (var prop in type) {\r\n interact.off(prop, type[prop], listener);\r\n }\r\n\r\n return interact;\r\n }\r\n\r\n if (!utils.contains(Interactable.eventTypes, type)) {\r\n events.remove(scope.document, type, listener, options);\r\n } else {\r\n var index = void 0;\r\n\r\n if (type in globalEvents && (index = utils.indexOf(globalEvents[type], listener)) !== -1) {\r\n globalEvents[type].splice(index, 1);\r\n }\r\n }\r\n\r\n return interact;\r\n};\r\n\r\n/*\\\r\n * interact.debug\r\n [ method ]\r\n *\r\n * Returns an object which exposes internal data\r\n = (object) An object with properties that outline the current state and expose internal functions and variables\r\n\\*/\r\ninteract.debug = function () {\r\n return scope;\r\n};\r\n\r\n// expose the functions used to calculate multi-touch properties\r\ninteract.getPointerAverage = utils.pointerAverage;\r\ninteract.getTouchBBox = utils.touchBBox;\r\ninteract.getTouchDistance = utils.touchDistance;\r\ninteract.getTouchAngle = utils.touchAngle;\r\n\r\ninteract.getElementRect = utils.getElementRect;\r\ninteract.getElementClientRect = utils.getElementClientRect;\r\ninteract.matchesSelector = utils.matchesSelector;\r\ninteract.closest = utils.closest;\r\n\r\n/*\\\r\n * interact.supportsTouch\r\n [ method ]\r\n *\r\n = (boolean) Whether or not the browser supports touch input\r\n\\*/\r\ninteract.supportsTouch = function () {\r\n return browser.supportsTouch;\r\n};\r\n\r\n/*\\\r\n * interact.supportsPointerEvent\r\n [ method ]\r\n *\r\n = (boolean) Whether or not the browser supports PointerEvents\r\n\\*/\r\ninteract.supportsPointerEvent = function () {\r\n return browser.supportsPointerEvent;\r\n};\r\n\r\n/*\\\r\n * interact.stop\r\n [ method ]\r\n *\r\n * Cancels all interactions (end events are not fired)\r\n *\r\n - event (Event) An event on which to call preventDefault()\r\n = (object) interact\r\n\\*/\r\ninteract.stop = function (event) {\r\n for (var i = scope.interactions.length - 1; i >= 0; i--) {\r\n scope.interactions[i].stop(event);\r\n }\r\n\r\n return interact;\r\n};\r\n\r\n/*\\\r\n * interact.pointerMoveTolerance\r\n [ method ]\r\n * Returns or sets the distance the pointer must be moved before an action\r\n * sequence occurs. This also affects tolerance for tap events.\r\n *\r\n - newValue (number) #optional The movement from the start position must be greater than this value\r\n = (number | Interactable) The current setting or interact\r\n\\*/\r\ninteract.pointerMoveTolerance = function (newValue) {\r\n if (utils.is.number(newValue)) {\r\n Interaction.pointerMoveTolerance = newValue;\r\n\r\n return this;\r\n }\r\n\r\n return Interaction.pointerMoveTolerance;\r\n};\r\n\r\ninteract.addDocument = scope.addDocument;\r\ninteract.removeDocument = scope.removeDocument;\r\n\r\nscope.interact = interact;\r\n\r\nmodule.exports = interact;\r\n\r\n},{\"./Interactable\":4,\"./Interaction\":5,\"./scope\":34,\"./utils\":44,\"./utils/browser\":37,\"./utils/events\":40}],22:[function(require,module,exports){\r\n'use strict';\r\n\r\nvar Interactable = require('./Interactable');\r\nvar Interaction = require('./Interaction');\r\nvar scope = require('./scope');\r\nvar is = require('./utils/is');\r\nvar events = require('./utils/events');\r\n\r\nvar _require = require('./utils/domUtils'),\r\n nodeContains = _require.nodeContains,\r\n matchesSelector = _require.matchesSelector;\r\n\r\n/*\\\r\n * Interactable.preventDefault\r\n [ method ]\r\n *\r\n * Returns or sets whether to prevent the browser's default behaviour\r\n * in response to pointer events. Can be set to:\r\n * - `'always'` to always prevent\r\n * - `'never'` to never prevent\r\n * - `'auto'` to let interact.js try to determine what would be best\r\n *\r\n - newValue (string) #optional `true`, `false` or `'auto'`\r\n = (string | Interactable) The current setting or this Interactable\r\n\\*/\r\n\r\n\r\nInteractable.prototype.preventDefault = function (newValue) {\r\n if (/^(always|never|auto)$/.test(newValue)) {\r\n this.options.preventDefault = newValue;\r\n return this;\r\n }\r\n\r\n if (is.bool(newValue)) {\r\n this.options.preventDefault = newValue ? 'always' : 'never';\r\n return this;\r\n }\r\n\r\n return this.options.preventDefault;\r\n};\r\n\r\nInteractable.prototype.checkAndPreventDefault = function (event) {\r\n var setting = this.options.preventDefault;\r\n\r\n if (setting === 'never') {\r\n return;\r\n }\r\n\r\n if (setting === 'always') {\r\n event.preventDefault();\r\n return;\r\n }\r\n\r\n // setting === 'auto'\r\n\r\n // don't preventDefault if the browser supports passiveEvents\r\n // CSS touch-action and user-selecct should be used instead\r\n if (events.supportsOptions) {\r\n return;\r\n }\r\n\r\n // don't preventDefault of pointerdown events\r\n if (/^(mouse|pointer|touch)*(down|start)/i.test(event.type)) {\r\n return;\r\n }\r\n\r\n // don't preventDefault on editable elements\r\n if (is.element(event.target) && matchesSelector(event.target, 'input,select,textarea,[contenteditable=true],[contenteditable=true] *')) {\r\n return;\r\n }\r\n\r\n event.preventDefault();\r\n};\r\n\r\nfunction onInteractionEvent(_ref) {\r\n var interaction = _ref.interaction,\r\n event = _ref.event;\r\n\r\n if (interaction.target) {\r\n interaction.target.checkAndPreventDefault(event);\r\n }\r\n}\r\n\r\nvar _arr = ['down', 'move', 'up', 'cancel'];\r\nfor (var _i = 0; _i < _arr.length; _i++) {\r\n var eventSignal = _arr[_i];\r\n Interaction.signals.on(eventSignal, onInteractionEvent);\r\n}\r\n\r\n// prevent native HTML5 drag on interact.js target elements\r\nInteraction.docEvents.dragstart = function preventNativeDrag(event) {\r\n for (var _iterator = scope.interactions, _isArray = Array.isArray(_iterator), _i2 = 0, _iterator = _isArray ? _iterator : _iterator[Symbol.iterator]();;) {\r\n var _ref2;\r\n\r\n if (_isArray) {\r\n if (_i2 >= _iterator.length) break;\r\n _ref2 = _iterator[_i2++];\r\n } else {\r\n _i2 = _iterator.next();\r\n if (_i2.done) break;\r\n _ref2 = _i2.value;\r\n }\r\n\r\n var interaction = _ref2;\r\n\r\n\r\n if (interaction.element && (interaction.element === event.target || nodeContains(interaction.element, event.target))) {\r\n\r\n interaction.target.checkAndPreventDefault(event);\r\n return;\r\n }\r\n }\r\n};\r\n\r\n},{\"./Interactable\":4,\"./Interaction\":5,\"./scope\":34,\"./utils/domUtils\":39,\"./utils/events\":40,\"./utils/is\":46}],23:[function(require,module,exports){\r\n'use strict';\r\n\r\nvar scope = require('./scope');\r\nvar events = require('./utils/events');\r\nvar browser = require('./utils/browser');\r\nvar iFinder = require('./utils/interactionFinder');\r\nvar pointerEvents = require('./pointerEvents/base');\r\n\r\nvar _require = require('./utils/window'),\r\n window = _require.window;\r\n\r\nvar toString = Object.prototype.toString;\r\n\r\nif (!window.Array.isArray) {\r\n window.Array.isArray = function (obj) {\r\n return toString.call(obj) === '[object Array]';\r\n };\r\n}\r\n\r\nif (!String.prototype.trim) {\r\n String.prototype.trim = function () {\r\n return this.replace(/^[\\s\\uFEFF\\xA0]+|[\\s\\uFEFF\\xA0]+$/g, '');\r\n };\r\n}\r\n\r\n// http://www.quirksmode.org/dom/events/click.html\r\n// >Events leading to dblclick\r\n//\r\n// IE8 doesn't fire down event before dblclick.\r\n// This workaround tries to fire a tap and doubletap after dblclick\r\nfunction onIE8Dblclick(event) {\r\n var eventTarget = event.target;\r\n var interaction = iFinder.search(event, event.type, eventTarget);\r\n\r\n if (!interaction) {\r\n return;\r\n }\r\n\r\n if (interaction.prevTap && event.clientX === interaction.prevTap.clientX && event.clientY === interaction.prevTap.clientY && eventTarget === interaction.prevTap.target) {\r\n\r\n interaction.downTargets[0] = eventTarget;\r\n interaction.downTimes[0] = new Date().getTime();\r\n\r\n pointerEvents.fire({\r\n interaction: interaction,\r\n event: event,\r\n eventTarget: eventTarget,\r\n pointer: event,\r\n type: 'tap'\r\n });\r\n }\r\n}\r\n\r\nif (browser.isIE8) {\r\n var selectFix = function selectFix(event) {\r\n for (var _iterator = scope.interactions, _isArray = Array.isArray(_iterator), _i = 0, _iterator = _isArray ? _iterator : _iterator[Symbol.iterator]();;) {\r\n var _ref;\r\n\r\n if (_isArray) {\r\n if (_i >= _iterator.length) break;\r\n _ref = _iterator[_i++];\r\n } else {\r\n _i = _iterator.next();\r\n if (_i.done) break;\r\n _ref = _i.value;\r\n }\r\n\r\n var interaction = _ref;\r\n\r\n if (interaction.interacting()) {\r\n interaction.target.checkAndPreventDefault(event);\r\n }\r\n }\r\n };\r\n\r\n var onDocIE8 = function onDocIE8(_ref2, signalName) {\r\n var doc = _ref2.doc,\r\n win = _ref2.win;\r\n\r\n var eventMethod = signalName.indexOf('listen') === 0 ? events.add : events.remove;\r\n\r\n // For IE's lack of Event#preventDefault\r\n eventMethod(doc, 'selectstart', selectFix);\r\n\r\n if (pointerEvents) {\r\n eventMethod(doc, 'dblclick', onIE8Dblclick);\r\n }\r\n };\r\n\r\n scope.signals.on('add-document', onDocIE8);\r\n scope.signals.on('remove-document', onDocIE8);\r\n}\r\n\r\nmodule.exports = null;\r\n\r\n},{\"./pointerEvents/base\":31,\"./scope\":34,\"./utils/browser\":37,\"./utils/events\":40,\"./utils/interactionFinder\":45,\"./utils/window\":52}],24:[function(require,module,exports){\r\n'use strict';\r\n\r\nvar InteractEvent = require('../InteractEvent');\r\nvar Interaction = require('../Interaction');\r\nvar extend = require('../utils/extend');\r\n\r\nvar modifiers = {\r\n names: [],\r\n\r\n setOffsets: function setOffsets(arg) {\r\n var interaction = arg.interaction,\r\n page = arg.pageCoords;\r\n var target = interaction.target,\r\n element = interaction.element,\r\n startOffset = interaction.startOffset;\r\n\r\n var rect = target.getRect(element);\r\n\r\n if (rect) {\r\n startOffset.left = page.x - rect.left;\r\n startOffset.top = page.y - rect.top;\r\n\r\n startOffset.right = rect.right - page.x;\r\n startOffset.bottom = rect.bottom - page.y;\r\n\r\n if (!('width' in rect)) {\r\n rect.width = rect.right - rect.left;\r\n }\r\n if (!('height' in rect)) {\r\n rect.height = rect.bottom - rect.top;\r\n }\r\n } else {\r\n startOffset.left = startOffset.top = startOffset.right = startOffset.bottom = 0;\r\n }\r\n\r\n arg.rect = rect;\r\n arg.interactable = target;\r\n arg.element = element;\r\n\r\n for (var i = 0; i < modifiers.names.length; i++) {\r\n var modifierName = modifiers.names[i];\r\n\r\n arg.options = target.options[interaction.prepared.name][modifierName];\r\n\r\n if (!arg.options) {\r\n continue;\r\n }\r\n\r\n interaction.modifierOffsets[modifierName] = modifiers[modifierName].setOffset(arg);\r\n }\r\n },\r\n\r\n setAll: function setAll(arg) {\r\n var interaction = arg.interaction,\r\n statuses = arg.statuses,\r\n preEnd = arg.preEnd,\r\n requireEndOnly = arg.requireEndOnly;\r\n\r\n var coords = extend({}, arg.pageCoords);\r\n var result = {\r\n dx: 0,\r\n dy: 0,\r\n changed: false,\r\n locked: false,\r\n shouldMove: true\r\n };\r\n\r\n for (var _iterator = modifiers.names, _isArray = Array.isArray(_iterator), _i = 0, _iterator = _isArray ? _iterator : _iterator[Symbol.iterator]();;) {\r\n var _ref;\r\n\r\n if (_isArray) {\r\n if (_i >= _iterator.length) break;\r\n _ref = _iterator[_i++];\r\n } else {\r\n _i = _iterator.next();\r\n if (_i.done) break;\r\n _ref = _i.value;\r\n }\r\n\r\n var modifierName = _ref;\r\n\r\n var modifier = modifiers[modifierName];\r\n var options = interaction.target.options[interaction.prepared.name][modifierName];\r\n\r\n if (!shouldDo(options, preEnd, requireEndOnly)) {\r\n continue;\r\n }\r\n\r\n arg.status = arg.status = statuses[modifierName];\r\n arg.options = options;\r\n arg.offset = arg.interaction.modifierOffsets[modifierName];\r\n\r\n modifier.set(arg);\r\n\r\n if (arg.status.locked) {\r\n coords.x += arg.status.dx;\r\n coords.y += arg.status.dy;\r\n\r\n result.dx += arg.status.dx;\r\n result.dy += arg.status.dy;\r\n\r\n result.locked = true;\r\n }\r\n }\r\n\r\n // a move should be fired if:\r\n // - there are no modifiers enabled,\r\n // - no modifiers are \"locked\" i.e. have changed the pointer's coordinates, or\r\n // - the locked coords have changed since the last pointer move\r\n result.shouldMove = !arg.status || !result.locked || arg.status.changed;\r\n\r\n return result;\r\n },\r\n\r\n resetStatuses: function resetStatuses(statuses) {\r\n for (var _iterator2 = modifiers.names, _isArray2 = Array.isArray(_iterator2), _i2 = 0, _iterator2 = _isArray2 ? _iterator2 : _iterator2[Symbol.iterator]();;) {\r\n var _ref2;\r\n\r\n if (_isArray2) {\r\n if (_i2 >= _iterator2.length) break;\r\n _ref2 = _iterator2[_i2++];\r\n } else {\r\n _i2 = _iterator2.next();\r\n if (_i2.done) break;\r\n _ref2 = _i2.value;\r\n }\r\n\r\n var modifierName = _ref2;\r\n\r\n var status = statuses[modifierName] || {};\r\n\r\n status.dx = status.dy = 0;\r\n status.modifiedX = status.modifiedY = NaN;\r\n status.locked = false;\r\n status.changed = true;\r\n\r\n statuses[modifierName] = status;\r\n }\r\n\r\n return statuses;\r\n },\r\n\r\n start: function start(_ref3, signalName) {\r\n var interaction = _ref3.interaction;\r\n\r\n var arg = {\r\n interaction: interaction,\r\n pageCoords: (signalName === 'action-resume' ? interaction.curCoords : interaction.startCoords).page,\r\n startOffset: interaction.startOffset,\r\n statuses: interaction.modifierStatuses,\r\n preEnd: false,\r\n requireEndOnly: false\r\n };\r\n\r\n modifiers.setOffsets(arg);\r\n modifiers.resetStatuses(arg.statuses);\r\n\r\n arg.pageCoords = extend({}, interaction.startCoords.page);\r\n interaction.modifierResult = modifiers.setAll(arg);\r\n }\r\n};\r\n\r\nInteraction.signals.on('new', function (interaction) {\r\n interaction.startOffset = { left: 0, right: 0, top: 0, bottom: 0 };\r\n interaction.modifierOffsets = {};\r\n interaction.modifierStatuses = modifiers.resetStatuses({});\r\n interaction.modifierResult = null;\r\n});\r\n\r\nInteraction.signals.on('action-start', modifiers.start);\r\nInteraction.signals.on('action-resume', modifiers.start);\r\n\r\nInteraction.signals.on('before-action-move', function (_ref4) {\r\n var interaction = _ref4.interaction,\r\n preEnd = _ref4.preEnd,\r\n interactingBeforeMove = _ref4.interactingBeforeMove;\r\n\r\n var modifierResult = modifiers.setAll({\r\n interaction: interaction,\r\n preEnd: preEnd,\r\n pageCoords: interaction.curCoords.page,\r\n statuses: interaction.modifierStatuses,\r\n requireEndOnly: false\r\n });\r\n\r\n // don't fire an action move if a modifier would keep the event in the same\r\n // cordinates as before\r\n if (!modifierResult.shouldMove && interactingBeforeMove) {\r\n interaction._dontFireMove = true;\r\n }\r\n\r\n interaction.modifierResult = modifierResult;\r\n});\r\n\r\nInteraction.signals.on('action-end', function (_ref5) {\r\n var interaction = _ref5.interaction,\r\n event = _ref5.event;\r\n\r\n for (var i = 0; i < modifiers.names.length; i++) {\r\n var options = interaction.target.options[interaction.prepared.name][modifiers.names[i]];\r\n\r\n // if the endOnly option is true for any modifier\r\n if (shouldDo(options, true, true)) {\r\n // fire a move event at the modified coordinates\r\n interaction.doMove({ event: event, preEnd: true });\r\n break;\r\n }\r\n }\r\n});\r\n\r\nInteractEvent.signals.on('set-xy', function (arg) {\r\n var iEvent = arg.iEvent,\r\n interaction = arg.interaction;\r\n\r\n var modifierArg = extend({}, arg);\r\n\r\n for (var i = 0; i < modifiers.names.length; i++) {\r\n var modifierName = modifiers.names[i];\r\n modifierArg.options = interaction.target.options[interaction.prepared.name][modifierName];\r\n\r\n if (!modifierArg.options) {\r\n continue;\r\n }\r\n\r\n var modifier = modifiers[modifierName];\r\n\r\n modifierArg.status = interaction.modifierStatuses[modifierName];\r\n\r\n iEvent[modifierName] = modifier.modifyCoords(modifierArg);\r\n }\r\n});\r\n\r\nfunction shouldDo(options, preEnd, requireEndOnly) {\r\n return options && options.enabled && (preEnd || !options.endOnly) && (!requireEndOnly || options.endOnly);\r\n}\r\n\r\nmodule.exports = modifiers;\r\n\r\n},{\"../InteractEvent\":3,\"../Interaction\":5,\"../utils/extend\":41}],25:[function(require,module,exports){\r\n'use strict';\r\n\r\nvar modifiers = require('./index');\r\nvar utils = require('../utils');\r\nvar defaultOptions = require('../defaultOptions');\r\n\r\nvar restrict = {\r\n defaults: {\r\n enabled: false,\r\n endOnly: false,\r\n restriction: null,\r\n elementRect: null\r\n },\r\n\r\n setOffset: function setOffset(_ref) {\r\n var rect = _ref.rect,\r\n startOffset = _ref.startOffset,\r\n options = _ref.options;\r\n\r\n var elementRect = options && options.elementRect;\r\n var offset = {};\r\n\r\n if (rect && elementRect) {\r\n offset.left = startOffset.left - rect.width * elementRect.left;\r\n offset.top = startOffset.top - rect.height * elementRect.top;\r\n\r\n offset.right = startOffset.right - rect.width * (1 - elementRect.right);\r\n offset.bottom = startOffset.bottom - rect.height * (1 - elementRect.bottom);\r\n } else {\r\n offset.left = offset.top = offset.right = offset.bottom = 0;\r\n }\r\n\r\n return offset;\r\n },\r\n\r\n set: function set(_ref2) {\r\n var pageCoords = _ref2.pageCoords,\r\n interaction = _ref2.interaction,\r\n status = _ref2.status,\r\n options = _ref2.options;\r\n\r\n if (!options) {\r\n return status;\r\n }\r\n\r\n var page = status.useStatusXY ? { x: status.x, y: status.y } : utils.extend({}, pageCoords);\r\n\r\n var restriction = getRestrictionRect(options.restriction, interaction, page);\r\n\r\n if (!restriction) {\r\n return status;\r\n }\r\n\r\n status.dx = 0;\r\n status.dy = 0;\r\n status.locked = false;\r\n\r\n var rect = restriction;\r\n var modifiedX = page.x;\r\n var modifiedY = page.y;\r\n\r\n var offset = interaction.modifierOffsets.restrict;\r\n\r\n // object is assumed to have\r\n // x, y, width, height or\r\n // left, top, right, bottom\r\n if ('x' in restriction && 'y' in restriction) {\r\n modifiedX = Math.max(Math.min(rect.x + rect.width - offset.right, page.x), rect.x + offset.left);\r\n modifiedY = Math.max(Math.min(rect.y + rect.height - offset.bottom, page.y), rect.y + offset.top);\r\n } else {\r\n modifiedX = Math.max(Math.min(rect.right - offset.right, page.x), rect.left + offset.left);\r\n modifiedY = Math.max(Math.min(rect.bottom - offset.bottom, page.y), rect.top + offset.top);\r\n }\r\n\r\n status.dx = modifiedX - page.x;\r\n status.dy = modifiedY - page.y;\r\n\r\n status.changed = status.modifiedX !== modifiedX || status.modifiedY !== modifiedY;\r\n status.locked = !!(status.dx || status.dy);\r\n\r\n status.modifiedX = modifiedX;\r\n status.modifiedY = modifiedY;\r\n },\r\n\r\n modifyCoords: function modifyCoords(_ref3) {\r\n var page = _ref3.page,\r\n client = _ref3.client,\r\n status = _ref3.status,\r\n phase = _ref3.phase,\r\n options = _ref3.options;\r\n\r\n var elementRect = options && options.elementRect;\r\n\r\n if (options && options.enabled && !(phase === 'start' && elementRect && status.locked)) {\r\n\r\n if (status.locked) {\r\n page.x += status.dx;\r\n page.y += status.dy;\r\n client.x += status.dx;\r\n client.y += status.dy;\r\n\r\n return {\r\n dx: status.dx,\r\n dy: status.dy\r\n };\r\n }\r\n }\r\n },\r\n\r\n getRestrictionRect: getRestrictionRect\r\n};\r\n\r\nfunction getRestrictionRect(value, interaction, page) {\r\n if (utils.is.function(value)) {\r\n return utils.resolveRectLike(value, interaction.target, interaction.element, [page.x, page.y, interaction]);\r\n } else {\r\n return utils.resolveRectLike(value, interaction.target, interaction.element);\r\n }\r\n}\r\n\r\nmodifiers.restrict = restrict;\r\nmodifiers.names.push('restrict');\r\n\r\ndefaultOptions.perAction.restrict = restrict.defaults;\r\n\r\nmodule.exports = restrict;\r\n\r\n},{\"../defaultOptions\":18,\"../utils\":44,\"./index\":24}],26:[function(require,module,exports){\r\n'use strict';\r\n\r\n// This module adds the options.resize.restrictEdges setting which sets min and\r\n// max for the top, left, bottom and right edges of the target being resized.\r\n//\r\n// interact(target).resize({\r\n// edges: { top: true, left: true },\r\n// restrictEdges: {\r\n// inner: { top: 200, left: 200, right: 400, bottom: 400 },\r\n// outer: { top: 0, left: 0, right: 600, bottom: 600 },\r\n// },\r\n// });\r\n\r\nvar modifiers = require('./index');\r\nvar utils = require('../utils');\r\nvar rectUtils = require('../utils/rect');\r\nvar defaultOptions = require('../defaultOptions');\r\nvar resize = require('../actions/resize');\r\n\r\nvar _require = require('./restrict'),\r\n getRestrictionRect = _require.getRestrictionRect;\r\n\r\nvar noInner = { top: +Infinity, left: +Infinity, bottom: -Infinity, right: -Infinity };\r\nvar noOuter = { top: -Infinity, left: -Infinity, bottom: +Infinity, right: +Infinity };\r\n\r\nvar restrictEdges = {\r\n defaults: {\r\n enabled: false,\r\n endOnly: false,\r\n min: null,\r\n max: null,\r\n offset: null\r\n },\r\n\r\n setOffset: function setOffset(_ref) {\r\n var interaction = _ref.interaction,\r\n startOffset = _ref.startOffset,\r\n options = _ref.options;\r\n\r\n if (!options) {\r\n return utils.extend({}, startOffset);\r\n }\r\n\r\n var offset = getRestrictionRect(options.offset, interaction, interaction.startCoords.page);\r\n\r\n if (offset) {\r\n return {\r\n top: startOffset.top + offset.y,\r\n left: startOffset.left + offset.x,\r\n bottom: startOffset.bottom + offset.y,\r\n right: startOffset.right + offset.x\r\n };\r\n }\r\n\r\n return startOffset;\r\n },\r\n\r\n set: function set(_ref2) {\r\n var pageCoords = _ref2.pageCoords,\r\n interaction = _ref2.interaction,\r\n status = _ref2.status,\r\n offset = _ref2.offset,\r\n options = _ref2.options;\r\n\r\n var edges = interaction.prepared.linkedEdges || interaction.prepared.edges;\r\n\r\n if (!interaction.interacting() || !edges) {\r\n return;\r\n }\r\n\r\n var page = status.useStatusXY ? { x: status.x, y: status.y } : utils.extend({}, pageCoords);\r\n var inner = rectUtils.xywhToTlbr(getRestrictionRect(options.inner, interaction, page)) || noInner;\r\n var outer = rectUtils.xywhToTlbr(getRestrictionRect(options.outer, interaction, page)) || noOuter;\r\n\r\n var modifiedX = page.x;\r\n var modifiedY = page.y;\r\n\r\n status.dx = 0;\r\n status.dy = 0;\r\n status.locked = false;\r\n\r\n if (edges.top) {\r\n modifiedY = Math.min(Math.max(outer.top + offset.top, page.y), inner.top + offset.top);\r\n } else if (edges.bottom) {\r\n modifiedY = Math.max(Math.min(outer.bottom - offset.bottom, page.y), inner.bottom - offset.bottom);\r\n }\r\n if (edges.left) {\r\n modifiedX = Math.min(Math.max(outer.left + offset.left, page.x), inner.left + offset.left);\r\n } else if (edges.right) {\r\n modifiedX = Math.max(Math.min(outer.right - offset.right, page.x), inner.right - offset.right);\r\n }\r\n\r\n status.dx = modifiedX - page.x;\r\n status.dy = modifiedY - page.y;\r\n\r\n status.changed = status.modifiedX !== modifiedX || status.modifiedY !== modifiedY;\r\n status.locked = !!(status.dx || status.dy);\r\n\r\n status.modifiedX = modifiedX;\r\n status.modifiedY = modifiedY;\r\n },\r\n\r\n modifyCoords: function modifyCoords(_ref3) {\r\n var page = _ref3.page,\r\n client = _ref3.client,\r\n status = _ref3.status,\r\n phase = _ref3.phase,\r\n options = _ref3.options;\r\n\r\n if (options && options.enabled && !(phase === 'start' && status.locked)) {\r\n\r\n if (status.locked) {\r\n page.x += status.dx;\r\n page.y += status.dy;\r\n client.x += status.dx;\r\n client.y += status.dy;\r\n\r\n return {\r\n dx: status.dx,\r\n dy: status.dy\r\n };\r\n }\r\n }\r\n },\r\n\r\n noInner: noInner,\r\n noOuter: noOuter,\r\n getRestrictionRect: getRestrictionRect\r\n};\r\n\r\nmodifiers.restrictEdges = restrictEdges;\r\nmodifiers.names.push('restrictEdges');\r\n\r\ndefaultOptions.perAction.restrictEdges = restrictEdges.defaults;\r\nresize.defaults.restrictEdges = restrictEdges.defaults;\r\n\r\nmodule.exports = restrictEdges;\r\n\r\n},{\"../actions/resize\":10,\"../defaultOptions\":18,\"../utils\":44,\"../utils/rect\":51,\"./index\":24,\"./restrict\":25}],27:[function(require,module,exports){\r\n'use strict';\r\n\r\n// This module adds the options.resize.restrictSize setting which sets min and\r\n// max width and height for the target being resized.\r\n//\r\n// interact(target).resize({\r\n// edges: { top: true, left: true },\r\n// restrictSize: {\r\n// min: { width: -600, height: -600 },\r\n// max: { width: 600, height: 600 },\r\n// },\r\n// });\r\n\r\nvar modifiers = require('./index');\r\nvar restrictEdges = require('./restrictEdges');\r\nvar utils = require('../utils');\r\nvar rectUtils = require('../utils/rect');\r\nvar defaultOptions = require('../defaultOptions');\r\nvar resize = require('../actions/resize');\r\n\r\nvar noMin = { width: -Infinity, height: -Infinity };\r\nvar noMax = { width: +Infinity, height: +Infinity };\r\n\r\nvar restrictSize = {\r\n defaults: {\r\n enabled: false,\r\n endOnly: false,\r\n min: null,\r\n max: null\r\n },\r\n\r\n setOffset: function setOffset(_ref) {\r\n var interaction = _ref.interaction;\r\n\r\n return interaction.startOffset;\r\n },\r\n\r\n set: function set(arg) {\r\n var interaction = arg.interaction,\r\n options = arg.options;\r\n\r\n var edges = interaction.prepared.linkedEdges || interaction.prepared.edges;\r\n\r\n if (!interaction.interacting() || !edges) {\r\n return;\r\n }\r\n\r\n var rect = rectUtils.xywhToTlbr(interaction.resizeRects.inverted);\r\n\r\n var minSize = rectUtils.tlbrToXywh(restrictEdges.getRestrictionRect(options.min, interaction)) || noMin;\r\n var maxSize = rectUtils.tlbrToXywh(restrictEdges.getRestrictionRect(options.max, interaction)) || noMax;\r\n\r\n arg.options = {\r\n enabled: options.enabled,\r\n endOnly: options.endOnly,\r\n inner: utils.extend({}, restrictEdges.noInner),\r\n outer: utils.extend({}, restrictEdges.noOuter)\r\n };\r\n\r\n if (edges.top) {\r\n arg.options.inner.top = rect.bottom - minSize.height;\r\n arg.options.outer.top = rect.bottom - maxSize.height;\r\n } else if (edges.bottom) {\r\n arg.options.inner.bottom = rect.top + minSize.height;\r\n arg.options.outer.bottom = rect.top + maxSize.height;\r\n }\r\n if (edges.left) {\r\n arg.options.inner.left = rect.right - minSize.width;\r\n arg.options.outer.left = rect.right - maxSize.width;\r\n } else if (edges.right) {\r\n arg.options.inner.right = rect.left + minSize.width;\r\n arg.options.outer.right = rect.left + maxSize.width;\r\n }\r\n\r\n restrictEdges.set(arg);\r\n },\r\n\r\n modifyCoords: restrictEdges.modifyCoords\r\n};\r\n\r\nmodifiers.restrictSize = restrictSize;\r\nmodifiers.names.push('restrictSize');\r\n\r\ndefaultOptions.perAction.restrictSize = restrictSize.defaults;\r\nresize.defaults.restrictSize = restrictSize.defaults;\r\n\r\nmodule.exports = restrictSize;\r\n\r\n},{\"../actions/resize\":10,\"../defaultOptions\":18,\"../utils\":44,\"../utils/rect\":51,\"./index\":24,\"./restrictEdges\":26}],28:[function(require,module,exports){\r\n'use strict';\r\n\r\nvar modifiers = require('./index');\r\nvar interact = require('../interact');\r\nvar utils = require('../utils');\r\nvar defaultOptions = require('../defaultOptions');\r\n\r\nvar snap = {\r\n defaults: {\r\n enabled: false,\r\n endOnly: false,\r\n range: Infinity,\r\n targets: null,\r\n offsets: null,\r\n\r\n relativePoints: null\r\n },\r\n\r\n setOffset: function setOffset(_ref) {\r\n var interaction = _ref.interaction,\r\n interactable = _ref.interactable,\r\n element = _ref.element,\r\n rect = _ref.rect,\r\n startOffset = _ref.startOffset,\r\n options = _ref.options;\r\n\r\n var offsets = [];\r\n var optionsOrigin = utils.rectToXY(utils.resolveRectLike(options.origin));\r\n var origin = optionsOrigin || utils.getOriginXY(interactable, element, interaction.prepared.name);\r\n options = options || interactable.options[interaction.prepared.name].snap || {};\r\n\r\n var snapOffset = void 0;\r\n\r\n if (options.offset === 'startCoords') {\r\n snapOffset = {\r\n x: interaction.startCoords.page.x - origin.x,\r\n y: interaction.startCoords.page.y - origin.y\r\n };\r\n } else {\r\n var offsetRect = utils.resolveRectLike(options.offset, interactable, element, [interaction]);\r\n\r\n snapOffset = utils.rectToXY(offsetRect) || { x: 0, y: 0 };\r\n }\r\n\r\n if (rect && options.relativePoints && options.relativePoints.length) {\r\n for (var _iterator = options.relativePoints, _isArray = Array.isArray(_iterator), _i = 0, _iterator = _isArray ? _iterator : _iterator[Symbol.iterator]();;) {\r\n var _ref2;\r\n\r\n if (_isArray) {\r\n if (_i >= _iterator.length) break;\r\n _ref2 = _iterator[_i++];\r\n } else {\r\n _i = _iterator.next();\r\n if (_i.done) break;\r\n _ref2 = _i.value;\r\n }\r\n\r\n var _ref3 = _ref2,\r\n relativeX = _ref3.x,\r\n relativeY = _ref3.y;\r\n\r\n offsets.push({\r\n x: startOffset.left - rect.width * relativeX + snapOffset.x,\r\n y: startOffset.top - rect.height * relativeY + snapOffset.y\r\n });\r\n }\r\n } else {\r\n offsets.push(snapOffset);\r\n }\r\n\r\n return offsets;\r\n },\r\n\r\n set: function set(_ref4) {\r\n var interaction = _ref4.interaction,\r\n pageCoords = _ref4.pageCoords,\r\n status = _ref4.status,\r\n options = _ref4.options,\r\n offsets = _ref4.offset;\r\n\r\n var targets = [];\r\n var target = void 0;\r\n var page = void 0;\r\n var i = void 0;\r\n\r\n if (status.useStatusXY) {\r\n page = { x: status.x, y: status.y };\r\n } else {\r\n var origin = utils.getOriginXY(interaction.target, interaction.element, interaction.prepared.name);\r\n\r\n page = utils.extend({}, pageCoords);\r\n\r\n page.x -= origin.x;\r\n page.y -= origin.y;\r\n }\r\n\r\n status.realX = page.x;\r\n status.realY = page.y;\r\n\r\n var len = options.targets ? options.targets.length : 0;\r\n\r\n for (var _iterator2 = offsets, _isArray2 = Array.isArray(_iterator2), _i2 = 0, _iterator2 = _isArray2 ? _iterator2 : _iterator2[Symbol.iterator]();;) {\r\n var _ref5;\r\n\r\n if (_isArray2) {\r\n if (_i2 >= _iterator2.length) break;\r\n _ref5 = _iterator2[_i2++];\r\n } else {\r\n _i2 = _iterator2.next();\r\n if (_i2.done) break;\r\n _ref5 = _i2.value;\r\n }\r\n\r\n var _ref6 = _ref5,\r\n offsetX = _ref6.x,\r\n offsetY = _ref6.y;\r\n\r\n var relativeX = page.x - offsetX;\r\n var relativeY = page.y - offsetY;\r\n\r\n for (var _iterator3 = options.targets, _isArray3 = Array.isArray(_iterator3), _i3 = 0, _iterator3 = _isArray3 ? _iterator3 : _iterator3[Symbol.iterator]();;) {\r\n var _ref7;\r\n\r\n if (_isArray3) {\r\n if (_i3 >= _iterator3.length) break;\r\n _ref7 = _iterator3[_i3++];\r\n } else {\r\n _i3 = _iterator3.next();\r\n if (_i3.done) break;\r\n _ref7 = _i3.value;\r\n }\r\n\r\n var snapTarget = _ref7;\r\n\r\n if (utils.is.function(snapTarget)) {\r\n target = snapTarget(relativeX, relativeY, interaction);\r\n } else {\r\n target = snapTarget;\r\n }\r\n\r\n if (!target) {\r\n continue;\r\n }\r\n\r\n targets.push({\r\n x: utils.is.number(target.x) ? target.x + offsetX : relativeX,\r\n y: utils.is.number(target.y) ? target.y + offsetY : relativeY,\r\n\r\n range: utils.is.number(target.range) ? target.range : options.range\r\n });\r\n }\r\n }\r\n\r\n var closest = {\r\n target: null,\r\n inRange: false,\r\n distance: 0,\r\n range: 0,\r\n dx: 0,\r\n dy: 0\r\n };\r\n\r\n for (i = 0, len = targets.length; i < len; i++) {\r\n target = targets[i];\r\n\r\n var range = target.range;\r\n var dx = target.x - page.x;\r\n var dy = target.y - page.y;\r\n var distance = utils.hypot(dx, dy);\r\n var inRange = distance <= range;\r\n\r\n // Infinite targets count as being out of range\r\n // compared to non infinite ones that are in range\r\n if (range === Infinity && closest.inRange && closest.range !== Infinity) {\r\n inRange = false;\r\n }\r\n\r\n if (!closest.target || (inRange\r\n // is the closest target in range?\r\n ? closest.inRange && range !== Infinity\r\n // the pointer is relatively deeper in this target\r\n ? distance / range < closest.distance / closest.range\r\n // this target has Infinite range and the closest doesn't\r\n : range === Infinity && closest.range !== Infinity ||\r\n // OR this target is closer that the previous closest\r\n distance < closest.distance :\r\n // The other is not in range and the pointer is closer to this target\r\n !closest.inRange && distance < closest.distance)) {\r\n\r\n closest.target = target;\r\n closest.distance = distance;\r\n closest.range = range;\r\n closest.inRange = inRange;\r\n closest.dx = dx;\r\n closest.dy = dy;\r\n\r\n status.range = range;\r\n }\r\n }\r\n\r\n var snapChanged = void 0;\r\n\r\n if (closest.target) {\r\n snapChanged = status.modifiedX !== closest.target.x || status.modifiedY !== closest.target.y;\r\n\r\n status.modifiedX = closest.target.x;\r\n status.modifiedY = closest.target.y;\r\n } else {\r\n snapChanged = true;\r\n\r\n status.modifiedX = NaN;\r\n status.modifiedY = NaN;\r\n }\r\n\r\n status.dx = closest.dx;\r\n status.dy = closest.dy;\r\n\r\n status.changed = snapChanged || closest.inRange && !status.locked;\r\n status.locked = closest.inRange;\r\n },\r\n\r\n modifyCoords: function modifyCoords(_ref8) {\r\n var page = _ref8.page,\r\n client = _ref8.client,\r\n status = _ref8.status,\r\n phase = _ref8.phase,\r\n options = _ref8.options;\r\n\r\n var relativePoints = options && options.relativePoints;\r\n\r\n if (options && options.enabled && !(phase === 'start' && relativePoints && relativePoints.length)) {\r\n\r\n if (status.locked) {\r\n page.x += status.dx;\r\n page.y += status.dy;\r\n client.x += status.dx;\r\n client.y += status.dy;\r\n }\r\n\r\n return {\r\n range: status.range,\r\n locked: status.locked,\r\n x: status.modifiedX,\r\n y: status.modifiedY,\r\n realX: status.realX,\r\n realY: status.realY,\r\n dx: status.dx,\r\n dy: status.dy\r\n };\r\n }\r\n }\r\n};\r\n\r\ninteract.createSnapGrid = function (grid) {\r\n return function (x, y) {\r\n var limits = grid.limits || {\r\n left: -Infinity,\r\n right: Infinity,\r\n top: -Infinity,\r\n bottom: Infinity\r\n };\r\n var offsetX = 0;\r\n var offsetY = 0;\r\n\r\n if (utils.is.object(grid.offset)) {\r\n offsetX = grid.offset.x;\r\n offsetY = grid.offset.y;\r\n }\r\n\r\n var gridx = Math.round((x - offsetX) / grid.x);\r\n var gridy = Math.round((y - offsetY) / grid.y);\r\n\r\n var newX = Math.max(limits.left, Math.min(limits.right, gridx * grid.x + offsetX));\r\n var newY = Math.max(limits.top, Math.min(limits.bottom, gridy * grid.y + offsetY));\r\n\r\n return {\r\n x: newX,\r\n y: newY,\r\n range: grid.range\r\n };\r\n };\r\n};\r\n\r\nmodifiers.snap = snap;\r\nmodifiers.names.push('snap');\r\n\r\ndefaultOptions.perAction.snap = snap.defaults;\r\n\r\nmodule.exports = snap;\r\n\r\n},{\"../defaultOptions\":18,\"../interact\":21,\"../utils\":44,\"./index\":24}],29:[function(require,module,exports){\r\n'use strict';\r\n\r\n// This module allows snapping of the size of targets during resize\r\n// interactions.\r\n\r\nvar modifiers = require('./index');\r\nvar snap = require('./snap');\r\nvar defaultOptions = require('../defaultOptions');\r\nvar resize = require('../actions/resize');\r\nvar utils = require('../utils/');\r\n\r\nvar snapSize = {\r\n defaults: {\r\n enabled: false,\r\n endOnly: false,\r\n range: Infinity,\r\n targets: null,\r\n offsets: null\r\n },\r\n\r\n setOffset: function setOffset(arg) {\r\n var interaction = arg.interaction,\r\n options = arg.options;\r\n\r\n var edges = interaction.prepared.edges;\r\n\r\n if (!edges) {\r\n return;\r\n }\r\n\r\n arg.options = {\r\n relativePoints: [{\r\n x: edges.left ? 0 : 1,\r\n y: edges.top ? 0 : 1\r\n }],\r\n origin: { x: 0, y: 0 },\r\n offset: 'self',\r\n range: options.range\r\n };\r\n\r\n var offsets = snap.setOffset(arg);\r\n arg.options = options;\r\n\r\n return offsets;\r\n },\r\n\r\n set: function set(arg) {\r\n var interaction = arg.interaction,\r\n options = arg.options,\r\n offset = arg.offset,\r\n pageCoords = arg.pageCoords;\r\n\r\n var page = utils.extend({}, pageCoords);\r\n var relativeX = page.x - offset[0].x;\r\n var relativeY = page.y - offset[0].y;\r\n\r\n arg.options = utils.extend({}, options);\r\n arg.options.targets = [];\r\n\r\n for (var _iterator = options.targets, _isArray = Array.isArray(_iterator), _i = 0, _iterator = _isArray ? _iterator : _iterator[Symbol.iterator]();;) {\r\n var _ref;\r\n\r\n if (_isArray) {\r\n if (_i >= _iterator.length) break;\r\n _ref = _iterator[_i++];\r\n } else {\r\n _i = _iterator.next();\r\n if (_i.done) break;\r\n _ref = _i.value;\r\n }\r\n\r\n var snapTarget = _ref;\r\n\r\n var target = void 0;\r\n\r\n if (utils.is.function(snapTarget)) {\r\n target = snapTarget(relativeX, relativeY, interaction);\r\n } else {\r\n target = snapTarget;\r\n }\r\n\r\n if (!target) {\r\n continue;\r\n }\r\n\r\n if ('width' in target && 'height' in target) {\r\n target.x = target.width;\r\n target.y = target.height;\r\n }\r\n\r\n arg.options.targets.push(target);\r\n }\r\n\r\n snap.set(arg);\r\n },\r\n\r\n modifyCoords: function modifyCoords(arg) {\r\n var options = arg.options;\r\n\r\n\r\n arg.options = utils.extend({}, options);\r\n arg.options.enabled = options.enabled;\r\n arg.options.relativePoints = [null];\r\n\r\n snap.modifyCoords(arg);\r\n }\r\n};\r\n\r\nmodifiers.snapSize = snapSize;\r\nmodifiers.names.push('snapSize');\r\n\r\ndefaultOptions.perAction.snapSize = snapSize.defaults;\r\nresize.defaults.snapSize = snapSize.defaults;\r\n\r\nmodule.exports = snapSize;\r\n\r\n},{\"../actions/resize\":10,\"../defaultOptions\":18,\"../utils/\":44,\"./index\":24,\"./snap\":28}],30:[function(require,module,exports){\r\n'use strict';\r\n\r\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\r\n\r\nvar pointerUtils = require('../utils/pointerUtils');\r\n\r\nmodule.exports = function () {\r\n function PointerEvent(type, pointer, event, eventTarget, interaction) {\r\n _classCallCheck(this, PointerEvent);\r\n\r\n pointerUtils.pointerExtend(this, event);\r\n\r\n if (event !== pointer) {\r\n pointerUtils.pointerExtend(this, pointer);\r\n }\r\n\r\n this.interaction = interaction;\r\n\r\n this.timeStamp = new Date().getTime();\r\n this.originalEvent = event;\r\n this.type = type;\r\n this.pointerId = pointerUtils.getPointerId(pointer);\r\n this.pointerType = pointerUtils.getPointerType(pointer);\r\n this.target = eventTarget;\r\n this.currentTarget = null;\r\n\r\n if (type === 'tap') {\r\n var pointerIndex = interaction.getPointerIndex(pointer);\r\n this.dt = this.timeStamp - interaction.downTimes[pointerIndex];\r\n\r\n var interval = this.timeStamp - interaction.tapTime;\r\n\r\n this.double = !!(interaction.prevTap && interaction.prevTap.type !== 'doubletap' && interaction.prevTap.target === this.target && interval < 500);\r\n } else if (type === 'doubletap') {\r\n this.dt = pointer.timeStamp - interaction.tapTime;\r\n }\r\n }\r\n\r\n PointerEvent.prototype.subtractOrigin = function subtractOrigin(_ref) {\r\n var originX = _ref.x,\r\n originY = _ref.y;\r\n\r\n this.pageX -= originX;\r\n this.pageY -= originY;\r\n this.clientX -= originX;\r\n this.clientY -= originY;\r\n\r\n return this;\r\n };\r\n\r\n PointerEvent.prototype.addOrigin = function addOrigin(_ref2) {\r\n var originX = _ref2.x,\r\n originY = _ref2.y;\r\n\r\n this.pageX += originX;\r\n this.pageY += originY;\r\n this.clientX += originX;\r\n this.clientY += originY;\r\n\r\n return this;\r\n };\r\n\r\n PointerEvent.prototype.preventDefault = function preventDefault() {\r\n this.originalEvent.preventDefault();\r\n };\r\n\r\n PointerEvent.prototype.stopPropagation = function stopPropagation() {\r\n this.propagationStopped = true;\r\n };\r\n\r\n PointerEvent.prototype.stopImmediatePropagation = function stopImmediatePropagation() {\r\n this.immediatePropagationStopped = this.propagationStopped = true;\r\n };\r\n\r\n return PointerEvent;\r\n}();\r\n\r\n},{\"../utils/pointerUtils\":49}],31:[function(require,module,exports){\r\n'use strict';\r\n\r\nvar PointerEvent = require('./PointerEvent');\r\nvar Interaction = require('../Interaction');\r\nvar utils = require('../utils');\r\nvar browser = require('../utils/browser');\r\nvar defaults = require('../defaultOptions');\r\nvar signals = require('../utils/Signals').new();\r\n\r\nvar _require = require('../utils/arr'),\r\n filter = _require.filter;\r\n\r\nvar simpleSignals = ['down', 'up', 'cancel'];\r\nvar simpleEvents = ['down', 'up', 'cancel'];\r\n\r\nvar pointerEvents = {\r\n PointerEvent: PointerEvent,\r\n fire: fire,\r\n collectEventTargets: collectEventTargets,\r\n signals: signals,\r\n defaults: {\r\n holdDuration: 600,\r\n ignoreFrom: null,\r\n allowFrom: null,\r\n origin: { x: 0, y: 0 }\r\n },\r\n types: ['down', 'move', 'up', 'cancel', 'tap', 'doubletap', 'hold']\r\n};\r\n\r\nfunction fire(arg) {\r\n var interaction = arg.interaction,\r\n pointer = arg.pointer,\r\n event = arg.event,\r\n eventTarget = arg.eventTarget,\r\n _arg$type = arg.type,\r\n type = _arg$type === undefined ? arg.pointerEvent.type : _arg$type,\r\n _arg$targets = arg.targets,\r\n targets = _arg$targets === undefined ? collectEventTargets(arg) : _arg$targets,\r\n _arg$pointerEvent = arg.pointerEvent,\r\n pointerEvent = _arg$pointerEvent === undefined ? new PointerEvent(type, pointer, event, eventTarget, interaction) : _arg$pointerEvent;\r\n\r\n\r\n var signalArg = {\r\n interaction: interaction,\r\n pointer: pointer,\r\n event: event,\r\n eventTarget: eventTarget,\r\n targets: targets,\r\n type: type,\r\n pointerEvent: pointerEvent\r\n };\r\n\r\n for (var i = 0; i < targets.length; i++) {\r\n var target = targets[i];\r\n\r\n for (var prop in target.props || {}) {\r\n pointerEvent[prop] = target.props[prop];\r\n }\r\n\r\n var origin = utils.getOriginXY(target.eventable, target.element);\r\n\r\n pointerEvent.subtractOrigin(origin);\r\n pointerEvent.eventable = target.eventable;\r\n pointerEvent.currentTarget = target.element;\r\n\r\n target.eventable.fire(pointerEvent);\r\n\r\n pointerEvent.addOrigin(origin);\r\n\r\n if (pointerEvent.immediatePropagationStopped || pointerEvent.propagationStopped && i + 1 < targets.length && targets[i + 1].element !== pointerEvent.currentTarget) {\r\n break;\r\n }\r\n }\r\n\r\n signals.fire('fired', signalArg);\r\n\r\n if (type === 'tap') {\r\n // if pointerEvent should make a double tap, create and fire a doubletap\r\n // PointerEvent and use that as the prevTap\r\n var prevTap = pointerEvent.double ? fire({\r\n interaction: interaction, pointer: pointer, event: event, eventTarget: eventTarget,\r\n type: 'doubletap'\r\n }) : pointerEvent;\r\n\r\n interaction.prevTap = prevTap;\r\n interaction.tapTime = prevTap.timeStamp;\r\n }\r\n\r\n return pointerEvent;\r\n}\r\n\r\nfunction collectEventTargets(_ref) {\r\n var interaction = _ref.interaction,\r\n pointer = _ref.pointer,\r\n event = _ref.event,\r\n eventTarget = _ref.eventTarget,\r\n type = _ref.type;\r\n\r\n var pointerIndex = interaction.getPointerIndex(pointer);\r\n\r\n // do not fire a tap event if the pointer was moved before being lifted\r\n if (type === 'tap' && (interaction.pointerWasMoved\r\n // or if the pointerup target is different to the pointerdown target\r\n || !(interaction.downTargets[pointerIndex] && interaction.downTargets[pointerIndex] === eventTarget))) {\r\n return [];\r\n }\r\n\r\n var path = utils.getPath(eventTarget);\r\n var signalArg = {\r\n interaction: interaction,\r\n pointer: pointer,\r\n event: event,\r\n eventTarget: eventTarget,\r\n type: type,\r\n path: path,\r\n targets: [],\r\n element: null\r\n };\r\n\r\n for (var _iterator = path, _isArray = Array.isArray(_iterator), _i = 0, _iterator = _isArray ? _iterator : _iterator[Symbol.iterator]();;) {\r\n var _ref2;\r\n\r\n if (_isArray) {\r\n if (_i >= _iterator.length) break;\r\n _ref2 = _iterator[_i++];\r\n } else {\r\n _i = _iterator.next();\r\n if (_i.done) break;\r\n _ref2 = _i.value;\r\n }\r\n\r\n var element = _ref2;\r\n\r\n signalArg.element = element;\r\n\r\n signals.fire('collect-targets', signalArg);\r\n }\r\n\r\n if (type === 'hold') {\r\n signalArg.targets = filter(signalArg.targets, function (target) {\r\n return target.eventable.options.holdDuration === interaction.holdTimers[pointerIndex].duration;\r\n });\r\n }\r\n\r\n return signalArg.targets;\r\n}\r\n\r\nInteraction.signals.on('update-pointer-down', function (_ref3) {\r\n var interaction = _ref3.interaction,\r\n pointerIndex = _ref3.pointerIndex;\r\n\r\n interaction.holdTimers[pointerIndex] = { duration: Infinity, timeout: null };\r\n});\r\n\r\nInteraction.signals.on('remove-pointer', function (_ref4) {\r\n var interaction = _ref4.interaction,\r\n pointerIndex = _ref4.pointerIndex;\r\n\r\n interaction.holdTimers.splice(pointerIndex, 1);\r\n});\r\n\r\nInteraction.signals.on('move', function (_ref5) {\r\n var interaction = _ref5.interaction,\r\n pointer = _ref5.pointer,\r\n event = _ref5.event,\r\n eventTarget = _ref5.eventTarget,\r\n duplicateMove = _ref5.duplicateMove;\r\n\r\n var pointerIndex = interaction.getPointerIndex(pointer);\r\n\r\n if (!duplicateMove && (!interaction.pointerIsDown || interaction.pointerWasMoved)) {\r\n if (interaction.pointerIsDown) {\r\n clearTimeout(interaction.holdTimers[pointerIndex].timeout);\r\n }\r\n\r\n fire({\r\n interaction: interaction, pointer: pointer, event: event, eventTarget: eventTarget,\r\n type: 'move'\r\n });\r\n }\r\n});\r\n\r\nInteraction.signals.on('down', function (_ref6) {\r\n var interaction = _ref6.interaction,\r\n pointer = _ref6.pointer,\r\n event = _ref6.event,\r\n eventTarget = _ref6.eventTarget,\r\n pointerIndex = _ref6.pointerIndex;\r\n\r\n // copy event to be used in timeout for IE8\r\n var eventCopy = browser.isIE8 ? utils.extend({}, event) : event;\r\n\r\n var timer = interaction.holdTimers[pointerIndex];\r\n var path = utils.getPath(eventTarget);\r\n var signalArg = {\r\n interaction: interaction,\r\n pointer: pointer,\r\n event: event,\r\n eventTarget: eventTarget,\r\n type: 'hold',\r\n targets: [],\r\n path: path,\r\n element: null\r\n };\r\n\r\n for (var _iterator2 = path, _isArray2 = Array.isArray(_iterator2), _i2 = 0, _iterator2 = _isArray2 ? _iterator2 : _iterator2[Symbol.iterator]();;) {\r\n var _ref7;\r\n\r\n if (_isArray2) {\r\n if (_i2 >= _iterator2.length) break;\r\n _ref7 = _iterator2[_i2++];\r\n } else {\r\n _i2 = _iterator2.next();\r\n if (_i2.done) break;\r\n _ref7 = _i2.value;\r\n }\r\n\r\n var element = _ref7;\r\n\r\n signalArg.element = element;\r\n\r\n signals.fire('collect-targets', signalArg);\r\n }\r\n\r\n if (!signalArg.targets.length) {\r\n return;\r\n }\r\n\r\n var minDuration = Infinity;\r\n\r\n for (var i = 0; i < signalArg.targets.length; i++) {\r\n var target = signalArg.targets[i];\r\n var holdDuration = target.eventable.options.holdDuration;\r\n\r\n if (holdDuration < minDuration) {\r\n minDuration = holdDuration;\r\n }\r\n }\r\n\r\n timer.duration = minDuration;\r\n timer.timeout = setTimeout(function () {\r\n fire({\r\n interaction: interaction,\r\n eventTarget: eventTarget,\r\n pointer: browser.isIE8 ? eventCopy : pointer,\r\n event: eventCopy,\r\n type: 'hold'\r\n });\r\n }, minDuration);\r\n});\r\n\r\nInteraction.signals.on('up', function (_ref8) {\r\n var interaction = _ref8.interaction,\r\n pointer = _ref8.pointer,\r\n event = _ref8.event,\r\n eventTarget = _ref8.eventTarget;\r\n\r\n if (!interaction.pointerWasMoved) {\r\n fire({ interaction: interaction, eventTarget: eventTarget, pointer: pointer, event: event, type: 'tap' });\r\n }\r\n});\r\n\r\n['up', 'cancel'].forEach(function (signalName) {\r\n Interaction.signals.on(signalName, function (_ref9) {\r\n var interaction = _ref9.interaction,\r\n pointerIndex = _ref9.pointerIndex;\r\n\r\n if (interaction.holdTimers[pointerIndex]) {\r\n clearTimeout(interaction.holdTimers[pointerIndex].timeout);\r\n }\r\n });\r\n});\r\n\r\nfunction createSignalListener(type) {\r\n return function (_ref10) {\r\n var interaction = _ref10.interaction,\r\n pointer = _ref10.pointer,\r\n event = _ref10.event,\r\n eventTarget = _ref10.eventTarget;\r\n\r\n fire({ interaction: interaction, eventTarget: eventTarget, pointer: pointer, event: event, type: type });\r\n };\r\n}\r\n\r\nfor (var i = 0; i < simpleSignals.length; i++) {\r\n Interaction.signals.on(simpleSignals[i], createSignalListener(simpleEvents[i]));\r\n}\r\n\r\nInteraction.signals.on('new', function (interaction) {\r\n interaction.prevTap = null; // the most recent tap event on this interaction\r\n interaction.tapTime = 0; // time of the most recent tap event\r\n interaction.holdTimers = []; // [{ duration, timeout }]\r\n});\r\n\r\ndefaults.pointerEvents = pointerEvents.defaults;\r\nmodule.exports = pointerEvents;\r\n\r\n},{\"../Interaction\":5,\"../defaultOptions\":18,\"../utils\":44,\"../utils/Signals\":35,\"../utils/arr\":36,\"../utils/browser\":37,\"./PointerEvent\":30}],32:[function(require,module,exports){\r\n'use strict';\r\n\r\nvar pointerEvents = require('./base');\r\nvar Interaction = require('../Interaction');\r\n\r\npointerEvents.signals.on('new', onNew);\r\npointerEvents.signals.on('fired', onFired);\r\n\r\nvar _arr = ['move', 'up', 'cancel', 'endall'];\r\nfor (var _i = 0; _i < _arr.length; _i++) {\r\n var signal = _arr[_i];\r\n Interaction.signals.on(signal, endHoldRepeat);\r\n}\r\n\r\nfunction onNew(_ref) {\r\n var pointerEvent = _ref.pointerEvent;\r\n\r\n if (pointerEvent.type !== 'hold') {\r\n return;\r\n }\r\n\r\n pointerEvent.count = (pointerEvent.count || 0) + 1;\r\n}\r\n\r\nfunction onFired(_ref2) {\r\n var interaction = _ref2.interaction,\r\n pointerEvent = _ref2.pointerEvent,\r\n eventTarget = _ref2.eventTarget,\r\n targets = _ref2.targets;\r\n\r\n if (pointerEvent.type !== 'hold' || !targets.length) {\r\n return;\r\n }\r\n\r\n // get the repeat interval from the first eventable\r\n var interval = targets[0].eventable.options.holdRepeatInterval;\r\n\r\n // don't repeat if the interval is 0 or less\r\n if (interval <= 0) {\r\n return;\r\n }\r\n\r\n // set a timeout to fire the holdrepeat event\r\n interaction.holdIntervalHandle = setTimeout(function () {\r\n pointerEvents.fire({\r\n interaction: interaction,\r\n eventTarget: eventTarget,\r\n type: 'hold',\r\n pointer: pointerEvent,\r\n event: pointerEvent\r\n });\r\n }, interval);\r\n}\r\n\r\nfunction endHoldRepeat(_ref3) {\r\n var interaction = _ref3.interaction;\r\n\r\n // set the interaction's holdStopTime property\r\n // to stop further holdRepeat events\r\n if (interaction.holdIntervalHandle) {\r\n clearInterval(interaction.holdIntervalHandle);\r\n interaction.holdIntervalHandle = null;\r\n }\r\n}\r\n\r\n// don't repeat by default\r\npointerEvents.defaults.holdRepeatInterval = 0;\r\npointerEvents.types.push('holdrepeat');\r\n\r\nmodule.exports = {\r\n onNew: onNew,\r\n onFired: onFired,\r\n endHoldRepeat: endHoldRepeat\r\n};\r\n\r\n},{\"../Interaction\":5,\"./base\":31}],33:[function(require,module,exports){\r\n'use strict';\r\n\r\nvar pointerEvents = require('./base');\r\nvar Interactable = require('../Interactable');\r\nvar browser = require('../utils/browser');\r\nvar is = require('../utils/is');\r\nvar domUtils = require('../utils/domUtils');\r\nvar scope = require('../scope');\r\nvar extend = require('../utils/extend');\r\n\r\nvar _require = require('../utils/arr'),\r\n merge = _require.merge;\r\n\r\npointerEvents.signals.on('collect-targets', function (_ref) {\r\n var targets = _ref.targets,\r\n element = _ref.element,\r\n type = _ref.type,\r\n eventTarget = _ref.eventTarget;\r\n\r\n function collectSelectors(interactable, selector, context) {\r\n var els = browser.useMatchesSelectorPolyfill ? context.querySelectorAll(selector) : undefined;\r\n\r\n var eventable = interactable.events;\r\n var options = eventable.options;\r\n\r\n if (eventable[type] && is.element(element) && domUtils.matchesSelector(element, selector, els) && interactable.testIgnoreAllow(options, element, eventTarget)) {\r\n\r\n targets.push({\r\n element: element,\r\n eventable: eventable,\r\n props: { interactable: interactable }\r\n });\r\n }\r\n }\r\n\r\n var interactable = scope.interactables.get(element);\r\n\r\n if (interactable) {\r\n var eventable = interactable.events;\r\n var options = eventable.options;\r\n\r\n if (eventable[type] && interactable.testIgnoreAllow(options, element, eventTarget)) {\r\n targets.push({\r\n element: element,\r\n eventable: eventable,\r\n props: { interactable: interactable }\r\n });\r\n }\r\n }\r\n\r\n scope.interactables.forEachSelector(collectSelectors, element);\r\n});\r\n\r\nInteractable.signals.on('new', function (_ref2) {\r\n var interactable = _ref2.interactable;\r\n\r\n interactable.events.getRect = function (element) {\r\n return interactable.getRect(element);\r\n };\r\n});\r\n\r\nInteractable.signals.on('set', function (_ref3) {\r\n var interactable = _ref3.interactable,\r\n options = _ref3.options;\r\n\r\n extend(interactable.events.options, pointerEvents.defaults);\r\n extend(interactable.events.options, options);\r\n});\r\n\r\nmerge(Interactable.eventTypes, pointerEvents.types);\r\n\r\nInteractable.prototype.pointerEvents = function (options) {\r\n extend(this.events.options, options);\r\n\r\n return this;\r\n};\r\n\r\nvar __backCompatOption = Interactable.prototype._backCompatOption;\r\n\r\nInteractable.prototype._backCompatOption = function (optionName, newValue) {\r\n var ret = __backCompatOption.call(this, optionName, newValue);\r\n\r\n if (ret === this) {\r\n this.events.options[optionName] = newValue;\r\n }\r\n\r\n return ret;\r\n};\r\n\r\nInteractable.settingsMethods.push('pointerEvents');\r\n\r\n},{\"../Interactable\":4,\"../scope\":34,\"../utils/arr\":36,\"../utils/browser\":37,\"../utils/domUtils\":39,\"../utils/extend\":41,\"../utils/is\":46,\"./base\":31}],34:[function(require,module,exports){\r\n'use strict';\r\n\r\nvar utils = require('./utils');\r\nvar events = require('./utils/events');\r\nvar signals = require('./utils/Signals').new();\r\n\r\nvar scope = {\r\n signals: signals,\r\n events: events,\r\n utils: utils,\r\n\r\n // main document\r\n document: require('./utils/domObjects').document,\r\n // all documents being listened to\r\n documents: [],\r\n\r\n addDocument: function addDocument(doc, win) {\r\n // do nothing if document is already known\r\n if (utils.contains(scope.documents, doc)) {\r\n return false;\r\n }\r\n\r\n win = win || scope.getWindow(doc);\r\n\r\n scope.documents.push(doc);\r\n events.documents.push(doc);\r\n\r\n // don't add an unload event for the main document\r\n // so that the page may be cached in browser history\r\n if (doc !== scope.document) {\r\n events.add(win, 'unload', scope.onWindowUnload);\r\n }\r\n\r\n signals.fire('add-document', { doc: doc, win: win });\r\n },\r\n\r\n removeDocument: function removeDocument(doc, win) {\r\n var index = utils.indexOf(scope.documents, doc);\r\n\r\n win = win || scope.getWindow(doc);\r\n\r\n events.remove(win, 'unload', scope.onWindowUnload);\r\n\r\n scope.documents.splice(index, 1);\r\n events.documents.splice(index, 1);\r\n\r\n signals.fire('remove-document', { win: win, doc: doc });\r\n },\r\n\r\n onWindowUnload: function onWindowUnload() {\r\n scope.removeDocument(this.document, this);\r\n }\r\n};\r\n\r\nmodule.exports = scope;\r\n\r\n},{\"./utils\":44,\"./utils/Signals\":35,\"./utils/domObjects\":38,\"./utils/events\":40}],35:[function(require,module,exports){\r\n'use strict';\r\n\r\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\r\n\r\nvar _require = require('./arr'),\r\n indexOf = _require.indexOf;\r\n\r\nvar Signals = function () {\r\n function Signals() {\r\n _classCallCheck(this, Signals);\r\n\r\n this.listeners = {\r\n // signalName: [listeners],\r\n };\r\n }\r\n\r\n Signals.prototype.on = function on(name, listener) {\r\n if (!this.listeners[name]) {\r\n this.listeners[name] = [listener];\r\n return;\r\n }\r\n\r\n this.listeners[name].push(listener);\r\n };\r\n\r\n Signals.prototype.off = function off(name, listener) {\r\n if (!this.listeners[name]) {\r\n return;\r\n }\r\n\r\n var index = indexOf(this.listeners[name], listener);\r\n\r\n if (index !== -1) {\r\n this.listeners[name].splice(index, 1);\r\n }\r\n };\r\n\r\n Signals.prototype.fire = function fire(name, arg) {\r\n var targetListeners = this.listeners[name];\r\n\r\n if (!targetListeners) {\r\n return;\r\n }\r\n\r\n for (var i = 0; i < targetListeners.length; i++) {\r\n if (targetListeners[i](arg, name) === false) {\r\n return;\r\n }\r\n }\r\n };\r\n\r\n return Signals;\r\n}();\r\n\r\nSignals.new = function () {\r\n return new Signals();\r\n};\r\n\r\nmodule.exports = Signals;\r\n\r\n},{\"./arr\":36}],36:[function(require,module,exports){\r\n\"use strict\";\r\n\r\nfunction indexOf(array, target) {\r\n for (var i = 0, len = array.length; i < len; i++) {\r\n if (array[i] === target) {\r\n return i;\r\n }\r\n }\r\n\r\n return -1;\r\n}\r\n\r\nfunction contains(array, target) {\r\n return indexOf(array, target) !== -1;\r\n}\r\n\r\nfunction merge(target, source) {\r\n for (var i = 0; i < source.length; i++) {\r\n target.push(source[i]);\r\n }\r\n\r\n return target;\r\n}\r\n\r\nfunction filter(array, test) {\r\n var result = [];\r\n\r\n for (var i = 0; i < array.length; i++) {\r\n if (test(array[i])) {\r\n result.push(array[i]);\r\n }\r\n }\r\n\r\n return result;\r\n}\r\n\r\nmodule.exports = {\r\n indexOf: indexOf,\r\n contains: contains,\r\n merge: merge,\r\n filter: filter\r\n};\r\n\r\n},{}],37:[function(require,module,exports){\r\n'use strict';\r\n\r\nvar _require = require('./window'),\r\n window = _require.window;\r\n\r\nvar is = require('./is');\r\nvar domObjects = require('./domObjects');\r\n\r\nvar Element = domObjects.Element;\r\nvar navigator = window.navigator;\r\n\r\nvar browser = {\r\n // Does the browser support touch input?\r\n supportsTouch: !!('ontouchstart' in window || is.function(window.DocumentTouch) && domObjects.document instanceof window.DocumentTouch),\r\n\r\n // Does the browser support PointerEvents\r\n supportsPointerEvent: !!domObjects.PointerEvent,\r\n\r\n isIE8: 'attachEvent' in window && !('addEventListener' in window),\r\n\r\n // Opera Mobile must be handled differently\r\n isOperaMobile: navigator.appName === 'Opera' && browser.supportsTouch && navigator.userAgent.match('Presto'),\r\n\r\n // scrolling doesn't change the result of getClientRects on iOS 7\r\n isIOS7: /iP(hone|od|ad)/.test(navigator.platform) && /OS 7[^\\d]/.test(navigator.appVersion),\r\n\r\n isIe9OrOlder: /MSIE (8|9)/.test(navigator.userAgent),\r\n\r\n // prefix matchesSelector\r\n prefixedMatchesSelector: 'matches' in Element.prototype ? 'matches' : 'webkitMatchesSelector' in Element.prototype ? 'webkitMatchesSelector' : 'mozMatchesSelector' in Element.prototype ? 'mozMatchesSelector' : 'oMatchesSelector' in Element.prototype ? 'oMatchesSelector' : 'msMatchesSelector',\r\n\r\n useMatchesSelectorPolyfill: false,\r\n\r\n pEventTypes: domObjects.PointerEvent ? domObjects.PointerEvent === window.MSPointerEvent ? {\r\n up: 'MSPointerUp',\r\n down: 'MSPointerDown',\r\n over: 'mouseover',\r\n out: 'mouseout',\r\n move: 'MSPointerMove',\r\n cancel: 'MSPointerCancel'\r\n } : {\r\n up: 'pointerup',\r\n down: 'pointerdown',\r\n over: 'pointerover',\r\n out: 'pointerout',\r\n move: 'pointermove',\r\n cancel: 'pointercancel'\r\n } : null,\r\n\r\n // because Webkit and Opera still use 'mousewheel' event type\r\n wheelEvent: 'onmousewheel' in domObjects.document ? 'mousewheel' : 'wheel'\r\n\r\n};\r\n\r\nbrowser.useMatchesSelectorPolyfill = !is.function(Element.prototype[browser.prefixedMatchesSelector]);\r\n\r\nmodule.exports = browser;\r\n\r\n},{\"./domObjects\":38,\"./is\":46,\"./window\":52}],38:[function(require,module,exports){\r\n'use strict';\r\n\r\nvar domObjects = {};\r\nvar win = require('./window').window;\r\n\r\nfunction blank() {}\r\n\r\ndomObjects.document = win.document;\r\ndomObjects.DocumentFragment = win.DocumentFragment || blank;\r\ndomObjects.SVGElement = win.SVGElement || blank;\r\ndomObjects.SVGSVGElement = win.SVGSVGElement || blank;\r\ndomObjects.SVGElementInstance = win.SVGElementInstance || blank;\r\ndomObjects.Element = win.Element || blank;\r\ndomObjects.HTMLElement = win.HTMLElement || domObjects.Element;\r\n\r\ndomObjects.Event = win.Event;\r\ndomObjects.Touch = win.Touch || blank;\r\ndomObjects.PointerEvent = win.PointerEvent || win.MSPointerEvent;\r\n\r\nmodule.exports = domObjects;\r\n\r\n},{\"./window\":52}],39:[function(require,module,exports){\r\n'use strict';\r\n\r\nvar win = require('./window');\r\nvar browser = require('./browser');\r\nvar is = require('./is');\r\nvar domObjects = require('./domObjects');\r\n\r\nvar domUtils = {\r\n nodeContains: function nodeContains(parent, child) {\r\n while (child) {\r\n if (child === parent) {\r\n return true;\r\n }\r\n\r\n child = child.parentNode;\r\n }\r\n\r\n return false;\r\n },\r\n\r\n closest: function closest(element, selector) {\r\n while (is.element(element)) {\r\n if (domUtils.matchesSelector(element, selector)) {\r\n return element;\r\n }\r\n\r\n element = domUtils.parentNode(element);\r\n }\r\n\r\n return null;\r\n },\r\n\r\n parentNode: function parentNode(node) {\r\n var parent = node.parentNode;\r\n\r\n if (is.docFrag(parent)) {\r\n // skip past #shado-root fragments\r\n while ((parent = parent.host) && is.docFrag(parent)) {\r\n continue;\r\n }\r\n\r\n return parent;\r\n }\r\n\r\n return parent;\r\n },\r\n\r\n // taken from http://tanalin.com/en/blog/2012/12/matches-selector-ie8/ and modified\r\n matchesSelectorPolyfill: browser.useMatchesSelectorPolyfill ? function (element, selector, elems) {\r\n elems = elems || element.parentNode.querySelectorAll(selector);\r\n\r\n for (var i = 0, len = elems.length; i < len; i++) {\r\n if (elems[i] === element) {\r\n return true;\r\n }\r\n }\r\n\r\n return false;\r\n } : null,\r\n\r\n matchesSelector: function matchesSelector(element, selector, nodeList) {\r\n if (browser.useMatchesSelectorPolyfill) {\r\n return domUtils.matchesSelectorPolyfill(element, selector, nodeList);\r\n }\r\n\r\n // remove /deep/ from selectors if shadowDOM polyfill is used\r\n if (win.window !== win.realWindow) {\r\n selector = selector.replace(/\\/deep\\//g, ' ');\r\n }\r\n\r\n return element[browser.prefixedMatchesSelector](selector);\r\n },\r\n\r\n // Test for the element that's \"above\" all other qualifiers\r\n indexOfDeepestElement: function indexOfDeepestElement(elements) {\r\n var deepestZoneParents = [];\r\n var dropzoneParents = [];\r\n var dropzone = void 0;\r\n var deepestZone = elements[0];\r\n var index = deepestZone ? 0 : -1;\r\n var parent = void 0;\r\n var child = void 0;\r\n var i = void 0;\r\n var n = void 0;\r\n\r\n for (i = 1; i < elements.length; i++) {\r\n dropzone = elements[i];\r\n\r\n // an element might belong to multiple selector dropzones\r\n if (!dropzone || dropzone === deepestZone) {\r\n continue;\r\n }\r\n\r\n if (!deepestZone) {\r\n deepestZone = dropzone;\r\n index = i;\r\n continue;\r\n }\r\n\r\n // check if the deepest or current are document.documentElement or document.rootElement\r\n // - if the current dropzone is, do nothing and continue\r\n if (dropzone.parentNode === dropzone.ownerDocument) {\r\n continue;\r\n }\r\n // - if deepest is, update with the current dropzone and continue to next\r\n else if (deepestZone.parentNode === dropzone.ownerDocument) {\r\n deepestZone = dropzone;\r\n index = i;\r\n continue;\r\n }\r\n\r\n if (!deepestZoneParents.length) {\r\n parent = deepestZone;\r\n while (parent.parentNode && parent.parentNode !== parent.ownerDocument) {\r\n deepestZoneParents.unshift(parent);\r\n parent = parent.parentNode;\r\n }\r\n }\r\n\r\n // if this element is an svg element and the current deepest is\r\n // an HTMLElement\r\n if (deepestZone instanceof domObjects.HTMLElement && dropzone instanceof domObjects.SVGElement && !(dropzone instanceof domObjects.SVGSVGElement)) {\r\n\r\n if (dropzone === deepestZone.parentNode) {\r\n continue;\r\n }\r\n\r\n parent = dropzone.ownerSVGElement;\r\n } else {\r\n parent = dropzone;\r\n }\r\n\r\n dropzoneParents = [];\r\n\r\n while (parent.parentNode !== parent.ownerDocument) {\r\n dropzoneParents.unshift(parent);\r\n parent = parent.parentNode;\r\n }\r\n\r\n n = 0;\r\n\r\n // get (position of last common ancestor) + 1\r\n while (dropzoneParents[n] && dropzoneParents[n] === deepestZoneParents[n]) {\r\n n++;\r\n }\r\n\r\n var parents = [dropzoneParents[n - 1], dropzoneParents[n], deepestZoneParents[n]];\r\n\r\n child = parents[0].lastChild;\r\n\r\n while (child) {\r\n if (child === parents[1]) {\r\n deepestZone = dropzone;\r\n index = i;\r\n deepestZoneParents = [];\r\n\r\n break;\r\n } else if (child === parents[2]) {\r\n break;\r\n }\r\n\r\n child = child.previousSibling;\r\n }\r\n }\r\n\r\n return index;\r\n },\r\n\r\n matchesUpTo: function matchesUpTo(element, selector, limit) {\r\n while (is.element(element)) {\r\n if (domUtils.matchesSelector(element, selector)) {\r\n return true;\r\n }\r\n\r\n element = domUtils.parentNode(element);\r\n\r\n if (element === limit) {\r\n return domUtils.matchesSelector(element, selector);\r\n }\r\n }\r\n\r\n return false;\r\n },\r\n\r\n getActualElement: function getActualElement(element) {\r\n return element instanceof domObjects.SVGElementInstance ? element.correspondingUseElement : element;\r\n },\r\n\r\n getScrollXY: function getScrollXY(relevantWindow) {\r\n relevantWindow = relevantWindow || win.window;\r\n return {\r\n x: relevantWindow.scrollX || relevantWindow.document.documentElement.scrollLeft,\r\n y: relevantWindow.scrollY || relevantWindow.document.documentElement.scrollTop\r\n };\r\n },\r\n\r\n getElementClientRect: function getElementClientRect(element) {\r\n var clientRect = element instanceof domObjects.SVGElement ? element.getBoundingClientRect() : element.getClientRects()[0];\r\n\r\n return clientRect && {\r\n left: clientRect.left,\r\n right: clientRect.right,\r\n top: clientRect.top,\r\n bottom: clientRect.bottom,\r\n width: clientRect.width || clientRect.right - clientRect.left,\r\n height: clientRect.height || clientRect.bottom - clientRect.top\r\n };\r\n },\r\n\r\n getElementRect: function getElementRect(element) {\r\n var clientRect = domUtils.getElementClientRect(element);\r\n\r\n if (!browser.isIOS7 && clientRect) {\r\n var scroll = domUtils.getScrollXY(win.getWindow(element));\r\n\r\n clientRect.left += scroll.x;\r\n clientRect.right += scroll.x;\r\n clientRect.top += scroll.y;\r\n clientRect.bottom += scroll.y;\r\n }\r\n\r\n return clientRect;\r\n },\r\n\r\n getPath: function getPath(element) {\r\n var path = [];\r\n\r\n while (element) {\r\n path.push(element);\r\n element = domUtils.parentNode(element);\r\n }\r\n\r\n return path;\r\n },\r\n\r\n trySelector: function trySelector(value) {\r\n if (!is.string(value)) {\r\n return false;\r\n }\r\n\r\n // an exception will be raised if it is invalid\r\n domObjects.document.querySelector(value);\r\n return true;\r\n }\r\n};\r\n\r\nmodule.exports = domUtils;\r\n\r\n},{\"./browser\":37,\"./domObjects\":38,\"./is\":46,\"./window\":52}],40:[function(require,module,exports){\r\n'use strict';\r\n\r\nvar is = require('./is');\r\nvar domUtils = require('./domUtils');\r\nvar pExtend = require('./pointerExtend');\r\n\r\nvar _require = require('./window'),\r\n window = _require.window,\r\n getWindow = _require.getWindow;\r\n\r\nvar _require2 = require('./arr'),\r\n indexOf = _require2.indexOf,\r\n contains = _require2.contains;\r\n\r\nvar useAttachEvent = 'attachEvent' in window && !('addEventListener' in window);\r\nvar addEvent = useAttachEvent ? 'attachEvent' : 'addEventListener';\r\nvar removeEvent = useAttachEvent ? 'detachEvent' : 'removeEventListener';\r\nvar on = useAttachEvent ? 'on' : '';\r\n\r\nvar elements = [];\r\nvar targets = [];\r\nvar attachedListeners = [];\r\n\r\n// {\r\n// type: {\r\n// selectors: ['selector', ...],\r\n// contexts : [document, ...],\r\n// listeners: [[listener, capture, passive], ...]\r\n// }\r\n// }\r\nvar delegatedEvents = {};\r\n\r\nvar documents = [];\r\n\r\nvar supportsOptions = !useAttachEvent && function () {\r\n var supported = false;\r\n\r\n window.document.createElement('div').addEventListener('test', null, {\r\n get capture() {\r\n supported = true;\r\n }\r\n });\r\n\r\n return supported;\r\n}();\r\n\r\nfunction add(element, type, listener, optionalArg) {\r\n var options = getOptions(optionalArg);\r\n var elementIndex = indexOf(elements, element);\r\n var target = targets[elementIndex];\r\n\r\n if (!target) {\r\n target = {\r\n events: {},\r\n typeCount: 0\r\n };\r\n\r\n elementIndex = elements.push(element) - 1;\r\n targets.push(target);\r\n\r\n attachedListeners.push(useAttachEvent ? {\r\n supplied: [],\r\n wrapped: [],\r\n useCount: []\r\n } : null);\r\n }\r\n\r\n if (!target.events[type]) {\r\n target.events[type] = [];\r\n target.typeCount++;\r\n }\r\n\r\n if (!contains(target.events[type], listener)) {\r\n var ret = void 0;\r\n\r\n if (useAttachEvent) {\r\n var _attachedListeners$el = attachedListeners[elementIndex],\r\n supplied = _attachedListeners$el.supplied,\r\n wrapped = _attachedListeners$el.wrapped,\r\n useCount = _attachedListeners$el.useCount;\r\n\r\n var listenerIndex = indexOf(supplied, listener);\r\n\r\n var wrappedListener = wrapped[listenerIndex] || function (event) {\r\n if (!event.immediatePropagationStopped) {\r\n event.target = event.srcElement;\r\n event.currentTarget = element;\r\n\r\n event.preventDefault = event.preventDefault || preventDef;\r\n event.stopPropagation = event.stopPropagation || stopProp;\r\n event.stopImmediatePropagation = event.stopImmediatePropagation || stopImmProp;\r\n\r\n if (/mouse|click/.test(event.type)) {\r\n event.pageX = event.clientX + getWindow(element).document.documentElement.scrollLeft;\r\n event.pageY = event.clientY + getWindow(element).document.documentElement.scrollTop;\r\n }\r\n\r\n listener(event);\r\n }\r\n };\r\n\r\n ret = element[addEvent](on + type, wrappedListener, !!options.capture);\r\n\r\n if (listenerIndex === -1) {\r\n supplied.push(listener);\r\n wrapped.push(wrappedListener);\r\n useCount.push(1);\r\n } else {\r\n useCount[listenerIndex]++;\r\n }\r\n } else {\r\n ret = element[addEvent](type, listener, supportsOptions ? options : !!options.capture);\r\n }\r\n target.events[type].push(listener);\r\n\r\n return ret;\r\n }\r\n}\r\n\r\nfunction remove(element, type, listener, optionalArg) {\r\n var options = getOptions(optionalArg);\r\n var elementIndex = indexOf(elements, element);\r\n var target = targets[elementIndex];\r\n\r\n if (!target || !target.events) {\r\n return;\r\n }\r\n\r\n var wrappedListener = listener;\r\n var listeners = void 0;\r\n var listenerIndex = void 0;\r\n\r\n if (useAttachEvent) {\r\n listeners = attachedListeners[elementIndex];\r\n listenerIndex = indexOf(listeners.supplied, listener);\r\n wrappedListener = listeners.wrapped[listenerIndex];\r\n }\r\n\r\n if (type === 'all') {\r\n for (type in target.events) {\r\n if (target.events.hasOwnProperty(type)) {\r\n remove(element, type, 'all');\r\n }\r\n }\r\n return;\r\n }\r\n\r\n if (target.events[type]) {\r\n var len = target.events[type].length;\r\n\r\n if (listener === 'all') {\r\n for (var i = 0; i < len; i++) {\r\n remove(element, type, target.events[type][i], options);\r\n }\r\n return;\r\n } else {\r\n for (var _i = 0; _i < len; _i++) {\r\n if (target.events[type][_i] === listener) {\r\n element[removeEvent](on + type, wrappedListener, supportsOptions ? options : !!options.capture);\r\n target.events[type].splice(_i, 1);\r\n\r\n if (useAttachEvent && listeners) {\r\n listeners.useCount[listenerIndex]--;\r\n if (listeners.useCount[listenerIndex] === 0) {\r\n listeners.supplied.splice(listenerIndex, 1);\r\n listeners.wrapped.splice(listenerIndex, 1);\r\n listeners.useCount.splice(listenerIndex, 1);\r\n }\r\n }\r\n\r\n break;\r\n }\r\n }\r\n }\r\n\r\n if (target.events[type] && target.events[type].length === 0) {\r\n target.events[type] = null;\r\n target.typeCount--;\r\n }\r\n }\r\n\r\n if (!target.typeCount) {\r\n targets.splice(elementIndex, 1);\r\n elements.splice(elementIndex, 1);\r\n attachedListeners.splice(elementIndex, 1);\r\n }\r\n}\r\n\r\nfunction addDelegate(selector, context, type, listener, optionalArg) {\r\n var options = getOptions(optionalArg);\r\n if (!delegatedEvents[type]) {\r\n delegatedEvents[type] = {\r\n selectors: [],\r\n contexts: [],\r\n listeners: []\r\n };\r\n\r\n // add delegate listener functions\r\n for (var i = 0; i < documents.length; i++) {\r\n add(documents[i], type, delegateListener);\r\n add(documents[i], type, delegateUseCapture, true);\r\n }\r\n }\r\n\r\n var delegated = delegatedEvents[type];\r\n var index = void 0;\r\n\r\n for (index = delegated.selectors.length - 1; index >= 0; index--) {\r\n if (delegated.selectors[index] === selector && delegated.contexts[index] === context) {\r\n break;\r\n }\r\n }\r\n\r\n if (index === -1) {\r\n index = delegated.selectors.length;\r\n\r\n delegated.selectors.push(selector);\r\n delegated.contexts.push(context);\r\n delegated.listeners.push([]);\r\n }\r\n\r\n // keep listener and capture and passive flags\r\n delegated.listeners[index].push([listener, !!options.capture, options.passive]);\r\n}\r\n\r\nfunction removeDelegate(selector, context, type, listener, optionalArg) {\r\n var options = getOptions(optionalArg);\r\n var delegated = delegatedEvents[type];\r\n var matchFound = false;\r\n var index = void 0;\r\n\r\n if (!delegated) {\r\n return;\r\n }\r\n\r\n // count from last index of delegated to 0\r\n for (index = delegated.selectors.length - 1; index >= 0; index--) {\r\n // look for matching selector and context Node\r\n if (delegated.selectors[index] === selector && delegated.contexts[index] === context) {\r\n\r\n var listeners = delegated.listeners[index];\r\n\r\n // each item of the listeners array is an array: [function, capture, passive]\r\n for (var i = listeners.length - 1; i >= 0; i--) {\r\n var _listeners$i = listeners[i],\r\n fn = _listeners$i[0],\r\n capture = _listeners$i[1],\r\n passive = _listeners$i[2];\r\n\r\n // check if the listener functions and capture and passive flags match\r\n\r\n if (fn === listener && capture === !!options.capture && passive === options.passive) {\r\n // remove the listener from the array of listeners\r\n listeners.splice(i, 1);\r\n\r\n // if all listeners for this interactable have been removed\r\n // remove the interactable from the delegated arrays\r\n if (!listeners.length) {\r\n delegated.selectors.splice(index, 1);\r\n delegated.contexts.splice(index, 1);\r\n delegated.listeners.splice(index, 1);\r\n\r\n // remove delegate function from context\r\n remove(context, type, delegateListener);\r\n remove(context, type, delegateUseCapture, true);\r\n\r\n // remove the arrays if they are empty\r\n if (!delegated.selectors.length) {\r\n delegatedEvents[type] = null;\r\n }\r\n }\r\n\r\n // only remove one listener\r\n matchFound = true;\r\n break;\r\n }\r\n }\r\n\r\n if (matchFound) {\r\n break;\r\n }\r\n }\r\n }\r\n}\r\n\r\n// bound to the interactable context when a DOM event\r\n// listener is added to a selector interactable\r\nfunction delegateListener(event, optionalArg) {\r\n var options = getOptions(optionalArg);\r\n var fakeEvent = {};\r\n var delegated = delegatedEvents[event.type];\r\n var eventTarget = domUtils.getActualElement(event.path ? event.path[0] : event.target);\r\n var element = eventTarget;\r\n\r\n // duplicate the event so that currentTarget can be changed\r\n pExtend(fakeEvent, event);\r\n\r\n fakeEvent.originalEvent = event;\r\n fakeEvent.preventDefault = preventOriginalDefault;\r\n\r\n // climb up document tree looking for selector matches\r\n while (is.element(element)) {\r\n for (var i = 0; i < delegated.selectors.length; i++) {\r\n var selector = delegated.selectors[i];\r\n var context = delegated.contexts[i];\r\n\r\n if (domUtils.matchesSelector(element, selector) && domUtils.nodeContains(context, eventTarget) && domUtils.nodeContains(context, element)) {\r\n\r\n var listeners = delegated.listeners[i];\r\n\r\n fakeEvent.currentTarget = element;\r\n\r\n for (var j = 0; j < listeners.length; j++) {\r\n var _listeners$j = listeners[j],\r\n fn = _listeners$j[0],\r\n capture = _listeners$j[1],\r\n passive = _listeners$j[2];\r\n\r\n\r\n if (capture === !!options.capture && passive === options.passive) {\r\n fn(fakeEvent);\r\n }\r\n }\r\n }\r\n }\r\n\r\n element = domUtils.parentNode(element);\r\n }\r\n}\r\n\r\nfunction delegateUseCapture(event) {\r\n return delegateListener.call(this, event, true);\r\n}\r\n\r\nfunction preventDef() {\r\n this.returnValue = false;\r\n}\r\n\r\nfunction preventOriginalDefault() {\r\n this.originalEvent.preventDefault();\r\n}\r\n\r\nfunction stopProp() {\r\n this.cancelBubble = true;\r\n}\r\n\r\nfunction stopImmProp() {\r\n this.cancelBubble = true;\r\n this.immediatePropagationStopped = true;\r\n}\r\n\r\nfunction getOptions(param) {\r\n return is.object(param) ? param : { capture: param };\r\n}\r\n\r\nmodule.exports = {\r\n add: add,\r\n remove: remove,\r\n\r\n addDelegate: addDelegate,\r\n removeDelegate: removeDelegate,\r\n\r\n delegateListener: delegateListener,\r\n delegateUseCapture: delegateUseCapture,\r\n delegatedEvents: delegatedEvents,\r\n documents: documents,\r\n\r\n useAttachEvent: useAttachEvent,\r\n supportsOptions: supportsOptions,\r\n\r\n _elements: elements,\r\n _targets: targets,\r\n _attachedListeners: attachedListeners\r\n};\r\n\r\n},{\"./arr\":36,\"./domUtils\":39,\"./is\":46,\"./pointerExtend\":48,\"./window\":52}],41:[function(require,module,exports){\r\n\"use strict\";\r\n\r\nmodule.exports = function extend(dest, source) {\r\n for (var prop in source) {\r\n dest[prop] = source[prop];\r\n }\r\n return dest;\r\n};\r\n\r\n},{}],42:[function(require,module,exports){\r\n'use strict';\r\n\r\nvar _require = require('./rect'),\r\n resolveRectLike = _require.resolveRectLike,\r\n rectToXY = _require.rectToXY;\r\n\r\nmodule.exports = function (target, element, action) {\r\n var actionOptions = target.options[action];\r\n var actionOrigin = actionOptions && actionOptions.origin;\r\n var origin = actionOrigin || target.options.origin;\r\n\r\n var originRect = resolveRectLike(origin, target, element, [target && element]);\r\n\r\n return rectToXY(originRect) || { x: 0, y: 0 };\r\n};\r\n\r\n},{\"./rect\":51}],43:[function(require,module,exports){\r\n\"use strict\";\r\n\r\nmodule.exports = function (x, y) {\r\n return Math.sqrt(x * x + y * y);\r\n};\r\n\r\n},{}],44:[function(require,module,exports){\r\n'use strict';\r\n\r\nvar extend = require('./extend');\r\nvar win = require('./window');\r\n\r\nvar utils = {\r\n warnOnce: function warnOnce(method, message) {\r\n var warned = false;\r\n\r\n return function () {\r\n if (!warned) {\r\n win.window.console.warn(message);\r\n warned = true;\r\n }\r\n\r\n return method.apply(this, arguments);\r\n };\r\n },\r\n\r\n // http://stackoverflow.com/a/5634528/2280888\r\n _getQBezierValue: function _getQBezierValue(t, p1, p2, p3) {\r\n var iT = 1 - t;\r\n return iT * iT * p1 + 2 * iT * t * p2 + t * t * p3;\r\n },\r\n\r\n getQuadraticCurvePoint: function getQuadraticCurvePoint(startX, startY, cpX, cpY, endX, endY, position) {\r\n return {\r\n x: utils._getQBezierValue(position, startX, cpX, endX),\r\n y: utils._getQBezierValue(position, startY, cpY, endY)\r\n };\r\n },\r\n\r\n // http://gizma.com/easing/\r\n easeOutQuad: function easeOutQuad(t, b, c, d) {\r\n t /= d;\r\n return -c * t * (t - 2) + b;\r\n },\r\n\r\n copyAction: function copyAction(dest, src) {\r\n dest.name = src.name;\r\n dest.axis = src.axis;\r\n dest.edges = src.edges;\r\n\r\n return dest;\r\n },\r\n\r\n is: require('./is'),\r\n extend: extend,\r\n hypot: require('./hypot'),\r\n getOriginXY: require('./getOriginXY')\r\n};\r\n\r\nextend(utils, require('./arr'));\r\nextend(utils, require('./domUtils'));\r\nextend(utils, require('./pointerUtils'));\r\nextend(utils, require('./rect'));\r\n\r\nmodule.exports = utils;\r\n\r\n},{\"./arr\":36,\"./domUtils\":39,\"./extend\":41,\"./getOriginXY\":42,\"./hypot\":43,\"./is\":46,\"./pointerUtils\":49,\"./rect\":51,\"./window\":52}],45:[function(require,module,exports){\r\n'use strict';\r\n\r\nvar scope = require('../scope');\r\nvar utils = require('./index');\r\n\r\nvar finder = {\r\n methodOrder: ['simulationResume', 'mouseOrPen', 'hasPointer', 'idle'],\r\n\r\n search: function search(pointer, eventType, eventTarget) {\r\n var pointerType = utils.getPointerType(pointer);\r\n var pointerId = utils.getPointerId(pointer);\r\n var details = { pointer: pointer, pointerId: pointerId, pointerType: pointerType, eventType: eventType, eventTarget: eventTarget };\r\n\r\n for (var _iterator = finder.methodOrder, _isArray = Array.isArray(_iterator), _i = 0, _iterator = _isArray ? _iterator : _iterator[Symbol.iterator]();;) {\r\n var _ref;\r\n\r\n if (_isArray) {\r\n if (_i >= _iterator.length) break;\r\n _ref = _iterator[_i++];\r\n } else {\r\n _i = _iterator.next();\r\n if (_i.done) break;\r\n _ref = _i.value;\r\n }\r\n\r\n var method = _ref;\r\n\r\n var interaction = finder[method](details);\r\n\r\n if (interaction) {\r\n return interaction;\r\n }\r\n }\r\n },\r\n\r\n // try to resume simulation with a new pointer\r\n simulationResume: function simulationResume(_ref2) {\r\n var pointerType = _ref2.pointerType,\r\n eventType = _ref2.eventType,\r\n eventTarget = _ref2.eventTarget;\r\n\r\n if (!/down|start/i.test(eventType)) {\r\n return null;\r\n }\r\n\r\n for (var _iterator2 = scope.interactions, _isArray2 = Array.isArray(_iterator2), _i2 = 0, _iterator2 = _isArray2 ? _iterator2 : _iterator2[Symbol.iterator]();;) {\r\n var _ref3;\r\n\r\n if (_isArray2) {\r\n if (_i2 >= _iterator2.length) break;\r\n _ref3 = _iterator2[_i2++];\r\n } else {\r\n _i2 = _iterator2.next();\r\n if (_i2.done) break;\r\n _ref3 = _i2.value;\r\n }\r\n\r\n var interaction = _ref3;\r\n\r\n var element = eventTarget;\r\n\r\n if (interaction.simulation && interaction.simulation.allowResume && interaction.pointerType === pointerType) {\r\n while (element) {\r\n // if the element is the interaction element\r\n if (element === interaction.element) {\r\n return interaction;\r\n }\r\n element = utils.parentNode(element);\r\n }\r\n }\r\n }\r\n\r\n return null;\r\n },\r\n\r\n // if it's a mouse or pen interaction\r\n mouseOrPen: function mouseOrPen(_ref4) {\r\n var pointerId = _ref4.pointerId,\r\n pointerType = _ref4.pointerType,\r\n eventType = _ref4.eventType;\r\n\r\n if (pointerType !== 'mouse' && pointerType !== 'pen') {\r\n return null;\r\n }\r\n\r\n var firstNonActive = void 0;\r\n\r\n for (var _iterator3 = scope.interactions, _isArray3 = Array.isArray(_iterator3), _i3 = 0, _iterator3 = _isArray3 ? _iterator3 : _iterator3[Symbol.iterator]();;) {\r\n var _ref5;\r\n\r\n if (_isArray3) {\r\n if (_i3 >= _iterator3.length) break;\r\n _ref5 = _iterator3[_i3++];\r\n } else {\r\n _i3 = _iterator3.next();\r\n if (_i3.done) break;\r\n _ref5 = _i3.value;\r\n }\r\n\r\n var interaction = _ref5;\r\n\r\n if (interaction.pointerType === pointerType) {\r\n // if it's a down event, skip interactions with running simulations\r\n if (interaction.simulation && !utils.contains(interaction.pointerIds, pointerId)) {\r\n continue;\r\n }\r\n\r\n // if the interaction is active, return it immediately\r\n if (interaction.interacting()) {\r\n return interaction;\r\n }\r\n // otherwise save it and look for another active interaction\r\n else if (!firstNonActive) {\r\n firstNonActive = interaction;\r\n }\r\n }\r\n }\r\n\r\n // if no active mouse interaction was found use the first inactive mouse\r\n // interaction\r\n if (firstNonActive) {\r\n return firstNonActive;\r\n }\r\n\r\n // find any mouse or pen interaction.\r\n // ignore the interaction if the eventType is a *down, and a simulation\r\n // is active\r\n for (var _iterator4 = scope.interactions, _isArray4 = Array.isArray(_iterator4), _i4 = 0, _iterator4 = _isArray4 ? _iterator4 : _iterator4[Symbol.iterator]();;) {\r\n var _ref6;\r\n\r\n if (_isArray4) {\r\n if (_i4 >= _iterator4.length) break;\r\n _ref6 = _iterator4[_i4++];\r\n } else {\r\n _i4 = _iterator4.next();\r\n if (_i4.done) break;\r\n _ref6 = _i4.value;\r\n }\r\n\r\n var _interaction = _ref6;\r\n\r\n if (_interaction.pointerType === pointerType && !(/down/i.test(eventType) && _interaction.simulation)) {\r\n return _interaction;\r\n }\r\n }\r\n\r\n return null;\r\n },\r\n\r\n // get interaction that has this pointer\r\n hasPointer: function hasPointer(_ref7) {\r\n var pointerId = _ref7.pointerId;\r\n\r\n for (var _iterator5 = scope.interactions, _isArray5 = Array.isArray(_iterator5), _i5 = 0, _iterator5 = _isArray5 ? _iterator5 : _iterator5[Symbol.iterator]();;) {\r\n var _ref8;\r\n\r\n if (_isArray5) {\r\n if (_i5 >= _iterator5.length) break;\r\n _ref8 = _iterator5[_i5++];\r\n } else {\r\n _i5 = _iterator5.next();\r\n if (_i5.done) break;\r\n _ref8 = _i5.value;\r\n }\r\n\r\n var interaction = _ref8;\r\n\r\n if (utils.contains(interaction.pointerIds, pointerId)) {\r\n return interaction;\r\n }\r\n }\r\n },\r\n\r\n // get first idle interaction with a matching pointerType\r\n idle: function idle(_ref9) {\r\n var pointerType = _ref9.pointerType;\r\n\r\n for (var _iterator6 = scope.interactions, _isArray6 = Array.isArray(_iterator6), _i6 = 0, _iterator6 = _isArray6 ? _iterator6 : _iterator6[Symbol.iterator]();;) {\r\n var _ref10;\r\n\r\n if (_isArray6) {\r\n if (_i6 >= _iterator6.length) break;\r\n _ref10 = _iterator6[_i6++];\r\n } else {\r\n _i6 = _iterator6.next();\r\n if (_i6.done) break;\r\n _ref10 = _i6.value;\r\n }\r\n\r\n var interaction = _ref10;\r\n\r\n // if there's already a pointer held down\r\n if (interaction.pointerIds.length === 1) {\r\n var target = interaction.target;\r\n // don't add this pointer if there is a target interactable and it\r\n // isn't gesturable\r\n if (target && !target.options.gesture.enabled) {\r\n continue;\r\n }\r\n }\r\n // maximum of 2 pointers per interaction\r\n else if (interaction.pointerIds.length >= 2) {\r\n continue;\r\n }\r\n\r\n if (!interaction.interacting() && pointerType === interaction.pointerType) {\r\n return interaction;\r\n }\r\n }\r\n\r\n return null;\r\n }\r\n};\r\n\r\nmodule.exports = finder;\r\n\r\n},{\"../scope\":34,\"./index\":44}],46:[function(require,module,exports){\r\n'use strict';\r\n\r\nvar _typeof = typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; };\r\n\r\nvar win = require('./window');\r\nvar isWindow = require('./isWindow');\r\n\r\nvar is = {\r\n array: function array() {},\r\n\r\n window: function window(thing) {\r\n return thing === win.window || isWindow(thing);\r\n },\r\n\r\n docFrag: function docFrag(thing) {\r\n return is.object(thing) && thing.nodeType === 11;\r\n },\r\n\r\n object: function object(thing) {\r\n return !!thing && (typeof thing === 'undefined' ? 'undefined' : _typeof(thing)) === 'object';\r\n },\r\n\r\n function: function _function(thing) {\r\n return typeof thing === 'function';\r\n },\r\n\r\n number: function number(thing) {\r\n return typeof thing === 'number';\r\n },\r\n\r\n bool: function bool(thing) {\r\n return typeof thing === 'boolean';\r\n },\r\n\r\n string: function string(thing) {\r\n return typeof thing === 'string';\r\n },\r\n\r\n element: function element(thing) {\r\n if (!thing || (typeof thing === 'undefined' ? 'undefined' : _typeof(thing)) !== 'object') {\r\n return false;\r\n }\r\n\r\n var _window = win.getWindow(thing) || win.window;\r\n\r\n return (/object|function/.test(_typeof(_window.Element)) ? thing instanceof _window.Element //DOM2\r\n : thing.nodeType === 1 && typeof thing.nodeName === 'string'\r\n );\r\n }\r\n};\r\n\r\nis.array = function (thing) {\r\n return is.object(thing) && typeof thing.length !== 'undefined' && is.function(thing.splice);\r\n};\r\n\r\nmodule.exports = is;\r\n\r\n},{\"./isWindow\":47,\"./window\":52}],47:[function(require,module,exports){\r\n\"use strict\";\r\n\r\nmodule.exports = function (thing) {\r\n return !!(thing && thing.Window) && thing instanceof thing.Window;\r\n};\r\n\r\n},{}],48:[function(require,module,exports){\r\n'use strict';\r\n\r\nfunction pointerExtend(dest, source) {\r\n for (var prop in source) {\r\n var prefixedPropREs = module.exports.prefixedPropREs;\r\n var deprecated = false;\r\n\r\n // skip deprecated prefixed properties\r\n for (var vendor in prefixedPropREs) {\r\n if (prop.indexOf(vendor) === 0 && prefixedPropREs[vendor].test(prop)) {\r\n deprecated = true;\r\n break;\r\n }\r\n }\r\n\r\n if (!deprecated && typeof source[prop] !== 'function') {\r\n dest[prop] = source[prop];\r\n }\r\n }\r\n return dest;\r\n}\r\n\r\npointerExtend.prefixedPropREs = {\r\n webkit: /(Movement[XY]|Radius[XY]|RotationAngle|Force)$/\r\n};\r\n\r\nmodule.exports = pointerExtend;\r\n\r\n},{}],49:[function(require,module,exports){\r\n'use strict';\r\n\r\nvar hypot = require('./hypot');\r\nvar browser = require('./browser');\r\nvar dom = require('./domObjects');\r\nvar domUtils = require('./domUtils');\r\nvar domObjects = require('./domObjects');\r\nvar is = require('./is');\r\nvar pointerExtend = require('./pointerExtend');\r\n\r\nvar pointerUtils = {\r\n copyCoords: function copyCoords(dest, src) {\r\n dest.page = dest.page || {};\r\n dest.page.x = src.page.x;\r\n dest.page.y = src.page.y;\r\n\r\n dest.client = dest.client || {};\r\n dest.client.x = src.client.x;\r\n dest.client.y = src.client.y;\r\n\r\n dest.timeStamp = src.timeStamp;\r\n },\r\n\r\n setCoordDeltas: function setCoordDeltas(targetObj, prev, cur) {\r\n targetObj.page.x = cur.page.x - prev.page.x;\r\n targetObj.page.y = cur.page.y - prev.page.y;\r\n targetObj.client.x = cur.client.x - prev.client.x;\r\n targetObj.client.y = cur.client.y - prev.client.y;\r\n targetObj.timeStamp = cur.timeStamp - prev.timeStamp;\r\n\r\n // set pointer velocity\r\n var dt = Math.max(targetObj.timeStamp / 1000, 0.001);\r\n\r\n targetObj.page.speed = hypot(targetObj.page.x, targetObj.page.y) / dt;\r\n targetObj.page.vx = targetObj.page.x / dt;\r\n targetObj.page.vy = targetObj.page.y / dt;\r\n\r\n targetObj.client.speed = hypot(targetObj.client.x, targetObj.page.y) / dt;\r\n targetObj.client.vx = targetObj.client.x / dt;\r\n targetObj.client.vy = targetObj.client.y / dt;\r\n },\r\n\r\n isNativePointer: function isNativePointer(pointer) {\r\n return pointer instanceof dom.Event || pointer instanceof dom.Touch;\r\n },\r\n\r\n // Get specified X/Y coords for mouse or event.touches[0]\r\n getXY: function getXY(type, pointer, xy) {\r\n xy = xy || {};\r\n type = type || 'page';\r\n\r\n xy.x = pointer[type + 'X'];\r\n xy.y = pointer[type + 'Y'];\r\n\r\n return xy;\r\n },\r\n\r\n getPageXY: function getPageXY(pointer, page) {\r\n page = page || {};\r\n\r\n // Opera Mobile handles the viewport and scrolling oddly\r\n if (browser.isOperaMobile && pointerUtils.isNativePointer(pointer)) {\r\n pointerUtils.getXY('screen', pointer, page);\r\n\r\n page.x += window.scrollX;\r\n page.y += window.scrollY;\r\n } else {\r\n pointerUtils.getXY('page', pointer, page);\r\n }\r\n\r\n return page;\r\n },\r\n\r\n getClientXY: function getClientXY(pointer, client) {\r\n client = client || {};\r\n\r\n if (browser.isOperaMobile && pointerUtils.isNativePointer(pointer)) {\r\n // Opera Mobile handles the viewport and scrolling oddly\r\n pointerUtils.getXY('screen', pointer, client);\r\n } else {\r\n pointerUtils.getXY('client', pointer, client);\r\n }\r\n\r\n return client;\r\n },\r\n\r\n getPointerId: function getPointerId(pointer) {\r\n return is.number(pointer.pointerId) ? pointer.pointerId : pointer.identifier;\r\n },\r\n\r\n setCoords: function setCoords(targetObj, pointers, timeStamp) {\r\n var pointer = pointers.length > 1 ? pointerUtils.pointerAverage(pointers) : pointers[0];\r\n\r\n var tmpXY = {};\r\n\r\n pointerUtils.getPageXY(pointer, tmpXY);\r\n targetObj.page.x = tmpXY.x;\r\n targetObj.page.y = tmpXY.y;\r\n\r\n pointerUtils.getClientXY(pointer, tmpXY);\r\n targetObj.client.x = tmpXY.x;\r\n targetObj.client.y = tmpXY.y;\r\n\r\n targetObj.timeStamp = is.number(timeStamp) ? timeStamp : new Date().getTime();\r\n },\r\n\r\n pointerExtend: pointerExtend,\r\n\r\n getTouchPair: function getTouchPair(event) {\r\n var touches = [];\r\n\r\n // array of touches is supplied\r\n if (is.array(event)) {\r\n touches[0] = event[0];\r\n touches[1] = event[1];\r\n }\r\n // an event\r\n else {\r\n if (event.type === 'touchend') {\r\n if (event.touches.length === 1) {\r\n touches[0] = event.touches[0];\r\n touches[1] = event.changedTouches[0];\r\n } else if (event.touches.length === 0) {\r\n touches[0] = event.changedTouches[0];\r\n touches[1] = event.changedTouches[1];\r\n }\r\n } else {\r\n touches[0] = event.touches[0];\r\n touches[1] = event.touches[1];\r\n }\r\n }\r\n\r\n return touches;\r\n },\r\n\r\n pointerAverage: function pointerAverage(pointers) {\r\n var average = {\r\n pageX: 0,\r\n pageY: 0,\r\n clientX: 0,\r\n clientY: 0,\r\n screenX: 0,\r\n screenY: 0\r\n };\r\n\r\n for (var _iterator = pointers, _isArray = Array.isArray(_iterator), _i = 0, _iterator = _isArray ? _iterator : _iterator[Symbol.iterator]();;) {\r\n var _ref;\r\n\r\n if (_isArray) {\r\n if (_i >= _iterator.length) break;\r\n _ref = _iterator[_i++];\r\n } else {\r\n _i = _iterator.next();\r\n if (_i.done) break;\r\n _ref = _i.value;\r\n }\r\n\r\n var pointer = _ref;\r\n\r\n for (var _prop in average) {\r\n average[_prop] += pointer[_prop];\r\n }\r\n }\r\n for (var prop in average) {\r\n average[prop] /= pointers.length;\r\n }\r\n\r\n return average;\r\n },\r\n\r\n touchBBox: function touchBBox(event) {\r\n if (!event.length && !(event.touches && event.touches.length > 1)) {\r\n return;\r\n }\r\n\r\n var touches = pointerUtils.getTouchPair(event);\r\n var minX = Math.min(touches[0].pageX, touches[1].pageX);\r\n var minY = Math.min(touches[0].pageY, touches[1].pageY);\r\n var maxX = Math.max(touches[0].pageX, touches[1].pageX);\r\n var maxY = Math.max(touches[0].pageY, touches[1].pageY);\r\n\r\n return {\r\n x: minX,\r\n y: minY,\r\n left: minX,\r\n top: minY,\r\n width: maxX - minX,\r\n height: maxY - minY\r\n };\r\n },\r\n\r\n touchDistance: function touchDistance(event, deltaSource) {\r\n var sourceX = deltaSource + 'X';\r\n var sourceY = deltaSource + 'Y';\r\n var touches = pointerUtils.getTouchPair(event);\r\n\r\n var dx = touches[0][sourceX] - touches[1][sourceX];\r\n var dy = touches[0][sourceY] - touches[1][sourceY];\r\n\r\n return hypot(dx, dy);\r\n },\r\n\r\n touchAngle: function touchAngle(event, prevAngle, deltaSource) {\r\n var sourceX = deltaSource + 'X';\r\n var sourceY = deltaSource + 'Y';\r\n var touches = pointerUtils.getTouchPair(event);\r\n var dx = touches[1][sourceX] - touches[0][sourceX];\r\n var dy = touches[1][sourceY] - touches[0][sourceY];\r\n var angle = 180 * Math.atan2(dy, dx) / Math.PI;\r\n\r\n return angle;\r\n },\r\n\r\n getPointerType: function getPointerType(pointer) {\r\n return is.string(pointer.pointerType) ? pointer.pointerType : is.number(pointer.pointerType) ? [undefined, undefined, 'touch', 'pen', 'mouse'][pointer.pointerType]\r\n // if the PointerEvent API isn't available, then the \"pointer\" must\r\n // be either a MouseEvent, TouchEvent, or Touch object\r\n : /touch/.test(pointer.type) || pointer instanceof domObjects.Touch ? 'touch' : 'mouse';\r\n },\r\n\r\n // [ event.target, event.currentTarget ]\r\n getEventTargets: function getEventTargets(event) {\r\n return [domUtils.getActualElement(event.path ? event.path[0] : event.target), domUtils.getActualElement(event.currentTarget)];\r\n }\r\n};\r\n\r\nmodule.exports = pointerUtils;\r\n\r\n},{\"./browser\":37,\"./domObjects\":38,\"./domUtils\":39,\"./hypot\":43,\"./is\":46,\"./pointerExtend\":48}],50:[function(require,module,exports){\r\n'use strict';\r\n\r\nvar _require = require('./window'),\r\n window = _require.window;\r\n\r\nvar vendors = ['ms', 'moz', 'webkit', 'o'];\r\nvar lastTime = 0;\r\nvar request = void 0;\r\nvar cancel = void 0;\r\n\r\nfor (var x = 0; x < vendors.length && !window.requestAnimationFrame; x++) {\r\n request = window[vendors[x] + 'RequestAnimationFrame'];\r\n cancel = window[vendors[x] + 'CancelAnimationFrame'] || window[vendors[x] + 'CancelRequestAnimationFrame'];\r\n}\r\n\r\nif (!request) {\r\n request = function request(callback) {\r\n var currTime = new Date().getTime();\r\n var timeToCall = Math.max(0, 16 - (currTime - lastTime));\r\n var id = setTimeout(function () {\r\n callback(currTime + timeToCall);\r\n }, timeToCall);\r\n\r\n lastTime = currTime + timeToCall;\r\n return id;\r\n };\r\n}\r\n\r\nif (!cancel) {\r\n cancel = function cancel(id) {\r\n clearTimeout(id);\r\n };\r\n}\r\n\r\nmodule.exports = {\r\n request: request,\r\n cancel: cancel\r\n};\r\n\r\n},{\"./window\":52}],51:[function(require,module,exports){\r\n'use strict';\r\n\r\nvar extend = require('./extend');\r\nvar is = require('./is');\r\n\r\nvar _require = require('./domUtils'),\r\n closest = _require.closest,\r\n parentNode = _require.parentNode,\r\n getElementRect = _require.getElementRect;\r\n\r\nvar rectUtils = {\r\n getStringOptionResult: function getStringOptionResult(value, interactable, element) {\r\n if (!is.string(value)) {\r\n return null;\r\n }\r\n\r\n if (value === 'parent') {\r\n value = parentNode(element);\r\n } else if (value === 'self') {\r\n value = interactable.getRect(element);\r\n } else {\r\n value = closest(element, value);\r\n }\r\n\r\n return value;\r\n },\r\n\r\n resolveRectLike: function resolveRectLike(value, interactable, element, functionArgs) {\r\n value = rectUtils.getStringOptionResult(value, interactable, element) || value;\r\n\r\n if (is.function(value)) {\r\n value = value.apply(null, functionArgs);\r\n }\r\n\r\n if (is.element(value)) {\r\n value = getElementRect(value);\r\n }\r\n\r\n return value;\r\n },\r\n\r\n rectToXY: function rectToXY(rect) {\r\n return rect && {\r\n x: 'x' in rect ? rect.x : rect.left,\r\n y: 'y' in rect ? rect.y : rect.top\r\n };\r\n },\r\n\r\n xywhToTlbr: function xywhToTlbr(rect) {\r\n if (rect && !('left' in rect && 'top' in rect)) {\r\n rect = extend({}, rect);\r\n\r\n rect.left = rect.x || 0;\r\n rect.top = rect.y || 0;\r\n rect.right = rect.right || rect.left + rect.width;\r\n rect.bottom = rect.bottom || rect.top + rect.height;\r\n }\r\n\r\n return rect;\r\n },\r\n\r\n tlbrToXywh: function tlbrToXywh(rect) {\r\n if (rect && !('x' in rect && 'y' in rect)) {\r\n rect = extend({}, rect);\r\n\r\n rect.x = rect.left || 0;\r\n rect.top = rect.top || 0;\r\n rect.width = rect.width || rect.right - rect.x;\r\n rect.height = rect.height || rect.bottom - rect.y;\r\n }\r\n\r\n return rect;\r\n }\r\n};\r\n\r\nmodule.exports = rectUtils;\r\n\r\n},{\"./domUtils\":39,\"./extend\":41,\"./is\":46}],52:[function(require,module,exports){\r\n'use strict';\r\n\r\nvar win = module.exports;\r\nvar isWindow = require('./isWindow');\r\n\r\nfunction init(window) {\r\n // get wrapped window if using Shadow DOM polyfill\r\n\r\n win.realWindow = window;\r\n\r\n // create a TextNode\r\n var el = window.document.createTextNode('');\r\n\r\n // check if it's wrapped by a polyfill\r\n if (el.ownerDocument !== window.document && typeof window.wrap === 'function' && window.wrap(el) === el) {\r\n // use wrapped window\r\n window = window.wrap(window);\r\n }\r\n\r\n win.window = window;\r\n}\r\n\r\nif (typeof window === 'undefined') {\r\n win.window = undefined;\r\n win.realWindow = undefined;\r\n} else {\r\n init(window);\r\n}\r\n\r\nwin.getWindow = function getWindow(node) {\r\n if (isWindow(node)) {\r\n return node;\r\n }\r\n\r\n var rootNode = node.ownerDocument || node;\r\n\r\n return rootNode.defaultView || rootNode.parentWindow || win.window;\r\n};\r\n\r\nwin.init = init;\r\n\r\n},{\"./isWindow\":47}]},{},[1])(1)\r\n});\r\n\r\n\r\n//# sourceMappingURL=interact.js.map\r\n\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack:///./node_modules/interactjs/dist/interact.js?bbfe"],"names":[],"mappings":"YAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa,SAA2D,mBAAmB,gDAAgD,aAAa,KAAK,MAAM,gCAAgC,SAAS,qCAAqC,SAAS,mCAAmC,OAAO,KAAK,OAAO,kBAAkB,aAAa,0BAA0B,0BAA0B,gBAAgB,UAAU,UAAU,0CAA0C,8BAAwB,oBAAoB,8CAA8C,kCAAkC,YAAY,YAAY,mCAAmC,iBAAiB,gBAAgB,sBAAsB,oBAAoB,0CAA0C,YAAY,WAAW,YAAY,SAAS,GAAG;AAC5yB;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,CAAC;AACD;AACA;;AAEA,CAAC,EAAE,yCAAyC;AAC5C;;AAEA,iDAAiD,0CAA0C,0DAA0D,EAAE;;AAEvJ;AACA;;AAEA;;AAEA;AACA,yCAAyC,+CAA+C;AACxF;AACA;AACA;;AAEA;AACA;AACA;;AAEA,4BAA4B,eAAe;AAC3C;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA,CAAC;;AAED;;AAEA,CAAC,EAAE,wCAAwC;AAC3C;;AAEA,iDAAiD,0CAA0C,0DAA0D,EAAE;;AAEvJ;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA,wBAAwB;AACxB,0BAA0B;;AAE1B;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA,CAAC;;AAED;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA,CAAC;;AAED;;AAEA;;AAEA,CAAC,EAAE,wFAAwF;AAC3F;;AAEA,iDAAiD,0CAA0C,0DAA0D,EAAE;;AAEvJ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;;;AAGA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,KAAK;;AAEL;;AAEA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kFAAkF;;AAElF;AACA;AACA;AACA,SAAS;AACT;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AAGA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AAGA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA,wJAAwJ;AACxJ;;AAEA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,uDAAuD,aAAa;AACpE;AACA;AACA;AACA;AACA;;;AAGA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,yFAAyF;AACzF;AACA;;;AAGA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AAGA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AAGA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA,qBAAqB,sBAAsB;AAC3C;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AAGA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AAGA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AAGA;AACA;AACA;AACA;;AAEA,4BAA4B;;AAE5B,8BAA8B;;AAE9B;AACA;;AAEA,0CAA0C;;AAE1C;;AAEA;AACA;;AAEA,6KAA6K;AAC7K;;AAEA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;;AAEA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,KAAK;;AAEL;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AAGA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,KAAK;AACL;AACA;;AAEA,2BAA2B,qBAAqB;;AAEhD;;AAEA;AACA,yKAAyK;AACzK;;AAEA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA,CAAC;;AAED;AACA;;AAEA,iBAAiB,iBAAiB;AAClC;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA,iBAAiB,iBAAiB;AAClC;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;;AAEA;;AAEA,CAAC,EAAE,mOAAmO;AACtO;;AAEA,iDAAiD,0CAA0C,0DAA0D,EAAE;;AAEvJ;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA,uBAAuB;AACvB,wBAAwB;;AAExB,qBAAqB;AACrB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,aAAa,aAAa;AAC1B,eAAe,aAAa;AAC5B;AACA;AACA;AACA;AACA,aAAa,aAAa;AAC1B,eAAe,aAAa;AAC5B;AACA;;AAEA;AACA;AACA,aAAa,aAAa;AAC1B,eAAe,aAAa;AAC5B;AACA;;AAEA;AACA;AACA,aAAa,qCAAqC;AAClD,eAAe,qCAAqC;AACpD;AACA;;AAEA,0BAA0B;AAC1B;;AAEA;AACA;;AAEA,0BAA0B;;AAE1B;AACA;AACA;;AAEA;;AAEA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,6CAA6C,qBAAqB;AAClE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ;AACR;AACA;AACA;AACA;AACA;AACA,8BAA8B,eAAe;AAC7C;AACA;AACA;AACA,MAAM;AACN;;;AAGA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA,KAAK;AACL;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,yCAAyC,QAAQ,eAAe;AAChE;AACA;AACA;AACA,QAAQ;AACR;;;AAGA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK,iBAAiB;;AAEtB;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;;;AAGA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;;AAEL;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ;AACR;;;AAGA;AACA;;AAEA;AACA;AACA;AACA;AACA,OAAO;AACP;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA,0BAA0B,oBAAoB;;AAE9C;AACA,mCAAmC,oBAAoB;AACvD,kDAAkD,oBAAoB;AACtE;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;;AAEA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,KAAK;;AAEL;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA,CAAC;;AAED,yCAAyC,SAAS;AAClD;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA,qBAAqB;;AAErB;AACA;;AAEA,sBAAsB,kCAAkC;AACxD;AACA;;AAEA,+DAA+D,2BAA2B;AAC1F;AACA,KAAK;AACL;;AAEA;AACA;AACA,yBAAyB,oDAAoD;AAC7E;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA,0CAA0C,2BAA2B;AACrE;;AAEA;AACA;AACA;;AAEA,iJAAiJ;AACjJ;;AAEA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA,mBAAmB,iCAAiC;AACpD;;AAEA;AACA,4BAA4B,yCAAyC;AACrE;AACA;;AAEA,iBAAiB;AACjB;;AAEA;AACA;AACA;AACA;AACA;AACA,CAAC;AACD;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA,CAAC;;AAED;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;;AAEA,CAAC,EAAE,+IAA+I;AAClJ;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA,CAAC;;AAED;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA,CAAC;;AAED;AACA;AACA;;AAEA;AACA,CAAC;;AAED;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;;AAEA,CAAC,EAAE,wCAAwC;AAC3C;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,GAAG;;AAEH;AACA;;AAEA,kCAAkC,sGAAsG;AACxI,GAAG;;AAEH;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,CAAC;;AAED;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA,CAAC;;AAED;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,mCAAmC;AACnC,mCAAmC;AACnC,mCAAmC;AACnC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;;AAEA,CAAC,EAAE,4GAA4G;AAC/G;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,CAAC;;AAED;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA,CAAC;;AAED;AACA;;AAEA;AACA;AACA;;AAEA;AACA,CAAC;;AAED;AACA;;AAEA;AACA;AACA;AACA,CAAC;;AAED;AACA;;AAEA;AACA,CAAC;;AAED;AACA;AACA;;AAEA;;AAEA;AACA,0JAA0J;AAC1J;;AAEA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA,mBAAmB,yBAAyB;AAC5C;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA,iBAAiB,8CAA8C;AAC/D;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA,iBAAiB,8CAA8C;AAC/D;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA,iBAAiB,8CAA8C;AAC/D;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,uCAAuC,oBAAoB;;AAE3D;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA,oCAAoC,eAAe;;AAEnD;AACA;AACA;AACA;AACA,wCAAwC,uBAAuB;;AAE/D;AACA;AACA;AACA;AACA,0CAA0C,yBAAyB;;AAEnE;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;;AAEL;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,4CAA4C;AAC5C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA,CAAC;;AAED;;AAEA;AACA,gCAAgC;AAChC,iCAAiC;AACjC,oCAAoC;AACpC,qCAAqC;AACrC,gCAAgC;;AAEhC;AACA;AACA;AACA;AACA;AACA,CAAC;;AAED;AACA;;AAEA;AACA,CAAC;;AAED;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;;AAEA,CAAC,EAAE,2IAA2I;AAC9I;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;AACA,cAAc;AACd;;AAEA;AACA,GAAG;;AAEH;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,CAAC;;AAED;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA,CAAC;;AAED;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,mCAAmC;AACnC,mCAAmC;AACnC,mCAAmC;AACnC;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,CAAC;;AAED;AACA;AACA,YAAY,aAAa;;AAEzB;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA,CAAC;;AAED;AACA;AACA;AACA;;AAEA;;AAEA;;AAEA,CAAC,EAAE,4GAA4G;AAC/G;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;AACA;AACA;;AAEA,8BAA8B;AAC9B;;AAEA;AACA;AACA,yBAAyB;;AAEzB;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,GAAG;;AAEH;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;AACA;AACA,KAAK;AACL;AACA;;AAEA,qBAAqB,OAAO;AAC5B;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,qCAAqC;;AAErC;AACA;AACA;AACA;;AAEA;AACA,GAAG;AACH;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA,4BAA4B;AAC5B,6BAA6B;AAC7B,6BAA6B;AAC7B;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,CAAC;;AAED;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA,KAAK;AACL;AACA,KAAK;AACL;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA,CAAC;;AAED;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,mCAAmC;AACnC,mCAAmC;AACnC,mCAAmC;AACnC;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,KAAK;AACL;AACA;;AAEA;AACA;AACA,KAAK;AACL;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,CAAC;;AAED;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,GAAG;AACH;;AAEA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,CAAC;;AAED;AACA;AACA;AACA;;AAEA;;AAEA;;AAEA,CAAC,EAAE,kIAAkI;AACrI;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA,GAAG;;AAEH;AACA;AACA;AACA,GAAG;;AAEH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;;AAEA;AACA,GAAG;AACH;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA,CAAC;;AAED;;AAEA;;AAEA;;AAEA,CAAC,EAAE,mHAAmH;AACtH;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,sBAAsB,mDAAmD;AACzE;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,sBAAsB,oDAAoD;AAC1E;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA,GAAG;AACH;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA,GAAG;AACH;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,uBAAuB;AACvB;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA,oJAAoJ;AACpJ;;AAEA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;;AAEA,CAAC,EAAE,gFAAgF;AACnF;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA,CAAC;;AAED;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA,CAAC;;AAED;AACA;AACA;;;AAGA;AACA;AACA;;AAEA;;AAEA;;AAEA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,CAAC;;AAED;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA,uCAAuC,SAAS;AAChD;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA,4BAA4B,2BAA2B;AACvD;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA;AACA,CAAC;;AAED;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,uBAAuB;AACvB;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;;AAEA,oJAAoJ;AACpJ;;AAEA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA,kDAAkD,SAAS;AAC3D;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;;AAEA,CAAC,EAAE,sMAAsM;AACzM;;AAEA;AACA;;AAEA;AACA;AACA,CAAC;;AAED;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA,KAAK;AACL;AACA,CAAC;;AAED;AACA;AACA;;AAEA;AACA;AACA;AACA,CAAC;;AAED;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA,CAAC;;AAED,CAAC,EAAE,+BAA+B;AAClC;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,CAAC;;AAED;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA,CAAC,EAAE,4GAA4G;AAC/G;;AAEA;;AAEA,CAAC,EAAE,mCAAmC;AACtC;;AAEA;;AAEA,CAAC,EAAE,mCAAmC;AACtC;;AAEA;AACA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA,aAAa,aAAa;;AAE1B;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,CAAC,GAAG;AACJ;;AAEA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA,CAAC,EAAE,sgBAAsgB;AACzgB;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA,gBAAgB;;AAEhB;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,CAAC;;AAED;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA,yBAAyB;AACzB;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA,CAAC;;AAED;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA,4BAA4B;AAC5B;;AAEA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;;AAEA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;;AAEA;AACA;;AAEA;;AAEA;;AAEA;AACA;;AAEA;AACA,GAAG;AACH;AACA;AACA;;AAEA;;AAEA;AACA;AACA,CAAC;;AAED;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA,CAAC;;AAED;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;;AAEA;AACA;AACA;AACA,KAAK;AACL;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA,GAAG;AACH;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA,GAAG;AACH;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;;AAEA,CAAC,EAAE,qFAAqF;AACxF;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ;AACR;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,6IAA6I;AAC7I;;AAEA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA,kDAAkD,mBAAmB;AACrE;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,qJAAqJ;AACrJ;;AAEA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA,GAAG;AACH;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,6CAA6C,QAAQ;AACrD;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;;AAEA;;AAEA,CAAC,EAAE,wGAAwG;AAC3G;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AAGA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA,gBAAgB,kBAAkB;AAClC;AACA;AACA;;AAEA;AACA;AACA,0JAA0J;AAC1J;;AAEA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;;AAEA;;;AAGA;;AAEA;AACA;AACA;AACA;AACA;;AAEA,CAAC,EAAE,4GAA4G;AAC/G;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;;AAEA;AACA;AACA,2JAA2J;AAC3J;;AAEA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA,CAAC,EAAE,mIAAmI;AACtI;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;;AAEA;AACA;AACA;;AAEA,mBAAmB,4BAA4B;AAC/C;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA,GAAG;;AAEH;AACA;AACA;AACA;AACA;;AAEA,0BAA0B;AAC1B;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,wJAAwJ;AACxJ;;AAEA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA,GAAG;;AAEH;AACA,gKAAgK;AAChK;;AAEA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;;AAEA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA,GAAG;;AAEH;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA,8BAA8B;AAC9B;AACA;AACA;;AAEA;AACA,6BAA6B;AAC7B;AACA,2DAA2D;AAC3D;AACA,CAAC;;AAED;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;AACA;AACA;AACA;;AAEA;AACA,CAAC;;AAED;AACA;AACA;;AAEA,iBAAiB,4BAA4B;AAC7C;;AAEA;AACA;AACA;AACA,0BAA0B,6BAA6B;AACvD;AACA;AACA;AACA,CAAC;;AAED;AACA;AACA;;AAEA,6BAA6B;;AAE7B,iBAAiB,4BAA4B;AAC7C;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;;AAEA;AACA;AACA,CAAC;;AAED;AACA;AACA;;AAEA;;AAEA,CAAC,EAAE,6DAA6D;AAChE;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA,KAAK;AACL;AACA;;AAEA;AACA,GAAG;;AAEH;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA,qCAAqC,2BAA2B,kBAAkB;;AAElF;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA,GAAG;;AAEH;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;;AAEA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;;AAEA,CAAC,EAAE,kDAAkD;AACrD;;AAEA;AACA;AACA;AACA;AACA,aAAa,wBAAwB;AACrC;AACA,eAAe,+CAA+C;AAC9D,eAAe,+CAA+C;AAC9D,MAAM;AACN,IAAI;;AAEJ;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA,eAAe;AACf,eAAe;;AAEf;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;AACA;AACA;;AAEA;AACA,4BAA4B;AAC5B;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,GAAG;;AAEH;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA,qCAAqC,2BAA2B,kBAAkB;AAClF;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA,GAAG;;AAEH;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;;AAEA,CAAC,EAAE,4GAA4G;AAC/G;;AAEA;AACA;AACA;AACA;AACA,aAAa,wBAAwB;AACrC;AACA,aAAa,4BAA4B;AACzC,aAAa,4BAA4B;AACzC,MAAM;AACN,IAAI;;AAEJ;AACA;AACA;AACA;AACA;AACA;;AAEA,aAAa;AACb,aAAa;;AAEb;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;;AAEA;AACA,GAAG;;AAEH;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,4BAA4B;AAC5B,4BAA4B;AAC5B;;AAEA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;;AAEA;AACA,GAAG;;AAEH;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;;AAEA,CAAC,EAAE,iHAAiH;AACpH;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,GAAG;;AAEH;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;;AAEA,kDAAkD;AAClD;;AAEA;AACA,iKAAiK;AACjK;;AAEA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA,SAAS;AACT;AACA,KAAK;AACL;AACA;;AAEA;AACA,GAAG;;AAEH;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA,cAAc;AACd,KAAK;AACL;;AAEA,4BAA4B;;AAE5B;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA,wJAAwJ;AACxJ;;AAEA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA,kKAAkK;AAClK;;AAEA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA,SAAS;AACT;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA,SAAS;AACT;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,qCAAqC,SAAS;AAC9C;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA,KAAK;AACL;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA,GAAG;;AAEH;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;;AAEA,CAAC,EAAE,mEAAmE;AACtE;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,OAAO;AACP,eAAe,aAAa;AAC5B;AACA;AACA;;AAEA;AACA;;AAEA;AACA,GAAG;;AAEH;AACA;AACA;AACA;AACA;;AAEA,8BAA8B;AAC9B;AACA;;AAEA,iCAAiC;AACjC;;AAEA,wJAAwJ;AACxJ;;AAEA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;;AAEA;;AAEA;;AAEA;AACA;AACA,OAAO;AACP;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA,GAAG;;AAEH;AACA;;;AAGA,iCAAiC;AACjC;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;;AAEA,CAAC,EAAE,sFAAsF;AACzF;;AAEA,iDAAiD,0CAA0C,0DAA0D,EAAE;;AAEvJ;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA,KAAK;AACL;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA,CAAC;;AAED,CAAC,EAAE,2BAA2B;AAC9B;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb,GAAG;AACH;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,iBAAiB,oBAAoB;AACrC;;AAEA,uCAAuC;AACvC;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;;AAEL;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,2IAA2I;AAC3I;;AAEA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;;AAEA;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,KAAK;AACL;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA,0CAA0C;AAC1C,CAAC;;AAED;AACA;AACA;;AAEA;AACA,CAAC;;AAED;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,KAAK;AACL;AACA,CAAC;;AAED;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,iDAAiD;;AAEjD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,mJAAmJ;AACnJ;;AAEA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;;AAEA;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA,iBAAiB,8BAA8B;AAC/C;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL,GAAG;AACH,CAAC;;AAED;AACA;AACA;AACA;AACA;;AAEA;AACA,UAAU,kGAAkG;AAC5G;AACA,CAAC;;AAED;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,GAAG;AACH,CAAC;;AAED;AACA;AACA;AACA;AACA;AACA;;AAEA,UAAU,iGAAiG;AAC3G;AACA;;AAEA,eAAe,0BAA0B;AACzC;AACA;;AAEA;AACA,6BAA6B;AAC7B,0BAA0B;AAC1B,8BAA8B,MAAM,oBAAoB;AACxD,CAAC;;AAED;AACA;;AAEA,CAAC,EAAE,0IAA0I;AAC7I;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA,gBAAgB,kBAAkB;AAClC;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL,GAAG;AACH;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA,CAAC,EAAE,+BAA+B;AAClC;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA;AACA,gBAAgB;AAChB,OAAO;AACP;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,gBAAgB;AAChB,OAAO;AACP;AACA;;AAEA;AACA,CAAC;;AAED;AACA;;AAEA;AACA;AACA;AACA,CAAC;;AAED;AACA;AACA;;AAEA;AACA;AACA,CAAC;;AAED;;AAEA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA,CAAC,EAAE,mJAAmJ;AACtJ;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA,kCAAkC,qBAAqB;AACvD,GAAG;;AAEH;AACA;;AAEA;;AAEA;;AAEA;AACA;;AAEA,qCAAqC,qBAAqB;AAC1D,GAAG;;AAEH;AACA;AACA;AACA;;AAEA;;AAEA,CAAC,EAAE,8EAA8E;AACjF;;AAEA,iDAAiD,0CAA0C,0DAA0D,EAAE;;AAEvJ;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA,mBAAmB,4BAA4B;AAC/C;AACA;AACA;AACA;AACA;;AAEA;AACA,CAAC;;AAED;AACA;AACA;;AAEA;;AAEA,CAAC,EAAE,WAAW;AACd;;AAEA;AACA,qCAAqC,SAAS;AAC9C;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA,iBAAiB,mBAAmB;AACpC;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA,iBAAiB,kBAAkB;AACnC;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA,CAAC,GAAG;AACJ;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;;AAEA;;AAEA;;AAEA;;AAEA,CAAC,EAAE,0CAA0C;AAC7C;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA,CAAC,EAAE,cAAc;AACjB;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA,GAAG;;AAEH;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA,GAAG;;AAEH;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA,GAAG;;AAEH;AACA;AACA;;AAEA,uCAAuC,SAAS;AAChD;AACA;AACA;AACA;;AAEA;AACA,GAAG;;AAEH;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA,GAAG;;AAEH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,eAAe,qBAAqB;AACpC;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA,OAAO;AACP;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA,SAAS;AACT;AACA;;AAEA;AACA;AACA;;AAEA;AACA,GAAG;;AAEH;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA,GAAG;;AAEH;AACA;AACA,GAAG;;AAEH;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA,GAAG;;AAEH;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA,GAAG;;AAEH;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;AAEA,CAAC,EAAE,yDAAyD;AAC5D;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA,CAAC;;AAED;AACA;AACA;AACA;;AAEA;AACA;AACA,gBAAgB;AAChB;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,KAAK;AACL;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA,KAAK;AACL;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA,qBAAqB,SAAS;AAC9B;AACA;AACA;AACA,KAAK;AACL,sBAAsB,UAAU;AAChC;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,mBAAmB,sBAAsB;AACzC;AACA;AACA;AACA;;AAEA;AACA;;AAEA,8CAA8C,YAAY;AAC1D;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA,8CAA8C,YAAY;AAC1D;AACA;;AAEA;;AAEA;AACA,wCAAwC,QAAQ;AAChD;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA,mBAAmB,gCAAgC;AACnD;AACA;;AAEA;;AAEA;;AAEA;;AAEA,uBAAuB,sBAAsB;AAC7C;AACA;AACA;AACA;;;AAGA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA,qCAAqC;AACrC;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA,CAAC,EAAE,wEAAwE;AAC3E;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA,CAAC,GAAG;AACJ;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA,kCAAkC;AAClC;;AAEA,CAAC,EAAE,YAAY;AACf;;AAEA;AACA;AACA;;AAEA,CAAC,GAAG;AACJ;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,GAAG;;AAEH;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;AACA;AACA;;AAEA;AACA,GAAG;;AAEH;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA,CAAC,EAAE,iIAAiI;AACpI;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,mBAAmB;;AAEnB,2JAA2J;AAC3J;;AAEA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;;AAEA;;AAEA;;AAEA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA,mKAAmK;AACnK;;AAEA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;;AAEA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,GAAG;;AAEH;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA,mKAAmK;AACnK;;AAEA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,mKAAmK;AACnK;;AAEA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA,GAAG;;AAEH;AACA;AACA;;AAEA,mKAAmK;AACnK;;AAEA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;AACA;;AAEA,mKAAmK;AACnK;;AAEA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA,CAAC,EAAE,2BAA2B;AAC9B;;AAEA,oGAAoG,mBAAmB,EAAE,mBAAmB,8HAA8H;;AAE1Q;AACA;;AAEA;AACA,4BAA4B;;AAE5B;AACA;AACA,GAAG;;AAEH;AACA;AACA,GAAG;;AAEH;AACA;AACA,GAAG;;AAEH;AACA;AACA,GAAG;;AAEH;AACA;AACA,GAAG;;AAEH;AACA;AACA,GAAG;;AAEH;AACA;AACA,GAAG;;AAEH;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA,CAAC,EAAE,8BAA8B;AACjC;;AAEA;AACA;AACA;;AAEA,CAAC,GAAG;AACJ;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA,CAAC,GAAG;AACJ;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA,GAAG;;AAEH;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA,GAAG;;AAEH;AACA;AACA,GAAG;;AAEH;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA,GAAG;;AAEH;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA,KAAK;AACL;AACA;;AAEA;AACA,GAAG;;AAEH;AACA;;AAEA;AACA;AACA;AACA,KAAK;AACL;AACA;;AAEA;AACA,GAAG;;AAEH;AACA;AACA,GAAG;;AAEH;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA,GAAG;;AAEH;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW;AACX;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;;AAEA;AACA,GAAG;;AAEH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,iJAAiJ;AACjJ;;AAEA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,GAAG;;AAEH;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA,GAAG;;AAEH;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,GAAG;;AAEH;AACA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;AACA;AACA;AACA;;AAEA;;AAEA,CAAC,EAAE,6FAA6F;AAChG;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA,eAAe,qDAAqD;AACpE;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;;AAEL;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA,CAAC,EAAE,cAAc;AACjB;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,KAAK;AACL;AACA,KAAK;AACL;AACA;;AAEA;AACA,GAAG;;AAEH;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA,GAAG;;AAEH;AACA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;AACA,sBAAsB;;AAEtB;AACA;AACA;AACA;AACA;;AAEA;AACA,GAAG;;AAEH;AACA;AACA,sBAAsB;;AAEtB;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA,CAAC,EAAE,wCAAwC;AAC3C;;AAEA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,CAAC;AACD;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;;AAEA,CAAC,EAAE,gBAAgB,EAAE,GAAG;AACxB,CAAC;;;AAGD","file":"15.js","sourcesContent":["/**\r\n * interact.js v1.3.0-alpha.4+sha.7970416-dirty\r\n *\r\n * Copyright (c) 2012-2017 Taye Adeyemi <dev@taye.me>\r\n * Open source under the MIT License.\r\n * https://raw.github.com/taye/interact.js/master/LICENSE\r\n */\r\n(function(f){if(typeof exports===\"object\"&&typeof module!==\"undefined\"){module.exports=f()}else if(typeof define===\"function\"&&define.amd){define([],f)}else{var g;if(typeof window!==\"undefined\"){g=window}else if(typeof global!==\"undefined\"){g=global}else if(typeof self!==\"undefined\"){g=self}else{g=this}g.interact = f()}})(function(){var define,module,exports;return (function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require==\"function\"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error(\"Cannot find module '\"+o+\"'\");throw f.code=\"MODULE_NOT_FOUND\",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require==\"function\"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})({1:[function(require,module,exports){\r\n'use strict';\r\n\r\n/*\r\n * In a (windowless) server environment this file exports a factory function\r\n * that takes the window to use.\r\n *\r\n *     var interact = require('interact.js')(windowObject);\r\n *\r\n * See https://github.com/taye/interact.js/issues/187\r\n */\r\nif (typeof window === 'undefined') {\r\n  module.exports = function (window) {\r\n    require('./src/utils/window').init(window);\r\n\r\n    return require('./src/index');\r\n  };\r\n} else {\r\n  module.exports = require('./src/index');\r\n}\r\n\r\n},{\"./src/index\":19,\"./src/utils/window\":52}],2:[function(require,module,exports){\r\n'use strict';\r\n\r\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\r\n\r\nvar _require = require('./utils/arr'),\r\n    indexOf = _require.indexOf;\r\n\r\nvar extend = require('./utils/extend.js');\r\n\r\nfunction fireUntilImmediateStopped(event, listeners) {\r\n  for (var i = 0, len = listeners.length; i < len && !event.immediatePropagationStopped; i++) {\r\n    listeners[i](event);\r\n  }\r\n}\r\n\r\nvar Eventable = function () {\r\n  function Eventable(options) {\r\n    _classCallCheck(this, Eventable);\r\n\r\n    this.options = extend({}, options || {});\r\n  }\r\n\r\n  Eventable.prototype.fire = function fire(event) {\r\n    var listeners = void 0;\r\n    var onEvent = 'on' + event.type;\r\n    var global = this.global;\r\n\r\n    // Interactable#on() listeners\r\n    if (listeners = this[event.type]) {\r\n      fireUntilImmediateStopped(event, listeners);\r\n    }\r\n\r\n    // interactable.onevent listener\r\n    if (this[onEvent]) {\r\n      this[onEvent](event);\r\n    }\r\n\r\n    // interact.on() listeners\r\n    if (!event.propagationStopped && global && (listeners = global[event.type])) {\r\n      fireUntilImmediateStopped(event, listeners);\r\n    }\r\n  };\r\n\r\n  Eventable.prototype.on = function on(eventType, listener) {\r\n    // if this type of event was never bound\r\n    if (this[eventType]) {\r\n      this[eventType].push(listener);\r\n    } else {\r\n      this[eventType] = [listener];\r\n    }\r\n  };\r\n\r\n  Eventable.prototype.off = function off(eventType, listener) {\r\n    // if it is an action event type\r\n    var eventList = this[eventType];\r\n    var index = eventList ? indexOf(eventList, listener) : -1;\r\n\r\n    if (index !== -1) {\r\n      eventList.splice(index, 1);\r\n    }\r\n\r\n    if (eventList && eventList.length === 0 || !listener) {\r\n      this[eventType] = listener;\r\n    }\r\n  };\r\n\r\n  return Eventable;\r\n}();\r\n\r\nmodule.exports = Eventable;\r\n\r\n},{\"./utils/arr\":36,\"./utils/extend.js\":41}],3:[function(require,module,exports){\r\n'use strict';\r\n\r\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\r\n\r\nvar extend = require('./utils/extend');\r\nvar getOriginXY = require('./utils/getOriginXY');\r\nvar defaults = require('./defaultOptions');\r\nvar signals = require('./utils/Signals').new();\r\n\r\nvar InteractEvent = function () {\r\n  function InteractEvent(interaction, event, action, phase, element, related) {\r\n    var preEnd = arguments.length > 6 && arguments[6] !== undefined ? arguments[6] : false;\r\n\r\n    _classCallCheck(this, InteractEvent);\r\n\r\n    var target = interaction.target;\r\n    var deltaSource = (target && target.options || defaults).deltaSource;\r\n    var origin = getOriginXY(target, element, action);\r\n    var starting = phase === 'start';\r\n    var ending = phase === 'end';\r\n    var coords = starting ? interaction.startCoords : interaction.curCoords;\r\n    var prevEvent = interaction.prevEvent;\r\n\r\n    element = element || interaction.element;\r\n\r\n    var page = extend({}, coords.page);\r\n    var client = extend({}, coords.client);\r\n\r\n    page.x -= origin.x;\r\n    page.y -= origin.y;\r\n\r\n    client.x -= origin.x;\r\n    client.y -= origin.y;\r\n\r\n    this.ctrlKey = event.ctrlKey;\r\n    this.altKey = event.altKey;\r\n    this.shiftKey = event.shiftKey;\r\n    this.metaKey = event.metaKey;\r\n    this.button = event.button;\r\n    this.buttons = event.buttons;\r\n    this.target = element;\r\n    this.currentTarget = element;\r\n    this.relatedTarget = related || null;\r\n    this.preEnd = preEnd;\r\n    this.type = action + (phase || '');\r\n    this.interaction = interaction;\r\n    this.interactable = target;\r\n\r\n    this.t0 = starting ? interaction.downTimes[interaction.downTimes.length - 1] : prevEvent.t0;\r\n\r\n    var signalArg = {\r\n      interaction: interaction,\r\n      event: event,\r\n      action: action,\r\n      phase: phase,\r\n      element: element,\r\n      related: related,\r\n      page: page,\r\n      client: client,\r\n      coords: coords,\r\n      starting: starting,\r\n      ending: ending,\r\n      deltaSource: deltaSource,\r\n      iEvent: this\r\n    };\r\n\r\n    signals.fire('set-xy', signalArg);\r\n\r\n    if (ending) {\r\n      // use previous coords when ending\r\n      this.pageX = prevEvent.pageX;\r\n      this.pageY = prevEvent.pageY;\r\n      this.clientX = prevEvent.clientX;\r\n      this.clientY = prevEvent.clientY;\r\n    } else {\r\n      this.pageX = page.x;\r\n      this.pageY = page.y;\r\n      this.clientX = client.x;\r\n      this.clientY = client.y;\r\n    }\r\n\r\n    this.x0 = interaction.startCoords.page.x - origin.x;\r\n    this.y0 = interaction.startCoords.page.y - origin.y;\r\n    this.clientX0 = interaction.startCoords.client.x - origin.x;\r\n    this.clientY0 = interaction.startCoords.client.y - origin.y;\r\n\r\n    signals.fire('set-delta', signalArg);\r\n\r\n    this.timeStamp = coords.timeStamp;\r\n    this.dt = interaction.pointerDelta.timeStamp;\r\n    this.duration = this.timeStamp - this.t0;\r\n\r\n    // speed and velocity in pixels per second\r\n    this.speed = interaction.pointerDelta[deltaSource].speed;\r\n    this.velocityX = interaction.pointerDelta[deltaSource].vx;\r\n    this.velocityY = interaction.pointerDelta[deltaSource].vy;\r\n\r\n    this.swipe = ending || phase === 'inertiastart' ? this.getSwipe() : null;\r\n\r\n    signals.fire('new', signalArg);\r\n  }\r\n\r\n  InteractEvent.prototype.getSwipe = function getSwipe() {\r\n    var interaction = this.interaction;\r\n\r\n    if (interaction.prevEvent.speed < 600 || this.timeStamp - interaction.prevEvent.timeStamp > 150) {\r\n      return null;\r\n    }\r\n\r\n    var angle = 180 * Math.atan2(interaction.prevEvent.velocityY, interaction.prevEvent.velocityX) / Math.PI;\r\n    var overlap = 22.5;\r\n\r\n    if (angle < 0) {\r\n      angle += 360;\r\n    }\r\n\r\n    var left = 135 - overlap <= angle && angle < 225 + overlap;\r\n    var up = 225 - overlap <= angle && angle < 315 + overlap;\r\n\r\n    var right = !left && (315 - overlap <= angle || angle < 45 + overlap);\r\n    var down = !up && 45 - overlap <= angle && angle < 135 + overlap;\r\n\r\n    return {\r\n      up: up,\r\n      down: down,\r\n      left: left,\r\n      right: right,\r\n      angle: angle,\r\n      speed: interaction.prevEvent.speed,\r\n      velocity: {\r\n        x: interaction.prevEvent.velocityX,\r\n        y: interaction.prevEvent.velocityY\r\n      }\r\n    };\r\n  };\r\n\r\n  InteractEvent.prototype.preventDefault = function preventDefault() {};\r\n\r\n  InteractEvent.prototype.stopImmediatePropagation = function stopImmediatePropagation() {\r\n    this.immediatePropagationStopped = this.propagationStopped = true;\r\n  };\r\n\r\n  InteractEvent.prototype.stopPropagation = function stopPropagation() {\r\n    this.propagationStopped = true;\r\n  };\r\n\r\n  return InteractEvent;\r\n}();\r\n\r\nsignals.on('set-delta', function (_ref) {\r\n  var iEvent = _ref.iEvent,\r\n      interaction = _ref.interaction,\r\n      starting = _ref.starting,\r\n      deltaSource = _ref.deltaSource;\r\n\r\n  var prevEvent = starting ? iEvent : interaction.prevEvent;\r\n\r\n  if (deltaSource === 'client') {\r\n    iEvent.dx = iEvent.clientX - prevEvent.clientX;\r\n    iEvent.dy = iEvent.clientY - prevEvent.clientY;\r\n  } else {\r\n    iEvent.dx = iEvent.pageX - prevEvent.pageX;\r\n    iEvent.dy = iEvent.pageY - prevEvent.pageY;\r\n  }\r\n});\r\n\r\nInteractEvent.signals = signals;\r\n\r\nmodule.exports = InteractEvent;\r\n\r\n},{\"./defaultOptions\":18,\"./utils/Signals\":35,\"./utils/extend\":41,\"./utils/getOriginXY\":42}],4:[function(require,module,exports){\r\n'use strict';\r\n\r\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\r\n\r\nvar is = require('./utils/is');\r\nvar events = require('./utils/events');\r\nvar extend = require('./utils/extend');\r\nvar actions = require('./actions/base');\r\nvar scope = require('./scope');\r\nvar Eventable = require('./Eventable');\r\nvar defaults = require('./defaultOptions');\r\nvar signals = require('./utils/Signals').new();\r\n\r\nvar _require = require('./utils/domUtils'),\r\n    getElementRect = _require.getElementRect,\r\n    nodeContains = _require.nodeContains,\r\n    trySelector = _require.trySelector;\r\n\r\nvar _require2 = require('./utils/window'),\r\n    getWindow = _require2.getWindow;\r\n\r\nvar _require3 = require('./utils/arr'),\r\n    indexOf = _require3.indexOf,\r\n    contains = _require3.contains;\r\n\r\nvar _require4 = require('./utils/browser'),\r\n    wheelEvent = _require4.wheelEvent;\r\n\r\n// all set interactables\r\n\r\n\r\nscope.interactables = [];\r\n\r\n/*\\\r\n * Interactable\r\n [ property ]\r\n **\r\n * Object type returned by @interact\r\n\\*/\r\n\r\nvar Interactable = function () {\r\n  function Interactable(target, options) {\r\n    _classCallCheck(this, Interactable);\r\n\r\n    options = options || {};\r\n\r\n    this.target = target;\r\n    this.events = new Eventable();\r\n    this._context = options.context || scope.document;\r\n    this._win = getWindow(trySelector(target) ? this._context : target);\r\n    this._doc = this._win.document;\r\n\r\n    signals.fire('new', {\r\n      target: target,\r\n      options: options,\r\n      interactable: this,\r\n      win: this._win\r\n    });\r\n\r\n    scope.addDocument(this._doc, this._win);\r\n\r\n    scope.interactables.push(this);\r\n\r\n    this.set(options);\r\n  }\r\n\r\n  Interactable.prototype.setOnEvents = function setOnEvents(action, phases) {\r\n    var onAction = 'on' + action;\r\n\r\n    if (is.function(phases.onstart)) {\r\n      this.events[onAction + 'start'] = phases.onstart;\r\n    }\r\n    if (is.function(phases.onmove)) {\r\n      this.events[onAction + 'move'] = phases.onmove;\r\n    }\r\n    if (is.function(phases.onend)) {\r\n      this.events[onAction + 'end'] = phases.onend;\r\n    }\r\n    if (is.function(phases.oninertiastart)) {\r\n      this.events[onAction + 'inertiastart'] = phases.oninertiastart;\r\n    }\r\n\r\n    return this;\r\n  };\r\n\r\n  Interactable.prototype.setPerAction = function setPerAction(action, options) {\r\n    // for all the default per-action options\r\n    for (var option in options) {\r\n      // if this option exists for this action\r\n      if (option in defaults[action]) {\r\n        // if the option in the options arg is an object value\r\n        if (is.object(options[option])) {\r\n          // duplicate the object\r\n          this.options[action][option] = extend(this.options[action][option] || {}, options[option]);\r\n\r\n          if (is.object(defaults.perAction[option]) && 'enabled' in defaults.perAction[option]) {\r\n            this.options[action][option].enabled = options[option].enabled === false ? false : true;\r\n          }\r\n        } else if (is.bool(options[option]) && is.object(defaults.perAction[option])) {\r\n          this.options[action][option].enabled = options[option];\r\n        } else if (options[option] !== undefined) {\r\n          // or if it's not undefined, do a plain assignment\r\n          this.options[action][option] = options[option];\r\n        }\r\n      }\r\n    }\r\n  };\r\n\r\n  /*\\\r\n   * Interactable.getRect\r\n   [ method ]\r\n   *\r\n   * The default function to get an Interactables bounding rect. Can be\r\n   * overridden using @Interactable.rectChecker.\r\n   *\r\n   - element (Element) #optional The element to measure.\r\n   = (object) The object's bounding rectangle.\r\n   o {\r\n   o     top   : 0,\r\n   o     left  : 0,\r\n   o     bottom: 0,\r\n   o     right : 0,\r\n   o     width : 0,\r\n   o     height: 0\r\n   o }\r\n  \\*/\r\n\r\n\r\n  Interactable.prototype.getRect = function getRect(element) {\r\n    element = element || this.target;\r\n\r\n    if (is.string(this.target) && !is.element(element)) {\r\n      element = this._context.querySelector(this.target);\r\n    }\r\n\r\n    return getElementRect(element);\r\n  };\r\n\r\n  /*\\\r\n   * Interactable.rectChecker\r\n   [ method ]\r\n   *\r\n   * Returns or sets the function used to calculate the interactable's\r\n   * element's rectangle\r\n   *\r\n   - checker (function) #optional A function which returns this Interactable's bounding rectangle. See @Interactable.getRect\r\n   = (function | object) The checker function or this Interactable\r\n  \\*/\r\n\r\n\r\n  Interactable.prototype.rectChecker = function rectChecker(checker) {\r\n    if (is.function(checker)) {\r\n      this.getRect = checker;\r\n\r\n      return this;\r\n    }\r\n\r\n    if (checker === null) {\r\n      delete this.options.getRect;\r\n\r\n      return this;\r\n    }\r\n\r\n    return this.getRect;\r\n  };\r\n\r\n  Interactable.prototype._backCompatOption = function _backCompatOption(optionName, newValue) {\r\n    if (trySelector(newValue) || is.object(newValue)) {\r\n      this.options[optionName] = newValue;\r\n\r\n      for (var _iterator = actions.names, _isArray = Array.isArray(_iterator), _i = 0, _iterator = _isArray ? _iterator : _iterator[Symbol.iterator]();;) {\r\n        var _ref;\r\n\r\n        if (_isArray) {\r\n          if (_i >= _iterator.length) break;\r\n          _ref = _iterator[_i++];\r\n        } else {\r\n          _i = _iterator.next();\r\n          if (_i.done) break;\r\n          _ref = _i.value;\r\n        }\r\n\r\n        var action = _ref;\r\n\r\n        this.options[action][optionName] = newValue;\r\n      }\r\n\r\n      return this;\r\n    }\r\n\r\n    return this.options[optionName];\r\n  };\r\n\r\n  /*\\\r\n   * Interactable.origin\r\n   [ method ]\r\n   *\r\n   * Gets or sets the origin of the Interactable's element.  The x and y\r\n   * of the origin will be subtracted from action event coordinates.\r\n   *\r\n   - origin (object | string) #optional An object eg. { x: 0, y: 0 } or string 'parent', 'self' or any CSS selector\r\n   * OR\r\n   - origin (Element) #optional An HTML or SVG Element whose rect will be used\r\n   **\r\n   = (object) The current origin or this Interactable\r\n  \\*/\r\n\r\n\r\n  Interactable.prototype.origin = function origin(newValue) {\r\n    return this._backCompatOption('origin', newValue);\r\n  };\r\n\r\n  /*\\\r\n   * Interactable.deltaSource\r\n   [ method ]\r\n   *\r\n   * Returns or sets the mouse coordinate types used to calculate the\r\n   * movement of the pointer.\r\n   *\r\n   - newValue (string) #optional Use 'client' if you will be scrolling while interacting; Use 'page' if you want autoScroll to work\r\n   = (string | object) The current deltaSource or this Interactable\r\n  \\*/\r\n\r\n\r\n  Interactable.prototype.deltaSource = function deltaSource(newValue) {\r\n    if (newValue === 'page' || newValue === 'client') {\r\n      this.options.deltaSource = newValue;\r\n\r\n      return this;\r\n    }\r\n\r\n    return this.options.deltaSource;\r\n  };\r\n\r\n  /*\\\r\n   * Interactable.context\r\n   [ method ]\r\n   *\r\n   * Gets the selector context Node of the Interactable. The default is `window.document`.\r\n   *\r\n   = (Node) The context Node of this Interactable\r\n   **\r\n  \\*/\r\n\r\n\r\n  Interactable.prototype.context = function context() {\r\n    return this._context;\r\n  };\r\n\r\n  Interactable.prototype.inContext = function inContext(element) {\r\n    return this._context === element.ownerDocument || nodeContains(this._context, element);\r\n  };\r\n\r\n  /*\\\r\n   * Interactable.fire\r\n   [ method ]\r\n   *\r\n   * Calls listeners for the given InteractEvent type bound globally\r\n   * and directly to this Interactable\r\n   *\r\n   - iEvent (InteractEvent) The InteractEvent object to be fired on this Interactable\r\n   = (Interactable) this Interactable\r\n  \\*/\r\n\r\n\r\n  Interactable.prototype.fire = function fire(iEvent) {\r\n    this.events.fire(iEvent);\r\n\r\n    return this;\r\n  };\r\n\r\n  Interactable.prototype._onOffMultiple = function _onOffMultiple(method, eventType, listener, options) {\r\n    if (is.string(eventType) && eventType.search(' ') !== -1) {\r\n      eventType = eventType.trim().split(/ +/);\r\n    }\r\n\r\n    if (is.array(eventType)) {\r\n      for (var i = 0; i < eventType.length; i++) {\r\n        this[method](eventType[i], listener, options);\r\n      }\r\n\r\n      return true;\r\n    }\r\n\r\n    if (is.object(eventType)) {\r\n      for (var prop in eventType) {\r\n        this[method](prop, eventType[prop], listener);\r\n      }\r\n\r\n      return true;\r\n    }\r\n  };\r\n\r\n  /*\\\r\n   * Interactable.on\r\n   [ method ]\r\n   *\r\n   * Binds a listener for an InteractEvent, pointerEvent or DOM event.\r\n   *\r\n   - eventType  (string | array | object) The types of events to listen for\r\n   - listener   (function) The function event (s)\r\n   - options    (object | boolean) #optional options object or useCapture flag for addEventListener\r\n   = (object) This Interactable\r\n  \\*/\r\n\r\n\r\n  Interactable.prototype.on = function on(eventType, listener, options) {\r\n    if (this._onOffMultiple('on', eventType, listener, options)) {\r\n      return this;\r\n    }\r\n\r\n    if (eventType === 'wheel') {\r\n      eventType = wheelEvent;\r\n    }\r\n\r\n    if (contains(Interactable.eventTypes, eventType)) {\r\n      this.events.on(eventType, listener);\r\n    }\r\n    // delegated event for selector\r\n    else if (is.string(this.target)) {\r\n        events.addDelegate(this.target, this._context, eventType, listener, options);\r\n      } else {\r\n        events.add(this.target, eventType, listener, options);\r\n      }\r\n\r\n    return this;\r\n  };\r\n\r\n  /*\\\r\n   * Interactable.off\r\n   [ method ]\r\n   *\r\n   * Removes an InteractEvent, pointerEvent or DOM event listener\r\n   *\r\n   - eventType  (string | array | object) The types of events that were listened for\r\n   - listener   (function) The listener function to be removed\r\n   - options    (object | boolean) #optional options object or useCapture flag for removeEventListener\r\n   = (object) This Interactable\r\n  \\*/\r\n\r\n\r\n  Interactable.prototype.off = function off(eventType, listener, options) {\r\n    if (this._onOffMultiple('off', eventType, listener, options)) {\r\n      return this;\r\n    }\r\n\r\n    if (eventType === 'wheel') {\r\n      eventType = wheelEvent;\r\n    }\r\n\r\n    // if it is an action event type\r\n    if (contains(Interactable.eventTypes, eventType)) {\r\n      this.events.off(eventType, listener);\r\n    }\r\n    // delegated event\r\n    else if (is.string(this.target)) {\r\n        events.removeDelegate(this.target, this._context, eventType, listener, options);\r\n      }\r\n      // remove listener from this Interatable's element\r\n      else {\r\n          events.remove(this.target, eventType, listener, options);\r\n        }\r\n\r\n    return this;\r\n  };\r\n\r\n  /*\\\r\n   * Interactable.set\r\n   [ method ]\r\n   *\r\n   * Reset the options of this Interactable\r\n   - options (object) The new settings to apply\r\n   = (object) This Interactable\r\n  \\*/\r\n\r\n\r\n  Interactable.prototype.set = function set(options) {\r\n    if (!is.object(options)) {\r\n      options = {};\r\n    }\r\n\r\n    this.options = extend({}, defaults.base);\r\n\r\n    var perActions = extend({}, defaults.perAction);\r\n\r\n    for (var actionName in actions.methodDict) {\r\n      var methodName = actions.methodDict[actionName];\r\n\r\n      this.options[actionName] = extend({}, defaults[actionName]);\r\n\r\n      this.setPerAction(actionName, perActions);\r\n\r\n      this[methodName](options[actionName]);\r\n    }\r\n\r\n    for (var _iterator2 = Interactable.settingsMethods, _isArray2 = Array.isArray(_iterator2), _i2 = 0, _iterator2 = _isArray2 ? _iterator2 : _iterator2[Symbol.iterator]();;) {\r\n      var _ref2;\r\n\r\n      if (_isArray2) {\r\n        if (_i2 >= _iterator2.length) break;\r\n        _ref2 = _iterator2[_i2++];\r\n      } else {\r\n        _i2 = _iterator2.next();\r\n        if (_i2.done) break;\r\n        _ref2 = _i2.value;\r\n      }\r\n\r\n      var setting = _ref2;\r\n\r\n      this.options[setting] = defaults.base[setting];\r\n\r\n      if (setting in options) {\r\n        this[setting](options[setting]);\r\n      }\r\n    }\r\n\r\n    signals.fire('set', {\r\n      options: options,\r\n      interactable: this\r\n    });\r\n\r\n    return this;\r\n  };\r\n\r\n  /*\\\r\n   * Interactable.unset\r\n   [ method ]\r\n   *\r\n   * Remove this interactable from the list of interactables and remove\r\n   * it's action capabilities and event listeners\r\n   *\r\n   = (object) @interact\r\n  \\*/\r\n\r\n\r\n  Interactable.prototype.unset = function unset() {\r\n    events.remove(this.target, 'all');\r\n\r\n    if (is.string(this.target)) {\r\n      // remove delegated events\r\n      for (var type in events.delegatedEvents) {\r\n        var delegated = events.delegatedEvents[type];\r\n\r\n        if (delegated.selectors[0] === this.target && delegated.contexts[0] === this._context) {\r\n\r\n          delegated.selectors.splice(0, 1);\r\n          delegated.contexts.splice(0, 1);\r\n          delegated.listeners.splice(0, 1);\r\n\r\n          // remove the arrays if they are empty\r\n          if (!delegated.selectors.length) {\r\n            delegated[type] = null;\r\n          }\r\n        }\r\n\r\n        events.remove(this._context, type, events.delegateListener);\r\n        events.remove(this._context, type, events.delegateUseCapture, true);\r\n      }\r\n    } else {\r\n      events.remove(this, 'all');\r\n    }\r\n\r\n    signals.fire('unset', { interactable: this });\r\n\r\n    scope.interactables.splice(indexOf(scope.interactables, this), 1);\r\n\r\n    // Stop related interactions when an Interactable is unset\r\n    for (var _iterator3 = scope.interactions || [], _isArray3 = Array.isArray(_iterator3), _i3 = 0, _iterator3 = _isArray3 ? _iterator3 : _iterator3[Symbol.iterator]();;) {\r\n      var _ref3;\r\n\r\n      if (_isArray3) {\r\n        if (_i3 >= _iterator3.length) break;\r\n        _ref3 = _iterator3[_i3++];\r\n      } else {\r\n        _i3 = _iterator3.next();\r\n        if (_i3.done) break;\r\n        _ref3 = _i3.value;\r\n      }\r\n\r\n      var interaction = _ref3;\r\n\r\n      if (interaction.target === this && interaction.interacting()) {\r\n        interaction.stop();\r\n      }\r\n    }\r\n\r\n    return scope.interact;\r\n  };\r\n\r\n  return Interactable;\r\n}();\r\n\r\nscope.interactables.indexOfElement = function indexOfElement(target, context) {\r\n  context = context || scope.document;\r\n\r\n  for (var i = 0; i < this.length; i++) {\r\n    var interactable = this[i];\r\n\r\n    if (interactable.target === target && interactable._context === context) {\r\n      return i;\r\n    }\r\n  }\r\n  return -1;\r\n};\r\n\r\nscope.interactables.get = function interactableGet(element, options, dontCheckInContext) {\r\n  var ret = this[this.indexOfElement(element, options && options.context)];\r\n\r\n  return ret && (is.string(element) || dontCheckInContext || ret.inContext(element)) ? ret : null;\r\n};\r\n\r\nscope.interactables.forEachSelector = function (callback, element) {\r\n  for (var i = 0; i < this.length; i++) {\r\n    var interactable = this[i];\r\n\r\n    // skip non CSS selector targets and out of context elements\r\n    if (!is.string(interactable.target) || element && !interactable.inContext(element)) {\r\n      continue;\r\n    }\r\n\r\n    var ret = callback(interactable, interactable.target, interactable._context, i, this);\r\n\r\n    if (ret !== undefined) {\r\n      return ret;\r\n    }\r\n  }\r\n};\r\n\r\n// all interact.js eventTypes\r\nInteractable.eventTypes = scope.eventTypes = [];\r\n\r\nInteractable.signals = signals;\r\n\r\nInteractable.settingsMethods = ['deltaSource', 'origin', 'preventDefault', 'rectChecker'];\r\n\r\nmodule.exports = Interactable;\r\n\r\n},{\"./Eventable\":2,\"./actions/base\":6,\"./defaultOptions\":18,\"./scope\":34,\"./utils/Signals\":35,\"./utils/arr\":36,\"./utils/browser\":37,\"./utils/domUtils\":39,\"./utils/events\":40,\"./utils/extend\":41,\"./utils/is\":46,\"./utils/window\":52}],5:[function(require,module,exports){\r\n'use strict';\r\n\r\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\r\n\r\nvar scope = require('./scope');\r\nvar utils = require('./utils');\r\nvar events = require('./utils/events');\r\nvar browser = require('./utils/browser');\r\nvar domObjects = require('./utils/domObjects');\r\nvar finder = require('./utils/interactionFinder');\r\nvar signals = require('./utils/Signals').new();\r\n\r\nvar listeners = {};\r\nvar methodNames = ['pointerDown', 'pointerMove', 'pointerUp', 'updatePointer', 'removePointer'];\r\n\r\n// for ignoring browser's simulated mouse events\r\nvar prevTouchTime = 0;\r\n\r\n// all active and idle interactions\r\nscope.interactions = [];\r\n\r\nvar Interaction = function () {\r\n  function Interaction(_ref) {\r\n    var pointerType = _ref.pointerType;\r\n\r\n    _classCallCheck(this, Interaction);\r\n\r\n    this.target = null; // current interactable being interacted with\r\n    this.element = null; // the target element of the interactable\r\n\r\n    this.prepared = { // action that's ready to be fired on next move event\r\n      name: null,\r\n      axis: null,\r\n      edges: null\r\n    };\r\n\r\n    // keep track of added pointers\r\n    this.pointers = [];\r\n    this.pointerIds = [];\r\n    this.downTargets = [];\r\n    this.downTimes = [];\r\n\r\n    // Previous native pointer move event coordinates\r\n    this.prevCoords = {\r\n      page: { x: 0, y: 0 },\r\n      client: { x: 0, y: 0 },\r\n      timeStamp: 0\r\n    };\r\n    // current native pointer move event coordinates\r\n    this.curCoords = {\r\n      page: { x: 0, y: 0 },\r\n      client: { x: 0, y: 0 },\r\n      timeStamp: 0\r\n    };\r\n\r\n    // Starting InteractEvent pointer coordinates\r\n    this.startCoords = {\r\n      page: { x: 0, y: 0 },\r\n      client: { x: 0, y: 0 },\r\n      timeStamp: 0\r\n    };\r\n\r\n    // Change in coordinates and time of the pointer\r\n    this.pointerDelta = {\r\n      page: { x: 0, y: 0, vx: 0, vy: 0, speed: 0 },\r\n      client: { x: 0, y: 0, vx: 0, vy: 0, speed: 0 },\r\n      timeStamp: 0\r\n    };\r\n\r\n    this.downEvent = null; // pointerdown/mousedown/touchstart event\r\n    this.downPointer = {};\r\n\r\n    this._eventTarget = null;\r\n    this._curEventTarget = null;\r\n\r\n    this.prevEvent = null; // previous action event\r\n\r\n    this.pointerIsDown = false;\r\n    this.pointerWasMoved = false;\r\n    this._interacting = false;\r\n\r\n    this.pointerType = pointerType;\r\n\r\n    signals.fire('new', this);\r\n\r\n    scope.interactions.push(this);\r\n  }\r\n\r\n  Interaction.prototype.pointerDown = function pointerDown(pointer, event, eventTarget) {\r\n    var pointerIndex = this.updatePointer(pointer, event, true);\r\n\r\n    signals.fire('down', {\r\n      pointer: pointer,\r\n      event: event,\r\n      eventTarget: eventTarget,\r\n      pointerIndex: pointerIndex,\r\n      interaction: this\r\n    });\r\n  };\r\n\r\n  /*\\\r\n   * Interaction.start\r\n   [ method ]\r\n   *\r\n   * Start an action with the given Interactable and Element as tartgets. The\r\n   * action must be enabled for the target Interactable and an appropriate number\r\n   * of pointers must be held down - 1 for drag/resize, 2 for gesture.\r\n   *\r\n   * Use it with `interactable.<action>able({ manualStart: false })` to always\r\n   * [start actions manually](https://github.com/taye/interact.js/issues/114)\r\n   *\r\n   - action  (object)  The action to be performed - drag, resize, etc.\r\n   - target  (Interactable) The Interactable to target\r\n   - element (Element) The DOM Element to target\r\n   = (object) interact\r\n   **\r\n   | interact(target)\r\n   |   .draggable({\r\n   |     // disable the default drag start by down->move\r\n   |     manualStart: true\r\n   |   })\r\n   |   // start dragging after the user holds the pointer down\r\n   |   .on('hold', function (event) {\r\n   |     var interaction = event.interaction;\r\n   |\r\n   |     if (!interaction.interacting()) {\r\n   |       interaction.start({ name: 'drag' },\r\n   |                         event.interactable,\r\n   |                         event.currentTarget);\r\n   |     }\r\n   | });\r\n   \\*/\r\n\r\n\r\n  Interaction.prototype.start = function start(action, target, element) {\r\n    if (this.interacting() || !this.pointerIsDown || this.pointerIds.length < (action.name === 'gesture' ? 2 : 1)) {\r\n      return;\r\n    }\r\n\r\n    // if this interaction had been removed after stopping\r\n    // add it back\r\n    if (utils.indexOf(scope.interactions, this) === -1) {\r\n      scope.interactions.push(this);\r\n    }\r\n\r\n    utils.copyAction(this.prepared, action);\r\n    this.target = target;\r\n    this.element = element;\r\n\r\n    signals.fire('action-start', {\r\n      interaction: this,\r\n      event: this.downEvent\r\n    });\r\n  };\r\n\r\n  Interaction.prototype.pointerMove = function pointerMove(pointer, event, eventTarget) {\r\n    if (!this.simulation) {\r\n      this.updatePointer(pointer);\r\n      utils.setCoords(this.curCoords, this.pointers);\r\n    }\r\n\r\n    var duplicateMove = this.curCoords.page.x === this.prevCoords.page.x && this.curCoords.page.y === this.prevCoords.page.y && this.curCoords.client.x === this.prevCoords.client.x && this.curCoords.client.y === this.prevCoords.client.y;\r\n\r\n    var dx = void 0;\r\n    var dy = void 0;\r\n\r\n    // register movement greater than pointerMoveTolerance\r\n    if (this.pointerIsDown && !this.pointerWasMoved) {\r\n      dx = this.curCoords.client.x - this.startCoords.client.x;\r\n      dy = this.curCoords.client.y - this.startCoords.client.y;\r\n\r\n      this.pointerWasMoved = utils.hypot(dx, dy) > Interaction.pointerMoveTolerance;\r\n    }\r\n\r\n    var signalArg = {\r\n      pointer: pointer,\r\n      pointerIndex: this.getPointerIndex(pointer),\r\n      event: event,\r\n      eventTarget: eventTarget,\r\n      dx: dx,\r\n      dy: dy,\r\n      duplicate: duplicateMove,\r\n      interaction: this,\r\n      interactingBeforeMove: this.interacting()\r\n    };\r\n\r\n    if (!duplicateMove) {\r\n      // set pointer coordinate, time changes and speeds\r\n      utils.setCoordDeltas(this.pointerDelta, this.prevCoords, this.curCoords);\r\n    }\r\n\r\n    signals.fire('move', signalArg);\r\n\r\n    if (!duplicateMove) {\r\n      // if interacting, fire an 'action-move' signal etc\r\n      if (this.interacting()) {\r\n        this.doMove(signalArg);\r\n      }\r\n\r\n      if (this.pointerWasMoved) {\r\n        utils.copyCoords(this.prevCoords, this.curCoords);\r\n      }\r\n    }\r\n  };\r\n\r\n  /*\\\r\n   * Interaction.doMove\r\n   [ method ]\r\n   *\r\n   * Force a move of the current action at the same coordinates. Useful if\r\n   * snap/restrict has been changed and you want a movement with the new\r\n   * settings.\r\n   *\r\n   **\r\n   | interact(target)\r\n   |   .draggable(true)\r\n   |   .on('dragmove', function (event) {\r\n   |     if (someCondition) {\r\n   |       // change the snap settings\r\n   |       event.interactable.draggable({ snap: { targets: [] }});\r\n   |       // fire another move event with re-calculated snap\r\n   |       event.interaction.doMove();\r\n   |     }\r\n   |   });\r\n   \\*/\r\n\r\n\r\n  Interaction.prototype.doMove = function doMove(signalArg) {\r\n    signalArg = utils.extend({\r\n      pointer: this.pointers[0],\r\n      event: this.prevEvent,\r\n      eventTarget: this._eventTarget,\r\n      interaction: this\r\n    }, signalArg || {});\r\n\r\n    signals.fire('before-action-move', signalArg);\r\n\r\n    if (!this._dontFireMove) {\r\n      signals.fire('action-move', signalArg);\r\n    }\r\n\r\n    this._dontFireMove = false;\r\n  };\r\n\r\n  // End interact move events and stop auto-scroll unless simulation is running\r\n\r\n\r\n  Interaction.prototype.pointerUp = function pointerUp(pointer, event, eventTarget, curEventTarget) {\r\n    var pointerIndex = this.getPointerIndex(pointer);\r\n\r\n    signals.fire(/cancel$/i.test(event.type) ? 'cancel' : 'up', {\r\n      pointer: pointer,\r\n      pointerIndex: pointerIndex,\r\n      event: event,\r\n      eventTarget: eventTarget,\r\n      curEventTarget: curEventTarget,\r\n      interaction: this\r\n    });\r\n\r\n    if (!this.simulation) {\r\n      this.end(event);\r\n    }\r\n\r\n    this.pointerIsDown = false;\r\n    this.removePointer(pointer, event);\r\n  };\r\n\r\n  /*\\\r\n   * Interaction.end\r\n   [ method ]\r\n   *\r\n   * Stop the current action and fire an end event. Inertial movement does\r\n   * not happen.\r\n   *\r\n   - event (PointerEvent) #optional\r\n   **\r\n   | interact(target)\r\n   |   .draggable(true)\r\n   |   .on('move', function (event) {\r\n   |     if (event.pageX > 1000) {\r\n   |       // end the current action\r\n   |       event.interaction.end();\r\n   |       // stop all further listeners from being called\r\n   |       event.stopImmediatePropagation();\r\n   |     }\r\n   |   });\r\n   \\*/\r\n\r\n\r\n  Interaction.prototype.end = function end(event) {\r\n    event = event || this.prevEvent;\r\n\r\n    if (this.interacting()) {\r\n      signals.fire('action-end', {\r\n        event: event,\r\n        interaction: this\r\n      });\r\n    }\r\n\r\n    this.stop();\r\n  };\r\n\r\n  Interaction.prototype.currentAction = function currentAction() {\r\n    return this._interacting ? this.prepared.name : null;\r\n  };\r\n\r\n  Interaction.prototype.interacting = function interacting() {\r\n    return this._interacting;\r\n  };\r\n\r\n  Interaction.prototype.stop = function stop() {\r\n    signals.fire('stop', { interaction: this });\r\n\r\n    if (this._interacting) {\r\n      signals.fire('stop-active', { interaction: this });\r\n      signals.fire('stop-' + this.prepared.name, { interaction: this });\r\n    }\r\n\r\n    this.target = this.element = null;\r\n\r\n    this._interacting = false;\r\n    this.prepared.name = this.prevEvent = null;\r\n  };\r\n\r\n  Interaction.prototype.getPointerIndex = function getPointerIndex(pointer) {\r\n    // mouse and pen interactions may have only one pointer\r\n    if (this.pointerType === 'mouse' || this.pointerType === 'pen') {\r\n      return 0;\r\n    }\r\n\r\n    return utils.indexOf(this.pointerIds, utils.getPointerId(pointer));\r\n  };\r\n\r\n  Interaction.prototype.updatePointer = function updatePointer(pointer, event) {\r\n    var down = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : event && /(down|start)$/i.test(event.type);\r\n\r\n    var id = utils.getPointerId(pointer);\r\n    var index = this.getPointerIndex(pointer);\r\n\r\n    if (index === -1) {\r\n      index = this.pointerIds.length;\r\n      this.pointerIds[index] = id;\r\n    }\r\n\r\n    if (down) {\r\n      signals.fire('update-pointer-down', {\r\n        pointer: pointer,\r\n        event: event,\r\n        down: down,\r\n        pointerId: id,\r\n        pointerIndex: index,\r\n        interaction: this\r\n      });\r\n    }\r\n\r\n    this.pointers[index] = pointer;\r\n\r\n    return index;\r\n  };\r\n\r\n  Interaction.prototype.removePointer = function removePointer(pointer, event) {\r\n    var index = this.getPointerIndex(pointer);\r\n\r\n    if (index === -1) {\r\n      return;\r\n    }\r\n\r\n    signals.fire('remove-pointer', {\r\n      pointer: pointer,\r\n      event: event,\r\n      pointerIndex: index,\r\n      interaction: this\r\n    });\r\n\r\n    this.pointers.splice(index, 1);\r\n    this.pointerIds.splice(index, 1);\r\n    this.downTargets.splice(index, 1);\r\n    this.downTimes.splice(index, 1);\r\n  };\r\n\r\n  Interaction.prototype._updateEventTargets = function _updateEventTargets(target, currentTarget) {\r\n    this._eventTarget = target;\r\n    this._curEventTarget = currentTarget;\r\n  };\r\n\r\n  return Interaction;\r\n}();\r\n\r\nfor (var i = 0, len = methodNames.length; i < len; i++) {\r\n  var method = methodNames[i];\r\n\r\n  listeners[method] = doOnInteractions(method);\r\n}\r\n\r\nfunction doOnInteractions(method) {\r\n  return function (event) {\r\n    var pointerType = utils.getPointerType(event);\r\n\r\n    var _utils$getEventTarget = utils.getEventTargets(event),\r\n        eventTarget = _utils$getEventTarget[0],\r\n        curEventTarget = _utils$getEventTarget[1];\r\n\r\n    var matches = []; // [ [pointer, interaction], ...]\r\n\r\n    if (browser.supportsTouch && /touch/.test(event.type)) {\r\n      prevTouchTime = new Date().getTime();\r\n\r\n      for (var _i = 0; _i < event.changedTouches.length; _i++) {\r\n        var pointer = event.changedTouches[_i];\r\n        var interaction = finder.search(pointer, event.type, eventTarget);\r\n\r\n        matches.push([pointer, interaction || new Interaction({ pointerType: pointerType })]);\r\n      }\r\n    } else {\r\n      var invalidPointer = false;\r\n\r\n      if (!browser.supportsPointerEvent && /mouse/.test(event.type)) {\r\n        // ignore mouse events while touch interactions are active\r\n        for (var _i2 = 0; _i2 < scope.interactions.length && !invalidPointer; _i2++) {\r\n          invalidPointer = scope.interactions[_i2].pointerType !== 'mouse' && scope.interactions[_i2].pointerIsDown;\r\n        }\r\n\r\n        // try to ignore mouse events that are simulated by the browser\r\n        // after a touch event\r\n        invalidPointer = invalidPointer || new Date().getTime() - prevTouchTime < 500\r\n        // on iOS and Firefox Mobile, MouseEvent.timeStamp is zero if simulated\r\n        || event.timeStamp === 0;\r\n      }\r\n\r\n      if (!invalidPointer) {\r\n        var _interaction = finder.search(event, event.type, eventTarget);\r\n\r\n        if (!_interaction) {\r\n          _interaction = new Interaction({ pointerType: pointerType });\r\n        }\r\n\r\n        matches.push([event, _interaction]);\r\n      }\r\n    }\r\n\r\n    for (var _iterator = matches, _isArray = Array.isArray(_iterator), _i3 = 0, _iterator = _isArray ? _iterator : _iterator[Symbol.iterator]();;) {\r\n      var _ref2;\r\n\r\n      if (_isArray) {\r\n        if (_i3 >= _iterator.length) break;\r\n        _ref2 = _iterator[_i3++];\r\n      } else {\r\n        _i3 = _iterator.next();\r\n        if (_i3.done) break;\r\n        _ref2 = _i3.value;\r\n      }\r\n\r\n      var _ref3 = _ref2,\r\n          _pointer = _ref3[0],\r\n          _interaction2 = _ref3[1];\r\n\r\n      _interaction2._updateEventTargets(eventTarget, curEventTarget);\r\n      _interaction2[method](_pointer, event, eventTarget, curEventTarget);\r\n    }\r\n  };\r\n}\r\n\r\nfunction endAll(event) {\r\n  for (var _i4 = 0; _i4 < scope.interactions.length; _i4++) {\r\n    var interaction = scope.interactions[_i4];\r\n\r\n    interaction.end(event);\r\n    signals.fire('endall', { event: event, interaction: interaction });\r\n  }\r\n}\r\n\r\nvar docEvents = {/* 'eventType': listenerFunc */};\r\nvar pEventTypes = browser.pEventTypes;\r\n\r\nif (domObjects.PointerEvent) {\r\n  docEvents[pEventTypes.down] = listeners.pointerDown;\r\n  docEvents[pEventTypes.move] = listeners.pointerMove;\r\n  docEvents[pEventTypes.up] = listeners.pointerUp;\r\n  docEvents[pEventTypes.cancel] = listeners.pointerUp;\r\n} else {\r\n  docEvents.mousedown = listeners.pointerDown;\r\n  docEvents.mousemove = listeners.pointerMove;\r\n  docEvents.mouseup = listeners.pointerUp;\r\n\r\n  docEvents.touchstart = listeners.pointerDown;\r\n  docEvents.touchmove = listeners.pointerMove;\r\n  docEvents.touchend = listeners.pointerUp;\r\n  docEvents.touchcancel = listeners.pointerUp;\r\n}\r\n\r\ndocEvents.blur = endAll;\r\n\r\nfunction onDocSignal(_ref4, signalName) {\r\n  var doc = _ref4.doc;\r\n\r\n  var eventMethod = signalName.indexOf('add') === 0 ? events.add : events.remove;\r\n\r\n  // delegate event listener\r\n  for (var eventType in scope.delegatedEvents) {\r\n    eventMethod(doc, eventType, events.delegateListener);\r\n    eventMethod(doc, eventType, events.delegateUseCapture, true);\r\n  }\r\n\r\n  for (var _eventType in docEvents) {\r\n    eventMethod(doc, _eventType, docEvents[_eventType]);\r\n  }\r\n}\r\n\r\nsignals.on('update-pointer-down', function (_ref5) {\r\n  var interaction = _ref5.interaction,\r\n      pointer = _ref5.pointer,\r\n      pointerId = _ref5.pointerId,\r\n      pointerIndex = _ref5.pointerIndex,\r\n      event = _ref5.event,\r\n      eventTarget = _ref5.eventTarget,\r\n      down = _ref5.down;\r\n\r\n  interaction.pointerIds[pointerIndex] = pointerId;\r\n  interaction.pointers[pointerIndex] = pointer;\r\n\r\n  if (down) {\r\n    interaction.pointerIsDown = true;\r\n  }\r\n\r\n  if (!interaction.interacting()) {\r\n    utils.setCoords(interaction.startCoords, interaction.pointers);\r\n\r\n    utils.copyCoords(interaction.curCoords, interaction.startCoords);\r\n    utils.copyCoords(interaction.prevCoords, interaction.startCoords);\r\n\r\n    interaction.downEvent = event;\r\n    interaction.downTimes[pointerIndex] = interaction.curCoords.timeStamp;\r\n    interaction.downTargets[pointerIndex] = eventTarget || event && utils.getEventTargets(event)[0];\r\n    interaction.pointerWasMoved = false;\r\n\r\n    utils.pointerExtend(interaction.downPointer, pointer);\r\n  }\r\n});\r\n\r\nscope.signals.on('add-document', onDocSignal);\r\nscope.signals.on('remove-document', onDocSignal);\r\n\r\nInteraction.pointerMoveTolerance = 1;\r\nInteraction.doOnInteractions = doOnInteractions;\r\nInteraction.endAll = endAll;\r\nInteraction.signals = signals;\r\nInteraction.docEvents = docEvents;\r\n\r\nscope.endAllInteractions = endAll;\r\n\r\nmodule.exports = Interaction;\r\n\r\n},{\"./scope\":34,\"./utils\":44,\"./utils/Signals\":35,\"./utils/browser\":37,\"./utils/domObjects\":38,\"./utils/events\":40,\"./utils/interactionFinder\":45}],6:[function(require,module,exports){\r\n'use strict';\r\n\r\nvar Interaction = require('../Interaction');\r\nvar InteractEvent = require('../InteractEvent');\r\n\r\nvar actions = {\r\n  firePrepared: firePrepared,\r\n  names: [],\r\n  methodDict: {}\r\n};\r\n\r\nInteraction.signals.on('action-start', function (_ref) {\r\n  var interaction = _ref.interaction,\r\n      event = _ref.event;\r\n\r\n  interaction._interacting = true;\r\n  firePrepared(interaction, event, 'start');\r\n});\r\n\r\nInteraction.signals.on('action-move', function (_ref2) {\r\n  var interaction = _ref2.interaction,\r\n      event = _ref2.event,\r\n      preEnd = _ref2.preEnd;\r\n\r\n  firePrepared(interaction, event, 'move', preEnd);\r\n\r\n  // if the action was ended in a listener\r\n  if (!interaction.interacting()) {\r\n    return false;\r\n  }\r\n});\r\n\r\nInteraction.signals.on('action-end', function (_ref3) {\r\n  var interaction = _ref3.interaction,\r\n      event = _ref3.event;\r\n\r\n  firePrepared(interaction, event, 'end');\r\n});\r\n\r\nfunction firePrepared(interaction, event, phase, preEnd) {\r\n  var actionName = interaction.prepared.name;\r\n\r\n  var newEvent = new InteractEvent(interaction, event, actionName, phase, interaction.element, null, preEnd);\r\n\r\n  interaction.target.fire(newEvent);\r\n  interaction.prevEvent = newEvent;\r\n}\r\n\r\nmodule.exports = actions;\r\n\r\n},{\"../InteractEvent\":3,\"../Interaction\":5}],7:[function(require,module,exports){\r\n'use strict';\r\n\r\nvar actions = require('./base');\r\nvar utils = require('../utils');\r\nvar InteractEvent = require('../InteractEvent');\r\nvar Interactable = require('../Interactable');\r\nvar Interaction = require('../Interaction');\r\nvar defaultOptions = require('../defaultOptions');\r\n\r\nvar drag = {\r\n  defaults: {\r\n    enabled: false,\r\n    mouseButtons: null,\r\n\r\n    origin: null,\r\n    snap: null,\r\n    restrict: null,\r\n    inertia: null,\r\n    autoScroll: null,\r\n\r\n    startAxis: 'xy',\r\n    lockAxis: 'xy'\r\n  },\r\n\r\n  checker: function checker(pointer, event, interactable) {\r\n    var dragOptions = interactable.options.drag;\r\n\r\n    return dragOptions.enabled ? { name: 'drag', axis: dragOptions.lockAxis === 'start' ? dragOptions.startAxis : dragOptions.lockAxis } : null;\r\n  },\r\n\r\n  getCursor: function getCursor() {\r\n    return 'move';\r\n  }\r\n};\r\n\r\nInteraction.signals.on('before-action-move', function (_ref) {\r\n  var interaction = _ref.interaction;\r\n\r\n  if (interaction.prepared.name !== 'drag') {\r\n    return;\r\n  }\r\n\r\n  var axis = interaction.prepared.axis;\r\n\r\n  if (axis === 'x') {\r\n    interaction.curCoords.page.y = interaction.startCoords.page.y;\r\n    interaction.curCoords.client.y = interaction.startCoords.client.y;\r\n\r\n    interaction.pointerDelta.page.speed = Math.abs(interaction.pointerDelta.page.vx);\r\n    interaction.pointerDelta.client.speed = Math.abs(interaction.pointerDelta.client.vx);\r\n    interaction.pointerDelta.client.vy = 0;\r\n    interaction.pointerDelta.page.vy = 0;\r\n  } else if (axis === 'y') {\r\n    interaction.curCoords.page.x = interaction.startCoords.page.x;\r\n    interaction.curCoords.client.x = interaction.startCoords.client.x;\r\n\r\n    interaction.pointerDelta.page.speed = Math.abs(interaction.pointerDelta.page.vy);\r\n    interaction.pointerDelta.client.speed = Math.abs(interaction.pointerDelta.client.vy);\r\n    interaction.pointerDelta.client.vx = 0;\r\n    interaction.pointerDelta.page.vx = 0;\r\n  }\r\n});\r\n\r\n// dragmove\r\nInteractEvent.signals.on('new', function (_ref2) {\r\n  var iEvent = _ref2.iEvent,\r\n      interaction = _ref2.interaction;\r\n\r\n  if (iEvent.type !== 'dragmove') {\r\n    return;\r\n  }\r\n\r\n  var axis = interaction.prepared.axis;\r\n\r\n  if (axis === 'x') {\r\n    iEvent.pageY = interaction.startCoords.page.y;\r\n    iEvent.clientY = interaction.startCoords.client.y;\r\n    iEvent.dy = 0;\r\n  } else if (axis === 'y') {\r\n    iEvent.pageX = interaction.startCoords.page.x;\r\n    iEvent.clientX = interaction.startCoords.client.x;\r\n    iEvent.dx = 0;\r\n  }\r\n});\r\n\r\n/*\\\r\n * Interactable.draggable\r\n [ method ]\r\n *\r\n * Gets or sets whether drag actions can be performed on the\r\n * Interactable\r\n *\r\n = (boolean) Indicates if this can be the target of drag events\r\n | var isDraggable = interact('ul li').draggable();\r\n * or\r\n - options (boolean | object) #optional true/false or An object with event listeners to be fired on drag events (object makes the Interactable draggable)\r\n = (object) This Interactable\r\n | interact(element).draggable({\r\n |     onstart: function (event) {},\r\n |     onmove : function (event) {},\r\n |     onend  : function (event) {},\r\n |\r\n |     // the axis in which the first movement must be\r\n |     // for the drag sequence to start\r\n |     // 'xy' by default - any direction\r\n |     startAxis: 'x' || 'y' || 'xy',\r\n |\r\n |     // 'xy' by default - don't restrict to one axis (move in any direction)\r\n |     // 'x' or 'y' to restrict movement to either axis\r\n |     // 'start' to restrict movement to the axis the drag started in\r\n |     lockAxis: 'x' || 'y' || 'xy' || 'start',\r\n |\r\n |     // max number of drags that can happen concurrently\r\n |     // with elements of this Interactable. Infinity by default\r\n |     max: Infinity,\r\n |\r\n |     // max number of drags that can target the same element+Interactable\r\n |     // 1 by default\r\n |     maxPerElement: 2\r\n | });\r\n\\*/\r\nInteractable.prototype.draggable = function (options) {\r\n  if (utils.is.object(options)) {\r\n    this.options.drag.enabled = options.enabled === false ? false : true;\r\n    this.setPerAction('drag', options);\r\n    this.setOnEvents('drag', options);\r\n\r\n    if (/^(xy|x|y|start)$/.test(options.lockAxis)) {\r\n      this.options.drag.lockAxis = options.lockAxis;\r\n    }\r\n    if (/^(xy|x|y)$/.test(options.startAxis)) {\r\n      this.options.drag.startAxis = options.startAxis;\r\n    }\r\n\r\n    return this;\r\n  }\r\n\r\n  if (utils.is.bool(options)) {\r\n    this.options.drag.enabled = options;\r\n\r\n    if (!options) {\r\n      this.ondragstart = this.ondragstart = this.ondragend = null;\r\n    }\r\n\r\n    return this;\r\n  }\r\n\r\n  return this.options.drag;\r\n};\r\n\r\nactions.drag = drag;\r\nactions.names.push('drag');\r\nutils.merge(Interactable.eventTypes, ['dragstart', 'dragmove', 'draginertiastart', 'draginertiaresume', 'dragend']);\r\nactions.methodDict.drag = 'draggable';\r\n\r\ndefaultOptions.drag = drag.defaults;\r\n\r\nmodule.exports = drag;\r\n\r\n},{\"../InteractEvent\":3,\"../Interactable\":4,\"../Interaction\":5,\"../defaultOptions\":18,\"../utils\":44,\"./base\":6}],8:[function(require,module,exports){\r\n'use strict';\r\n\r\nvar actions = require('./base');\r\nvar utils = require('../utils');\r\nvar scope = require('../scope');\r\nvar interact = require('../interact');\r\nvar InteractEvent = require('../InteractEvent');\r\nvar Interactable = require('../Interactable');\r\nvar Interaction = require('../Interaction');\r\nvar defaultOptions = require('../defaultOptions');\r\n\r\nvar drop = {\r\n  defaults: {\r\n    enabled: false,\r\n    accept: null,\r\n    overlap: 'pointer'\r\n  }\r\n};\r\n\r\nvar dynamicDrop = false;\r\n\r\nInteraction.signals.on('action-start', function (_ref) {\r\n  var interaction = _ref.interaction,\r\n      event = _ref.event;\r\n\r\n  if (interaction.prepared.name !== 'drag') {\r\n    return;\r\n  }\r\n\r\n  // reset active dropzones\r\n  interaction.activeDrops.dropzones = [];\r\n  interaction.activeDrops.elements = [];\r\n  interaction.activeDrops.rects = [];\r\n\r\n  interaction.dropEvents = null;\r\n\r\n  if (!interaction.dynamicDrop) {\r\n    setActiveDrops(interaction, interaction.element);\r\n  }\r\n\r\n  var dragEvent = interaction.prevEvent;\r\n  var dropEvents = getDropEvents(interaction, event, dragEvent);\r\n\r\n  if (dropEvents.activate) {\r\n    fireActiveDrops(interaction, dropEvents.activate);\r\n  }\r\n});\r\n\r\nInteractEvent.signals.on('new', function (_ref2) {\r\n  var interaction = _ref2.interaction,\r\n      iEvent = _ref2.iEvent,\r\n      event = _ref2.event;\r\n\r\n  if (iEvent.type !== 'dragmove' && iEvent.type !== 'dragend') {\r\n    return;\r\n  }\r\n\r\n  var draggableElement = interaction.element;\r\n  var dragEvent = iEvent;\r\n  var dropResult = getDrop(dragEvent, event, draggableElement);\r\n\r\n  interaction.dropTarget = dropResult.dropzone;\r\n  interaction.dropElement = dropResult.element;\r\n\r\n  interaction.dropEvents = getDropEvents(interaction, event, dragEvent);\r\n});\r\n\r\nInteraction.signals.on('action-move', function (_ref3) {\r\n  var interaction = _ref3.interaction;\r\n\r\n  if (interaction.prepared.name !== 'drag') {\r\n    return;\r\n  }\r\n\r\n  fireDropEvents(interaction, interaction.dropEvents);\r\n});\r\n\r\nInteraction.signals.on('action-end', function (_ref4) {\r\n  var interaction = _ref4.interaction;\r\n\r\n  if (interaction.prepared.name === 'drag') {\r\n    fireDropEvents(interaction, interaction.dropEvents);\r\n  }\r\n});\r\n\r\nInteraction.signals.on('stop-drag', function (_ref5) {\r\n  var interaction = _ref5.interaction;\r\n\r\n  interaction.activeDrops.dropzones = interaction.activeDrops.elements = interaction.activeDrops.rects = interaction.dropEvents = null;\r\n});\r\n\r\nfunction collectDrops(interaction, element) {\r\n  var drops = [];\r\n  var elements = [];\r\n\r\n  element = element || interaction.element;\r\n\r\n  // collect all dropzones and their elements which qualify for a drop\r\n  for (var _iterator = scope.interactables, _isArray = Array.isArray(_iterator), _i = 0, _iterator = _isArray ? _iterator : _iterator[Symbol.iterator]();;) {\r\n    var _ref6;\r\n\r\n    if (_isArray) {\r\n      if (_i >= _iterator.length) break;\r\n      _ref6 = _iterator[_i++];\r\n    } else {\r\n      _i = _iterator.next();\r\n      if (_i.done) break;\r\n      _ref6 = _i.value;\r\n    }\r\n\r\n    var current = _ref6;\r\n\r\n    if (!current.options.drop.enabled) {\r\n      continue;\r\n    }\r\n\r\n    var accept = current.options.drop.accept;\r\n\r\n    // test the draggable element against the dropzone's accept setting\r\n    if (utils.is.element(accept) && accept !== element || utils.is.string(accept) && !utils.matchesSelector(element, accept)) {\r\n\r\n      continue;\r\n    }\r\n\r\n    // query for new elements if necessary\r\n    var dropElements = utils.is.string(current.target) ? current._context.querySelectorAll(current.target) : [current.target];\r\n\r\n    for (var i = 0; i < dropElements.length; i++) {\r\n      var currentElement = dropElements[i];\r\n\r\n      if (currentElement !== element) {\r\n        drops.push(current);\r\n        elements.push(currentElement);\r\n      }\r\n    }\r\n  }\r\n\r\n  return {\r\n    elements: elements,\r\n    dropzones: drops\r\n  };\r\n}\r\n\r\nfunction fireActiveDrops(interaction, event) {\r\n  var prevElement = void 0;\r\n\r\n  // loop through all active dropzones and trigger event\r\n  for (var i = 0; i < interaction.activeDrops.dropzones.length; i++) {\r\n    var current = interaction.activeDrops.dropzones[i];\r\n    var currentElement = interaction.activeDrops.elements[i];\r\n\r\n    // prevent trigger of duplicate events on same element\r\n    if (currentElement !== prevElement) {\r\n      // set current element as event target\r\n      event.target = currentElement;\r\n      current.fire(event);\r\n    }\r\n    prevElement = currentElement;\r\n  }\r\n}\r\n\r\n// Collect a new set of possible drops and save them in activeDrops.\r\n// setActiveDrops should always be called when a drag has just started or a\r\n// drag event happens while dynamicDrop is true\r\nfunction setActiveDrops(interaction, dragElement) {\r\n  // get dropzones and their elements that could receive the draggable\r\n  var possibleDrops = collectDrops(interaction, dragElement, true);\r\n\r\n  interaction.activeDrops.dropzones = possibleDrops.dropzones;\r\n  interaction.activeDrops.elements = possibleDrops.elements;\r\n  interaction.activeDrops.rects = [];\r\n\r\n  for (var i = 0; i < interaction.activeDrops.dropzones.length; i++) {\r\n    interaction.activeDrops.rects[i] = interaction.activeDrops.dropzones[i].getRect(interaction.activeDrops.elements[i]);\r\n  }\r\n}\r\n\r\nfunction getDrop(dragEvent, event, dragElement) {\r\n  var interaction = dragEvent.interaction;\r\n  var validDrops = [];\r\n\r\n  if (dynamicDrop) {\r\n    setActiveDrops(interaction, dragElement);\r\n  }\r\n\r\n  // collect all dropzones and their elements which qualify for a drop\r\n  for (var j = 0; j < interaction.activeDrops.dropzones.length; j++) {\r\n    var current = interaction.activeDrops.dropzones[j];\r\n    var currentElement = interaction.activeDrops.elements[j];\r\n    var rect = interaction.activeDrops.rects[j];\r\n\r\n    validDrops.push(current.dropCheck(dragEvent, event, interaction.target, dragElement, currentElement, rect) ? currentElement : null);\r\n  }\r\n\r\n  // get the most appropriate dropzone based on DOM depth and order\r\n  var dropIndex = utils.indexOfDeepestElement(validDrops);\r\n\r\n  return {\r\n    dropzone: interaction.activeDrops.dropzones[dropIndex] || null,\r\n    element: interaction.activeDrops.elements[dropIndex] || null\r\n  };\r\n}\r\n\r\nfunction getDropEvents(interaction, pointerEvent, dragEvent) {\r\n  var dropEvents = {\r\n    enter: null,\r\n    leave: null,\r\n    activate: null,\r\n    deactivate: null,\r\n    move: null,\r\n    drop: null\r\n  };\r\n\r\n  var tmpl = {\r\n    dragEvent: dragEvent,\r\n    interaction: interaction,\r\n    target: interaction.dropElement,\r\n    dropzone: interaction.dropTarget,\r\n    relatedTarget: dragEvent.target,\r\n    draggable: dragEvent.interactable,\r\n    timeStamp: dragEvent.timeStamp\r\n  };\r\n\r\n  if (interaction.dropElement !== interaction.prevDropElement) {\r\n    // if there was a prevDropTarget, create a dragleave event\r\n    if (interaction.prevDropTarget) {\r\n      dropEvents.leave = utils.extend({ type: 'dragleave' }, tmpl);\r\n\r\n      dragEvent.dragLeave = dropEvents.leave.target = interaction.prevDropElement;\r\n      dragEvent.prevDropzone = dropEvents.leave.dropzone = interaction.prevDropTarget;\r\n    }\r\n    // if the dropTarget is not null, create a dragenter event\r\n    if (interaction.dropTarget) {\r\n      dropEvents.enter = {\r\n        dragEvent: dragEvent,\r\n        interaction: interaction,\r\n        target: interaction.dropElement,\r\n        dropzone: interaction.dropTarget,\r\n        relatedTarget: dragEvent.target,\r\n        draggable: dragEvent.interactable,\r\n        timeStamp: dragEvent.timeStamp,\r\n        type: 'dragenter'\r\n      };\r\n\r\n      dragEvent.dragEnter = interaction.dropElement;\r\n      dragEvent.dropzone = interaction.dropTarget;\r\n    }\r\n  }\r\n\r\n  if (dragEvent.type === 'dragend' && interaction.dropTarget) {\r\n    dropEvents.drop = utils.extend({ type: 'drop' }, tmpl);\r\n\r\n    dragEvent.dropzone = interaction.dropTarget;\r\n    dragEvent.relatedTarget = interaction.dropElement;\r\n  }\r\n  if (dragEvent.type === 'dragstart') {\r\n    dropEvents.activate = utils.extend({ type: 'dropactivate' }, tmpl);\r\n\r\n    dropEvents.activate.target = null;\r\n    dropEvents.activate.dropzone = null;\r\n  }\r\n  if (dragEvent.type === 'dragend') {\r\n    dropEvents.deactivate = utils.extend({ type: 'dropdeactivate' }, tmpl);\r\n\r\n    dropEvents.deactivate.target = null;\r\n    dropEvents.deactivate.dropzone = null;\r\n  }\r\n  if (dragEvent.type === 'dragmove' && interaction.dropTarget) {\r\n    dropEvents.move = utils.extend({\r\n      dragmove: dragEvent,\r\n      type: 'dropmove'\r\n    }, tmpl);\r\n\r\n    dragEvent.dropzone = interaction.dropTarget;\r\n  }\r\n\r\n  return dropEvents;\r\n}\r\n\r\nfunction fireDropEvents(interaction, dropEvents) {\r\n  if (dropEvents.leave) {\r\n    interaction.prevDropTarget.fire(dropEvents.leave);\r\n  }\r\n  if (dropEvents.move) {\r\n    interaction.dropTarget.fire(dropEvents.move);\r\n  }\r\n  if (dropEvents.enter) {\r\n    interaction.dropTarget.fire(dropEvents.enter);\r\n  }\r\n  if (dropEvents.drop) {\r\n    interaction.dropTarget.fire(dropEvents.drop);\r\n  }\r\n  if (dropEvents.deactivate) {\r\n    fireActiveDrops(interaction, dropEvents.deactivate);\r\n  }\r\n\r\n  interaction.prevDropTarget = interaction.dropTarget;\r\n  interaction.prevDropElement = interaction.dropElement;\r\n}\r\n\r\n/*\\\r\n * Interactable.dropzone\r\n [ method ]\r\n *\r\n * Returns or sets whether elements can be dropped onto this\r\n * Interactable to trigger drop events\r\n *\r\n * Dropzones can receive the following events:\r\n *  - `dropactivate` and `dropdeactivate` when an acceptable drag starts and ends\r\n *  - `dragenter` and `dragleave` when a draggable enters and leaves the dropzone\r\n *  - `dragmove` when a draggable that has entered the dropzone is moved\r\n *  - `drop` when a draggable is dropped into this dropzone\r\n *\r\n * Use the `accept` option to allow only elements that match the given CSS\r\n * selector or element. The value can be:\r\n *\r\n *  - **an Element** - only that element can be dropped into this dropzone.\r\n *  - **a string**, - the element being dragged must match it as a CSS selector.\r\n *  - **`null`** - accept options is cleared - it accepts any element.\r\n *\r\n * Use the `overlap` option to set how drops are checked for. The allowed\r\n * values are:\r\n *\r\n *   - `'pointer'`, the pointer must be over the dropzone (default)\r\n *   - `'center'`, the draggable element's center must be over the dropzone\r\n *   - a number from 0-1 which is the `(intersection area) / (draggable area)`.\r\n *   e.g. `0.5` for drop to happen when half of the area of the draggable is\r\n *   over the dropzone\r\n *\r\n * Use the `checker` option to specify a function to check if a dragged\r\n * element is over this Interactable.\r\n *\r\n | interact(target)\r\n | .dropChecker(function(dragEvent,         // related dragmove or dragend event\r\n |                       event,             // TouchEvent/PointerEvent/MouseEvent\r\n |                       dropped,           // bool result of the default checker\r\n |                       dropzone,          // dropzone Interactable\r\n |                       dropElement,       // dropzone elemnt\r\n |                       draggable,         // draggable Interactable\r\n |                       draggableElement) {// draggable element\r\n |\r\n |   return dropped && event.target.hasAttribute('allow-drop');\r\n | }\r\n *\r\n *\r\n - options (boolean | object | null) #optional The new value to be set.\r\n | interact('.drop').dropzone({\r\n |   accept: '.can-drop' || document.getElementById('single-drop'),\r\n |   overlap: 'pointer' || 'center' || zeroToOne\r\n | }\r\n = (boolean | object) The current setting or this Interactable\r\n\\*/\r\nInteractable.prototype.dropzone = function (options) {\r\n  if (utils.is.object(options)) {\r\n    this.options.drop.enabled = options.enabled === false ? false : true;\r\n\r\n    if (utils.is.function(options.ondrop)) {\r\n      this.events.ondrop = options.ondrop;\r\n    }\r\n    if (utils.is.function(options.ondropactivate)) {\r\n      this.events.ondropactivate = options.ondropactivate;\r\n    }\r\n    if (utils.is.function(options.ondropdeactivate)) {\r\n      this.events.ondropdeactivate = options.ondropdeactivate;\r\n    }\r\n    if (utils.is.function(options.ondragenter)) {\r\n      this.events.ondragenter = options.ondragenter;\r\n    }\r\n    if (utils.is.function(options.ondragleave)) {\r\n      this.events.ondragleave = options.ondragleave;\r\n    }\r\n    if (utils.is.function(options.ondropmove)) {\r\n      this.events.ondropmove = options.ondropmove;\r\n    }\r\n\r\n    if (/^(pointer|center)$/.test(options.overlap)) {\r\n      this.options.drop.overlap = options.overlap;\r\n    } else if (utils.is.number(options.overlap)) {\r\n      this.options.drop.overlap = Math.max(Math.min(1, options.overlap), 0);\r\n    }\r\n    if ('accept' in options) {\r\n      this.options.drop.accept = options.accept;\r\n    }\r\n    if ('checker' in options) {\r\n      this.options.drop.checker = options.checker;\r\n    }\r\n\r\n    return this;\r\n  }\r\n\r\n  if (utils.is.bool(options)) {\r\n    this.options.drop.enabled = options;\r\n\r\n    if (!options) {\r\n      this.ondragenter = this.ondragleave = this.ondrop = this.ondropactivate = this.ondropdeactivate = null;\r\n    }\r\n\r\n    return this;\r\n  }\r\n\r\n  return this.options.drop;\r\n};\r\n\r\nInteractable.prototype.dropCheck = function (dragEvent, event, draggable, draggableElement, dropElement, rect) {\r\n  var dropped = false;\r\n\r\n  // if the dropzone has no rect (eg. display: none)\r\n  // call the custom dropChecker or just return false\r\n  if (!(rect = rect || this.getRect(dropElement))) {\r\n    return this.options.drop.checker ? this.options.drop.checker(dragEvent, event, dropped, this, dropElement, draggable, draggableElement) : false;\r\n  }\r\n\r\n  var dropOverlap = this.options.drop.overlap;\r\n\r\n  if (dropOverlap === 'pointer') {\r\n    var origin = utils.getOriginXY(draggable, draggableElement, 'drag');\r\n    var page = utils.getPageXY(dragEvent);\r\n\r\n    page.x += origin.x;\r\n    page.y += origin.y;\r\n\r\n    var horizontal = page.x > rect.left && page.x < rect.right;\r\n    var vertical = page.y > rect.top && page.y < rect.bottom;\r\n\r\n    dropped = horizontal && vertical;\r\n  }\r\n\r\n  var dragRect = draggable.getRect(draggableElement);\r\n\r\n  if (dragRect && dropOverlap === 'center') {\r\n    var cx = dragRect.left + dragRect.width / 2;\r\n    var cy = dragRect.top + dragRect.height / 2;\r\n\r\n    dropped = cx >= rect.left && cx <= rect.right && cy >= rect.top && cy <= rect.bottom;\r\n  }\r\n\r\n  if (dragRect && utils.is.number(dropOverlap)) {\r\n    var overlapArea = Math.max(0, Math.min(rect.right, dragRect.right) - Math.max(rect.left, dragRect.left)) * Math.max(0, Math.min(rect.bottom, dragRect.bottom) - Math.max(rect.top, dragRect.top));\r\n\r\n    var overlapRatio = overlapArea / (dragRect.width * dragRect.height);\r\n\r\n    dropped = overlapRatio >= dropOverlap;\r\n  }\r\n\r\n  if (this.options.drop.checker) {\r\n    dropped = this.options.drop.checker(dragEvent, event, dropped, this, dropElement, draggable, draggableElement);\r\n  }\r\n\r\n  return dropped;\r\n};\r\n\r\nInteractable.signals.on('unset', function (_ref7) {\r\n  var interactable = _ref7.interactable;\r\n\r\n  interactable.dropzone(false);\r\n});\r\n\r\nInteractable.settingsMethods.push('dropChecker');\r\n\r\nInteraction.signals.on('new', function (interaction) {\r\n  interaction.dropTarget = null; // the dropzone a drag target might be dropped into\r\n  interaction.dropElement = null; // the element at the time of checking\r\n  interaction.prevDropTarget = null; // the dropzone that was recently dragged away from\r\n  interaction.prevDropElement = null; // the element at the time of checking\r\n  interaction.dropEvents = null; // the dropEvents related to the current drag event\r\n\r\n  interaction.activeDrops = {\r\n    dropzones: [], // the dropzones that are mentioned below\r\n    elements: [], // elements of dropzones that accept the target draggable\r\n    rects: [] // the rects of the elements mentioned above\r\n  };\r\n});\r\n\r\nInteraction.signals.on('stop', function (_ref8) {\r\n  var interaction = _ref8.interaction;\r\n\r\n  interaction.dropTarget = interaction.dropElement = interaction.prevDropTarget = interaction.prevDropElement = null;\r\n});\r\n\r\n/*\\\r\n * interact.dynamicDrop\r\n [ method ]\r\n *\r\n * Returns or sets whether the dimensions of dropzone elements are\r\n * calculated on every dragmove or only on dragstart for the default\r\n * dropChecker\r\n *\r\n - newValue (boolean) #optional True to check on each move. False to check only before start\r\n = (boolean | interact) The current setting or interact\r\n\\*/\r\ninteract.dynamicDrop = function (newValue) {\r\n  if (utils.is.bool(newValue)) {\r\n    //if (dragging && dynamicDrop !== newValue && !newValue) {\r\n    //calcRects(dropzones);\r\n    //}\r\n\r\n    dynamicDrop = newValue;\r\n\r\n    return interact;\r\n  }\r\n  return dynamicDrop;\r\n};\r\n\r\nutils.merge(Interactable.eventTypes, ['dragenter', 'dragleave', 'dropactivate', 'dropdeactivate', 'dropmove', 'drop']);\r\nactions.methodDict.drop = 'dropzone';\r\n\r\ndefaultOptions.drop = drop.defaults;\r\n\r\nmodule.exports = drop;\r\n\r\n},{\"../InteractEvent\":3,\"../Interactable\":4,\"../Interaction\":5,\"../defaultOptions\":18,\"../interact\":21,\"../scope\":34,\"../utils\":44,\"./base\":6}],9:[function(require,module,exports){\r\n'use strict';\r\n\r\nvar actions = require('./base');\r\nvar utils = require('../utils');\r\nvar InteractEvent = require('../InteractEvent');\r\nvar Interactable = require('../Interactable');\r\nvar Interaction = require('../Interaction');\r\nvar defaultOptions = require('../defaultOptions');\r\n\r\nvar gesture = {\r\n  defaults: {\r\n    enabled: false,\r\n    origin: null,\r\n    restrict: null\r\n  },\r\n\r\n  checker: function checker(pointer, event, interactable, element, interaction) {\r\n    if (interaction.pointerIds.length >= 2) {\r\n      return { name: 'gesture' };\r\n    }\r\n\r\n    return null;\r\n  },\r\n\r\n  getCursor: function getCursor() {\r\n    return '';\r\n  }\r\n};\r\n\r\nInteractEvent.signals.on('new', function (_ref) {\r\n  var iEvent = _ref.iEvent,\r\n      interaction = _ref.interaction;\r\n\r\n  if (iEvent.type !== 'gesturestart') {\r\n    return;\r\n  }\r\n  iEvent.ds = 0;\r\n\r\n  interaction.gesture.startDistance = interaction.gesture.prevDistance = iEvent.distance;\r\n  interaction.gesture.startAngle = interaction.gesture.prevAngle = iEvent.angle;\r\n  interaction.gesture.scale = 1;\r\n});\r\n\r\nInteractEvent.signals.on('new', function (_ref2) {\r\n  var iEvent = _ref2.iEvent,\r\n      interaction = _ref2.interaction;\r\n\r\n  if (iEvent.type !== 'gesturemove') {\r\n    return;\r\n  }\r\n\r\n  iEvent.ds = iEvent.scale - interaction.gesture.scale;\r\n\r\n  interaction.target.fire(iEvent);\r\n\r\n  interaction.gesture.prevAngle = iEvent.angle;\r\n  interaction.gesture.prevDistance = iEvent.distance;\r\n\r\n  if (iEvent.scale !== Infinity && iEvent.scale !== null && iEvent.scale !== undefined && !isNaN(iEvent.scale)) {\r\n\r\n    interaction.gesture.scale = iEvent.scale;\r\n  }\r\n});\r\n\r\n/*\\\r\n * Interactable.gesturable\r\n [ method ]\r\n *\r\n * Gets or sets whether multitouch gestures can be performed on the\r\n * Interactable's element\r\n *\r\n = (boolean) Indicates if this can be the target of gesture events\r\n   | var isGestureable = interact(element).gesturable();\r\n * or\r\n - options (boolean | object) #optional true/false or An object with event listeners to be fired on gesture events (makes the Interactable gesturable)\r\n = (object) this Interactable\r\n | interact(element).gesturable({\r\n |     onstart: function (event) {},\r\n |     onmove : function (event) {},\r\n |     onend  : function (event) {},\r\n |\r\n |     // limit multiple gestures.\r\n |     // See the explanation in @Interactable.draggable example\r\n |     max: Infinity,\r\n |     maxPerElement: 1,\r\n | });\r\n\\*/\r\nInteractable.prototype.gesturable = function (options) {\r\n  if (utils.is.object(options)) {\r\n    this.options.gesture.enabled = options.enabled === false ? false : true;\r\n    this.setPerAction('gesture', options);\r\n    this.setOnEvents('gesture', options);\r\n\r\n    return this;\r\n  }\r\n\r\n  if (utils.is.bool(options)) {\r\n    this.options.gesture.enabled = options;\r\n\r\n    if (!options) {\r\n      this.ongesturestart = this.ongesturestart = this.ongestureend = null;\r\n    }\r\n\r\n    return this;\r\n  }\r\n\r\n  return this.options.gesture;\r\n};\r\n\r\nInteractEvent.signals.on('set-delta', function (_ref3) {\r\n  var interaction = _ref3.interaction,\r\n      iEvent = _ref3.iEvent,\r\n      action = _ref3.action,\r\n      event = _ref3.event,\r\n      starting = _ref3.starting,\r\n      ending = _ref3.ending,\r\n      deltaSource = _ref3.deltaSource;\r\n\r\n  if (action !== 'gesture') {\r\n    return;\r\n  }\r\n\r\n  var pointers = interaction.pointers;\r\n\r\n  iEvent.touches = [pointers[0], pointers[1]];\r\n\r\n  if (starting) {\r\n    iEvent.distance = utils.touchDistance(pointers, deltaSource);\r\n    iEvent.box = utils.touchBBox(pointers);\r\n    iEvent.scale = 1;\r\n    iEvent.ds = 0;\r\n    iEvent.angle = utils.touchAngle(pointers, undefined, deltaSource);\r\n    iEvent.da = 0;\r\n  } else if (ending || event instanceof InteractEvent) {\r\n    iEvent.distance = interaction.prevEvent.distance;\r\n    iEvent.box = interaction.prevEvent.box;\r\n    iEvent.scale = interaction.prevEvent.scale;\r\n    iEvent.ds = iEvent.scale - 1;\r\n    iEvent.angle = interaction.prevEvent.angle;\r\n    iEvent.da = iEvent.angle - interaction.gesture.startAngle;\r\n  } else {\r\n    iEvent.distance = utils.touchDistance(pointers, deltaSource);\r\n    iEvent.box = utils.touchBBox(pointers);\r\n    iEvent.scale = iEvent.distance / interaction.gesture.startDistance;\r\n    iEvent.angle = utils.touchAngle(pointers, interaction.gesture.prevAngle, deltaSource);\r\n\r\n    iEvent.ds = iEvent.scale - interaction.gesture.prevScale;\r\n    iEvent.da = iEvent.angle - interaction.gesture.prevAngle;\r\n  }\r\n});\r\n\r\nInteraction.signals.on('new', function (interaction) {\r\n  interaction.gesture = {\r\n    start: { x: 0, y: 0 },\r\n\r\n    startDistance: 0, // distance between two touches of touchStart\r\n    prevDistance: 0,\r\n    distance: 0,\r\n\r\n    scale: 1, // gesture.distance / gesture.startDistance\r\n\r\n    startAngle: 0, // angle of line joining two touches\r\n    prevAngle: 0 // angle of the previous gesture event\r\n  };\r\n});\r\n\r\nactions.gesture = gesture;\r\nactions.names.push('gesture');\r\nutils.merge(Interactable.eventTypes, ['gesturestart', 'gesturemove', 'gestureend']);\r\nactions.methodDict.gesture = 'gesturable';\r\n\r\ndefaultOptions.gesture = gesture.defaults;\r\n\r\nmodule.exports = gesture;\r\n\r\n},{\"../InteractEvent\":3,\"../Interactable\":4,\"../Interaction\":5,\"../defaultOptions\":18,\"../utils\":44,\"./base\":6}],10:[function(require,module,exports){\r\n'use strict';\r\n\r\nvar actions = require('./base');\r\nvar utils = require('../utils');\r\nvar browser = require('../utils/browser');\r\nvar InteractEvent = require('../InteractEvent');\r\nvar Interactable = require('../Interactable');\r\nvar Interaction = require('../Interaction');\r\nvar defaultOptions = require('../defaultOptions');\r\n\r\n// Less Precision with touch input\r\nvar defaultMargin = browser.supportsTouch || browser.supportsPointerEvent ? 20 : 10;\r\n\r\nvar resize = {\r\n  defaults: {\r\n    enabled: false,\r\n    mouseButtons: null,\r\n\r\n    origin: null,\r\n    snap: null,\r\n    restrict: null,\r\n    inertia: null,\r\n    autoScroll: null,\r\n\r\n    square: false,\r\n    preserveAspectRatio: false,\r\n    axis: 'xy',\r\n\r\n    // use default margin\r\n    margin: NaN,\r\n\r\n    // object with props left, right, top, bottom which are\r\n    // true/false values to resize when the pointer is over that edge,\r\n    // CSS selectors to match the handles for each direction\r\n    // or the Elements for each handle\r\n    edges: null,\r\n\r\n    // a value of 'none' will limit the resize rect to a minimum of 0x0\r\n    // 'negate' will alow the rect to have negative width/height\r\n    // 'reposition' will keep the width/height positive by swapping\r\n    // the top and bottom edges and/or swapping the left and right edges\r\n    invert: 'none'\r\n  },\r\n\r\n  checker: function checker(pointer, event, interactable, element, interaction, rect) {\r\n    if (!rect) {\r\n      return null;\r\n    }\r\n\r\n    var page = utils.extend({}, interaction.curCoords.page);\r\n    var options = interactable.options;\r\n\r\n    if (options.resize.enabled) {\r\n      var resizeOptions = options.resize;\r\n      var resizeEdges = { left: false, right: false, top: false, bottom: false };\r\n\r\n      // if using resize.edges\r\n      if (utils.is.object(resizeOptions.edges)) {\r\n        for (var edge in resizeEdges) {\r\n          resizeEdges[edge] = checkResizeEdge(edge, resizeOptions.edges[edge], page, interaction._eventTarget, element, rect, resizeOptions.margin || defaultMargin);\r\n        }\r\n\r\n        resizeEdges.left = resizeEdges.left && !resizeEdges.right;\r\n        resizeEdges.top = resizeEdges.top && !resizeEdges.bottom;\r\n\r\n        if (resizeEdges.left || resizeEdges.right || resizeEdges.top || resizeEdges.bottom) {\r\n          return {\r\n            name: 'resize',\r\n            edges: resizeEdges\r\n          };\r\n        }\r\n      } else {\r\n        var right = options.resize.axis !== 'y' && page.x > rect.right - defaultMargin;\r\n        var bottom = options.resize.axis !== 'x' && page.y > rect.bottom - defaultMargin;\r\n\r\n        if (right || bottom) {\r\n          return {\r\n            name: 'resize',\r\n            axes: (right ? 'x' : '') + (bottom ? 'y' : '')\r\n          };\r\n        }\r\n      }\r\n    }\r\n\r\n    return null;\r\n  },\r\n\r\n  cursors: browser.isIe9OrOlder ? {\r\n    x: 'e-resize',\r\n    y: 's-resize',\r\n    xy: 'se-resize',\r\n\r\n    top: 'n-resize',\r\n    left: 'w-resize',\r\n    bottom: 's-resize',\r\n    right: 'e-resize',\r\n    topleft: 'se-resize',\r\n    bottomright: 'se-resize',\r\n    topright: 'ne-resize',\r\n    bottomleft: 'ne-resize'\r\n  } : {\r\n    x: 'ew-resize',\r\n    y: 'ns-resize',\r\n    xy: 'nwse-resize',\r\n\r\n    top: 'ns-resize',\r\n    left: 'ew-resize',\r\n    bottom: 'ns-resize',\r\n    right: 'ew-resize',\r\n    topleft: 'nwse-resize',\r\n    bottomright: 'nwse-resize',\r\n    topright: 'nesw-resize',\r\n    bottomleft: 'nesw-resize'\r\n  },\r\n\r\n  getCursor: function getCursor(action) {\r\n    if (action.axis) {\r\n      return resize.cursors[action.name + action.axis];\r\n    } else if (action.edges) {\r\n      var cursorKey = '';\r\n      var edgeNames = ['top', 'bottom', 'left', 'right'];\r\n\r\n      for (var i = 0; i < 4; i++) {\r\n        if (action.edges[edgeNames[i]]) {\r\n          cursorKey += edgeNames[i];\r\n        }\r\n      }\r\n\r\n      return resize.cursors[cursorKey];\r\n    }\r\n  }\r\n};\r\n\r\n// resizestart\r\nInteractEvent.signals.on('new', function (_ref) {\r\n  var iEvent = _ref.iEvent,\r\n      interaction = _ref.interaction;\r\n\r\n  if (iEvent.type !== 'resizestart' || !interaction.prepared.edges) {\r\n    return;\r\n  }\r\n\r\n  var startRect = interaction.target.getRect(interaction.element);\r\n  var resizeOptions = interaction.target.options.resize;\r\n\r\n  /*\r\n   * When using the `resizable.square` or `resizable.preserveAspectRatio` options, resizing from one edge\r\n   * will affect another. E.g. with `resizable.square`, resizing to make the right edge larger will make\r\n   * the bottom edge larger by the same amount. We call these 'linked' edges. Any linked edges will depend\r\n   * on the active edges and the edge being interacted with.\r\n   */\r\n  if (resizeOptions.square || resizeOptions.preserveAspectRatio) {\r\n    var linkedEdges = utils.extend({}, interaction.prepared.edges);\r\n\r\n    linkedEdges.top = linkedEdges.top || linkedEdges.left && !linkedEdges.bottom;\r\n    linkedEdges.left = linkedEdges.left || linkedEdges.top && !linkedEdges.right;\r\n    linkedEdges.bottom = linkedEdges.bottom || linkedEdges.right && !linkedEdges.top;\r\n    linkedEdges.right = linkedEdges.right || linkedEdges.bottom && !linkedEdges.left;\r\n\r\n    interaction.prepared._linkedEdges = linkedEdges;\r\n  } else {\r\n    interaction.prepared._linkedEdges = null;\r\n  }\r\n\r\n  // if using `resizable.preserveAspectRatio` option, record aspect ratio at the start of the resize\r\n  if (resizeOptions.preserveAspectRatio) {\r\n    interaction.resizeStartAspectRatio = startRect.width / startRect.height;\r\n  }\r\n\r\n  interaction.resizeRects = {\r\n    start: startRect,\r\n    current: utils.extend({}, startRect),\r\n    inverted: utils.extend({}, startRect),\r\n    previous: utils.extend({}, startRect),\r\n    delta: {\r\n      left: 0, right: 0, width: 0,\r\n      top: 0, bottom: 0, height: 0\r\n    }\r\n  };\r\n\r\n  iEvent.rect = interaction.resizeRects.inverted;\r\n  iEvent.deltaRect = interaction.resizeRects.delta;\r\n});\r\n\r\n// resizemove\r\nInteractEvent.signals.on('new', function (_ref2) {\r\n  var iEvent = _ref2.iEvent,\r\n      phase = _ref2.phase,\r\n      interaction = _ref2.interaction;\r\n\r\n  if (phase !== 'move' || !interaction.prepared.edges) {\r\n    return;\r\n  }\r\n\r\n  var resizeOptions = interaction.target.options.resize;\r\n  var invert = resizeOptions.invert;\r\n  var invertible = invert === 'reposition' || invert === 'negate';\r\n\r\n  var edges = interaction.prepared.edges;\r\n\r\n  var start = interaction.resizeRects.start;\r\n  var current = interaction.resizeRects.current;\r\n  var inverted = interaction.resizeRects.inverted;\r\n  var delta = interaction.resizeRects.delta;\r\n  var previous = utils.extend(interaction.resizeRects.previous, inverted);\r\n  var originalEdges = edges;\r\n\r\n  var dx = iEvent.dx;\r\n  var dy = iEvent.dy;\r\n\r\n  if (resizeOptions.preserveAspectRatio || resizeOptions.square) {\r\n    // `resize.preserveAspectRatio` takes precedence over `resize.square`\r\n    var startAspectRatio = resizeOptions.preserveAspectRatio ? interaction.resizeStartAspectRatio : 1;\r\n\r\n    edges = interaction.prepared._linkedEdges;\r\n\r\n    if (originalEdges.left && originalEdges.bottom || originalEdges.right && originalEdges.top) {\r\n      dy = -dx / startAspectRatio;\r\n    } else if (originalEdges.left || originalEdges.right) {\r\n      dy = dx / startAspectRatio;\r\n    } else if (originalEdges.top || originalEdges.bottom) {\r\n      dx = dy * startAspectRatio;\r\n    }\r\n  }\r\n\r\n  // update the 'current' rect without modifications\r\n  if (edges.top) {\r\n    current.top += dy;\r\n  }\r\n  if (edges.bottom) {\r\n    current.bottom += dy;\r\n  }\r\n  if (edges.left) {\r\n    current.left += dx;\r\n  }\r\n  if (edges.right) {\r\n    current.right += dx;\r\n  }\r\n\r\n  if (invertible) {\r\n    // if invertible, copy the current rect\r\n    utils.extend(inverted, current);\r\n\r\n    if (invert === 'reposition') {\r\n      // swap edge values if necessary to keep width/height positive\r\n      var swap = void 0;\r\n\r\n      if (inverted.top > inverted.bottom) {\r\n        swap = inverted.top;\r\n\r\n        inverted.top = inverted.bottom;\r\n        inverted.bottom = swap;\r\n      }\r\n      if (inverted.left > inverted.right) {\r\n        swap = inverted.left;\r\n\r\n        inverted.left = inverted.right;\r\n        inverted.right = swap;\r\n      }\r\n    }\r\n  } else {\r\n    // if not invertible, restrict to minimum of 0x0 rect\r\n    inverted.top = Math.min(current.top, start.bottom);\r\n    inverted.bottom = Math.max(current.bottom, start.top);\r\n    inverted.left = Math.min(current.left, start.right);\r\n    inverted.right = Math.max(current.right, start.left);\r\n  }\r\n\r\n  inverted.width = inverted.right - inverted.left;\r\n  inverted.height = inverted.bottom - inverted.top;\r\n\r\n  for (var edge in inverted) {\r\n    delta[edge] = inverted[edge] - previous[edge];\r\n  }\r\n\r\n  iEvent.edges = interaction.prepared.edges;\r\n  iEvent.rect = inverted;\r\n  iEvent.deltaRect = delta;\r\n});\r\n\r\n/*\\\r\n * Interactable.resizable\r\n [ method ]\r\n *\r\n * Gets or sets whether resize actions can be performed on the\r\n * Interactable\r\n *\r\n = (boolean) Indicates if this can be the target of resize elements\r\n   | var isResizeable = interact('input[type=text]').resizable();\r\n * or\r\n - options (boolean | object) #optional true/false or An object with event listeners to be fired on resize events (object makes the Interactable resizable)\r\n = (object) This Interactable\r\n   | interact(element).resizable({\r\n   |   onstart: function (event) {},\r\n   |   onmove : function (event) {},\r\n   |   onend  : function (event) {},\r\n   |\r\n   |   edges: {\r\n   |     top   : true,       // Use pointer coords to check for resize.\r\n   |     left  : false,      // Disable resizing from left edge.\r\n   |     bottom: '.resize-s',// Resize if pointer target matches selector\r\n   |     right : handleEl    // Resize if pointer target is the given Element\r\n   |   },\r\n   |\r\n   |     // Width and height can be adjusted independently. When `true`, width and\r\n   |     // height are adjusted at a 1:1 ratio.\r\n   |     square: false,\r\n   |\r\n   |     // Width and height can be adjusted independently. When `true`, width and\r\n   |     // height maintain the aspect ratio they had when resizing started.\r\n   |     preserveAspectRatio: false,\r\n   |\r\n   |   // a value of 'none' will limit the resize rect to a minimum of 0x0\r\n   |   // 'negate' will allow the rect to have negative width/height\r\n   |   // 'reposition' will keep the width/height positive by swapping\r\n   |   // the top and bottom edges and/or swapping the left and right edges\r\n   |   invert: 'none' || 'negate' || 'reposition'\r\n   |\r\n   |   // limit multiple resizes.\r\n   |   // See the explanation in the @Interactable.draggable example\r\n   |   max: Infinity,\r\n   |   maxPerElement: 1,\r\n   | });\r\n  \\*/\r\nInteractable.prototype.resizable = function (options) {\r\n  if (utils.is.object(options)) {\r\n    this.options.resize.enabled = options.enabled === false ? false : true;\r\n    this.setPerAction('resize', options);\r\n    this.setOnEvents('resize', options);\r\n\r\n    if (/^x$|^y$|^xy$/.test(options.axis)) {\r\n      this.options.resize.axis = options.axis;\r\n    } else if (options.axis === null) {\r\n      this.options.resize.axis = defaultOptions.resize.axis;\r\n    }\r\n\r\n    if (utils.is.bool(options.preserveAspectRatio)) {\r\n      this.options.resize.preserveAspectRatio = options.preserveAspectRatio;\r\n    } else if (utils.is.bool(options.square)) {\r\n      this.options.resize.square = options.square;\r\n    }\r\n\r\n    return this;\r\n  }\r\n  if (utils.is.bool(options)) {\r\n    this.options.resize.enabled = options;\r\n\r\n    if (!options) {\r\n      this.onresizestart = this.onresizestart = this.onresizeend = null;\r\n    }\r\n\r\n    return this;\r\n  }\r\n  return this.options.resize;\r\n};\r\n\r\nfunction checkResizeEdge(name, value, page, element, interactableElement, rect, margin) {\r\n  // false, '', undefined, null\r\n  if (!value) {\r\n    return false;\r\n  }\r\n\r\n  // true value, use pointer coords and element rect\r\n  if (value === true) {\r\n    // if dimensions are negative, \"switch\" edges\r\n    var width = utils.is.number(rect.width) ? rect.width : rect.right - rect.left;\r\n    var height = utils.is.number(rect.height) ? rect.height : rect.bottom - rect.top;\r\n\r\n    if (width < 0) {\r\n      if (name === 'left') {\r\n        name = 'right';\r\n      } else if (name === 'right') {\r\n        name = 'left';\r\n      }\r\n    }\r\n    if (height < 0) {\r\n      if (name === 'top') {\r\n        name = 'bottom';\r\n      } else if (name === 'bottom') {\r\n        name = 'top';\r\n      }\r\n    }\r\n\r\n    if (name === 'left') {\r\n      return page.x < (width >= 0 ? rect.left : rect.right) + margin;\r\n    }\r\n    if (name === 'top') {\r\n      return page.y < (height >= 0 ? rect.top : rect.bottom) + margin;\r\n    }\r\n\r\n    if (name === 'right') {\r\n      return page.x > (width >= 0 ? rect.right : rect.left) - margin;\r\n    }\r\n    if (name === 'bottom') {\r\n      return page.y > (height >= 0 ? rect.bottom : rect.top) - margin;\r\n    }\r\n  }\r\n\r\n  // the remaining checks require an element\r\n  if (!utils.is.element(element)) {\r\n    return false;\r\n  }\r\n\r\n  return utils.is.element(value)\r\n  // the value is an element to use as a resize handle\r\n  ? value === element\r\n  // otherwise check if element matches value as selector\r\n  : utils.matchesUpTo(element, value, interactableElement);\r\n}\r\n\r\nInteraction.signals.on('new', function (interaction) {\r\n  interaction.resizeAxes = 'xy';\r\n});\r\n\r\nInteractEvent.signals.on('set-delta', function (_ref3) {\r\n  var interaction = _ref3.interaction,\r\n      iEvent = _ref3.iEvent,\r\n      action = _ref3.action;\r\n\r\n  if (action !== 'resize' || !interaction.resizeAxes) {\r\n    return;\r\n  }\r\n\r\n  var options = interaction.target.options;\r\n\r\n  if (options.resize.square) {\r\n    if (interaction.resizeAxes === 'y') {\r\n      iEvent.dx = iEvent.dy;\r\n    } else {\r\n      iEvent.dy = iEvent.dx;\r\n    }\r\n    iEvent.axes = 'xy';\r\n  } else {\r\n    iEvent.axes = interaction.resizeAxes;\r\n\r\n    if (interaction.resizeAxes === 'x') {\r\n      iEvent.dy = 0;\r\n    } else if (interaction.resizeAxes === 'y') {\r\n      iEvent.dx = 0;\r\n    }\r\n  }\r\n});\r\n\r\nactions.resize = resize;\r\nactions.names.push('resize');\r\nutils.merge(Interactable.eventTypes, ['resizestart', 'resizemove', 'resizeinertiastart', 'resizeinertiaresume', 'resizeend']);\r\nactions.methodDict.resize = 'resizable';\r\n\r\ndefaultOptions.resize = resize.defaults;\r\n\r\nmodule.exports = resize;\r\n\r\n},{\"../InteractEvent\":3,\"../Interactable\":4,\"../Interaction\":5,\"../defaultOptions\":18,\"../utils\":44,\"../utils/browser\":37,\"./base\":6}],11:[function(require,module,exports){\r\n'use strict';\r\n\r\nvar raf = require('./utils/raf');\r\nvar getWindow = require('./utils/window').getWindow;\r\nvar is = require('./utils/is');\r\nvar domUtils = require('./utils/domUtils');\r\nvar Interaction = require('./Interaction');\r\nvar defaultOptions = require('./defaultOptions');\r\n\r\nvar autoScroll = {\r\n  defaults: {\r\n    enabled: false,\r\n    container: null, // the item that is scrolled (Window or HTMLElement)\r\n    margin: 60,\r\n    speed: 300 // the scroll speed in pixels per second\r\n  },\r\n\r\n  interaction: null,\r\n  i: null, // the handle returned by window.setInterval\r\n  x: 0, y: 0, // Direction each pulse is to scroll in\r\n\r\n  isScrolling: false,\r\n  prevTime: 0,\r\n\r\n  start: function start(interaction) {\r\n    autoScroll.isScrolling = true;\r\n    raf.cancel(autoScroll.i);\r\n\r\n    autoScroll.interaction = interaction;\r\n    autoScroll.prevTime = new Date().getTime();\r\n    autoScroll.i = raf.request(autoScroll.scroll);\r\n  },\r\n\r\n  stop: function stop() {\r\n    autoScroll.isScrolling = false;\r\n    raf.cancel(autoScroll.i);\r\n  },\r\n\r\n  // scroll the window by the values in scroll.x/y\r\n  scroll: function scroll() {\r\n    var options = autoScroll.interaction.target.options[autoScroll.interaction.prepared.name].autoScroll;\r\n    var container = options.container || getWindow(autoScroll.interaction.element);\r\n    var now = new Date().getTime();\r\n    // change in time in seconds\r\n    var dt = (now - autoScroll.prevTime) / 1000;\r\n    // displacement\r\n    var s = options.speed * dt;\r\n\r\n    if (s >= 1) {\r\n      if (is.window(container)) {\r\n        container.scrollBy(autoScroll.x * s, autoScroll.y * s);\r\n      } else if (container) {\r\n        container.scrollLeft += autoScroll.x * s;\r\n        container.scrollTop += autoScroll.y * s;\r\n      }\r\n\r\n      autoScroll.prevTime = now;\r\n    }\r\n\r\n    if (autoScroll.isScrolling) {\r\n      raf.cancel(autoScroll.i);\r\n      autoScroll.i = raf.request(autoScroll.scroll);\r\n    }\r\n  },\r\n  check: function check(interactable, actionName) {\r\n    var options = interactable.options;\r\n\r\n    return options[actionName].autoScroll && options[actionName].autoScroll.enabled;\r\n  },\r\n  onInteractionMove: function onInteractionMove(_ref) {\r\n    var interaction = _ref.interaction,\r\n        pointer = _ref.pointer;\r\n\r\n    if (!(interaction.interacting() && autoScroll.check(interaction.target, interaction.prepared.name))) {\r\n      return;\r\n    }\r\n\r\n    if (interaction.simulation) {\r\n      autoScroll.x = autoScroll.y = 0;\r\n      return;\r\n    }\r\n\r\n    var top = void 0;\r\n    var right = void 0;\r\n    var bottom = void 0;\r\n    var left = void 0;\r\n\r\n    var options = interaction.target.options[interaction.prepared.name].autoScroll;\r\n    var container = options.container || getWindow(interaction.element);\r\n\r\n    if (is.window(container)) {\r\n      left = pointer.clientX < autoScroll.margin;\r\n      top = pointer.clientY < autoScroll.margin;\r\n      right = pointer.clientX > container.innerWidth - autoScroll.margin;\r\n      bottom = pointer.clientY > container.innerHeight - autoScroll.margin;\r\n    } else {\r\n      var rect = domUtils.getElementClientRect(container);\r\n\r\n      left = pointer.clientX < rect.left + autoScroll.margin;\r\n      top = pointer.clientY < rect.top + autoScroll.margin;\r\n      right = pointer.clientX > rect.right - autoScroll.margin;\r\n      bottom = pointer.clientY > rect.bottom - autoScroll.margin;\r\n    }\r\n\r\n    autoScroll.x = right ? 1 : left ? -1 : 0;\r\n    autoScroll.y = bottom ? 1 : top ? -1 : 0;\r\n\r\n    if (!autoScroll.isScrolling) {\r\n      // set the autoScroll properties to those of the target\r\n      autoScroll.margin = options.margin;\r\n      autoScroll.speed = options.speed;\r\n\r\n      autoScroll.start(interaction);\r\n    }\r\n  }\r\n};\r\n\r\nInteraction.signals.on('stop-active', function () {\r\n  autoScroll.stop();\r\n});\r\n\r\nInteraction.signals.on('action-move', autoScroll.onInteractionMove);\r\n\r\ndefaultOptions.perAction.autoScroll = autoScroll.defaults;\r\n\r\nmodule.exports = autoScroll;\r\n\r\n},{\"./Interaction\":5,\"./defaultOptions\":18,\"./utils/domUtils\":39,\"./utils/is\":46,\"./utils/raf\":50,\"./utils/window\":52}],12:[function(require,module,exports){\r\n'use strict';\r\n\r\nvar Interactable = require('../Interactable');\r\nvar actions = require('../actions/base');\r\nvar is = require('../utils/is');\r\nvar domUtils = require('../utils/domUtils');\r\n\r\nInteractable.prototype.getAction = function (pointer, event, interaction, element) {\r\n  var action = this.defaultActionChecker(pointer, event, interaction, element);\r\n\r\n  if (this.options.actionChecker) {\r\n    return this.options.actionChecker(pointer, event, action, this, element, interaction);\r\n  }\r\n\r\n  return action;\r\n};\r\n\r\n/*\\\r\n * Interactable.ignoreFrom\r\n [ method ]\r\n *\r\n * If the target of the `mousedown`, `pointerdown` or `touchstart`\r\n * event or any of it's parents match the given CSS selector or\r\n * Element, no drag/resize/gesture is started.\r\n *\r\n - newValue (string | Element | null) #optional a CSS selector string, an Element or `null` to not ignore any elements\r\n = (string | Element | object) The current ignoreFrom value or this Interactable\r\n **\r\n | interact(element, { ignoreFrom: document.getElementById('no-action') });\r\n | // or\r\n | interact(element).ignoreFrom('input, textarea, a');\r\n\\*/\r\nInteractable.prototype.ignoreFrom = function (newValue) {\r\n  return this._backCompatOption('ignoreFrom', newValue);\r\n};\r\n\r\n/*\\\r\n * Interactable.allowFrom\r\n [ method ]\r\n *\r\n * A drag/resize/gesture is started only If the target of the\r\n * `mousedown`, `pointerdown` or `touchstart` event or any of it's\r\n * parents match the given CSS selector or Element.\r\n *\r\n - newValue (string | Element | null) #optional a CSS selector string, an Element or `null` to allow from any element\r\n = (string | Element | object) The current allowFrom value or this Interactable\r\n **\r\n | interact(element, { allowFrom: document.getElementById('drag-handle') });\r\n | // or\r\n | interact(element).allowFrom('.handle');\r\n\\*/\r\nInteractable.prototype.allowFrom = function (newValue) {\r\n  return this._backCompatOption('allowFrom', newValue);\r\n};\r\n\r\nInteractable.prototype.testIgnore = function (ignoreFrom, interactableElement, element) {\r\n  if (!ignoreFrom || !is.element(element)) {\r\n    return false;\r\n  }\r\n\r\n  if (is.string(ignoreFrom)) {\r\n    return domUtils.matchesUpTo(element, ignoreFrom, interactableElement);\r\n  } else if (is.element(ignoreFrom)) {\r\n    return domUtils.nodeContains(ignoreFrom, element);\r\n  }\r\n\r\n  return false;\r\n};\r\n\r\nInteractable.prototype.testAllow = function (allowFrom, interactableElement, element) {\r\n  if (!allowFrom) {\r\n    return true;\r\n  }\r\n\r\n  if (!is.element(element)) {\r\n    return false;\r\n  }\r\n\r\n  if (is.string(allowFrom)) {\r\n    return domUtils.matchesUpTo(element, allowFrom, interactableElement);\r\n  } else if (is.element(allowFrom)) {\r\n    return domUtils.nodeContains(allowFrom, element);\r\n  }\r\n\r\n  return false;\r\n};\r\n\r\nInteractable.prototype.testIgnoreAllow = function (options, interactableElement, eventTarget) {\r\n  return !this.testIgnore(options.ignoreFrom, interactableElement, eventTarget) && this.testAllow(options.allowFrom, interactableElement, eventTarget);\r\n};\r\n\r\n/*\\\r\n * Interactable.actionChecker\r\n [ method ]\r\n *\r\n * Gets or sets the function used to check action to be performed on\r\n * pointerDown\r\n *\r\n - checker (function | null) #optional A function which takes a pointer event, defaultAction string, interactable, element and interaction as parameters and returns an object with name property 'drag' 'resize' or 'gesture' and optionally an `edges` object with boolean 'top', 'left', 'bottom' and right props.\r\n = (Function | Interactable) The checker function or this Interactable\r\n *\r\n | interact('.resize-drag')\r\n |   .resizable(true)\r\n |   .draggable(true)\r\n |   .actionChecker(function (pointer, event, action, interactable, element, interaction) {\r\n |\r\n |   if (interact.matchesSelector(event.target, '.drag-handle') {\r\n |     // force drag with handle target\r\n |     action.name = drag;\r\n |   }\r\n |   else {\r\n |     // resize from the top and right edges\r\n |     action.name  = 'resize';\r\n |     action.edges = { top: true, right: true };\r\n |   }\r\n |\r\n |   return action;\r\n | });\r\n\\*/\r\nInteractable.prototype.actionChecker = function (checker) {\r\n  if (is.function(checker)) {\r\n    this.options.actionChecker = checker;\r\n\r\n    return this;\r\n  }\r\n\r\n  if (checker === null) {\r\n    delete this.options.actionChecker;\r\n\r\n    return this;\r\n  }\r\n\r\n  return this.options.actionChecker;\r\n};\r\n\r\n/*\\\r\n * Interactable.styleCursor\r\n [ method ]\r\n *\r\n * Returns or sets whether the the cursor should be changed depending on the\r\n * action that would be performed if the mouse were pressed and dragged.\r\n *\r\n - newValue (boolean) #optional\r\n = (boolean | Interactable) The current setting or this Interactable\r\n\\*/\r\nInteractable.prototype.styleCursor = function (newValue) {\r\n  if (is.bool(newValue)) {\r\n    this.options.styleCursor = newValue;\r\n\r\n    return this;\r\n  }\r\n\r\n  if (newValue === null) {\r\n    delete this.options.styleCursor;\r\n\r\n    return this;\r\n  }\r\n\r\n  return this.options.styleCursor;\r\n};\r\n\r\nInteractable.prototype.defaultActionChecker = function (pointer, event, interaction, element) {\r\n  var rect = this.getRect(element);\r\n  var action = null;\r\n\r\n  for (var _iterator = actions.names, _isArray = Array.isArray(_iterator), _i = 0, _iterator = _isArray ? _iterator : _iterator[Symbol.iterator]();;) {\r\n    var _ref;\r\n\r\n    if (_isArray) {\r\n      if (_i >= _iterator.length) break;\r\n      _ref = _iterator[_i++];\r\n    } else {\r\n      _i = _iterator.next();\r\n      if (_i.done) break;\r\n      _ref = _i.value;\r\n    }\r\n\r\n    var actionName = _ref;\r\n\r\n    // check mouseButton setting if the pointer is down\r\n    if (interaction.pointerIsDown && interaction.mouse && (event.buttons & this.options[actionName].mouseButtons) === 0) {\r\n      continue;\r\n    }\r\n\r\n    action = actions[actionName].checker(pointer, event, this, element, interaction, rect);\r\n\r\n    if (action) {\r\n      return action;\r\n    }\r\n  }\r\n};\r\n\r\n},{\"../Interactable\":4,\"../actions/base\":6,\"../utils/domUtils\":39,\"../utils/is\":46}],13:[function(require,module,exports){\r\n'use strict';\r\n\r\nvar interact = require('../interact');\r\nvar Interactable = require('../Interactable');\r\nvar Interaction = require('../Interaction');\r\nvar actions = require('../actions/base');\r\nvar defaultOptions = require('../defaultOptions');\r\nvar browser = require('../utils/browser');\r\nvar scope = require('../scope');\r\nvar utils = require('../utils');\r\nvar signals = require('../utils/Signals').new();\r\n\r\nrequire('./InteractableMethods');\r\n\r\nvar autoStart = {\r\n  signals: signals,\r\n  withinInteractionLimit: withinInteractionLimit,\r\n  // Allow this many interactions to happen simultaneously\r\n  maxInteractions: Infinity,\r\n  defaults: {\r\n    perAction: {\r\n      manualStart: false,\r\n      max: Infinity,\r\n      maxPerElement: 1,\r\n      allowFrom: null,\r\n      ignoreFrom: null\r\n    }\r\n  },\r\n  setActionDefaults: function setActionDefaults(action) {\r\n    utils.extend(action.defaults, autoStart.defaults.perAction);\r\n  }\r\n};\r\n\r\n// set cursor style on mousedown\r\nInteraction.signals.on('down', function (_ref) {\r\n  var interaction = _ref.interaction,\r\n      pointer = _ref.pointer,\r\n      event = _ref.event,\r\n      eventTarget = _ref.eventTarget;\r\n\r\n  if (interaction.interacting()) {\r\n    return;\r\n  }\r\n\r\n  var actionInfo = getActionInfo(interaction, pointer, event, eventTarget);\r\n  prepare(interaction, actionInfo);\r\n});\r\n\r\n// set cursor style on mousemove\r\nInteraction.signals.on('move', function (_ref2) {\r\n  var interaction = _ref2.interaction,\r\n      pointer = _ref2.pointer,\r\n      event = _ref2.event,\r\n      eventTarget = _ref2.eventTarget;\r\n\r\n  if (!interaction.mouse || interaction.pointerIsDown || interaction.interacting()) {\r\n    return;\r\n  }\r\n\r\n  var actionInfo = getActionInfo(interaction, pointer, event, eventTarget);\r\n  prepare(interaction, actionInfo);\r\n});\r\n\r\nInteraction.signals.on('move', function (arg) {\r\n  var interaction = arg.interaction,\r\n      event = arg.event;\r\n\r\n\r\n  if (!interaction.pointerIsDown || interaction.interacting() || !interaction.pointerWasMoved || !interaction.prepared.name) {\r\n    return;\r\n  }\r\n\r\n  signals.fire('before-start', arg);\r\n\r\n  var target = interaction.target;\r\n\r\n  if (interaction.prepared.name && target) {\r\n    // check manualStart and interaction limit\r\n    if (target.options[interaction.prepared.name].manualStart || !withinInteractionLimit(target, interaction.element, interaction.prepared)) {\r\n      interaction.stop(event);\r\n    } else {\r\n      interaction.start(interaction.prepared, target, interaction.element);\r\n    }\r\n  }\r\n});\r\n\r\n// Check if the current target supports the action.\r\n// If so, return the validated action. Otherwise, return null\r\nfunction validateAction(action, interactable, element, eventTarget) {\r\n  if (utils.is.object(action) && interactable.testIgnoreAllow(interactable.options[action.name], element, eventTarget) && interactable.options[action.name].enabled && withinInteractionLimit(interactable, element, action)) {\r\n    return action;\r\n  }\r\n\r\n  return null;\r\n}\r\n\r\nfunction validateSelector(interaction, pointer, event, matches, matchElements, eventTarget) {\r\n  for (var i = 0, len = matches.length; i < len; i++) {\r\n    var match = matches[i];\r\n    var matchElement = matchElements[i];\r\n    var action = validateAction(match.getAction(pointer, event, interaction, matchElement), match, matchElement, eventTarget);\r\n\r\n    if (action) {\r\n      return {\r\n        action: action,\r\n        target: match,\r\n        element: matchElement\r\n      };\r\n    }\r\n  }\r\n\r\n  return {};\r\n}\r\n\r\nfunction getActionInfo(interaction, pointer, event, eventTarget) {\r\n  var matches = [];\r\n  var matchElements = [];\r\n\r\n  var element = eventTarget;\r\n  var action = null;\r\n\r\n  function pushMatches(interactable, selector, context) {\r\n    var elements = browser.useMatchesSelectorPolyfill ? context.querySelectorAll(selector) : undefined;\r\n\r\n    if (utils.matchesSelector(element, selector, elements)) {\r\n\r\n      matches.push(interactable);\r\n      matchElements.push(element);\r\n    }\r\n  }\r\n\r\n  while (utils.is.element(element)) {\r\n    matches = [];\r\n    matchElements = [];\r\n\r\n    var elementInteractable = scope.interactables.get(element);\r\n\r\n    if (elementInteractable && (action = validateAction(elementInteractable.getAction(pointer, event, interaction, element, eventTarget), elementInteractable, element, eventTarget)) && !elementInteractable.options[action.name].manualStart) {\r\n      return {\r\n        element: element,\r\n        action: action,\r\n        target: elementInteractable\r\n      };\r\n    } else {\r\n      scope.interactables.forEachSelector(pushMatches, element);\r\n\r\n      var actionInfo = validateSelector(interaction, pointer, event, matches, matchElements, eventTarget);\r\n\r\n      if (actionInfo.action && !actionInfo.target.options[actionInfo.action.name].manualStart) {\r\n        return actionInfo;\r\n      }\r\n    }\r\n\r\n    element = utils.parentNode(element);\r\n  }\r\n\r\n  return {};\r\n}\r\n\r\nfunction prepare(interaction, _ref3) {\r\n  var action = _ref3.action,\r\n      target = _ref3.target,\r\n      element = _ref3.element;\r\n\r\n  action = action || {};\r\n\r\n  if (interaction.target && interaction.target.options.styleCursor) {\r\n    interaction.target._doc.documentElement.style.cursor = '';\r\n  }\r\n\r\n  interaction.target = target;\r\n  interaction.element = element;\r\n  utils.copyAction(interaction.prepared, action);\r\n\r\n  if (target && target.options.styleCursor) {\r\n    var cursor = action ? actions[action.name].getCursor(action) : '';\r\n    interaction.target._doc.documentElement.style.cursor = cursor;\r\n  }\r\n\r\n  signals.fire('prepared', { interaction: interaction });\r\n}\r\n\r\nInteraction.signals.on('stop', function (_ref4) {\r\n  var interaction = _ref4.interaction;\r\n\r\n  var target = interaction.target;\r\n\r\n  if (target && target.options.styleCursor) {\r\n    target._doc.documentElement.style.cursor = '';\r\n  }\r\n});\r\n\r\nInteractable.prototype.getAction = function (pointer, event, interaction, element) {\r\n  var action = this.defaultActionChecker(pointer, event, interaction, element);\r\n\r\n  if (this.options.actionChecker) {\r\n    return this.options.actionChecker(pointer, event, action, this, element, interaction);\r\n  }\r\n\r\n  return action;\r\n};\r\n\r\n/*\\\r\n * Interactable.actionChecker\r\n [ method ]\r\n *\r\n * Gets or sets the function used to check action to be performed on\r\n * pointerDown\r\n *\r\n - checker (function | null) #optional A function which takes a pointer event, defaultAction string, interactable, element and interaction as parameters and returns an object with name property 'drag' 'resize' or 'gesture' and optionally an `edges` object with boolean 'top', 'left', 'bottom' and right props.\r\n = (Function | Interactable) The checker function or this Interactable\r\n *\r\n | interact('.resize-drag')\r\n |   .resizable(true)\r\n |   .draggable(true)\r\n |   .actionChecker(function (pointer, event, action, interactable, element, interaction) {\r\n |\r\n |   if (interact.matchesSelector(event.target, '.drag-handle') {\r\n |     // force drag with handle target\r\n |     action.name = drag;\r\n |   }\r\n |   else {\r\n |     // resize from the top and right edges\r\n |     action.name  = 'resize';\r\n |     action.edges = { top: true, right: true };\r\n |   }\r\n |\r\n |   return action;\r\n | });\r\n\\*/\r\nInteractable.prototype.actionChecker = function (checker) {\r\n  if (utils.is.function(checker)) {\r\n    this.options.actionChecker = checker;\r\n\r\n    return this;\r\n  }\r\n\r\n  if (checker === null) {\r\n    delete this.options.actionChecker;\r\n\r\n    return this;\r\n  }\r\n\r\n  return this.options.actionChecker;\r\n};\r\n\r\n/*\\\r\n * Interactable.styleCursor\r\n [ method ]\r\n *\r\n * Returns or sets whether the the cursor should be changed depending on the\r\n * action that would be performed if the mouse were pressed and dragged.\r\n *\r\n - newValue (boolean) #optional\r\n = (boolean | Interactable) The current setting or this Interactable\r\n\\*/\r\nInteractable.prototype.styleCursor = function (newValue) {\r\n  if (utils.is.bool(newValue)) {\r\n    this.options.styleCursor = newValue;\r\n\r\n    return this;\r\n  }\r\n\r\n  if (newValue === null) {\r\n    delete this.options.styleCursor;\r\n\r\n    return this;\r\n  }\r\n\r\n  return this.options.styleCursor;\r\n};\r\n\r\nInteractable.prototype.defaultActionChecker = function (pointer, event, interaction, element) {\r\n  var rect = this.getRect(element);\r\n  var buttons = event.buttons || {\r\n    0: 1,\r\n    1: 4,\r\n    3: 8,\r\n    4: 16\r\n  }[event.button];\r\n  var action = null;\r\n\r\n  for (var _iterator = actions.names, _isArray = Array.isArray(_iterator), _i = 0, _iterator = _isArray ? _iterator : _iterator[Symbol.iterator]();;) {\r\n    var _ref5;\r\n\r\n    if (_isArray) {\r\n      if (_i >= _iterator.length) break;\r\n      _ref5 = _iterator[_i++];\r\n    } else {\r\n      _i = _iterator.next();\r\n      if (_i.done) break;\r\n      _ref5 = _i.value;\r\n    }\r\n\r\n    var actionName = _ref5;\r\n\r\n    // check mouseButton setting if the pointer is down\r\n    if (interaction.pointerIsDown && interaction.mouse && (buttons & this.options[actionName].mouseButtons) === 0) {\r\n      continue;\r\n    }\r\n\r\n    action = actions[actionName].checker(pointer, event, this, element, interaction, rect);\r\n\r\n    if (action) {\r\n      return action;\r\n    }\r\n  }\r\n};\r\n\r\nfunction withinInteractionLimit(interactable, element, action) {\r\n  var options = interactable.options;\r\n  var maxActions = options[action.name].max;\r\n  var maxPerElement = options[action.name].maxPerElement;\r\n  var activeInteractions = 0;\r\n  var targetCount = 0;\r\n  var targetElementCount = 0;\r\n\r\n  // no actions if any of these values == 0\r\n  if (!(maxActions && maxPerElement && autoStart.maxInteractions)) {\r\n    return;\r\n  }\r\n\r\n  for (var i = 0, len = scope.interactions.length; i < len; i++) {\r\n    var interaction = scope.interactions[i];\r\n    var otherAction = interaction.prepared.name;\r\n\r\n    if (!interaction.interacting()) {\r\n      continue;\r\n    }\r\n\r\n    activeInteractions++;\r\n\r\n    if (activeInteractions >= autoStart.maxInteractions) {\r\n      return false;\r\n    }\r\n\r\n    if (interaction.target !== interactable) {\r\n      continue;\r\n    }\r\n\r\n    targetCount += otherAction === action.name | 0;\r\n\r\n    if (targetCount >= maxActions) {\r\n      return false;\r\n    }\r\n\r\n    if (interaction.element === element) {\r\n      targetElementCount++;\r\n\r\n      if (otherAction !== action.name || targetElementCount >= maxPerElement) {\r\n        return false;\r\n      }\r\n    }\r\n  }\r\n\r\n  return autoStart.maxInteractions > 0;\r\n}\r\n\r\n/*\\\r\n * interact.maxInteractions\r\n [ method ]\r\n **\r\n * Returns or sets the maximum number of concurrent interactions allowed.\r\n * By default only 1 interaction is allowed at a time (for backwards\r\n * compatibility). To allow multiple interactions on the same Interactables\r\n * and elements, you need to enable it in the draggable, resizable and\r\n * gesturable `'max'` and `'maxPerElement'` options.\r\n **\r\n - newValue (number) #optional Any number. newValue <= 0 means no interactions.\r\n\\*/\r\ninteract.maxInteractions = function (newValue) {\r\n  if (utils.is.number(newValue)) {\r\n    autoStart.maxInteractions = newValue;\r\n\r\n    return this;\r\n  }\r\n\r\n  return autoStart.maxInteractions;\r\n};\r\n\r\nInteractable.settingsMethods.push('styleCursor');\r\nInteractable.settingsMethods.push('actionChecker');\r\nInteractable.settingsMethods.push('ignoreFrom');\r\nInteractable.settingsMethods.push('allowFrom');\r\n\r\ndefaultOptions.base.actionChecker = null;\r\ndefaultOptions.base.styleCursor = true;\r\n\r\nutils.extend(defaultOptions.perAction, autoStart.defaults.perAction);\r\n\r\nmodule.exports = autoStart;\r\n\r\n},{\"../Interactable\":4,\"../Interaction\":5,\"../actions/base\":6,\"../defaultOptions\":18,\"../interact\":21,\"../scope\":34,\"../utils\":44,\"../utils/Signals\":35,\"../utils/browser\":37,\"./InteractableMethods\":12}],14:[function(require,module,exports){\r\n'use strict';\r\n\r\nvar autoStart = require('./base');\r\nvar Interaction = require('../Interaction');\r\n\r\nInteraction.signals.on('new', function (interaction) {\r\n  interaction.delayTimer = null;\r\n});\r\n\r\nautoStart.signals.on('prepared', function (_ref) {\r\n  var interaction = _ref.interaction;\r\n\r\n  var actionName = interaction.prepared.name;\r\n\r\n  if (!actionName) {\r\n    return;\r\n  }\r\n\r\n  var delay = interaction.target.options[actionName].delay;\r\n\r\n  if (delay > 0) {\r\n    interaction.delayTimer = setTimeout(function () {\r\n      interaction.start(interaction.prepared, interaction.target, interaction.element);\r\n    }, delay);\r\n  }\r\n});\r\n\r\nInteraction.signals.on('move', function (_ref2) {\r\n  var interaction = _ref2.interaction,\r\n      duplicate = _ref2.duplicate;\r\n\r\n  if (interaction.pointerWasMoved && !duplicate) {\r\n    clearTimeout(interaction.delayTimer);\r\n  }\r\n});\r\n\r\n// prevent regular down->move autoStart\r\nautoStart.signals.on('before-start', function (_ref3) {\r\n  var interaction = _ref3.interaction;\r\n\r\n  var actionName = interaction.prepared.name;\r\n\r\n  if (!actionName) {\r\n    return;\r\n  }\r\n\r\n  var delay = interaction.target.options[actionName].delay;\r\n\r\n  if (delay > 0) {\r\n    interaction.prepared.name = null;\r\n  }\r\n});\r\n\r\n},{\"../Interaction\":5,\"./base\":13}],15:[function(require,module,exports){\r\n'use strict';\r\n\r\nvar autoStart = require('./base');\r\nvar scope = require('../scope');\r\nvar browser = require('../utils/browser');\r\nvar is = require('../utils/is');\r\n\r\nvar _require = require('../utils/domUtils'),\r\n    matchesSelector = _require.matchesSelector,\r\n    parentNode = _require.parentNode;\r\n\r\nautoStart.setActionDefaults(require('../actions/drag'));\r\n\r\nautoStart.signals.on('before-start', function (_ref) {\r\n  var interaction = _ref.interaction,\r\n      eventTarget = _ref.eventTarget,\r\n      dx = _ref.dx,\r\n      dy = _ref.dy;\r\n\r\n  if (interaction.prepared.name !== 'drag') {\r\n    return;\r\n  }\r\n\r\n  // check if a drag is in the correct axis\r\n  var absX = Math.abs(dx);\r\n  var absY = Math.abs(dy);\r\n  var options = interaction.target.options.drag;\r\n  var startAxis = options.startAxis;\r\n  var currentAxis = absX > absY ? 'x' : absX < absY ? 'y' : 'xy';\r\n\r\n  interaction.prepared.axis = options.lockAxis === 'start' ? currentAxis[0] // always lock to one axis even if currentAxis === 'xy'\r\n  : options.lockAxis;\r\n\r\n  // if the movement isn't in the startAxis of the interactable\r\n  if (currentAxis !== 'xy' && startAxis !== 'xy' && startAxis !== currentAxis) {\r\n    // cancel the prepared action\r\n    interaction.prepared.name = null;\r\n\r\n    // then try to get a drag from another ineractable\r\n\r\n    if (!interaction.prepared.name) {\r\n\r\n      var element = eventTarget;\r\n\r\n      var getDraggable = function getDraggable(interactable, selector, context) {\r\n        var elements = browser.useMatchesSelectorPolyfill ? context.querySelectorAll(selector) : undefined;\r\n\r\n        if (interactable === interaction.target) {\r\n          return;\r\n        }\r\n\r\n        if (!options.manualStart && !interactable.testIgnoreAllow(options, element, eventTarget) && matchesSelector(element, selector, elements)) {\r\n\r\n          var _action = interactable.getAction(interaction.downPointer, interaction.downEvent, interaction, element);\r\n\r\n          if (_action && _action.name === 'drag' && checkStartAxis(currentAxis, interactable) && autoStart.validateAction(_action, interactable, element, eventTarget)) {\r\n\r\n            return interactable;\r\n          }\r\n        }\r\n      };\r\n\r\n      var action = null;\r\n\r\n      // check all interactables\r\n      while (is.element(element)) {\r\n        var elementInteractable = scope.interactables.get(element);\r\n\r\n        if (elementInteractable && elementInteractable !== interaction.target && !elementInteractable.options.drag.manualStart) {\r\n\r\n          action = elementInteractable.getAction(interaction.downPointer, interaction.downEvent, interaction, element);\r\n        }\r\n        if (action && action.name === 'drag' && checkStartAxis(currentAxis, elementInteractable)) {\r\n\r\n          interaction.prepared.name = 'drag';\r\n          interaction.target = elementInteractable;\r\n          interaction.element = element;\r\n          break;\r\n        }\r\n\r\n        var selectorInteractable = scope.interactables.forEachSelector(getDraggable, element);\r\n\r\n        if (selectorInteractable) {\r\n          interaction.prepared.name = 'drag';\r\n          interaction.target = selectorInteractable;\r\n          interaction.element = element;\r\n          break;\r\n        }\r\n\r\n        element = parentNode(element);\r\n      }\r\n    }\r\n  }\r\n});\r\n\r\nfunction checkStartAxis(startAxis, interactable) {\r\n  if (!interactable) {\r\n    return false;\r\n  }\r\n\r\n  var thisAxis = interactable.options.drag.startAxis;\r\n\r\n  return startAxis === 'xy' || thisAxis === 'xy' || thisAxis === startAxis;\r\n}\r\n\r\n},{\"../actions/drag\":7,\"../scope\":34,\"../utils/browser\":37,\"../utils/domUtils\":39,\"../utils/is\":46,\"./base\":13}],16:[function(require,module,exports){\r\n'use strict';\r\n\r\nrequire('./base').setActionDefaults(require('../actions/gesture'));\r\n\r\n},{\"../actions/gesture\":9,\"./base\":13}],17:[function(require,module,exports){\r\n'use strict';\r\n\r\nrequire('./base').setActionDefaults(require('../actions/resize'));\r\n\r\n},{\"../actions/resize\":10,\"./base\":13}],18:[function(require,module,exports){\r\n'use strict';\r\n\r\nmodule.exports = {\r\n  base: {\r\n    accept: null,\r\n    preventDefault: 'auto',\r\n    deltaSource: 'page'\r\n  },\r\n\r\n  perAction: {\r\n    origin: { x: 0, y: 0 },\r\n\r\n    // only allow left button by default\r\n    // see https://developer.mozilla.org/en-US/docs/Web/API/MouseEvent/buttons#Return_value\r\n    mouseButtons: 1,\r\n\r\n    inertia: {\r\n      enabled: false,\r\n      resistance: 10, // the lambda in exponential decay\r\n      minSpeed: 100, // target speed must be above this for inertia to start\r\n      endSpeed: 10, // the speed at which inertia is slow enough to stop\r\n      allowResume: true, // allow resuming an action in inertia phase\r\n      smoothEndDuration: 300 // animate to snap/restrict endOnly if there's no inertia\r\n    }\r\n  }\r\n};\r\n\r\n},{}],19:[function(require,module,exports){\r\n'use strict';\r\n\r\n/* browser entry point */\r\n\r\n// Legacy browser support\r\nrequire('./legacyBrowsers');\r\n\r\n// inertia\r\nrequire('./inertia');\r\n\r\n// modifiers\r\nrequire('./modifiers/snap');\r\nrequire('./modifiers/restrict');\r\n\r\n// pointerEvents\r\nrequire('./pointerEvents/base');\r\nrequire('./pointerEvents/holdRepeat');\r\nrequire('./pointerEvents/interactableTargets');\r\n\r\n// delay\r\nrequire('./autoStart/delay');\r\n\r\n// actions\r\nrequire('./actions/gesture');\r\nrequire('./actions/resize');\r\nrequire('./actions/drag');\r\nrequire('./actions/drop');\r\n\r\n// load these modifiers after resize is loaded\r\nrequire('./modifiers/snapSize');\r\nrequire('./modifiers/restrictEdges');\r\nrequire('./modifiers/restrictSize');\r\n\r\n// autoStart actions\r\nrequire('./autoStart/gesture');\r\nrequire('./autoStart/resize');\r\nrequire('./autoStart/drag');\r\n\r\n// Interactable preventDefault setting\r\nrequire('./interactablePreventDefault.js');\r\n\r\n// autoScroll\r\nrequire('./autoScroll');\r\n\r\n// export interact\r\nmodule.exports = require('./interact');\r\n\r\n},{\"./actions/drag\":7,\"./actions/drop\":8,\"./actions/gesture\":9,\"./actions/resize\":10,\"./autoScroll\":11,\"./autoStart/delay\":14,\"./autoStart/drag\":15,\"./autoStart/gesture\":16,\"./autoStart/resize\":17,\"./inertia\":20,\"./interact\":21,\"./interactablePreventDefault.js\":22,\"./legacyBrowsers\":23,\"./modifiers/restrict\":25,\"./modifiers/restrictEdges\":26,\"./modifiers/restrictSize\":27,\"./modifiers/snap\":28,\"./modifiers/snapSize\":29,\"./pointerEvents/base\":31,\"./pointerEvents/holdRepeat\":32,\"./pointerEvents/interactableTargets\":33}],20:[function(require,module,exports){\r\n'use strict';\r\n\r\nvar InteractEvent = require('./InteractEvent');\r\nvar Interaction = require('./Interaction');\r\nvar modifiers = require('./modifiers');\r\nvar utils = require('./utils');\r\nvar animationFrame = require('./utils/raf');\r\n\r\nInteraction.signals.on('new', function (interaction) {\r\n  interaction.inertiaStatus = {\r\n    active: false,\r\n    smoothEnd: false,\r\n    allowResume: false,\r\n\r\n    startEvent: null,\r\n    upCoords: {},\r\n\r\n    xe: 0, ye: 0,\r\n    sx: 0, sy: 0,\r\n\r\n    t0: 0,\r\n    vx0: 0, vys: 0,\r\n    duration: 0,\r\n\r\n    lambda_v0: 0,\r\n    one_ve_v0: 0,\r\n    i: null\r\n  };\r\n\r\n  interaction.boundInertiaFrame = function () {\r\n    return inertiaFrame.apply(interaction);\r\n  };\r\n  interaction.boundSmoothEndFrame = function () {\r\n    return smoothEndFrame.apply(interaction);\r\n  };\r\n});\r\n\r\nInteraction.signals.on('down', function (_ref) {\r\n  var interaction = _ref.interaction,\r\n      event = _ref.event,\r\n      pointer = _ref.pointer,\r\n      eventTarget = _ref.eventTarget;\r\n\r\n  var status = interaction.inertiaStatus;\r\n\r\n  // Check if the down event hits the current inertia target\r\n  if (status.active) {\r\n    var element = eventTarget;\r\n\r\n    // climb up the DOM tree from the event target\r\n    while (utils.is.element(element)) {\r\n\r\n      // if interaction element is the current inertia target element\r\n      if (element === interaction.element) {\r\n        // stop inertia\r\n        animationFrame.cancel(status.i);\r\n        status.active = false;\r\n        interaction.simulation = null;\r\n\r\n        // update pointers to the down event's coordinates\r\n        interaction.updatePointer(pointer);\r\n        utils.setCoords(interaction.curCoords, interaction.pointers);\r\n\r\n        // fire appropriate signals\r\n        var signalArg = { interaction: interaction };\r\n        Interaction.signals.fire('before-action-move', signalArg);\r\n        Interaction.signals.fire('action-resume', signalArg);\r\n\r\n        // fire a reume event\r\n        var resumeEvent = new InteractEvent(interaction, event, interaction.prepared.name, 'inertiaresume', interaction.element);\r\n\r\n        interaction.target.fire(resumeEvent);\r\n        interaction.prevEvent = resumeEvent;\r\n        modifiers.resetStatuses(interaction.modifierStatuses);\r\n\r\n        utils.copyCoords(interaction.prevCoords, interaction.curCoords);\r\n        break;\r\n      }\r\n\r\n      element = utils.parentNode(element);\r\n    }\r\n  }\r\n});\r\n\r\nInteraction.signals.on('up', function (_ref2) {\r\n  var interaction = _ref2.interaction,\r\n      event = _ref2.event;\r\n\r\n  var status = interaction.inertiaStatus;\r\n\r\n  if (!interaction.interacting() || status.active) {\r\n    return;\r\n  }\r\n\r\n  var target = interaction.target;\r\n  var options = target && target.options;\r\n  var inertiaOptions = options && interaction.prepared.name && options[interaction.prepared.name].inertia;\r\n\r\n  var now = new Date().getTime();\r\n  var statuses = {};\r\n  var page = utils.extend({}, interaction.curCoords.page);\r\n  var pointerSpeed = interaction.pointerDelta.client.speed;\r\n\r\n  var smoothEnd = false;\r\n  var modifierResult = void 0;\r\n\r\n  // check if inertia should be started\r\n  var inertiaPossible = inertiaOptions && inertiaOptions.enabled && interaction.prepared.name !== 'gesture' && event !== status.startEvent;\r\n\r\n  var inertia = inertiaPossible && now - interaction.curCoords.timeStamp < 50 && pointerSpeed > inertiaOptions.minSpeed && pointerSpeed > inertiaOptions.endSpeed;\r\n\r\n  var modifierArg = {\r\n    interaction: interaction,\r\n    pageCoords: page,\r\n    statuses: statuses,\r\n    preEnd: true,\r\n    requireEndOnly: true\r\n  };\r\n\r\n  // smoothEnd\r\n  if (inertiaPossible && !inertia) {\r\n    modifiers.resetStatuses(statuses);\r\n\r\n    modifierResult = modifiers.setAll(modifierArg);\r\n\r\n    if (modifierResult.shouldMove && modifierResult.locked) {\r\n      smoothEnd = true;\r\n    }\r\n  }\r\n\r\n  if (!(inertia || smoothEnd)) {\r\n    return;\r\n  }\r\n\r\n  utils.copyCoords(status.upCoords, interaction.curCoords);\r\n\r\n  interaction.pointers[0] = status.startEvent = new InteractEvent(interaction, event, interaction.prepared.name, 'inertiastart', interaction.element);\r\n\r\n  status.t0 = now;\r\n\r\n  status.active = true;\r\n  status.allowResume = inertiaOptions.allowResume;\r\n  interaction.simulation = status;\r\n\r\n  target.fire(status.startEvent);\r\n\r\n  if (inertia) {\r\n    status.vx0 = interaction.pointerDelta.client.vx;\r\n    status.vy0 = interaction.pointerDelta.client.vy;\r\n    status.v0 = pointerSpeed;\r\n\r\n    calcInertia(interaction, status);\r\n\r\n    utils.extend(page, interaction.curCoords.page);\r\n\r\n    page.x += status.xe;\r\n    page.y += status.ye;\r\n\r\n    modifiers.resetStatuses(statuses);\r\n\r\n    modifierResult = modifiers.setAll(modifierArg);\r\n\r\n    status.modifiedXe += modifierResult.dx;\r\n    status.modifiedYe += modifierResult.dy;\r\n\r\n    status.i = animationFrame.request(interaction.boundInertiaFrame);\r\n  } else {\r\n    status.smoothEnd = true;\r\n    status.xe = modifierResult.dx;\r\n    status.ye = modifierResult.dy;\r\n\r\n    status.sx = status.sy = 0;\r\n\r\n    status.i = animationFrame.request(interaction.boundSmoothEndFrame);\r\n  }\r\n});\r\n\r\nInteraction.signals.on('stop-active', function (_ref3) {\r\n  var interaction = _ref3.interaction;\r\n\r\n  var status = interaction.inertiaStatus;\r\n\r\n  if (status.active) {\r\n    animationFrame.cancel(status.i);\r\n    status.active = false;\r\n    interaction.simulation = null;\r\n  }\r\n});\r\n\r\nfunction calcInertia(interaction, status) {\r\n  var inertiaOptions = interaction.target.options[interaction.prepared.name].inertia;\r\n  var lambda = inertiaOptions.resistance;\r\n  var inertiaDur = -Math.log(inertiaOptions.endSpeed / status.v0) / lambda;\r\n\r\n  status.x0 = interaction.prevEvent.pageX;\r\n  status.y0 = interaction.prevEvent.pageY;\r\n  status.t0 = status.startEvent.timeStamp / 1000;\r\n  status.sx = status.sy = 0;\r\n\r\n  status.modifiedXe = status.xe = (status.vx0 - inertiaDur) / lambda;\r\n  status.modifiedYe = status.ye = (status.vy0 - inertiaDur) / lambda;\r\n  status.te = inertiaDur;\r\n\r\n  status.lambda_v0 = lambda / status.v0;\r\n  status.one_ve_v0 = 1 - inertiaOptions.endSpeed / status.v0;\r\n}\r\n\r\nfunction inertiaFrame() {\r\n  updateInertiaCoords(this);\r\n  utils.setCoordDeltas(this.pointerDelta, this.prevCoords, this.curCoords);\r\n\r\n  var status = this.inertiaStatus;\r\n  var options = this.target.options[this.prepared.name].inertia;\r\n  var lambda = options.resistance;\r\n  var t = new Date().getTime() / 1000 - status.t0;\r\n\r\n  if (t < status.te) {\r\n\r\n    var progress = 1 - (Math.exp(-lambda * t) - status.lambda_v0) / status.one_ve_v0;\r\n\r\n    if (status.modifiedXe === status.xe && status.modifiedYe === status.ye) {\r\n      status.sx = status.xe * progress;\r\n      status.sy = status.ye * progress;\r\n    } else {\r\n      var quadPoint = utils.getQuadraticCurvePoint(0, 0, status.xe, status.ye, status.modifiedXe, status.modifiedYe, progress);\r\n\r\n      status.sx = quadPoint.x;\r\n      status.sy = quadPoint.y;\r\n    }\r\n\r\n    this.doMove();\r\n\r\n    status.i = animationFrame.request(this.boundInertiaFrame);\r\n  } else {\r\n    status.sx = status.modifiedXe;\r\n    status.sy = status.modifiedYe;\r\n\r\n    this.doMove();\r\n    this.end(status.startEvent);\r\n    status.active = false;\r\n    this.simulation = null;\r\n  }\r\n\r\n  utils.copyCoords(this.prevCoords, this.curCoords);\r\n}\r\n\r\nfunction smoothEndFrame() {\r\n  updateInertiaCoords(this);\r\n\r\n  var status = this.inertiaStatus;\r\n  var t = new Date().getTime() - status.t0;\r\n  var duration = this.target.options[this.prepared.name].inertia.smoothEndDuration;\r\n\r\n  if (t < duration) {\r\n    status.sx = utils.easeOutQuad(t, 0, status.xe, duration);\r\n    status.sy = utils.easeOutQuad(t, 0, status.ye, duration);\r\n\r\n    this.pointerMove(status.startEvent, status.startEvent);\r\n\r\n    status.i = animationFrame.request(this.boundSmoothEndFrame);\r\n  } else {\r\n    status.sx = status.xe;\r\n    status.sy = status.ye;\r\n\r\n    this.pointerMove(status.startEvent, status.startEvent);\r\n    this.end(status.startEvent);\r\n\r\n    status.smoothEnd = status.active = false;\r\n    this.simulation = null;\r\n  }\r\n}\r\n\r\nfunction updateInertiaCoords(interaction) {\r\n  var status = interaction.inertiaStatus;\r\n\r\n  // return if inertia isn't running\r\n  if (!status.active) {\r\n    return;\r\n  }\r\n\r\n  var pageUp = status.upCoords.page;\r\n  var clientUp = status.upCoords.client;\r\n\r\n  utils.setCoords(interaction.curCoords, [{\r\n    pageX: pageUp.x + status.sx,\r\n    pageY: pageUp.y + status.sy,\r\n    clientX: clientUp.x + status.sx,\r\n    clientY: clientUp.y + status.sy\r\n  }]);\r\n}\r\n\r\n},{\"./InteractEvent\":3,\"./Interaction\":5,\"./modifiers\":24,\"./utils\":44,\"./utils/raf\":50}],21:[function(require,module,exports){\r\n'use strict';\r\n\r\nvar browser = require('./utils/browser');\r\nvar events = require('./utils/events');\r\nvar utils = require('./utils');\r\nvar scope = require('./scope');\r\nvar Interactable = require('./Interactable');\r\nvar Interaction = require('./Interaction');\r\n\r\nvar globalEvents = {};\r\n\r\n/*\\\r\n * interact\r\n [ method ]\r\n *\r\n * The methods of this variable can be used to set elements as\r\n * interactables and also to change various default settings.\r\n *\r\n * Calling it as a function and passing an element or a valid CSS selector\r\n * string returns an Interactable object which has various methods to\r\n * configure it.\r\n *\r\n - element (Element | string) The HTML or SVG Element to interact with or CSS selector\r\n = (object) An @Interactable\r\n *\r\n > Usage\r\n | interact('#draggable').draggable(true);\r\n |\r\n | var rectables = interact('rect');\r\n | rectables\r\n |     .gesturable(true)\r\n |     .on('gesturemove', function (event) {\r\n |         // ...\r\n |     });\r\n\\*/\r\nfunction interact(element, options) {\r\n  var interactable = scope.interactables.get(element, options);\r\n\r\n  if (!interactable) {\r\n    interactable = new Interactable(element, options);\r\n    interactable.events.global = globalEvents;\r\n  }\r\n\r\n  return interactable;\r\n}\r\n\r\n/*\\\r\n * interact.isSet\r\n [ method ]\r\n *\r\n * Check if an element has been set\r\n - element (Element) The Element being searched for\r\n = (boolean) Indicates if the element or CSS selector was previously passed to interact\r\n\\*/\r\ninteract.isSet = function (element, options) {\r\n  return scope.interactables.indexOfElement(element, options && options.context) !== -1;\r\n};\r\n\r\n/*\\\r\n * interact.on\r\n [ method ]\r\n *\r\n * Adds a global listener for an InteractEvent or adds a DOM event to\r\n * `document`\r\n *\r\n - type       (string | array | object) The types of events to listen for\r\n - listener   (function) The function event (s)\r\n - options    (object | boolean) #optional options object or useCapture flag for addEventListener\r\n = (object) interact\r\n\\*/\r\ninteract.on = function (type, listener, options) {\r\n  if (utils.is.string(type) && type.search(' ') !== -1) {\r\n    type = type.trim().split(/ +/);\r\n  }\r\n\r\n  if (utils.is.array(type)) {\r\n    for (var _iterator = type, _isArray = Array.isArray(_iterator), _i = 0, _iterator = _isArray ? _iterator : _iterator[Symbol.iterator]();;) {\r\n      var _ref;\r\n\r\n      if (_isArray) {\r\n        if (_i >= _iterator.length) break;\r\n        _ref = _iterator[_i++];\r\n      } else {\r\n        _i = _iterator.next();\r\n        if (_i.done) break;\r\n        _ref = _i.value;\r\n      }\r\n\r\n      var eventType = _ref;\r\n\r\n      interact.on(eventType, listener, options);\r\n    }\r\n\r\n    return interact;\r\n  }\r\n\r\n  if (utils.is.object(type)) {\r\n    for (var prop in type) {\r\n      interact.on(prop, type[prop], listener);\r\n    }\r\n\r\n    return interact;\r\n  }\r\n\r\n  // if it is an InteractEvent type, add listener to globalEvents\r\n  if (utils.contains(Interactable.eventTypes, type)) {\r\n    // if this type of event was never bound\r\n    if (!globalEvents[type]) {\r\n      globalEvents[type] = [listener];\r\n    } else {\r\n      globalEvents[type].push(listener);\r\n    }\r\n  }\r\n  // If non InteractEvent type, addEventListener to document\r\n  else {\r\n      events.add(scope.document, type, listener, { options: options });\r\n    }\r\n\r\n  return interact;\r\n};\r\n\r\n/*\\\r\n * interact.off\r\n [ method ]\r\n *\r\n * Removes a global InteractEvent listener or DOM event from `document`\r\n *\r\n - type       (string | array | object) The types of events that were listened for\r\n - listener   (function) The listener function to be removed\r\n - options    (object | boolean) #optional options object or useCapture flag for removeEventListener\r\n = (object) interact\r\n \\*/\r\ninteract.off = function (type, listener, options) {\r\n  if (utils.is.string(type) && type.search(' ') !== -1) {\r\n    type = type.trim().split(/ +/);\r\n  }\r\n\r\n  if (utils.is.array(type)) {\r\n    for (var _iterator2 = type, _isArray2 = Array.isArray(_iterator2), _i2 = 0, _iterator2 = _isArray2 ? _iterator2 : _iterator2[Symbol.iterator]();;) {\r\n      var _ref2;\r\n\r\n      if (_isArray2) {\r\n        if (_i2 >= _iterator2.length) break;\r\n        _ref2 = _iterator2[_i2++];\r\n      } else {\r\n        _i2 = _iterator2.next();\r\n        if (_i2.done) break;\r\n        _ref2 = _i2.value;\r\n      }\r\n\r\n      var eventType = _ref2;\r\n\r\n      interact.off(eventType, listener, options);\r\n    }\r\n\r\n    return interact;\r\n  }\r\n\r\n  if (utils.is.object(type)) {\r\n    for (var prop in type) {\r\n      interact.off(prop, type[prop], listener);\r\n    }\r\n\r\n    return interact;\r\n  }\r\n\r\n  if (!utils.contains(Interactable.eventTypes, type)) {\r\n    events.remove(scope.document, type, listener, options);\r\n  } else {\r\n    var index = void 0;\r\n\r\n    if (type in globalEvents && (index = utils.indexOf(globalEvents[type], listener)) !== -1) {\r\n      globalEvents[type].splice(index, 1);\r\n    }\r\n  }\r\n\r\n  return interact;\r\n};\r\n\r\n/*\\\r\n * interact.debug\r\n [ method ]\r\n *\r\n * Returns an object which exposes internal data\r\n = (object) An object with properties that outline the current state and expose internal functions and variables\r\n\\*/\r\ninteract.debug = function () {\r\n  return scope;\r\n};\r\n\r\n// expose the functions used to calculate multi-touch properties\r\ninteract.getPointerAverage = utils.pointerAverage;\r\ninteract.getTouchBBox = utils.touchBBox;\r\ninteract.getTouchDistance = utils.touchDistance;\r\ninteract.getTouchAngle = utils.touchAngle;\r\n\r\ninteract.getElementRect = utils.getElementRect;\r\ninteract.getElementClientRect = utils.getElementClientRect;\r\ninteract.matchesSelector = utils.matchesSelector;\r\ninteract.closest = utils.closest;\r\n\r\n/*\\\r\n * interact.supportsTouch\r\n [ method ]\r\n *\r\n = (boolean) Whether or not the browser supports touch input\r\n\\*/\r\ninteract.supportsTouch = function () {\r\n  return browser.supportsTouch;\r\n};\r\n\r\n/*\\\r\n * interact.supportsPointerEvent\r\n [ method ]\r\n *\r\n = (boolean) Whether or not the browser supports PointerEvents\r\n\\*/\r\ninteract.supportsPointerEvent = function () {\r\n  return browser.supportsPointerEvent;\r\n};\r\n\r\n/*\\\r\n * interact.stop\r\n [ method ]\r\n *\r\n * Cancels all interactions (end events are not fired)\r\n *\r\n - event (Event) An event on which to call preventDefault()\r\n = (object) interact\r\n\\*/\r\ninteract.stop = function (event) {\r\n  for (var i = scope.interactions.length - 1; i >= 0; i--) {\r\n    scope.interactions[i].stop(event);\r\n  }\r\n\r\n  return interact;\r\n};\r\n\r\n/*\\\r\n * interact.pointerMoveTolerance\r\n [ method ]\r\n * Returns or sets the distance the pointer must be moved before an action\r\n * sequence occurs. This also affects tolerance for tap events.\r\n *\r\n - newValue (number) #optional The movement from the start position must be greater than this value\r\n = (number | Interactable) The current setting or interact\r\n\\*/\r\ninteract.pointerMoveTolerance = function (newValue) {\r\n  if (utils.is.number(newValue)) {\r\n    Interaction.pointerMoveTolerance = newValue;\r\n\r\n    return this;\r\n  }\r\n\r\n  return Interaction.pointerMoveTolerance;\r\n};\r\n\r\ninteract.addDocument = scope.addDocument;\r\ninteract.removeDocument = scope.removeDocument;\r\n\r\nscope.interact = interact;\r\n\r\nmodule.exports = interact;\r\n\r\n},{\"./Interactable\":4,\"./Interaction\":5,\"./scope\":34,\"./utils\":44,\"./utils/browser\":37,\"./utils/events\":40}],22:[function(require,module,exports){\r\n'use strict';\r\n\r\nvar Interactable = require('./Interactable');\r\nvar Interaction = require('./Interaction');\r\nvar scope = require('./scope');\r\nvar is = require('./utils/is');\r\nvar events = require('./utils/events');\r\n\r\nvar _require = require('./utils/domUtils'),\r\n    nodeContains = _require.nodeContains,\r\n    matchesSelector = _require.matchesSelector;\r\n\r\n/*\\\r\n * Interactable.preventDefault\r\n [ method ]\r\n *\r\n * Returns or sets whether to prevent the browser's default behaviour\r\n * in response to pointer events. Can be set to:\r\n *  - `'always'` to always prevent\r\n *  - `'never'` to never prevent\r\n *  - `'auto'` to let interact.js try to determine what would be best\r\n *\r\n - newValue (string) #optional `true`, `false` or `'auto'`\r\n = (string | Interactable) The current setting or this Interactable\r\n\\*/\r\n\r\n\r\nInteractable.prototype.preventDefault = function (newValue) {\r\n  if (/^(always|never|auto)$/.test(newValue)) {\r\n    this.options.preventDefault = newValue;\r\n    return this;\r\n  }\r\n\r\n  if (is.bool(newValue)) {\r\n    this.options.preventDefault = newValue ? 'always' : 'never';\r\n    return this;\r\n  }\r\n\r\n  return this.options.preventDefault;\r\n};\r\n\r\nInteractable.prototype.checkAndPreventDefault = function (event) {\r\n  var setting = this.options.preventDefault;\r\n\r\n  if (setting === 'never') {\r\n    return;\r\n  }\r\n\r\n  if (setting === 'always') {\r\n    event.preventDefault();\r\n    return;\r\n  }\r\n\r\n  // setting === 'auto'\r\n\r\n  // don't preventDefault if the browser supports passiveEvents\r\n  // CSS touch-action and user-selecct should be used instead\r\n  if (events.supportsOptions) {\r\n    return;\r\n  }\r\n\r\n  // don't preventDefault of pointerdown events\r\n  if (/^(mouse|pointer|touch)*(down|start)/i.test(event.type)) {\r\n    return;\r\n  }\r\n\r\n  // don't preventDefault on editable elements\r\n  if (is.element(event.target) && matchesSelector(event.target, 'input,select,textarea,[contenteditable=true],[contenteditable=true] *')) {\r\n    return;\r\n  }\r\n\r\n  event.preventDefault();\r\n};\r\n\r\nfunction onInteractionEvent(_ref) {\r\n  var interaction = _ref.interaction,\r\n      event = _ref.event;\r\n\r\n  if (interaction.target) {\r\n    interaction.target.checkAndPreventDefault(event);\r\n  }\r\n}\r\n\r\nvar _arr = ['down', 'move', 'up', 'cancel'];\r\nfor (var _i = 0; _i < _arr.length; _i++) {\r\n  var eventSignal = _arr[_i];\r\n  Interaction.signals.on(eventSignal, onInteractionEvent);\r\n}\r\n\r\n// prevent native HTML5 drag on interact.js target elements\r\nInteraction.docEvents.dragstart = function preventNativeDrag(event) {\r\n  for (var _iterator = scope.interactions, _isArray = Array.isArray(_iterator), _i2 = 0, _iterator = _isArray ? _iterator : _iterator[Symbol.iterator]();;) {\r\n    var _ref2;\r\n\r\n    if (_isArray) {\r\n      if (_i2 >= _iterator.length) break;\r\n      _ref2 = _iterator[_i2++];\r\n    } else {\r\n      _i2 = _iterator.next();\r\n      if (_i2.done) break;\r\n      _ref2 = _i2.value;\r\n    }\r\n\r\n    var interaction = _ref2;\r\n\r\n\r\n    if (interaction.element && (interaction.element === event.target || nodeContains(interaction.element, event.target))) {\r\n\r\n      interaction.target.checkAndPreventDefault(event);\r\n      return;\r\n    }\r\n  }\r\n};\r\n\r\n},{\"./Interactable\":4,\"./Interaction\":5,\"./scope\":34,\"./utils/domUtils\":39,\"./utils/events\":40,\"./utils/is\":46}],23:[function(require,module,exports){\r\n'use strict';\r\n\r\nvar scope = require('./scope');\r\nvar events = require('./utils/events');\r\nvar browser = require('./utils/browser');\r\nvar iFinder = require('./utils/interactionFinder');\r\nvar pointerEvents = require('./pointerEvents/base');\r\n\r\nvar _require = require('./utils/window'),\r\n    window = _require.window;\r\n\r\nvar toString = Object.prototype.toString;\r\n\r\nif (!window.Array.isArray) {\r\n  window.Array.isArray = function (obj) {\r\n    return toString.call(obj) === '[object Array]';\r\n  };\r\n}\r\n\r\nif (!String.prototype.trim) {\r\n  String.prototype.trim = function () {\r\n    return this.replace(/^[\\s\\uFEFF\\xA0]+|[\\s\\uFEFF\\xA0]+$/g, '');\r\n  };\r\n}\r\n\r\n// http://www.quirksmode.org/dom/events/click.html\r\n// >Events leading to dblclick\r\n//\r\n// IE8 doesn't fire down event before dblclick.\r\n// This workaround tries to fire a tap and doubletap after dblclick\r\nfunction onIE8Dblclick(event) {\r\n  var eventTarget = event.target;\r\n  var interaction = iFinder.search(event, event.type, eventTarget);\r\n\r\n  if (!interaction) {\r\n    return;\r\n  }\r\n\r\n  if (interaction.prevTap && event.clientX === interaction.prevTap.clientX && event.clientY === interaction.prevTap.clientY && eventTarget === interaction.prevTap.target) {\r\n\r\n    interaction.downTargets[0] = eventTarget;\r\n    interaction.downTimes[0] = new Date().getTime();\r\n\r\n    pointerEvents.fire({\r\n      interaction: interaction,\r\n      event: event,\r\n      eventTarget: eventTarget,\r\n      pointer: event,\r\n      type: 'tap'\r\n    });\r\n  }\r\n}\r\n\r\nif (browser.isIE8) {\r\n  var selectFix = function selectFix(event) {\r\n    for (var _iterator = scope.interactions, _isArray = Array.isArray(_iterator), _i = 0, _iterator = _isArray ? _iterator : _iterator[Symbol.iterator]();;) {\r\n      var _ref;\r\n\r\n      if (_isArray) {\r\n        if (_i >= _iterator.length) break;\r\n        _ref = _iterator[_i++];\r\n      } else {\r\n        _i = _iterator.next();\r\n        if (_i.done) break;\r\n        _ref = _i.value;\r\n      }\r\n\r\n      var interaction = _ref;\r\n\r\n      if (interaction.interacting()) {\r\n        interaction.target.checkAndPreventDefault(event);\r\n      }\r\n    }\r\n  };\r\n\r\n  var onDocIE8 = function onDocIE8(_ref2, signalName) {\r\n    var doc = _ref2.doc,\r\n        win = _ref2.win;\r\n\r\n    var eventMethod = signalName.indexOf('listen') === 0 ? events.add : events.remove;\r\n\r\n    // For IE's lack of Event#preventDefault\r\n    eventMethod(doc, 'selectstart', selectFix);\r\n\r\n    if (pointerEvents) {\r\n      eventMethod(doc, 'dblclick', onIE8Dblclick);\r\n    }\r\n  };\r\n\r\n  scope.signals.on('add-document', onDocIE8);\r\n  scope.signals.on('remove-document', onDocIE8);\r\n}\r\n\r\nmodule.exports = null;\r\n\r\n},{\"./pointerEvents/base\":31,\"./scope\":34,\"./utils/browser\":37,\"./utils/events\":40,\"./utils/interactionFinder\":45,\"./utils/window\":52}],24:[function(require,module,exports){\r\n'use strict';\r\n\r\nvar InteractEvent = require('../InteractEvent');\r\nvar Interaction = require('../Interaction');\r\nvar extend = require('../utils/extend');\r\n\r\nvar modifiers = {\r\n  names: [],\r\n\r\n  setOffsets: function setOffsets(arg) {\r\n    var interaction = arg.interaction,\r\n        page = arg.pageCoords;\r\n    var target = interaction.target,\r\n        element = interaction.element,\r\n        startOffset = interaction.startOffset;\r\n\r\n    var rect = target.getRect(element);\r\n\r\n    if (rect) {\r\n      startOffset.left = page.x - rect.left;\r\n      startOffset.top = page.y - rect.top;\r\n\r\n      startOffset.right = rect.right - page.x;\r\n      startOffset.bottom = rect.bottom - page.y;\r\n\r\n      if (!('width' in rect)) {\r\n        rect.width = rect.right - rect.left;\r\n      }\r\n      if (!('height' in rect)) {\r\n        rect.height = rect.bottom - rect.top;\r\n      }\r\n    } else {\r\n      startOffset.left = startOffset.top = startOffset.right = startOffset.bottom = 0;\r\n    }\r\n\r\n    arg.rect = rect;\r\n    arg.interactable = target;\r\n    arg.element = element;\r\n\r\n    for (var i = 0; i < modifiers.names.length; i++) {\r\n      var modifierName = modifiers.names[i];\r\n\r\n      arg.options = target.options[interaction.prepared.name][modifierName];\r\n\r\n      if (!arg.options) {\r\n        continue;\r\n      }\r\n\r\n      interaction.modifierOffsets[modifierName] = modifiers[modifierName].setOffset(arg);\r\n    }\r\n  },\r\n\r\n  setAll: function setAll(arg) {\r\n    var interaction = arg.interaction,\r\n        statuses = arg.statuses,\r\n        preEnd = arg.preEnd,\r\n        requireEndOnly = arg.requireEndOnly;\r\n\r\n    var coords = extend({}, arg.pageCoords);\r\n    var result = {\r\n      dx: 0,\r\n      dy: 0,\r\n      changed: false,\r\n      locked: false,\r\n      shouldMove: true\r\n    };\r\n\r\n    for (var _iterator = modifiers.names, _isArray = Array.isArray(_iterator), _i = 0, _iterator = _isArray ? _iterator : _iterator[Symbol.iterator]();;) {\r\n      var _ref;\r\n\r\n      if (_isArray) {\r\n        if (_i >= _iterator.length) break;\r\n        _ref = _iterator[_i++];\r\n      } else {\r\n        _i = _iterator.next();\r\n        if (_i.done) break;\r\n        _ref = _i.value;\r\n      }\r\n\r\n      var modifierName = _ref;\r\n\r\n      var modifier = modifiers[modifierName];\r\n      var options = interaction.target.options[interaction.prepared.name][modifierName];\r\n\r\n      if (!shouldDo(options, preEnd, requireEndOnly)) {\r\n        continue;\r\n      }\r\n\r\n      arg.status = arg.status = statuses[modifierName];\r\n      arg.options = options;\r\n      arg.offset = arg.interaction.modifierOffsets[modifierName];\r\n\r\n      modifier.set(arg);\r\n\r\n      if (arg.status.locked) {\r\n        coords.x += arg.status.dx;\r\n        coords.y += arg.status.dy;\r\n\r\n        result.dx += arg.status.dx;\r\n        result.dy += arg.status.dy;\r\n\r\n        result.locked = true;\r\n      }\r\n    }\r\n\r\n    // a move should be fired if:\r\n    //  - there are no modifiers enabled,\r\n    //  - no modifiers are \"locked\" i.e. have changed the pointer's coordinates, or\r\n    //  - the locked coords have changed since the last pointer move\r\n    result.shouldMove = !arg.status || !result.locked || arg.status.changed;\r\n\r\n    return result;\r\n  },\r\n\r\n  resetStatuses: function resetStatuses(statuses) {\r\n    for (var _iterator2 = modifiers.names, _isArray2 = Array.isArray(_iterator2), _i2 = 0, _iterator2 = _isArray2 ? _iterator2 : _iterator2[Symbol.iterator]();;) {\r\n      var _ref2;\r\n\r\n      if (_isArray2) {\r\n        if (_i2 >= _iterator2.length) break;\r\n        _ref2 = _iterator2[_i2++];\r\n      } else {\r\n        _i2 = _iterator2.next();\r\n        if (_i2.done) break;\r\n        _ref2 = _i2.value;\r\n      }\r\n\r\n      var modifierName = _ref2;\r\n\r\n      var status = statuses[modifierName] || {};\r\n\r\n      status.dx = status.dy = 0;\r\n      status.modifiedX = status.modifiedY = NaN;\r\n      status.locked = false;\r\n      status.changed = true;\r\n\r\n      statuses[modifierName] = status;\r\n    }\r\n\r\n    return statuses;\r\n  },\r\n\r\n  start: function start(_ref3, signalName) {\r\n    var interaction = _ref3.interaction;\r\n\r\n    var arg = {\r\n      interaction: interaction,\r\n      pageCoords: (signalName === 'action-resume' ? interaction.curCoords : interaction.startCoords).page,\r\n      startOffset: interaction.startOffset,\r\n      statuses: interaction.modifierStatuses,\r\n      preEnd: false,\r\n      requireEndOnly: false\r\n    };\r\n\r\n    modifiers.setOffsets(arg);\r\n    modifiers.resetStatuses(arg.statuses);\r\n\r\n    arg.pageCoords = extend({}, interaction.startCoords.page);\r\n    interaction.modifierResult = modifiers.setAll(arg);\r\n  }\r\n};\r\n\r\nInteraction.signals.on('new', function (interaction) {\r\n  interaction.startOffset = { left: 0, right: 0, top: 0, bottom: 0 };\r\n  interaction.modifierOffsets = {};\r\n  interaction.modifierStatuses = modifiers.resetStatuses({});\r\n  interaction.modifierResult = null;\r\n});\r\n\r\nInteraction.signals.on('action-start', modifiers.start);\r\nInteraction.signals.on('action-resume', modifiers.start);\r\n\r\nInteraction.signals.on('before-action-move', function (_ref4) {\r\n  var interaction = _ref4.interaction,\r\n      preEnd = _ref4.preEnd,\r\n      interactingBeforeMove = _ref4.interactingBeforeMove;\r\n\r\n  var modifierResult = modifiers.setAll({\r\n    interaction: interaction,\r\n    preEnd: preEnd,\r\n    pageCoords: interaction.curCoords.page,\r\n    statuses: interaction.modifierStatuses,\r\n    requireEndOnly: false\r\n  });\r\n\r\n  // don't fire an action move if a modifier would keep the event in the same\r\n  // cordinates as before\r\n  if (!modifierResult.shouldMove && interactingBeforeMove) {\r\n    interaction._dontFireMove = true;\r\n  }\r\n\r\n  interaction.modifierResult = modifierResult;\r\n});\r\n\r\nInteraction.signals.on('action-end', function (_ref5) {\r\n  var interaction = _ref5.interaction,\r\n      event = _ref5.event;\r\n\r\n  for (var i = 0; i < modifiers.names.length; i++) {\r\n    var options = interaction.target.options[interaction.prepared.name][modifiers.names[i]];\r\n\r\n    // if the endOnly option is true for any modifier\r\n    if (shouldDo(options, true, true)) {\r\n      // fire a move event at the modified coordinates\r\n      interaction.doMove({ event: event, preEnd: true });\r\n      break;\r\n    }\r\n  }\r\n});\r\n\r\nInteractEvent.signals.on('set-xy', function (arg) {\r\n  var iEvent = arg.iEvent,\r\n      interaction = arg.interaction;\r\n\r\n  var modifierArg = extend({}, arg);\r\n\r\n  for (var i = 0; i < modifiers.names.length; i++) {\r\n    var modifierName = modifiers.names[i];\r\n    modifierArg.options = interaction.target.options[interaction.prepared.name][modifierName];\r\n\r\n    if (!modifierArg.options) {\r\n      continue;\r\n    }\r\n\r\n    var modifier = modifiers[modifierName];\r\n\r\n    modifierArg.status = interaction.modifierStatuses[modifierName];\r\n\r\n    iEvent[modifierName] = modifier.modifyCoords(modifierArg);\r\n  }\r\n});\r\n\r\nfunction shouldDo(options, preEnd, requireEndOnly) {\r\n  return options && options.enabled && (preEnd || !options.endOnly) && (!requireEndOnly || options.endOnly);\r\n}\r\n\r\nmodule.exports = modifiers;\r\n\r\n},{\"../InteractEvent\":3,\"../Interaction\":5,\"../utils/extend\":41}],25:[function(require,module,exports){\r\n'use strict';\r\n\r\nvar modifiers = require('./index');\r\nvar utils = require('../utils');\r\nvar defaultOptions = require('../defaultOptions');\r\n\r\nvar restrict = {\r\n  defaults: {\r\n    enabled: false,\r\n    endOnly: false,\r\n    restriction: null,\r\n    elementRect: null\r\n  },\r\n\r\n  setOffset: function setOffset(_ref) {\r\n    var rect = _ref.rect,\r\n        startOffset = _ref.startOffset,\r\n        options = _ref.options;\r\n\r\n    var elementRect = options && options.elementRect;\r\n    var offset = {};\r\n\r\n    if (rect && elementRect) {\r\n      offset.left = startOffset.left - rect.width * elementRect.left;\r\n      offset.top = startOffset.top - rect.height * elementRect.top;\r\n\r\n      offset.right = startOffset.right - rect.width * (1 - elementRect.right);\r\n      offset.bottom = startOffset.bottom - rect.height * (1 - elementRect.bottom);\r\n    } else {\r\n      offset.left = offset.top = offset.right = offset.bottom = 0;\r\n    }\r\n\r\n    return offset;\r\n  },\r\n\r\n  set: function set(_ref2) {\r\n    var pageCoords = _ref2.pageCoords,\r\n        interaction = _ref2.interaction,\r\n        status = _ref2.status,\r\n        options = _ref2.options;\r\n\r\n    if (!options) {\r\n      return status;\r\n    }\r\n\r\n    var page = status.useStatusXY ? { x: status.x, y: status.y } : utils.extend({}, pageCoords);\r\n\r\n    var restriction = getRestrictionRect(options.restriction, interaction, page);\r\n\r\n    if (!restriction) {\r\n      return status;\r\n    }\r\n\r\n    status.dx = 0;\r\n    status.dy = 0;\r\n    status.locked = false;\r\n\r\n    var rect = restriction;\r\n    var modifiedX = page.x;\r\n    var modifiedY = page.y;\r\n\r\n    var offset = interaction.modifierOffsets.restrict;\r\n\r\n    // object is assumed to have\r\n    // x, y, width, height or\r\n    // left, top, right, bottom\r\n    if ('x' in restriction && 'y' in restriction) {\r\n      modifiedX = Math.max(Math.min(rect.x + rect.width - offset.right, page.x), rect.x + offset.left);\r\n      modifiedY = Math.max(Math.min(rect.y + rect.height - offset.bottom, page.y), rect.y + offset.top);\r\n    } else {\r\n      modifiedX = Math.max(Math.min(rect.right - offset.right, page.x), rect.left + offset.left);\r\n      modifiedY = Math.max(Math.min(rect.bottom - offset.bottom, page.y), rect.top + offset.top);\r\n    }\r\n\r\n    status.dx = modifiedX - page.x;\r\n    status.dy = modifiedY - page.y;\r\n\r\n    status.changed = status.modifiedX !== modifiedX || status.modifiedY !== modifiedY;\r\n    status.locked = !!(status.dx || status.dy);\r\n\r\n    status.modifiedX = modifiedX;\r\n    status.modifiedY = modifiedY;\r\n  },\r\n\r\n  modifyCoords: function modifyCoords(_ref3) {\r\n    var page = _ref3.page,\r\n        client = _ref3.client,\r\n        status = _ref3.status,\r\n        phase = _ref3.phase,\r\n        options = _ref3.options;\r\n\r\n    var elementRect = options && options.elementRect;\r\n\r\n    if (options && options.enabled && !(phase === 'start' && elementRect && status.locked)) {\r\n\r\n      if (status.locked) {\r\n        page.x += status.dx;\r\n        page.y += status.dy;\r\n        client.x += status.dx;\r\n        client.y += status.dy;\r\n\r\n        return {\r\n          dx: status.dx,\r\n          dy: status.dy\r\n        };\r\n      }\r\n    }\r\n  },\r\n\r\n  getRestrictionRect: getRestrictionRect\r\n};\r\n\r\nfunction getRestrictionRect(value, interaction, page) {\r\n  if (utils.is.function(value)) {\r\n    return utils.resolveRectLike(value, interaction.target, interaction.element, [page.x, page.y, interaction]);\r\n  } else {\r\n    return utils.resolveRectLike(value, interaction.target, interaction.element);\r\n  }\r\n}\r\n\r\nmodifiers.restrict = restrict;\r\nmodifiers.names.push('restrict');\r\n\r\ndefaultOptions.perAction.restrict = restrict.defaults;\r\n\r\nmodule.exports = restrict;\r\n\r\n},{\"../defaultOptions\":18,\"../utils\":44,\"./index\":24}],26:[function(require,module,exports){\r\n'use strict';\r\n\r\n// This module adds the options.resize.restrictEdges setting which sets min and\r\n// max for the top, left, bottom and right edges of the target being resized.\r\n//\r\n// interact(target).resize({\r\n//   edges: { top: true, left: true },\r\n//   restrictEdges: {\r\n//     inner: { top: 200, left: 200, right: 400, bottom: 400 },\r\n//     outer: { top:   0, left:   0, right: 600, bottom: 600 },\r\n//   },\r\n// });\r\n\r\nvar modifiers = require('./index');\r\nvar utils = require('../utils');\r\nvar rectUtils = require('../utils/rect');\r\nvar defaultOptions = require('../defaultOptions');\r\nvar resize = require('../actions/resize');\r\n\r\nvar _require = require('./restrict'),\r\n    getRestrictionRect = _require.getRestrictionRect;\r\n\r\nvar noInner = { top: +Infinity, left: +Infinity, bottom: -Infinity, right: -Infinity };\r\nvar noOuter = { top: -Infinity, left: -Infinity, bottom: +Infinity, right: +Infinity };\r\n\r\nvar restrictEdges = {\r\n  defaults: {\r\n    enabled: false,\r\n    endOnly: false,\r\n    min: null,\r\n    max: null,\r\n    offset: null\r\n  },\r\n\r\n  setOffset: function setOffset(_ref) {\r\n    var interaction = _ref.interaction,\r\n        startOffset = _ref.startOffset,\r\n        options = _ref.options;\r\n\r\n    if (!options) {\r\n      return utils.extend({}, startOffset);\r\n    }\r\n\r\n    var offset = getRestrictionRect(options.offset, interaction, interaction.startCoords.page);\r\n\r\n    if (offset) {\r\n      return {\r\n        top: startOffset.top + offset.y,\r\n        left: startOffset.left + offset.x,\r\n        bottom: startOffset.bottom + offset.y,\r\n        right: startOffset.right + offset.x\r\n      };\r\n    }\r\n\r\n    return startOffset;\r\n  },\r\n\r\n  set: function set(_ref2) {\r\n    var pageCoords = _ref2.pageCoords,\r\n        interaction = _ref2.interaction,\r\n        status = _ref2.status,\r\n        offset = _ref2.offset,\r\n        options = _ref2.options;\r\n\r\n    var edges = interaction.prepared.linkedEdges || interaction.prepared.edges;\r\n\r\n    if (!interaction.interacting() || !edges) {\r\n      return;\r\n    }\r\n\r\n    var page = status.useStatusXY ? { x: status.x, y: status.y } : utils.extend({}, pageCoords);\r\n    var inner = rectUtils.xywhToTlbr(getRestrictionRect(options.inner, interaction, page)) || noInner;\r\n    var outer = rectUtils.xywhToTlbr(getRestrictionRect(options.outer, interaction, page)) || noOuter;\r\n\r\n    var modifiedX = page.x;\r\n    var modifiedY = page.y;\r\n\r\n    status.dx = 0;\r\n    status.dy = 0;\r\n    status.locked = false;\r\n\r\n    if (edges.top) {\r\n      modifiedY = Math.min(Math.max(outer.top + offset.top, page.y), inner.top + offset.top);\r\n    } else if (edges.bottom) {\r\n      modifiedY = Math.max(Math.min(outer.bottom - offset.bottom, page.y), inner.bottom - offset.bottom);\r\n    }\r\n    if (edges.left) {\r\n      modifiedX = Math.min(Math.max(outer.left + offset.left, page.x), inner.left + offset.left);\r\n    } else if (edges.right) {\r\n      modifiedX = Math.max(Math.min(outer.right - offset.right, page.x), inner.right - offset.right);\r\n    }\r\n\r\n    status.dx = modifiedX - page.x;\r\n    status.dy = modifiedY - page.y;\r\n\r\n    status.changed = status.modifiedX !== modifiedX || status.modifiedY !== modifiedY;\r\n    status.locked = !!(status.dx || status.dy);\r\n\r\n    status.modifiedX = modifiedX;\r\n    status.modifiedY = modifiedY;\r\n  },\r\n\r\n  modifyCoords: function modifyCoords(_ref3) {\r\n    var page = _ref3.page,\r\n        client = _ref3.client,\r\n        status = _ref3.status,\r\n        phase = _ref3.phase,\r\n        options = _ref3.options;\r\n\r\n    if (options && options.enabled && !(phase === 'start' && status.locked)) {\r\n\r\n      if (status.locked) {\r\n        page.x += status.dx;\r\n        page.y += status.dy;\r\n        client.x += status.dx;\r\n        client.y += status.dy;\r\n\r\n        return {\r\n          dx: status.dx,\r\n          dy: status.dy\r\n        };\r\n      }\r\n    }\r\n  },\r\n\r\n  noInner: noInner,\r\n  noOuter: noOuter,\r\n  getRestrictionRect: getRestrictionRect\r\n};\r\n\r\nmodifiers.restrictEdges = restrictEdges;\r\nmodifiers.names.push('restrictEdges');\r\n\r\ndefaultOptions.perAction.restrictEdges = restrictEdges.defaults;\r\nresize.defaults.restrictEdges = restrictEdges.defaults;\r\n\r\nmodule.exports = restrictEdges;\r\n\r\n},{\"../actions/resize\":10,\"../defaultOptions\":18,\"../utils\":44,\"../utils/rect\":51,\"./index\":24,\"./restrict\":25}],27:[function(require,module,exports){\r\n'use strict';\r\n\r\n// This module adds the options.resize.restrictSize setting which sets min and\r\n// max width and height for the target being resized.\r\n//\r\n// interact(target).resize({\r\n//   edges: { top: true, left: true },\r\n//   restrictSize: {\r\n//     min: { width: -600, height: -600 },\r\n//     max: { width:  600, height:  600 },\r\n//   },\r\n// });\r\n\r\nvar modifiers = require('./index');\r\nvar restrictEdges = require('./restrictEdges');\r\nvar utils = require('../utils');\r\nvar rectUtils = require('../utils/rect');\r\nvar defaultOptions = require('../defaultOptions');\r\nvar resize = require('../actions/resize');\r\n\r\nvar noMin = { width: -Infinity, height: -Infinity };\r\nvar noMax = { width: +Infinity, height: +Infinity };\r\n\r\nvar restrictSize = {\r\n  defaults: {\r\n    enabled: false,\r\n    endOnly: false,\r\n    min: null,\r\n    max: null\r\n  },\r\n\r\n  setOffset: function setOffset(_ref) {\r\n    var interaction = _ref.interaction;\r\n\r\n    return interaction.startOffset;\r\n  },\r\n\r\n  set: function set(arg) {\r\n    var interaction = arg.interaction,\r\n        options = arg.options;\r\n\r\n    var edges = interaction.prepared.linkedEdges || interaction.prepared.edges;\r\n\r\n    if (!interaction.interacting() || !edges) {\r\n      return;\r\n    }\r\n\r\n    var rect = rectUtils.xywhToTlbr(interaction.resizeRects.inverted);\r\n\r\n    var minSize = rectUtils.tlbrToXywh(restrictEdges.getRestrictionRect(options.min, interaction)) || noMin;\r\n    var maxSize = rectUtils.tlbrToXywh(restrictEdges.getRestrictionRect(options.max, interaction)) || noMax;\r\n\r\n    arg.options = {\r\n      enabled: options.enabled,\r\n      endOnly: options.endOnly,\r\n      inner: utils.extend({}, restrictEdges.noInner),\r\n      outer: utils.extend({}, restrictEdges.noOuter)\r\n    };\r\n\r\n    if (edges.top) {\r\n      arg.options.inner.top = rect.bottom - minSize.height;\r\n      arg.options.outer.top = rect.bottom - maxSize.height;\r\n    } else if (edges.bottom) {\r\n      arg.options.inner.bottom = rect.top + minSize.height;\r\n      arg.options.outer.bottom = rect.top + maxSize.height;\r\n    }\r\n    if (edges.left) {\r\n      arg.options.inner.left = rect.right - minSize.width;\r\n      arg.options.outer.left = rect.right - maxSize.width;\r\n    } else if (edges.right) {\r\n      arg.options.inner.right = rect.left + minSize.width;\r\n      arg.options.outer.right = rect.left + maxSize.width;\r\n    }\r\n\r\n    restrictEdges.set(arg);\r\n  },\r\n\r\n  modifyCoords: restrictEdges.modifyCoords\r\n};\r\n\r\nmodifiers.restrictSize = restrictSize;\r\nmodifiers.names.push('restrictSize');\r\n\r\ndefaultOptions.perAction.restrictSize = restrictSize.defaults;\r\nresize.defaults.restrictSize = restrictSize.defaults;\r\n\r\nmodule.exports = restrictSize;\r\n\r\n},{\"../actions/resize\":10,\"../defaultOptions\":18,\"../utils\":44,\"../utils/rect\":51,\"./index\":24,\"./restrictEdges\":26}],28:[function(require,module,exports){\r\n'use strict';\r\n\r\nvar modifiers = require('./index');\r\nvar interact = require('../interact');\r\nvar utils = require('../utils');\r\nvar defaultOptions = require('../defaultOptions');\r\n\r\nvar snap = {\r\n  defaults: {\r\n    enabled: false,\r\n    endOnly: false,\r\n    range: Infinity,\r\n    targets: null,\r\n    offsets: null,\r\n\r\n    relativePoints: null\r\n  },\r\n\r\n  setOffset: function setOffset(_ref) {\r\n    var interaction = _ref.interaction,\r\n        interactable = _ref.interactable,\r\n        element = _ref.element,\r\n        rect = _ref.rect,\r\n        startOffset = _ref.startOffset,\r\n        options = _ref.options;\r\n\r\n    var offsets = [];\r\n    var optionsOrigin = utils.rectToXY(utils.resolveRectLike(options.origin));\r\n    var origin = optionsOrigin || utils.getOriginXY(interactable, element, interaction.prepared.name);\r\n    options = options || interactable.options[interaction.prepared.name].snap || {};\r\n\r\n    var snapOffset = void 0;\r\n\r\n    if (options.offset === 'startCoords') {\r\n      snapOffset = {\r\n        x: interaction.startCoords.page.x - origin.x,\r\n        y: interaction.startCoords.page.y - origin.y\r\n      };\r\n    } else {\r\n      var offsetRect = utils.resolveRectLike(options.offset, interactable, element, [interaction]);\r\n\r\n      snapOffset = utils.rectToXY(offsetRect) || { x: 0, y: 0 };\r\n    }\r\n\r\n    if (rect && options.relativePoints && options.relativePoints.length) {\r\n      for (var _iterator = options.relativePoints, _isArray = Array.isArray(_iterator), _i = 0, _iterator = _isArray ? _iterator : _iterator[Symbol.iterator]();;) {\r\n        var _ref2;\r\n\r\n        if (_isArray) {\r\n          if (_i >= _iterator.length) break;\r\n          _ref2 = _iterator[_i++];\r\n        } else {\r\n          _i = _iterator.next();\r\n          if (_i.done) break;\r\n          _ref2 = _i.value;\r\n        }\r\n\r\n        var _ref3 = _ref2,\r\n            relativeX = _ref3.x,\r\n            relativeY = _ref3.y;\r\n\r\n        offsets.push({\r\n          x: startOffset.left - rect.width * relativeX + snapOffset.x,\r\n          y: startOffset.top - rect.height * relativeY + snapOffset.y\r\n        });\r\n      }\r\n    } else {\r\n      offsets.push(snapOffset);\r\n    }\r\n\r\n    return offsets;\r\n  },\r\n\r\n  set: function set(_ref4) {\r\n    var interaction = _ref4.interaction,\r\n        pageCoords = _ref4.pageCoords,\r\n        status = _ref4.status,\r\n        options = _ref4.options,\r\n        offsets = _ref4.offset;\r\n\r\n    var targets = [];\r\n    var target = void 0;\r\n    var page = void 0;\r\n    var i = void 0;\r\n\r\n    if (status.useStatusXY) {\r\n      page = { x: status.x, y: status.y };\r\n    } else {\r\n      var origin = utils.getOriginXY(interaction.target, interaction.element, interaction.prepared.name);\r\n\r\n      page = utils.extend({}, pageCoords);\r\n\r\n      page.x -= origin.x;\r\n      page.y -= origin.y;\r\n    }\r\n\r\n    status.realX = page.x;\r\n    status.realY = page.y;\r\n\r\n    var len = options.targets ? options.targets.length : 0;\r\n\r\n    for (var _iterator2 = offsets, _isArray2 = Array.isArray(_iterator2), _i2 = 0, _iterator2 = _isArray2 ? _iterator2 : _iterator2[Symbol.iterator]();;) {\r\n      var _ref5;\r\n\r\n      if (_isArray2) {\r\n        if (_i2 >= _iterator2.length) break;\r\n        _ref5 = _iterator2[_i2++];\r\n      } else {\r\n        _i2 = _iterator2.next();\r\n        if (_i2.done) break;\r\n        _ref5 = _i2.value;\r\n      }\r\n\r\n      var _ref6 = _ref5,\r\n          offsetX = _ref6.x,\r\n          offsetY = _ref6.y;\r\n\r\n      var relativeX = page.x - offsetX;\r\n      var relativeY = page.y - offsetY;\r\n\r\n      for (var _iterator3 = options.targets, _isArray3 = Array.isArray(_iterator3), _i3 = 0, _iterator3 = _isArray3 ? _iterator3 : _iterator3[Symbol.iterator]();;) {\r\n        var _ref7;\r\n\r\n        if (_isArray3) {\r\n          if (_i3 >= _iterator3.length) break;\r\n          _ref7 = _iterator3[_i3++];\r\n        } else {\r\n          _i3 = _iterator3.next();\r\n          if (_i3.done) break;\r\n          _ref7 = _i3.value;\r\n        }\r\n\r\n        var snapTarget = _ref7;\r\n\r\n        if (utils.is.function(snapTarget)) {\r\n          target = snapTarget(relativeX, relativeY, interaction);\r\n        } else {\r\n          target = snapTarget;\r\n        }\r\n\r\n        if (!target) {\r\n          continue;\r\n        }\r\n\r\n        targets.push({\r\n          x: utils.is.number(target.x) ? target.x + offsetX : relativeX,\r\n          y: utils.is.number(target.y) ? target.y + offsetY : relativeY,\r\n\r\n          range: utils.is.number(target.range) ? target.range : options.range\r\n        });\r\n      }\r\n    }\r\n\r\n    var closest = {\r\n      target: null,\r\n      inRange: false,\r\n      distance: 0,\r\n      range: 0,\r\n      dx: 0,\r\n      dy: 0\r\n    };\r\n\r\n    for (i = 0, len = targets.length; i < len; i++) {\r\n      target = targets[i];\r\n\r\n      var range = target.range;\r\n      var dx = target.x - page.x;\r\n      var dy = target.y - page.y;\r\n      var distance = utils.hypot(dx, dy);\r\n      var inRange = distance <= range;\r\n\r\n      // Infinite targets count as being out of range\r\n      // compared to non infinite ones that are in range\r\n      if (range === Infinity && closest.inRange && closest.range !== Infinity) {\r\n        inRange = false;\r\n      }\r\n\r\n      if (!closest.target || (inRange\r\n      // is the closest target in range?\r\n      ? closest.inRange && range !== Infinity\r\n      // the pointer is relatively deeper in this target\r\n      ? distance / range < closest.distance / closest.range\r\n      // this target has Infinite range and the closest doesn't\r\n      : range === Infinity && closest.range !== Infinity ||\r\n      // OR this target is closer that the previous closest\r\n      distance < closest.distance :\r\n      // The other is not in range and the pointer is closer to this target\r\n      !closest.inRange && distance < closest.distance)) {\r\n\r\n        closest.target = target;\r\n        closest.distance = distance;\r\n        closest.range = range;\r\n        closest.inRange = inRange;\r\n        closest.dx = dx;\r\n        closest.dy = dy;\r\n\r\n        status.range = range;\r\n      }\r\n    }\r\n\r\n    var snapChanged = void 0;\r\n\r\n    if (closest.target) {\r\n      snapChanged = status.modifiedX !== closest.target.x || status.modifiedY !== closest.target.y;\r\n\r\n      status.modifiedX = closest.target.x;\r\n      status.modifiedY = closest.target.y;\r\n    } else {\r\n      snapChanged = true;\r\n\r\n      status.modifiedX = NaN;\r\n      status.modifiedY = NaN;\r\n    }\r\n\r\n    status.dx = closest.dx;\r\n    status.dy = closest.dy;\r\n\r\n    status.changed = snapChanged || closest.inRange && !status.locked;\r\n    status.locked = closest.inRange;\r\n  },\r\n\r\n  modifyCoords: function modifyCoords(_ref8) {\r\n    var page = _ref8.page,\r\n        client = _ref8.client,\r\n        status = _ref8.status,\r\n        phase = _ref8.phase,\r\n        options = _ref8.options;\r\n\r\n    var relativePoints = options && options.relativePoints;\r\n\r\n    if (options && options.enabled && !(phase === 'start' && relativePoints && relativePoints.length)) {\r\n\r\n      if (status.locked) {\r\n        page.x += status.dx;\r\n        page.y += status.dy;\r\n        client.x += status.dx;\r\n        client.y += status.dy;\r\n      }\r\n\r\n      return {\r\n        range: status.range,\r\n        locked: status.locked,\r\n        x: status.modifiedX,\r\n        y: status.modifiedY,\r\n        realX: status.realX,\r\n        realY: status.realY,\r\n        dx: status.dx,\r\n        dy: status.dy\r\n      };\r\n    }\r\n  }\r\n};\r\n\r\ninteract.createSnapGrid = function (grid) {\r\n  return function (x, y) {\r\n    var limits = grid.limits || {\r\n      left: -Infinity,\r\n      right: Infinity,\r\n      top: -Infinity,\r\n      bottom: Infinity\r\n    };\r\n    var offsetX = 0;\r\n    var offsetY = 0;\r\n\r\n    if (utils.is.object(grid.offset)) {\r\n      offsetX = grid.offset.x;\r\n      offsetY = grid.offset.y;\r\n    }\r\n\r\n    var gridx = Math.round((x - offsetX) / grid.x);\r\n    var gridy = Math.round((y - offsetY) / grid.y);\r\n\r\n    var newX = Math.max(limits.left, Math.min(limits.right, gridx * grid.x + offsetX));\r\n    var newY = Math.max(limits.top, Math.min(limits.bottom, gridy * grid.y + offsetY));\r\n\r\n    return {\r\n      x: newX,\r\n      y: newY,\r\n      range: grid.range\r\n    };\r\n  };\r\n};\r\n\r\nmodifiers.snap = snap;\r\nmodifiers.names.push('snap');\r\n\r\ndefaultOptions.perAction.snap = snap.defaults;\r\n\r\nmodule.exports = snap;\r\n\r\n},{\"../defaultOptions\":18,\"../interact\":21,\"../utils\":44,\"./index\":24}],29:[function(require,module,exports){\r\n'use strict';\r\n\r\n// This module allows snapping of the size of targets during resize\r\n// interactions.\r\n\r\nvar modifiers = require('./index');\r\nvar snap = require('./snap');\r\nvar defaultOptions = require('../defaultOptions');\r\nvar resize = require('../actions/resize');\r\nvar utils = require('../utils/');\r\n\r\nvar snapSize = {\r\n  defaults: {\r\n    enabled: false,\r\n    endOnly: false,\r\n    range: Infinity,\r\n    targets: null,\r\n    offsets: null\r\n  },\r\n\r\n  setOffset: function setOffset(arg) {\r\n    var interaction = arg.interaction,\r\n        options = arg.options;\r\n\r\n    var edges = interaction.prepared.edges;\r\n\r\n    if (!edges) {\r\n      return;\r\n    }\r\n\r\n    arg.options = {\r\n      relativePoints: [{\r\n        x: edges.left ? 0 : 1,\r\n        y: edges.top ? 0 : 1\r\n      }],\r\n      origin: { x: 0, y: 0 },\r\n      offset: 'self',\r\n      range: options.range\r\n    };\r\n\r\n    var offsets = snap.setOffset(arg);\r\n    arg.options = options;\r\n\r\n    return offsets;\r\n  },\r\n\r\n  set: function set(arg) {\r\n    var interaction = arg.interaction,\r\n        options = arg.options,\r\n        offset = arg.offset,\r\n        pageCoords = arg.pageCoords;\r\n\r\n    var page = utils.extend({}, pageCoords);\r\n    var relativeX = page.x - offset[0].x;\r\n    var relativeY = page.y - offset[0].y;\r\n\r\n    arg.options = utils.extend({}, options);\r\n    arg.options.targets = [];\r\n\r\n    for (var _iterator = options.targets, _isArray = Array.isArray(_iterator), _i = 0, _iterator = _isArray ? _iterator : _iterator[Symbol.iterator]();;) {\r\n      var _ref;\r\n\r\n      if (_isArray) {\r\n        if (_i >= _iterator.length) break;\r\n        _ref = _iterator[_i++];\r\n      } else {\r\n        _i = _iterator.next();\r\n        if (_i.done) break;\r\n        _ref = _i.value;\r\n      }\r\n\r\n      var snapTarget = _ref;\r\n\r\n      var target = void 0;\r\n\r\n      if (utils.is.function(snapTarget)) {\r\n        target = snapTarget(relativeX, relativeY, interaction);\r\n      } else {\r\n        target = snapTarget;\r\n      }\r\n\r\n      if (!target) {\r\n        continue;\r\n      }\r\n\r\n      if ('width' in target && 'height' in target) {\r\n        target.x = target.width;\r\n        target.y = target.height;\r\n      }\r\n\r\n      arg.options.targets.push(target);\r\n    }\r\n\r\n    snap.set(arg);\r\n  },\r\n\r\n  modifyCoords: function modifyCoords(arg) {\r\n    var options = arg.options;\r\n\r\n\r\n    arg.options = utils.extend({}, options);\r\n    arg.options.enabled = options.enabled;\r\n    arg.options.relativePoints = [null];\r\n\r\n    snap.modifyCoords(arg);\r\n  }\r\n};\r\n\r\nmodifiers.snapSize = snapSize;\r\nmodifiers.names.push('snapSize');\r\n\r\ndefaultOptions.perAction.snapSize = snapSize.defaults;\r\nresize.defaults.snapSize = snapSize.defaults;\r\n\r\nmodule.exports = snapSize;\r\n\r\n},{\"../actions/resize\":10,\"../defaultOptions\":18,\"../utils/\":44,\"./index\":24,\"./snap\":28}],30:[function(require,module,exports){\r\n'use strict';\r\n\r\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\r\n\r\nvar pointerUtils = require('../utils/pointerUtils');\r\n\r\nmodule.exports = function () {\r\n  function PointerEvent(type, pointer, event, eventTarget, interaction) {\r\n    _classCallCheck(this, PointerEvent);\r\n\r\n    pointerUtils.pointerExtend(this, event);\r\n\r\n    if (event !== pointer) {\r\n      pointerUtils.pointerExtend(this, pointer);\r\n    }\r\n\r\n    this.interaction = interaction;\r\n\r\n    this.timeStamp = new Date().getTime();\r\n    this.originalEvent = event;\r\n    this.type = type;\r\n    this.pointerId = pointerUtils.getPointerId(pointer);\r\n    this.pointerType = pointerUtils.getPointerType(pointer);\r\n    this.target = eventTarget;\r\n    this.currentTarget = null;\r\n\r\n    if (type === 'tap') {\r\n      var pointerIndex = interaction.getPointerIndex(pointer);\r\n      this.dt = this.timeStamp - interaction.downTimes[pointerIndex];\r\n\r\n      var interval = this.timeStamp - interaction.tapTime;\r\n\r\n      this.double = !!(interaction.prevTap && interaction.prevTap.type !== 'doubletap' && interaction.prevTap.target === this.target && interval < 500);\r\n    } else if (type === 'doubletap') {\r\n      this.dt = pointer.timeStamp - interaction.tapTime;\r\n    }\r\n  }\r\n\r\n  PointerEvent.prototype.subtractOrigin = function subtractOrigin(_ref) {\r\n    var originX = _ref.x,\r\n        originY = _ref.y;\r\n\r\n    this.pageX -= originX;\r\n    this.pageY -= originY;\r\n    this.clientX -= originX;\r\n    this.clientY -= originY;\r\n\r\n    return this;\r\n  };\r\n\r\n  PointerEvent.prototype.addOrigin = function addOrigin(_ref2) {\r\n    var originX = _ref2.x,\r\n        originY = _ref2.y;\r\n\r\n    this.pageX += originX;\r\n    this.pageY += originY;\r\n    this.clientX += originX;\r\n    this.clientY += originY;\r\n\r\n    return this;\r\n  };\r\n\r\n  PointerEvent.prototype.preventDefault = function preventDefault() {\r\n    this.originalEvent.preventDefault();\r\n  };\r\n\r\n  PointerEvent.prototype.stopPropagation = function stopPropagation() {\r\n    this.propagationStopped = true;\r\n  };\r\n\r\n  PointerEvent.prototype.stopImmediatePropagation = function stopImmediatePropagation() {\r\n    this.immediatePropagationStopped = this.propagationStopped = true;\r\n  };\r\n\r\n  return PointerEvent;\r\n}();\r\n\r\n},{\"../utils/pointerUtils\":49}],31:[function(require,module,exports){\r\n'use strict';\r\n\r\nvar PointerEvent = require('./PointerEvent');\r\nvar Interaction = require('../Interaction');\r\nvar utils = require('../utils');\r\nvar browser = require('../utils/browser');\r\nvar defaults = require('../defaultOptions');\r\nvar signals = require('../utils/Signals').new();\r\n\r\nvar _require = require('../utils/arr'),\r\n    filter = _require.filter;\r\n\r\nvar simpleSignals = ['down', 'up', 'cancel'];\r\nvar simpleEvents = ['down', 'up', 'cancel'];\r\n\r\nvar pointerEvents = {\r\n  PointerEvent: PointerEvent,\r\n  fire: fire,\r\n  collectEventTargets: collectEventTargets,\r\n  signals: signals,\r\n  defaults: {\r\n    holdDuration: 600,\r\n    ignoreFrom: null,\r\n    allowFrom: null,\r\n    origin: { x: 0, y: 0 }\r\n  },\r\n  types: ['down', 'move', 'up', 'cancel', 'tap', 'doubletap', 'hold']\r\n};\r\n\r\nfunction fire(arg) {\r\n  var interaction = arg.interaction,\r\n      pointer = arg.pointer,\r\n      event = arg.event,\r\n      eventTarget = arg.eventTarget,\r\n      _arg$type = arg.type,\r\n      type = _arg$type === undefined ? arg.pointerEvent.type : _arg$type,\r\n      _arg$targets = arg.targets,\r\n      targets = _arg$targets === undefined ? collectEventTargets(arg) : _arg$targets,\r\n      _arg$pointerEvent = arg.pointerEvent,\r\n      pointerEvent = _arg$pointerEvent === undefined ? new PointerEvent(type, pointer, event, eventTarget, interaction) : _arg$pointerEvent;\r\n\r\n\r\n  var signalArg = {\r\n    interaction: interaction,\r\n    pointer: pointer,\r\n    event: event,\r\n    eventTarget: eventTarget,\r\n    targets: targets,\r\n    type: type,\r\n    pointerEvent: pointerEvent\r\n  };\r\n\r\n  for (var i = 0; i < targets.length; i++) {\r\n    var target = targets[i];\r\n\r\n    for (var prop in target.props || {}) {\r\n      pointerEvent[prop] = target.props[prop];\r\n    }\r\n\r\n    var origin = utils.getOriginXY(target.eventable, target.element);\r\n\r\n    pointerEvent.subtractOrigin(origin);\r\n    pointerEvent.eventable = target.eventable;\r\n    pointerEvent.currentTarget = target.element;\r\n\r\n    target.eventable.fire(pointerEvent);\r\n\r\n    pointerEvent.addOrigin(origin);\r\n\r\n    if (pointerEvent.immediatePropagationStopped || pointerEvent.propagationStopped && i + 1 < targets.length && targets[i + 1].element !== pointerEvent.currentTarget) {\r\n      break;\r\n    }\r\n  }\r\n\r\n  signals.fire('fired', signalArg);\r\n\r\n  if (type === 'tap') {\r\n    // if pointerEvent should make a double tap, create and fire a doubletap\r\n    // PointerEvent and use that as the prevTap\r\n    var prevTap = pointerEvent.double ? fire({\r\n      interaction: interaction, pointer: pointer, event: event, eventTarget: eventTarget,\r\n      type: 'doubletap'\r\n    }) : pointerEvent;\r\n\r\n    interaction.prevTap = prevTap;\r\n    interaction.tapTime = prevTap.timeStamp;\r\n  }\r\n\r\n  return pointerEvent;\r\n}\r\n\r\nfunction collectEventTargets(_ref) {\r\n  var interaction = _ref.interaction,\r\n      pointer = _ref.pointer,\r\n      event = _ref.event,\r\n      eventTarget = _ref.eventTarget,\r\n      type = _ref.type;\r\n\r\n  var pointerIndex = interaction.getPointerIndex(pointer);\r\n\r\n  // do not fire a tap event if the pointer was moved before being lifted\r\n  if (type === 'tap' && (interaction.pointerWasMoved\r\n  // or if the pointerup target is different to the pointerdown target\r\n  || !(interaction.downTargets[pointerIndex] && interaction.downTargets[pointerIndex] === eventTarget))) {\r\n    return [];\r\n  }\r\n\r\n  var path = utils.getPath(eventTarget);\r\n  var signalArg = {\r\n    interaction: interaction,\r\n    pointer: pointer,\r\n    event: event,\r\n    eventTarget: eventTarget,\r\n    type: type,\r\n    path: path,\r\n    targets: [],\r\n    element: null\r\n  };\r\n\r\n  for (var _iterator = path, _isArray = Array.isArray(_iterator), _i = 0, _iterator = _isArray ? _iterator : _iterator[Symbol.iterator]();;) {\r\n    var _ref2;\r\n\r\n    if (_isArray) {\r\n      if (_i >= _iterator.length) break;\r\n      _ref2 = _iterator[_i++];\r\n    } else {\r\n      _i = _iterator.next();\r\n      if (_i.done) break;\r\n      _ref2 = _i.value;\r\n    }\r\n\r\n    var element = _ref2;\r\n\r\n    signalArg.element = element;\r\n\r\n    signals.fire('collect-targets', signalArg);\r\n  }\r\n\r\n  if (type === 'hold') {\r\n    signalArg.targets = filter(signalArg.targets, function (target) {\r\n      return target.eventable.options.holdDuration === interaction.holdTimers[pointerIndex].duration;\r\n    });\r\n  }\r\n\r\n  return signalArg.targets;\r\n}\r\n\r\nInteraction.signals.on('update-pointer-down', function (_ref3) {\r\n  var interaction = _ref3.interaction,\r\n      pointerIndex = _ref3.pointerIndex;\r\n\r\n  interaction.holdTimers[pointerIndex] = { duration: Infinity, timeout: null };\r\n});\r\n\r\nInteraction.signals.on('remove-pointer', function (_ref4) {\r\n  var interaction = _ref4.interaction,\r\n      pointerIndex = _ref4.pointerIndex;\r\n\r\n  interaction.holdTimers.splice(pointerIndex, 1);\r\n});\r\n\r\nInteraction.signals.on('move', function (_ref5) {\r\n  var interaction = _ref5.interaction,\r\n      pointer = _ref5.pointer,\r\n      event = _ref5.event,\r\n      eventTarget = _ref5.eventTarget,\r\n      duplicateMove = _ref5.duplicateMove;\r\n\r\n  var pointerIndex = interaction.getPointerIndex(pointer);\r\n\r\n  if (!duplicateMove && (!interaction.pointerIsDown || interaction.pointerWasMoved)) {\r\n    if (interaction.pointerIsDown) {\r\n      clearTimeout(interaction.holdTimers[pointerIndex].timeout);\r\n    }\r\n\r\n    fire({\r\n      interaction: interaction, pointer: pointer, event: event, eventTarget: eventTarget,\r\n      type: 'move'\r\n    });\r\n  }\r\n});\r\n\r\nInteraction.signals.on('down', function (_ref6) {\r\n  var interaction = _ref6.interaction,\r\n      pointer = _ref6.pointer,\r\n      event = _ref6.event,\r\n      eventTarget = _ref6.eventTarget,\r\n      pointerIndex = _ref6.pointerIndex;\r\n\r\n  // copy event to be used in timeout for IE8\r\n  var eventCopy = browser.isIE8 ? utils.extend({}, event) : event;\r\n\r\n  var timer = interaction.holdTimers[pointerIndex];\r\n  var path = utils.getPath(eventTarget);\r\n  var signalArg = {\r\n    interaction: interaction,\r\n    pointer: pointer,\r\n    event: event,\r\n    eventTarget: eventTarget,\r\n    type: 'hold',\r\n    targets: [],\r\n    path: path,\r\n    element: null\r\n  };\r\n\r\n  for (var _iterator2 = path, _isArray2 = Array.isArray(_iterator2), _i2 = 0, _iterator2 = _isArray2 ? _iterator2 : _iterator2[Symbol.iterator]();;) {\r\n    var _ref7;\r\n\r\n    if (_isArray2) {\r\n      if (_i2 >= _iterator2.length) break;\r\n      _ref7 = _iterator2[_i2++];\r\n    } else {\r\n      _i2 = _iterator2.next();\r\n      if (_i2.done) break;\r\n      _ref7 = _i2.value;\r\n    }\r\n\r\n    var element = _ref7;\r\n\r\n    signalArg.element = element;\r\n\r\n    signals.fire('collect-targets', signalArg);\r\n  }\r\n\r\n  if (!signalArg.targets.length) {\r\n    return;\r\n  }\r\n\r\n  var minDuration = Infinity;\r\n\r\n  for (var i = 0; i < signalArg.targets.length; i++) {\r\n    var target = signalArg.targets[i];\r\n    var holdDuration = target.eventable.options.holdDuration;\r\n\r\n    if (holdDuration < minDuration) {\r\n      minDuration = holdDuration;\r\n    }\r\n  }\r\n\r\n  timer.duration = minDuration;\r\n  timer.timeout = setTimeout(function () {\r\n    fire({\r\n      interaction: interaction,\r\n      eventTarget: eventTarget,\r\n      pointer: browser.isIE8 ? eventCopy : pointer,\r\n      event: eventCopy,\r\n      type: 'hold'\r\n    });\r\n  }, minDuration);\r\n});\r\n\r\nInteraction.signals.on('up', function (_ref8) {\r\n  var interaction = _ref8.interaction,\r\n      pointer = _ref8.pointer,\r\n      event = _ref8.event,\r\n      eventTarget = _ref8.eventTarget;\r\n\r\n  if (!interaction.pointerWasMoved) {\r\n    fire({ interaction: interaction, eventTarget: eventTarget, pointer: pointer, event: event, type: 'tap' });\r\n  }\r\n});\r\n\r\n['up', 'cancel'].forEach(function (signalName) {\r\n  Interaction.signals.on(signalName, function (_ref9) {\r\n    var interaction = _ref9.interaction,\r\n        pointerIndex = _ref9.pointerIndex;\r\n\r\n    if (interaction.holdTimers[pointerIndex]) {\r\n      clearTimeout(interaction.holdTimers[pointerIndex].timeout);\r\n    }\r\n  });\r\n});\r\n\r\nfunction createSignalListener(type) {\r\n  return function (_ref10) {\r\n    var interaction = _ref10.interaction,\r\n        pointer = _ref10.pointer,\r\n        event = _ref10.event,\r\n        eventTarget = _ref10.eventTarget;\r\n\r\n    fire({ interaction: interaction, eventTarget: eventTarget, pointer: pointer, event: event, type: type });\r\n  };\r\n}\r\n\r\nfor (var i = 0; i < simpleSignals.length; i++) {\r\n  Interaction.signals.on(simpleSignals[i], createSignalListener(simpleEvents[i]));\r\n}\r\n\r\nInteraction.signals.on('new', function (interaction) {\r\n  interaction.prevTap = null; // the most recent tap event on this interaction\r\n  interaction.tapTime = 0; // time of the most recent tap event\r\n  interaction.holdTimers = []; // [{ duration, timeout }]\r\n});\r\n\r\ndefaults.pointerEvents = pointerEvents.defaults;\r\nmodule.exports = pointerEvents;\r\n\r\n},{\"../Interaction\":5,\"../defaultOptions\":18,\"../utils\":44,\"../utils/Signals\":35,\"../utils/arr\":36,\"../utils/browser\":37,\"./PointerEvent\":30}],32:[function(require,module,exports){\r\n'use strict';\r\n\r\nvar pointerEvents = require('./base');\r\nvar Interaction = require('../Interaction');\r\n\r\npointerEvents.signals.on('new', onNew);\r\npointerEvents.signals.on('fired', onFired);\r\n\r\nvar _arr = ['move', 'up', 'cancel', 'endall'];\r\nfor (var _i = 0; _i < _arr.length; _i++) {\r\n  var signal = _arr[_i];\r\n  Interaction.signals.on(signal, endHoldRepeat);\r\n}\r\n\r\nfunction onNew(_ref) {\r\n  var pointerEvent = _ref.pointerEvent;\r\n\r\n  if (pointerEvent.type !== 'hold') {\r\n    return;\r\n  }\r\n\r\n  pointerEvent.count = (pointerEvent.count || 0) + 1;\r\n}\r\n\r\nfunction onFired(_ref2) {\r\n  var interaction = _ref2.interaction,\r\n      pointerEvent = _ref2.pointerEvent,\r\n      eventTarget = _ref2.eventTarget,\r\n      targets = _ref2.targets;\r\n\r\n  if (pointerEvent.type !== 'hold' || !targets.length) {\r\n    return;\r\n  }\r\n\r\n  // get the repeat interval from the first eventable\r\n  var interval = targets[0].eventable.options.holdRepeatInterval;\r\n\r\n  // don't repeat if the interval is 0 or less\r\n  if (interval <= 0) {\r\n    return;\r\n  }\r\n\r\n  // set a timeout to fire the holdrepeat event\r\n  interaction.holdIntervalHandle = setTimeout(function () {\r\n    pointerEvents.fire({\r\n      interaction: interaction,\r\n      eventTarget: eventTarget,\r\n      type: 'hold',\r\n      pointer: pointerEvent,\r\n      event: pointerEvent\r\n    });\r\n  }, interval);\r\n}\r\n\r\nfunction endHoldRepeat(_ref3) {\r\n  var interaction = _ref3.interaction;\r\n\r\n  // set the interaction's holdStopTime property\r\n  // to stop further holdRepeat events\r\n  if (interaction.holdIntervalHandle) {\r\n    clearInterval(interaction.holdIntervalHandle);\r\n    interaction.holdIntervalHandle = null;\r\n  }\r\n}\r\n\r\n// don't repeat by default\r\npointerEvents.defaults.holdRepeatInterval = 0;\r\npointerEvents.types.push('holdrepeat');\r\n\r\nmodule.exports = {\r\n  onNew: onNew,\r\n  onFired: onFired,\r\n  endHoldRepeat: endHoldRepeat\r\n};\r\n\r\n},{\"../Interaction\":5,\"./base\":31}],33:[function(require,module,exports){\r\n'use strict';\r\n\r\nvar pointerEvents = require('./base');\r\nvar Interactable = require('../Interactable');\r\nvar browser = require('../utils/browser');\r\nvar is = require('../utils/is');\r\nvar domUtils = require('../utils/domUtils');\r\nvar scope = require('../scope');\r\nvar extend = require('../utils/extend');\r\n\r\nvar _require = require('../utils/arr'),\r\n    merge = _require.merge;\r\n\r\npointerEvents.signals.on('collect-targets', function (_ref) {\r\n  var targets = _ref.targets,\r\n      element = _ref.element,\r\n      type = _ref.type,\r\n      eventTarget = _ref.eventTarget;\r\n\r\n  function collectSelectors(interactable, selector, context) {\r\n    var els = browser.useMatchesSelectorPolyfill ? context.querySelectorAll(selector) : undefined;\r\n\r\n    var eventable = interactable.events;\r\n    var options = eventable.options;\r\n\r\n    if (eventable[type] && is.element(element) && domUtils.matchesSelector(element, selector, els) && interactable.testIgnoreAllow(options, element, eventTarget)) {\r\n\r\n      targets.push({\r\n        element: element,\r\n        eventable: eventable,\r\n        props: { interactable: interactable }\r\n      });\r\n    }\r\n  }\r\n\r\n  var interactable = scope.interactables.get(element);\r\n\r\n  if (interactable) {\r\n    var eventable = interactable.events;\r\n    var options = eventable.options;\r\n\r\n    if (eventable[type] && interactable.testIgnoreAllow(options, element, eventTarget)) {\r\n      targets.push({\r\n        element: element,\r\n        eventable: eventable,\r\n        props: { interactable: interactable }\r\n      });\r\n    }\r\n  }\r\n\r\n  scope.interactables.forEachSelector(collectSelectors, element);\r\n});\r\n\r\nInteractable.signals.on('new', function (_ref2) {\r\n  var interactable = _ref2.interactable;\r\n\r\n  interactable.events.getRect = function (element) {\r\n    return interactable.getRect(element);\r\n  };\r\n});\r\n\r\nInteractable.signals.on('set', function (_ref3) {\r\n  var interactable = _ref3.interactable,\r\n      options = _ref3.options;\r\n\r\n  extend(interactable.events.options, pointerEvents.defaults);\r\n  extend(interactable.events.options, options);\r\n});\r\n\r\nmerge(Interactable.eventTypes, pointerEvents.types);\r\n\r\nInteractable.prototype.pointerEvents = function (options) {\r\n  extend(this.events.options, options);\r\n\r\n  return this;\r\n};\r\n\r\nvar __backCompatOption = Interactable.prototype._backCompatOption;\r\n\r\nInteractable.prototype._backCompatOption = function (optionName, newValue) {\r\n  var ret = __backCompatOption.call(this, optionName, newValue);\r\n\r\n  if (ret === this) {\r\n    this.events.options[optionName] = newValue;\r\n  }\r\n\r\n  return ret;\r\n};\r\n\r\nInteractable.settingsMethods.push('pointerEvents');\r\n\r\n},{\"../Interactable\":4,\"../scope\":34,\"../utils/arr\":36,\"../utils/browser\":37,\"../utils/domUtils\":39,\"../utils/extend\":41,\"../utils/is\":46,\"./base\":31}],34:[function(require,module,exports){\r\n'use strict';\r\n\r\nvar utils = require('./utils');\r\nvar events = require('./utils/events');\r\nvar signals = require('./utils/Signals').new();\r\n\r\nvar scope = {\r\n  signals: signals,\r\n  events: events,\r\n  utils: utils,\r\n\r\n  // main document\r\n  document: require('./utils/domObjects').document,\r\n  // all documents being listened to\r\n  documents: [],\r\n\r\n  addDocument: function addDocument(doc, win) {\r\n    // do nothing if document is already known\r\n    if (utils.contains(scope.documents, doc)) {\r\n      return false;\r\n    }\r\n\r\n    win = win || scope.getWindow(doc);\r\n\r\n    scope.documents.push(doc);\r\n    events.documents.push(doc);\r\n\r\n    // don't add an unload event for the main document\r\n    // so that the page may be cached in browser history\r\n    if (doc !== scope.document) {\r\n      events.add(win, 'unload', scope.onWindowUnload);\r\n    }\r\n\r\n    signals.fire('add-document', { doc: doc, win: win });\r\n  },\r\n\r\n  removeDocument: function removeDocument(doc, win) {\r\n    var index = utils.indexOf(scope.documents, doc);\r\n\r\n    win = win || scope.getWindow(doc);\r\n\r\n    events.remove(win, 'unload', scope.onWindowUnload);\r\n\r\n    scope.documents.splice(index, 1);\r\n    events.documents.splice(index, 1);\r\n\r\n    signals.fire('remove-document', { win: win, doc: doc });\r\n  },\r\n\r\n  onWindowUnload: function onWindowUnload() {\r\n    scope.removeDocument(this.document, this);\r\n  }\r\n};\r\n\r\nmodule.exports = scope;\r\n\r\n},{\"./utils\":44,\"./utils/Signals\":35,\"./utils/domObjects\":38,\"./utils/events\":40}],35:[function(require,module,exports){\r\n'use strict';\r\n\r\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\r\n\r\nvar _require = require('./arr'),\r\n    indexOf = _require.indexOf;\r\n\r\nvar Signals = function () {\r\n  function Signals() {\r\n    _classCallCheck(this, Signals);\r\n\r\n    this.listeners = {\r\n      // signalName: [listeners],\r\n    };\r\n  }\r\n\r\n  Signals.prototype.on = function on(name, listener) {\r\n    if (!this.listeners[name]) {\r\n      this.listeners[name] = [listener];\r\n      return;\r\n    }\r\n\r\n    this.listeners[name].push(listener);\r\n  };\r\n\r\n  Signals.prototype.off = function off(name, listener) {\r\n    if (!this.listeners[name]) {\r\n      return;\r\n    }\r\n\r\n    var index = indexOf(this.listeners[name], listener);\r\n\r\n    if (index !== -1) {\r\n      this.listeners[name].splice(index, 1);\r\n    }\r\n  };\r\n\r\n  Signals.prototype.fire = function fire(name, arg) {\r\n    var targetListeners = this.listeners[name];\r\n\r\n    if (!targetListeners) {\r\n      return;\r\n    }\r\n\r\n    for (var i = 0; i < targetListeners.length; i++) {\r\n      if (targetListeners[i](arg, name) === false) {\r\n        return;\r\n      }\r\n    }\r\n  };\r\n\r\n  return Signals;\r\n}();\r\n\r\nSignals.new = function () {\r\n  return new Signals();\r\n};\r\n\r\nmodule.exports = Signals;\r\n\r\n},{\"./arr\":36}],36:[function(require,module,exports){\r\n\"use strict\";\r\n\r\nfunction indexOf(array, target) {\r\n  for (var i = 0, len = array.length; i < len; i++) {\r\n    if (array[i] === target) {\r\n      return i;\r\n    }\r\n  }\r\n\r\n  return -1;\r\n}\r\n\r\nfunction contains(array, target) {\r\n  return indexOf(array, target) !== -1;\r\n}\r\n\r\nfunction merge(target, source) {\r\n  for (var i = 0; i < source.length; i++) {\r\n    target.push(source[i]);\r\n  }\r\n\r\n  return target;\r\n}\r\n\r\nfunction filter(array, test) {\r\n  var result = [];\r\n\r\n  for (var i = 0; i < array.length; i++) {\r\n    if (test(array[i])) {\r\n      result.push(array[i]);\r\n    }\r\n  }\r\n\r\n  return result;\r\n}\r\n\r\nmodule.exports = {\r\n  indexOf: indexOf,\r\n  contains: contains,\r\n  merge: merge,\r\n  filter: filter\r\n};\r\n\r\n},{}],37:[function(require,module,exports){\r\n'use strict';\r\n\r\nvar _require = require('./window'),\r\n    window = _require.window;\r\n\r\nvar is = require('./is');\r\nvar domObjects = require('./domObjects');\r\n\r\nvar Element = domObjects.Element;\r\nvar navigator = window.navigator;\r\n\r\nvar browser = {\r\n  // Does the browser support touch input?\r\n  supportsTouch: !!('ontouchstart' in window || is.function(window.DocumentTouch) && domObjects.document instanceof window.DocumentTouch),\r\n\r\n  // Does the browser support PointerEvents\r\n  supportsPointerEvent: !!domObjects.PointerEvent,\r\n\r\n  isIE8: 'attachEvent' in window && !('addEventListener' in window),\r\n\r\n  // Opera Mobile must be handled differently\r\n  isOperaMobile: navigator.appName === 'Opera' && browser.supportsTouch && navigator.userAgent.match('Presto'),\r\n\r\n  // scrolling doesn't change the result of getClientRects on iOS 7\r\n  isIOS7: /iP(hone|od|ad)/.test(navigator.platform) && /OS 7[^\\d]/.test(navigator.appVersion),\r\n\r\n  isIe9OrOlder: /MSIE (8|9)/.test(navigator.userAgent),\r\n\r\n  // prefix matchesSelector\r\n  prefixedMatchesSelector: 'matches' in Element.prototype ? 'matches' : 'webkitMatchesSelector' in Element.prototype ? 'webkitMatchesSelector' : 'mozMatchesSelector' in Element.prototype ? 'mozMatchesSelector' : 'oMatchesSelector' in Element.prototype ? 'oMatchesSelector' : 'msMatchesSelector',\r\n\r\n  useMatchesSelectorPolyfill: false,\r\n\r\n  pEventTypes: domObjects.PointerEvent ? domObjects.PointerEvent === window.MSPointerEvent ? {\r\n    up: 'MSPointerUp',\r\n    down: 'MSPointerDown',\r\n    over: 'mouseover',\r\n    out: 'mouseout',\r\n    move: 'MSPointerMove',\r\n    cancel: 'MSPointerCancel'\r\n  } : {\r\n    up: 'pointerup',\r\n    down: 'pointerdown',\r\n    over: 'pointerover',\r\n    out: 'pointerout',\r\n    move: 'pointermove',\r\n    cancel: 'pointercancel'\r\n  } : null,\r\n\r\n  // because Webkit and Opera still use 'mousewheel' event type\r\n  wheelEvent: 'onmousewheel' in domObjects.document ? 'mousewheel' : 'wheel'\r\n\r\n};\r\n\r\nbrowser.useMatchesSelectorPolyfill = !is.function(Element.prototype[browser.prefixedMatchesSelector]);\r\n\r\nmodule.exports = browser;\r\n\r\n},{\"./domObjects\":38,\"./is\":46,\"./window\":52}],38:[function(require,module,exports){\r\n'use strict';\r\n\r\nvar domObjects = {};\r\nvar win = require('./window').window;\r\n\r\nfunction blank() {}\r\n\r\ndomObjects.document = win.document;\r\ndomObjects.DocumentFragment = win.DocumentFragment || blank;\r\ndomObjects.SVGElement = win.SVGElement || blank;\r\ndomObjects.SVGSVGElement = win.SVGSVGElement || blank;\r\ndomObjects.SVGElementInstance = win.SVGElementInstance || blank;\r\ndomObjects.Element = win.Element || blank;\r\ndomObjects.HTMLElement = win.HTMLElement || domObjects.Element;\r\n\r\ndomObjects.Event = win.Event;\r\ndomObjects.Touch = win.Touch || blank;\r\ndomObjects.PointerEvent = win.PointerEvent || win.MSPointerEvent;\r\n\r\nmodule.exports = domObjects;\r\n\r\n},{\"./window\":52}],39:[function(require,module,exports){\r\n'use strict';\r\n\r\nvar win = require('./window');\r\nvar browser = require('./browser');\r\nvar is = require('./is');\r\nvar domObjects = require('./domObjects');\r\n\r\nvar domUtils = {\r\n  nodeContains: function nodeContains(parent, child) {\r\n    while (child) {\r\n      if (child === parent) {\r\n        return true;\r\n      }\r\n\r\n      child = child.parentNode;\r\n    }\r\n\r\n    return false;\r\n  },\r\n\r\n  closest: function closest(element, selector) {\r\n    while (is.element(element)) {\r\n      if (domUtils.matchesSelector(element, selector)) {\r\n        return element;\r\n      }\r\n\r\n      element = domUtils.parentNode(element);\r\n    }\r\n\r\n    return null;\r\n  },\r\n\r\n  parentNode: function parentNode(node) {\r\n    var parent = node.parentNode;\r\n\r\n    if (is.docFrag(parent)) {\r\n      // skip past #shado-root fragments\r\n      while ((parent = parent.host) && is.docFrag(parent)) {\r\n        continue;\r\n      }\r\n\r\n      return parent;\r\n    }\r\n\r\n    return parent;\r\n  },\r\n\r\n  // taken from http://tanalin.com/en/blog/2012/12/matches-selector-ie8/ and modified\r\n  matchesSelectorPolyfill: browser.useMatchesSelectorPolyfill ? function (element, selector, elems) {\r\n    elems = elems || element.parentNode.querySelectorAll(selector);\r\n\r\n    for (var i = 0, len = elems.length; i < len; i++) {\r\n      if (elems[i] === element) {\r\n        return true;\r\n      }\r\n    }\r\n\r\n    return false;\r\n  } : null,\r\n\r\n  matchesSelector: function matchesSelector(element, selector, nodeList) {\r\n    if (browser.useMatchesSelectorPolyfill) {\r\n      return domUtils.matchesSelectorPolyfill(element, selector, nodeList);\r\n    }\r\n\r\n    // remove /deep/ from selectors if shadowDOM polyfill is used\r\n    if (win.window !== win.realWindow) {\r\n      selector = selector.replace(/\\/deep\\//g, ' ');\r\n    }\r\n\r\n    return element[browser.prefixedMatchesSelector](selector);\r\n  },\r\n\r\n  // Test for the element that's \"above\" all other qualifiers\r\n  indexOfDeepestElement: function indexOfDeepestElement(elements) {\r\n    var deepestZoneParents = [];\r\n    var dropzoneParents = [];\r\n    var dropzone = void 0;\r\n    var deepestZone = elements[0];\r\n    var index = deepestZone ? 0 : -1;\r\n    var parent = void 0;\r\n    var child = void 0;\r\n    var i = void 0;\r\n    var n = void 0;\r\n\r\n    for (i = 1; i < elements.length; i++) {\r\n      dropzone = elements[i];\r\n\r\n      // an element might belong to multiple selector dropzones\r\n      if (!dropzone || dropzone === deepestZone) {\r\n        continue;\r\n      }\r\n\r\n      if (!deepestZone) {\r\n        deepestZone = dropzone;\r\n        index = i;\r\n        continue;\r\n      }\r\n\r\n      // check if the deepest or current are document.documentElement or document.rootElement\r\n      // - if the current dropzone is, do nothing and continue\r\n      if (dropzone.parentNode === dropzone.ownerDocument) {\r\n        continue;\r\n      }\r\n      // - if deepest is, update with the current dropzone and continue to next\r\n      else if (deepestZone.parentNode === dropzone.ownerDocument) {\r\n          deepestZone = dropzone;\r\n          index = i;\r\n          continue;\r\n        }\r\n\r\n      if (!deepestZoneParents.length) {\r\n        parent = deepestZone;\r\n        while (parent.parentNode && parent.parentNode !== parent.ownerDocument) {\r\n          deepestZoneParents.unshift(parent);\r\n          parent = parent.parentNode;\r\n        }\r\n      }\r\n\r\n      // if this element is an svg element and the current deepest is\r\n      // an HTMLElement\r\n      if (deepestZone instanceof domObjects.HTMLElement && dropzone instanceof domObjects.SVGElement && !(dropzone instanceof domObjects.SVGSVGElement)) {\r\n\r\n        if (dropzone === deepestZone.parentNode) {\r\n          continue;\r\n        }\r\n\r\n        parent = dropzone.ownerSVGElement;\r\n      } else {\r\n        parent = dropzone;\r\n      }\r\n\r\n      dropzoneParents = [];\r\n\r\n      while (parent.parentNode !== parent.ownerDocument) {\r\n        dropzoneParents.unshift(parent);\r\n        parent = parent.parentNode;\r\n      }\r\n\r\n      n = 0;\r\n\r\n      // get (position of last common ancestor) + 1\r\n      while (dropzoneParents[n] && dropzoneParents[n] === deepestZoneParents[n]) {\r\n        n++;\r\n      }\r\n\r\n      var parents = [dropzoneParents[n - 1], dropzoneParents[n], deepestZoneParents[n]];\r\n\r\n      child = parents[0].lastChild;\r\n\r\n      while (child) {\r\n        if (child === parents[1]) {\r\n          deepestZone = dropzone;\r\n          index = i;\r\n          deepestZoneParents = [];\r\n\r\n          break;\r\n        } else if (child === parents[2]) {\r\n          break;\r\n        }\r\n\r\n        child = child.previousSibling;\r\n      }\r\n    }\r\n\r\n    return index;\r\n  },\r\n\r\n  matchesUpTo: function matchesUpTo(element, selector, limit) {\r\n    while (is.element(element)) {\r\n      if (domUtils.matchesSelector(element, selector)) {\r\n        return true;\r\n      }\r\n\r\n      element = domUtils.parentNode(element);\r\n\r\n      if (element === limit) {\r\n        return domUtils.matchesSelector(element, selector);\r\n      }\r\n    }\r\n\r\n    return false;\r\n  },\r\n\r\n  getActualElement: function getActualElement(element) {\r\n    return element instanceof domObjects.SVGElementInstance ? element.correspondingUseElement : element;\r\n  },\r\n\r\n  getScrollXY: function getScrollXY(relevantWindow) {\r\n    relevantWindow = relevantWindow || win.window;\r\n    return {\r\n      x: relevantWindow.scrollX || relevantWindow.document.documentElement.scrollLeft,\r\n      y: relevantWindow.scrollY || relevantWindow.document.documentElement.scrollTop\r\n    };\r\n  },\r\n\r\n  getElementClientRect: function getElementClientRect(element) {\r\n    var clientRect = element instanceof domObjects.SVGElement ? element.getBoundingClientRect() : element.getClientRects()[0];\r\n\r\n    return clientRect && {\r\n      left: clientRect.left,\r\n      right: clientRect.right,\r\n      top: clientRect.top,\r\n      bottom: clientRect.bottom,\r\n      width: clientRect.width || clientRect.right - clientRect.left,\r\n      height: clientRect.height || clientRect.bottom - clientRect.top\r\n    };\r\n  },\r\n\r\n  getElementRect: function getElementRect(element) {\r\n    var clientRect = domUtils.getElementClientRect(element);\r\n\r\n    if (!browser.isIOS7 && clientRect) {\r\n      var scroll = domUtils.getScrollXY(win.getWindow(element));\r\n\r\n      clientRect.left += scroll.x;\r\n      clientRect.right += scroll.x;\r\n      clientRect.top += scroll.y;\r\n      clientRect.bottom += scroll.y;\r\n    }\r\n\r\n    return clientRect;\r\n  },\r\n\r\n  getPath: function getPath(element) {\r\n    var path = [];\r\n\r\n    while (element) {\r\n      path.push(element);\r\n      element = domUtils.parentNode(element);\r\n    }\r\n\r\n    return path;\r\n  },\r\n\r\n  trySelector: function trySelector(value) {\r\n    if (!is.string(value)) {\r\n      return false;\r\n    }\r\n\r\n    // an exception will be raised if it is invalid\r\n    domObjects.document.querySelector(value);\r\n    return true;\r\n  }\r\n};\r\n\r\nmodule.exports = domUtils;\r\n\r\n},{\"./browser\":37,\"./domObjects\":38,\"./is\":46,\"./window\":52}],40:[function(require,module,exports){\r\n'use strict';\r\n\r\nvar is = require('./is');\r\nvar domUtils = require('./domUtils');\r\nvar pExtend = require('./pointerExtend');\r\n\r\nvar _require = require('./window'),\r\n    window = _require.window,\r\n    getWindow = _require.getWindow;\r\n\r\nvar _require2 = require('./arr'),\r\n    indexOf = _require2.indexOf,\r\n    contains = _require2.contains;\r\n\r\nvar useAttachEvent = 'attachEvent' in window && !('addEventListener' in window);\r\nvar addEvent = useAttachEvent ? 'attachEvent' : 'addEventListener';\r\nvar removeEvent = useAttachEvent ? 'detachEvent' : 'removeEventListener';\r\nvar on = useAttachEvent ? 'on' : '';\r\n\r\nvar elements = [];\r\nvar targets = [];\r\nvar attachedListeners = [];\r\n\r\n// {\r\n//   type: {\r\n//     selectors: ['selector', ...],\r\n//     contexts : [document, ...],\r\n//     listeners: [[listener, capture, passive], ...]\r\n//   }\r\n//  }\r\nvar delegatedEvents = {};\r\n\r\nvar documents = [];\r\n\r\nvar supportsOptions = !useAttachEvent && function () {\r\n  var supported = false;\r\n\r\n  window.document.createElement('div').addEventListener('test', null, {\r\n    get capture() {\r\n      supported = true;\r\n    }\r\n  });\r\n\r\n  return supported;\r\n}();\r\n\r\nfunction add(element, type, listener, optionalArg) {\r\n  var options = getOptions(optionalArg);\r\n  var elementIndex = indexOf(elements, element);\r\n  var target = targets[elementIndex];\r\n\r\n  if (!target) {\r\n    target = {\r\n      events: {},\r\n      typeCount: 0\r\n    };\r\n\r\n    elementIndex = elements.push(element) - 1;\r\n    targets.push(target);\r\n\r\n    attachedListeners.push(useAttachEvent ? {\r\n      supplied: [],\r\n      wrapped: [],\r\n      useCount: []\r\n    } : null);\r\n  }\r\n\r\n  if (!target.events[type]) {\r\n    target.events[type] = [];\r\n    target.typeCount++;\r\n  }\r\n\r\n  if (!contains(target.events[type], listener)) {\r\n    var ret = void 0;\r\n\r\n    if (useAttachEvent) {\r\n      var _attachedListeners$el = attachedListeners[elementIndex],\r\n          supplied = _attachedListeners$el.supplied,\r\n          wrapped = _attachedListeners$el.wrapped,\r\n          useCount = _attachedListeners$el.useCount;\r\n\r\n      var listenerIndex = indexOf(supplied, listener);\r\n\r\n      var wrappedListener = wrapped[listenerIndex] || function (event) {\r\n        if (!event.immediatePropagationStopped) {\r\n          event.target = event.srcElement;\r\n          event.currentTarget = element;\r\n\r\n          event.preventDefault = event.preventDefault || preventDef;\r\n          event.stopPropagation = event.stopPropagation || stopProp;\r\n          event.stopImmediatePropagation = event.stopImmediatePropagation || stopImmProp;\r\n\r\n          if (/mouse|click/.test(event.type)) {\r\n            event.pageX = event.clientX + getWindow(element).document.documentElement.scrollLeft;\r\n            event.pageY = event.clientY + getWindow(element).document.documentElement.scrollTop;\r\n          }\r\n\r\n          listener(event);\r\n        }\r\n      };\r\n\r\n      ret = element[addEvent](on + type, wrappedListener, !!options.capture);\r\n\r\n      if (listenerIndex === -1) {\r\n        supplied.push(listener);\r\n        wrapped.push(wrappedListener);\r\n        useCount.push(1);\r\n      } else {\r\n        useCount[listenerIndex]++;\r\n      }\r\n    } else {\r\n      ret = element[addEvent](type, listener, supportsOptions ? options : !!options.capture);\r\n    }\r\n    target.events[type].push(listener);\r\n\r\n    return ret;\r\n  }\r\n}\r\n\r\nfunction remove(element, type, listener, optionalArg) {\r\n  var options = getOptions(optionalArg);\r\n  var elementIndex = indexOf(elements, element);\r\n  var target = targets[elementIndex];\r\n\r\n  if (!target || !target.events) {\r\n    return;\r\n  }\r\n\r\n  var wrappedListener = listener;\r\n  var listeners = void 0;\r\n  var listenerIndex = void 0;\r\n\r\n  if (useAttachEvent) {\r\n    listeners = attachedListeners[elementIndex];\r\n    listenerIndex = indexOf(listeners.supplied, listener);\r\n    wrappedListener = listeners.wrapped[listenerIndex];\r\n  }\r\n\r\n  if (type === 'all') {\r\n    for (type in target.events) {\r\n      if (target.events.hasOwnProperty(type)) {\r\n        remove(element, type, 'all');\r\n      }\r\n    }\r\n    return;\r\n  }\r\n\r\n  if (target.events[type]) {\r\n    var len = target.events[type].length;\r\n\r\n    if (listener === 'all') {\r\n      for (var i = 0; i < len; i++) {\r\n        remove(element, type, target.events[type][i], options);\r\n      }\r\n      return;\r\n    } else {\r\n      for (var _i = 0; _i < len; _i++) {\r\n        if (target.events[type][_i] === listener) {\r\n          element[removeEvent](on + type, wrappedListener, supportsOptions ? options : !!options.capture);\r\n          target.events[type].splice(_i, 1);\r\n\r\n          if (useAttachEvent && listeners) {\r\n            listeners.useCount[listenerIndex]--;\r\n            if (listeners.useCount[listenerIndex] === 0) {\r\n              listeners.supplied.splice(listenerIndex, 1);\r\n              listeners.wrapped.splice(listenerIndex, 1);\r\n              listeners.useCount.splice(listenerIndex, 1);\r\n            }\r\n          }\r\n\r\n          break;\r\n        }\r\n      }\r\n    }\r\n\r\n    if (target.events[type] && target.events[type].length === 0) {\r\n      target.events[type] = null;\r\n      target.typeCount--;\r\n    }\r\n  }\r\n\r\n  if (!target.typeCount) {\r\n    targets.splice(elementIndex, 1);\r\n    elements.splice(elementIndex, 1);\r\n    attachedListeners.splice(elementIndex, 1);\r\n  }\r\n}\r\n\r\nfunction addDelegate(selector, context, type, listener, optionalArg) {\r\n  var options = getOptions(optionalArg);\r\n  if (!delegatedEvents[type]) {\r\n    delegatedEvents[type] = {\r\n      selectors: [],\r\n      contexts: [],\r\n      listeners: []\r\n    };\r\n\r\n    // add delegate listener functions\r\n    for (var i = 0; i < documents.length; i++) {\r\n      add(documents[i], type, delegateListener);\r\n      add(documents[i], type, delegateUseCapture, true);\r\n    }\r\n  }\r\n\r\n  var delegated = delegatedEvents[type];\r\n  var index = void 0;\r\n\r\n  for (index = delegated.selectors.length - 1; index >= 0; index--) {\r\n    if (delegated.selectors[index] === selector && delegated.contexts[index] === context) {\r\n      break;\r\n    }\r\n  }\r\n\r\n  if (index === -1) {\r\n    index = delegated.selectors.length;\r\n\r\n    delegated.selectors.push(selector);\r\n    delegated.contexts.push(context);\r\n    delegated.listeners.push([]);\r\n  }\r\n\r\n  // keep listener and capture and passive flags\r\n  delegated.listeners[index].push([listener, !!options.capture, options.passive]);\r\n}\r\n\r\nfunction removeDelegate(selector, context, type, listener, optionalArg) {\r\n  var options = getOptions(optionalArg);\r\n  var delegated = delegatedEvents[type];\r\n  var matchFound = false;\r\n  var index = void 0;\r\n\r\n  if (!delegated) {\r\n    return;\r\n  }\r\n\r\n  // count from last index of delegated to 0\r\n  for (index = delegated.selectors.length - 1; index >= 0; index--) {\r\n    // look for matching selector and context Node\r\n    if (delegated.selectors[index] === selector && delegated.contexts[index] === context) {\r\n\r\n      var listeners = delegated.listeners[index];\r\n\r\n      // each item of the listeners array is an array: [function, capture, passive]\r\n      for (var i = listeners.length - 1; i >= 0; i--) {\r\n        var _listeners$i = listeners[i],\r\n            fn = _listeners$i[0],\r\n            capture = _listeners$i[1],\r\n            passive = _listeners$i[2];\r\n\r\n        // check if the listener functions and capture and passive flags match\r\n\r\n        if (fn === listener && capture === !!options.capture && passive === options.passive) {\r\n          // remove the listener from the array of listeners\r\n          listeners.splice(i, 1);\r\n\r\n          // if all listeners for this interactable have been removed\r\n          // remove the interactable from the delegated arrays\r\n          if (!listeners.length) {\r\n            delegated.selectors.splice(index, 1);\r\n            delegated.contexts.splice(index, 1);\r\n            delegated.listeners.splice(index, 1);\r\n\r\n            // remove delegate function from context\r\n            remove(context, type, delegateListener);\r\n            remove(context, type, delegateUseCapture, true);\r\n\r\n            // remove the arrays if they are empty\r\n            if (!delegated.selectors.length) {\r\n              delegatedEvents[type] = null;\r\n            }\r\n          }\r\n\r\n          // only remove one listener\r\n          matchFound = true;\r\n          break;\r\n        }\r\n      }\r\n\r\n      if (matchFound) {\r\n        break;\r\n      }\r\n    }\r\n  }\r\n}\r\n\r\n// bound to the interactable context when a DOM event\r\n// listener is added to a selector interactable\r\nfunction delegateListener(event, optionalArg) {\r\n  var options = getOptions(optionalArg);\r\n  var fakeEvent = {};\r\n  var delegated = delegatedEvents[event.type];\r\n  var eventTarget = domUtils.getActualElement(event.path ? event.path[0] : event.target);\r\n  var element = eventTarget;\r\n\r\n  // duplicate the event so that currentTarget can be changed\r\n  pExtend(fakeEvent, event);\r\n\r\n  fakeEvent.originalEvent = event;\r\n  fakeEvent.preventDefault = preventOriginalDefault;\r\n\r\n  // climb up document tree looking for selector matches\r\n  while (is.element(element)) {\r\n    for (var i = 0; i < delegated.selectors.length; i++) {\r\n      var selector = delegated.selectors[i];\r\n      var context = delegated.contexts[i];\r\n\r\n      if (domUtils.matchesSelector(element, selector) && domUtils.nodeContains(context, eventTarget) && domUtils.nodeContains(context, element)) {\r\n\r\n        var listeners = delegated.listeners[i];\r\n\r\n        fakeEvent.currentTarget = element;\r\n\r\n        for (var j = 0; j < listeners.length; j++) {\r\n          var _listeners$j = listeners[j],\r\n              fn = _listeners$j[0],\r\n              capture = _listeners$j[1],\r\n              passive = _listeners$j[2];\r\n\r\n\r\n          if (capture === !!options.capture && passive === options.passive) {\r\n            fn(fakeEvent);\r\n          }\r\n        }\r\n      }\r\n    }\r\n\r\n    element = domUtils.parentNode(element);\r\n  }\r\n}\r\n\r\nfunction delegateUseCapture(event) {\r\n  return delegateListener.call(this, event, true);\r\n}\r\n\r\nfunction preventDef() {\r\n  this.returnValue = false;\r\n}\r\n\r\nfunction preventOriginalDefault() {\r\n  this.originalEvent.preventDefault();\r\n}\r\n\r\nfunction stopProp() {\r\n  this.cancelBubble = true;\r\n}\r\n\r\nfunction stopImmProp() {\r\n  this.cancelBubble = true;\r\n  this.immediatePropagationStopped = true;\r\n}\r\n\r\nfunction getOptions(param) {\r\n  return is.object(param) ? param : { capture: param };\r\n}\r\n\r\nmodule.exports = {\r\n  add: add,\r\n  remove: remove,\r\n\r\n  addDelegate: addDelegate,\r\n  removeDelegate: removeDelegate,\r\n\r\n  delegateListener: delegateListener,\r\n  delegateUseCapture: delegateUseCapture,\r\n  delegatedEvents: delegatedEvents,\r\n  documents: documents,\r\n\r\n  useAttachEvent: useAttachEvent,\r\n  supportsOptions: supportsOptions,\r\n\r\n  _elements: elements,\r\n  _targets: targets,\r\n  _attachedListeners: attachedListeners\r\n};\r\n\r\n},{\"./arr\":36,\"./domUtils\":39,\"./is\":46,\"./pointerExtend\":48,\"./window\":52}],41:[function(require,module,exports){\r\n\"use strict\";\r\n\r\nmodule.exports = function extend(dest, source) {\r\n  for (var prop in source) {\r\n    dest[prop] = source[prop];\r\n  }\r\n  return dest;\r\n};\r\n\r\n},{}],42:[function(require,module,exports){\r\n'use strict';\r\n\r\nvar _require = require('./rect'),\r\n    resolveRectLike = _require.resolveRectLike,\r\n    rectToXY = _require.rectToXY;\r\n\r\nmodule.exports = function (target, element, action) {\r\n  var actionOptions = target.options[action];\r\n  var actionOrigin = actionOptions && actionOptions.origin;\r\n  var origin = actionOrigin || target.options.origin;\r\n\r\n  var originRect = resolveRectLike(origin, target, element, [target && element]);\r\n\r\n  return rectToXY(originRect) || { x: 0, y: 0 };\r\n};\r\n\r\n},{\"./rect\":51}],43:[function(require,module,exports){\r\n\"use strict\";\r\n\r\nmodule.exports = function (x, y) {\r\n  return Math.sqrt(x * x + y * y);\r\n};\r\n\r\n},{}],44:[function(require,module,exports){\r\n'use strict';\r\n\r\nvar extend = require('./extend');\r\nvar win = require('./window');\r\n\r\nvar utils = {\r\n  warnOnce: function warnOnce(method, message) {\r\n    var warned = false;\r\n\r\n    return function () {\r\n      if (!warned) {\r\n        win.window.console.warn(message);\r\n        warned = true;\r\n      }\r\n\r\n      return method.apply(this, arguments);\r\n    };\r\n  },\r\n\r\n  // http://stackoverflow.com/a/5634528/2280888\r\n  _getQBezierValue: function _getQBezierValue(t, p1, p2, p3) {\r\n    var iT = 1 - t;\r\n    return iT * iT * p1 + 2 * iT * t * p2 + t * t * p3;\r\n  },\r\n\r\n  getQuadraticCurvePoint: function getQuadraticCurvePoint(startX, startY, cpX, cpY, endX, endY, position) {\r\n    return {\r\n      x: utils._getQBezierValue(position, startX, cpX, endX),\r\n      y: utils._getQBezierValue(position, startY, cpY, endY)\r\n    };\r\n  },\r\n\r\n  // http://gizma.com/easing/\r\n  easeOutQuad: function easeOutQuad(t, b, c, d) {\r\n    t /= d;\r\n    return -c * t * (t - 2) + b;\r\n  },\r\n\r\n  copyAction: function copyAction(dest, src) {\r\n    dest.name = src.name;\r\n    dest.axis = src.axis;\r\n    dest.edges = src.edges;\r\n\r\n    return dest;\r\n  },\r\n\r\n  is: require('./is'),\r\n  extend: extend,\r\n  hypot: require('./hypot'),\r\n  getOriginXY: require('./getOriginXY')\r\n};\r\n\r\nextend(utils, require('./arr'));\r\nextend(utils, require('./domUtils'));\r\nextend(utils, require('./pointerUtils'));\r\nextend(utils, require('./rect'));\r\n\r\nmodule.exports = utils;\r\n\r\n},{\"./arr\":36,\"./domUtils\":39,\"./extend\":41,\"./getOriginXY\":42,\"./hypot\":43,\"./is\":46,\"./pointerUtils\":49,\"./rect\":51,\"./window\":52}],45:[function(require,module,exports){\r\n'use strict';\r\n\r\nvar scope = require('../scope');\r\nvar utils = require('./index');\r\n\r\nvar finder = {\r\n  methodOrder: ['simulationResume', 'mouseOrPen', 'hasPointer', 'idle'],\r\n\r\n  search: function search(pointer, eventType, eventTarget) {\r\n    var pointerType = utils.getPointerType(pointer);\r\n    var pointerId = utils.getPointerId(pointer);\r\n    var details = { pointer: pointer, pointerId: pointerId, pointerType: pointerType, eventType: eventType, eventTarget: eventTarget };\r\n\r\n    for (var _iterator = finder.methodOrder, _isArray = Array.isArray(_iterator), _i = 0, _iterator = _isArray ? _iterator : _iterator[Symbol.iterator]();;) {\r\n      var _ref;\r\n\r\n      if (_isArray) {\r\n        if (_i >= _iterator.length) break;\r\n        _ref = _iterator[_i++];\r\n      } else {\r\n        _i = _iterator.next();\r\n        if (_i.done) break;\r\n        _ref = _i.value;\r\n      }\r\n\r\n      var method = _ref;\r\n\r\n      var interaction = finder[method](details);\r\n\r\n      if (interaction) {\r\n        return interaction;\r\n      }\r\n    }\r\n  },\r\n\r\n  // try to resume simulation with a new pointer\r\n  simulationResume: function simulationResume(_ref2) {\r\n    var pointerType = _ref2.pointerType,\r\n        eventType = _ref2.eventType,\r\n        eventTarget = _ref2.eventTarget;\r\n\r\n    if (!/down|start/i.test(eventType)) {\r\n      return null;\r\n    }\r\n\r\n    for (var _iterator2 = scope.interactions, _isArray2 = Array.isArray(_iterator2), _i2 = 0, _iterator2 = _isArray2 ? _iterator2 : _iterator2[Symbol.iterator]();;) {\r\n      var _ref3;\r\n\r\n      if (_isArray2) {\r\n        if (_i2 >= _iterator2.length) break;\r\n        _ref3 = _iterator2[_i2++];\r\n      } else {\r\n        _i2 = _iterator2.next();\r\n        if (_i2.done) break;\r\n        _ref3 = _i2.value;\r\n      }\r\n\r\n      var interaction = _ref3;\r\n\r\n      var element = eventTarget;\r\n\r\n      if (interaction.simulation && interaction.simulation.allowResume && interaction.pointerType === pointerType) {\r\n        while (element) {\r\n          // if the element is the interaction element\r\n          if (element === interaction.element) {\r\n            return interaction;\r\n          }\r\n          element = utils.parentNode(element);\r\n        }\r\n      }\r\n    }\r\n\r\n    return null;\r\n  },\r\n\r\n  // if it's a mouse or pen interaction\r\n  mouseOrPen: function mouseOrPen(_ref4) {\r\n    var pointerId = _ref4.pointerId,\r\n        pointerType = _ref4.pointerType,\r\n        eventType = _ref4.eventType;\r\n\r\n    if (pointerType !== 'mouse' && pointerType !== 'pen') {\r\n      return null;\r\n    }\r\n\r\n    var firstNonActive = void 0;\r\n\r\n    for (var _iterator3 = scope.interactions, _isArray3 = Array.isArray(_iterator3), _i3 = 0, _iterator3 = _isArray3 ? _iterator3 : _iterator3[Symbol.iterator]();;) {\r\n      var _ref5;\r\n\r\n      if (_isArray3) {\r\n        if (_i3 >= _iterator3.length) break;\r\n        _ref5 = _iterator3[_i3++];\r\n      } else {\r\n        _i3 = _iterator3.next();\r\n        if (_i3.done) break;\r\n        _ref5 = _i3.value;\r\n      }\r\n\r\n      var interaction = _ref5;\r\n\r\n      if (interaction.pointerType === pointerType) {\r\n        // if it's a down event, skip interactions with running simulations\r\n        if (interaction.simulation && !utils.contains(interaction.pointerIds, pointerId)) {\r\n          continue;\r\n        }\r\n\r\n        // if the interaction is active, return it immediately\r\n        if (interaction.interacting()) {\r\n          return interaction;\r\n        }\r\n        // otherwise save it and look for another active interaction\r\n        else if (!firstNonActive) {\r\n            firstNonActive = interaction;\r\n          }\r\n      }\r\n    }\r\n\r\n    // if no active mouse interaction was found use the first inactive mouse\r\n    // interaction\r\n    if (firstNonActive) {\r\n      return firstNonActive;\r\n    }\r\n\r\n    // find any mouse or pen interaction.\r\n    // ignore the interaction if the eventType is a *down, and a simulation\r\n    // is active\r\n    for (var _iterator4 = scope.interactions, _isArray4 = Array.isArray(_iterator4), _i4 = 0, _iterator4 = _isArray4 ? _iterator4 : _iterator4[Symbol.iterator]();;) {\r\n      var _ref6;\r\n\r\n      if (_isArray4) {\r\n        if (_i4 >= _iterator4.length) break;\r\n        _ref6 = _iterator4[_i4++];\r\n      } else {\r\n        _i4 = _iterator4.next();\r\n        if (_i4.done) break;\r\n        _ref6 = _i4.value;\r\n      }\r\n\r\n      var _interaction = _ref6;\r\n\r\n      if (_interaction.pointerType === pointerType && !(/down/i.test(eventType) && _interaction.simulation)) {\r\n        return _interaction;\r\n      }\r\n    }\r\n\r\n    return null;\r\n  },\r\n\r\n  // get interaction that has this pointer\r\n  hasPointer: function hasPointer(_ref7) {\r\n    var pointerId = _ref7.pointerId;\r\n\r\n    for (var _iterator5 = scope.interactions, _isArray5 = Array.isArray(_iterator5), _i5 = 0, _iterator5 = _isArray5 ? _iterator5 : _iterator5[Symbol.iterator]();;) {\r\n      var _ref8;\r\n\r\n      if (_isArray5) {\r\n        if (_i5 >= _iterator5.length) break;\r\n        _ref8 = _iterator5[_i5++];\r\n      } else {\r\n        _i5 = _iterator5.next();\r\n        if (_i5.done) break;\r\n        _ref8 = _i5.value;\r\n      }\r\n\r\n      var interaction = _ref8;\r\n\r\n      if (utils.contains(interaction.pointerIds, pointerId)) {\r\n        return interaction;\r\n      }\r\n    }\r\n  },\r\n\r\n  // get first idle interaction with a matching pointerType\r\n  idle: function idle(_ref9) {\r\n    var pointerType = _ref9.pointerType;\r\n\r\n    for (var _iterator6 = scope.interactions, _isArray6 = Array.isArray(_iterator6), _i6 = 0, _iterator6 = _isArray6 ? _iterator6 : _iterator6[Symbol.iterator]();;) {\r\n      var _ref10;\r\n\r\n      if (_isArray6) {\r\n        if (_i6 >= _iterator6.length) break;\r\n        _ref10 = _iterator6[_i6++];\r\n      } else {\r\n        _i6 = _iterator6.next();\r\n        if (_i6.done) break;\r\n        _ref10 = _i6.value;\r\n      }\r\n\r\n      var interaction = _ref10;\r\n\r\n      // if there's already a pointer held down\r\n      if (interaction.pointerIds.length === 1) {\r\n        var target = interaction.target;\r\n        // don't add this pointer if there is a target interactable and it\r\n        // isn't gesturable\r\n        if (target && !target.options.gesture.enabled) {\r\n          continue;\r\n        }\r\n      }\r\n      // maximum of 2 pointers per interaction\r\n      else if (interaction.pointerIds.length >= 2) {\r\n          continue;\r\n        }\r\n\r\n      if (!interaction.interacting() && pointerType === interaction.pointerType) {\r\n        return interaction;\r\n      }\r\n    }\r\n\r\n    return null;\r\n  }\r\n};\r\n\r\nmodule.exports = finder;\r\n\r\n},{\"../scope\":34,\"./index\":44}],46:[function(require,module,exports){\r\n'use strict';\r\n\r\nvar _typeof = typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; };\r\n\r\nvar win = require('./window');\r\nvar isWindow = require('./isWindow');\r\n\r\nvar is = {\r\n  array: function array() {},\r\n\r\n  window: function window(thing) {\r\n    return thing === win.window || isWindow(thing);\r\n  },\r\n\r\n  docFrag: function docFrag(thing) {\r\n    return is.object(thing) && thing.nodeType === 11;\r\n  },\r\n\r\n  object: function object(thing) {\r\n    return !!thing && (typeof thing === 'undefined' ? 'undefined' : _typeof(thing)) === 'object';\r\n  },\r\n\r\n  function: function _function(thing) {\r\n    return typeof thing === 'function';\r\n  },\r\n\r\n  number: function number(thing) {\r\n    return typeof thing === 'number';\r\n  },\r\n\r\n  bool: function bool(thing) {\r\n    return typeof thing === 'boolean';\r\n  },\r\n\r\n  string: function string(thing) {\r\n    return typeof thing === 'string';\r\n  },\r\n\r\n  element: function element(thing) {\r\n    if (!thing || (typeof thing === 'undefined' ? 'undefined' : _typeof(thing)) !== 'object') {\r\n      return false;\r\n    }\r\n\r\n    var _window = win.getWindow(thing) || win.window;\r\n\r\n    return (/object|function/.test(_typeof(_window.Element)) ? thing instanceof _window.Element //DOM2\r\n      : thing.nodeType === 1 && typeof thing.nodeName === 'string'\r\n    );\r\n  }\r\n};\r\n\r\nis.array = function (thing) {\r\n  return is.object(thing) && typeof thing.length !== 'undefined' && is.function(thing.splice);\r\n};\r\n\r\nmodule.exports = is;\r\n\r\n},{\"./isWindow\":47,\"./window\":52}],47:[function(require,module,exports){\r\n\"use strict\";\r\n\r\nmodule.exports = function (thing) {\r\n  return !!(thing && thing.Window) && thing instanceof thing.Window;\r\n};\r\n\r\n},{}],48:[function(require,module,exports){\r\n'use strict';\r\n\r\nfunction pointerExtend(dest, source) {\r\n  for (var prop in source) {\r\n    var prefixedPropREs = module.exports.prefixedPropREs;\r\n    var deprecated = false;\r\n\r\n    // skip deprecated prefixed properties\r\n    for (var vendor in prefixedPropREs) {\r\n      if (prop.indexOf(vendor) === 0 && prefixedPropREs[vendor].test(prop)) {\r\n        deprecated = true;\r\n        break;\r\n      }\r\n    }\r\n\r\n    if (!deprecated && typeof source[prop] !== 'function') {\r\n      dest[prop] = source[prop];\r\n    }\r\n  }\r\n  return dest;\r\n}\r\n\r\npointerExtend.prefixedPropREs = {\r\n  webkit: /(Movement[XY]|Radius[XY]|RotationAngle|Force)$/\r\n};\r\n\r\nmodule.exports = pointerExtend;\r\n\r\n},{}],49:[function(require,module,exports){\r\n'use strict';\r\n\r\nvar hypot = require('./hypot');\r\nvar browser = require('./browser');\r\nvar dom = require('./domObjects');\r\nvar domUtils = require('./domUtils');\r\nvar domObjects = require('./domObjects');\r\nvar is = require('./is');\r\nvar pointerExtend = require('./pointerExtend');\r\n\r\nvar pointerUtils = {\r\n  copyCoords: function copyCoords(dest, src) {\r\n    dest.page = dest.page || {};\r\n    dest.page.x = src.page.x;\r\n    dest.page.y = src.page.y;\r\n\r\n    dest.client = dest.client || {};\r\n    dest.client.x = src.client.x;\r\n    dest.client.y = src.client.y;\r\n\r\n    dest.timeStamp = src.timeStamp;\r\n  },\r\n\r\n  setCoordDeltas: function setCoordDeltas(targetObj, prev, cur) {\r\n    targetObj.page.x = cur.page.x - prev.page.x;\r\n    targetObj.page.y = cur.page.y - prev.page.y;\r\n    targetObj.client.x = cur.client.x - prev.client.x;\r\n    targetObj.client.y = cur.client.y - prev.client.y;\r\n    targetObj.timeStamp = cur.timeStamp - prev.timeStamp;\r\n\r\n    // set pointer velocity\r\n    var dt = Math.max(targetObj.timeStamp / 1000, 0.001);\r\n\r\n    targetObj.page.speed = hypot(targetObj.page.x, targetObj.page.y) / dt;\r\n    targetObj.page.vx = targetObj.page.x / dt;\r\n    targetObj.page.vy = targetObj.page.y / dt;\r\n\r\n    targetObj.client.speed = hypot(targetObj.client.x, targetObj.page.y) / dt;\r\n    targetObj.client.vx = targetObj.client.x / dt;\r\n    targetObj.client.vy = targetObj.client.y / dt;\r\n  },\r\n\r\n  isNativePointer: function isNativePointer(pointer) {\r\n    return pointer instanceof dom.Event || pointer instanceof dom.Touch;\r\n  },\r\n\r\n  // Get specified X/Y coords for mouse or event.touches[0]\r\n  getXY: function getXY(type, pointer, xy) {\r\n    xy = xy || {};\r\n    type = type || 'page';\r\n\r\n    xy.x = pointer[type + 'X'];\r\n    xy.y = pointer[type + 'Y'];\r\n\r\n    return xy;\r\n  },\r\n\r\n  getPageXY: function getPageXY(pointer, page) {\r\n    page = page || {};\r\n\r\n    // Opera Mobile handles the viewport and scrolling oddly\r\n    if (browser.isOperaMobile && pointerUtils.isNativePointer(pointer)) {\r\n      pointerUtils.getXY('screen', pointer, page);\r\n\r\n      page.x += window.scrollX;\r\n      page.y += window.scrollY;\r\n    } else {\r\n      pointerUtils.getXY('page', pointer, page);\r\n    }\r\n\r\n    return page;\r\n  },\r\n\r\n  getClientXY: function getClientXY(pointer, client) {\r\n    client = client || {};\r\n\r\n    if (browser.isOperaMobile && pointerUtils.isNativePointer(pointer)) {\r\n      // Opera Mobile handles the viewport and scrolling oddly\r\n      pointerUtils.getXY('screen', pointer, client);\r\n    } else {\r\n      pointerUtils.getXY('client', pointer, client);\r\n    }\r\n\r\n    return client;\r\n  },\r\n\r\n  getPointerId: function getPointerId(pointer) {\r\n    return is.number(pointer.pointerId) ? pointer.pointerId : pointer.identifier;\r\n  },\r\n\r\n  setCoords: function setCoords(targetObj, pointers, timeStamp) {\r\n    var pointer = pointers.length > 1 ? pointerUtils.pointerAverage(pointers) : pointers[0];\r\n\r\n    var tmpXY = {};\r\n\r\n    pointerUtils.getPageXY(pointer, tmpXY);\r\n    targetObj.page.x = tmpXY.x;\r\n    targetObj.page.y = tmpXY.y;\r\n\r\n    pointerUtils.getClientXY(pointer, tmpXY);\r\n    targetObj.client.x = tmpXY.x;\r\n    targetObj.client.y = tmpXY.y;\r\n\r\n    targetObj.timeStamp = is.number(timeStamp) ? timeStamp : new Date().getTime();\r\n  },\r\n\r\n  pointerExtend: pointerExtend,\r\n\r\n  getTouchPair: function getTouchPair(event) {\r\n    var touches = [];\r\n\r\n    // array of touches is supplied\r\n    if (is.array(event)) {\r\n      touches[0] = event[0];\r\n      touches[1] = event[1];\r\n    }\r\n    // an event\r\n    else {\r\n        if (event.type === 'touchend') {\r\n          if (event.touches.length === 1) {\r\n            touches[0] = event.touches[0];\r\n            touches[1] = event.changedTouches[0];\r\n          } else if (event.touches.length === 0) {\r\n            touches[0] = event.changedTouches[0];\r\n            touches[1] = event.changedTouches[1];\r\n          }\r\n        } else {\r\n          touches[0] = event.touches[0];\r\n          touches[1] = event.touches[1];\r\n        }\r\n      }\r\n\r\n    return touches;\r\n  },\r\n\r\n  pointerAverage: function pointerAverage(pointers) {\r\n    var average = {\r\n      pageX: 0,\r\n      pageY: 0,\r\n      clientX: 0,\r\n      clientY: 0,\r\n      screenX: 0,\r\n      screenY: 0\r\n    };\r\n\r\n    for (var _iterator = pointers, _isArray = Array.isArray(_iterator), _i = 0, _iterator = _isArray ? _iterator : _iterator[Symbol.iterator]();;) {\r\n      var _ref;\r\n\r\n      if (_isArray) {\r\n        if (_i >= _iterator.length) break;\r\n        _ref = _iterator[_i++];\r\n      } else {\r\n        _i = _iterator.next();\r\n        if (_i.done) break;\r\n        _ref = _i.value;\r\n      }\r\n\r\n      var pointer = _ref;\r\n\r\n      for (var _prop in average) {\r\n        average[_prop] += pointer[_prop];\r\n      }\r\n    }\r\n    for (var prop in average) {\r\n      average[prop] /= pointers.length;\r\n    }\r\n\r\n    return average;\r\n  },\r\n\r\n  touchBBox: function touchBBox(event) {\r\n    if (!event.length && !(event.touches && event.touches.length > 1)) {\r\n      return;\r\n    }\r\n\r\n    var touches = pointerUtils.getTouchPair(event);\r\n    var minX = Math.min(touches[0].pageX, touches[1].pageX);\r\n    var minY = Math.min(touches[0].pageY, touches[1].pageY);\r\n    var maxX = Math.max(touches[0].pageX, touches[1].pageX);\r\n    var maxY = Math.max(touches[0].pageY, touches[1].pageY);\r\n\r\n    return {\r\n      x: minX,\r\n      y: minY,\r\n      left: minX,\r\n      top: minY,\r\n      width: maxX - minX,\r\n      height: maxY - minY\r\n    };\r\n  },\r\n\r\n  touchDistance: function touchDistance(event, deltaSource) {\r\n    var sourceX = deltaSource + 'X';\r\n    var sourceY = deltaSource + 'Y';\r\n    var touches = pointerUtils.getTouchPair(event);\r\n\r\n    var dx = touches[0][sourceX] - touches[1][sourceX];\r\n    var dy = touches[0][sourceY] - touches[1][sourceY];\r\n\r\n    return hypot(dx, dy);\r\n  },\r\n\r\n  touchAngle: function touchAngle(event, prevAngle, deltaSource) {\r\n    var sourceX = deltaSource + 'X';\r\n    var sourceY = deltaSource + 'Y';\r\n    var touches = pointerUtils.getTouchPair(event);\r\n    var dx = touches[1][sourceX] - touches[0][sourceX];\r\n    var dy = touches[1][sourceY] - touches[0][sourceY];\r\n    var angle = 180 * Math.atan2(dy, dx) / Math.PI;\r\n\r\n    return angle;\r\n  },\r\n\r\n  getPointerType: function getPointerType(pointer) {\r\n    return is.string(pointer.pointerType) ? pointer.pointerType : is.number(pointer.pointerType) ? [undefined, undefined, 'touch', 'pen', 'mouse'][pointer.pointerType]\r\n    // if the PointerEvent API isn't available, then the \"pointer\" must\r\n    // be either a MouseEvent, TouchEvent, or Touch object\r\n    : /touch/.test(pointer.type) || pointer instanceof domObjects.Touch ? 'touch' : 'mouse';\r\n  },\r\n\r\n  // [ event.target, event.currentTarget ]\r\n  getEventTargets: function getEventTargets(event) {\r\n    return [domUtils.getActualElement(event.path ? event.path[0] : event.target), domUtils.getActualElement(event.currentTarget)];\r\n  }\r\n};\r\n\r\nmodule.exports = pointerUtils;\r\n\r\n},{\"./browser\":37,\"./domObjects\":38,\"./domUtils\":39,\"./hypot\":43,\"./is\":46,\"./pointerExtend\":48}],50:[function(require,module,exports){\r\n'use strict';\r\n\r\nvar _require = require('./window'),\r\n    window = _require.window;\r\n\r\nvar vendors = ['ms', 'moz', 'webkit', 'o'];\r\nvar lastTime = 0;\r\nvar request = void 0;\r\nvar cancel = void 0;\r\n\r\nfor (var x = 0; x < vendors.length && !window.requestAnimationFrame; x++) {\r\n  request = window[vendors[x] + 'RequestAnimationFrame'];\r\n  cancel = window[vendors[x] + 'CancelAnimationFrame'] || window[vendors[x] + 'CancelRequestAnimationFrame'];\r\n}\r\n\r\nif (!request) {\r\n  request = function request(callback) {\r\n    var currTime = new Date().getTime();\r\n    var timeToCall = Math.max(0, 16 - (currTime - lastTime));\r\n    var id = setTimeout(function () {\r\n      callback(currTime + timeToCall);\r\n    }, timeToCall);\r\n\r\n    lastTime = currTime + timeToCall;\r\n    return id;\r\n  };\r\n}\r\n\r\nif (!cancel) {\r\n  cancel = function cancel(id) {\r\n    clearTimeout(id);\r\n  };\r\n}\r\n\r\nmodule.exports = {\r\n  request: request,\r\n  cancel: cancel\r\n};\r\n\r\n},{\"./window\":52}],51:[function(require,module,exports){\r\n'use strict';\r\n\r\nvar extend = require('./extend');\r\nvar is = require('./is');\r\n\r\nvar _require = require('./domUtils'),\r\n    closest = _require.closest,\r\n    parentNode = _require.parentNode,\r\n    getElementRect = _require.getElementRect;\r\n\r\nvar rectUtils = {\r\n  getStringOptionResult: function getStringOptionResult(value, interactable, element) {\r\n    if (!is.string(value)) {\r\n      return null;\r\n    }\r\n\r\n    if (value === 'parent') {\r\n      value = parentNode(element);\r\n    } else if (value === 'self') {\r\n      value = interactable.getRect(element);\r\n    } else {\r\n      value = closest(element, value);\r\n    }\r\n\r\n    return value;\r\n  },\r\n\r\n  resolveRectLike: function resolveRectLike(value, interactable, element, functionArgs) {\r\n    value = rectUtils.getStringOptionResult(value, interactable, element) || value;\r\n\r\n    if (is.function(value)) {\r\n      value = value.apply(null, functionArgs);\r\n    }\r\n\r\n    if (is.element(value)) {\r\n      value = getElementRect(value);\r\n    }\r\n\r\n    return value;\r\n  },\r\n\r\n  rectToXY: function rectToXY(rect) {\r\n    return rect && {\r\n      x: 'x' in rect ? rect.x : rect.left,\r\n      y: 'y' in rect ? rect.y : rect.top\r\n    };\r\n  },\r\n\r\n  xywhToTlbr: function xywhToTlbr(rect) {\r\n    if (rect && !('left' in rect && 'top' in rect)) {\r\n      rect = extend({}, rect);\r\n\r\n      rect.left = rect.x || 0;\r\n      rect.top = rect.y || 0;\r\n      rect.right = rect.right || rect.left + rect.width;\r\n      rect.bottom = rect.bottom || rect.top + rect.height;\r\n    }\r\n\r\n    return rect;\r\n  },\r\n\r\n  tlbrToXywh: function tlbrToXywh(rect) {\r\n    if (rect && !('x' in rect && 'y' in rect)) {\r\n      rect = extend({}, rect);\r\n\r\n      rect.x = rect.left || 0;\r\n      rect.top = rect.top || 0;\r\n      rect.width = rect.width || rect.right - rect.x;\r\n      rect.height = rect.height || rect.bottom - rect.y;\r\n    }\r\n\r\n    return rect;\r\n  }\r\n};\r\n\r\nmodule.exports = rectUtils;\r\n\r\n},{\"./domUtils\":39,\"./extend\":41,\"./is\":46}],52:[function(require,module,exports){\r\n'use strict';\r\n\r\nvar win = module.exports;\r\nvar isWindow = require('./isWindow');\r\n\r\nfunction init(window) {\r\n  // get wrapped window if using Shadow DOM polyfill\r\n\r\n  win.realWindow = window;\r\n\r\n  // create a TextNode\r\n  var el = window.document.createTextNode('');\r\n\r\n  // check if it's wrapped by a polyfill\r\n  if (el.ownerDocument !== window.document && typeof window.wrap === 'function' && window.wrap(el) === el) {\r\n    // use wrapped window\r\n    window = window.wrap(window);\r\n  }\r\n\r\n  win.window = window;\r\n}\r\n\r\nif (typeof window === 'undefined') {\r\n  win.window = undefined;\r\n  win.realWindow = undefined;\r\n} else {\r\n  init(window);\r\n}\r\n\r\nwin.getWindow = function getWindow(node) {\r\n  if (isWindow(node)) {\r\n    return node;\r\n  }\r\n\r\n  var rootNode = node.ownerDocument || node;\r\n\r\n  return rootNode.defaultView || rootNode.parentWindow || win.window;\r\n};\r\n\r\nwin.init = init;\r\n\r\n},{\"./isWindow\":47}]},{},[1])(1)\r\n});\r\n\r\n\r\n//# sourceMappingURL=interact.js.map\r\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/interactjs/dist/interact.js\n// module id = 15\n// module chunks = 0"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///15\n"); /***/ }), /* 16 */ /***/ (function(module, exports, __webpack_require__) { -eval("var require;var require;/**\n * interact.js v1.3.0-alpha.4+sha.7970416-dirty\n *\n * Copyright (c) 2012-2017 Taye Adeyemi \n * Open source under the MIT License.\n * https://raw.github.com/taye/interact.js/master/LICENSE\n */\n(function(f){if(true){module.exports=f()}else if(typeof define===\"function\"&&define.amd){define([],f)}else{var g;if(typeof window!==\"undefined\"){g=window}else if(typeof global!==\"undefined\"){g=global}else if(typeof self!==\"undefined\"){g=self}else{g=this}g.interact = f()}})(function(){var define,module,exports;return (function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require==\"function\"&&require;if(!u&&a)return require(o,!0);if(i)return i(o,!0);var f=new Error(\"Cannot find module '\"+o+\"'\");throw f.code=\"MODULE_NOT_FOUND\",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require==\"function\"&&require;for(var o=0;o 6 && arguments[6] !== undefined ? arguments[6] : false;\n\n _classCallCheck(this, InteractEvent);\n\n var target = interaction.target;\n var deltaSource = (target && target.options || defaults).deltaSource;\n var origin = getOriginXY(target, element, action);\n var starting = phase === 'start';\n var ending = phase === 'end';\n var coords = starting ? interaction.startCoords : interaction.curCoords;\n var prevEvent = interaction.prevEvent;\n\n element = element || interaction.element;\n\n var page = extend({}, coords.page);\n var client = extend({}, coords.client);\n\n page.x -= origin.x;\n page.y -= origin.y;\n\n client.x -= origin.x;\n client.y -= origin.y;\n\n this.ctrlKey = event.ctrlKey;\n this.altKey = event.altKey;\n this.shiftKey = event.shiftKey;\n this.metaKey = event.metaKey;\n this.button = event.button;\n this.buttons = event.buttons;\n this.target = element;\n this.currentTarget = element;\n this.relatedTarget = related || null;\n this.preEnd = preEnd;\n this.type = action + (phase || '');\n this.interaction = interaction;\n this.interactable = target;\n\n this.t0 = starting ? interaction.downTimes[interaction.downTimes.length - 1] : prevEvent.t0;\n\n var signalArg = {\n interaction: interaction,\n event: event,\n action: action,\n phase: phase,\n element: element,\n related: related,\n page: page,\n client: client,\n coords: coords,\n starting: starting,\n ending: ending,\n deltaSource: deltaSource,\n iEvent: this\n };\n\n signals.fire('set-xy', signalArg);\n\n if (ending) {\n // use previous coords when ending\n this.pageX = prevEvent.pageX;\n this.pageY = prevEvent.pageY;\n this.clientX = prevEvent.clientX;\n this.clientY = prevEvent.clientY;\n } else {\n this.pageX = page.x;\n this.pageY = page.y;\n this.clientX = client.x;\n this.clientY = client.y;\n }\n\n this.x0 = interaction.startCoords.page.x - origin.x;\n this.y0 = interaction.startCoords.page.y - origin.y;\n this.clientX0 = interaction.startCoords.client.x - origin.x;\n this.clientY0 = interaction.startCoords.client.y - origin.y;\n\n signals.fire('set-delta', signalArg);\n\n this.timeStamp = coords.timeStamp;\n this.dt = interaction.pointerDelta.timeStamp;\n this.duration = this.timeStamp - this.t0;\n\n // speed and velocity in pixels per second\n this.speed = interaction.pointerDelta[deltaSource].speed;\n this.velocityX = interaction.pointerDelta[deltaSource].vx;\n this.velocityY = interaction.pointerDelta[deltaSource].vy;\n\n this.swipe = ending || phase === 'inertiastart' ? this.getSwipe() : null;\n\n signals.fire('new', signalArg);\n }\n\n InteractEvent.prototype.getSwipe = function getSwipe() {\n var interaction = this.interaction;\n\n if (interaction.prevEvent.speed < 600 || this.timeStamp - interaction.prevEvent.timeStamp > 150) {\n return null;\n }\n\n var angle = 180 * Math.atan2(interaction.prevEvent.velocityY, interaction.prevEvent.velocityX) / Math.PI;\n var overlap = 22.5;\n\n if (angle < 0) {\n angle += 360;\n }\n\n var left = 135 - overlap <= angle && angle < 225 + overlap;\n var up = 225 - overlap <= angle && angle < 315 + overlap;\n\n var right = !left && (315 - overlap <= angle || angle < 45 + overlap);\n var down = !up && 45 - overlap <= angle && angle < 135 + overlap;\n\n return {\n up: up,\n down: down,\n left: left,\n right: right,\n angle: angle,\n speed: interaction.prevEvent.speed,\n velocity: {\n x: interaction.prevEvent.velocityX,\n y: interaction.prevEvent.velocityY\n }\n };\n };\n\n InteractEvent.prototype.preventDefault = function preventDefault() {};\n\n InteractEvent.prototype.stopImmediatePropagation = function stopImmediatePropagation() {\n this.immediatePropagationStopped = this.propagationStopped = true;\n };\n\n InteractEvent.prototype.stopPropagation = function stopPropagation() {\n this.propagationStopped = true;\n };\n\n return InteractEvent;\n}();\n\nsignals.on('set-delta', function (_ref) {\n var iEvent = _ref.iEvent,\n interaction = _ref.interaction,\n starting = _ref.starting,\n deltaSource = _ref.deltaSource;\n\n var prevEvent = starting ? iEvent : interaction.prevEvent;\n\n if (deltaSource === 'client') {\n iEvent.dx = iEvent.clientX - prevEvent.clientX;\n iEvent.dy = iEvent.clientY - prevEvent.clientY;\n } else {\n iEvent.dx = iEvent.pageX - prevEvent.pageX;\n iEvent.dy = iEvent.pageY - prevEvent.pageY;\n }\n});\n\nInteractEvent.signals = signals;\n\nmodule.exports = InteractEvent;\n\n},{\"./defaultOptions\":18,\"./utils/Signals\":35,\"./utils/extend\":41,\"./utils/getOriginXY\":42}],4:[function(require,module,exports){\n'use strict';\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nvar is = require('./utils/is');\nvar events = require('./utils/events');\nvar extend = require('./utils/extend');\nvar actions = require('./actions/base');\nvar scope = require('./scope');\nvar Eventable = require('./Eventable');\nvar defaults = require('./defaultOptions');\nvar signals = require('./utils/Signals').new();\n\nvar _require = require('./utils/domUtils'),\n getElementRect = _require.getElementRect,\n nodeContains = _require.nodeContains,\n trySelector = _require.trySelector;\n\nvar _require2 = require('./utils/window'),\n getWindow = _require2.getWindow;\n\nvar _require3 = require('./utils/arr'),\n indexOf = _require3.indexOf,\n contains = _require3.contains;\n\nvar _require4 = require('./utils/browser'),\n wheelEvent = _require4.wheelEvent;\n\n// all set interactables\n\n\nscope.interactables = [];\n\n/*\\\n * Interactable\n [ property ]\n **\n * Object type returned by @interact\n\\*/\n\nvar Interactable = function () {\n function Interactable(target, options) {\n _classCallCheck(this, Interactable);\n\n options = options || {};\n\n this.target = target;\n this.events = new Eventable();\n this._context = options.context || scope.document;\n this._win = getWindow(trySelector(target) ? this._context : target);\n this._doc = this._win.document;\n\n signals.fire('new', {\n target: target,\n options: options,\n interactable: this,\n win: this._win\n });\n\n scope.addDocument(this._doc, this._win);\n\n scope.interactables.push(this);\n\n this.set(options);\n }\n\n Interactable.prototype.setOnEvents = function setOnEvents(action, phases) {\n var onAction = 'on' + action;\n\n if (is.function(phases.onstart)) {\n this.events[onAction + 'start'] = phases.onstart;\n }\n if (is.function(phases.onmove)) {\n this.events[onAction + 'move'] = phases.onmove;\n }\n if (is.function(phases.onend)) {\n this.events[onAction + 'end'] = phases.onend;\n }\n if (is.function(phases.oninertiastart)) {\n this.events[onAction + 'inertiastart'] = phases.oninertiastart;\n }\n\n return this;\n };\n\n Interactable.prototype.setPerAction = function setPerAction(action, options) {\n // for all the default per-action options\n for (var option in options) {\n // if this option exists for this action\n if (option in defaults[action]) {\n // if the option in the options arg is an object value\n if (is.object(options[option])) {\n // duplicate the object\n this.options[action][option] = extend(this.options[action][option] || {}, options[option]);\n\n if (is.object(defaults.perAction[option]) && 'enabled' in defaults.perAction[option]) {\n this.options[action][option].enabled = options[option].enabled === false ? false : true;\n }\n } else if (is.bool(options[option]) && is.object(defaults.perAction[option])) {\n this.options[action][option].enabled = options[option];\n } else if (options[option] !== undefined) {\n // or if it's not undefined, do a plain assignment\n this.options[action][option] = options[option];\n }\n }\n }\n };\n\n /*\\\n * Interactable.getRect\n [ method ]\n *\n * The default function to get an Interactables bounding rect. Can be\n * overridden using @Interactable.rectChecker.\n *\n - element (Element) #optional The element to measure.\n = (object) The object's bounding rectangle.\n o {\n o top : 0,\n o left : 0,\n o bottom: 0,\n o right : 0,\n o width : 0,\n o height: 0\n o }\n \\*/\n\n\n Interactable.prototype.getRect = function getRect(element) {\n element = element || this.target;\n\n if (is.string(this.target) && !is.element(element)) {\n element = this._context.querySelector(this.target);\n }\n\n return getElementRect(element);\n };\n\n /*\\\n * Interactable.rectChecker\n [ method ]\n *\n * Returns or sets the function used to calculate the interactable's\n * element's rectangle\n *\n - checker (function) #optional A function which returns this Interactable's bounding rectangle. See @Interactable.getRect\n = (function | object) The checker function or this Interactable\n \\*/\n\n\n Interactable.prototype.rectChecker = function rectChecker(checker) {\n if (is.function(checker)) {\n this.getRect = checker;\n\n return this;\n }\n\n if (checker === null) {\n delete this.options.getRect;\n\n return this;\n }\n\n return this.getRect;\n };\n\n Interactable.prototype._backCompatOption = function _backCompatOption(optionName, newValue) {\n if (trySelector(newValue) || is.object(newValue)) {\n this.options[optionName] = newValue;\n\n for (var _iterator = actions.names, _isArray = Array.isArray(_iterator), _i = 0, _iterator = _isArray ? _iterator : _iterator[Symbol.iterator]();;) {\n var _ref;\n\n if (_isArray) {\n if (_i >= _iterator.length) break;\n _ref = _iterator[_i++];\n } else {\n _i = _iterator.next();\n if (_i.done) break;\n _ref = _i.value;\n }\n\n var action = _ref;\n\n this.options[action][optionName] = newValue;\n }\n\n return this;\n }\n\n return this.options[optionName];\n };\n\n /*\\\n * Interactable.origin\n [ method ]\n *\n * Gets or sets the origin of the Interactable's element. The x and y\n * of the origin will be subtracted from action event coordinates.\n *\n - origin (object | string) #optional An object eg. { x: 0, y: 0 } or string 'parent', 'self' or any CSS selector\n * OR\n - origin (Element) #optional An HTML or SVG Element whose rect will be used\n **\n = (object) The current origin or this Interactable\n \\*/\n\n\n Interactable.prototype.origin = function origin(newValue) {\n return this._backCompatOption('origin', newValue);\n };\n\n /*\\\n * Interactable.deltaSource\n [ method ]\n *\n * Returns or sets the mouse coordinate types used to calculate the\n * movement of the pointer.\n *\n - newValue (string) #optional Use 'client' if you will be scrolling while interacting; Use 'page' if you want autoScroll to work\n = (string | object) The current deltaSource or this Interactable\n \\*/\n\n\n Interactable.prototype.deltaSource = function deltaSource(newValue) {\n if (newValue === 'page' || newValue === 'client') {\n this.options.deltaSource = newValue;\n\n return this;\n }\n\n return this.options.deltaSource;\n };\n\n /*\\\n * Interactable.context\n [ method ]\n *\n * Gets the selector context Node of the Interactable. The default is `window.document`.\n *\n = (Node) The context Node of this Interactable\n **\n \\*/\n\n\n Interactable.prototype.context = function context() {\n return this._context;\n };\n\n Interactable.prototype.inContext = function inContext(element) {\n return this._context === element.ownerDocument || nodeContains(this._context, element);\n };\n\n /*\\\n * Interactable.fire\n [ method ]\n *\n * Calls listeners for the given InteractEvent type bound globally\n * and directly to this Interactable\n *\n - iEvent (InteractEvent) The InteractEvent object to be fired on this Interactable\n = (Interactable) this Interactable\n \\*/\n\n\n Interactable.prototype.fire = function fire(iEvent) {\n this.events.fire(iEvent);\n\n return this;\n };\n\n Interactable.prototype._onOffMultiple = function _onOffMultiple(method, eventType, listener, options) {\n if (is.string(eventType) && eventType.search(' ') !== -1) {\n eventType = eventType.trim().split(/ +/);\n }\n\n if (is.array(eventType)) {\n for (var i = 0; i < eventType.length; i++) {\n this[method](eventType[i], listener, options);\n }\n\n return true;\n }\n\n if (is.object(eventType)) {\n for (var prop in eventType) {\n this[method](prop, eventType[prop], listener);\n }\n\n return true;\n }\n };\n\n /*\\\n * Interactable.on\n [ method ]\n *\n * Binds a listener for an InteractEvent, pointerEvent or DOM event.\n *\n - eventType (string | array | object) The types of events to listen for\n - listener (function) The function event (s)\n - options (object | boolean) #optional options object or useCapture flag for addEventListener\n = (object) This Interactable\n \\*/\n\n\n Interactable.prototype.on = function on(eventType, listener, options) {\n if (this._onOffMultiple('on', eventType, listener, options)) {\n return this;\n }\n\n if (eventType === 'wheel') {\n eventType = wheelEvent;\n }\n\n if (contains(Interactable.eventTypes, eventType)) {\n this.events.on(eventType, listener);\n }\n // delegated event for selector\n else if (is.string(this.target)) {\n events.addDelegate(this.target, this._context, eventType, listener, options);\n } else {\n events.add(this.target, eventType, listener, options);\n }\n\n return this;\n };\n\n /*\\\n * Interactable.off\n [ method ]\n *\n * Removes an InteractEvent, pointerEvent or DOM event listener\n *\n - eventType (string | array | object) The types of events that were listened for\n - listener (function) The listener function to be removed\n - options (object | boolean) #optional options object or useCapture flag for removeEventListener\n = (object) This Interactable\n \\*/\n\n\n Interactable.prototype.off = function off(eventType, listener, options) {\n if (this._onOffMultiple('off', eventType, listener, options)) {\n return this;\n }\n\n if (eventType === 'wheel') {\n eventType = wheelEvent;\n }\n\n // if it is an action event type\n if (contains(Interactable.eventTypes, eventType)) {\n this.events.off(eventType, listener);\n }\n // delegated event\n else if (is.string(this.target)) {\n events.removeDelegate(this.target, this._context, eventType, listener, options);\n }\n // remove listener from this Interatable's element\n else {\n events.remove(this.target, eventType, listener, options);\n }\n\n return this;\n };\n\n /*\\\n * Interactable.set\n [ method ]\n *\n * Reset the options of this Interactable\n - options (object) The new settings to apply\n = (object) This Interactable\n \\*/\n\n\n Interactable.prototype.set = function set(options) {\n if (!is.object(options)) {\n options = {};\n }\n\n this.options = extend({}, defaults.base);\n\n var perActions = extend({}, defaults.perAction);\n\n for (var actionName in actions.methodDict) {\n var methodName = actions.methodDict[actionName];\n\n this.options[actionName] = extend({}, defaults[actionName]);\n\n this.setPerAction(actionName, perActions);\n\n this[methodName](options[actionName]);\n }\n\n for (var _iterator2 = Interactable.settingsMethods, _isArray2 = Array.isArray(_iterator2), _i2 = 0, _iterator2 = _isArray2 ? _iterator2 : _iterator2[Symbol.iterator]();;) {\n var _ref2;\n\n if (_isArray2) {\n if (_i2 >= _iterator2.length) break;\n _ref2 = _iterator2[_i2++];\n } else {\n _i2 = _iterator2.next();\n if (_i2.done) break;\n _ref2 = _i2.value;\n }\n\n var setting = _ref2;\n\n this.options[setting] = defaults.base[setting];\n\n if (setting in options) {\n this[setting](options[setting]);\n }\n }\n\n signals.fire('set', {\n options: options,\n interactable: this\n });\n\n return this;\n };\n\n /*\\\n * Interactable.unset\n [ method ]\n *\n * Remove this interactable from the list of interactables and remove\n * it's action capabilities and event listeners\n *\n = (object) @interact\n \\*/\n\n\n Interactable.prototype.unset = function unset() {\n events.remove(this.target, 'all');\n\n if (is.string(this.target)) {\n // remove delegated events\n for (var type in events.delegatedEvents) {\n var delegated = events.delegatedEvents[type];\n\n if (delegated.selectors[0] === this.target && delegated.contexts[0] === this._context) {\n\n delegated.selectors.splice(0, 1);\n delegated.contexts.splice(0, 1);\n delegated.listeners.splice(0, 1);\n\n // remove the arrays if they are empty\n if (!delegated.selectors.length) {\n delegated[type] = null;\n }\n }\n\n events.remove(this._context, type, events.delegateListener);\n events.remove(this._context, type, events.delegateUseCapture, true);\n }\n } else {\n events.remove(this, 'all');\n }\n\n signals.fire('unset', { interactable: this });\n\n scope.interactables.splice(indexOf(scope.interactables, this), 1);\n\n // Stop related interactions when an Interactable is unset\n for (var _iterator3 = scope.interactions || [], _isArray3 = Array.isArray(_iterator3), _i3 = 0, _iterator3 = _isArray3 ? _iterator3 : _iterator3[Symbol.iterator]();;) {\n var _ref3;\n\n if (_isArray3) {\n if (_i3 >= _iterator3.length) break;\n _ref3 = _iterator3[_i3++];\n } else {\n _i3 = _iterator3.next();\n if (_i3.done) break;\n _ref3 = _i3.value;\n }\n\n var interaction = _ref3;\n\n if (interaction.target === this && interaction.interacting()) {\n interaction.stop();\n }\n }\n\n return scope.interact;\n };\n\n return Interactable;\n}();\n\nscope.interactables.indexOfElement = function indexOfElement(target, context) {\n context = context || scope.document;\n\n for (var i = 0; i < this.length; i++) {\n var interactable = this[i];\n\n if (interactable.target === target && interactable._context === context) {\n return i;\n }\n }\n return -1;\n};\n\nscope.interactables.get = function interactableGet(element, options, dontCheckInContext) {\n var ret = this[this.indexOfElement(element, options && options.context)];\n\n return ret && (is.string(element) || dontCheckInContext || ret.inContext(element)) ? ret : null;\n};\n\nscope.interactables.forEachSelector = function (callback, element) {\n for (var i = 0; i < this.length; i++) {\n var interactable = this[i];\n\n // skip non CSS selector targets and out of context elements\n if (!is.string(interactable.target) || element && !interactable.inContext(element)) {\n continue;\n }\n\n var ret = callback(interactable, interactable.target, interactable._context, i, this);\n\n if (ret !== undefined) {\n return ret;\n }\n }\n};\n\n// all interact.js eventTypes\nInteractable.eventTypes = scope.eventTypes = [];\n\nInteractable.signals = signals;\n\nInteractable.settingsMethods = ['deltaSource', 'origin', 'preventDefault', 'rectChecker'];\n\nmodule.exports = Interactable;\n\n},{\"./Eventable\":2,\"./actions/base\":6,\"./defaultOptions\":18,\"./scope\":34,\"./utils/Signals\":35,\"./utils/arr\":36,\"./utils/browser\":37,\"./utils/domUtils\":39,\"./utils/events\":40,\"./utils/extend\":41,\"./utils/is\":46,\"./utils/window\":52}],5:[function(require,module,exports){\n'use strict';\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nvar scope = require('./scope');\nvar utils = require('./utils');\nvar events = require('./utils/events');\nvar browser = require('./utils/browser');\nvar domObjects = require('./utils/domObjects');\nvar finder = require('./utils/interactionFinder');\nvar signals = require('./utils/Signals').new();\n\nvar listeners = {};\nvar methodNames = ['pointerDown', 'pointerMove', 'pointerUp', 'updatePointer', 'removePointer'];\n\n// for ignoring browser's simulated mouse events\nvar prevTouchTime = 0;\n\n// all active and idle interactions\nscope.interactions = [];\n\nvar Interaction = function () {\n function Interaction(_ref) {\n var pointerType = _ref.pointerType;\n\n _classCallCheck(this, Interaction);\n\n this.target = null; // current interactable being interacted with\n this.element = null; // the target element of the interactable\n\n this.prepared = { // action that's ready to be fired on next move event\n name: null,\n axis: null,\n edges: null\n };\n\n // keep track of added pointers\n this.pointers = [];\n this.pointerIds = [];\n this.downTargets = [];\n this.downTimes = [];\n\n // Previous native pointer move event coordinates\n this.prevCoords = {\n page: { x: 0, y: 0 },\n client: { x: 0, y: 0 },\n timeStamp: 0\n };\n // current native pointer move event coordinates\n this.curCoords = {\n page: { x: 0, y: 0 },\n client: { x: 0, y: 0 },\n timeStamp: 0\n };\n\n // Starting InteractEvent pointer coordinates\n this.startCoords = {\n page: { x: 0, y: 0 },\n client: { x: 0, y: 0 },\n timeStamp: 0\n };\n\n // Change in coordinates and time of the pointer\n this.pointerDelta = {\n page: { x: 0, y: 0, vx: 0, vy: 0, speed: 0 },\n client: { x: 0, y: 0, vx: 0, vy: 0, speed: 0 },\n timeStamp: 0\n };\n\n this.downEvent = null; // pointerdown/mousedown/touchstart event\n this.downPointer = {};\n\n this._eventTarget = null;\n this._curEventTarget = null;\n\n this.prevEvent = null; // previous action event\n\n this.pointerIsDown = false;\n this.pointerWasMoved = false;\n this._interacting = false;\n\n this.pointerType = pointerType;\n\n signals.fire('new', this);\n\n scope.interactions.push(this);\n }\n\n Interaction.prototype.pointerDown = function pointerDown(pointer, event, eventTarget) {\n var pointerIndex = this.updatePointer(pointer, event, true);\n\n signals.fire('down', {\n pointer: pointer,\n event: event,\n eventTarget: eventTarget,\n pointerIndex: pointerIndex,\n interaction: this\n });\n };\n\n /*\\\n * Interaction.start\n [ method ]\n *\n * Start an action with the given Interactable and Element as tartgets. The\n * action must be enabled for the target Interactable and an appropriate number\n * of pointers must be held down - 1 for drag/resize, 2 for gesture.\n *\n * Use it with `interactable.able({ manualStart: false })` to always\n * [start actions manually](https://github.com/taye/interact.js/issues/114)\n *\n - action (object) The action to be performed - drag, resize, etc.\n - target (Interactable) The Interactable to target\n - element (Element) The DOM Element to target\n = (object) interact\n **\n | interact(target)\n | .draggable({\n | // disable the default drag start by down->move\n | manualStart: true\n | })\n | // start dragging after the user holds the pointer down\n | .on('hold', function (event) {\n | var interaction = event.interaction;\n |\n | if (!interaction.interacting()) {\n | interaction.start({ name: 'drag' },\n | event.interactable,\n | event.currentTarget);\n | }\n | });\n \\*/\n\n\n Interaction.prototype.start = function start(action, target, element) {\n if (this.interacting() || !this.pointerIsDown || this.pointerIds.length < (action.name === 'gesture' ? 2 : 1)) {\n return;\n }\n\n // if this interaction had been removed after stopping\n // add it back\n if (utils.indexOf(scope.interactions, this) === -1) {\n scope.interactions.push(this);\n }\n\n utils.copyAction(this.prepared, action);\n this.target = target;\n this.element = element;\n\n signals.fire('action-start', {\n interaction: this,\n event: this.downEvent\n });\n };\n\n Interaction.prototype.pointerMove = function pointerMove(pointer, event, eventTarget) {\n if (!this.simulation) {\n this.updatePointer(pointer);\n utils.setCoords(this.curCoords, this.pointers);\n }\n\n var duplicateMove = this.curCoords.page.x === this.prevCoords.page.x && this.curCoords.page.y === this.prevCoords.page.y && this.curCoords.client.x === this.prevCoords.client.x && this.curCoords.client.y === this.prevCoords.client.y;\n\n var dx = void 0;\n var dy = void 0;\n\n // register movement greater than pointerMoveTolerance\n if (this.pointerIsDown && !this.pointerWasMoved) {\n dx = this.curCoords.client.x - this.startCoords.client.x;\n dy = this.curCoords.client.y - this.startCoords.client.y;\n\n this.pointerWasMoved = utils.hypot(dx, dy) > Interaction.pointerMoveTolerance;\n }\n\n var signalArg = {\n pointer: pointer,\n pointerIndex: this.getPointerIndex(pointer),\n event: event,\n eventTarget: eventTarget,\n dx: dx,\n dy: dy,\n duplicate: duplicateMove,\n interaction: this,\n interactingBeforeMove: this.interacting()\n };\n\n if (!duplicateMove) {\n // set pointer coordinate, time changes and speeds\n utils.setCoordDeltas(this.pointerDelta, this.prevCoords, this.curCoords);\n }\n\n signals.fire('move', signalArg);\n\n if (!duplicateMove) {\n // if interacting, fire an 'action-move' signal etc\n if (this.interacting()) {\n this.doMove(signalArg);\n }\n\n if (this.pointerWasMoved) {\n utils.copyCoords(this.prevCoords, this.curCoords);\n }\n }\n };\n\n /*\\\n * Interaction.doMove\n [ method ]\n *\n * Force a move of the current action at the same coordinates. Useful if\n * snap/restrict has been changed and you want a movement with the new\n * settings.\n *\n **\n | interact(target)\n | .draggable(true)\n | .on('dragmove', function (event) {\n | if (someCondition) {\n | // change the snap settings\n | event.interactable.draggable({ snap: { targets: [] }});\n | // fire another move event with re-calculated snap\n | event.interaction.doMove();\n | }\n | });\n \\*/\n\n\n Interaction.prototype.doMove = function doMove(signalArg) {\n signalArg = utils.extend({\n pointer: this.pointers[0],\n event: this.prevEvent,\n eventTarget: this._eventTarget,\n interaction: this\n }, signalArg || {});\n\n signals.fire('before-action-move', signalArg);\n\n if (!this._dontFireMove) {\n signals.fire('action-move', signalArg);\n }\n\n this._dontFireMove = false;\n };\n\n // End interact move events and stop auto-scroll unless simulation is running\n\n\n Interaction.prototype.pointerUp = function pointerUp(pointer, event, eventTarget, curEventTarget) {\n var pointerIndex = this.getPointerIndex(pointer);\n\n signals.fire(/cancel$/i.test(event.type) ? 'cancel' : 'up', {\n pointer: pointer,\n pointerIndex: pointerIndex,\n event: event,\n eventTarget: eventTarget,\n curEventTarget: curEventTarget,\n interaction: this\n });\n\n if (!this.simulation) {\n this.end(event);\n }\n\n this.pointerIsDown = false;\n this.removePointer(pointer, event);\n };\n\n /*\\\n * Interaction.end\n [ method ]\n *\n * Stop the current action and fire an end event. Inertial movement does\n * not happen.\n *\n - event (PointerEvent) #optional\n **\n | interact(target)\n | .draggable(true)\n | .on('move', function (event) {\n | if (event.pageX > 1000) {\n | // end the current action\n | event.interaction.end();\n | // stop all further listeners from being called\n | event.stopImmediatePropagation();\n | }\n | });\n \\*/\n\n\n Interaction.prototype.end = function end(event) {\n event = event || this.prevEvent;\n\n if (this.interacting()) {\n signals.fire('action-end', {\n event: event,\n interaction: this\n });\n }\n\n this.stop();\n };\n\n Interaction.prototype.currentAction = function currentAction() {\n return this._interacting ? this.prepared.name : null;\n };\n\n Interaction.prototype.interacting = function interacting() {\n return this._interacting;\n };\n\n Interaction.prototype.stop = function stop() {\n signals.fire('stop', { interaction: this });\n\n if (this._interacting) {\n signals.fire('stop-active', { interaction: this });\n signals.fire('stop-' + this.prepared.name, { interaction: this });\n }\n\n this.target = this.element = null;\n\n this._interacting = false;\n this.prepared.name = this.prevEvent = null;\n };\n\n Interaction.prototype.getPointerIndex = function getPointerIndex(pointer) {\n // mouse and pen interactions may have only one pointer\n if (this.pointerType === 'mouse' || this.pointerType === 'pen') {\n return 0;\n }\n\n return utils.indexOf(this.pointerIds, utils.getPointerId(pointer));\n };\n\n Interaction.prototype.updatePointer = function updatePointer(pointer, event) {\n var down = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : event && /(down|start)$/i.test(event.type);\n\n var id = utils.getPointerId(pointer);\n var index = this.getPointerIndex(pointer);\n\n if (index === -1) {\n index = this.pointerIds.length;\n this.pointerIds[index] = id;\n }\n\n if (down) {\n signals.fire('update-pointer-down', {\n pointer: pointer,\n event: event,\n down: down,\n pointerId: id,\n pointerIndex: index,\n interaction: this\n });\n }\n\n this.pointers[index] = pointer;\n\n return index;\n };\n\n Interaction.prototype.removePointer = function removePointer(pointer, event) {\n var index = this.getPointerIndex(pointer);\n\n if (index === -1) {\n return;\n }\n\n signals.fire('remove-pointer', {\n pointer: pointer,\n event: event,\n pointerIndex: index,\n interaction: this\n });\n\n this.pointers.splice(index, 1);\n this.pointerIds.splice(index, 1);\n this.downTargets.splice(index, 1);\n this.downTimes.splice(index, 1);\n };\n\n Interaction.prototype._updateEventTargets = function _updateEventTargets(target, currentTarget) {\n this._eventTarget = target;\n this._curEventTarget = currentTarget;\n };\n\n return Interaction;\n}();\n\nfor (var i = 0, len = methodNames.length; i < len; i++) {\n var method = methodNames[i];\n\n listeners[method] = doOnInteractions(method);\n}\n\nfunction doOnInteractions(method) {\n return function (event) {\n var pointerType = utils.getPointerType(event);\n\n var _utils$getEventTarget = utils.getEventTargets(event),\n eventTarget = _utils$getEventTarget[0],\n curEventTarget = _utils$getEventTarget[1];\n\n var matches = []; // [ [pointer, interaction], ...]\n\n if (browser.supportsTouch && /touch/.test(event.type)) {\n prevTouchTime = new Date().getTime();\n\n for (var _i = 0; _i < event.changedTouches.length; _i++) {\n var pointer = event.changedTouches[_i];\n var interaction = finder.search(pointer, event.type, eventTarget);\n\n matches.push([pointer, interaction || new Interaction({ pointerType: pointerType })]);\n }\n } else {\n var invalidPointer = false;\n\n if (!browser.supportsPointerEvent && /mouse/.test(event.type)) {\n // ignore mouse events while touch interactions are active\n for (var _i2 = 0; _i2 < scope.interactions.length && !invalidPointer; _i2++) {\n invalidPointer = scope.interactions[_i2].pointerType !== 'mouse' && scope.interactions[_i2].pointerIsDown;\n }\n\n // try to ignore mouse events that are simulated by the browser\n // after a touch event\n invalidPointer = invalidPointer || new Date().getTime() - prevTouchTime < 500\n // on iOS and Firefox Mobile, MouseEvent.timeStamp is zero if simulated\n || event.timeStamp === 0;\n }\n\n if (!invalidPointer) {\n var _interaction = finder.search(event, event.type, eventTarget);\n\n if (!_interaction) {\n _interaction = new Interaction({ pointerType: pointerType });\n }\n\n matches.push([event, _interaction]);\n }\n }\n\n for (var _iterator = matches, _isArray = Array.isArray(_iterator), _i3 = 0, _iterator = _isArray ? _iterator : _iterator[Symbol.iterator]();;) {\n var _ref2;\n\n if (_isArray) {\n if (_i3 >= _iterator.length) break;\n _ref2 = _iterator[_i3++];\n } else {\n _i3 = _iterator.next();\n if (_i3.done) break;\n _ref2 = _i3.value;\n }\n\n var _ref3 = _ref2,\n _pointer = _ref3[0],\n _interaction2 = _ref3[1];\n\n _interaction2._updateEventTargets(eventTarget, curEventTarget);\n _interaction2[method](_pointer, event, eventTarget, curEventTarget);\n }\n };\n}\n\nfunction endAll(event) {\n for (var _i4 = 0; _i4 < scope.interactions.length; _i4++) {\n var interaction = scope.interactions[_i4];\n\n interaction.end(event);\n signals.fire('endall', { event: event, interaction: interaction });\n }\n}\n\nvar docEvents = {/* 'eventType': listenerFunc */};\nvar pEventTypes = browser.pEventTypes;\n\nif (domObjects.PointerEvent) {\n docEvents[pEventTypes.down] = listeners.pointerDown;\n docEvents[pEventTypes.move] = listeners.pointerMove;\n docEvents[pEventTypes.up] = listeners.pointerUp;\n docEvents[pEventTypes.cancel] = listeners.pointerUp;\n} else {\n docEvents.mousedown = listeners.pointerDown;\n docEvents.mousemove = listeners.pointerMove;\n docEvents.mouseup = listeners.pointerUp;\n\n docEvents.touchstart = listeners.pointerDown;\n docEvents.touchmove = listeners.pointerMove;\n docEvents.touchend = listeners.pointerUp;\n docEvents.touchcancel = listeners.pointerUp;\n}\n\ndocEvents.blur = endAll;\n\nfunction onDocSignal(_ref4, signalName) {\n var doc = _ref4.doc;\n\n var eventMethod = signalName.indexOf('add') === 0 ? events.add : events.remove;\n\n // delegate event listener\n for (var eventType in scope.delegatedEvents) {\n eventMethod(doc, eventType, events.delegateListener);\n eventMethod(doc, eventType, events.delegateUseCapture, true);\n }\n\n for (var _eventType in docEvents) {\n eventMethod(doc, _eventType, docEvents[_eventType]);\n }\n}\n\nsignals.on('update-pointer-down', function (_ref5) {\n var interaction = _ref5.interaction,\n pointer = _ref5.pointer,\n pointerId = _ref5.pointerId,\n pointerIndex = _ref5.pointerIndex,\n event = _ref5.event,\n eventTarget = _ref5.eventTarget,\n down = _ref5.down;\n\n interaction.pointerIds[pointerIndex] = pointerId;\n interaction.pointers[pointerIndex] = pointer;\n\n if (down) {\n interaction.pointerIsDown = true;\n }\n\n if (!interaction.interacting()) {\n utils.setCoords(interaction.startCoords, interaction.pointers);\n\n utils.copyCoords(interaction.curCoords, interaction.startCoords);\n utils.copyCoords(interaction.prevCoords, interaction.startCoords);\n\n interaction.downEvent = event;\n interaction.downTimes[pointerIndex] = interaction.curCoords.timeStamp;\n interaction.downTargets[pointerIndex] = eventTarget || event && utils.getEventTargets(event)[0];\n interaction.pointerWasMoved = false;\n\n utils.pointerExtend(interaction.downPointer, pointer);\n }\n});\n\nscope.signals.on('add-document', onDocSignal);\nscope.signals.on('remove-document', onDocSignal);\n\nInteraction.pointerMoveTolerance = 1;\nInteraction.doOnInteractions = doOnInteractions;\nInteraction.endAll = endAll;\nInteraction.signals = signals;\nInteraction.docEvents = docEvents;\n\nscope.endAllInteractions = endAll;\n\nmodule.exports = Interaction;\n\n},{\"./scope\":34,\"./utils\":44,\"./utils/Signals\":35,\"./utils/browser\":37,\"./utils/domObjects\":38,\"./utils/events\":40,\"./utils/interactionFinder\":45}],6:[function(require,module,exports){\n'use strict';\n\nvar Interaction = require('../Interaction');\nvar InteractEvent = require('../InteractEvent');\n\nvar actions = {\n firePrepared: firePrepared,\n names: [],\n methodDict: {}\n};\n\nInteraction.signals.on('action-start', function (_ref) {\n var interaction = _ref.interaction,\n event = _ref.event;\n\n interaction._interacting = true;\n firePrepared(interaction, event, 'start');\n});\n\nInteraction.signals.on('action-move', function (_ref2) {\n var interaction = _ref2.interaction,\n event = _ref2.event,\n preEnd = _ref2.preEnd;\n\n firePrepared(interaction, event, 'move', preEnd);\n\n // if the action was ended in a listener\n if (!interaction.interacting()) {\n return false;\n }\n});\n\nInteraction.signals.on('action-end', function (_ref3) {\n var interaction = _ref3.interaction,\n event = _ref3.event;\n\n firePrepared(interaction, event, 'end');\n});\n\nfunction firePrepared(interaction, event, phase, preEnd) {\n var actionName = interaction.prepared.name;\n\n var newEvent = new InteractEvent(interaction, event, actionName, phase, interaction.element, null, preEnd);\n\n interaction.target.fire(newEvent);\n interaction.prevEvent = newEvent;\n}\n\nmodule.exports = actions;\n\n},{\"../InteractEvent\":3,\"../Interaction\":5}],7:[function(require,module,exports){\n'use strict';\n\nvar actions = require('./base');\nvar utils = require('../utils');\nvar InteractEvent = require('../InteractEvent');\nvar Interactable = require('../Interactable');\nvar Interaction = require('../Interaction');\nvar defaultOptions = require('../defaultOptions');\n\nvar drag = {\n defaults: {\n enabled: false,\n mouseButtons: null,\n\n origin: null,\n snap: null,\n restrict: null,\n inertia: null,\n autoScroll: null,\n\n startAxis: 'xy',\n lockAxis: 'xy'\n },\n\n checker: function checker(pointer, event, interactable) {\n var dragOptions = interactable.options.drag;\n\n return dragOptions.enabled ? { name: 'drag', axis: dragOptions.lockAxis === 'start' ? dragOptions.startAxis : dragOptions.lockAxis } : null;\n },\n\n getCursor: function getCursor() {\n return 'move';\n }\n};\n\nInteraction.signals.on('before-action-move', function (_ref) {\n var interaction = _ref.interaction;\n\n if (interaction.prepared.name !== 'drag') {\n return;\n }\n\n var axis = interaction.prepared.axis;\n\n if (axis === 'x') {\n interaction.curCoords.page.y = interaction.startCoords.page.y;\n interaction.curCoords.client.y = interaction.startCoords.client.y;\n\n interaction.pointerDelta.page.speed = Math.abs(interaction.pointerDelta.page.vx);\n interaction.pointerDelta.client.speed = Math.abs(interaction.pointerDelta.client.vx);\n interaction.pointerDelta.client.vy = 0;\n interaction.pointerDelta.page.vy = 0;\n } else if (axis === 'y') {\n interaction.curCoords.page.x = interaction.startCoords.page.x;\n interaction.curCoords.client.x = interaction.startCoords.client.x;\n\n interaction.pointerDelta.page.speed = Math.abs(interaction.pointerDelta.page.vy);\n interaction.pointerDelta.client.speed = Math.abs(interaction.pointerDelta.client.vy);\n interaction.pointerDelta.client.vx = 0;\n interaction.pointerDelta.page.vx = 0;\n }\n});\n\n// dragmove\nInteractEvent.signals.on('new', function (_ref2) {\n var iEvent = _ref2.iEvent,\n interaction = _ref2.interaction;\n\n if (iEvent.type !== 'dragmove') {\n return;\n }\n\n var axis = interaction.prepared.axis;\n\n if (axis === 'x') {\n iEvent.pageY = interaction.startCoords.page.y;\n iEvent.clientY = interaction.startCoords.client.y;\n iEvent.dy = 0;\n } else if (axis === 'y') {\n iEvent.pageX = interaction.startCoords.page.x;\n iEvent.clientX = interaction.startCoords.client.x;\n iEvent.dx = 0;\n }\n});\n\n/*\\\n * Interactable.draggable\n [ method ]\n *\n * Gets or sets whether drag actions can be performed on the\n * Interactable\n *\n = (boolean) Indicates if this can be the target of drag events\n | var isDraggable = interact('ul li').draggable();\n * or\n - options (boolean | object) #optional true/false or An object with event listeners to be fired on drag events (object makes the Interactable draggable)\n = (object) This Interactable\n | interact(element).draggable({\n | onstart: function (event) {},\n | onmove : function (event) {},\n | onend : function (event) {},\n |\n | // the axis in which the first movement must be\n | // for the drag sequence to start\n | // 'xy' by default - any direction\n | startAxis: 'x' || 'y' || 'xy',\n |\n | // 'xy' by default - don't restrict to one axis (move in any direction)\n | // 'x' or 'y' to restrict movement to either axis\n | // 'start' to restrict movement to the axis the drag started in\n | lockAxis: 'x' || 'y' || 'xy' || 'start',\n |\n | // max number of drags that can happen concurrently\n | // with elements of this Interactable. Infinity by default\n | max: Infinity,\n |\n | // max number of drags that can target the same element+Interactable\n | // 1 by default\n | maxPerElement: 2\n | });\n\\*/\nInteractable.prototype.draggable = function (options) {\n if (utils.is.object(options)) {\n this.options.drag.enabled = options.enabled === false ? false : true;\n this.setPerAction('drag', options);\n this.setOnEvents('drag', options);\n\n if (/^(xy|x|y|start)$/.test(options.lockAxis)) {\n this.options.drag.lockAxis = options.lockAxis;\n }\n if (/^(xy|x|y)$/.test(options.startAxis)) {\n this.options.drag.startAxis = options.startAxis;\n }\n\n return this;\n }\n\n if (utils.is.bool(options)) {\n this.options.drag.enabled = options;\n\n if (!options) {\n this.ondragstart = this.ondragstart = this.ondragend = null;\n }\n\n return this;\n }\n\n return this.options.drag;\n};\n\nactions.drag = drag;\nactions.names.push('drag');\nutils.merge(Interactable.eventTypes, ['dragstart', 'dragmove', 'draginertiastart', 'draginertiaresume', 'dragend']);\nactions.methodDict.drag = 'draggable';\n\ndefaultOptions.drag = drag.defaults;\n\nmodule.exports = drag;\n\n},{\"../InteractEvent\":3,\"../Interactable\":4,\"../Interaction\":5,\"../defaultOptions\":18,\"../utils\":44,\"./base\":6}],8:[function(require,module,exports){\n'use strict';\n\nvar actions = require('./base');\nvar utils = require('../utils');\nvar scope = require('../scope');\nvar interact = require('../interact');\nvar InteractEvent = require('../InteractEvent');\nvar Interactable = require('../Interactable');\nvar Interaction = require('../Interaction');\nvar defaultOptions = require('../defaultOptions');\n\nvar drop = {\n defaults: {\n enabled: false,\n accept: null,\n overlap: 'pointer'\n }\n};\n\nvar dynamicDrop = false;\n\nInteraction.signals.on('action-start', function (_ref) {\n var interaction = _ref.interaction,\n event = _ref.event;\n\n if (interaction.prepared.name !== 'drag') {\n return;\n }\n\n // reset active dropzones\n interaction.activeDrops.dropzones = [];\n interaction.activeDrops.elements = [];\n interaction.activeDrops.rects = [];\n\n interaction.dropEvents = null;\n\n if (!interaction.dynamicDrop) {\n setActiveDrops(interaction, interaction.element);\n }\n\n var dragEvent = interaction.prevEvent;\n var dropEvents = getDropEvents(interaction, event, dragEvent);\n\n if (dropEvents.activate) {\n fireActiveDrops(interaction, dropEvents.activate);\n }\n});\n\nInteractEvent.signals.on('new', function (_ref2) {\n var interaction = _ref2.interaction,\n iEvent = _ref2.iEvent,\n event = _ref2.event;\n\n if (iEvent.type !== 'dragmove' && iEvent.type !== 'dragend') {\n return;\n }\n\n var draggableElement = interaction.element;\n var dragEvent = iEvent;\n var dropResult = getDrop(dragEvent, event, draggableElement);\n\n interaction.dropTarget = dropResult.dropzone;\n interaction.dropElement = dropResult.element;\n\n interaction.dropEvents = getDropEvents(interaction, event, dragEvent);\n});\n\nInteraction.signals.on('action-move', function (_ref3) {\n var interaction = _ref3.interaction;\n\n if (interaction.prepared.name !== 'drag') {\n return;\n }\n\n fireDropEvents(interaction, interaction.dropEvents);\n});\n\nInteraction.signals.on('action-end', function (_ref4) {\n var interaction = _ref4.interaction;\n\n if (interaction.prepared.name === 'drag') {\n fireDropEvents(interaction, interaction.dropEvents);\n }\n});\n\nInteraction.signals.on('stop-drag', function (_ref5) {\n var interaction = _ref5.interaction;\n\n interaction.activeDrops.dropzones = interaction.activeDrops.elements = interaction.activeDrops.rects = interaction.dropEvents = null;\n});\n\nfunction collectDrops(interaction, element) {\n var drops = [];\n var elements = [];\n\n element = element || interaction.element;\n\n // collect all dropzones and their elements which qualify for a drop\n for (var _iterator = scope.interactables, _isArray = Array.isArray(_iterator), _i = 0, _iterator = _isArray ? _iterator : _iterator[Symbol.iterator]();;) {\n var _ref6;\n\n if (_isArray) {\n if (_i >= _iterator.length) break;\n _ref6 = _iterator[_i++];\n } else {\n _i = _iterator.next();\n if (_i.done) break;\n _ref6 = _i.value;\n }\n\n var current = _ref6;\n\n if (!current.options.drop.enabled) {\n continue;\n }\n\n var accept = current.options.drop.accept;\n\n // test the draggable element against the dropzone's accept setting\n if (utils.is.element(accept) && accept !== element || utils.is.string(accept) && !utils.matchesSelector(element, accept)) {\n\n continue;\n }\n\n // query for new elements if necessary\n var dropElements = utils.is.string(current.target) ? current._context.querySelectorAll(current.target) : [current.target];\n\n for (var i = 0; i < dropElements.length; i++) {\n var currentElement = dropElements[i];\n\n if (currentElement !== element) {\n drops.push(current);\n elements.push(currentElement);\n }\n }\n }\n\n return {\n elements: elements,\n dropzones: drops\n };\n}\n\nfunction fireActiveDrops(interaction, event) {\n var prevElement = void 0;\n\n // loop through all active dropzones and trigger event\n for (var i = 0; i < interaction.activeDrops.dropzones.length; i++) {\n var current = interaction.activeDrops.dropzones[i];\n var currentElement = interaction.activeDrops.elements[i];\n\n // prevent trigger of duplicate events on same element\n if (currentElement !== prevElement) {\n // set current element as event target\n event.target = currentElement;\n current.fire(event);\n }\n prevElement = currentElement;\n }\n}\n\n// Collect a new set of possible drops and save them in activeDrops.\n// setActiveDrops should always be called when a drag has just started or a\n// drag event happens while dynamicDrop is true\nfunction setActiveDrops(interaction, dragElement) {\n // get dropzones and their elements that could receive the draggable\n var possibleDrops = collectDrops(interaction, dragElement, true);\n\n interaction.activeDrops.dropzones = possibleDrops.dropzones;\n interaction.activeDrops.elements = possibleDrops.elements;\n interaction.activeDrops.rects = [];\n\n for (var i = 0; i < interaction.activeDrops.dropzones.length; i++) {\n interaction.activeDrops.rects[i] = interaction.activeDrops.dropzones[i].getRect(interaction.activeDrops.elements[i]);\n }\n}\n\nfunction getDrop(dragEvent, event, dragElement) {\n var interaction = dragEvent.interaction;\n var validDrops = [];\n\n if (dynamicDrop) {\n setActiveDrops(interaction, dragElement);\n }\n\n // collect all dropzones and their elements which qualify for a drop\n for (var j = 0; j < interaction.activeDrops.dropzones.length; j++) {\n var current = interaction.activeDrops.dropzones[j];\n var currentElement = interaction.activeDrops.elements[j];\n var rect = interaction.activeDrops.rects[j];\n\n validDrops.push(current.dropCheck(dragEvent, event, interaction.target, dragElement, currentElement, rect) ? currentElement : null);\n }\n\n // get the most appropriate dropzone based on DOM depth and order\n var dropIndex = utils.indexOfDeepestElement(validDrops);\n\n return {\n dropzone: interaction.activeDrops.dropzones[dropIndex] || null,\n element: interaction.activeDrops.elements[dropIndex] || null\n };\n}\n\nfunction getDropEvents(interaction, pointerEvent, dragEvent) {\n var dropEvents = {\n enter: null,\n leave: null,\n activate: null,\n deactivate: null,\n move: null,\n drop: null\n };\n\n var tmpl = {\n dragEvent: dragEvent,\n interaction: interaction,\n target: interaction.dropElement,\n dropzone: interaction.dropTarget,\n relatedTarget: dragEvent.target,\n draggable: dragEvent.interactable,\n timeStamp: dragEvent.timeStamp\n };\n\n if (interaction.dropElement !== interaction.prevDropElement) {\n // if there was a prevDropTarget, create a dragleave event\n if (interaction.prevDropTarget) {\n dropEvents.leave = utils.extend({ type: 'dragleave' }, tmpl);\n\n dragEvent.dragLeave = dropEvents.leave.target = interaction.prevDropElement;\n dragEvent.prevDropzone = dropEvents.leave.dropzone = interaction.prevDropTarget;\n }\n // if the dropTarget is not null, create a dragenter event\n if (interaction.dropTarget) {\n dropEvents.enter = {\n dragEvent: dragEvent,\n interaction: interaction,\n target: interaction.dropElement,\n dropzone: interaction.dropTarget,\n relatedTarget: dragEvent.target,\n draggable: dragEvent.interactable,\n timeStamp: dragEvent.timeStamp,\n type: 'dragenter'\n };\n\n dragEvent.dragEnter = interaction.dropElement;\n dragEvent.dropzone = interaction.dropTarget;\n }\n }\n\n if (dragEvent.type === 'dragend' && interaction.dropTarget) {\n dropEvents.drop = utils.extend({ type: 'drop' }, tmpl);\n\n dragEvent.dropzone = interaction.dropTarget;\n dragEvent.relatedTarget = interaction.dropElement;\n }\n if (dragEvent.type === 'dragstart') {\n dropEvents.activate = utils.extend({ type: 'dropactivate' }, tmpl);\n\n dropEvents.activate.target = null;\n dropEvents.activate.dropzone = null;\n }\n if (dragEvent.type === 'dragend') {\n dropEvents.deactivate = utils.extend({ type: 'dropdeactivate' }, tmpl);\n\n dropEvents.deactivate.target = null;\n dropEvents.deactivate.dropzone = null;\n }\n if (dragEvent.type === 'dragmove' && interaction.dropTarget) {\n dropEvents.move = utils.extend({\n dragmove: dragEvent,\n type: 'dropmove'\n }, tmpl);\n\n dragEvent.dropzone = interaction.dropTarget;\n }\n\n return dropEvents;\n}\n\nfunction fireDropEvents(interaction, dropEvents) {\n if (dropEvents.leave) {\n interaction.prevDropTarget.fire(dropEvents.leave);\n }\n if (dropEvents.move) {\n interaction.dropTarget.fire(dropEvents.move);\n }\n if (dropEvents.enter) {\n interaction.dropTarget.fire(dropEvents.enter);\n }\n if (dropEvents.drop) {\n interaction.dropTarget.fire(dropEvents.drop);\n }\n if (dropEvents.deactivate) {\n fireActiveDrops(interaction, dropEvents.deactivate);\n }\n\n interaction.prevDropTarget = interaction.dropTarget;\n interaction.prevDropElement = interaction.dropElement;\n}\n\n/*\\\n * Interactable.dropzone\n [ method ]\n *\n * Returns or sets whether elements can be dropped onto this\n * Interactable to trigger drop events\n *\n * Dropzones can receive the following events:\n * - `dropactivate` and `dropdeactivate` when an acceptable drag starts and ends\n * - `dragenter` and `dragleave` when a draggable enters and leaves the dropzone\n * - `dragmove` when a draggable that has entered the dropzone is moved\n * - `drop` when a draggable is dropped into this dropzone\n *\n * Use the `accept` option to allow only elements that match the given CSS\n * selector or element. The value can be:\n *\n * - **an Element** - only that element can be dropped into this dropzone.\n * - **a string**, - the element being dragged must match it as a CSS selector.\n * - **`null`** - accept options is cleared - it accepts any element.\n *\n * Use the `overlap` option to set how drops are checked for. The allowed\n * values are:\n *\n * - `'pointer'`, the pointer must be over the dropzone (default)\n * - `'center'`, the draggable element's center must be over the dropzone\n * - a number from 0-1 which is the `(intersection area) / (draggable area)`.\n * e.g. `0.5` for drop to happen when half of the area of the draggable is\n * over the dropzone\n *\n * Use the `checker` option to specify a function to check if a dragged\n * element is over this Interactable.\n *\n | interact(target)\n | .dropChecker(function(dragEvent, // related dragmove or dragend event\n | event, // TouchEvent/PointerEvent/MouseEvent\n | dropped, // bool result of the default checker\n | dropzone, // dropzone Interactable\n | dropElement, // dropzone elemnt\n | draggable, // draggable Interactable\n | draggableElement) {// draggable element\n |\n | return dropped && event.target.hasAttribute('allow-drop');\n | }\n *\n *\n - options (boolean | object | null) #optional The new value to be set.\n | interact('.drop').dropzone({\n | accept: '.can-drop' || document.getElementById('single-drop'),\n | overlap: 'pointer' || 'center' || zeroToOne\n | }\n = (boolean | object) The current setting or this Interactable\n\\*/\nInteractable.prototype.dropzone = function (options) {\n if (utils.is.object(options)) {\n this.options.drop.enabled = options.enabled === false ? false : true;\n\n if (utils.is.function(options.ondrop)) {\n this.events.ondrop = options.ondrop;\n }\n if (utils.is.function(options.ondropactivate)) {\n this.events.ondropactivate = options.ondropactivate;\n }\n if (utils.is.function(options.ondropdeactivate)) {\n this.events.ondropdeactivate = options.ondropdeactivate;\n }\n if (utils.is.function(options.ondragenter)) {\n this.events.ondragenter = options.ondragenter;\n }\n if (utils.is.function(options.ondragleave)) {\n this.events.ondragleave = options.ondragleave;\n }\n if (utils.is.function(options.ondropmove)) {\n this.events.ondropmove = options.ondropmove;\n }\n\n if (/^(pointer|center)$/.test(options.overlap)) {\n this.options.drop.overlap = options.overlap;\n } else if (utils.is.number(options.overlap)) {\n this.options.drop.overlap = Math.max(Math.min(1, options.overlap), 0);\n }\n if ('accept' in options) {\n this.options.drop.accept = options.accept;\n }\n if ('checker' in options) {\n this.options.drop.checker = options.checker;\n }\n\n return this;\n }\n\n if (utils.is.bool(options)) {\n this.options.drop.enabled = options;\n\n if (!options) {\n this.ondragenter = this.ondragleave = this.ondrop = this.ondropactivate = this.ondropdeactivate = null;\n }\n\n return this;\n }\n\n return this.options.drop;\n};\n\nInteractable.prototype.dropCheck = function (dragEvent, event, draggable, draggableElement, dropElement, rect) {\n var dropped = false;\n\n // if the dropzone has no rect (eg. display: none)\n // call the custom dropChecker or just return false\n if (!(rect = rect || this.getRect(dropElement))) {\n return this.options.drop.checker ? this.options.drop.checker(dragEvent, event, dropped, this, dropElement, draggable, draggableElement) : false;\n }\n\n var dropOverlap = this.options.drop.overlap;\n\n if (dropOverlap === 'pointer') {\n var origin = utils.getOriginXY(draggable, draggableElement, 'drag');\n var page = utils.getPageXY(dragEvent);\n\n page.x += origin.x;\n page.y += origin.y;\n\n var horizontal = page.x > rect.left && page.x < rect.right;\n var vertical = page.y > rect.top && page.y < rect.bottom;\n\n dropped = horizontal && vertical;\n }\n\n var dragRect = draggable.getRect(draggableElement);\n\n if (dragRect && dropOverlap === 'center') {\n var cx = dragRect.left + dragRect.width / 2;\n var cy = dragRect.top + dragRect.height / 2;\n\n dropped = cx >= rect.left && cx <= rect.right && cy >= rect.top && cy <= rect.bottom;\n }\n\n if (dragRect && utils.is.number(dropOverlap)) {\n var overlapArea = Math.max(0, Math.min(rect.right, dragRect.right) - Math.max(rect.left, dragRect.left)) * Math.max(0, Math.min(rect.bottom, dragRect.bottom) - Math.max(rect.top, dragRect.top));\n\n var overlapRatio = overlapArea / (dragRect.width * dragRect.height);\n\n dropped = overlapRatio >= dropOverlap;\n }\n\n if (this.options.drop.checker) {\n dropped = this.options.drop.checker(dragEvent, event, dropped, this, dropElement, draggable, draggableElement);\n }\n\n return dropped;\n};\n\nInteractable.signals.on('unset', function (_ref7) {\n var interactable = _ref7.interactable;\n\n interactable.dropzone(false);\n});\n\nInteractable.settingsMethods.push('dropChecker');\n\nInteraction.signals.on('new', function (interaction) {\n interaction.dropTarget = null; // the dropzone a drag target might be dropped into\n interaction.dropElement = null; // the element at the time of checking\n interaction.prevDropTarget = null; // the dropzone that was recently dragged away from\n interaction.prevDropElement = null; // the element at the time of checking\n interaction.dropEvents = null; // the dropEvents related to the current drag event\n\n interaction.activeDrops = {\n dropzones: [], // the dropzones that are mentioned below\n elements: [], // elements of dropzones that accept the target draggable\n rects: [] // the rects of the elements mentioned above\n };\n});\n\nInteraction.signals.on('stop', function (_ref8) {\n var interaction = _ref8.interaction;\n\n interaction.dropTarget = interaction.dropElement = interaction.prevDropTarget = interaction.prevDropElement = null;\n});\n\n/*\\\n * interact.dynamicDrop\n [ method ]\n *\n * Returns or sets whether the dimensions of dropzone elements are\n * calculated on every dragmove or only on dragstart for the default\n * dropChecker\n *\n - newValue (boolean) #optional True to check on each move. False to check only before start\n = (boolean | interact) The current setting or interact\n\\*/\ninteract.dynamicDrop = function (newValue) {\n if (utils.is.bool(newValue)) {\n //if (dragging && dynamicDrop !== newValue && !newValue) {\n //calcRects(dropzones);\n //}\n\n dynamicDrop = newValue;\n\n return interact;\n }\n return dynamicDrop;\n};\n\nutils.merge(Interactable.eventTypes, ['dragenter', 'dragleave', 'dropactivate', 'dropdeactivate', 'dropmove', 'drop']);\nactions.methodDict.drop = 'dropzone';\n\ndefaultOptions.drop = drop.defaults;\n\nmodule.exports = drop;\n\n},{\"../InteractEvent\":3,\"../Interactable\":4,\"../Interaction\":5,\"../defaultOptions\":18,\"../interact\":21,\"../scope\":34,\"../utils\":44,\"./base\":6}],9:[function(require,module,exports){\n'use strict';\n\nvar actions = require('./base');\nvar utils = require('../utils');\nvar InteractEvent = require('../InteractEvent');\nvar Interactable = require('../Interactable');\nvar Interaction = require('../Interaction');\nvar defaultOptions = require('../defaultOptions');\n\nvar gesture = {\n defaults: {\n enabled: false,\n origin: null,\n restrict: null\n },\n\n checker: function checker(pointer, event, interactable, element, interaction) {\n if (interaction.pointerIds.length >= 2) {\n return { name: 'gesture' };\n }\n\n return null;\n },\n\n getCursor: function getCursor() {\n return '';\n }\n};\n\nInteractEvent.signals.on('new', function (_ref) {\n var iEvent = _ref.iEvent,\n interaction = _ref.interaction;\n\n if (iEvent.type !== 'gesturestart') {\n return;\n }\n iEvent.ds = 0;\n\n interaction.gesture.startDistance = interaction.gesture.prevDistance = iEvent.distance;\n interaction.gesture.startAngle = interaction.gesture.prevAngle = iEvent.angle;\n interaction.gesture.scale = 1;\n});\n\nInteractEvent.signals.on('new', function (_ref2) {\n var iEvent = _ref2.iEvent,\n interaction = _ref2.interaction;\n\n if (iEvent.type !== 'gesturemove') {\n return;\n }\n\n iEvent.ds = iEvent.scale - interaction.gesture.scale;\n\n interaction.target.fire(iEvent);\n\n interaction.gesture.prevAngle = iEvent.angle;\n interaction.gesture.prevDistance = iEvent.distance;\n\n if (iEvent.scale !== Infinity && iEvent.scale !== null && iEvent.scale !== undefined && !isNaN(iEvent.scale)) {\n\n interaction.gesture.scale = iEvent.scale;\n }\n});\n\n/*\\\n * Interactable.gesturable\n [ method ]\n *\n * Gets or sets whether multitouch gestures can be performed on the\n * Interactable's element\n *\n = (boolean) Indicates if this can be the target of gesture events\n | var isGestureable = interact(element).gesturable();\n * or\n - options (boolean | object) #optional true/false or An object with event listeners to be fired on gesture events (makes the Interactable gesturable)\n = (object) this Interactable\n | interact(element).gesturable({\n | onstart: function (event) {},\n | onmove : function (event) {},\n | onend : function (event) {},\n |\n | // limit multiple gestures.\n | // See the explanation in @Interactable.draggable example\n | max: Infinity,\n | maxPerElement: 1,\n | });\n\\*/\nInteractable.prototype.gesturable = function (options) {\n if (utils.is.object(options)) {\n this.options.gesture.enabled = options.enabled === false ? false : true;\n this.setPerAction('gesture', options);\n this.setOnEvents('gesture', options);\n\n return this;\n }\n\n if (utils.is.bool(options)) {\n this.options.gesture.enabled = options;\n\n if (!options) {\n this.ongesturestart = this.ongesturestart = this.ongestureend = null;\n }\n\n return this;\n }\n\n return this.options.gesture;\n};\n\nInteractEvent.signals.on('set-delta', function (_ref3) {\n var interaction = _ref3.interaction,\n iEvent = _ref3.iEvent,\n action = _ref3.action,\n event = _ref3.event,\n starting = _ref3.starting,\n ending = _ref3.ending,\n deltaSource = _ref3.deltaSource;\n\n if (action !== 'gesture') {\n return;\n }\n\n var pointers = interaction.pointers;\n\n iEvent.touches = [pointers[0], pointers[1]];\n\n if (starting) {\n iEvent.distance = utils.touchDistance(pointers, deltaSource);\n iEvent.box = utils.touchBBox(pointers);\n iEvent.scale = 1;\n iEvent.ds = 0;\n iEvent.angle = utils.touchAngle(pointers, undefined, deltaSource);\n iEvent.da = 0;\n } else if (ending || event instanceof InteractEvent) {\n iEvent.distance = interaction.prevEvent.distance;\n iEvent.box = interaction.prevEvent.box;\n iEvent.scale = interaction.prevEvent.scale;\n iEvent.ds = iEvent.scale - 1;\n iEvent.angle = interaction.prevEvent.angle;\n iEvent.da = iEvent.angle - interaction.gesture.startAngle;\n } else {\n iEvent.distance = utils.touchDistance(pointers, deltaSource);\n iEvent.box = utils.touchBBox(pointers);\n iEvent.scale = iEvent.distance / interaction.gesture.startDistance;\n iEvent.angle = utils.touchAngle(pointers, interaction.gesture.prevAngle, deltaSource);\n\n iEvent.ds = iEvent.scale - interaction.gesture.prevScale;\n iEvent.da = iEvent.angle - interaction.gesture.prevAngle;\n }\n});\n\nInteraction.signals.on('new', function (interaction) {\n interaction.gesture = {\n start: { x: 0, y: 0 },\n\n startDistance: 0, // distance between two touches of touchStart\n prevDistance: 0,\n distance: 0,\n\n scale: 1, // gesture.distance / gesture.startDistance\n\n startAngle: 0, // angle of line joining two touches\n prevAngle: 0 // angle of the previous gesture event\n };\n});\n\nactions.gesture = gesture;\nactions.names.push('gesture');\nutils.merge(Interactable.eventTypes, ['gesturestart', 'gesturemove', 'gestureend']);\nactions.methodDict.gesture = 'gesturable';\n\ndefaultOptions.gesture = gesture.defaults;\n\nmodule.exports = gesture;\n\n},{\"../InteractEvent\":3,\"../Interactable\":4,\"../Interaction\":5,\"../defaultOptions\":18,\"../utils\":44,\"./base\":6}],10:[function(require,module,exports){\n'use strict';\n\nvar actions = require('./base');\nvar utils = require('../utils');\nvar browser = require('../utils/browser');\nvar InteractEvent = require('../InteractEvent');\nvar Interactable = require('../Interactable');\nvar Interaction = require('../Interaction');\nvar defaultOptions = require('../defaultOptions');\n\n// Less Precision with touch input\nvar defaultMargin = browser.supportsTouch || browser.supportsPointerEvent ? 20 : 10;\n\nvar resize = {\n defaults: {\n enabled: false,\n mouseButtons: null,\n\n origin: null,\n snap: null,\n restrict: null,\n inertia: null,\n autoScroll: null,\n\n square: false,\n preserveAspectRatio: false,\n axis: 'xy',\n\n // use default margin\n margin: NaN,\n\n // object with props left, right, top, bottom which are\n // true/false values to resize when the pointer is over that edge,\n // CSS selectors to match the handles for each direction\n // or the Elements for each handle\n edges: null,\n\n // a value of 'none' will limit the resize rect to a minimum of 0x0\n // 'negate' will alow the rect to have negative width/height\n // 'reposition' will keep the width/height positive by swapping\n // the top and bottom edges and/or swapping the left and right edges\n invert: 'none'\n },\n\n checker: function checker(pointer, event, interactable, element, interaction, rect) {\n if (!rect) {\n return null;\n }\n\n var page = utils.extend({}, interaction.curCoords.page);\n var options = interactable.options;\n\n if (options.resize.enabled) {\n var resizeOptions = options.resize;\n var resizeEdges = { left: false, right: false, top: false, bottom: false };\n\n // if using resize.edges\n if (utils.is.object(resizeOptions.edges)) {\n for (var edge in resizeEdges) {\n resizeEdges[edge] = checkResizeEdge(edge, resizeOptions.edges[edge], page, interaction._eventTarget, element, rect, resizeOptions.margin || defaultMargin);\n }\n\n resizeEdges.left = resizeEdges.left && !resizeEdges.right;\n resizeEdges.top = resizeEdges.top && !resizeEdges.bottom;\n\n if (resizeEdges.left || resizeEdges.right || resizeEdges.top || resizeEdges.bottom) {\n return {\n name: 'resize',\n edges: resizeEdges\n };\n }\n } else {\n var right = options.resize.axis !== 'y' && page.x > rect.right - defaultMargin;\n var bottom = options.resize.axis !== 'x' && page.y > rect.bottom - defaultMargin;\n\n if (right || bottom) {\n return {\n name: 'resize',\n axes: (right ? 'x' : '') + (bottom ? 'y' : '')\n };\n }\n }\n }\n\n return null;\n },\n\n cursors: browser.isIe9OrOlder ? {\n x: 'e-resize',\n y: 's-resize',\n xy: 'se-resize',\n\n top: 'n-resize',\n left: 'w-resize',\n bottom: 's-resize',\n right: 'e-resize',\n topleft: 'se-resize',\n bottomright: 'se-resize',\n topright: 'ne-resize',\n bottomleft: 'ne-resize'\n } : {\n x: 'ew-resize',\n y: 'ns-resize',\n xy: 'nwse-resize',\n\n top: 'ns-resize',\n left: 'ew-resize',\n bottom: 'ns-resize',\n right: 'ew-resize',\n topleft: 'nwse-resize',\n bottomright: 'nwse-resize',\n topright: 'nesw-resize',\n bottomleft: 'nesw-resize'\n },\n\n getCursor: function getCursor(action) {\n if (action.axis) {\n return resize.cursors[action.name + action.axis];\n } else if (action.edges) {\n var cursorKey = '';\n var edgeNames = ['top', 'bottom', 'left', 'right'];\n\n for (var i = 0; i < 4; i++) {\n if (action.edges[edgeNames[i]]) {\n cursorKey += edgeNames[i];\n }\n }\n\n return resize.cursors[cursorKey];\n }\n }\n};\n\n// resizestart\nInteractEvent.signals.on('new', function (_ref) {\n var iEvent = _ref.iEvent,\n interaction = _ref.interaction;\n\n if (iEvent.type !== 'resizestart' || !interaction.prepared.edges) {\n return;\n }\n\n var startRect = interaction.target.getRect(interaction.element);\n var resizeOptions = interaction.target.options.resize;\n\n /*\n * When using the `resizable.square` or `resizable.preserveAspectRatio` options, resizing from one edge\n * will affect another. E.g. with `resizable.square`, resizing to make the right edge larger will make\n * the bottom edge larger by the same amount. We call these 'linked' edges. Any linked edges will depend\n * on the active edges and the edge being interacted with.\n */\n if (resizeOptions.square || resizeOptions.preserveAspectRatio) {\n var linkedEdges = utils.extend({}, interaction.prepared.edges);\n\n linkedEdges.top = linkedEdges.top || linkedEdges.left && !linkedEdges.bottom;\n linkedEdges.left = linkedEdges.left || linkedEdges.top && !linkedEdges.right;\n linkedEdges.bottom = linkedEdges.bottom || linkedEdges.right && !linkedEdges.top;\n linkedEdges.right = linkedEdges.right || linkedEdges.bottom && !linkedEdges.left;\n\n interaction.prepared._linkedEdges = linkedEdges;\n } else {\n interaction.prepared._linkedEdges = null;\n }\n\n // if using `resizable.preserveAspectRatio` option, record aspect ratio at the start of the resize\n if (resizeOptions.preserveAspectRatio) {\n interaction.resizeStartAspectRatio = startRect.width / startRect.height;\n }\n\n interaction.resizeRects = {\n start: startRect,\n current: utils.extend({}, startRect),\n inverted: utils.extend({}, startRect),\n previous: utils.extend({}, startRect),\n delta: {\n left: 0, right: 0, width: 0,\n top: 0, bottom: 0, height: 0\n }\n };\n\n iEvent.rect = interaction.resizeRects.inverted;\n iEvent.deltaRect = interaction.resizeRects.delta;\n});\n\n// resizemove\nInteractEvent.signals.on('new', function (_ref2) {\n var iEvent = _ref2.iEvent,\n phase = _ref2.phase,\n interaction = _ref2.interaction;\n\n if (phase !== 'move' || !interaction.prepared.edges) {\n return;\n }\n\n var resizeOptions = interaction.target.options.resize;\n var invert = resizeOptions.invert;\n var invertible = invert === 'reposition' || invert === 'negate';\n\n var edges = interaction.prepared.edges;\n\n var start = interaction.resizeRects.start;\n var current = interaction.resizeRects.current;\n var inverted = interaction.resizeRects.inverted;\n var delta = interaction.resizeRects.delta;\n var previous = utils.extend(interaction.resizeRects.previous, inverted);\n var originalEdges = edges;\n\n var dx = iEvent.dx;\n var dy = iEvent.dy;\n\n if (resizeOptions.preserveAspectRatio || resizeOptions.square) {\n // `resize.preserveAspectRatio` takes precedence over `resize.square`\n var startAspectRatio = resizeOptions.preserveAspectRatio ? interaction.resizeStartAspectRatio : 1;\n\n edges = interaction.prepared._linkedEdges;\n\n if (originalEdges.left && originalEdges.bottom || originalEdges.right && originalEdges.top) {\n dy = -dx / startAspectRatio;\n } else if (originalEdges.left || originalEdges.right) {\n dy = dx / startAspectRatio;\n } else if (originalEdges.top || originalEdges.bottom) {\n dx = dy * startAspectRatio;\n }\n }\n\n // update the 'current' rect without modifications\n if (edges.top) {\n current.top += dy;\n }\n if (edges.bottom) {\n current.bottom += dy;\n }\n if (edges.left) {\n current.left += dx;\n }\n if (edges.right) {\n current.right += dx;\n }\n\n if (invertible) {\n // if invertible, copy the current rect\n utils.extend(inverted, current);\n\n if (invert === 'reposition') {\n // swap edge values if necessary to keep width/height positive\n var swap = void 0;\n\n if (inverted.top > inverted.bottom) {\n swap = inverted.top;\n\n inverted.top = inverted.bottom;\n inverted.bottom = swap;\n }\n if (inverted.left > inverted.right) {\n swap = inverted.left;\n\n inverted.left = inverted.right;\n inverted.right = swap;\n }\n }\n } else {\n // if not invertible, restrict to minimum of 0x0 rect\n inverted.top = Math.min(current.top, start.bottom);\n inverted.bottom = Math.max(current.bottom, start.top);\n inverted.left = Math.min(current.left, start.right);\n inverted.right = Math.max(current.right, start.left);\n }\n\n inverted.width = inverted.right - inverted.left;\n inverted.height = inverted.bottom - inverted.top;\n\n for (var edge in inverted) {\n delta[edge] = inverted[edge] - previous[edge];\n }\n\n iEvent.edges = interaction.prepared.edges;\n iEvent.rect = inverted;\n iEvent.deltaRect = delta;\n});\n\n/*\\\n * Interactable.resizable\n [ method ]\n *\n * Gets or sets whether resize actions can be performed on the\n * Interactable\n *\n = (boolean) Indicates if this can be the target of resize elements\n | var isResizeable = interact('input[type=text]').resizable();\n * or\n - options (boolean | object) #optional true/false or An object with event listeners to be fired on resize events (object makes the Interactable resizable)\n = (object) This Interactable\n | interact(element).resizable({\n | onstart: function (event) {},\n | onmove : function (event) {},\n | onend : function (event) {},\n |\n | edges: {\n | top : true, // Use pointer coords to check for resize.\n | left : false, // Disable resizing from left edge.\n | bottom: '.resize-s',// Resize if pointer target matches selector\n | right : handleEl // Resize if pointer target is the given Element\n | },\n |\n | // Width and height can be adjusted independently. When `true`, width and\n | // height are adjusted at a 1:1 ratio.\n | square: false,\n |\n | // Width and height can be adjusted independently. When `true`, width and\n | // height maintain the aspect ratio they had when resizing started.\n | preserveAspectRatio: false,\n |\n | // a value of 'none' will limit the resize rect to a minimum of 0x0\n | // 'negate' will allow the rect to have negative width/height\n | // 'reposition' will keep the width/height positive by swapping\n | // the top and bottom edges and/or swapping the left and right edges\n | invert: 'none' || 'negate' || 'reposition'\n |\n | // limit multiple resizes.\n | // See the explanation in the @Interactable.draggable example\n | max: Infinity,\n | maxPerElement: 1,\n | });\n \\*/\nInteractable.prototype.resizable = function (options) {\n if (utils.is.object(options)) {\n this.options.resize.enabled = options.enabled === false ? false : true;\n this.setPerAction('resize', options);\n this.setOnEvents('resize', options);\n\n if (/^x$|^y$|^xy$/.test(options.axis)) {\n this.options.resize.axis = options.axis;\n } else if (options.axis === null) {\n this.options.resize.axis = defaultOptions.resize.axis;\n }\n\n if (utils.is.bool(options.preserveAspectRatio)) {\n this.options.resize.preserveAspectRatio = options.preserveAspectRatio;\n } else if (utils.is.bool(options.square)) {\n this.options.resize.square = options.square;\n }\n\n return this;\n }\n if (utils.is.bool(options)) {\n this.options.resize.enabled = options;\n\n if (!options) {\n this.onresizestart = this.onresizestart = this.onresizeend = null;\n }\n\n return this;\n }\n return this.options.resize;\n};\n\nfunction checkResizeEdge(name, value, page, element, interactableElement, rect, margin) {\n // false, '', undefined, null\n if (!value) {\n return false;\n }\n\n // true value, use pointer coords and element rect\n if (value === true) {\n // if dimensions are negative, \"switch\" edges\n var width = utils.is.number(rect.width) ? rect.width : rect.right - rect.left;\n var height = utils.is.number(rect.height) ? rect.height : rect.bottom - rect.top;\n\n if (width < 0) {\n if (name === 'left') {\n name = 'right';\n } else if (name === 'right') {\n name = 'left';\n }\n }\n if (height < 0) {\n if (name === 'top') {\n name = 'bottom';\n } else if (name === 'bottom') {\n name = 'top';\n }\n }\n\n if (name === 'left') {\n return page.x < (width >= 0 ? rect.left : rect.right) + margin;\n }\n if (name === 'top') {\n return page.y < (height >= 0 ? rect.top : rect.bottom) + margin;\n }\n\n if (name === 'right') {\n return page.x > (width >= 0 ? rect.right : rect.left) - margin;\n }\n if (name === 'bottom') {\n return page.y > (height >= 0 ? rect.bottom : rect.top) - margin;\n }\n }\n\n // the remaining checks require an element\n if (!utils.is.element(element)) {\n return false;\n }\n\n return utils.is.element(value)\n // the value is an element to use as a resize handle\n ? value === element\n // otherwise check if element matches value as selector\n : utils.matchesUpTo(element, value, interactableElement);\n}\n\nInteraction.signals.on('new', function (interaction) {\n interaction.resizeAxes = 'xy';\n});\n\nInteractEvent.signals.on('set-delta', function (_ref3) {\n var interaction = _ref3.interaction,\n iEvent = _ref3.iEvent,\n action = _ref3.action;\n\n if (action !== 'resize' || !interaction.resizeAxes) {\n return;\n }\n\n var options = interaction.target.options;\n\n if (options.resize.square) {\n if (interaction.resizeAxes === 'y') {\n iEvent.dx = iEvent.dy;\n } else {\n iEvent.dy = iEvent.dx;\n }\n iEvent.axes = 'xy';\n } else {\n iEvent.axes = interaction.resizeAxes;\n\n if (interaction.resizeAxes === 'x') {\n iEvent.dy = 0;\n } else if (interaction.resizeAxes === 'y') {\n iEvent.dx = 0;\n }\n }\n});\n\nactions.resize = resize;\nactions.names.push('resize');\nutils.merge(Interactable.eventTypes, ['resizestart', 'resizemove', 'resizeinertiastart', 'resizeinertiaresume', 'resizeend']);\nactions.methodDict.resize = 'resizable';\n\ndefaultOptions.resize = resize.defaults;\n\nmodule.exports = resize;\n\n},{\"../InteractEvent\":3,\"../Interactable\":4,\"../Interaction\":5,\"../defaultOptions\":18,\"../utils\":44,\"../utils/browser\":37,\"./base\":6}],11:[function(require,module,exports){\n'use strict';\n\nvar raf = require('./utils/raf');\nvar getWindow = require('./utils/window').getWindow;\nvar is = require('./utils/is');\nvar domUtils = require('./utils/domUtils');\nvar Interaction = require('./Interaction');\nvar defaultOptions = require('./defaultOptions');\n\nvar autoScroll = {\n defaults: {\n enabled: false,\n container: null, // the item that is scrolled (Window or HTMLElement)\n margin: 60,\n speed: 300 // the scroll speed in pixels per second\n },\n\n interaction: null,\n i: null, // the handle returned by window.setInterval\n x: 0, y: 0, // Direction each pulse is to scroll in\n\n isScrolling: false,\n prevTime: 0,\n\n start: function start(interaction) {\n autoScroll.isScrolling = true;\n raf.cancel(autoScroll.i);\n\n autoScroll.interaction = interaction;\n autoScroll.prevTime = new Date().getTime();\n autoScroll.i = raf.request(autoScroll.scroll);\n },\n\n stop: function stop() {\n autoScroll.isScrolling = false;\n raf.cancel(autoScroll.i);\n },\n\n // scroll the window by the values in scroll.x/y\n scroll: function scroll() {\n var options = autoScroll.interaction.target.options[autoScroll.interaction.prepared.name].autoScroll;\n var container = options.container || getWindow(autoScroll.interaction.element);\n var now = new Date().getTime();\n // change in time in seconds\n var dt = (now - autoScroll.prevTime) / 1000;\n // displacement\n var s = options.speed * dt;\n\n if (s >= 1) {\n if (is.window(container)) {\n container.scrollBy(autoScroll.x * s, autoScroll.y * s);\n } else if (container) {\n container.scrollLeft += autoScroll.x * s;\n container.scrollTop += autoScroll.y * s;\n }\n\n autoScroll.prevTime = now;\n }\n\n if (autoScroll.isScrolling) {\n raf.cancel(autoScroll.i);\n autoScroll.i = raf.request(autoScroll.scroll);\n }\n },\n check: function check(interactable, actionName) {\n var options = interactable.options;\n\n return options[actionName].autoScroll && options[actionName].autoScroll.enabled;\n },\n onInteractionMove: function onInteractionMove(_ref) {\n var interaction = _ref.interaction,\n pointer = _ref.pointer;\n\n if (!(interaction.interacting() && autoScroll.check(interaction.target, interaction.prepared.name))) {\n return;\n }\n\n if (interaction.simulation) {\n autoScroll.x = autoScroll.y = 0;\n return;\n }\n\n var top = void 0;\n var right = void 0;\n var bottom = void 0;\n var left = void 0;\n\n var options = interaction.target.options[interaction.prepared.name].autoScroll;\n var container = options.container || getWindow(interaction.element);\n\n if (is.window(container)) {\n left = pointer.clientX < autoScroll.margin;\n top = pointer.clientY < autoScroll.margin;\n right = pointer.clientX > container.innerWidth - autoScroll.margin;\n bottom = pointer.clientY > container.innerHeight - autoScroll.margin;\n } else {\n var rect = domUtils.getElementClientRect(container);\n\n left = pointer.clientX < rect.left + autoScroll.margin;\n top = pointer.clientY < rect.top + autoScroll.margin;\n right = pointer.clientX > rect.right - autoScroll.margin;\n bottom = pointer.clientY > rect.bottom - autoScroll.margin;\n }\n\n autoScroll.x = right ? 1 : left ? -1 : 0;\n autoScroll.y = bottom ? 1 : top ? -1 : 0;\n\n if (!autoScroll.isScrolling) {\n // set the autoScroll properties to those of the target\n autoScroll.margin = options.margin;\n autoScroll.speed = options.speed;\n\n autoScroll.start(interaction);\n }\n }\n};\n\nInteraction.signals.on('stop-active', function () {\n autoScroll.stop();\n});\n\nInteraction.signals.on('action-move', autoScroll.onInteractionMove);\n\ndefaultOptions.perAction.autoScroll = autoScroll.defaults;\n\nmodule.exports = autoScroll;\n\n},{\"./Interaction\":5,\"./defaultOptions\":18,\"./utils/domUtils\":39,\"./utils/is\":46,\"./utils/raf\":50,\"./utils/window\":52}],12:[function(require,module,exports){\n'use strict';\n\nvar Interactable = require('../Interactable');\nvar actions = require('../actions/base');\nvar is = require('../utils/is');\nvar domUtils = require('../utils/domUtils');\n\nInteractable.prototype.getAction = function (pointer, event, interaction, element) {\n var action = this.defaultActionChecker(pointer, event, interaction, element);\n\n if (this.options.actionChecker) {\n return this.options.actionChecker(pointer, event, action, this, element, interaction);\n }\n\n return action;\n};\n\n/*\\\n * Interactable.ignoreFrom\n [ method ]\n *\n * If the target of the `mousedown`, `pointerdown` or `touchstart`\n * event or any of it's parents match the given CSS selector or\n * Element, no drag/resize/gesture is started.\n *\n - newValue (string | Element | null) #optional a CSS selector string, an Element or `null` to not ignore any elements\n = (string | Element | object) The current ignoreFrom value or this Interactable\n **\n | interact(element, { ignoreFrom: document.getElementById('no-action') });\n | // or\n | interact(element).ignoreFrom('input, textarea, a');\n\\*/\nInteractable.prototype.ignoreFrom = function (newValue) {\n return this._backCompatOption('ignoreFrom', newValue);\n};\n\n/*\\\n * Interactable.allowFrom\n [ method ]\n *\n * A drag/resize/gesture is started only If the target of the\n * `mousedown`, `pointerdown` or `touchstart` event or any of it's\n * parents match the given CSS selector or Element.\n *\n - newValue (string | Element | null) #optional a CSS selector string, an Element or `null` to allow from any element\n = (string | Element | object) The current allowFrom value or this Interactable\n **\n | interact(element, { allowFrom: document.getElementById('drag-handle') });\n | // or\n | interact(element).allowFrom('.handle');\n\\*/\nInteractable.prototype.allowFrom = function (newValue) {\n return this._backCompatOption('allowFrom', newValue);\n};\n\nInteractable.prototype.testIgnore = function (ignoreFrom, interactableElement, element) {\n if (!ignoreFrom || !is.element(element)) {\n return false;\n }\n\n if (is.string(ignoreFrom)) {\n return domUtils.matchesUpTo(element, ignoreFrom, interactableElement);\n } else if (is.element(ignoreFrom)) {\n return domUtils.nodeContains(ignoreFrom, element);\n }\n\n return false;\n};\n\nInteractable.prototype.testAllow = function (allowFrom, interactableElement, element) {\n if (!allowFrom) {\n return true;\n }\n\n if (!is.element(element)) {\n return false;\n }\n\n if (is.string(allowFrom)) {\n return domUtils.matchesUpTo(element, allowFrom, interactableElement);\n } else if (is.element(allowFrom)) {\n return domUtils.nodeContains(allowFrom, element);\n }\n\n return false;\n};\n\nInteractable.prototype.testIgnoreAllow = function (options, interactableElement, eventTarget) {\n return !this.testIgnore(options.ignoreFrom, interactableElement, eventTarget) && this.testAllow(options.allowFrom, interactableElement, eventTarget);\n};\n\n/*\\\n * Interactable.actionChecker\n [ method ]\n *\n * Gets or sets the function used to check action to be performed on\n * pointerDown\n *\n - checker (function | null) #optional A function which takes a pointer event, defaultAction string, interactable, element and interaction as parameters and returns an object with name property 'drag' 'resize' or 'gesture' and optionally an `edges` object with boolean 'top', 'left', 'bottom' and right props.\n = (Function | Interactable) The checker function or this Interactable\n *\n | interact('.resize-drag')\n | .resizable(true)\n | .draggable(true)\n | .actionChecker(function (pointer, event, action, interactable, element, interaction) {\n |\n | if (interact.matchesSelector(event.target, '.drag-handle') {\n | // force drag with handle target\n | action.name = drag;\n | }\n | else {\n | // resize from the top and right edges\n | action.name = 'resize';\n | action.edges = { top: true, right: true };\n | }\n |\n | return action;\n | });\n\\*/\nInteractable.prototype.actionChecker = function (checker) {\n if (is.function(checker)) {\n this.options.actionChecker = checker;\n\n return this;\n }\n\n if (checker === null) {\n delete this.options.actionChecker;\n\n return this;\n }\n\n return this.options.actionChecker;\n};\n\n/*\\\n * Interactable.styleCursor\n [ method ]\n *\n * Returns or sets whether the the cursor should be changed depending on the\n * action that would be performed if the mouse were pressed and dragged.\n *\n - newValue (boolean) #optional\n = (boolean | Interactable) The current setting or this Interactable\n\\*/\nInteractable.prototype.styleCursor = function (newValue) {\n if (is.bool(newValue)) {\n this.options.styleCursor = newValue;\n\n return this;\n }\n\n if (newValue === null) {\n delete this.options.styleCursor;\n\n return this;\n }\n\n return this.options.styleCursor;\n};\n\nInteractable.prototype.defaultActionChecker = function (pointer, event, interaction, element) {\n var rect = this.getRect(element);\n var action = null;\n\n for (var _iterator = actions.names, _isArray = Array.isArray(_iterator), _i = 0, _iterator = _isArray ? _iterator : _iterator[Symbol.iterator]();;) {\n var _ref;\n\n if (_isArray) {\n if (_i >= _iterator.length) break;\n _ref = _iterator[_i++];\n } else {\n _i = _iterator.next();\n if (_i.done) break;\n _ref = _i.value;\n }\n\n var actionName = _ref;\n\n // check mouseButton setting if the pointer is down\n if (interaction.pointerIsDown && interaction.mouse && (event.buttons & this.options[actionName].mouseButtons) === 0) {\n continue;\n }\n\n action = actions[actionName].checker(pointer, event, this, element, interaction, rect);\n\n if (action) {\n return action;\n }\n }\n};\n\n},{\"../Interactable\":4,\"../actions/base\":6,\"../utils/domUtils\":39,\"../utils/is\":46}],13:[function(require,module,exports){\n'use strict';\n\nvar interact = require('../interact');\nvar Interactable = require('../Interactable');\nvar Interaction = require('../Interaction');\nvar actions = require('../actions/base');\nvar defaultOptions = require('../defaultOptions');\nvar browser = require('../utils/browser');\nvar scope = require('../scope');\nvar utils = require('../utils');\nvar signals = require('../utils/Signals').new();\n\nrequire('./InteractableMethods');\n\nvar autoStart = {\n signals: signals,\n withinInteractionLimit: withinInteractionLimit,\n // Allow this many interactions to happen simultaneously\n maxInteractions: Infinity,\n defaults: {\n perAction: {\n manualStart: false,\n max: Infinity,\n maxPerElement: 1,\n allowFrom: null,\n ignoreFrom: null\n }\n },\n setActionDefaults: function setActionDefaults(action) {\n utils.extend(action.defaults, autoStart.defaults.perAction);\n }\n};\n\n// set cursor style on mousedown\nInteraction.signals.on('down', function (_ref) {\n var interaction = _ref.interaction,\n pointer = _ref.pointer,\n event = _ref.event,\n eventTarget = _ref.eventTarget;\n\n if (interaction.interacting()) {\n return;\n }\n\n var actionInfo = getActionInfo(interaction, pointer, event, eventTarget);\n prepare(interaction, actionInfo);\n});\n\n// set cursor style on mousemove\nInteraction.signals.on('move', function (_ref2) {\n var interaction = _ref2.interaction,\n pointer = _ref2.pointer,\n event = _ref2.event,\n eventTarget = _ref2.eventTarget;\n\n if (!interaction.mouse || interaction.pointerIsDown || interaction.interacting()) {\n return;\n }\n\n var actionInfo = getActionInfo(interaction, pointer, event, eventTarget);\n prepare(interaction, actionInfo);\n});\n\nInteraction.signals.on('move', function (arg) {\n var interaction = arg.interaction,\n event = arg.event;\n\n\n if (!interaction.pointerIsDown || interaction.interacting() || !interaction.pointerWasMoved || !interaction.prepared.name) {\n return;\n }\n\n signals.fire('before-start', arg);\n\n var target = interaction.target;\n\n if (interaction.prepared.name && target) {\n // check manualStart and interaction limit\n if (target.options[interaction.prepared.name].manualStart || !withinInteractionLimit(target, interaction.element, interaction.prepared)) {\n interaction.stop(event);\n } else {\n interaction.start(interaction.prepared, target, interaction.element);\n }\n }\n});\n\n// Check if the current target supports the action.\n// If so, return the validated action. Otherwise, return null\nfunction validateAction(action, interactable, element, eventTarget) {\n if (utils.is.object(action) && interactable.testIgnoreAllow(interactable.options[action.name], element, eventTarget) && interactable.options[action.name].enabled && withinInteractionLimit(interactable, element, action)) {\n return action;\n }\n\n return null;\n}\n\nfunction validateSelector(interaction, pointer, event, matches, matchElements, eventTarget) {\n for (var i = 0, len = matches.length; i < len; i++) {\n var match = matches[i];\n var matchElement = matchElements[i];\n var action = validateAction(match.getAction(pointer, event, interaction, matchElement), match, matchElement, eventTarget);\n\n if (action) {\n return {\n action: action,\n target: match,\n element: matchElement\n };\n }\n }\n\n return {};\n}\n\nfunction getActionInfo(interaction, pointer, event, eventTarget) {\n var matches = [];\n var matchElements = [];\n\n var element = eventTarget;\n var action = null;\n\n function pushMatches(interactable, selector, context) {\n var elements = browser.useMatchesSelectorPolyfill ? context.querySelectorAll(selector) : undefined;\n\n if (utils.matchesSelector(element, selector, elements)) {\n\n matches.push(interactable);\n matchElements.push(element);\n }\n }\n\n while (utils.is.element(element)) {\n matches = [];\n matchElements = [];\n\n var elementInteractable = scope.interactables.get(element);\n\n if (elementInteractable && (action = validateAction(elementInteractable.getAction(pointer, event, interaction, element, eventTarget), elementInteractable, element, eventTarget)) && !elementInteractable.options[action.name].manualStart) {\n return {\n element: element,\n action: action,\n target: elementInteractable\n };\n } else {\n scope.interactables.forEachSelector(pushMatches, element);\n\n var actionInfo = validateSelector(interaction, pointer, event, matches, matchElements, eventTarget);\n\n if (actionInfo.action && !actionInfo.target.options[actionInfo.action.name].manualStart) {\n return actionInfo;\n }\n }\n\n element = utils.parentNode(element);\n }\n\n return {};\n}\n\nfunction prepare(interaction, _ref3) {\n var action = _ref3.action,\n target = _ref3.target,\n element = _ref3.element;\n\n action = action || {};\n\n if (interaction.target && interaction.target.options.styleCursor) {\n interaction.target._doc.documentElement.style.cursor = '';\n }\n\n interaction.target = target;\n interaction.element = element;\n utils.copyAction(interaction.prepared, action);\n\n if (target && target.options.styleCursor) {\n var cursor = action ? actions[action.name].getCursor(action) : '';\n interaction.target._doc.documentElement.style.cursor = cursor;\n }\n\n signals.fire('prepared', { interaction: interaction });\n}\n\nInteraction.signals.on('stop', function (_ref4) {\n var interaction = _ref4.interaction;\n\n var target = interaction.target;\n\n if (target && target.options.styleCursor) {\n target._doc.documentElement.style.cursor = '';\n }\n});\n\nInteractable.prototype.getAction = function (pointer, event, interaction, element) {\n var action = this.defaultActionChecker(pointer, event, interaction, element);\n\n if (this.options.actionChecker) {\n return this.options.actionChecker(pointer, event, action, this, element, interaction);\n }\n\n return action;\n};\n\n/*\\\n * Interactable.actionChecker\n [ method ]\n *\n * Gets or sets the function used to check action to be performed on\n * pointerDown\n *\n - checker (function | null) #optional A function which takes a pointer event, defaultAction string, interactable, element and interaction as parameters and returns an object with name property 'drag' 'resize' or 'gesture' and optionally an `edges` object with boolean 'top', 'left', 'bottom' and right props.\n = (Function | Interactable) The checker function or this Interactable\n *\n | interact('.resize-drag')\n | .resizable(true)\n | .draggable(true)\n | .actionChecker(function (pointer, event, action, interactable, element, interaction) {\n |\n | if (interact.matchesSelector(event.target, '.drag-handle') {\n | // force drag with handle target\n | action.name = drag;\n | }\n | else {\n | // resize from the top and right edges\n | action.name = 'resize';\n | action.edges = { top: true, right: true };\n | }\n |\n | return action;\n | });\n\\*/\nInteractable.prototype.actionChecker = function (checker) {\n if (utils.is.function(checker)) {\n this.options.actionChecker = checker;\n\n return this;\n }\n\n if (checker === null) {\n delete this.options.actionChecker;\n\n return this;\n }\n\n return this.options.actionChecker;\n};\n\n/*\\\n * Interactable.styleCursor\n [ method ]\n *\n * Returns or sets whether the the cursor should be changed depending on the\n * action that would be performed if the mouse were pressed and dragged.\n *\n - newValue (boolean) #optional\n = (boolean | Interactable) The current setting or this Interactable\n\\*/\nInteractable.prototype.styleCursor = function (newValue) {\n if (utils.is.bool(newValue)) {\n this.options.styleCursor = newValue;\n\n return this;\n }\n\n if (newValue === null) {\n delete this.options.styleCursor;\n\n return this;\n }\n\n return this.options.styleCursor;\n};\n\nInteractable.prototype.defaultActionChecker = function (pointer, event, interaction, element) {\n var rect = this.getRect(element);\n var buttons = event.buttons || {\n 0: 1,\n 1: 4,\n 3: 8,\n 4: 16\n }[event.button];\n var action = null;\n\n for (var _iterator = actions.names, _isArray = Array.isArray(_iterator), _i = 0, _iterator = _isArray ? _iterator : _iterator[Symbol.iterator]();;) {\n var _ref5;\n\n if (_isArray) {\n if (_i >= _iterator.length) break;\n _ref5 = _iterator[_i++];\n } else {\n _i = _iterator.next();\n if (_i.done) break;\n _ref5 = _i.value;\n }\n\n var actionName = _ref5;\n\n // check mouseButton setting if the pointer is down\n if (interaction.pointerIsDown && interaction.mouse && (buttons & this.options[actionName].mouseButtons) === 0) {\n continue;\n }\n\n action = actions[actionName].checker(pointer, event, this, element, interaction, rect);\n\n if (action) {\n return action;\n }\n }\n};\n\nfunction withinInteractionLimit(interactable, element, action) {\n var options = interactable.options;\n var maxActions = options[action.name].max;\n var maxPerElement = options[action.name].maxPerElement;\n var activeInteractions = 0;\n var targetCount = 0;\n var targetElementCount = 0;\n\n // no actions if any of these values == 0\n if (!(maxActions && maxPerElement && autoStart.maxInteractions)) {\n return;\n }\n\n for (var i = 0, len = scope.interactions.length; i < len; i++) {\n var interaction = scope.interactions[i];\n var otherAction = interaction.prepared.name;\n\n if (!interaction.interacting()) {\n continue;\n }\n\n activeInteractions++;\n\n if (activeInteractions >= autoStart.maxInteractions) {\n return false;\n }\n\n if (interaction.target !== interactable) {\n continue;\n }\n\n targetCount += otherAction === action.name | 0;\n\n if (targetCount >= maxActions) {\n return false;\n }\n\n if (interaction.element === element) {\n targetElementCount++;\n\n if (otherAction !== action.name || targetElementCount >= maxPerElement) {\n return false;\n }\n }\n }\n\n return autoStart.maxInteractions > 0;\n}\n\n/*\\\n * interact.maxInteractions\n [ method ]\n **\n * Returns or sets the maximum number of concurrent interactions allowed.\n * By default only 1 interaction is allowed at a time (for backwards\n * compatibility). To allow multiple interactions on the same Interactables\n * and elements, you need to enable it in the draggable, resizable and\n * gesturable `'max'` and `'maxPerElement'` options.\n **\n - newValue (number) #optional Any number. newValue <= 0 means no interactions.\n\\*/\ninteract.maxInteractions = function (newValue) {\n if (utils.is.number(newValue)) {\n autoStart.maxInteractions = newValue;\n\n return this;\n }\n\n return autoStart.maxInteractions;\n};\n\nInteractable.settingsMethods.push('styleCursor');\nInteractable.settingsMethods.push('actionChecker');\nInteractable.settingsMethods.push('ignoreFrom');\nInteractable.settingsMethods.push('allowFrom');\n\ndefaultOptions.base.actionChecker = null;\ndefaultOptions.base.styleCursor = true;\n\nutils.extend(defaultOptions.perAction, autoStart.defaults.perAction);\n\nmodule.exports = autoStart;\n\n},{\"../Interactable\":4,\"../Interaction\":5,\"../actions/base\":6,\"../defaultOptions\":18,\"../interact\":21,\"../scope\":34,\"../utils\":44,\"../utils/Signals\":35,\"../utils/browser\":37,\"./InteractableMethods\":12}],14:[function(require,module,exports){\n'use strict';\n\nvar autoStart = require('./base');\nvar Interaction = require('../Interaction');\n\nInteraction.signals.on('new', function (interaction) {\n interaction.delayTimer = null;\n});\n\nautoStart.signals.on('prepared', function (_ref) {\n var interaction = _ref.interaction;\n\n var actionName = interaction.prepared.name;\n\n if (!actionName) {\n return;\n }\n\n var delay = interaction.target.options[actionName].delay;\n\n if (delay > 0) {\n interaction.delayTimer = setTimeout(function () {\n interaction.start(interaction.prepared, interaction.target, interaction.element);\n }, delay);\n }\n});\n\nInteraction.signals.on('move', function (_ref2) {\n var interaction = _ref2.interaction,\n duplicate = _ref2.duplicate;\n\n if (interaction.pointerWasMoved && !duplicate) {\n clearTimeout(interaction.delayTimer);\n }\n});\n\n// prevent regular down->move autoStart\nautoStart.signals.on('before-start', function (_ref3) {\n var interaction = _ref3.interaction;\n\n var actionName = interaction.prepared.name;\n\n if (!actionName) {\n return;\n }\n\n var delay = interaction.target.options[actionName].delay;\n\n if (delay > 0) {\n interaction.prepared.name = null;\n }\n});\n\n},{\"../Interaction\":5,\"./base\":13}],15:[function(require,module,exports){\n'use strict';\n\nvar autoStart = require('./base');\nvar scope = require('../scope');\nvar browser = require('../utils/browser');\nvar is = require('../utils/is');\n\nvar _require = require('../utils/domUtils'),\n matchesSelector = _require.matchesSelector,\n parentNode = _require.parentNode;\n\nautoStart.setActionDefaults(require('../actions/drag'));\n\nautoStart.signals.on('before-start', function (_ref) {\n var interaction = _ref.interaction,\n eventTarget = _ref.eventTarget,\n dx = _ref.dx,\n dy = _ref.dy;\n\n if (interaction.prepared.name !== 'drag') {\n return;\n }\n\n // check if a drag is in the correct axis\n var absX = Math.abs(dx);\n var absY = Math.abs(dy);\n var options = interaction.target.options.drag;\n var startAxis = options.startAxis;\n var currentAxis = absX > absY ? 'x' : absX < absY ? 'y' : 'xy';\n\n interaction.prepared.axis = options.lockAxis === 'start' ? currentAxis[0] // always lock to one axis even if currentAxis === 'xy'\n : options.lockAxis;\n\n // if the movement isn't in the startAxis of the interactable\n if (currentAxis !== 'xy' && startAxis !== 'xy' && startAxis !== currentAxis) {\n // cancel the prepared action\n interaction.prepared.name = null;\n\n // then try to get a drag from another ineractable\n\n if (!interaction.prepared.name) {\n\n var element = eventTarget;\n\n var getDraggable = function getDraggable(interactable, selector, context) {\n var elements = browser.useMatchesSelectorPolyfill ? context.querySelectorAll(selector) : undefined;\n\n if (interactable === interaction.target) {\n return;\n }\n\n if (!options.manualStart && !interactable.testIgnoreAllow(options, element, eventTarget) && matchesSelector(element, selector, elements)) {\n\n var _action = interactable.getAction(interaction.downPointer, interaction.downEvent, interaction, element);\n\n if (_action && _action.name === 'drag' && checkStartAxis(currentAxis, interactable) && autoStart.validateAction(_action, interactable, element, eventTarget)) {\n\n return interactable;\n }\n }\n };\n\n var action = null;\n\n // check all interactables\n while (is.element(element)) {\n var elementInteractable = scope.interactables.get(element);\n\n if (elementInteractable && elementInteractable !== interaction.target && !elementInteractable.options.drag.manualStart) {\n\n action = elementInteractable.getAction(interaction.downPointer, interaction.downEvent, interaction, element);\n }\n if (action && action.name === 'drag' && checkStartAxis(currentAxis, elementInteractable)) {\n\n interaction.prepared.name = 'drag';\n interaction.target = elementInteractable;\n interaction.element = element;\n break;\n }\n\n var selectorInteractable = scope.interactables.forEachSelector(getDraggable, element);\n\n if (selectorInteractable) {\n interaction.prepared.name = 'drag';\n interaction.target = selectorInteractable;\n interaction.element = element;\n break;\n }\n\n element = parentNode(element);\n }\n }\n }\n});\n\nfunction checkStartAxis(startAxis, interactable) {\n if (!interactable) {\n return false;\n }\n\n var thisAxis = interactable.options.drag.startAxis;\n\n return startAxis === 'xy' || thisAxis === 'xy' || thisAxis === startAxis;\n}\n\n},{\"../actions/drag\":7,\"../scope\":34,\"../utils/browser\":37,\"../utils/domUtils\":39,\"../utils/is\":46,\"./base\":13}],16:[function(require,module,exports){\n'use strict';\n\nrequire('./base').setActionDefaults(require('../actions/gesture'));\n\n},{\"../actions/gesture\":9,\"./base\":13}],17:[function(require,module,exports){\n'use strict';\n\nrequire('./base').setActionDefaults(require('../actions/resize'));\n\n},{\"../actions/resize\":10,\"./base\":13}],18:[function(require,module,exports){\n'use strict';\n\nmodule.exports = {\n base: {\n accept: null,\n preventDefault: 'auto',\n deltaSource: 'page'\n },\n\n perAction: {\n origin: { x: 0, y: 0 },\n\n // only allow left button by default\n // see https://developer.mozilla.org/en-US/docs/Web/API/MouseEvent/buttons#Return_value\n mouseButtons: 1,\n\n inertia: {\n enabled: false,\n resistance: 10, // the lambda in exponential decay\n minSpeed: 100, // target speed must be above this for inertia to start\n endSpeed: 10, // the speed at which inertia is slow enough to stop\n allowResume: true, // allow resuming an action in inertia phase\n smoothEndDuration: 300 // animate to snap/restrict endOnly if there's no inertia\n }\n }\n};\n\n},{}],19:[function(require,module,exports){\n'use strict';\n\n/* browser entry point */\n\n// Legacy browser support\nrequire('./legacyBrowsers');\n\n// inertia\nrequire('./inertia');\n\n// modifiers\nrequire('./modifiers/snap');\nrequire('./modifiers/restrict');\n\n// pointerEvents\nrequire('./pointerEvents/base');\nrequire('./pointerEvents/holdRepeat');\nrequire('./pointerEvents/interactableTargets');\n\n// delay\nrequire('./autoStart/delay');\n\n// actions\nrequire('./actions/gesture');\nrequire('./actions/resize');\nrequire('./actions/drag');\nrequire('./actions/drop');\n\n// load these modifiers after resize is loaded\nrequire('./modifiers/snapSize');\nrequire('./modifiers/restrictEdges');\nrequire('./modifiers/restrictSize');\n\n// autoStart actions\nrequire('./autoStart/gesture');\nrequire('./autoStart/resize');\nrequire('./autoStart/drag');\n\n// Interactable preventDefault setting\nrequire('./interactablePreventDefault.js');\n\n// autoScroll\nrequire('./autoScroll');\n\n// export interact\nmodule.exports = require('./interact');\n\n},{\"./actions/drag\":7,\"./actions/drop\":8,\"./actions/gesture\":9,\"./actions/resize\":10,\"./autoScroll\":11,\"./autoStart/delay\":14,\"./autoStart/drag\":15,\"./autoStart/gesture\":16,\"./autoStart/resize\":17,\"./inertia\":20,\"./interact\":21,\"./interactablePreventDefault.js\":22,\"./legacyBrowsers\":23,\"./modifiers/restrict\":25,\"./modifiers/restrictEdges\":26,\"./modifiers/restrictSize\":27,\"./modifiers/snap\":28,\"./modifiers/snapSize\":29,\"./pointerEvents/base\":31,\"./pointerEvents/holdRepeat\":32,\"./pointerEvents/interactableTargets\":33}],20:[function(require,module,exports){\n'use strict';\n\nvar InteractEvent = require('./InteractEvent');\nvar Interaction = require('./Interaction');\nvar modifiers = require('./modifiers');\nvar utils = require('./utils');\nvar animationFrame = require('./utils/raf');\n\nInteraction.signals.on('new', function (interaction) {\n interaction.inertiaStatus = {\n active: false,\n smoothEnd: false,\n allowResume: false,\n\n startEvent: null,\n upCoords: {},\n\n xe: 0, ye: 0,\n sx: 0, sy: 0,\n\n t0: 0,\n vx0: 0, vys: 0,\n duration: 0,\n\n lambda_v0: 0,\n one_ve_v0: 0,\n i: null\n };\n\n interaction.boundInertiaFrame = function () {\n return inertiaFrame.apply(interaction);\n };\n interaction.boundSmoothEndFrame = function () {\n return smoothEndFrame.apply(interaction);\n };\n});\n\nInteraction.signals.on('down', function (_ref) {\n var interaction = _ref.interaction,\n event = _ref.event,\n pointer = _ref.pointer,\n eventTarget = _ref.eventTarget;\n\n var status = interaction.inertiaStatus;\n\n // Check if the down event hits the current inertia target\n if (status.active) {\n var element = eventTarget;\n\n // climb up the DOM tree from the event target\n while (utils.is.element(element)) {\n\n // if interaction element is the current inertia target element\n if (element === interaction.element) {\n // stop inertia\n animationFrame.cancel(status.i);\n status.active = false;\n interaction.simulation = null;\n\n // update pointers to the down event's coordinates\n interaction.updatePointer(pointer);\n utils.setCoords(interaction.curCoords, interaction.pointers);\n\n // fire appropriate signals\n var signalArg = { interaction: interaction };\n Interaction.signals.fire('before-action-move', signalArg);\n Interaction.signals.fire('action-resume', signalArg);\n\n // fire a reume event\n var resumeEvent = new InteractEvent(interaction, event, interaction.prepared.name, 'inertiaresume', interaction.element);\n\n interaction.target.fire(resumeEvent);\n interaction.prevEvent = resumeEvent;\n modifiers.resetStatuses(interaction.modifierStatuses);\n\n utils.copyCoords(interaction.prevCoords, interaction.curCoords);\n break;\n }\n\n element = utils.parentNode(element);\n }\n }\n});\n\nInteraction.signals.on('up', function (_ref2) {\n var interaction = _ref2.interaction,\n event = _ref2.event;\n\n var status = interaction.inertiaStatus;\n\n if (!interaction.interacting() || status.active) {\n return;\n }\n\n var target = interaction.target;\n var options = target && target.options;\n var inertiaOptions = options && interaction.prepared.name && options[interaction.prepared.name].inertia;\n\n var now = new Date().getTime();\n var statuses = {};\n var page = utils.extend({}, interaction.curCoords.page);\n var pointerSpeed = interaction.pointerDelta.client.speed;\n\n var smoothEnd = false;\n var modifierResult = void 0;\n\n // check if inertia should be started\n var inertiaPossible = inertiaOptions && inertiaOptions.enabled && interaction.prepared.name !== 'gesture' && event !== status.startEvent;\n\n var inertia = inertiaPossible && now - interaction.curCoords.timeStamp < 50 && pointerSpeed > inertiaOptions.minSpeed && pointerSpeed > inertiaOptions.endSpeed;\n\n var modifierArg = {\n interaction: interaction,\n pageCoords: page,\n statuses: statuses,\n preEnd: true,\n requireEndOnly: true\n };\n\n // smoothEnd\n if (inertiaPossible && !inertia) {\n modifiers.resetStatuses(statuses);\n\n modifierResult = modifiers.setAll(modifierArg);\n\n if (modifierResult.shouldMove && modifierResult.locked) {\n smoothEnd = true;\n }\n }\n\n if (!(inertia || smoothEnd)) {\n return;\n }\n\n utils.copyCoords(status.upCoords, interaction.curCoords);\n\n interaction.pointers[0] = status.startEvent = new InteractEvent(interaction, event, interaction.prepared.name, 'inertiastart', interaction.element);\n\n status.t0 = now;\n\n status.active = true;\n status.allowResume = inertiaOptions.allowResume;\n interaction.simulation = status;\n\n target.fire(status.startEvent);\n\n if (inertia) {\n status.vx0 = interaction.pointerDelta.client.vx;\n status.vy0 = interaction.pointerDelta.client.vy;\n status.v0 = pointerSpeed;\n\n calcInertia(interaction, status);\n\n utils.extend(page, interaction.curCoords.page);\n\n page.x += status.xe;\n page.y += status.ye;\n\n modifiers.resetStatuses(statuses);\n\n modifierResult = modifiers.setAll(modifierArg);\n\n status.modifiedXe += modifierResult.dx;\n status.modifiedYe += modifierResult.dy;\n\n status.i = animationFrame.request(interaction.boundInertiaFrame);\n } else {\n status.smoothEnd = true;\n status.xe = modifierResult.dx;\n status.ye = modifierResult.dy;\n\n status.sx = status.sy = 0;\n\n status.i = animationFrame.request(interaction.boundSmoothEndFrame);\n }\n});\n\nInteraction.signals.on('stop-active', function (_ref3) {\n var interaction = _ref3.interaction;\n\n var status = interaction.inertiaStatus;\n\n if (status.active) {\n animationFrame.cancel(status.i);\n status.active = false;\n interaction.simulation = null;\n }\n});\n\nfunction calcInertia(interaction, status) {\n var inertiaOptions = interaction.target.options[interaction.prepared.name].inertia;\n var lambda = inertiaOptions.resistance;\n var inertiaDur = -Math.log(inertiaOptions.endSpeed / status.v0) / lambda;\n\n status.x0 = interaction.prevEvent.pageX;\n status.y0 = interaction.prevEvent.pageY;\n status.t0 = status.startEvent.timeStamp / 1000;\n status.sx = status.sy = 0;\n\n status.modifiedXe = status.xe = (status.vx0 - inertiaDur) / lambda;\n status.modifiedYe = status.ye = (status.vy0 - inertiaDur) / lambda;\n status.te = inertiaDur;\n\n status.lambda_v0 = lambda / status.v0;\n status.one_ve_v0 = 1 - inertiaOptions.endSpeed / status.v0;\n}\n\nfunction inertiaFrame() {\n updateInertiaCoords(this);\n utils.setCoordDeltas(this.pointerDelta, this.prevCoords, this.curCoords);\n\n var status = this.inertiaStatus;\n var options = this.target.options[this.prepared.name].inertia;\n var lambda = options.resistance;\n var t = new Date().getTime() / 1000 - status.t0;\n\n if (t < status.te) {\n\n var progress = 1 - (Math.exp(-lambda * t) - status.lambda_v0) / status.one_ve_v0;\n\n if (status.modifiedXe === status.xe && status.modifiedYe === status.ye) {\n status.sx = status.xe * progress;\n status.sy = status.ye * progress;\n } else {\n var quadPoint = utils.getQuadraticCurvePoint(0, 0, status.xe, status.ye, status.modifiedXe, status.modifiedYe, progress);\n\n status.sx = quadPoint.x;\n status.sy = quadPoint.y;\n }\n\n this.doMove();\n\n status.i = animationFrame.request(this.boundInertiaFrame);\n } else {\n status.sx = status.modifiedXe;\n status.sy = status.modifiedYe;\n\n this.doMove();\n this.end(status.startEvent);\n status.active = false;\n this.simulation = null;\n }\n\n utils.copyCoords(this.prevCoords, this.curCoords);\n}\n\nfunction smoothEndFrame() {\n updateInertiaCoords(this);\n\n var status = this.inertiaStatus;\n var t = new Date().getTime() - status.t0;\n var duration = this.target.options[this.prepared.name].inertia.smoothEndDuration;\n\n if (t < duration) {\n status.sx = utils.easeOutQuad(t, 0, status.xe, duration);\n status.sy = utils.easeOutQuad(t, 0, status.ye, duration);\n\n this.pointerMove(status.startEvent, status.startEvent);\n\n status.i = animationFrame.request(this.boundSmoothEndFrame);\n } else {\n status.sx = status.xe;\n status.sy = status.ye;\n\n this.pointerMove(status.startEvent, status.startEvent);\n this.end(status.startEvent);\n\n status.smoothEnd = status.active = false;\n this.simulation = null;\n }\n}\n\nfunction updateInertiaCoords(interaction) {\n var status = interaction.inertiaStatus;\n\n // return if inertia isn't running\n if (!status.active) {\n return;\n }\n\n var pageUp = status.upCoords.page;\n var clientUp = status.upCoords.client;\n\n utils.setCoords(interaction.curCoords, [{\n pageX: pageUp.x + status.sx,\n pageY: pageUp.y + status.sy,\n clientX: clientUp.x + status.sx,\n clientY: clientUp.y + status.sy\n }]);\n}\n\n},{\"./InteractEvent\":3,\"./Interaction\":5,\"./modifiers\":24,\"./utils\":44,\"./utils/raf\":50}],21:[function(require,module,exports){\n'use strict';\n\nvar browser = require('./utils/browser');\nvar events = require('./utils/events');\nvar utils = require('./utils');\nvar scope = require('./scope');\nvar Interactable = require('./Interactable');\nvar Interaction = require('./Interaction');\n\nvar globalEvents = {};\n\n/*\\\n * interact\n [ method ]\n *\n * The methods of this variable can be used to set elements as\n * interactables and also to change various default settings.\n *\n * Calling it as a function and passing an element or a valid CSS selector\n * string returns an Interactable object which has various methods to\n * configure it.\n *\n - element (Element | string) The HTML or SVG Element to interact with or CSS selector\n = (object) An @Interactable\n *\n > Usage\n | interact('#draggable').draggable(true);\n |\n | var rectables = interact('rect');\n | rectables\n | .gesturable(true)\n | .on('gesturemove', function (event) {\n | // ...\n | });\n\\*/\nfunction interact(element, options) {\n var interactable = scope.interactables.get(element, options);\n\n if (!interactable) {\n interactable = new Interactable(element, options);\n interactable.events.global = globalEvents;\n }\n\n return interactable;\n}\n\n/*\\\n * interact.isSet\n [ method ]\n *\n * Check if an element has been set\n - element (Element) The Element being searched for\n = (boolean) Indicates if the element or CSS selector was previously passed to interact\n\\*/\ninteract.isSet = function (element, options) {\n return scope.interactables.indexOfElement(element, options && options.context) !== -1;\n};\n\n/*\\\n * interact.on\n [ method ]\n *\n * Adds a global listener for an InteractEvent or adds a DOM event to\n * `document`\n *\n - type (string | array | object) The types of events to listen for\n - listener (function) The function event (s)\n - options (object | boolean) #optional options object or useCapture flag for addEventListener\n = (object) interact\n\\*/\ninteract.on = function (type, listener, options) {\n if (utils.is.string(type) && type.search(' ') !== -1) {\n type = type.trim().split(/ +/);\n }\n\n if (utils.is.array(type)) {\n for (var _iterator = type, _isArray = Array.isArray(_iterator), _i = 0, _iterator = _isArray ? _iterator : _iterator[Symbol.iterator]();;) {\n var _ref;\n\n if (_isArray) {\n if (_i >= _iterator.length) break;\n _ref = _iterator[_i++];\n } else {\n _i = _iterator.next();\n if (_i.done) break;\n _ref = _i.value;\n }\n\n var eventType = _ref;\n\n interact.on(eventType, listener, options);\n }\n\n return interact;\n }\n\n if (utils.is.object(type)) {\n for (var prop in type) {\n interact.on(prop, type[prop], listener);\n }\n\n return interact;\n }\n\n // if it is an InteractEvent type, add listener to globalEvents\n if (utils.contains(Interactable.eventTypes, type)) {\n // if this type of event was never bound\n if (!globalEvents[type]) {\n globalEvents[type] = [listener];\n } else {\n globalEvents[type].push(listener);\n }\n }\n // If non InteractEvent type, addEventListener to document\n else {\n events.add(scope.document, type, listener, { options: options });\n }\n\n return interact;\n};\n\n/*\\\n * interact.off\n [ method ]\n *\n * Removes a global InteractEvent listener or DOM event from `document`\n *\n - type (string | array | object) The types of events that were listened for\n - listener (function) The listener function to be removed\n - options (object | boolean) #optional options object or useCapture flag for removeEventListener\n = (object) interact\n \\*/\ninteract.off = function (type, listener, options) {\n if (utils.is.string(type) && type.search(' ') !== -1) {\n type = type.trim().split(/ +/);\n }\n\n if (utils.is.array(type)) {\n for (var _iterator2 = type, _isArray2 = Array.isArray(_iterator2), _i2 = 0, _iterator2 = _isArray2 ? _iterator2 : _iterator2[Symbol.iterator]();;) {\n var _ref2;\n\n if (_isArray2) {\n if (_i2 >= _iterator2.length) break;\n _ref2 = _iterator2[_i2++];\n } else {\n _i2 = _iterator2.next();\n if (_i2.done) break;\n _ref2 = _i2.value;\n }\n\n var eventType = _ref2;\n\n interact.off(eventType, listener, options);\n }\n\n return interact;\n }\n\n if (utils.is.object(type)) {\n for (var prop in type) {\n interact.off(prop, type[prop], listener);\n }\n\n return interact;\n }\n\n if (!utils.contains(Interactable.eventTypes, type)) {\n events.remove(scope.document, type, listener, options);\n } else {\n var index = void 0;\n\n if (type in globalEvents && (index = utils.indexOf(globalEvents[type], listener)) !== -1) {\n globalEvents[type].splice(index, 1);\n }\n }\n\n return interact;\n};\n\n/*\\\n * interact.debug\n [ method ]\n *\n * Returns an object which exposes internal data\n = (object) An object with properties that outline the current state and expose internal functions and variables\n\\*/\ninteract.debug = function () {\n return scope;\n};\n\n// expose the functions used to calculate multi-touch properties\ninteract.getPointerAverage = utils.pointerAverage;\ninteract.getTouchBBox = utils.touchBBox;\ninteract.getTouchDistance = utils.touchDistance;\ninteract.getTouchAngle = utils.touchAngle;\n\ninteract.getElementRect = utils.getElementRect;\ninteract.getElementClientRect = utils.getElementClientRect;\ninteract.matchesSelector = utils.matchesSelector;\ninteract.closest = utils.closest;\n\n/*\\\n * interact.supportsTouch\n [ method ]\n *\n = (boolean) Whether or not the browser supports touch input\n\\*/\ninteract.supportsTouch = function () {\n return browser.supportsTouch;\n};\n\n/*\\\n * interact.supportsPointerEvent\n [ method ]\n *\n = (boolean) Whether or not the browser supports PointerEvents\n\\*/\ninteract.supportsPointerEvent = function () {\n return browser.supportsPointerEvent;\n};\n\n/*\\\n * interact.stop\n [ method ]\n *\n * Cancels all interactions (end events are not fired)\n *\n - event (Event) An event on which to call preventDefault()\n = (object) interact\n\\*/\ninteract.stop = function (event) {\n for (var i = scope.interactions.length - 1; i >= 0; i--) {\n scope.interactions[i].stop(event);\n }\n\n return interact;\n};\n\n/*\\\n * interact.pointerMoveTolerance\n [ method ]\n * Returns or sets the distance the pointer must be moved before an action\n * sequence occurs. This also affects tolerance for tap events.\n *\n - newValue (number) #optional The movement from the start position must be greater than this value\n = (number | Interactable) The current setting or interact\n\\*/\ninteract.pointerMoveTolerance = function (newValue) {\n if (utils.is.number(newValue)) {\n Interaction.pointerMoveTolerance = newValue;\n\n return this;\n }\n\n return Interaction.pointerMoveTolerance;\n};\n\ninteract.addDocument = scope.addDocument;\ninteract.removeDocument = scope.removeDocument;\n\nscope.interact = interact;\n\nmodule.exports = interact;\n\n},{\"./Interactable\":4,\"./Interaction\":5,\"./scope\":34,\"./utils\":44,\"./utils/browser\":37,\"./utils/events\":40}],22:[function(require,module,exports){\n'use strict';\n\nvar Interactable = require('./Interactable');\nvar Interaction = require('./Interaction');\nvar scope = require('./scope');\nvar is = require('./utils/is');\nvar events = require('./utils/events');\n\nvar _require = require('./utils/domUtils'),\n nodeContains = _require.nodeContains,\n matchesSelector = _require.matchesSelector;\n\n/*\\\n * Interactable.preventDefault\n [ method ]\n *\n * Returns or sets whether to prevent the browser's default behaviour\n * in response to pointer events. Can be set to:\n * - `'always'` to always prevent\n * - `'never'` to never prevent\n * - `'auto'` to let interact.js try to determine what would be best\n *\n - newValue (string) #optional `true`, `false` or `'auto'`\n = (string | Interactable) The current setting or this Interactable\n\\*/\n\n\nInteractable.prototype.preventDefault = function (newValue) {\n if (/^(always|never|auto)$/.test(newValue)) {\n this.options.preventDefault = newValue;\n return this;\n }\n\n if (is.bool(newValue)) {\n this.options.preventDefault = newValue ? 'always' : 'never';\n return this;\n }\n\n return this.options.preventDefault;\n};\n\nInteractable.prototype.checkAndPreventDefault = function (event) {\n var setting = this.options.preventDefault;\n\n if (setting === 'never') {\n return;\n }\n\n if (setting === 'always') {\n event.preventDefault();\n return;\n }\n\n // setting === 'auto'\n\n // don't preventDefault if the browser supports passiveEvents\n // CSS touch-action and user-selecct should be used instead\n if (events.supportsOptions) {\n return;\n }\n\n // don't preventDefault of pointerdown events\n if (/^(mouse|pointer|touch)*(down|start)/i.test(event.type)) {\n return;\n }\n\n // don't preventDefault on editable elements\n if (is.element(event.target) && matchesSelector(event.target, 'input,select,textarea,[contenteditable=true],[contenteditable=true] *')) {\n return;\n }\n\n event.preventDefault();\n};\n\nfunction onInteractionEvent(_ref) {\n var interaction = _ref.interaction,\n event = _ref.event;\n\n if (interaction.target) {\n interaction.target.checkAndPreventDefault(event);\n }\n}\n\nvar _arr = ['down', 'move', 'up', 'cancel'];\nfor (var _i = 0; _i < _arr.length; _i++) {\n var eventSignal = _arr[_i];\n Interaction.signals.on(eventSignal, onInteractionEvent);\n}\n\n// prevent native HTML5 drag on interact.js target elements\nInteraction.docEvents.dragstart = function preventNativeDrag(event) {\n for (var _iterator = scope.interactions, _isArray = Array.isArray(_iterator), _i2 = 0, _iterator = _isArray ? _iterator : _iterator[Symbol.iterator]();;) {\n var _ref2;\n\n if (_isArray) {\n if (_i2 >= _iterator.length) break;\n _ref2 = _iterator[_i2++];\n } else {\n _i2 = _iterator.next();\n if (_i2.done) break;\n _ref2 = _i2.value;\n }\n\n var interaction = _ref2;\n\n\n if (interaction.element && (interaction.element === event.target || nodeContains(interaction.element, event.target))) {\n\n interaction.target.checkAndPreventDefault(event);\n return;\n }\n }\n};\n\n},{\"./Interactable\":4,\"./Interaction\":5,\"./scope\":34,\"./utils/domUtils\":39,\"./utils/events\":40,\"./utils/is\":46}],23:[function(require,module,exports){\n'use strict';\n\nvar scope = require('./scope');\nvar events = require('./utils/events');\nvar browser = require('./utils/browser');\nvar iFinder = require('./utils/interactionFinder');\nvar pointerEvents = require('./pointerEvents/base');\n\nvar _require = require('./utils/window'),\n window = _require.window;\n\nvar toString = Object.prototype.toString;\n\nif (!window.Array.isArray) {\n window.Array.isArray = function (obj) {\n return toString.call(obj) === '[object Array]';\n };\n}\n\nif (!String.prototype.trim) {\n String.prototype.trim = function () {\n return this.replace(/^[\\s\\uFEFF\\xA0]+|[\\s\\uFEFF\\xA0]+$/g, '');\n };\n}\n\n// http://www.quirksmode.org/dom/events/click.html\n// >Events leading to dblclick\n//\n// IE8 doesn't fire down event before dblclick.\n// This workaround tries to fire a tap and doubletap after dblclick\nfunction onIE8Dblclick(event) {\n var eventTarget = event.target;\n var interaction = iFinder.search(event, event.type, eventTarget);\n\n if (!interaction) {\n return;\n }\n\n if (interaction.prevTap && event.clientX === interaction.prevTap.clientX && event.clientY === interaction.prevTap.clientY && eventTarget === interaction.prevTap.target) {\n\n interaction.downTargets[0] = eventTarget;\n interaction.downTimes[0] = new Date().getTime();\n\n pointerEvents.fire({\n interaction: interaction,\n event: event,\n eventTarget: eventTarget,\n pointer: event,\n type: 'tap'\n });\n }\n}\n\nif (browser.isIE8) {\n var selectFix = function selectFix(event) {\n for (var _iterator = scope.interactions, _isArray = Array.isArray(_iterator), _i = 0, _iterator = _isArray ? _iterator : _iterator[Symbol.iterator]();;) {\n var _ref;\n\n if (_isArray) {\n if (_i >= _iterator.length) break;\n _ref = _iterator[_i++];\n } else {\n _i = _iterator.next();\n if (_i.done) break;\n _ref = _i.value;\n }\n\n var interaction = _ref;\n\n if (interaction.interacting()) {\n interaction.target.checkAndPreventDefault(event);\n }\n }\n };\n\n var onDocIE8 = function onDocIE8(_ref2, signalName) {\n var doc = _ref2.doc,\n win = _ref2.win;\n\n var eventMethod = signalName.indexOf('listen') === 0 ? events.add : events.remove;\n\n // For IE's lack of Event#preventDefault\n eventMethod(doc, 'selectstart', selectFix);\n\n if (pointerEvents) {\n eventMethod(doc, 'dblclick', onIE8Dblclick);\n }\n };\n\n scope.signals.on('add-document', onDocIE8);\n scope.signals.on('remove-document', onDocIE8);\n}\n\nmodule.exports = null;\n\n},{\"./pointerEvents/base\":31,\"./scope\":34,\"./utils/browser\":37,\"./utils/events\":40,\"./utils/interactionFinder\":45,\"./utils/window\":52}],24:[function(require,module,exports){\n'use strict';\n\nvar InteractEvent = require('../InteractEvent');\nvar Interaction = require('../Interaction');\nvar extend = require('../utils/extend');\n\nvar modifiers = {\n names: [],\n\n setOffsets: function setOffsets(arg) {\n var interaction = arg.interaction,\n page = arg.pageCoords;\n var target = interaction.target,\n element = interaction.element,\n startOffset = interaction.startOffset;\n\n var rect = target.getRect(element);\n\n if (rect) {\n startOffset.left = page.x - rect.left;\n startOffset.top = page.y - rect.top;\n\n startOffset.right = rect.right - page.x;\n startOffset.bottom = rect.bottom - page.y;\n\n if (!('width' in rect)) {\n rect.width = rect.right - rect.left;\n }\n if (!('height' in rect)) {\n rect.height = rect.bottom - rect.top;\n }\n } else {\n startOffset.left = startOffset.top = startOffset.right = startOffset.bottom = 0;\n }\n\n arg.rect = rect;\n arg.interactable = target;\n arg.element = element;\n\n for (var i = 0; i < modifiers.names.length; i++) {\n var modifierName = modifiers.names[i];\n\n arg.options = target.options[interaction.prepared.name][modifierName];\n\n if (!arg.options) {\n continue;\n }\n\n interaction.modifierOffsets[modifierName] = modifiers[modifierName].setOffset(arg);\n }\n },\n\n setAll: function setAll(arg) {\n var interaction = arg.interaction,\n statuses = arg.statuses,\n preEnd = arg.preEnd,\n requireEndOnly = arg.requireEndOnly;\n\n var coords = extend({}, arg.pageCoords);\n var result = {\n dx: 0,\n dy: 0,\n changed: false,\n locked: false,\n shouldMove: true\n };\n\n for (var _iterator = modifiers.names, _isArray = Array.isArray(_iterator), _i = 0, _iterator = _isArray ? _iterator : _iterator[Symbol.iterator]();;) {\n var _ref;\n\n if (_isArray) {\n if (_i >= _iterator.length) break;\n _ref = _iterator[_i++];\n } else {\n _i = _iterator.next();\n if (_i.done) break;\n _ref = _i.value;\n }\n\n var modifierName = _ref;\n\n var modifier = modifiers[modifierName];\n var options = interaction.target.options[interaction.prepared.name][modifierName];\n\n if (!shouldDo(options, preEnd, requireEndOnly)) {\n continue;\n }\n\n arg.status = arg.status = statuses[modifierName];\n arg.options = options;\n arg.offset = arg.interaction.modifierOffsets[modifierName];\n\n modifier.set(arg);\n\n if (arg.status.locked) {\n coords.x += arg.status.dx;\n coords.y += arg.status.dy;\n\n result.dx += arg.status.dx;\n result.dy += arg.status.dy;\n\n result.locked = true;\n }\n }\n\n // a move should be fired if:\n // - there are no modifiers enabled,\n // - no modifiers are \"locked\" i.e. have changed the pointer's coordinates, or\n // - the locked coords have changed since the last pointer move\n result.shouldMove = !arg.status || !result.locked || arg.status.changed;\n\n return result;\n },\n\n resetStatuses: function resetStatuses(statuses) {\n for (var _iterator2 = modifiers.names, _isArray2 = Array.isArray(_iterator2), _i2 = 0, _iterator2 = _isArray2 ? _iterator2 : _iterator2[Symbol.iterator]();;) {\n var _ref2;\n\n if (_isArray2) {\n if (_i2 >= _iterator2.length) break;\n _ref2 = _iterator2[_i2++];\n } else {\n _i2 = _iterator2.next();\n if (_i2.done) break;\n _ref2 = _i2.value;\n }\n\n var modifierName = _ref2;\n\n var status = statuses[modifierName] || {};\n\n status.dx = status.dy = 0;\n status.modifiedX = status.modifiedY = NaN;\n status.locked = false;\n status.changed = true;\n\n statuses[modifierName] = status;\n }\n\n return statuses;\n },\n\n start: function start(_ref3, signalName) {\n var interaction = _ref3.interaction;\n\n var arg = {\n interaction: interaction,\n pageCoords: (signalName === 'action-resume' ? interaction.curCoords : interaction.startCoords).page,\n startOffset: interaction.startOffset,\n statuses: interaction.modifierStatuses,\n preEnd: false,\n requireEndOnly: false\n };\n\n modifiers.setOffsets(arg);\n modifiers.resetStatuses(arg.statuses);\n\n arg.pageCoords = extend({}, interaction.startCoords.page);\n interaction.modifierResult = modifiers.setAll(arg);\n }\n};\n\nInteraction.signals.on('new', function (interaction) {\n interaction.startOffset = { left: 0, right: 0, top: 0, bottom: 0 };\n interaction.modifierOffsets = {};\n interaction.modifierStatuses = modifiers.resetStatuses({});\n interaction.modifierResult = null;\n});\n\nInteraction.signals.on('action-start', modifiers.start);\nInteraction.signals.on('action-resume', modifiers.start);\n\nInteraction.signals.on('before-action-move', function (_ref4) {\n var interaction = _ref4.interaction,\n preEnd = _ref4.preEnd,\n interactingBeforeMove = _ref4.interactingBeforeMove;\n\n var modifierResult = modifiers.setAll({\n interaction: interaction,\n preEnd: preEnd,\n pageCoords: interaction.curCoords.page,\n statuses: interaction.modifierStatuses,\n requireEndOnly: false\n });\n\n // don't fire an action move if a modifier would keep the event in the same\n // cordinates as before\n if (!modifierResult.shouldMove && interactingBeforeMove) {\n interaction._dontFireMove = true;\n }\n\n interaction.modifierResult = modifierResult;\n});\n\nInteraction.signals.on('action-end', function (_ref5) {\n var interaction = _ref5.interaction,\n event = _ref5.event;\n\n for (var i = 0; i < modifiers.names.length; i++) {\n var options = interaction.target.options[interaction.prepared.name][modifiers.names[i]];\n\n // if the endOnly option is true for any modifier\n if (shouldDo(options, true, true)) {\n // fire a move event at the modified coordinates\n interaction.doMove({ event: event, preEnd: true });\n break;\n }\n }\n});\n\nInteractEvent.signals.on('set-xy', function (arg) {\n var iEvent = arg.iEvent,\n interaction = arg.interaction;\n\n var modifierArg = extend({}, arg);\n\n for (var i = 0; i < modifiers.names.length; i++) {\n var modifierName = modifiers.names[i];\n modifierArg.options = interaction.target.options[interaction.prepared.name][modifierName];\n\n if (!modifierArg.options) {\n continue;\n }\n\n var modifier = modifiers[modifierName];\n\n modifierArg.status = interaction.modifierStatuses[modifierName];\n\n iEvent[modifierName] = modifier.modifyCoords(modifierArg);\n }\n});\n\nfunction shouldDo(options, preEnd, requireEndOnly) {\n return options && options.enabled && (preEnd || !options.endOnly) && (!requireEndOnly || options.endOnly);\n}\n\nmodule.exports = modifiers;\n\n},{\"../InteractEvent\":3,\"../Interaction\":5,\"../utils/extend\":41}],25:[function(require,module,exports){\n'use strict';\n\nvar modifiers = require('./index');\nvar utils = require('../utils');\nvar defaultOptions = require('../defaultOptions');\n\nvar restrict = {\n defaults: {\n enabled: false,\n endOnly: false,\n restriction: null,\n elementRect: null\n },\n\n setOffset: function setOffset(_ref) {\n var rect = _ref.rect,\n startOffset = _ref.startOffset,\n options = _ref.options;\n\n var elementRect = options && options.elementRect;\n var offset = {};\n\n if (rect && elementRect) {\n offset.left = startOffset.left - rect.width * elementRect.left;\n offset.top = startOffset.top - rect.height * elementRect.top;\n\n offset.right = startOffset.right - rect.width * (1 - elementRect.right);\n offset.bottom = startOffset.bottom - rect.height * (1 - elementRect.bottom);\n } else {\n offset.left = offset.top = offset.right = offset.bottom = 0;\n }\n\n return offset;\n },\n\n set: function set(_ref2) {\n var pageCoords = _ref2.pageCoords,\n interaction = _ref2.interaction,\n status = _ref2.status,\n options = _ref2.options;\n\n if (!options) {\n return status;\n }\n\n var page = status.useStatusXY ? { x: status.x, y: status.y } : utils.extend({}, pageCoords);\n\n var restriction = getRestrictionRect(options.restriction, interaction, page);\n\n if (!restriction) {\n return status;\n }\n\n status.dx = 0;\n status.dy = 0;\n status.locked = false;\n\n var rect = restriction;\n var modifiedX = page.x;\n var modifiedY = page.y;\n\n var offset = interaction.modifierOffsets.restrict;\n\n // object is assumed to have\n // x, y, width, height or\n // left, top, right, bottom\n if ('x' in restriction && 'y' in restriction) {\n modifiedX = Math.max(Math.min(rect.x + rect.width - offset.right, page.x), rect.x + offset.left);\n modifiedY = Math.max(Math.min(rect.y + rect.height - offset.bottom, page.y), rect.y + offset.top);\n } else {\n modifiedX = Math.max(Math.min(rect.right - offset.right, page.x), rect.left + offset.left);\n modifiedY = Math.max(Math.min(rect.bottom - offset.bottom, page.y), rect.top + offset.top);\n }\n\n status.dx = modifiedX - page.x;\n status.dy = modifiedY - page.y;\n\n status.changed = status.modifiedX !== modifiedX || status.modifiedY !== modifiedY;\n status.locked = !!(status.dx || status.dy);\n\n status.modifiedX = modifiedX;\n status.modifiedY = modifiedY;\n },\n\n modifyCoords: function modifyCoords(_ref3) {\n var page = _ref3.page,\n client = _ref3.client,\n status = _ref3.status,\n phase = _ref3.phase,\n options = _ref3.options;\n\n var elementRect = options && options.elementRect;\n\n if (options && options.enabled && !(phase === 'start' && elementRect && status.locked)) {\n\n if (status.locked) {\n page.x += status.dx;\n page.y += status.dy;\n client.x += status.dx;\n client.y += status.dy;\n\n return {\n dx: status.dx,\n dy: status.dy\n };\n }\n }\n },\n\n getRestrictionRect: getRestrictionRect\n};\n\nfunction getRestrictionRect(value, interaction, page) {\n if (utils.is.function(value)) {\n return utils.resolveRectLike(value, interaction.target, interaction.element, [page.x, page.y, interaction]);\n } else {\n return utils.resolveRectLike(value, interaction.target, interaction.element);\n }\n}\n\nmodifiers.restrict = restrict;\nmodifiers.names.push('restrict');\n\ndefaultOptions.perAction.restrict = restrict.defaults;\n\nmodule.exports = restrict;\n\n},{\"../defaultOptions\":18,\"../utils\":44,\"./index\":24}],26:[function(require,module,exports){\n'use strict';\n\n// This module adds the options.resize.restrictEdges setting which sets min and\n// max for the top, left, bottom and right edges of the target being resized.\n//\n// interact(target).resize({\n// edges: { top: true, left: true },\n// restrictEdges: {\n// inner: { top: 200, left: 200, right: 400, bottom: 400 },\n// outer: { top: 0, left: 0, right: 600, bottom: 600 },\n// },\n// });\n\nvar modifiers = require('./index');\nvar utils = require('../utils');\nvar rectUtils = require('../utils/rect');\nvar defaultOptions = require('../defaultOptions');\nvar resize = require('../actions/resize');\n\nvar _require = require('./restrict'),\n getRestrictionRect = _require.getRestrictionRect;\n\nvar noInner = { top: +Infinity, left: +Infinity, bottom: -Infinity, right: -Infinity };\nvar noOuter = { top: -Infinity, left: -Infinity, bottom: +Infinity, right: +Infinity };\n\nvar restrictEdges = {\n defaults: {\n enabled: false,\n endOnly: false,\n min: null,\n max: null,\n offset: null\n },\n\n setOffset: function setOffset(_ref) {\n var interaction = _ref.interaction,\n startOffset = _ref.startOffset,\n options = _ref.options;\n\n if (!options) {\n return utils.extend({}, startOffset);\n }\n\n var offset = getRestrictionRect(options.offset, interaction, interaction.startCoords.page);\n\n if (offset) {\n return {\n top: startOffset.top + offset.y,\n left: startOffset.left + offset.x,\n bottom: startOffset.bottom + offset.y,\n right: startOffset.right + offset.x\n };\n }\n\n return startOffset;\n },\n\n set: function set(_ref2) {\n var pageCoords = _ref2.pageCoords,\n interaction = _ref2.interaction,\n status = _ref2.status,\n offset = _ref2.offset,\n options = _ref2.options;\n\n var edges = interaction.prepared.linkedEdges || interaction.prepared.edges;\n\n if (!interaction.interacting() || !edges) {\n return;\n }\n\n var page = status.useStatusXY ? { x: status.x, y: status.y } : utils.extend({}, pageCoords);\n var inner = rectUtils.xywhToTlbr(getRestrictionRect(options.inner, interaction, page)) || noInner;\n var outer = rectUtils.xywhToTlbr(getRestrictionRect(options.outer, interaction, page)) || noOuter;\n\n var modifiedX = page.x;\n var modifiedY = page.y;\n\n status.dx = 0;\n status.dy = 0;\n status.locked = false;\n\n if (edges.top) {\n modifiedY = Math.min(Math.max(outer.top + offset.top, page.y), inner.top + offset.top);\n } else if (edges.bottom) {\n modifiedY = Math.max(Math.min(outer.bottom - offset.bottom, page.y), inner.bottom - offset.bottom);\n }\n if (edges.left) {\n modifiedX = Math.min(Math.max(outer.left + offset.left, page.x), inner.left + offset.left);\n } else if (edges.right) {\n modifiedX = Math.max(Math.min(outer.right - offset.right, page.x), inner.right - offset.right);\n }\n\n status.dx = modifiedX - page.x;\n status.dy = modifiedY - page.y;\n\n status.changed = status.modifiedX !== modifiedX || status.modifiedY !== modifiedY;\n status.locked = !!(status.dx || status.dy);\n\n status.modifiedX = modifiedX;\n status.modifiedY = modifiedY;\n },\n\n modifyCoords: function modifyCoords(_ref3) {\n var page = _ref3.page,\n client = _ref3.client,\n status = _ref3.status,\n phase = _ref3.phase,\n options = _ref3.options;\n\n if (options && options.enabled && !(phase === 'start' && status.locked)) {\n\n if (status.locked) {\n page.x += status.dx;\n page.y += status.dy;\n client.x += status.dx;\n client.y += status.dy;\n\n return {\n dx: status.dx,\n dy: status.dy\n };\n }\n }\n },\n\n noInner: noInner,\n noOuter: noOuter,\n getRestrictionRect: getRestrictionRect\n};\n\nmodifiers.restrictEdges = restrictEdges;\nmodifiers.names.push('restrictEdges');\n\ndefaultOptions.perAction.restrictEdges = restrictEdges.defaults;\nresize.defaults.restrictEdges = restrictEdges.defaults;\n\nmodule.exports = restrictEdges;\n\n},{\"../actions/resize\":10,\"../defaultOptions\":18,\"../utils\":44,\"../utils/rect\":51,\"./index\":24,\"./restrict\":25}],27:[function(require,module,exports){\n'use strict';\n\n// This module adds the options.resize.restrictSize setting which sets min and\n// max width and height for the target being resized.\n//\n// interact(target).resize({\n// edges: { top: true, left: true },\n// restrictSize: {\n// min: { width: -600, height: -600 },\n// max: { width: 600, height: 600 },\n// },\n// });\n\nvar modifiers = require('./index');\nvar restrictEdges = require('./restrictEdges');\nvar utils = require('../utils');\nvar rectUtils = require('../utils/rect');\nvar defaultOptions = require('../defaultOptions');\nvar resize = require('../actions/resize');\n\nvar noMin = { width: -Infinity, height: -Infinity };\nvar noMax = { width: +Infinity, height: +Infinity };\n\nvar restrictSize = {\n defaults: {\n enabled: false,\n endOnly: false,\n min: null,\n max: null\n },\n\n setOffset: function setOffset(_ref) {\n var interaction = _ref.interaction;\n\n return interaction.startOffset;\n },\n\n set: function set(arg) {\n var interaction = arg.interaction,\n options = arg.options;\n\n var edges = interaction.prepared.linkedEdges || interaction.prepared.edges;\n\n if (!interaction.interacting() || !edges) {\n return;\n }\n\n var rect = rectUtils.xywhToTlbr(interaction.resizeRects.inverted);\n\n var minSize = rectUtils.tlbrToXywh(restrictEdges.getRestrictionRect(options.min, interaction)) || noMin;\n var maxSize = rectUtils.tlbrToXywh(restrictEdges.getRestrictionRect(options.max, interaction)) || noMax;\n\n arg.options = {\n enabled: options.enabled,\n endOnly: options.endOnly,\n inner: utils.extend({}, restrictEdges.noInner),\n outer: utils.extend({}, restrictEdges.noOuter)\n };\n\n if (edges.top) {\n arg.options.inner.top = rect.bottom - minSize.height;\n arg.options.outer.top = rect.bottom - maxSize.height;\n } else if (edges.bottom) {\n arg.options.inner.bottom = rect.top + minSize.height;\n arg.options.outer.bottom = rect.top + maxSize.height;\n }\n if (edges.left) {\n arg.options.inner.left = rect.right - minSize.width;\n arg.options.outer.left = rect.right - maxSize.width;\n } else if (edges.right) {\n arg.options.inner.right = rect.left + minSize.width;\n arg.options.outer.right = rect.left + maxSize.width;\n }\n\n restrictEdges.set(arg);\n },\n\n modifyCoords: restrictEdges.modifyCoords\n};\n\nmodifiers.restrictSize = restrictSize;\nmodifiers.names.push('restrictSize');\n\ndefaultOptions.perAction.restrictSize = restrictSize.defaults;\nresize.defaults.restrictSize = restrictSize.defaults;\n\nmodule.exports = restrictSize;\n\n},{\"../actions/resize\":10,\"../defaultOptions\":18,\"../utils\":44,\"../utils/rect\":51,\"./index\":24,\"./restrictEdges\":26}],28:[function(require,module,exports){\n'use strict';\n\nvar modifiers = require('./index');\nvar interact = require('../interact');\nvar utils = require('../utils');\nvar defaultOptions = require('../defaultOptions');\n\nvar snap = {\n defaults: {\n enabled: false,\n endOnly: false,\n range: Infinity,\n targets: null,\n offsets: null,\n\n relativePoints: null\n },\n\n setOffset: function setOffset(_ref) {\n var interaction = _ref.interaction,\n interactable = _ref.interactable,\n element = _ref.element,\n rect = _ref.rect,\n startOffset = _ref.startOffset,\n options = _ref.options;\n\n var offsets = [];\n var optionsOrigin = utils.rectToXY(utils.resolveRectLike(options.origin));\n var origin = optionsOrigin || utils.getOriginXY(interactable, element, interaction.prepared.name);\n options = options || interactable.options[interaction.prepared.name].snap || {};\n\n var snapOffset = void 0;\n\n if (options.offset === 'startCoords') {\n snapOffset = {\n x: interaction.startCoords.page.x - origin.x,\n y: interaction.startCoords.page.y - origin.y\n };\n } else {\n var offsetRect = utils.resolveRectLike(options.offset, interactable, element, [interaction]);\n\n snapOffset = utils.rectToXY(offsetRect) || { x: 0, y: 0 };\n }\n\n if (rect && options.relativePoints && options.relativePoints.length) {\n for (var _iterator = options.relativePoints, _isArray = Array.isArray(_iterator), _i = 0, _iterator = _isArray ? _iterator : _iterator[Symbol.iterator]();;) {\n var _ref2;\n\n if (_isArray) {\n if (_i >= _iterator.length) break;\n _ref2 = _iterator[_i++];\n } else {\n _i = _iterator.next();\n if (_i.done) break;\n _ref2 = _i.value;\n }\n\n var _ref3 = _ref2,\n relativeX = _ref3.x,\n relativeY = _ref3.y;\n\n offsets.push({\n x: startOffset.left - rect.width * relativeX + snapOffset.x,\n y: startOffset.top - rect.height * relativeY + snapOffset.y\n });\n }\n } else {\n offsets.push(snapOffset);\n }\n\n return offsets;\n },\n\n set: function set(_ref4) {\n var interaction = _ref4.interaction,\n pageCoords = _ref4.pageCoords,\n status = _ref4.status,\n options = _ref4.options,\n offsets = _ref4.offset;\n\n var targets = [];\n var target = void 0;\n var page = void 0;\n var i = void 0;\n\n if (status.useStatusXY) {\n page = { x: status.x, y: status.y };\n } else {\n var origin = utils.getOriginXY(interaction.target, interaction.element, interaction.prepared.name);\n\n page = utils.extend({}, pageCoords);\n\n page.x -= origin.x;\n page.y -= origin.y;\n }\n\n status.realX = page.x;\n status.realY = page.y;\n\n var len = options.targets ? options.targets.length : 0;\n\n for (var _iterator2 = offsets, _isArray2 = Array.isArray(_iterator2), _i2 = 0, _iterator2 = _isArray2 ? _iterator2 : _iterator2[Symbol.iterator]();;) {\n var _ref5;\n\n if (_isArray2) {\n if (_i2 >= _iterator2.length) break;\n _ref5 = _iterator2[_i2++];\n } else {\n _i2 = _iterator2.next();\n if (_i2.done) break;\n _ref5 = _i2.value;\n }\n\n var _ref6 = _ref5,\n offsetX = _ref6.x,\n offsetY = _ref6.y;\n\n var relativeX = page.x - offsetX;\n var relativeY = page.y - offsetY;\n\n for (var _iterator3 = options.targets, _isArray3 = Array.isArray(_iterator3), _i3 = 0, _iterator3 = _isArray3 ? _iterator3 : _iterator3[Symbol.iterator]();;) {\n var _ref7;\n\n if (_isArray3) {\n if (_i3 >= _iterator3.length) break;\n _ref7 = _iterator3[_i3++];\n } else {\n _i3 = _iterator3.next();\n if (_i3.done) break;\n _ref7 = _i3.value;\n }\n\n var snapTarget = _ref7;\n\n if (utils.is.function(snapTarget)) {\n target = snapTarget(relativeX, relativeY, interaction);\n } else {\n target = snapTarget;\n }\n\n if (!target) {\n continue;\n }\n\n targets.push({\n x: utils.is.number(target.x) ? target.x + offsetX : relativeX,\n y: utils.is.number(target.y) ? target.y + offsetY : relativeY,\n\n range: utils.is.number(target.range) ? target.range : options.range\n });\n }\n }\n\n var closest = {\n target: null,\n inRange: false,\n distance: 0,\n range: 0,\n dx: 0,\n dy: 0\n };\n\n for (i = 0, len = targets.length; i < len; i++) {\n target = targets[i];\n\n var range = target.range;\n var dx = target.x - page.x;\n var dy = target.y - page.y;\n var distance = utils.hypot(dx, dy);\n var inRange = distance <= range;\n\n // Infinite targets count as being out of range\n // compared to non infinite ones that are in range\n if (range === Infinity && closest.inRange && closest.range !== Infinity) {\n inRange = false;\n }\n\n if (!closest.target || (inRange\n // is the closest target in range?\n ? closest.inRange && range !== Infinity\n // the pointer is relatively deeper in this target\n ? distance / range < closest.distance / closest.range\n // this target has Infinite range and the closest doesn't\n : range === Infinity && closest.range !== Infinity ||\n // OR this target is closer that the previous closest\n distance < closest.distance :\n // The other is not in range and the pointer is closer to this target\n !closest.inRange && distance < closest.distance)) {\n\n closest.target = target;\n closest.distance = distance;\n closest.range = range;\n closest.inRange = inRange;\n closest.dx = dx;\n closest.dy = dy;\n\n status.range = range;\n }\n }\n\n var snapChanged = void 0;\n\n if (closest.target) {\n snapChanged = status.modifiedX !== closest.target.x || status.modifiedY !== closest.target.y;\n\n status.modifiedX = closest.target.x;\n status.modifiedY = closest.target.y;\n } else {\n snapChanged = true;\n\n status.modifiedX = NaN;\n status.modifiedY = NaN;\n }\n\n status.dx = closest.dx;\n status.dy = closest.dy;\n\n status.changed = snapChanged || closest.inRange && !status.locked;\n status.locked = closest.inRange;\n },\n\n modifyCoords: function modifyCoords(_ref8) {\n var page = _ref8.page,\n client = _ref8.client,\n status = _ref8.status,\n phase = _ref8.phase,\n options = _ref8.options;\n\n var relativePoints = options && options.relativePoints;\n\n if (options && options.enabled && !(phase === 'start' && relativePoints && relativePoints.length)) {\n\n if (status.locked) {\n page.x += status.dx;\n page.y += status.dy;\n client.x += status.dx;\n client.y += status.dy;\n }\n\n return {\n range: status.range,\n locked: status.locked,\n x: status.modifiedX,\n y: status.modifiedY,\n realX: status.realX,\n realY: status.realY,\n dx: status.dx,\n dy: status.dy\n };\n }\n }\n};\n\ninteract.createSnapGrid = function (grid) {\n return function (x, y) {\n var limits = grid.limits || {\n left: -Infinity,\n right: Infinity,\n top: -Infinity,\n bottom: Infinity\n };\n var offsetX = 0;\n var offsetY = 0;\n\n if (utils.is.object(grid.offset)) {\n offsetX = grid.offset.x;\n offsetY = grid.offset.y;\n }\n\n var gridx = Math.round((x - offsetX) / grid.x);\n var gridy = Math.round((y - offsetY) / grid.y);\n\n var newX = Math.max(limits.left, Math.min(limits.right, gridx * grid.x + offsetX));\n var newY = Math.max(limits.top, Math.min(limits.bottom, gridy * grid.y + offsetY));\n\n return {\n x: newX,\n y: newY,\n range: grid.range\n };\n };\n};\n\nmodifiers.snap = snap;\nmodifiers.names.push('snap');\n\ndefaultOptions.perAction.snap = snap.defaults;\n\nmodule.exports = snap;\n\n},{\"../defaultOptions\":18,\"../interact\":21,\"../utils\":44,\"./index\":24}],29:[function(require,module,exports){\n'use strict';\n\n// This module allows snapping of the size of targets during resize\n// interactions.\n\nvar modifiers = require('./index');\nvar snap = require('./snap');\nvar defaultOptions = require('../defaultOptions');\nvar resize = require('../actions/resize');\nvar utils = require('../utils/');\n\nvar snapSize = {\n defaults: {\n enabled: false,\n endOnly: false,\n range: Infinity,\n targets: null,\n offsets: null\n },\n\n setOffset: function setOffset(arg) {\n var interaction = arg.interaction,\n options = arg.options;\n\n var edges = interaction.prepared.edges;\n\n if (!edges) {\n return;\n }\n\n arg.options = {\n relativePoints: [{\n x: edges.left ? 0 : 1,\n y: edges.top ? 0 : 1\n }],\n origin: { x: 0, y: 0 },\n offset: 'self',\n range: options.range\n };\n\n var offsets = snap.setOffset(arg);\n arg.options = options;\n\n return offsets;\n },\n\n set: function set(arg) {\n var interaction = arg.interaction,\n options = arg.options,\n offset = arg.offset,\n pageCoords = arg.pageCoords;\n\n var page = utils.extend({}, pageCoords);\n var relativeX = page.x - offset[0].x;\n var relativeY = page.y - offset[0].y;\n\n arg.options = utils.extend({}, options);\n arg.options.targets = [];\n\n for (var _iterator = options.targets, _isArray = Array.isArray(_iterator), _i = 0, _iterator = _isArray ? _iterator : _iterator[Symbol.iterator]();;) {\n var _ref;\n\n if (_isArray) {\n if (_i >= _iterator.length) break;\n _ref = _iterator[_i++];\n } else {\n _i = _iterator.next();\n if (_i.done) break;\n _ref = _i.value;\n }\n\n var snapTarget = _ref;\n\n var target = void 0;\n\n if (utils.is.function(snapTarget)) {\n target = snapTarget(relativeX, relativeY, interaction);\n } else {\n target = snapTarget;\n }\n\n if (!target) {\n continue;\n }\n\n if ('width' in target && 'height' in target) {\n target.x = target.width;\n target.y = target.height;\n }\n\n arg.options.targets.push(target);\n }\n\n snap.set(arg);\n },\n\n modifyCoords: function modifyCoords(arg) {\n var options = arg.options;\n\n\n arg.options = utils.extend({}, options);\n arg.options.enabled = options.enabled;\n arg.options.relativePoints = [null];\n\n snap.modifyCoords(arg);\n }\n};\n\nmodifiers.snapSize = snapSize;\nmodifiers.names.push('snapSize');\n\ndefaultOptions.perAction.snapSize = snapSize.defaults;\nresize.defaults.snapSize = snapSize.defaults;\n\nmodule.exports = snapSize;\n\n},{\"../actions/resize\":10,\"../defaultOptions\":18,\"../utils/\":44,\"./index\":24,\"./snap\":28}],30:[function(require,module,exports){\n'use strict';\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nvar pointerUtils = require('../utils/pointerUtils');\n\nmodule.exports = function () {\n function PointerEvent(type, pointer, event, eventTarget, interaction) {\n _classCallCheck(this, PointerEvent);\n\n pointerUtils.pointerExtend(this, event);\n\n if (event !== pointer) {\n pointerUtils.pointerExtend(this, pointer);\n }\n\n this.interaction = interaction;\n\n this.timeStamp = new Date().getTime();\n this.originalEvent = event;\n this.type = type;\n this.pointerId = pointerUtils.getPointerId(pointer);\n this.pointerType = pointerUtils.getPointerType(pointer);\n this.target = eventTarget;\n this.currentTarget = null;\n\n if (type === 'tap') {\n var pointerIndex = interaction.getPointerIndex(pointer);\n this.dt = this.timeStamp - interaction.downTimes[pointerIndex];\n\n var interval = this.timeStamp - interaction.tapTime;\n\n this.double = !!(interaction.prevTap && interaction.prevTap.type !== 'doubletap' && interaction.prevTap.target === this.target && interval < 500);\n } else if (type === 'doubletap') {\n this.dt = pointer.timeStamp - interaction.tapTime;\n }\n }\n\n PointerEvent.prototype.subtractOrigin = function subtractOrigin(_ref) {\n var originX = _ref.x,\n originY = _ref.y;\n\n this.pageX -= originX;\n this.pageY -= originY;\n this.clientX -= originX;\n this.clientY -= originY;\n\n return this;\n };\n\n PointerEvent.prototype.addOrigin = function addOrigin(_ref2) {\n var originX = _ref2.x,\n originY = _ref2.y;\n\n this.pageX += originX;\n this.pageY += originY;\n this.clientX += originX;\n this.clientY += originY;\n\n return this;\n };\n\n PointerEvent.prototype.preventDefault = function preventDefault() {\n this.originalEvent.preventDefault();\n };\n\n PointerEvent.prototype.stopPropagation = function stopPropagation() {\n this.propagationStopped = true;\n };\n\n PointerEvent.prototype.stopImmediatePropagation = function stopImmediatePropagation() {\n this.immediatePropagationStopped = this.propagationStopped = true;\n };\n\n return PointerEvent;\n}();\n\n},{\"../utils/pointerUtils\":49}],31:[function(require,module,exports){\n'use strict';\n\nvar PointerEvent = require('./PointerEvent');\nvar Interaction = require('../Interaction');\nvar utils = require('../utils');\nvar browser = require('../utils/browser');\nvar defaults = require('../defaultOptions');\nvar signals = require('../utils/Signals').new();\n\nvar _require = require('../utils/arr'),\n filter = _require.filter;\n\nvar simpleSignals = ['down', 'up', 'cancel'];\nvar simpleEvents = ['down', 'up', 'cancel'];\n\nvar pointerEvents = {\n PointerEvent: PointerEvent,\n fire: fire,\n collectEventTargets: collectEventTargets,\n signals: signals,\n defaults: {\n holdDuration: 600,\n ignoreFrom: null,\n allowFrom: null,\n origin: { x: 0, y: 0 }\n },\n types: ['down', 'move', 'up', 'cancel', 'tap', 'doubletap', 'hold']\n};\n\nfunction fire(arg) {\n var interaction = arg.interaction,\n pointer = arg.pointer,\n event = arg.event,\n eventTarget = arg.eventTarget,\n _arg$type = arg.type,\n type = _arg$type === undefined ? arg.pointerEvent.type : _arg$type,\n _arg$targets = arg.targets,\n targets = _arg$targets === undefined ? collectEventTargets(arg) : _arg$targets,\n _arg$pointerEvent = arg.pointerEvent,\n pointerEvent = _arg$pointerEvent === undefined ? new PointerEvent(type, pointer, event, eventTarget, interaction) : _arg$pointerEvent;\n\n\n var signalArg = {\n interaction: interaction,\n pointer: pointer,\n event: event,\n eventTarget: eventTarget,\n targets: targets,\n type: type,\n pointerEvent: pointerEvent\n };\n\n for (var i = 0; i < targets.length; i++) {\n var target = targets[i];\n\n for (var prop in target.props || {}) {\n pointerEvent[prop] = target.props[prop];\n }\n\n var origin = utils.getOriginXY(target.eventable, target.element);\n\n pointerEvent.subtractOrigin(origin);\n pointerEvent.eventable = target.eventable;\n pointerEvent.currentTarget = target.element;\n\n target.eventable.fire(pointerEvent);\n\n pointerEvent.addOrigin(origin);\n\n if (pointerEvent.immediatePropagationStopped || pointerEvent.propagationStopped && i + 1 < targets.length && targets[i + 1].element !== pointerEvent.currentTarget) {\n break;\n }\n }\n\n signals.fire('fired', signalArg);\n\n if (type === 'tap') {\n // if pointerEvent should make a double tap, create and fire a doubletap\n // PointerEvent and use that as the prevTap\n var prevTap = pointerEvent.double ? fire({\n interaction: interaction, pointer: pointer, event: event, eventTarget: eventTarget,\n type: 'doubletap'\n }) : pointerEvent;\n\n interaction.prevTap = prevTap;\n interaction.tapTime = prevTap.timeStamp;\n }\n\n return pointerEvent;\n}\n\nfunction collectEventTargets(_ref) {\n var interaction = _ref.interaction,\n pointer = _ref.pointer,\n event = _ref.event,\n eventTarget = _ref.eventTarget,\n type = _ref.type;\n\n var pointerIndex = interaction.getPointerIndex(pointer);\n\n // do not fire a tap event if the pointer was moved before being lifted\n if (type === 'tap' && (interaction.pointerWasMoved\n // or if the pointerup target is different to the pointerdown target\n || !(interaction.downTargets[pointerIndex] && interaction.downTargets[pointerIndex] === eventTarget))) {\n return [];\n }\n\n var path = utils.getPath(eventTarget);\n var signalArg = {\n interaction: interaction,\n pointer: pointer,\n event: event,\n eventTarget: eventTarget,\n type: type,\n path: path,\n targets: [],\n element: null\n };\n\n for (var _iterator = path, _isArray = Array.isArray(_iterator), _i = 0, _iterator = _isArray ? _iterator : _iterator[Symbol.iterator]();;) {\n var _ref2;\n\n if (_isArray) {\n if (_i >= _iterator.length) break;\n _ref2 = _iterator[_i++];\n } else {\n _i = _iterator.next();\n if (_i.done) break;\n _ref2 = _i.value;\n }\n\n var element = _ref2;\n\n signalArg.element = element;\n\n signals.fire('collect-targets', signalArg);\n }\n\n if (type === 'hold') {\n signalArg.targets = filter(signalArg.targets, function (target) {\n return target.eventable.options.holdDuration === interaction.holdTimers[pointerIndex].duration;\n });\n }\n\n return signalArg.targets;\n}\n\nInteraction.signals.on('update-pointer-down', function (_ref3) {\n var interaction = _ref3.interaction,\n pointerIndex = _ref3.pointerIndex;\n\n interaction.holdTimers[pointerIndex] = { duration: Infinity, timeout: null };\n});\n\nInteraction.signals.on('remove-pointer', function (_ref4) {\n var interaction = _ref4.interaction,\n pointerIndex = _ref4.pointerIndex;\n\n interaction.holdTimers.splice(pointerIndex, 1);\n});\n\nInteraction.signals.on('move', function (_ref5) {\n var interaction = _ref5.interaction,\n pointer = _ref5.pointer,\n event = _ref5.event,\n eventTarget = _ref5.eventTarget,\n duplicateMove = _ref5.duplicateMove;\n\n var pointerIndex = interaction.getPointerIndex(pointer);\n\n if (!duplicateMove && (!interaction.pointerIsDown || interaction.pointerWasMoved)) {\n if (interaction.pointerIsDown) {\n clearTimeout(interaction.holdTimers[pointerIndex].timeout);\n }\n\n fire({\n interaction: interaction, pointer: pointer, event: event, eventTarget: eventTarget,\n type: 'move'\n });\n }\n});\n\nInteraction.signals.on('down', function (_ref6) {\n var interaction = _ref6.interaction,\n pointer = _ref6.pointer,\n event = _ref6.event,\n eventTarget = _ref6.eventTarget,\n pointerIndex = _ref6.pointerIndex;\n\n // copy event to be used in timeout for IE8\n var eventCopy = browser.isIE8 ? utils.extend({}, event) : event;\n\n var timer = interaction.holdTimers[pointerIndex];\n var path = utils.getPath(eventTarget);\n var signalArg = {\n interaction: interaction,\n pointer: pointer,\n event: event,\n eventTarget: eventTarget,\n type: 'hold',\n targets: [],\n path: path,\n element: null\n };\n\n for (var _iterator2 = path, _isArray2 = Array.isArray(_iterator2), _i2 = 0, _iterator2 = _isArray2 ? _iterator2 : _iterator2[Symbol.iterator]();;) {\n var _ref7;\n\n if (_isArray2) {\n if (_i2 >= _iterator2.length) break;\n _ref7 = _iterator2[_i2++];\n } else {\n _i2 = _iterator2.next();\n if (_i2.done) break;\n _ref7 = _i2.value;\n }\n\n var element = _ref7;\n\n signalArg.element = element;\n\n signals.fire('collect-targets', signalArg);\n }\n\n if (!signalArg.targets.length) {\n return;\n }\n\n var minDuration = Infinity;\n\n for (var i = 0; i < signalArg.targets.length; i++) {\n var target = signalArg.targets[i];\n var holdDuration = target.eventable.options.holdDuration;\n\n if (holdDuration < minDuration) {\n minDuration = holdDuration;\n }\n }\n\n timer.duration = minDuration;\n timer.timeout = setTimeout(function () {\n fire({\n interaction: interaction,\n eventTarget: eventTarget,\n pointer: browser.isIE8 ? eventCopy : pointer,\n event: eventCopy,\n type: 'hold'\n });\n }, minDuration);\n});\n\nInteraction.signals.on('up', function (_ref8) {\n var interaction = _ref8.interaction,\n pointer = _ref8.pointer,\n event = _ref8.event,\n eventTarget = _ref8.eventTarget;\n\n if (!interaction.pointerWasMoved) {\n fire({ interaction: interaction, eventTarget: eventTarget, pointer: pointer, event: event, type: 'tap' });\n }\n});\n\n['up', 'cancel'].forEach(function (signalName) {\n Interaction.signals.on(signalName, function (_ref9) {\n var interaction = _ref9.interaction,\n pointerIndex = _ref9.pointerIndex;\n\n if (interaction.holdTimers[pointerIndex]) {\n clearTimeout(interaction.holdTimers[pointerIndex].timeout);\n }\n });\n});\n\nfunction createSignalListener(type) {\n return function (_ref10) {\n var interaction = _ref10.interaction,\n pointer = _ref10.pointer,\n event = _ref10.event,\n eventTarget = _ref10.eventTarget;\n\n fire({ interaction: interaction, eventTarget: eventTarget, pointer: pointer, event: event, type: type });\n };\n}\n\nfor (var i = 0; i < simpleSignals.length; i++) {\n Interaction.signals.on(simpleSignals[i], createSignalListener(simpleEvents[i]));\n}\n\nInteraction.signals.on('new', function (interaction) {\n interaction.prevTap = null; // the most recent tap event on this interaction\n interaction.tapTime = 0; // time of the most recent tap event\n interaction.holdTimers = []; // [{ duration, timeout }]\n});\n\ndefaults.pointerEvents = pointerEvents.defaults;\nmodule.exports = pointerEvents;\n\n},{\"../Interaction\":5,\"../defaultOptions\":18,\"../utils\":44,\"../utils/Signals\":35,\"../utils/arr\":36,\"../utils/browser\":37,\"./PointerEvent\":30}],32:[function(require,module,exports){\n'use strict';\n\nvar pointerEvents = require('./base');\nvar Interaction = require('../Interaction');\n\npointerEvents.signals.on('new', onNew);\npointerEvents.signals.on('fired', onFired);\n\nvar _arr = ['move', 'up', 'cancel', 'endall'];\nfor (var _i = 0; _i < _arr.length; _i++) {\n var signal = _arr[_i];\n Interaction.signals.on(signal, endHoldRepeat);\n}\n\nfunction onNew(_ref) {\n var pointerEvent = _ref.pointerEvent;\n\n if (pointerEvent.type !== 'hold') {\n return;\n }\n\n pointerEvent.count = (pointerEvent.count || 0) + 1;\n}\n\nfunction onFired(_ref2) {\n var interaction = _ref2.interaction,\n pointerEvent = _ref2.pointerEvent,\n eventTarget = _ref2.eventTarget,\n targets = _ref2.targets;\n\n if (pointerEvent.type !== 'hold' || !targets.length) {\n return;\n }\n\n // get the repeat interval from the first eventable\n var interval = targets[0].eventable.options.holdRepeatInterval;\n\n // don't repeat if the interval is 0 or less\n if (interval <= 0) {\n return;\n }\n\n // set a timeout to fire the holdrepeat event\n interaction.holdIntervalHandle = setTimeout(function () {\n pointerEvents.fire({\n interaction: interaction,\n eventTarget: eventTarget,\n type: 'hold',\n pointer: pointerEvent,\n event: pointerEvent\n });\n }, interval);\n}\n\nfunction endHoldRepeat(_ref3) {\n var interaction = _ref3.interaction;\n\n // set the interaction's holdStopTime property\n // to stop further holdRepeat events\n if (interaction.holdIntervalHandle) {\n clearInterval(interaction.holdIntervalHandle);\n interaction.holdIntervalHandle = null;\n }\n}\n\n// don't repeat by default\npointerEvents.defaults.holdRepeatInterval = 0;\npointerEvents.types.push('holdrepeat');\n\nmodule.exports = {\n onNew: onNew,\n onFired: onFired,\n endHoldRepeat: endHoldRepeat\n};\n\n},{\"../Interaction\":5,\"./base\":31}],33:[function(require,module,exports){\n'use strict';\n\nvar pointerEvents = require('./base');\nvar Interactable = require('../Interactable');\nvar browser = require('../utils/browser');\nvar is = require('../utils/is');\nvar domUtils = require('../utils/domUtils');\nvar scope = require('../scope');\nvar extend = require('../utils/extend');\n\nvar _require = require('../utils/arr'),\n merge = _require.merge;\n\npointerEvents.signals.on('collect-targets', function (_ref) {\n var targets = _ref.targets,\n element = _ref.element,\n type = _ref.type,\n eventTarget = _ref.eventTarget;\n\n function collectSelectors(interactable, selector, context) {\n var els = browser.useMatchesSelectorPolyfill ? context.querySelectorAll(selector) : undefined;\n\n var eventable = interactable.events;\n var options = eventable.options;\n\n if (eventable[type] && is.element(element) && domUtils.matchesSelector(element, selector, els) && interactable.testIgnoreAllow(options, element, eventTarget)) {\n\n targets.push({\n element: element,\n eventable: eventable,\n props: { interactable: interactable }\n });\n }\n }\n\n var interactable = scope.interactables.get(element);\n\n if (interactable) {\n var eventable = interactable.events;\n var options = eventable.options;\n\n if (eventable[type] && interactable.testIgnoreAllow(options, element, eventTarget)) {\n targets.push({\n element: element,\n eventable: eventable,\n props: { interactable: interactable }\n });\n }\n }\n\n scope.interactables.forEachSelector(collectSelectors, element);\n});\n\nInteractable.signals.on('new', function (_ref2) {\n var interactable = _ref2.interactable;\n\n interactable.events.getRect = function (element) {\n return interactable.getRect(element);\n };\n});\n\nInteractable.signals.on('set', function (_ref3) {\n var interactable = _ref3.interactable,\n options = _ref3.options;\n\n extend(interactable.events.options, pointerEvents.defaults);\n extend(interactable.events.options, options);\n});\n\nmerge(Interactable.eventTypes, pointerEvents.types);\n\nInteractable.prototype.pointerEvents = function (options) {\n extend(this.events.options, options);\n\n return this;\n};\n\nvar __backCompatOption = Interactable.prototype._backCompatOption;\n\nInteractable.prototype._backCompatOption = function (optionName, newValue) {\n var ret = __backCompatOption.call(this, optionName, newValue);\n\n if (ret === this) {\n this.events.options[optionName] = newValue;\n }\n\n return ret;\n};\n\nInteractable.settingsMethods.push('pointerEvents');\n\n},{\"../Interactable\":4,\"../scope\":34,\"../utils/arr\":36,\"../utils/browser\":37,\"../utils/domUtils\":39,\"../utils/extend\":41,\"../utils/is\":46,\"./base\":31}],34:[function(require,module,exports){\n'use strict';\n\nvar utils = require('./utils');\nvar events = require('./utils/events');\nvar signals = require('./utils/Signals').new();\n\nvar scope = {\n signals: signals,\n events: events,\n utils: utils,\n\n // main document\n document: require('./utils/domObjects').document,\n // all documents being listened to\n documents: [],\n\n addDocument: function addDocument(doc, win) {\n // do nothing if document is already known\n if (utils.contains(scope.documents, doc)) {\n return false;\n }\n\n win = win || scope.getWindow(doc);\n\n scope.documents.push(doc);\n events.documents.push(doc);\n\n // don't add an unload event for the main document\n // so that the page may be cached in browser history\n if (doc !== scope.document) {\n events.add(win, 'unload', scope.onWindowUnload);\n }\n\n signals.fire('add-document', { doc: doc, win: win });\n },\n\n removeDocument: function removeDocument(doc, win) {\n var index = utils.indexOf(scope.documents, doc);\n\n win = win || scope.getWindow(doc);\n\n events.remove(win, 'unload', scope.onWindowUnload);\n\n scope.documents.splice(index, 1);\n events.documents.splice(index, 1);\n\n signals.fire('remove-document', { win: win, doc: doc });\n },\n\n onWindowUnload: function onWindowUnload() {\n scope.removeDocument(this.document, this);\n }\n};\n\nmodule.exports = scope;\n\n},{\"./utils\":44,\"./utils/Signals\":35,\"./utils/domObjects\":38,\"./utils/events\":40}],35:[function(require,module,exports){\n'use strict';\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nvar _require = require('./arr'),\n indexOf = _require.indexOf;\n\nvar Signals = function () {\n function Signals() {\n _classCallCheck(this, Signals);\n\n this.listeners = {\n // signalName: [listeners],\n };\n }\n\n Signals.prototype.on = function on(name, listener) {\n if (!this.listeners[name]) {\n this.listeners[name] = [listener];\n return;\n }\n\n this.listeners[name].push(listener);\n };\n\n Signals.prototype.off = function off(name, listener) {\n if (!this.listeners[name]) {\n return;\n }\n\n var index = indexOf(this.listeners[name], listener);\n\n if (index !== -1) {\n this.listeners[name].splice(index, 1);\n }\n };\n\n Signals.prototype.fire = function fire(name, arg) {\n var targetListeners = this.listeners[name];\n\n if (!targetListeners) {\n return;\n }\n\n for (var i = 0; i < targetListeners.length; i++) {\n if (targetListeners[i](arg, name) === false) {\n return;\n }\n }\n };\n\n return Signals;\n}();\n\nSignals.new = function () {\n return new Signals();\n};\n\nmodule.exports = Signals;\n\n},{\"./arr\":36}],36:[function(require,module,exports){\n\"use strict\";\n\nfunction indexOf(array, target) {\n for (var i = 0, len = array.length; i < len; i++) {\n if (array[i] === target) {\n return i;\n }\n }\n\n return -1;\n}\n\nfunction contains(array, target) {\n return indexOf(array, target) !== -1;\n}\n\nfunction merge(target, source) {\n for (var i = 0; i < source.length; i++) {\n target.push(source[i]);\n }\n\n return target;\n}\n\nfunction filter(array, test) {\n var result = [];\n\n for (var i = 0; i < array.length; i++) {\n if (test(array[i])) {\n result.push(array[i]);\n }\n }\n\n return result;\n}\n\nmodule.exports = {\n indexOf: indexOf,\n contains: contains,\n merge: merge,\n filter: filter\n};\n\n},{}],37:[function(require,module,exports){\n'use strict';\n\nvar _require = require('./window'),\n window = _require.window;\n\nvar is = require('./is');\nvar domObjects = require('./domObjects');\n\nvar Element = domObjects.Element;\nvar navigator = window.navigator;\n\nvar browser = {\n // Does the browser support touch input?\n supportsTouch: !!('ontouchstart' in window || is.function(window.DocumentTouch) && domObjects.document instanceof window.DocumentTouch),\n\n // Does the browser support PointerEvents\n supportsPointerEvent: !!domObjects.PointerEvent,\n\n isIE8: 'attachEvent' in window && !('addEventListener' in window),\n\n // Opera Mobile must be handled differently\n isOperaMobile: navigator.appName === 'Opera' && browser.supportsTouch && navigator.userAgent.match('Presto'),\n\n // scrolling doesn't change the result of getClientRects on iOS 7\n isIOS7: /iP(hone|od|ad)/.test(navigator.platform) && /OS 7[^\\d]/.test(navigator.appVersion),\n\n isIe9OrOlder: /MSIE (8|9)/.test(navigator.userAgent),\n\n // prefix matchesSelector\n prefixedMatchesSelector: 'matches' in Element.prototype ? 'matches' : 'webkitMatchesSelector' in Element.prototype ? 'webkitMatchesSelector' : 'mozMatchesSelector' in Element.prototype ? 'mozMatchesSelector' : 'oMatchesSelector' in Element.prototype ? 'oMatchesSelector' : 'msMatchesSelector',\n\n useMatchesSelectorPolyfill: false,\n\n pEventTypes: domObjects.PointerEvent ? domObjects.PointerEvent === window.MSPointerEvent ? {\n up: 'MSPointerUp',\n down: 'MSPointerDown',\n over: 'mouseover',\n out: 'mouseout',\n move: 'MSPointerMove',\n cancel: 'MSPointerCancel'\n } : {\n up: 'pointerup',\n down: 'pointerdown',\n over: 'pointerover',\n out: 'pointerout',\n move: 'pointermove',\n cancel: 'pointercancel'\n } : null,\n\n // because Webkit and Opera still use 'mousewheel' event type\n wheelEvent: 'onmousewheel' in domObjects.document ? 'mousewheel' : 'wheel'\n\n};\n\nbrowser.useMatchesSelectorPolyfill = !is.function(Element.prototype[browser.prefixedMatchesSelector]);\n\nmodule.exports = browser;\n\n},{\"./domObjects\":38,\"./is\":46,\"./window\":52}],38:[function(require,module,exports){\n'use strict';\n\nvar domObjects = {};\nvar win = require('./window').window;\n\nfunction blank() {}\n\ndomObjects.document = win.document;\ndomObjects.DocumentFragment = win.DocumentFragment || blank;\ndomObjects.SVGElement = win.SVGElement || blank;\ndomObjects.SVGSVGElement = win.SVGSVGElement || blank;\ndomObjects.SVGElementInstance = win.SVGElementInstance || blank;\ndomObjects.Element = win.Element || blank;\ndomObjects.HTMLElement = win.HTMLElement || domObjects.Element;\n\ndomObjects.Event = win.Event;\ndomObjects.Touch = win.Touch || blank;\ndomObjects.PointerEvent = win.PointerEvent || win.MSPointerEvent;\n\nmodule.exports = domObjects;\n\n},{\"./window\":52}],39:[function(require,module,exports){\n'use strict';\n\nvar win = require('./window');\nvar browser = require('./browser');\nvar is = require('./is');\nvar domObjects = require('./domObjects');\n\nvar domUtils = {\n nodeContains: function nodeContains(parent, child) {\n while (child) {\n if (child === parent) {\n return true;\n }\n\n child = child.parentNode;\n }\n\n return false;\n },\n\n closest: function closest(element, selector) {\n while (is.element(element)) {\n if (domUtils.matchesSelector(element, selector)) {\n return element;\n }\n\n element = domUtils.parentNode(element);\n }\n\n return null;\n },\n\n parentNode: function parentNode(node) {\n var parent = node.parentNode;\n\n if (is.docFrag(parent)) {\n // skip past #shado-root fragments\n while ((parent = parent.host) && is.docFrag(parent)) {\n continue;\n }\n\n return parent;\n }\n\n return parent;\n },\n\n // taken from http://tanalin.com/en/blog/2012/12/matches-selector-ie8/ and modified\n matchesSelectorPolyfill: browser.useMatchesSelectorPolyfill ? function (element, selector, elems) {\n elems = elems || element.parentNode.querySelectorAll(selector);\n\n for (var i = 0, len = elems.length; i < len; i++) {\n if (elems[i] === element) {\n return true;\n }\n }\n\n return false;\n } : null,\n\n matchesSelector: function matchesSelector(element, selector, nodeList) {\n if (browser.useMatchesSelectorPolyfill) {\n return domUtils.matchesSelectorPolyfill(element, selector, nodeList);\n }\n\n // remove /deep/ from selectors if shadowDOM polyfill is used\n if (win.window !== win.realWindow) {\n selector = selector.replace(/\\/deep\\//g, ' ');\n }\n\n return element[browser.prefixedMatchesSelector](selector);\n },\n\n // Test for the element that's \"above\" all other qualifiers\n indexOfDeepestElement: function indexOfDeepestElement(elements) {\n var deepestZoneParents = [];\n var dropzoneParents = [];\n var dropzone = void 0;\n var deepestZone = elements[0];\n var index = deepestZone ? 0 : -1;\n var parent = void 0;\n var child = void 0;\n var i = void 0;\n var n = void 0;\n\n for (i = 1; i < elements.length; i++) {\n dropzone = elements[i];\n\n // an element might belong to multiple selector dropzones\n if (!dropzone || dropzone === deepestZone) {\n continue;\n }\n\n if (!deepestZone) {\n deepestZone = dropzone;\n index = i;\n continue;\n }\n\n // check if the deepest or current are document.documentElement or document.rootElement\n // - if the current dropzone is, do nothing and continue\n if (dropzone.parentNode === dropzone.ownerDocument) {\n continue;\n }\n // - if deepest is, update with the current dropzone and continue to next\n else if (deepestZone.parentNode === dropzone.ownerDocument) {\n deepestZone = dropzone;\n index = i;\n continue;\n }\n\n if (!deepestZoneParents.length) {\n parent = deepestZone;\n while (parent.parentNode && parent.parentNode !== parent.ownerDocument) {\n deepestZoneParents.unshift(parent);\n parent = parent.parentNode;\n }\n }\n\n // if this element is an svg element and the current deepest is\n // an HTMLElement\n if (deepestZone instanceof domObjects.HTMLElement && dropzone instanceof domObjects.SVGElement && !(dropzone instanceof domObjects.SVGSVGElement)) {\n\n if (dropzone === deepestZone.parentNode) {\n continue;\n }\n\n parent = dropzone.ownerSVGElement;\n } else {\n parent = dropzone;\n }\n\n dropzoneParents = [];\n\n while (parent.parentNode !== parent.ownerDocument) {\n dropzoneParents.unshift(parent);\n parent = parent.parentNode;\n }\n\n n = 0;\n\n // get (position of last common ancestor) + 1\n while (dropzoneParents[n] && dropzoneParents[n] === deepestZoneParents[n]) {\n n++;\n }\n\n var parents = [dropzoneParents[n - 1], dropzoneParents[n], deepestZoneParents[n]];\n\n child = parents[0].lastChild;\n\n while (child) {\n if (child === parents[1]) {\n deepestZone = dropzone;\n index = i;\n deepestZoneParents = [];\n\n break;\n } else if (child === parents[2]) {\n break;\n }\n\n child = child.previousSibling;\n }\n }\n\n return index;\n },\n\n matchesUpTo: function matchesUpTo(element, selector, limit) {\n while (is.element(element)) {\n if (domUtils.matchesSelector(element, selector)) {\n return true;\n }\n\n element = domUtils.parentNode(element);\n\n if (element === limit) {\n return domUtils.matchesSelector(element, selector);\n }\n }\n\n return false;\n },\n\n getActualElement: function getActualElement(element) {\n return element instanceof domObjects.SVGElementInstance ? element.correspondingUseElement : element;\n },\n\n getScrollXY: function getScrollXY(relevantWindow) {\n relevantWindow = relevantWindow || win.window;\n return {\n x: relevantWindow.scrollX || relevantWindow.document.documentElement.scrollLeft,\n y: relevantWindow.scrollY || relevantWindow.document.documentElement.scrollTop\n };\n },\n\n getElementClientRect: function getElementClientRect(element) {\n var clientRect = element instanceof domObjects.SVGElement ? element.getBoundingClientRect() : element.getClientRects()[0];\n\n return clientRect && {\n left: clientRect.left,\n right: clientRect.right,\n top: clientRect.top,\n bottom: clientRect.bottom,\n width: clientRect.width || clientRect.right - clientRect.left,\n height: clientRect.height || clientRect.bottom - clientRect.top\n };\n },\n\n getElementRect: function getElementRect(element) {\n var clientRect = domUtils.getElementClientRect(element);\n\n if (!browser.isIOS7 && clientRect) {\n var scroll = domUtils.getScrollXY(win.getWindow(element));\n\n clientRect.left += scroll.x;\n clientRect.right += scroll.x;\n clientRect.top += scroll.y;\n clientRect.bottom += scroll.y;\n }\n\n return clientRect;\n },\n\n getPath: function getPath(element) {\n var path = [];\n\n while (element) {\n path.push(element);\n element = domUtils.parentNode(element);\n }\n\n return path;\n },\n\n trySelector: function trySelector(value) {\n if (!is.string(value)) {\n return false;\n }\n\n // an exception will be raised if it is invalid\n domObjects.document.querySelector(value);\n return true;\n }\n};\n\nmodule.exports = domUtils;\n\n},{\"./browser\":37,\"./domObjects\":38,\"./is\":46,\"./window\":52}],40:[function(require,module,exports){\n'use strict';\n\nvar is = require('./is');\nvar domUtils = require('./domUtils');\nvar pExtend = require('./pointerExtend');\n\nvar _require = require('./window'),\n window = _require.window,\n getWindow = _require.getWindow;\n\nvar _require2 = require('./arr'),\n indexOf = _require2.indexOf,\n contains = _require2.contains;\n\nvar useAttachEvent = 'attachEvent' in window && !('addEventListener' in window);\nvar addEvent = useAttachEvent ? 'attachEvent' : 'addEventListener';\nvar removeEvent = useAttachEvent ? 'detachEvent' : 'removeEventListener';\nvar on = useAttachEvent ? 'on' : '';\n\nvar elements = [];\nvar targets = [];\nvar attachedListeners = [];\n\n// {\n// type: {\n// selectors: ['selector', ...],\n// contexts : [document, ...],\n// listeners: [[listener, capture, passive], ...]\n// }\n// }\nvar delegatedEvents = {};\n\nvar documents = [];\n\nvar supportsOptions = !useAttachEvent && function () {\n var supported = false;\n\n window.document.createElement('div').addEventListener('test', null, {\n get capture() {\n supported = true;\n }\n });\n\n return supported;\n}();\n\nfunction add(element, type, listener, optionalArg) {\n var options = getOptions(optionalArg);\n var elementIndex = indexOf(elements, element);\n var target = targets[elementIndex];\n\n if (!target) {\n target = {\n events: {},\n typeCount: 0\n };\n\n elementIndex = elements.push(element) - 1;\n targets.push(target);\n\n attachedListeners.push(useAttachEvent ? {\n supplied: [],\n wrapped: [],\n useCount: []\n } : null);\n }\n\n if (!target.events[type]) {\n target.events[type] = [];\n target.typeCount++;\n }\n\n if (!contains(target.events[type], listener)) {\n var ret = void 0;\n\n if (useAttachEvent) {\n var _attachedListeners$el = attachedListeners[elementIndex],\n supplied = _attachedListeners$el.supplied,\n wrapped = _attachedListeners$el.wrapped,\n useCount = _attachedListeners$el.useCount;\n\n var listenerIndex = indexOf(supplied, listener);\n\n var wrappedListener = wrapped[listenerIndex] || function (event) {\n if (!event.immediatePropagationStopped) {\n event.target = event.srcElement;\n event.currentTarget = element;\n\n event.preventDefault = event.preventDefault || preventDef;\n event.stopPropagation = event.stopPropagation || stopProp;\n event.stopImmediatePropagation = event.stopImmediatePropagation || stopImmProp;\n\n if (/mouse|click/.test(event.type)) {\n event.pageX = event.clientX + getWindow(element).document.documentElement.scrollLeft;\n event.pageY = event.clientY + getWindow(element).document.documentElement.scrollTop;\n }\n\n listener(event);\n }\n };\n\n ret = element[addEvent](on + type, wrappedListener, !!options.capture);\n\n if (listenerIndex === -1) {\n supplied.push(listener);\n wrapped.push(wrappedListener);\n useCount.push(1);\n } else {\n useCount[listenerIndex]++;\n }\n } else {\n ret = element[addEvent](type, listener, supportsOptions ? options : !!options.capture);\n }\n target.events[type].push(listener);\n\n return ret;\n }\n}\n\nfunction remove(element, type, listener, optionalArg) {\n var options = getOptions(optionalArg);\n var elementIndex = indexOf(elements, element);\n var target = targets[elementIndex];\n\n if (!target || !target.events) {\n return;\n }\n\n var wrappedListener = listener;\n var listeners = void 0;\n var listenerIndex = void 0;\n\n if (useAttachEvent) {\n listeners = attachedListeners[elementIndex];\n listenerIndex = indexOf(listeners.supplied, listener);\n wrappedListener = listeners.wrapped[listenerIndex];\n }\n\n if (type === 'all') {\n for (type in target.events) {\n if (target.events.hasOwnProperty(type)) {\n remove(element, type, 'all');\n }\n }\n return;\n }\n\n if (target.events[type]) {\n var len = target.events[type].length;\n\n if (listener === 'all') {\n for (var i = 0; i < len; i++) {\n remove(element, type, target.events[type][i], options);\n }\n return;\n } else {\n for (var _i = 0; _i < len; _i++) {\n if (target.events[type][_i] === listener) {\n element[removeEvent](on + type, wrappedListener, supportsOptions ? options : !!options.capture);\n target.events[type].splice(_i, 1);\n\n if (useAttachEvent && listeners) {\n listeners.useCount[listenerIndex]--;\n if (listeners.useCount[listenerIndex] === 0) {\n listeners.supplied.splice(listenerIndex, 1);\n listeners.wrapped.splice(listenerIndex, 1);\n listeners.useCount.splice(listenerIndex, 1);\n }\n }\n\n break;\n }\n }\n }\n\n if (target.events[type] && target.events[type].length === 0) {\n target.events[type] = null;\n target.typeCount--;\n }\n }\n\n if (!target.typeCount) {\n targets.splice(elementIndex, 1);\n elements.splice(elementIndex, 1);\n attachedListeners.splice(elementIndex, 1);\n }\n}\n\nfunction addDelegate(selector, context, type, listener, optionalArg) {\n var options = getOptions(optionalArg);\n if (!delegatedEvents[type]) {\n delegatedEvents[type] = {\n selectors: [],\n contexts: [],\n listeners: []\n };\n\n // add delegate listener functions\n for (var i = 0; i < documents.length; i++) {\n add(documents[i], type, delegateListener);\n add(documents[i], type, delegateUseCapture, true);\n }\n }\n\n var delegated = delegatedEvents[type];\n var index = void 0;\n\n for (index = delegated.selectors.length - 1; index >= 0; index--) {\n if (delegated.selectors[index] === selector && delegated.contexts[index] === context) {\n break;\n }\n }\n\n if (index === -1) {\n index = delegated.selectors.length;\n\n delegated.selectors.push(selector);\n delegated.contexts.push(context);\n delegated.listeners.push([]);\n }\n\n // keep listener and capture and passive flags\n delegated.listeners[index].push([listener, !!options.capture, options.passive]);\n}\n\nfunction removeDelegate(selector, context, type, listener, optionalArg) {\n var options = getOptions(optionalArg);\n var delegated = delegatedEvents[type];\n var matchFound = false;\n var index = void 0;\n\n if (!delegated) {\n return;\n }\n\n // count from last index of delegated to 0\n for (index = delegated.selectors.length - 1; index >= 0; index--) {\n // look for matching selector and context Node\n if (delegated.selectors[index] === selector && delegated.contexts[index] === context) {\n\n var listeners = delegated.listeners[index];\n\n // each item of the listeners array is an array: [function, capture, passive]\n for (var i = listeners.length - 1; i >= 0; i--) {\n var _listeners$i = listeners[i],\n fn = _listeners$i[0],\n capture = _listeners$i[1],\n passive = _listeners$i[2];\n\n // check if the listener functions and capture and passive flags match\n\n if (fn === listener && capture === !!options.capture && passive === options.passive) {\n // remove the listener from the array of listeners\n listeners.splice(i, 1);\n\n // if all listeners for this interactable have been removed\n // remove the interactable from the delegated arrays\n if (!listeners.length) {\n delegated.selectors.splice(index, 1);\n delegated.contexts.splice(index, 1);\n delegated.listeners.splice(index, 1);\n\n // remove delegate function from context\n remove(context, type, delegateListener);\n remove(context, type, delegateUseCapture, true);\n\n // remove the arrays if they are empty\n if (!delegated.selectors.length) {\n delegatedEvents[type] = null;\n }\n }\n\n // only remove one listener\n matchFound = true;\n break;\n }\n }\n\n if (matchFound) {\n break;\n }\n }\n }\n}\n\n// bound to the interactable context when a DOM event\n// listener is added to a selector interactable\nfunction delegateListener(event, optionalArg) {\n var options = getOptions(optionalArg);\n var fakeEvent = {};\n var delegated = delegatedEvents[event.type];\n var eventTarget = domUtils.getActualElement(event.path ? event.path[0] : event.target);\n var element = eventTarget;\n\n // duplicate the event so that currentTarget can be changed\n pExtend(fakeEvent, event);\n\n fakeEvent.originalEvent = event;\n fakeEvent.preventDefault = preventOriginalDefault;\n\n // climb up document tree looking for selector matches\n while (is.element(element)) {\n for (var i = 0; i < delegated.selectors.length; i++) {\n var selector = delegated.selectors[i];\n var context = delegated.contexts[i];\n\n if (domUtils.matchesSelector(element, selector) && domUtils.nodeContains(context, eventTarget) && domUtils.nodeContains(context, element)) {\n\n var listeners = delegated.listeners[i];\n\n fakeEvent.currentTarget = element;\n\n for (var j = 0; j < listeners.length; j++) {\n var _listeners$j = listeners[j],\n fn = _listeners$j[0],\n capture = _listeners$j[1],\n passive = _listeners$j[2];\n\n\n if (capture === !!options.capture && passive === options.passive) {\n fn(fakeEvent);\n }\n }\n }\n }\n\n element = domUtils.parentNode(element);\n }\n}\n\nfunction delegateUseCapture(event) {\n return delegateListener.call(this, event, true);\n}\n\nfunction preventDef() {\n this.returnValue = false;\n}\n\nfunction preventOriginalDefault() {\n this.originalEvent.preventDefault();\n}\n\nfunction stopProp() {\n this.cancelBubble = true;\n}\n\nfunction stopImmProp() {\n this.cancelBubble = true;\n this.immediatePropagationStopped = true;\n}\n\nfunction getOptions(param) {\n return is.object(param) ? param : { capture: param };\n}\n\nmodule.exports = {\n add: add,\n remove: remove,\n\n addDelegate: addDelegate,\n removeDelegate: removeDelegate,\n\n delegateListener: delegateListener,\n delegateUseCapture: delegateUseCapture,\n delegatedEvents: delegatedEvents,\n documents: documents,\n\n useAttachEvent: useAttachEvent,\n supportsOptions: supportsOptions,\n\n _elements: elements,\n _targets: targets,\n _attachedListeners: attachedListeners\n};\n\n},{\"./arr\":36,\"./domUtils\":39,\"./is\":46,\"./pointerExtend\":48,\"./window\":52}],41:[function(require,module,exports){\n\"use strict\";\n\nmodule.exports = function extend(dest, source) {\n for (var prop in source) {\n dest[prop] = source[prop];\n }\n return dest;\n};\n\n},{}],42:[function(require,module,exports){\n'use strict';\n\nvar _require = require('./rect'),\n resolveRectLike = _require.resolveRectLike,\n rectToXY = _require.rectToXY;\n\nmodule.exports = function (target, element, action) {\n var actionOptions = target.options[action];\n var actionOrigin = actionOptions && actionOptions.origin;\n var origin = actionOrigin || target.options.origin;\n\n var originRect = resolveRectLike(origin, target, element, [target && element]);\n\n return rectToXY(originRect) || { x: 0, y: 0 };\n};\n\n},{\"./rect\":51}],43:[function(require,module,exports){\n\"use strict\";\n\nmodule.exports = function (x, y) {\n return Math.sqrt(x * x + y * y);\n};\n\n},{}],44:[function(require,module,exports){\n'use strict';\n\nvar extend = require('./extend');\nvar win = require('./window');\n\nvar utils = {\n warnOnce: function warnOnce(method, message) {\n var warned = false;\n\n return function () {\n if (!warned) {\n win.window.console.warn(message);\n warned = true;\n }\n\n return method.apply(this, arguments);\n };\n },\n\n // http://stackoverflow.com/a/5634528/2280888\n _getQBezierValue: function _getQBezierValue(t, p1, p2, p3) {\n var iT = 1 - t;\n return iT * iT * p1 + 2 * iT * t * p2 + t * t * p3;\n },\n\n getQuadraticCurvePoint: function getQuadraticCurvePoint(startX, startY, cpX, cpY, endX, endY, position) {\n return {\n x: utils._getQBezierValue(position, startX, cpX, endX),\n y: utils._getQBezierValue(position, startY, cpY, endY)\n };\n },\n\n // http://gizma.com/easing/\n easeOutQuad: function easeOutQuad(t, b, c, d) {\n t /= d;\n return -c * t * (t - 2) + b;\n },\n\n copyAction: function copyAction(dest, src) {\n dest.name = src.name;\n dest.axis = src.axis;\n dest.edges = src.edges;\n\n return dest;\n },\n\n is: require('./is'),\n extend: extend,\n hypot: require('./hypot'),\n getOriginXY: require('./getOriginXY')\n};\n\nextend(utils, require('./arr'));\nextend(utils, require('./domUtils'));\nextend(utils, require('./pointerUtils'));\nextend(utils, require('./rect'));\n\nmodule.exports = utils;\n\n},{\"./arr\":36,\"./domUtils\":39,\"./extend\":41,\"./getOriginXY\":42,\"./hypot\":43,\"./is\":46,\"./pointerUtils\":49,\"./rect\":51,\"./window\":52}],45:[function(require,module,exports){\n'use strict';\n\nvar scope = require('../scope');\nvar utils = require('./index');\n\nvar finder = {\n methodOrder: ['simulationResume', 'mouseOrPen', 'hasPointer', 'idle'],\n\n search: function search(pointer, eventType, eventTarget) {\n var pointerType = utils.getPointerType(pointer);\n var pointerId = utils.getPointerId(pointer);\n var details = { pointer: pointer, pointerId: pointerId, pointerType: pointerType, eventType: eventType, eventTarget: eventTarget };\n\n for (var _iterator = finder.methodOrder, _isArray = Array.isArray(_iterator), _i = 0, _iterator = _isArray ? _iterator : _iterator[Symbol.iterator]();;) {\n var _ref;\n\n if (_isArray) {\n if (_i >= _iterator.length) break;\n _ref = _iterator[_i++];\n } else {\n _i = _iterator.next();\n if (_i.done) break;\n _ref = _i.value;\n }\n\n var method = _ref;\n\n var interaction = finder[method](details);\n\n if (interaction) {\n return interaction;\n }\n }\n },\n\n // try to resume simulation with a new pointer\n simulationResume: function simulationResume(_ref2) {\n var pointerType = _ref2.pointerType,\n eventType = _ref2.eventType,\n eventTarget = _ref2.eventTarget;\n\n if (!/down|start/i.test(eventType)) {\n return null;\n }\n\n for (var _iterator2 = scope.interactions, _isArray2 = Array.isArray(_iterator2), _i2 = 0, _iterator2 = _isArray2 ? _iterator2 : _iterator2[Symbol.iterator]();;) {\n var _ref3;\n\n if (_isArray2) {\n if (_i2 >= _iterator2.length) break;\n _ref3 = _iterator2[_i2++];\n } else {\n _i2 = _iterator2.next();\n if (_i2.done) break;\n _ref3 = _i2.value;\n }\n\n var interaction = _ref3;\n\n var element = eventTarget;\n\n if (interaction.simulation && interaction.simulation.allowResume && interaction.pointerType === pointerType) {\n while (element) {\n // if the element is the interaction element\n if (element === interaction.element) {\n return interaction;\n }\n element = utils.parentNode(element);\n }\n }\n }\n\n return null;\n },\n\n // if it's a mouse or pen interaction\n mouseOrPen: function mouseOrPen(_ref4) {\n var pointerId = _ref4.pointerId,\n pointerType = _ref4.pointerType,\n eventType = _ref4.eventType;\n\n if (pointerType !== 'mouse' && pointerType !== 'pen') {\n return null;\n }\n\n var firstNonActive = void 0;\n\n for (var _iterator3 = scope.interactions, _isArray3 = Array.isArray(_iterator3), _i3 = 0, _iterator3 = _isArray3 ? _iterator3 : _iterator3[Symbol.iterator]();;) {\n var _ref5;\n\n if (_isArray3) {\n if (_i3 >= _iterator3.length) break;\n _ref5 = _iterator3[_i3++];\n } else {\n _i3 = _iterator3.next();\n if (_i3.done) break;\n _ref5 = _i3.value;\n }\n\n var interaction = _ref5;\n\n if (interaction.pointerType === pointerType) {\n // if it's a down event, skip interactions with running simulations\n if (interaction.simulation && !utils.contains(interaction.pointerIds, pointerId)) {\n continue;\n }\n\n // if the interaction is active, return it immediately\n if (interaction.interacting()) {\n return interaction;\n }\n // otherwise save it and look for another active interaction\n else if (!firstNonActive) {\n firstNonActive = interaction;\n }\n }\n }\n\n // if no active mouse interaction was found use the first inactive mouse\n // interaction\n if (firstNonActive) {\n return firstNonActive;\n }\n\n // find any mouse or pen interaction.\n // ignore the interaction if the eventType is a *down, and a simulation\n // is active\n for (var _iterator4 = scope.interactions, _isArray4 = Array.isArray(_iterator4), _i4 = 0, _iterator4 = _isArray4 ? _iterator4 : _iterator4[Symbol.iterator]();;) {\n var _ref6;\n\n if (_isArray4) {\n if (_i4 >= _iterator4.length) break;\n _ref6 = _iterator4[_i4++];\n } else {\n _i4 = _iterator4.next();\n if (_i4.done) break;\n _ref6 = _i4.value;\n }\n\n var _interaction = _ref6;\n\n if (_interaction.pointerType === pointerType && !(/down/i.test(eventType) && _interaction.simulation)) {\n return _interaction;\n }\n }\n\n return null;\n },\n\n // get interaction that has this pointer\n hasPointer: function hasPointer(_ref7) {\n var pointerId = _ref7.pointerId;\n\n for (var _iterator5 = scope.interactions, _isArray5 = Array.isArray(_iterator5), _i5 = 0, _iterator5 = _isArray5 ? _iterator5 : _iterator5[Symbol.iterator]();;) {\n var _ref8;\n\n if (_isArray5) {\n if (_i5 >= _iterator5.length) break;\n _ref8 = _iterator5[_i5++];\n } else {\n _i5 = _iterator5.next();\n if (_i5.done) break;\n _ref8 = _i5.value;\n }\n\n var interaction = _ref8;\n\n if (utils.contains(interaction.pointerIds, pointerId)) {\n return interaction;\n }\n }\n },\n\n // get first idle interaction with a matching pointerType\n idle: function idle(_ref9) {\n var pointerType = _ref9.pointerType;\n\n for (var _iterator6 = scope.interactions, _isArray6 = Array.isArray(_iterator6), _i6 = 0, _iterator6 = _isArray6 ? _iterator6 : _iterator6[Symbol.iterator]();;) {\n var _ref10;\n\n if (_isArray6) {\n if (_i6 >= _iterator6.length) break;\n _ref10 = _iterator6[_i6++];\n } else {\n _i6 = _iterator6.next();\n if (_i6.done) break;\n _ref10 = _i6.value;\n }\n\n var interaction = _ref10;\n\n // if there's already a pointer held down\n if (interaction.pointerIds.length === 1) {\n var target = interaction.target;\n // don't add this pointer if there is a target interactable and it\n // isn't gesturable\n if (target && !target.options.gesture.enabled) {\n continue;\n }\n }\n // maximum of 2 pointers per interaction\n else if (interaction.pointerIds.length >= 2) {\n continue;\n }\n\n if (!interaction.interacting() && pointerType === interaction.pointerType) {\n return interaction;\n }\n }\n\n return null;\n }\n};\n\nmodule.exports = finder;\n\n},{\"../scope\":34,\"./index\":44}],46:[function(require,module,exports){\n'use strict';\n\nvar _typeof = typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; };\n\nvar win = require('./window');\nvar isWindow = require('./isWindow');\n\nvar is = {\n array: function array() {},\n\n window: function window(thing) {\n return thing === win.window || isWindow(thing);\n },\n\n docFrag: function docFrag(thing) {\n return is.object(thing) && thing.nodeType === 11;\n },\n\n object: function object(thing) {\n return !!thing && (typeof thing === 'undefined' ? 'undefined' : _typeof(thing)) === 'object';\n },\n\n function: function _function(thing) {\n return typeof thing === 'function';\n },\n\n number: function number(thing) {\n return typeof thing === 'number';\n },\n\n bool: function bool(thing) {\n return typeof thing === 'boolean';\n },\n\n string: function string(thing) {\n return typeof thing === 'string';\n },\n\n element: function element(thing) {\n if (!thing || (typeof thing === 'undefined' ? 'undefined' : _typeof(thing)) !== 'object') {\n return false;\n }\n\n var _window = win.getWindow(thing) || win.window;\n\n return (/object|function/.test(_typeof(_window.Element)) ? thing instanceof _window.Element //DOM2\n : thing.nodeType === 1 && typeof thing.nodeName === 'string'\n );\n }\n};\n\nis.array = function (thing) {\n return is.object(thing) && typeof thing.length !== 'undefined' && is.function(thing.splice);\n};\n\nmodule.exports = is;\n\n},{\"./isWindow\":47,\"./window\":52}],47:[function(require,module,exports){\n\"use strict\";\n\nmodule.exports = function (thing) {\n return !!(thing && thing.Window) && thing instanceof thing.Window;\n};\n\n},{}],48:[function(require,module,exports){\n'use strict';\n\nfunction pointerExtend(dest, source) {\n for (var prop in source) {\n var prefixedPropREs = module.exports.prefixedPropREs;\n var deprecated = false;\n\n // skip deprecated prefixed properties\n for (var vendor in prefixedPropREs) {\n if (prop.indexOf(vendor) === 0 && prefixedPropREs[vendor].test(prop)) {\n deprecated = true;\n break;\n }\n }\n\n if (!deprecated && typeof source[prop] !== 'function') {\n dest[prop] = source[prop];\n }\n }\n return dest;\n}\n\npointerExtend.prefixedPropREs = {\n webkit: /(Movement[XY]|Radius[XY]|RotationAngle|Force)$/\n};\n\nmodule.exports = pointerExtend;\n\n},{}],49:[function(require,module,exports){\n'use strict';\n\nvar hypot = require('./hypot');\nvar browser = require('./browser');\nvar dom = require('./domObjects');\nvar domUtils = require('./domUtils');\nvar domObjects = require('./domObjects');\nvar is = require('./is');\nvar pointerExtend = require('./pointerExtend');\n\nvar pointerUtils = {\n copyCoords: function copyCoords(dest, src) {\n dest.page = dest.page || {};\n dest.page.x = src.page.x;\n dest.page.y = src.page.y;\n\n dest.client = dest.client || {};\n dest.client.x = src.client.x;\n dest.client.y = src.client.y;\n\n dest.timeStamp = src.timeStamp;\n },\n\n setCoordDeltas: function setCoordDeltas(targetObj, prev, cur) {\n targetObj.page.x = cur.page.x - prev.page.x;\n targetObj.page.y = cur.page.y - prev.page.y;\n targetObj.client.x = cur.client.x - prev.client.x;\n targetObj.client.y = cur.client.y - prev.client.y;\n targetObj.timeStamp = cur.timeStamp - prev.timeStamp;\n\n // set pointer velocity\n var dt = Math.max(targetObj.timeStamp / 1000, 0.001);\n\n targetObj.page.speed = hypot(targetObj.page.x, targetObj.page.y) / dt;\n targetObj.page.vx = targetObj.page.x / dt;\n targetObj.page.vy = targetObj.page.y / dt;\n\n targetObj.client.speed = hypot(targetObj.client.x, targetObj.page.y) / dt;\n targetObj.client.vx = targetObj.client.x / dt;\n targetObj.client.vy = targetObj.client.y / dt;\n },\n\n isNativePointer: function isNativePointer(pointer) {\n return pointer instanceof dom.Event || pointer instanceof dom.Touch;\n },\n\n // Get specified X/Y coords for mouse or event.touches[0]\n getXY: function getXY(type, pointer, xy) {\n xy = xy || {};\n type = type || 'page';\n\n xy.x = pointer[type + 'X'];\n xy.y = pointer[type + 'Y'];\n\n return xy;\n },\n\n getPageXY: function getPageXY(pointer, page) {\n page = page || {};\n\n // Opera Mobile handles the viewport and scrolling oddly\n if (browser.isOperaMobile && pointerUtils.isNativePointer(pointer)) {\n pointerUtils.getXY('screen', pointer, page);\n\n page.x += window.scrollX;\n page.y += window.scrollY;\n } else {\n pointerUtils.getXY('page', pointer, page);\n }\n\n return page;\n },\n\n getClientXY: function getClientXY(pointer, client) {\n client = client || {};\n\n if (browser.isOperaMobile && pointerUtils.isNativePointer(pointer)) {\n // Opera Mobile handles the viewport and scrolling oddly\n pointerUtils.getXY('screen', pointer, client);\n } else {\n pointerUtils.getXY('client', pointer, client);\n }\n\n return client;\n },\n\n getPointerId: function getPointerId(pointer) {\n return is.number(pointer.pointerId) ? pointer.pointerId : pointer.identifier;\n },\n\n setCoords: function setCoords(targetObj, pointers, timeStamp) {\n var pointer = pointers.length > 1 ? pointerUtils.pointerAverage(pointers) : pointers[0];\n\n var tmpXY = {};\n\n pointerUtils.getPageXY(pointer, tmpXY);\n targetObj.page.x = tmpXY.x;\n targetObj.page.y = tmpXY.y;\n\n pointerUtils.getClientXY(pointer, tmpXY);\n targetObj.client.x = tmpXY.x;\n targetObj.client.y = tmpXY.y;\n\n targetObj.timeStamp = is.number(timeStamp) ? timeStamp : new Date().getTime();\n },\n\n pointerExtend: pointerExtend,\n\n getTouchPair: function getTouchPair(event) {\n var touches = [];\n\n // array of touches is supplied\n if (is.array(event)) {\n touches[0] = event[0];\n touches[1] = event[1];\n }\n // an event\n else {\n if (event.type === 'touchend') {\n if (event.touches.length === 1) {\n touches[0] = event.touches[0];\n touches[1] = event.changedTouches[0];\n } else if (event.touches.length === 0) {\n touches[0] = event.changedTouches[0];\n touches[1] = event.changedTouches[1];\n }\n } else {\n touches[0] = event.touches[0];\n touches[1] = event.touches[1];\n }\n }\n\n return touches;\n },\n\n pointerAverage: function pointerAverage(pointers) {\n var average = {\n pageX: 0,\n pageY: 0,\n clientX: 0,\n clientY: 0,\n screenX: 0,\n screenY: 0\n };\n\n for (var _iterator = pointers, _isArray = Array.isArray(_iterator), _i = 0, _iterator = _isArray ? _iterator : _iterator[Symbol.iterator]();;) {\n var _ref;\n\n if (_isArray) {\n if (_i >= _iterator.length) break;\n _ref = _iterator[_i++];\n } else {\n _i = _iterator.next();\n if (_i.done) break;\n _ref = _i.value;\n }\n\n var pointer = _ref;\n\n for (var _prop in average) {\n average[_prop] += pointer[_prop];\n }\n }\n for (var prop in average) {\n average[prop] /= pointers.length;\n }\n\n return average;\n },\n\n touchBBox: function touchBBox(event) {\n if (!event.length && !(event.touches && event.touches.length > 1)) {\n return;\n }\n\n var touches = pointerUtils.getTouchPair(event);\n var minX = Math.min(touches[0].pageX, touches[1].pageX);\n var minY = Math.min(touches[0].pageY, touches[1].pageY);\n var maxX = Math.max(touches[0].pageX, touches[1].pageX);\n var maxY = Math.max(touches[0].pageY, touches[1].pageY);\n\n return {\n x: minX,\n y: minY,\n left: minX,\n top: minY,\n width: maxX - minX,\n height: maxY - minY\n };\n },\n\n touchDistance: function touchDistance(event, deltaSource) {\n var sourceX = deltaSource + 'X';\n var sourceY = deltaSource + 'Y';\n var touches = pointerUtils.getTouchPair(event);\n\n var dx = touches[0][sourceX] - touches[1][sourceX];\n var dy = touches[0][sourceY] - touches[1][sourceY];\n\n return hypot(dx, dy);\n },\n\n touchAngle: function touchAngle(event, prevAngle, deltaSource) {\n var sourceX = deltaSource + 'X';\n var sourceY = deltaSource + 'Y';\n var touches = pointerUtils.getTouchPair(event);\n var dx = touches[1][sourceX] - touches[0][sourceX];\n var dy = touches[1][sourceY] - touches[0][sourceY];\n var angle = 180 * Math.atan2(dy, dx) / Math.PI;\n\n return angle;\n },\n\n getPointerType: function getPointerType(pointer) {\n return is.string(pointer.pointerType) ? pointer.pointerType : is.number(pointer.pointerType) ? [undefined, undefined, 'touch', 'pen', 'mouse'][pointer.pointerType]\n // if the PointerEvent API isn't available, then the \"pointer\" must\n // be either a MouseEvent, TouchEvent, or Touch object\n : /touch/.test(pointer.type) || pointer instanceof domObjects.Touch ? 'touch' : 'mouse';\n },\n\n // [ event.target, event.currentTarget ]\n getEventTargets: function getEventTargets(event) {\n return [domUtils.getActualElement(event.path ? event.path[0] : event.target), domUtils.getActualElement(event.currentTarget)];\n }\n};\n\nmodule.exports = pointerUtils;\n\n},{\"./browser\":37,\"./domObjects\":38,\"./domUtils\":39,\"./hypot\":43,\"./is\":46,\"./pointerExtend\":48}],50:[function(require,module,exports){\n'use strict';\n\nvar _require = require('./window'),\n window = _require.window;\n\nvar vendors = ['ms', 'moz', 'webkit', 'o'];\nvar lastTime = 0;\nvar request = void 0;\nvar cancel = void 0;\n\nfor (var x = 0; x < vendors.length && !window.requestAnimationFrame; x++) {\n request = window[vendors[x] + 'RequestAnimationFrame'];\n cancel = window[vendors[x] + 'CancelAnimationFrame'] || window[vendors[x] + 'CancelRequestAnimationFrame'];\n}\n\nif (!request) {\n request = function request(callback) {\n var currTime = new Date().getTime();\n var timeToCall = Math.max(0, 16 - (currTime - lastTime));\n var id = setTimeout(function () {\n callback(currTime + timeToCall);\n }, timeToCall);\n\n lastTime = currTime + timeToCall;\n return id;\n };\n}\n\nif (!cancel) {\n cancel = function cancel(id) {\n clearTimeout(id);\n };\n}\n\nmodule.exports = {\n request: request,\n cancel: cancel\n};\n\n},{\"./window\":52}],51:[function(require,module,exports){\n'use strict';\n\nvar extend = require('./extend');\nvar is = require('./is');\n\nvar _require = require('./domUtils'),\n closest = _require.closest,\n parentNode = _require.parentNode,\n getElementRect = _require.getElementRect;\n\nvar rectUtils = {\n getStringOptionResult: function getStringOptionResult(value, interactable, element) {\n if (!is.string(value)) {\n return null;\n }\n\n if (value === 'parent') {\n value = parentNode(element);\n } else if (value === 'self') {\n value = interactable.getRect(element);\n } else {\n value = closest(element, value);\n }\n\n return value;\n },\n\n resolveRectLike: function resolveRectLike(value, interactable, element, functionArgs) {\n value = rectUtils.getStringOptionResult(value, interactable, element) || value;\n\n if (is.function(value)) {\n value = value.apply(null, functionArgs);\n }\n\n if (is.element(value)) {\n value = getElementRect(value);\n }\n\n return value;\n },\n\n rectToXY: function rectToXY(rect) {\n return rect && {\n x: 'x' in rect ? rect.x : rect.left,\n y: 'y' in rect ? rect.y : rect.top\n };\n },\n\n xywhToTlbr: function xywhToTlbr(rect) {\n if (rect && !('left' in rect && 'top' in rect)) {\n rect = extend({}, rect);\n\n rect.left = rect.x || 0;\n rect.top = rect.y || 0;\n rect.right = rect.right || rect.left + rect.width;\n rect.bottom = rect.bottom || rect.top + rect.height;\n }\n\n return rect;\n },\n\n tlbrToXywh: function tlbrToXywh(rect) {\n if (rect && !('x' in rect && 'y' in rect)) {\n rect = extend({}, rect);\n\n rect.x = rect.left || 0;\n rect.top = rect.top || 0;\n rect.width = rect.width || rect.right - rect.x;\n rect.height = rect.height || rect.bottom - rect.y;\n }\n\n return rect;\n }\n};\n\nmodule.exports = rectUtils;\n\n},{\"./domUtils\":39,\"./extend\":41,\"./is\":46}],52:[function(require,module,exports){\n'use strict';\n\nvar win = module.exports;\nvar isWindow = require('./isWindow');\n\nfunction init(window) {\n // get wrapped window if using Shadow DOM polyfill\n\n win.realWindow = window;\n\n // create a TextNode\n var el = window.document.createTextNode('');\n\n // check if it's wrapped by a polyfill\n if (el.ownerDocument !== window.document && typeof window.wrap === 'function' && window.wrap(el) === el) {\n // use wrapped window\n window = window.wrap(window);\n }\n\n win.window = window;\n}\n\nif (typeof window === 'undefined') {\n win.window = undefined;\n win.realWindow = undefined;\n} else {\n init(window);\n}\n\nwin.getWindow = function getWindow(node) {\n if (isWindow(node)) {\n return node;\n }\n\n var rootNode = node.ownerDocument || node;\n\n return rootNode.defaultView || rootNode.parentWindow || win.window;\n};\n\nwin.init = init;\n\n},{\"./isWindow\":47}]},{},[1])(1)\n});\n\n\n//# sourceMappingURL=interact.js.map\n\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack:///./node_modules/interactjs/dist/interact.js?bbfe"],"names":[],"mappings":"YAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa,SAA2D,mBAAmB,gDAAgD,aAAa,KAAK,MAAM,gCAAgC,SAAS,qCAAqC,SAAS,mCAAmC,OAAO,KAAK,OAAO,kBAAkB,aAAa,0BAA0B,0BAA0B,gBAAgB,UAAU,UAAU,0CAA0C,8BAAwB,oBAAoB,8CAA8C,kCAAkC,YAAY,YAAY,mCAAmC,iBAAiB,gBAAgB,sBAAsB,oBAAoB,0CAA0C,YAAY,WAAW,YAAY,SAAS,GAAG;AAC5yB;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,CAAC;AACD;AACA;;AAEA,CAAC,EAAE,yCAAyC;AAC5C;;AAEA,iDAAiD,0CAA0C,0DAA0D,EAAE;;AAEvJ;AACA;;AAEA;;AAEA;AACA,yCAAyC,+CAA+C;AACxF;AACA;AACA;;AAEA;AACA;AACA;;AAEA,4BAA4B,eAAe;AAC3C;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA,CAAC;;AAED;;AAEA,CAAC,EAAE,wCAAwC;AAC3C;;AAEA,iDAAiD,0CAA0C,0DAA0D,EAAE;;AAEvJ;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA,wBAAwB;AACxB,0BAA0B;;AAE1B;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA,CAAC;;AAED;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA,CAAC;;AAED;;AAEA;;AAEA,CAAC,EAAE,wFAAwF;AAC3F;;AAEA,iDAAiD,0CAA0C,0DAA0D,EAAE;;AAEvJ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;;;AAGA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,KAAK;;AAEL;;AAEA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kFAAkF;;AAElF;AACA;AACA;AACA,SAAS;AACT;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AAGA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AAGA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA,wJAAwJ;AACxJ;;AAEA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,uDAAuD,aAAa;AACpE;AACA;AACA;AACA;AACA;;;AAGA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,yFAAyF;AACzF;AACA;;;AAGA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AAGA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AAGA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA,qBAAqB,sBAAsB;AAC3C;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AAGA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AAGA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AAGA;AACA;AACA;AACA;;AAEA,4BAA4B;;AAE5B,8BAA8B;;AAE9B;AACA;;AAEA,0CAA0C;;AAE1C;;AAEA;AACA;;AAEA,6KAA6K;AAC7K;;AAEA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;;AAEA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,KAAK;;AAEL;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AAGA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,KAAK;AACL;AACA;;AAEA,2BAA2B,qBAAqB;;AAEhD;;AAEA;AACA,yKAAyK;AACzK;;AAEA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA,CAAC;;AAED;AACA;;AAEA,iBAAiB,iBAAiB;AAClC;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA,iBAAiB,iBAAiB;AAClC;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;;AAEA;;AAEA,CAAC,EAAE,mOAAmO;AACtO;;AAEA,iDAAiD,0CAA0C,0DAA0D,EAAE;;AAEvJ;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA,uBAAuB;AACvB,wBAAwB;;AAExB,qBAAqB;AACrB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,aAAa,aAAa;AAC1B,eAAe,aAAa;AAC5B;AACA;AACA;AACA;AACA,aAAa,aAAa;AAC1B,eAAe,aAAa;AAC5B;AACA;;AAEA;AACA;AACA,aAAa,aAAa;AAC1B,eAAe,aAAa;AAC5B;AACA;;AAEA;AACA;AACA,aAAa,qCAAqC;AAClD,eAAe,qCAAqC;AACpD;AACA;;AAEA,0BAA0B;AAC1B;;AAEA;AACA;;AAEA,0BAA0B;;AAE1B;AACA;AACA;;AAEA;;AAEA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,6CAA6C,qBAAqB;AAClE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ;AACR;AACA;AACA;AACA;AACA;AACA,8BAA8B,eAAe;AAC7C;AACA;AACA;AACA,MAAM;AACN;;;AAGA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA,KAAK;AACL;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,yCAAyC,QAAQ,eAAe;AAChE;AACA;AACA;AACA,QAAQ;AACR;;;AAGA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK,iBAAiB;;AAEtB;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;;;AAGA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;;AAEL;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ;AACR;;;AAGA;AACA;;AAEA;AACA;AACA;AACA;AACA,OAAO;AACP;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA,0BAA0B,oBAAoB;;AAE9C;AACA,mCAAmC,oBAAoB;AACvD,kDAAkD,oBAAoB;AACtE;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;;AAEA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,KAAK;;AAEL;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA,CAAC;;AAED,yCAAyC,SAAS;AAClD;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA,qBAAqB;;AAErB;AACA;;AAEA,sBAAsB,kCAAkC;AACxD;AACA;;AAEA,+DAA+D,2BAA2B;AAC1F;AACA,KAAK;AACL;;AAEA;AACA;AACA,yBAAyB,oDAAoD;AAC7E;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA,0CAA0C,2BAA2B;AACrE;;AAEA;AACA;AACA;;AAEA,iJAAiJ;AACjJ;;AAEA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA,mBAAmB,iCAAiC;AACpD;;AAEA;AACA,4BAA4B,yCAAyC;AACrE;AACA;;AAEA,iBAAiB;AACjB;;AAEA;AACA;AACA;AACA;AACA;AACA,CAAC;AACD;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA,CAAC;;AAED;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;;AAEA,CAAC,EAAE,+IAA+I;AAClJ;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA,CAAC;;AAED;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA,CAAC;;AAED;AACA;AACA;;AAEA;AACA,CAAC;;AAED;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;;AAEA,CAAC,EAAE,wCAAwC;AAC3C;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,GAAG;;AAEH;AACA;;AAEA,kCAAkC,sGAAsG;AACxI,GAAG;;AAEH;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,CAAC;;AAED;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA,CAAC;;AAED;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,mCAAmC;AACnC,mCAAmC;AACnC,mCAAmC;AACnC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;;AAEA,CAAC,EAAE,4GAA4G;AAC/G;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,CAAC;;AAED;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA,CAAC;;AAED;AACA;;AAEA;AACA;AACA;;AAEA;AACA,CAAC;;AAED;AACA;;AAEA;AACA;AACA;AACA,CAAC;;AAED;AACA;;AAEA;AACA,CAAC;;AAED;AACA;AACA;;AAEA;;AAEA;AACA,0JAA0J;AAC1J;;AAEA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA,mBAAmB,yBAAyB;AAC5C;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA,iBAAiB,8CAA8C;AAC/D;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA,iBAAiB,8CAA8C;AAC/D;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA,iBAAiB,8CAA8C;AAC/D;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,uCAAuC,oBAAoB;;AAE3D;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA,oCAAoC,eAAe;;AAEnD;AACA;AACA;AACA;AACA,wCAAwC,uBAAuB;;AAE/D;AACA;AACA;AACA;AACA,0CAA0C,yBAAyB;;AAEnE;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;;AAEL;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,4CAA4C;AAC5C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA,CAAC;;AAED;;AAEA;AACA,gCAAgC;AAChC,iCAAiC;AACjC,oCAAoC;AACpC,qCAAqC;AACrC,gCAAgC;;AAEhC;AACA;AACA;AACA;AACA;AACA,CAAC;;AAED;AACA;;AAEA;AACA,CAAC;;AAED;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;;AAEA,CAAC,EAAE,2IAA2I;AAC9I;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;AACA,cAAc;AACd;;AAEA;AACA,GAAG;;AAEH;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,CAAC;;AAED;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA,CAAC;;AAED;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,mCAAmC;AACnC,mCAAmC;AACnC,mCAAmC;AACnC;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,CAAC;;AAED;AACA;AACA,YAAY,aAAa;;AAEzB;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA,CAAC;;AAED;AACA;AACA;AACA;;AAEA;;AAEA;;AAEA,CAAC,EAAE,4GAA4G;AAC/G;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;AACA;AACA;;AAEA,8BAA8B;AAC9B;;AAEA;AACA;AACA,yBAAyB;;AAEzB;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,GAAG;;AAEH;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;AACA;AACA,KAAK;AACL;AACA;;AAEA,qBAAqB,OAAO;AAC5B;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,qCAAqC;;AAErC;AACA;AACA;AACA;;AAEA;AACA,GAAG;AACH;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA,4BAA4B;AAC5B,6BAA6B;AAC7B,6BAA6B;AAC7B;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,CAAC;;AAED;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA,KAAK;AACL;AACA,KAAK;AACL;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA,CAAC;;AAED;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,mCAAmC;AACnC,mCAAmC;AACnC,mCAAmC;AACnC;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ;AACR;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,KAAK;AACL;AACA;;AAEA;AACA;AACA,KAAK;AACL;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,CAAC;;AAED;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,GAAG;AACH;;AAEA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,CAAC;;AAED;AACA;AACA;AACA;;AAEA;;AAEA;;AAEA,CAAC,EAAE,kIAAkI;AACrI;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA,GAAG;;AAEH;AACA;AACA;AACA,GAAG;;AAEH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;;AAEA;AACA,GAAG;AACH;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA,CAAC;;AAED;;AAEA;;AAEA;;AAEA,CAAC,EAAE,mHAAmH;AACtH;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,sBAAsB,mDAAmD;AACzE;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,sBAAsB,oDAAoD;AAC1E;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA,GAAG;AACH;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA,GAAG;AACH;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,uBAAuB;AACvB;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA,oJAAoJ;AACpJ;;AAEA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;;AAEA,CAAC,EAAE,gFAAgF;AACnF;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA,CAAC;;AAED;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA,CAAC;;AAED;AACA;AACA;;;AAGA;AACA;AACA;;AAEA;;AAEA;;AAEA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,CAAC;;AAED;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA,uCAAuC,SAAS;AAChD;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA,4BAA4B,2BAA2B;AACvD;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA;AACA,CAAC;;AAED;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,uBAAuB;AACvB;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;;AAEA,oJAAoJ;AACpJ;;AAEA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA,kDAAkD,SAAS;AAC3D;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;;AAEA,CAAC,EAAE,sMAAsM;AACzM;;AAEA;AACA;;AAEA;AACA;AACA,CAAC;;AAED;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA,KAAK;AACL;AACA,CAAC;;AAED;AACA;AACA;;AAEA;AACA;AACA;AACA,CAAC;;AAED;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA,CAAC;;AAED,CAAC,EAAE,+BAA+B;AAClC;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,CAAC;;AAED;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA,CAAC,EAAE,4GAA4G;AAC/G;;AAEA;;AAEA,CAAC,EAAE,mCAAmC;AACtC;;AAEA;;AAEA,CAAC,EAAE,mCAAmC;AACtC;;AAEA;AACA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA,aAAa,aAAa;;AAE1B;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,CAAC,GAAG;AACJ;;AAEA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA,CAAC,EAAE,sgBAAsgB;AACzgB;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA,gBAAgB;;AAEhB;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,CAAC;;AAED;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA,yBAAyB;AACzB;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA,CAAC;;AAED;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA,4BAA4B;AAC5B;;AAEA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;;AAEA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;;AAEA;AACA;;AAEA;;AAEA;;AAEA;AACA;;AAEA;AACA,GAAG;AACH;AACA;AACA;;AAEA;;AAEA;AACA;AACA,CAAC;;AAED;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA,CAAC;;AAED;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;;AAEA;AACA;AACA;AACA,KAAK;AACL;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA,GAAG;AACH;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA,GAAG;AACH;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;;AAEA,CAAC,EAAE,qFAAqF;AACxF;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ;AACR;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,6IAA6I;AAC7I;;AAEA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA,kDAAkD,mBAAmB;AACrE;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,qJAAqJ;AACrJ;;AAEA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA,GAAG;AACH;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,6CAA6C,QAAQ;AACrD;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;;AAEA;;AAEA,CAAC,EAAE,wGAAwG;AAC3G;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AAGA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA,gBAAgB,kBAAkB;AAClC;AACA;AACA;;AAEA;AACA;AACA,0JAA0J;AAC1J;;AAEA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;;AAEA;;;AAGA;;AAEA;AACA;AACA;AACA;AACA;;AAEA,CAAC,EAAE,4GAA4G;AAC/G;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;;AAEA;AACA;AACA,2JAA2J;AAC3J;;AAEA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA,CAAC,EAAE,mIAAmI;AACtI;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;;AAEA;AACA;AACA;;AAEA,mBAAmB,4BAA4B;AAC/C;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA,GAAG;;AAEH;AACA;AACA;AACA;AACA;;AAEA,0BAA0B;AAC1B;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,wJAAwJ;AACxJ;;AAEA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA,GAAG;;AAEH;AACA,gKAAgK;AAChK;;AAEA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;;AAEA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA,GAAG;;AAEH;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA,8BAA8B;AAC9B;AACA;AACA;;AAEA;AACA,6BAA6B;AAC7B;AACA,2DAA2D;AAC3D;AACA,CAAC;;AAED;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;AACA;AACA;AACA;;AAEA;AACA,CAAC;;AAED;AACA;AACA;;AAEA,iBAAiB,4BAA4B;AAC7C;;AAEA;AACA;AACA;AACA,0BAA0B,6BAA6B;AACvD;AACA;AACA;AACA,CAAC;;AAED;AACA;AACA;;AAEA,6BAA6B;;AAE7B,iBAAiB,4BAA4B;AAC7C;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;;AAEA;AACA;AACA,CAAC;;AAED;AACA;AACA;;AAEA;;AAEA,CAAC,EAAE,6DAA6D;AAChE;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA,KAAK;AACL;AACA;;AAEA;AACA,GAAG;;AAEH;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA,qCAAqC,2BAA2B,kBAAkB;;AAElF;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA,GAAG;;AAEH;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;;AAEA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;;AAEA,CAAC,EAAE,kDAAkD;AACrD;;AAEA;AACA;AACA;AACA;AACA,aAAa,wBAAwB;AACrC;AACA,eAAe,+CAA+C;AAC9D,eAAe,+CAA+C;AAC9D,MAAM;AACN,IAAI;;AAEJ;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA,eAAe;AACf,eAAe;;AAEf;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;AACA;AACA;;AAEA;AACA,4BAA4B;AAC5B;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,GAAG;;AAEH;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA,qCAAqC,2BAA2B,kBAAkB;AAClF;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA,GAAG;;AAEH;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;;AAEA,CAAC,EAAE,4GAA4G;AAC/G;;AAEA;AACA;AACA;AACA;AACA,aAAa,wBAAwB;AACrC;AACA,aAAa,4BAA4B;AACzC,aAAa,4BAA4B;AACzC,MAAM;AACN,IAAI;;AAEJ;AACA;AACA;AACA;AACA;AACA;;AAEA,aAAa;AACb,aAAa;;AAEb;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;;AAEA;AACA,GAAG;;AAEH;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,4BAA4B;AAC5B,4BAA4B;AAC5B;;AAEA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;;AAEA;AACA,GAAG;;AAEH;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;;AAEA,CAAC,EAAE,iHAAiH;AACpH;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,GAAG;;AAEH;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;;AAEA,kDAAkD;AAClD;;AAEA;AACA,iKAAiK;AACjK;;AAEA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA,SAAS;AACT;AACA,KAAK;AACL;AACA;;AAEA;AACA,GAAG;;AAEH;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA,cAAc;AACd,KAAK;AACL;;AAEA,4BAA4B;;AAE5B;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA,wJAAwJ;AACxJ;;AAEA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA,kKAAkK;AAClK;;AAEA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA,SAAS;AACT;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA,SAAS;AACT;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,qCAAqC,SAAS;AAC9C;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA,KAAK;AACL;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA,GAAG;;AAEH;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;;AAEA,CAAC,EAAE,mEAAmE;AACtE;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,OAAO;AACP,eAAe,aAAa;AAC5B;AACA;AACA;;AAEA;AACA;;AAEA;AACA,GAAG;;AAEH;AACA;AACA;AACA;AACA;;AAEA,8BAA8B;AAC9B;AACA;;AAEA,iCAAiC;AACjC;;AAEA,wJAAwJ;AACxJ;;AAEA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;;AAEA;;AAEA;;AAEA;AACA;AACA,OAAO;AACP;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA,GAAG;;AAEH;AACA;;;AAGA,iCAAiC;AACjC;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;;AAEA,CAAC,EAAE,sFAAsF;AACzF;;AAEA,iDAAiD,0CAA0C,0DAA0D,EAAE;;AAEvJ;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA,KAAK;AACL;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA,CAAC;;AAED,CAAC,EAAE,2BAA2B;AAC9B;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb,GAAG;AACH;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,iBAAiB,oBAAoB;AACrC;;AAEA,uCAAuC;AACvC;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;;AAEL;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,2IAA2I;AAC3I;;AAEA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;;AAEA;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,KAAK;AACL;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA,0CAA0C;AAC1C,CAAC;;AAED;AACA;AACA;;AAEA;AACA,CAAC;;AAED;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,KAAK;AACL;AACA,CAAC;;AAED;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,iDAAiD;;AAEjD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,mJAAmJ;AACnJ;;AAEA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;;AAEA;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA,iBAAiB,8BAA8B;AAC/C;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL,GAAG;AACH,CAAC;;AAED;AACA;AACA;AACA;AACA;;AAEA;AACA,UAAU,kGAAkG;AAC5G;AACA,CAAC;;AAED;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,GAAG;AACH,CAAC;;AAED;AACA;AACA;AACA;AACA;AACA;;AAEA,UAAU,iGAAiG;AAC3G;AACA;;AAEA,eAAe,0BAA0B;AACzC;AACA;;AAEA;AACA,6BAA6B;AAC7B,0BAA0B;AAC1B,8BAA8B,MAAM,oBAAoB;AACxD,CAAC;;AAED;AACA;;AAEA,CAAC,EAAE,0IAA0I;AAC7I;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA,gBAAgB,kBAAkB;AAClC;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL,GAAG;AACH;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA,CAAC,EAAE,+BAA+B;AAClC;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA;AACA,gBAAgB;AAChB,OAAO;AACP;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,gBAAgB;AAChB,OAAO;AACP;AACA;;AAEA;AACA,CAAC;;AAED;AACA;;AAEA;AACA;AACA;AACA,CAAC;;AAED;AACA;AACA;;AAEA;AACA;AACA,CAAC;;AAED;;AAEA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA,CAAC,EAAE,mJAAmJ;AACtJ;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA,kCAAkC,qBAAqB;AACvD,GAAG;;AAEH;AACA;;AAEA;;AAEA;;AAEA;AACA;;AAEA,qCAAqC,qBAAqB;AAC1D,GAAG;;AAEH;AACA;AACA;AACA;;AAEA;;AAEA,CAAC,EAAE,8EAA8E;AACjF;;AAEA,iDAAiD,0CAA0C,0DAA0D,EAAE;;AAEvJ;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA,mBAAmB,4BAA4B;AAC/C;AACA;AACA;AACA;AACA;;AAEA;AACA,CAAC;;AAED;AACA;AACA;;AAEA;;AAEA,CAAC,EAAE,WAAW;AACd;;AAEA;AACA,qCAAqC,SAAS;AAC9C;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA,iBAAiB,mBAAmB;AACpC;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA,iBAAiB,kBAAkB;AACnC;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA,CAAC,GAAG;AACJ;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;;AAEA;;AAEA;;AAEA;;AAEA,CAAC,EAAE,0CAA0C;AAC7C;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA,CAAC,EAAE,cAAc;AACjB;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA,GAAG;;AAEH;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA,GAAG;;AAEH;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA,GAAG;;AAEH;AACA;AACA;;AAEA,uCAAuC,SAAS;AAChD;AACA;AACA;AACA;;AAEA;AACA,GAAG;;AAEH;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA,GAAG;;AAEH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,eAAe,qBAAqB;AACpC;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA,OAAO;AACP;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA,SAAS;AACT;AACA;;AAEA;AACA;AACA;;AAEA;AACA,GAAG;;AAEH;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA,GAAG;;AAEH;AACA;AACA,GAAG;;AAEH;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA,GAAG;;AAEH;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA,GAAG;;AAEH;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;AAEA,CAAC,EAAE,yDAAyD;AAC5D;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA,CAAC;;AAED;AACA;AACA;AACA;;AAEA;AACA;AACA,gBAAgB;AAChB;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,KAAK;AACL;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA,KAAK;AACL;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA,qBAAqB,SAAS;AAC9B;AACA;AACA;AACA,KAAK;AACL,sBAAsB,UAAU;AAChC;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,mBAAmB,sBAAsB;AACzC;AACA;AACA;AACA;;AAEA;AACA;;AAEA,8CAA8C,YAAY;AAC1D;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA,8CAA8C,YAAY;AAC1D;AACA;;AAEA;;AAEA;AACA,wCAAwC,QAAQ;AAChD;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA,mBAAmB,gCAAgC;AACnD;AACA;;AAEA;;AAEA;;AAEA;;AAEA,uBAAuB,sBAAsB;AAC7C;AACA;AACA;AACA;;;AAGA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA,qCAAqC;AACrC;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA,CAAC,EAAE,wEAAwE;AAC3E;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA,CAAC,GAAG;AACJ;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA,kCAAkC;AAClC;;AAEA,CAAC,EAAE,YAAY;AACf;;AAEA;AACA;AACA;;AAEA,CAAC,GAAG;AACJ;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,GAAG;;AAEH;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;AACA;AACA;;AAEA;AACA,GAAG;;AAEH;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA,CAAC,EAAE,iIAAiI;AACpI;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,mBAAmB;;AAEnB,2JAA2J;AAC3J;;AAEA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;;AAEA;;AAEA;;AAEA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA,mKAAmK;AACnK;;AAEA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;;AAEA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,GAAG;;AAEH;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA,mKAAmK;AACnK;;AAEA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,mKAAmK;AACnK;;AAEA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA,GAAG;;AAEH;AACA;AACA;;AAEA,mKAAmK;AACnK;;AAEA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;AACA;;AAEA,mKAAmK;AACnK;;AAEA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA,CAAC,EAAE,2BAA2B;AAC9B;;AAEA,oGAAoG,mBAAmB,EAAE,mBAAmB,8HAA8H;;AAE1Q;AACA;;AAEA;AACA,4BAA4B;;AAE5B;AACA;AACA,GAAG;;AAEH;AACA;AACA,GAAG;;AAEH;AACA;AACA,GAAG;;AAEH;AACA;AACA,GAAG;;AAEH;AACA;AACA,GAAG;;AAEH;AACA;AACA,GAAG;;AAEH;AACA;AACA,GAAG;;AAEH;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA,CAAC,EAAE,8BAA8B;AACjC;;AAEA;AACA;AACA;;AAEA,CAAC,GAAG;AACJ;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA,CAAC,GAAG;AACJ;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA,GAAG;;AAEH;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA,GAAG;;AAEH;AACA;AACA,GAAG;;AAEH;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA,GAAG;;AAEH;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA,KAAK;AACL;AACA;;AAEA;AACA,GAAG;;AAEH;AACA;;AAEA;AACA;AACA;AACA,KAAK;AACL;AACA;;AAEA;AACA,GAAG;;AAEH;AACA;AACA,GAAG;;AAEH;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA,GAAG;;AAEH;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW;AACX;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;;AAEA;AACA,GAAG;;AAEH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,iJAAiJ;AACjJ;;AAEA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,GAAG;;AAEH;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA,GAAG;;AAEH;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,GAAG;;AAEH;AACA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;AACA;AACA;AACA;;AAEA;;AAEA,CAAC,EAAE,6FAA6F;AAChG;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA,eAAe,qDAAqD;AACpE;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;;AAEL;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA,CAAC,EAAE,cAAc;AACjB;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,KAAK;AACL;AACA,KAAK;AACL;AACA;;AAEA;AACA,GAAG;;AAEH;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA,GAAG;;AAEH;AACA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;AACA,sBAAsB;;AAEtB;AACA;AACA;AACA;AACA;;AAEA;AACA,GAAG;;AAEH;AACA;AACA,sBAAsB;;AAEtB;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA,CAAC,EAAE,wCAAwC;AAC3C;;AAEA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,CAAC;AACD;AACA;;AAEA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;;AAEA,CAAC,EAAE,gBAAgB,EAAE,GAAG;AACxB,CAAC;;;AAGD","file":"16.js","sourcesContent":["/**\n * interact.js v1.3.0-alpha.4+sha.7970416-dirty\n *\n * Copyright (c) 2012-2017 Taye Adeyemi <dev@taye.me>\n * Open source under the MIT License.\n * https://raw.github.com/taye/interact.js/master/LICENSE\n */\n(function(f){if(typeof exports===\"object\"&&typeof module!==\"undefined\"){module.exports=f()}else if(typeof define===\"function\"&&define.amd){define([],f)}else{var g;if(typeof window!==\"undefined\"){g=window}else if(typeof global!==\"undefined\"){g=global}else if(typeof self!==\"undefined\"){g=self}else{g=this}g.interact = f()}})(function(){var define,module,exports;return (function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require==\"function\"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error(\"Cannot find module '\"+o+\"'\");throw f.code=\"MODULE_NOT_FOUND\",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require==\"function\"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})({1:[function(require,module,exports){\n'use strict';\n\n/*\n * In a (windowless) server environment this file exports a factory function\n * that takes the window to use.\n *\n *     var interact = require('interact.js')(windowObject);\n *\n * See https://github.com/taye/interact.js/issues/187\n */\nif (typeof window === 'undefined') {\n  module.exports = function (window) {\n    require('./src/utils/window').init(window);\n\n    return require('./src/index');\n  };\n} else {\n  module.exports = require('./src/index');\n}\n\n},{\"./src/index\":19,\"./src/utils/window\":52}],2:[function(require,module,exports){\n'use strict';\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nvar _require = require('./utils/arr'),\n    indexOf = _require.indexOf;\n\nvar extend = require('./utils/extend.js');\n\nfunction fireUntilImmediateStopped(event, listeners) {\n  for (var i = 0, len = listeners.length; i < len && !event.immediatePropagationStopped; i++) {\n    listeners[i](event);\n  }\n}\n\nvar Eventable = function () {\n  function Eventable(options) {\n    _classCallCheck(this, Eventable);\n\n    this.options = extend({}, options || {});\n  }\n\n  Eventable.prototype.fire = function fire(event) {\n    var listeners = void 0;\n    var onEvent = 'on' + event.type;\n    var global = this.global;\n\n    // Interactable#on() listeners\n    if (listeners = this[event.type]) {\n      fireUntilImmediateStopped(event, listeners);\n    }\n\n    // interactable.onevent listener\n    if (this[onEvent]) {\n      this[onEvent](event);\n    }\n\n    // interact.on() listeners\n    if (!event.propagationStopped && global && (listeners = global[event.type])) {\n      fireUntilImmediateStopped(event, listeners);\n    }\n  };\n\n  Eventable.prototype.on = function on(eventType, listener) {\n    // if this type of event was never bound\n    if (this[eventType]) {\n      this[eventType].push(listener);\n    } else {\n      this[eventType] = [listener];\n    }\n  };\n\n  Eventable.prototype.off = function off(eventType, listener) {\n    // if it is an action event type\n    var eventList = this[eventType];\n    var index = eventList ? indexOf(eventList, listener) : -1;\n\n    if (index !== -1) {\n      eventList.splice(index, 1);\n    }\n\n    if (eventList && eventList.length === 0 || !listener) {\n      this[eventType] = listener;\n    }\n  };\n\n  return Eventable;\n}();\n\nmodule.exports = Eventable;\n\n},{\"./utils/arr\":36,\"./utils/extend.js\":41}],3:[function(require,module,exports){\n'use strict';\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nvar extend = require('./utils/extend');\nvar getOriginXY = require('./utils/getOriginXY');\nvar defaults = require('./defaultOptions');\nvar signals = require('./utils/Signals').new();\n\nvar InteractEvent = function () {\n  function InteractEvent(interaction, event, action, phase, element, related) {\n    var preEnd = arguments.length > 6 && arguments[6] !== undefined ? arguments[6] : false;\n\n    _classCallCheck(this, InteractEvent);\n\n    var target = interaction.target;\n    var deltaSource = (target && target.options || defaults).deltaSource;\n    var origin = getOriginXY(target, element, action);\n    var starting = phase === 'start';\n    var ending = phase === 'end';\n    var coords = starting ? interaction.startCoords : interaction.curCoords;\n    var prevEvent = interaction.prevEvent;\n\n    element = element || interaction.element;\n\n    var page = extend({}, coords.page);\n    var client = extend({}, coords.client);\n\n    page.x -= origin.x;\n    page.y -= origin.y;\n\n    client.x -= origin.x;\n    client.y -= origin.y;\n\n    this.ctrlKey = event.ctrlKey;\n    this.altKey = event.altKey;\n    this.shiftKey = event.shiftKey;\n    this.metaKey = event.metaKey;\n    this.button = event.button;\n    this.buttons = event.buttons;\n    this.target = element;\n    this.currentTarget = element;\n    this.relatedTarget = related || null;\n    this.preEnd = preEnd;\n    this.type = action + (phase || '');\n    this.interaction = interaction;\n    this.interactable = target;\n\n    this.t0 = starting ? interaction.downTimes[interaction.downTimes.length - 1] : prevEvent.t0;\n\n    var signalArg = {\n      interaction: interaction,\n      event: event,\n      action: action,\n      phase: phase,\n      element: element,\n      related: related,\n      page: page,\n      client: client,\n      coords: coords,\n      starting: starting,\n      ending: ending,\n      deltaSource: deltaSource,\n      iEvent: this\n    };\n\n    signals.fire('set-xy', signalArg);\n\n    if (ending) {\n      // use previous coords when ending\n      this.pageX = prevEvent.pageX;\n      this.pageY = prevEvent.pageY;\n      this.clientX = prevEvent.clientX;\n      this.clientY = prevEvent.clientY;\n    } else {\n      this.pageX = page.x;\n      this.pageY = page.y;\n      this.clientX = client.x;\n      this.clientY = client.y;\n    }\n\n    this.x0 = interaction.startCoords.page.x - origin.x;\n    this.y0 = interaction.startCoords.page.y - origin.y;\n    this.clientX0 = interaction.startCoords.client.x - origin.x;\n    this.clientY0 = interaction.startCoords.client.y - origin.y;\n\n    signals.fire('set-delta', signalArg);\n\n    this.timeStamp = coords.timeStamp;\n    this.dt = interaction.pointerDelta.timeStamp;\n    this.duration = this.timeStamp - this.t0;\n\n    // speed and velocity in pixels per second\n    this.speed = interaction.pointerDelta[deltaSource].speed;\n    this.velocityX = interaction.pointerDelta[deltaSource].vx;\n    this.velocityY = interaction.pointerDelta[deltaSource].vy;\n\n    this.swipe = ending || phase === 'inertiastart' ? this.getSwipe() : null;\n\n    signals.fire('new', signalArg);\n  }\n\n  InteractEvent.prototype.getSwipe = function getSwipe() {\n    var interaction = this.interaction;\n\n    if (interaction.prevEvent.speed < 600 || this.timeStamp - interaction.prevEvent.timeStamp > 150) {\n      return null;\n    }\n\n    var angle = 180 * Math.atan2(interaction.prevEvent.velocityY, interaction.prevEvent.velocityX) / Math.PI;\n    var overlap = 22.5;\n\n    if (angle < 0) {\n      angle += 360;\n    }\n\n    var left = 135 - overlap <= angle && angle < 225 + overlap;\n    var up = 225 - overlap <= angle && angle < 315 + overlap;\n\n    var right = !left && (315 - overlap <= angle || angle < 45 + overlap);\n    var down = !up && 45 - overlap <= angle && angle < 135 + overlap;\n\n    return {\n      up: up,\n      down: down,\n      left: left,\n      right: right,\n      angle: angle,\n      speed: interaction.prevEvent.speed,\n      velocity: {\n        x: interaction.prevEvent.velocityX,\n        y: interaction.prevEvent.velocityY\n      }\n    };\n  };\n\n  InteractEvent.prototype.preventDefault = function preventDefault() {};\n\n  InteractEvent.prototype.stopImmediatePropagation = function stopImmediatePropagation() {\n    this.immediatePropagationStopped = this.propagationStopped = true;\n  };\n\n  InteractEvent.prototype.stopPropagation = function stopPropagation() {\n    this.propagationStopped = true;\n  };\n\n  return InteractEvent;\n}();\n\nsignals.on('set-delta', function (_ref) {\n  var iEvent = _ref.iEvent,\n      interaction = _ref.interaction,\n      starting = _ref.starting,\n      deltaSource = _ref.deltaSource;\n\n  var prevEvent = starting ? iEvent : interaction.prevEvent;\n\n  if (deltaSource === 'client') {\n    iEvent.dx = iEvent.clientX - prevEvent.clientX;\n    iEvent.dy = iEvent.clientY - prevEvent.clientY;\n  } else {\n    iEvent.dx = iEvent.pageX - prevEvent.pageX;\n    iEvent.dy = iEvent.pageY - prevEvent.pageY;\n  }\n});\n\nInteractEvent.signals = signals;\n\nmodule.exports = InteractEvent;\n\n},{\"./defaultOptions\":18,\"./utils/Signals\":35,\"./utils/extend\":41,\"./utils/getOriginXY\":42}],4:[function(require,module,exports){\n'use strict';\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nvar is = require('./utils/is');\nvar events = require('./utils/events');\nvar extend = require('./utils/extend');\nvar actions = require('./actions/base');\nvar scope = require('./scope');\nvar Eventable = require('./Eventable');\nvar defaults = require('./defaultOptions');\nvar signals = require('./utils/Signals').new();\n\nvar _require = require('./utils/domUtils'),\n    getElementRect = _require.getElementRect,\n    nodeContains = _require.nodeContains,\n    trySelector = _require.trySelector;\n\nvar _require2 = require('./utils/window'),\n    getWindow = _require2.getWindow;\n\nvar _require3 = require('./utils/arr'),\n    indexOf = _require3.indexOf,\n    contains = _require3.contains;\n\nvar _require4 = require('./utils/browser'),\n    wheelEvent = _require4.wheelEvent;\n\n// all set interactables\n\n\nscope.interactables = [];\n\n/*\\\n * Interactable\n [ property ]\n **\n * Object type returned by @interact\n\\*/\n\nvar Interactable = function () {\n  function Interactable(target, options) {\n    _classCallCheck(this, Interactable);\n\n    options = options || {};\n\n    this.target = target;\n    this.events = new Eventable();\n    this._context = options.context || scope.document;\n    this._win = getWindow(trySelector(target) ? this._context : target);\n    this._doc = this._win.document;\n\n    signals.fire('new', {\n      target: target,\n      options: options,\n      interactable: this,\n      win: this._win\n    });\n\n    scope.addDocument(this._doc, this._win);\n\n    scope.interactables.push(this);\n\n    this.set(options);\n  }\n\n  Interactable.prototype.setOnEvents = function setOnEvents(action, phases) {\n    var onAction = 'on' + action;\n\n    if (is.function(phases.onstart)) {\n      this.events[onAction + 'start'] = phases.onstart;\n    }\n    if (is.function(phases.onmove)) {\n      this.events[onAction + 'move'] = phases.onmove;\n    }\n    if (is.function(phases.onend)) {\n      this.events[onAction + 'end'] = phases.onend;\n    }\n    if (is.function(phases.oninertiastart)) {\n      this.events[onAction + 'inertiastart'] = phases.oninertiastart;\n    }\n\n    return this;\n  };\n\n  Interactable.prototype.setPerAction = function setPerAction(action, options) {\n    // for all the default per-action options\n    for (var option in options) {\n      // if this option exists for this action\n      if (option in defaults[action]) {\n        // if the option in the options arg is an object value\n        if (is.object(options[option])) {\n          // duplicate the object\n          this.options[action][option] = extend(this.options[action][option] || {}, options[option]);\n\n          if (is.object(defaults.perAction[option]) && 'enabled' in defaults.perAction[option]) {\n            this.options[action][option].enabled = options[option].enabled === false ? false : true;\n          }\n        } else if (is.bool(options[option]) && is.object(defaults.perAction[option])) {\n          this.options[action][option].enabled = options[option];\n        } else if (options[option] !== undefined) {\n          // or if it's not undefined, do a plain assignment\n          this.options[action][option] = options[option];\n        }\n      }\n    }\n  };\n\n  /*\\\n   * Interactable.getRect\n   [ method ]\n   *\n   * The default function to get an Interactables bounding rect. Can be\n   * overridden using @Interactable.rectChecker.\n   *\n   - element (Element) #optional The element to measure.\n   = (object) The object's bounding rectangle.\n   o {\n   o     top   : 0,\n   o     left  : 0,\n   o     bottom: 0,\n   o     right : 0,\n   o     width : 0,\n   o     height: 0\n   o }\n  \\*/\n\n\n  Interactable.prototype.getRect = function getRect(element) {\n    element = element || this.target;\n\n    if (is.string(this.target) && !is.element(element)) {\n      element = this._context.querySelector(this.target);\n    }\n\n    return getElementRect(element);\n  };\n\n  /*\\\n   * Interactable.rectChecker\n   [ method ]\n   *\n   * Returns or sets the function used to calculate the interactable's\n   * element's rectangle\n   *\n   - checker (function) #optional A function which returns this Interactable's bounding rectangle. See @Interactable.getRect\n   = (function | object) The checker function or this Interactable\n  \\*/\n\n\n  Interactable.prototype.rectChecker = function rectChecker(checker) {\n    if (is.function(checker)) {\n      this.getRect = checker;\n\n      return this;\n    }\n\n    if (checker === null) {\n      delete this.options.getRect;\n\n      return this;\n    }\n\n    return this.getRect;\n  };\n\n  Interactable.prototype._backCompatOption = function _backCompatOption(optionName, newValue) {\n    if (trySelector(newValue) || is.object(newValue)) {\n      this.options[optionName] = newValue;\n\n      for (var _iterator = actions.names, _isArray = Array.isArray(_iterator), _i = 0, _iterator = _isArray ? _iterator : _iterator[Symbol.iterator]();;) {\n        var _ref;\n\n        if (_isArray) {\n          if (_i >= _iterator.length) break;\n          _ref = _iterator[_i++];\n        } else {\n          _i = _iterator.next();\n          if (_i.done) break;\n          _ref = _i.value;\n        }\n\n        var action = _ref;\n\n        this.options[action][optionName] = newValue;\n      }\n\n      return this;\n    }\n\n    return this.options[optionName];\n  };\n\n  /*\\\n   * Interactable.origin\n   [ method ]\n   *\n   * Gets or sets the origin of the Interactable's element.  The x and y\n   * of the origin will be subtracted from action event coordinates.\n   *\n   - origin (object | string) #optional An object eg. { x: 0, y: 0 } or string 'parent', 'self' or any CSS selector\n   * OR\n   - origin (Element) #optional An HTML or SVG Element whose rect will be used\n   **\n   = (object) The current origin or this Interactable\n  \\*/\n\n\n  Interactable.prototype.origin = function origin(newValue) {\n    return this._backCompatOption('origin', newValue);\n  };\n\n  /*\\\n   * Interactable.deltaSource\n   [ method ]\n   *\n   * Returns or sets the mouse coordinate types used to calculate the\n   * movement of the pointer.\n   *\n   - newValue (string) #optional Use 'client' if you will be scrolling while interacting; Use 'page' if you want autoScroll to work\n   = (string | object) The current deltaSource or this Interactable\n  \\*/\n\n\n  Interactable.prototype.deltaSource = function deltaSource(newValue) {\n    if (newValue === 'page' || newValue === 'client') {\n      this.options.deltaSource = newValue;\n\n      return this;\n    }\n\n    return this.options.deltaSource;\n  };\n\n  /*\\\n   * Interactable.context\n   [ method ]\n   *\n   * Gets the selector context Node of the Interactable. The default is `window.document`.\n   *\n   = (Node) The context Node of this Interactable\n   **\n  \\*/\n\n\n  Interactable.prototype.context = function context() {\n    return this._context;\n  };\n\n  Interactable.prototype.inContext = function inContext(element) {\n    return this._context === element.ownerDocument || nodeContains(this._context, element);\n  };\n\n  /*\\\n   * Interactable.fire\n   [ method ]\n   *\n   * Calls listeners for the given InteractEvent type bound globally\n   * and directly to this Interactable\n   *\n   - iEvent (InteractEvent) The InteractEvent object to be fired on this Interactable\n   = (Interactable) this Interactable\n  \\*/\n\n\n  Interactable.prototype.fire = function fire(iEvent) {\n    this.events.fire(iEvent);\n\n    return this;\n  };\n\n  Interactable.prototype._onOffMultiple = function _onOffMultiple(method, eventType, listener, options) {\n    if (is.string(eventType) && eventType.search(' ') !== -1) {\n      eventType = eventType.trim().split(/ +/);\n    }\n\n    if (is.array(eventType)) {\n      for (var i = 0; i < eventType.length; i++) {\n        this[method](eventType[i], listener, options);\n      }\n\n      return true;\n    }\n\n    if (is.object(eventType)) {\n      for (var prop in eventType) {\n        this[method](prop, eventType[prop], listener);\n      }\n\n      return true;\n    }\n  };\n\n  /*\\\n   * Interactable.on\n   [ method ]\n   *\n   * Binds a listener for an InteractEvent, pointerEvent or DOM event.\n   *\n   - eventType  (string | array | object) The types of events to listen for\n   - listener   (function) The function event (s)\n   - options    (object | boolean) #optional options object or useCapture flag for addEventListener\n   = (object) This Interactable\n  \\*/\n\n\n  Interactable.prototype.on = function on(eventType, listener, options) {\n    if (this._onOffMultiple('on', eventType, listener, options)) {\n      return this;\n    }\n\n    if (eventType === 'wheel') {\n      eventType = wheelEvent;\n    }\n\n    if (contains(Interactable.eventTypes, eventType)) {\n      this.events.on(eventType, listener);\n    }\n    // delegated event for selector\n    else if (is.string(this.target)) {\n        events.addDelegate(this.target, this._context, eventType, listener, options);\n      } else {\n        events.add(this.target, eventType, listener, options);\n      }\n\n    return this;\n  };\n\n  /*\\\n   * Interactable.off\n   [ method ]\n   *\n   * Removes an InteractEvent, pointerEvent or DOM event listener\n   *\n   - eventType  (string | array | object) The types of events that were listened for\n   - listener   (function) The listener function to be removed\n   - options    (object | boolean) #optional options object or useCapture flag for removeEventListener\n   = (object) This Interactable\n  \\*/\n\n\n  Interactable.prototype.off = function off(eventType, listener, options) {\n    if (this._onOffMultiple('off', eventType, listener, options)) {\n      return this;\n    }\n\n    if (eventType === 'wheel') {\n      eventType = wheelEvent;\n    }\n\n    // if it is an action event type\n    if (contains(Interactable.eventTypes, eventType)) {\n      this.events.off(eventType, listener);\n    }\n    // delegated event\n    else if (is.string(this.target)) {\n        events.removeDelegate(this.target, this._context, eventType, listener, options);\n      }\n      // remove listener from this Interatable's element\n      else {\n          events.remove(this.target, eventType, listener, options);\n        }\n\n    return this;\n  };\n\n  /*\\\n   * Interactable.set\n   [ method ]\n   *\n   * Reset the options of this Interactable\n   - options (object) The new settings to apply\n   = (object) This Interactable\n  \\*/\n\n\n  Interactable.prototype.set = function set(options) {\n    if (!is.object(options)) {\n      options = {};\n    }\n\n    this.options = extend({}, defaults.base);\n\n    var perActions = extend({}, defaults.perAction);\n\n    for (var actionName in actions.methodDict) {\n      var methodName = actions.methodDict[actionName];\n\n      this.options[actionName] = extend({}, defaults[actionName]);\n\n      this.setPerAction(actionName, perActions);\n\n      this[methodName](options[actionName]);\n    }\n\n    for (var _iterator2 = Interactable.settingsMethods, _isArray2 = Array.isArray(_iterator2), _i2 = 0, _iterator2 = _isArray2 ? _iterator2 : _iterator2[Symbol.iterator]();;) {\n      var _ref2;\n\n      if (_isArray2) {\n        if (_i2 >= _iterator2.length) break;\n        _ref2 = _iterator2[_i2++];\n      } else {\n        _i2 = _iterator2.next();\n        if (_i2.done) break;\n        _ref2 = _i2.value;\n      }\n\n      var setting = _ref2;\n\n      this.options[setting] = defaults.base[setting];\n\n      if (setting in options) {\n        this[setting](options[setting]);\n      }\n    }\n\n    signals.fire('set', {\n      options: options,\n      interactable: this\n    });\n\n    return this;\n  };\n\n  /*\\\n   * Interactable.unset\n   [ method ]\n   *\n   * Remove this interactable from the list of interactables and remove\n   * it's action capabilities and event listeners\n   *\n   = (object) @interact\n  \\*/\n\n\n  Interactable.prototype.unset = function unset() {\n    events.remove(this.target, 'all');\n\n    if (is.string(this.target)) {\n      // remove delegated events\n      for (var type in events.delegatedEvents) {\n        var delegated = events.delegatedEvents[type];\n\n        if (delegated.selectors[0] === this.target && delegated.contexts[0] === this._context) {\n\n          delegated.selectors.splice(0, 1);\n          delegated.contexts.splice(0, 1);\n          delegated.listeners.splice(0, 1);\n\n          // remove the arrays if they are empty\n          if (!delegated.selectors.length) {\n            delegated[type] = null;\n          }\n        }\n\n        events.remove(this._context, type, events.delegateListener);\n        events.remove(this._context, type, events.delegateUseCapture, true);\n      }\n    } else {\n      events.remove(this, 'all');\n    }\n\n    signals.fire('unset', { interactable: this });\n\n    scope.interactables.splice(indexOf(scope.interactables, this), 1);\n\n    // Stop related interactions when an Interactable is unset\n    for (var _iterator3 = scope.interactions || [], _isArray3 = Array.isArray(_iterator3), _i3 = 0, _iterator3 = _isArray3 ? _iterator3 : _iterator3[Symbol.iterator]();;) {\n      var _ref3;\n\n      if (_isArray3) {\n        if (_i3 >= _iterator3.length) break;\n        _ref3 = _iterator3[_i3++];\n      } else {\n        _i3 = _iterator3.next();\n        if (_i3.done) break;\n        _ref3 = _i3.value;\n      }\n\n      var interaction = _ref3;\n\n      if (interaction.target === this && interaction.interacting()) {\n        interaction.stop();\n      }\n    }\n\n    return scope.interact;\n  };\n\n  return Interactable;\n}();\n\nscope.interactables.indexOfElement = function indexOfElement(target, context) {\n  context = context || scope.document;\n\n  for (var i = 0; i < this.length; i++) {\n    var interactable = this[i];\n\n    if (interactable.target === target && interactable._context === context) {\n      return i;\n    }\n  }\n  return -1;\n};\n\nscope.interactables.get = function interactableGet(element, options, dontCheckInContext) {\n  var ret = this[this.indexOfElement(element, options && options.context)];\n\n  return ret && (is.string(element) || dontCheckInContext || ret.inContext(element)) ? ret : null;\n};\n\nscope.interactables.forEachSelector = function (callback, element) {\n  for (var i = 0; i < this.length; i++) {\n    var interactable = this[i];\n\n    // skip non CSS selector targets and out of context elements\n    if (!is.string(interactable.target) || element && !interactable.inContext(element)) {\n      continue;\n    }\n\n    var ret = callback(interactable, interactable.target, interactable._context, i, this);\n\n    if (ret !== undefined) {\n      return ret;\n    }\n  }\n};\n\n// all interact.js eventTypes\nInteractable.eventTypes = scope.eventTypes = [];\n\nInteractable.signals = signals;\n\nInteractable.settingsMethods = ['deltaSource', 'origin', 'preventDefault', 'rectChecker'];\n\nmodule.exports = Interactable;\n\n},{\"./Eventable\":2,\"./actions/base\":6,\"./defaultOptions\":18,\"./scope\":34,\"./utils/Signals\":35,\"./utils/arr\":36,\"./utils/browser\":37,\"./utils/domUtils\":39,\"./utils/events\":40,\"./utils/extend\":41,\"./utils/is\":46,\"./utils/window\":52}],5:[function(require,module,exports){\n'use strict';\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nvar scope = require('./scope');\nvar utils = require('./utils');\nvar events = require('./utils/events');\nvar browser = require('./utils/browser');\nvar domObjects = require('./utils/domObjects');\nvar finder = require('./utils/interactionFinder');\nvar signals = require('./utils/Signals').new();\n\nvar listeners = {};\nvar methodNames = ['pointerDown', 'pointerMove', 'pointerUp', 'updatePointer', 'removePointer'];\n\n// for ignoring browser's simulated mouse events\nvar prevTouchTime = 0;\n\n// all active and idle interactions\nscope.interactions = [];\n\nvar Interaction = function () {\n  function Interaction(_ref) {\n    var pointerType = _ref.pointerType;\n\n    _classCallCheck(this, Interaction);\n\n    this.target = null; // current interactable being interacted with\n    this.element = null; // the target element of the interactable\n\n    this.prepared = { // action that's ready to be fired on next move event\n      name: null,\n      axis: null,\n      edges: null\n    };\n\n    // keep track of added pointers\n    this.pointers = [];\n    this.pointerIds = [];\n    this.downTargets = [];\n    this.downTimes = [];\n\n    // Previous native pointer move event coordinates\n    this.prevCoords = {\n      page: { x: 0, y: 0 },\n      client: { x: 0, y: 0 },\n      timeStamp: 0\n    };\n    // current native pointer move event coordinates\n    this.curCoords = {\n      page: { x: 0, y: 0 },\n      client: { x: 0, y: 0 },\n      timeStamp: 0\n    };\n\n    // Starting InteractEvent pointer coordinates\n    this.startCoords = {\n      page: { x: 0, y: 0 },\n      client: { x: 0, y: 0 },\n      timeStamp: 0\n    };\n\n    // Change in coordinates and time of the pointer\n    this.pointerDelta = {\n      page: { x: 0, y: 0, vx: 0, vy: 0, speed: 0 },\n      client: { x: 0, y: 0, vx: 0, vy: 0, speed: 0 },\n      timeStamp: 0\n    };\n\n    this.downEvent = null; // pointerdown/mousedown/touchstart event\n    this.downPointer = {};\n\n    this._eventTarget = null;\n    this._curEventTarget = null;\n\n    this.prevEvent = null; // previous action event\n\n    this.pointerIsDown = false;\n    this.pointerWasMoved = false;\n    this._interacting = false;\n\n    this.pointerType = pointerType;\n\n    signals.fire('new', this);\n\n    scope.interactions.push(this);\n  }\n\n  Interaction.prototype.pointerDown = function pointerDown(pointer, event, eventTarget) {\n    var pointerIndex = this.updatePointer(pointer, event, true);\n\n    signals.fire('down', {\n      pointer: pointer,\n      event: event,\n      eventTarget: eventTarget,\n      pointerIndex: pointerIndex,\n      interaction: this\n    });\n  };\n\n  /*\\\n   * Interaction.start\n   [ method ]\n   *\n   * Start an action with the given Interactable and Element as tartgets. The\n   * action must be enabled for the target Interactable and an appropriate number\n   * of pointers must be held down - 1 for drag/resize, 2 for gesture.\n   *\n   * Use it with `interactable.<action>able({ manualStart: false })` to always\n   * [start actions manually](https://github.com/taye/interact.js/issues/114)\n   *\n   - action  (object)  The action to be performed - drag, resize, etc.\n   - target  (Interactable) The Interactable to target\n   - element (Element) The DOM Element to target\n   = (object) interact\n   **\n   | interact(target)\n   |   .draggable({\n   |     // disable the default drag start by down->move\n   |     manualStart: true\n   |   })\n   |   // start dragging after the user holds the pointer down\n   |   .on('hold', function (event) {\n   |     var interaction = event.interaction;\n   |\n   |     if (!interaction.interacting()) {\n   |       interaction.start({ name: 'drag' },\n   |                         event.interactable,\n   |                         event.currentTarget);\n   |     }\n   | });\n   \\*/\n\n\n  Interaction.prototype.start = function start(action, target, element) {\n    if (this.interacting() || !this.pointerIsDown || this.pointerIds.length < (action.name === 'gesture' ? 2 : 1)) {\n      return;\n    }\n\n    // if this interaction had been removed after stopping\n    // add it back\n    if (utils.indexOf(scope.interactions, this) === -1) {\n      scope.interactions.push(this);\n    }\n\n    utils.copyAction(this.prepared, action);\n    this.target = target;\n    this.element = element;\n\n    signals.fire('action-start', {\n      interaction: this,\n      event: this.downEvent\n    });\n  };\n\n  Interaction.prototype.pointerMove = function pointerMove(pointer, event, eventTarget) {\n    if (!this.simulation) {\n      this.updatePointer(pointer);\n      utils.setCoords(this.curCoords, this.pointers);\n    }\n\n    var duplicateMove = this.curCoords.page.x === this.prevCoords.page.x && this.curCoords.page.y === this.prevCoords.page.y && this.curCoords.client.x === this.prevCoords.client.x && this.curCoords.client.y === this.prevCoords.client.y;\n\n    var dx = void 0;\n    var dy = void 0;\n\n    // register movement greater than pointerMoveTolerance\n    if (this.pointerIsDown && !this.pointerWasMoved) {\n      dx = this.curCoords.client.x - this.startCoords.client.x;\n      dy = this.curCoords.client.y - this.startCoords.client.y;\n\n      this.pointerWasMoved = utils.hypot(dx, dy) > Interaction.pointerMoveTolerance;\n    }\n\n    var signalArg = {\n      pointer: pointer,\n      pointerIndex: this.getPointerIndex(pointer),\n      event: event,\n      eventTarget: eventTarget,\n      dx: dx,\n      dy: dy,\n      duplicate: duplicateMove,\n      interaction: this,\n      interactingBeforeMove: this.interacting()\n    };\n\n    if (!duplicateMove) {\n      // set pointer coordinate, time changes and speeds\n      utils.setCoordDeltas(this.pointerDelta, this.prevCoords, this.curCoords);\n    }\n\n    signals.fire('move', signalArg);\n\n    if (!duplicateMove) {\n      // if interacting, fire an 'action-move' signal etc\n      if (this.interacting()) {\n        this.doMove(signalArg);\n      }\n\n      if (this.pointerWasMoved) {\n        utils.copyCoords(this.prevCoords, this.curCoords);\n      }\n    }\n  };\n\n  /*\\\n   * Interaction.doMove\n   [ method ]\n   *\n   * Force a move of the current action at the same coordinates. Useful if\n   * snap/restrict has been changed and you want a movement with the new\n   * settings.\n   *\n   **\n   | interact(target)\n   |   .draggable(true)\n   |   .on('dragmove', function (event) {\n   |     if (someCondition) {\n   |       // change the snap settings\n   |       event.interactable.draggable({ snap: { targets: [] }});\n   |       // fire another move event with re-calculated snap\n   |       event.interaction.doMove();\n   |     }\n   |   });\n   \\*/\n\n\n  Interaction.prototype.doMove = function doMove(signalArg) {\n    signalArg = utils.extend({\n      pointer: this.pointers[0],\n      event: this.prevEvent,\n      eventTarget: this._eventTarget,\n      interaction: this\n    }, signalArg || {});\n\n    signals.fire('before-action-move', signalArg);\n\n    if (!this._dontFireMove) {\n      signals.fire('action-move', signalArg);\n    }\n\n    this._dontFireMove = false;\n  };\n\n  // End interact move events and stop auto-scroll unless simulation is running\n\n\n  Interaction.prototype.pointerUp = function pointerUp(pointer, event, eventTarget, curEventTarget) {\n    var pointerIndex = this.getPointerIndex(pointer);\n\n    signals.fire(/cancel$/i.test(event.type) ? 'cancel' : 'up', {\n      pointer: pointer,\n      pointerIndex: pointerIndex,\n      event: event,\n      eventTarget: eventTarget,\n      curEventTarget: curEventTarget,\n      interaction: this\n    });\n\n    if (!this.simulation) {\n      this.end(event);\n    }\n\n    this.pointerIsDown = false;\n    this.removePointer(pointer, event);\n  };\n\n  /*\\\n   * Interaction.end\n   [ method ]\n   *\n   * Stop the current action and fire an end event. Inertial movement does\n   * not happen.\n   *\n   - event (PointerEvent) #optional\n   **\n   | interact(target)\n   |   .draggable(true)\n   |   .on('move', function (event) {\n   |     if (event.pageX > 1000) {\n   |       // end the current action\n   |       event.interaction.end();\n   |       // stop all further listeners from being called\n   |       event.stopImmediatePropagation();\n   |     }\n   |   });\n   \\*/\n\n\n  Interaction.prototype.end = function end(event) {\n    event = event || this.prevEvent;\n\n    if (this.interacting()) {\n      signals.fire('action-end', {\n        event: event,\n        interaction: this\n      });\n    }\n\n    this.stop();\n  };\n\n  Interaction.prototype.currentAction = function currentAction() {\n    return this._interacting ? this.prepared.name : null;\n  };\n\n  Interaction.prototype.interacting = function interacting() {\n    return this._interacting;\n  };\n\n  Interaction.prototype.stop = function stop() {\n    signals.fire('stop', { interaction: this });\n\n    if (this._interacting) {\n      signals.fire('stop-active', { interaction: this });\n      signals.fire('stop-' + this.prepared.name, { interaction: this });\n    }\n\n    this.target = this.element = null;\n\n    this._interacting = false;\n    this.prepared.name = this.prevEvent = null;\n  };\n\n  Interaction.prototype.getPointerIndex = function getPointerIndex(pointer) {\n    // mouse and pen interactions may have only one pointer\n    if (this.pointerType === 'mouse' || this.pointerType === 'pen') {\n      return 0;\n    }\n\n    return utils.indexOf(this.pointerIds, utils.getPointerId(pointer));\n  };\n\n  Interaction.prototype.updatePointer = function updatePointer(pointer, event) {\n    var down = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : event && /(down|start)$/i.test(event.type);\n\n    var id = utils.getPointerId(pointer);\n    var index = this.getPointerIndex(pointer);\n\n    if (index === -1) {\n      index = this.pointerIds.length;\n      this.pointerIds[index] = id;\n    }\n\n    if (down) {\n      signals.fire('update-pointer-down', {\n        pointer: pointer,\n        event: event,\n        down: down,\n        pointerId: id,\n        pointerIndex: index,\n        interaction: this\n      });\n    }\n\n    this.pointers[index] = pointer;\n\n    return index;\n  };\n\n  Interaction.prototype.removePointer = function removePointer(pointer, event) {\n    var index = this.getPointerIndex(pointer);\n\n    if (index === -1) {\n      return;\n    }\n\n    signals.fire('remove-pointer', {\n      pointer: pointer,\n      event: event,\n      pointerIndex: index,\n      interaction: this\n    });\n\n    this.pointers.splice(index, 1);\n    this.pointerIds.splice(index, 1);\n    this.downTargets.splice(index, 1);\n    this.downTimes.splice(index, 1);\n  };\n\n  Interaction.prototype._updateEventTargets = function _updateEventTargets(target, currentTarget) {\n    this._eventTarget = target;\n    this._curEventTarget = currentTarget;\n  };\n\n  return Interaction;\n}();\n\nfor (var i = 0, len = methodNames.length; i < len; i++) {\n  var method = methodNames[i];\n\n  listeners[method] = doOnInteractions(method);\n}\n\nfunction doOnInteractions(method) {\n  return function (event) {\n    var pointerType = utils.getPointerType(event);\n\n    var _utils$getEventTarget = utils.getEventTargets(event),\n        eventTarget = _utils$getEventTarget[0],\n        curEventTarget = _utils$getEventTarget[1];\n\n    var matches = []; // [ [pointer, interaction], ...]\n\n    if (browser.supportsTouch && /touch/.test(event.type)) {\n      prevTouchTime = new Date().getTime();\n\n      for (var _i = 0; _i < event.changedTouches.length; _i++) {\n        var pointer = event.changedTouches[_i];\n        var interaction = finder.search(pointer, event.type, eventTarget);\n\n        matches.push([pointer, interaction || new Interaction({ pointerType: pointerType })]);\n      }\n    } else {\n      var invalidPointer = false;\n\n      if (!browser.supportsPointerEvent && /mouse/.test(event.type)) {\n        // ignore mouse events while touch interactions are active\n        for (var _i2 = 0; _i2 < scope.interactions.length && !invalidPointer; _i2++) {\n          invalidPointer = scope.interactions[_i2].pointerType !== 'mouse' && scope.interactions[_i2].pointerIsDown;\n        }\n\n        // try to ignore mouse events that are simulated by the browser\n        // after a touch event\n        invalidPointer = invalidPointer || new Date().getTime() - prevTouchTime < 500\n        // on iOS and Firefox Mobile, MouseEvent.timeStamp is zero if simulated\n        || event.timeStamp === 0;\n      }\n\n      if (!invalidPointer) {\n        var _interaction = finder.search(event, event.type, eventTarget);\n\n        if (!_interaction) {\n          _interaction = new Interaction({ pointerType: pointerType });\n        }\n\n        matches.push([event, _interaction]);\n      }\n    }\n\n    for (var _iterator = matches, _isArray = Array.isArray(_iterator), _i3 = 0, _iterator = _isArray ? _iterator : _iterator[Symbol.iterator]();;) {\n      var _ref2;\n\n      if (_isArray) {\n        if (_i3 >= _iterator.length) break;\n        _ref2 = _iterator[_i3++];\n      } else {\n        _i3 = _iterator.next();\n        if (_i3.done) break;\n        _ref2 = _i3.value;\n      }\n\n      var _ref3 = _ref2,\n          _pointer = _ref3[0],\n          _interaction2 = _ref3[1];\n\n      _interaction2._updateEventTargets(eventTarget, curEventTarget);\n      _interaction2[method](_pointer, event, eventTarget, curEventTarget);\n    }\n  };\n}\n\nfunction endAll(event) {\n  for (var _i4 = 0; _i4 < scope.interactions.length; _i4++) {\n    var interaction = scope.interactions[_i4];\n\n    interaction.end(event);\n    signals.fire('endall', { event: event, interaction: interaction });\n  }\n}\n\nvar docEvents = {/* 'eventType': listenerFunc */};\nvar pEventTypes = browser.pEventTypes;\n\nif (domObjects.PointerEvent) {\n  docEvents[pEventTypes.down] = listeners.pointerDown;\n  docEvents[pEventTypes.move] = listeners.pointerMove;\n  docEvents[pEventTypes.up] = listeners.pointerUp;\n  docEvents[pEventTypes.cancel] = listeners.pointerUp;\n} else {\n  docEvents.mousedown = listeners.pointerDown;\n  docEvents.mousemove = listeners.pointerMove;\n  docEvents.mouseup = listeners.pointerUp;\n\n  docEvents.touchstart = listeners.pointerDown;\n  docEvents.touchmove = listeners.pointerMove;\n  docEvents.touchend = listeners.pointerUp;\n  docEvents.touchcancel = listeners.pointerUp;\n}\n\ndocEvents.blur = endAll;\n\nfunction onDocSignal(_ref4, signalName) {\n  var doc = _ref4.doc;\n\n  var eventMethod = signalName.indexOf('add') === 0 ? events.add : events.remove;\n\n  // delegate event listener\n  for (var eventType in scope.delegatedEvents) {\n    eventMethod(doc, eventType, events.delegateListener);\n    eventMethod(doc, eventType, events.delegateUseCapture, true);\n  }\n\n  for (var _eventType in docEvents) {\n    eventMethod(doc, _eventType, docEvents[_eventType]);\n  }\n}\n\nsignals.on('update-pointer-down', function (_ref5) {\n  var interaction = _ref5.interaction,\n      pointer = _ref5.pointer,\n      pointerId = _ref5.pointerId,\n      pointerIndex = _ref5.pointerIndex,\n      event = _ref5.event,\n      eventTarget = _ref5.eventTarget,\n      down = _ref5.down;\n\n  interaction.pointerIds[pointerIndex] = pointerId;\n  interaction.pointers[pointerIndex] = pointer;\n\n  if (down) {\n    interaction.pointerIsDown = true;\n  }\n\n  if (!interaction.interacting()) {\n    utils.setCoords(interaction.startCoords, interaction.pointers);\n\n    utils.copyCoords(interaction.curCoords, interaction.startCoords);\n    utils.copyCoords(interaction.prevCoords, interaction.startCoords);\n\n    interaction.downEvent = event;\n    interaction.downTimes[pointerIndex] = interaction.curCoords.timeStamp;\n    interaction.downTargets[pointerIndex] = eventTarget || event && utils.getEventTargets(event)[0];\n    interaction.pointerWasMoved = false;\n\n    utils.pointerExtend(interaction.downPointer, pointer);\n  }\n});\n\nscope.signals.on('add-document', onDocSignal);\nscope.signals.on('remove-document', onDocSignal);\n\nInteraction.pointerMoveTolerance = 1;\nInteraction.doOnInteractions = doOnInteractions;\nInteraction.endAll = endAll;\nInteraction.signals = signals;\nInteraction.docEvents = docEvents;\n\nscope.endAllInteractions = endAll;\n\nmodule.exports = Interaction;\n\n},{\"./scope\":34,\"./utils\":44,\"./utils/Signals\":35,\"./utils/browser\":37,\"./utils/domObjects\":38,\"./utils/events\":40,\"./utils/interactionFinder\":45}],6:[function(require,module,exports){\n'use strict';\n\nvar Interaction = require('../Interaction');\nvar InteractEvent = require('../InteractEvent');\n\nvar actions = {\n  firePrepared: firePrepared,\n  names: [],\n  methodDict: {}\n};\n\nInteraction.signals.on('action-start', function (_ref) {\n  var interaction = _ref.interaction,\n      event = _ref.event;\n\n  interaction._interacting = true;\n  firePrepared(interaction, event, 'start');\n});\n\nInteraction.signals.on('action-move', function (_ref2) {\n  var interaction = _ref2.interaction,\n      event = _ref2.event,\n      preEnd = _ref2.preEnd;\n\n  firePrepared(interaction, event, 'move', preEnd);\n\n  // if the action was ended in a listener\n  if (!interaction.interacting()) {\n    return false;\n  }\n});\n\nInteraction.signals.on('action-end', function (_ref3) {\n  var interaction = _ref3.interaction,\n      event = _ref3.event;\n\n  firePrepared(interaction, event, 'end');\n});\n\nfunction firePrepared(interaction, event, phase, preEnd) {\n  var actionName = interaction.prepared.name;\n\n  var newEvent = new InteractEvent(interaction, event, actionName, phase, interaction.element, null, preEnd);\n\n  interaction.target.fire(newEvent);\n  interaction.prevEvent = newEvent;\n}\n\nmodule.exports = actions;\n\n},{\"../InteractEvent\":3,\"../Interaction\":5}],7:[function(require,module,exports){\n'use strict';\n\nvar actions = require('./base');\nvar utils = require('../utils');\nvar InteractEvent = require('../InteractEvent');\nvar Interactable = require('../Interactable');\nvar Interaction = require('../Interaction');\nvar defaultOptions = require('../defaultOptions');\n\nvar drag = {\n  defaults: {\n    enabled: false,\n    mouseButtons: null,\n\n    origin: null,\n    snap: null,\n    restrict: null,\n    inertia: null,\n    autoScroll: null,\n\n    startAxis: 'xy',\n    lockAxis: 'xy'\n  },\n\n  checker: function checker(pointer, event, interactable) {\n    var dragOptions = interactable.options.drag;\n\n    return dragOptions.enabled ? { name: 'drag', axis: dragOptions.lockAxis === 'start' ? dragOptions.startAxis : dragOptions.lockAxis } : null;\n  },\n\n  getCursor: function getCursor() {\n    return 'move';\n  }\n};\n\nInteraction.signals.on('before-action-move', function (_ref) {\n  var interaction = _ref.interaction;\n\n  if (interaction.prepared.name !== 'drag') {\n    return;\n  }\n\n  var axis = interaction.prepared.axis;\n\n  if (axis === 'x') {\n    interaction.curCoords.page.y = interaction.startCoords.page.y;\n    interaction.curCoords.client.y = interaction.startCoords.client.y;\n\n    interaction.pointerDelta.page.speed = Math.abs(interaction.pointerDelta.page.vx);\n    interaction.pointerDelta.client.speed = Math.abs(interaction.pointerDelta.client.vx);\n    interaction.pointerDelta.client.vy = 0;\n    interaction.pointerDelta.page.vy = 0;\n  } else if (axis === 'y') {\n    interaction.curCoords.page.x = interaction.startCoords.page.x;\n    interaction.curCoords.client.x = interaction.startCoords.client.x;\n\n    interaction.pointerDelta.page.speed = Math.abs(interaction.pointerDelta.page.vy);\n    interaction.pointerDelta.client.speed = Math.abs(interaction.pointerDelta.client.vy);\n    interaction.pointerDelta.client.vx = 0;\n    interaction.pointerDelta.page.vx = 0;\n  }\n});\n\n// dragmove\nInteractEvent.signals.on('new', function (_ref2) {\n  var iEvent = _ref2.iEvent,\n      interaction = _ref2.interaction;\n\n  if (iEvent.type !== 'dragmove') {\n    return;\n  }\n\n  var axis = interaction.prepared.axis;\n\n  if (axis === 'x') {\n    iEvent.pageY = interaction.startCoords.page.y;\n    iEvent.clientY = interaction.startCoords.client.y;\n    iEvent.dy = 0;\n  } else if (axis === 'y') {\n    iEvent.pageX = interaction.startCoords.page.x;\n    iEvent.clientX = interaction.startCoords.client.x;\n    iEvent.dx = 0;\n  }\n});\n\n/*\\\n * Interactable.draggable\n [ method ]\n *\n * Gets or sets whether drag actions can be performed on the\n * Interactable\n *\n = (boolean) Indicates if this can be the target of drag events\n | var isDraggable = interact('ul li').draggable();\n * or\n - options (boolean | object) #optional true/false or An object with event listeners to be fired on drag events (object makes the Interactable draggable)\n = (object) This Interactable\n | interact(element).draggable({\n |     onstart: function (event) {},\n |     onmove : function (event) {},\n |     onend  : function (event) {},\n |\n |     // the axis in which the first movement must be\n |     // for the drag sequence to start\n |     // 'xy' by default - any direction\n |     startAxis: 'x' || 'y' || 'xy',\n |\n |     // 'xy' by default - don't restrict to one axis (move in any direction)\n |     // 'x' or 'y' to restrict movement to either axis\n |     // 'start' to restrict movement to the axis the drag started in\n |     lockAxis: 'x' || 'y' || 'xy' || 'start',\n |\n |     // max number of drags that can happen concurrently\n |     // with elements of this Interactable. Infinity by default\n |     max: Infinity,\n |\n |     // max number of drags that can target the same element+Interactable\n |     // 1 by default\n |     maxPerElement: 2\n | });\n\\*/\nInteractable.prototype.draggable = function (options) {\n  if (utils.is.object(options)) {\n    this.options.drag.enabled = options.enabled === false ? false : true;\n    this.setPerAction('drag', options);\n    this.setOnEvents('drag', options);\n\n    if (/^(xy|x|y|start)$/.test(options.lockAxis)) {\n      this.options.drag.lockAxis = options.lockAxis;\n    }\n    if (/^(xy|x|y)$/.test(options.startAxis)) {\n      this.options.drag.startAxis = options.startAxis;\n    }\n\n    return this;\n  }\n\n  if (utils.is.bool(options)) {\n    this.options.drag.enabled = options;\n\n    if (!options) {\n      this.ondragstart = this.ondragstart = this.ondragend = null;\n    }\n\n    return this;\n  }\n\n  return this.options.drag;\n};\n\nactions.drag = drag;\nactions.names.push('drag');\nutils.merge(Interactable.eventTypes, ['dragstart', 'dragmove', 'draginertiastart', 'draginertiaresume', 'dragend']);\nactions.methodDict.drag = 'draggable';\n\ndefaultOptions.drag = drag.defaults;\n\nmodule.exports = drag;\n\n},{\"../InteractEvent\":3,\"../Interactable\":4,\"../Interaction\":5,\"../defaultOptions\":18,\"../utils\":44,\"./base\":6}],8:[function(require,module,exports){\n'use strict';\n\nvar actions = require('./base');\nvar utils = require('../utils');\nvar scope = require('../scope');\nvar interact = require('../interact');\nvar InteractEvent = require('../InteractEvent');\nvar Interactable = require('../Interactable');\nvar Interaction = require('../Interaction');\nvar defaultOptions = require('../defaultOptions');\n\nvar drop = {\n  defaults: {\n    enabled: false,\n    accept: null,\n    overlap: 'pointer'\n  }\n};\n\nvar dynamicDrop = false;\n\nInteraction.signals.on('action-start', function (_ref) {\n  var interaction = _ref.interaction,\n      event = _ref.event;\n\n  if (interaction.prepared.name !== 'drag') {\n    return;\n  }\n\n  // reset active dropzones\n  interaction.activeDrops.dropzones = [];\n  interaction.activeDrops.elements = [];\n  interaction.activeDrops.rects = [];\n\n  interaction.dropEvents = null;\n\n  if (!interaction.dynamicDrop) {\n    setActiveDrops(interaction, interaction.element);\n  }\n\n  var dragEvent = interaction.prevEvent;\n  var dropEvents = getDropEvents(interaction, event, dragEvent);\n\n  if (dropEvents.activate) {\n    fireActiveDrops(interaction, dropEvents.activate);\n  }\n});\n\nInteractEvent.signals.on('new', function (_ref2) {\n  var interaction = _ref2.interaction,\n      iEvent = _ref2.iEvent,\n      event = _ref2.event;\n\n  if (iEvent.type !== 'dragmove' && iEvent.type !== 'dragend') {\n    return;\n  }\n\n  var draggableElement = interaction.element;\n  var dragEvent = iEvent;\n  var dropResult = getDrop(dragEvent, event, draggableElement);\n\n  interaction.dropTarget = dropResult.dropzone;\n  interaction.dropElement = dropResult.element;\n\n  interaction.dropEvents = getDropEvents(interaction, event, dragEvent);\n});\n\nInteraction.signals.on('action-move', function (_ref3) {\n  var interaction = _ref3.interaction;\n\n  if (interaction.prepared.name !== 'drag') {\n    return;\n  }\n\n  fireDropEvents(interaction, interaction.dropEvents);\n});\n\nInteraction.signals.on('action-end', function (_ref4) {\n  var interaction = _ref4.interaction;\n\n  if (interaction.prepared.name === 'drag') {\n    fireDropEvents(interaction, interaction.dropEvents);\n  }\n});\n\nInteraction.signals.on('stop-drag', function (_ref5) {\n  var interaction = _ref5.interaction;\n\n  interaction.activeDrops.dropzones = interaction.activeDrops.elements = interaction.activeDrops.rects = interaction.dropEvents = null;\n});\n\nfunction collectDrops(interaction, element) {\n  var drops = [];\n  var elements = [];\n\n  element = element || interaction.element;\n\n  // collect all dropzones and their elements which qualify for a drop\n  for (var _iterator = scope.interactables, _isArray = Array.isArray(_iterator), _i = 0, _iterator = _isArray ? _iterator : _iterator[Symbol.iterator]();;) {\n    var _ref6;\n\n    if (_isArray) {\n      if (_i >= _iterator.length) break;\n      _ref6 = _iterator[_i++];\n    } else {\n      _i = _iterator.next();\n      if (_i.done) break;\n      _ref6 = _i.value;\n    }\n\n    var current = _ref6;\n\n    if (!current.options.drop.enabled) {\n      continue;\n    }\n\n    var accept = current.options.drop.accept;\n\n    // test the draggable element against the dropzone's accept setting\n    if (utils.is.element(accept) && accept !== element || utils.is.string(accept) && !utils.matchesSelector(element, accept)) {\n\n      continue;\n    }\n\n    // query for new elements if necessary\n    var dropElements = utils.is.string(current.target) ? current._context.querySelectorAll(current.target) : [current.target];\n\n    for (var i = 0; i < dropElements.length; i++) {\n      var currentElement = dropElements[i];\n\n      if (currentElement !== element) {\n        drops.push(current);\n        elements.push(currentElement);\n      }\n    }\n  }\n\n  return {\n    elements: elements,\n    dropzones: drops\n  };\n}\n\nfunction fireActiveDrops(interaction, event) {\n  var prevElement = void 0;\n\n  // loop through all active dropzones and trigger event\n  for (var i = 0; i < interaction.activeDrops.dropzones.length; i++) {\n    var current = interaction.activeDrops.dropzones[i];\n    var currentElement = interaction.activeDrops.elements[i];\n\n    // prevent trigger of duplicate events on same element\n    if (currentElement !== prevElement) {\n      // set current element as event target\n      event.target = currentElement;\n      current.fire(event);\n    }\n    prevElement = currentElement;\n  }\n}\n\n// Collect a new set of possible drops and save them in activeDrops.\n// setActiveDrops should always be called when a drag has just started or a\n// drag event happens while dynamicDrop is true\nfunction setActiveDrops(interaction, dragElement) {\n  // get dropzones and their elements that could receive the draggable\n  var possibleDrops = collectDrops(interaction, dragElement, true);\n\n  interaction.activeDrops.dropzones = possibleDrops.dropzones;\n  interaction.activeDrops.elements = possibleDrops.elements;\n  interaction.activeDrops.rects = [];\n\n  for (var i = 0; i < interaction.activeDrops.dropzones.length; i++) {\n    interaction.activeDrops.rects[i] = interaction.activeDrops.dropzones[i].getRect(interaction.activeDrops.elements[i]);\n  }\n}\n\nfunction getDrop(dragEvent, event, dragElement) {\n  var interaction = dragEvent.interaction;\n  var validDrops = [];\n\n  if (dynamicDrop) {\n    setActiveDrops(interaction, dragElement);\n  }\n\n  // collect all dropzones and their elements which qualify for a drop\n  for (var j = 0; j < interaction.activeDrops.dropzones.length; j++) {\n    var current = interaction.activeDrops.dropzones[j];\n    var currentElement = interaction.activeDrops.elements[j];\n    var rect = interaction.activeDrops.rects[j];\n\n    validDrops.push(current.dropCheck(dragEvent, event, interaction.target, dragElement, currentElement, rect) ? currentElement : null);\n  }\n\n  // get the most appropriate dropzone based on DOM depth and order\n  var dropIndex = utils.indexOfDeepestElement(validDrops);\n\n  return {\n    dropzone: interaction.activeDrops.dropzones[dropIndex] || null,\n    element: interaction.activeDrops.elements[dropIndex] || null\n  };\n}\n\nfunction getDropEvents(interaction, pointerEvent, dragEvent) {\n  var dropEvents = {\n    enter: null,\n    leave: null,\n    activate: null,\n    deactivate: null,\n    move: null,\n    drop: null\n  };\n\n  var tmpl = {\n    dragEvent: dragEvent,\n    interaction: interaction,\n    target: interaction.dropElement,\n    dropzone: interaction.dropTarget,\n    relatedTarget: dragEvent.target,\n    draggable: dragEvent.interactable,\n    timeStamp: dragEvent.timeStamp\n  };\n\n  if (interaction.dropElement !== interaction.prevDropElement) {\n    // if there was a prevDropTarget, create a dragleave event\n    if (interaction.prevDropTarget) {\n      dropEvents.leave = utils.extend({ type: 'dragleave' }, tmpl);\n\n      dragEvent.dragLeave = dropEvents.leave.target = interaction.prevDropElement;\n      dragEvent.prevDropzone = dropEvents.leave.dropzone = interaction.prevDropTarget;\n    }\n    // if the dropTarget is not null, create a dragenter event\n    if (interaction.dropTarget) {\n      dropEvents.enter = {\n        dragEvent: dragEvent,\n        interaction: interaction,\n        target: interaction.dropElement,\n        dropzone: interaction.dropTarget,\n        relatedTarget: dragEvent.target,\n        draggable: dragEvent.interactable,\n        timeStamp: dragEvent.timeStamp,\n        type: 'dragenter'\n      };\n\n      dragEvent.dragEnter = interaction.dropElement;\n      dragEvent.dropzone = interaction.dropTarget;\n    }\n  }\n\n  if (dragEvent.type === 'dragend' && interaction.dropTarget) {\n    dropEvents.drop = utils.extend({ type: 'drop' }, tmpl);\n\n    dragEvent.dropzone = interaction.dropTarget;\n    dragEvent.relatedTarget = interaction.dropElement;\n  }\n  if (dragEvent.type === 'dragstart') {\n    dropEvents.activate = utils.extend({ type: 'dropactivate' }, tmpl);\n\n    dropEvents.activate.target = null;\n    dropEvents.activate.dropzone = null;\n  }\n  if (dragEvent.type === 'dragend') {\n    dropEvents.deactivate = utils.extend({ type: 'dropdeactivate' }, tmpl);\n\n    dropEvents.deactivate.target = null;\n    dropEvents.deactivate.dropzone = null;\n  }\n  if (dragEvent.type === 'dragmove' && interaction.dropTarget) {\n    dropEvents.move = utils.extend({\n      dragmove: dragEvent,\n      type: 'dropmove'\n    }, tmpl);\n\n    dragEvent.dropzone = interaction.dropTarget;\n  }\n\n  return dropEvents;\n}\n\nfunction fireDropEvents(interaction, dropEvents) {\n  if (dropEvents.leave) {\n    interaction.prevDropTarget.fire(dropEvents.leave);\n  }\n  if (dropEvents.move) {\n    interaction.dropTarget.fire(dropEvents.move);\n  }\n  if (dropEvents.enter) {\n    interaction.dropTarget.fire(dropEvents.enter);\n  }\n  if (dropEvents.drop) {\n    interaction.dropTarget.fire(dropEvents.drop);\n  }\n  if (dropEvents.deactivate) {\n    fireActiveDrops(interaction, dropEvents.deactivate);\n  }\n\n  interaction.prevDropTarget = interaction.dropTarget;\n  interaction.prevDropElement = interaction.dropElement;\n}\n\n/*\\\n * Interactable.dropzone\n [ method ]\n *\n * Returns or sets whether elements can be dropped onto this\n * Interactable to trigger drop events\n *\n * Dropzones can receive the following events:\n *  - `dropactivate` and `dropdeactivate` when an acceptable drag starts and ends\n *  - `dragenter` and `dragleave` when a draggable enters and leaves the dropzone\n *  - `dragmove` when a draggable that has entered the dropzone is moved\n *  - `drop` when a draggable is dropped into this dropzone\n *\n * Use the `accept` option to allow only elements that match the given CSS\n * selector or element. The value can be:\n *\n *  - **an Element** - only that element can be dropped into this dropzone.\n *  - **a string**, - the element being dragged must match it as a CSS selector.\n *  - **`null`** - accept options is cleared - it accepts any element.\n *\n * Use the `overlap` option to set how drops are checked for. The allowed\n * values are:\n *\n *   - `'pointer'`, the pointer must be over the dropzone (default)\n *   - `'center'`, the draggable element's center must be over the dropzone\n *   - a number from 0-1 which is the `(intersection area) / (draggable area)`.\n *   e.g. `0.5` for drop to happen when half of the area of the draggable is\n *   over the dropzone\n *\n * Use the `checker` option to specify a function to check if a dragged\n * element is over this Interactable.\n *\n | interact(target)\n | .dropChecker(function(dragEvent,         // related dragmove or dragend event\n |                       event,             // TouchEvent/PointerEvent/MouseEvent\n |                       dropped,           // bool result of the default checker\n |                       dropzone,          // dropzone Interactable\n |                       dropElement,       // dropzone elemnt\n |                       draggable,         // draggable Interactable\n |                       draggableElement) {// draggable element\n |\n |   return dropped && event.target.hasAttribute('allow-drop');\n | }\n *\n *\n - options (boolean | object | null) #optional The new value to be set.\n | interact('.drop').dropzone({\n |   accept: '.can-drop' || document.getElementById('single-drop'),\n |   overlap: 'pointer' || 'center' || zeroToOne\n | }\n = (boolean | object) The current setting or this Interactable\n\\*/\nInteractable.prototype.dropzone = function (options) {\n  if (utils.is.object(options)) {\n    this.options.drop.enabled = options.enabled === false ? false : true;\n\n    if (utils.is.function(options.ondrop)) {\n      this.events.ondrop = options.ondrop;\n    }\n    if (utils.is.function(options.ondropactivate)) {\n      this.events.ondropactivate = options.ondropactivate;\n    }\n    if (utils.is.function(options.ondropdeactivate)) {\n      this.events.ondropdeactivate = options.ondropdeactivate;\n    }\n    if (utils.is.function(options.ondragenter)) {\n      this.events.ondragenter = options.ondragenter;\n    }\n    if (utils.is.function(options.ondragleave)) {\n      this.events.ondragleave = options.ondragleave;\n    }\n    if (utils.is.function(options.ondropmove)) {\n      this.events.ondropmove = options.ondropmove;\n    }\n\n    if (/^(pointer|center)$/.test(options.overlap)) {\n      this.options.drop.overlap = options.overlap;\n    } else if (utils.is.number(options.overlap)) {\n      this.options.drop.overlap = Math.max(Math.min(1, options.overlap), 0);\n    }\n    if ('accept' in options) {\n      this.options.drop.accept = options.accept;\n    }\n    if ('checker' in options) {\n      this.options.drop.checker = options.checker;\n    }\n\n    return this;\n  }\n\n  if (utils.is.bool(options)) {\n    this.options.drop.enabled = options;\n\n    if (!options) {\n      this.ondragenter = this.ondragleave = this.ondrop = this.ondropactivate = this.ondropdeactivate = null;\n    }\n\n    return this;\n  }\n\n  return this.options.drop;\n};\n\nInteractable.prototype.dropCheck = function (dragEvent, event, draggable, draggableElement, dropElement, rect) {\n  var dropped = false;\n\n  // if the dropzone has no rect (eg. display: none)\n  // call the custom dropChecker or just return false\n  if (!(rect = rect || this.getRect(dropElement))) {\n    return this.options.drop.checker ? this.options.drop.checker(dragEvent, event, dropped, this, dropElement, draggable, draggableElement) : false;\n  }\n\n  var dropOverlap = this.options.drop.overlap;\n\n  if (dropOverlap === 'pointer') {\n    var origin = utils.getOriginXY(draggable, draggableElement, 'drag');\n    var page = utils.getPageXY(dragEvent);\n\n    page.x += origin.x;\n    page.y += origin.y;\n\n    var horizontal = page.x > rect.left && page.x < rect.right;\n    var vertical = page.y > rect.top && page.y < rect.bottom;\n\n    dropped = horizontal && vertical;\n  }\n\n  var dragRect = draggable.getRect(draggableElement);\n\n  if (dragRect && dropOverlap === 'center') {\n    var cx = dragRect.left + dragRect.width / 2;\n    var cy = dragRect.top + dragRect.height / 2;\n\n    dropped = cx >= rect.left && cx <= rect.right && cy >= rect.top && cy <= rect.bottom;\n  }\n\n  if (dragRect && utils.is.number(dropOverlap)) {\n    var overlapArea = Math.max(0, Math.min(rect.right, dragRect.right) - Math.max(rect.left, dragRect.left)) * Math.max(0, Math.min(rect.bottom, dragRect.bottom) - Math.max(rect.top, dragRect.top));\n\n    var overlapRatio = overlapArea / (dragRect.width * dragRect.height);\n\n    dropped = overlapRatio >= dropOverlap;\n  }\n\n  if (this.options.drop.checker) {\n    dropped = this.options.drop.checker(dragEvent, event, dropped, this, dropElement, draggable, draggableElement);\n  }\n\n  return dropped;\n};\n\nInteractable.signals.on('unset', function (_ref7) {\n  var interactable = _ref7.interactable;\n\n  interactable.dropzone(false);\n});\n\nInteractable.settingsMethods.push('dropChecker');\n\nInteraction.signals.on('new', function (interaction) {\n  interaction.dropTarget = null; // the dropzone a drag target might be dropped into\n  interaction.dropElement = null; // the element at the time of checking\n  interaction.prevDropTarget = null; // the dropzone that was recently dragged away from\n  interaction.prevDropElement = null; // the element at the time of checking\n  interaction.dropEvents = null; // the dropEvents related to the current drag event\n\n  interaction.activeDrops = {\n    dropzones: [], // the dropzones that are mentioned below\n    elements: [], // elements of dropzones that accept the target draggable\n    rects: [] // the rects of the elements mentioned above\n  };\n});\n\nInteraction.signals.on('stop', function (_ref8) {\n  var interaction = _ref8.interaction;\n\n  interaction.dropTarget = interaction.dropElement = interaction.prevDropTarget = interaction.prevDropElement = null;\n});\n\n/*\\\n * interact.dynamicDrop\n [ method ]\n *\n * Returns or sets whether the dimensions of dropzone elements are\n * calculated on every dragmove or only on dragstart for the default\n * dropChecker\n *\n - newValue (boolean) #optional True to check on each move. False to check only before start\n = (boolean | interact) The current setting or interact\n\\*/\ninteract.dynamicDrop = function (newValue) {\n  if (utils.is.bool(newValue)) {\n    //if (dragging && dynamicDrop !== newValue && !newValue) {\n    //calcRects(dropzones);\n    //}\n\n    dynamicDrop = newValue;\n\n    return interact;\n  }\n  return dynamicDrop;\n};\n\nutils.merge(Interactable.eventTypes, ['dragenter', 'dragleave', 'dropactivate', 'dropdeactivate', 'dropmove', 'drop']);\nactions.methodDict.drop = 'dropzone';\n\ndefaultOptions.drop = drop.defaults;\n\nmodule.exports = drop;\n\n},{\"../InteractEvent\":3,\"../Interactable\":4,\"../Interaction\":5,\"../defaultOptions\":18,\"../interact\":21,\"../scope\":34,\"../utils\":44,\"./base\":6}],9:[function(require,module,exports){\n'use strict';\n\nvar actions = require('./base');\nvar utils = require('../utils');\nvar InteractEvent = require('../InteractEvent');\nvar Interactable = require('../Interactable');\nvar Interaction = require('../Interaction');\nvar defaultOptions = require('../defaultOptions');\n\nvar gesture = {\n  defaults: {\n    enabled: false,\n    origin: null,\n    restrict: null\n  },\n\n  checker: function checker(pointer, event, interactable, element, interaction) {\n    if (interaction.pointerIds.length >= 2) {\n      return { name: 'gesture' };\n    }\n\n    return null;\n  },\n\n  getCursor: function getCursor() {\n    return '';\n  }\n};\n\nInteractEvent.signals.on('new', function (_ref) {\n  var iEvent = _ref.iEvent,\n      interaction = _ref.interaction;\n\n  if (iEvent.type !== 'gesturestart') {\n    return;\n  }\n  iEvent.ds = 0;\n\n  interaction.gesture.startDistance = interaction.gesture.prevDistance = iEvent.distance;\n  interaction.gesture.startAngle = interaction.gesture.prevAngle = iEvent.angle;\n  interaction.gesture.scale = 1;\n});\n\nInteractEvent.signals.on('new', function (_ref2) {\n  var iEvent = _ref2.iEvent,\n      interaction = _ref2.interaction;\n\n  if (iEvent.type !== 'gesturemove') {\n    return;\n  }\n\n  iEvent.ds = iEvent.scale - interaction.gesture.scale;\n\n  interaction.target.fire(iEvent);\n\n  interaction.gesture.prevAngle = iEvent.angle;\n  interaction.gesture.prevDistance = iEvent.distance;\n\n  if (iEvent.scale !== Infinity && iEvent.scale !== null && iEvent.scale !== undefined && !isNaN(iEvent.scale)) {\n\n    interaction.gesture.scale = iEvent.scale;\n  }\n});\n\n/*\\\n * Interactable.gesturable\n [ method ]\n *\n * Gets or sets whether multitouch gestures can be performed on the\n * Interactable's element\n *\n = (boolean) Indicates if this can be the target of gesture events\n   | var isGestureable = interact(element).gesturable();\n * or\n - options (boolean | object) #optional true/false or An object with event listeners to be fired on gesture events (makes the Interactable gesturable)\n = (object) this Interactable\n | interact(element).gesturable({\n |     onstart: function (event) {},\n |     onmove : function (event) {},\n |     onend  : function (event) {},\n |\n |     // limit multiple gestures.\n |     // See the explanation in @Interactable.draggable example\n |     max: Infinity,\n |     maxPerElement: 1,\n | });\n\\*/\nInteractable.prototype.gesturable = function (options) {\n  if (utils.is.object(options)) {\n    this.options.gesture.enabled = options.enabled === false ? false : true;\n    this.setPerAction('gesture', options);\n    this.setOnEvents('gesture', options);\n\n    return this;\n  }\n\n  if (utils.is.bool(options)) {\n    this.options.gesture.enabled = options;\n\n    if (!options) {\n      this.ongesturestart = this.ongesturestart = this.ongestureend = null;\n    }\n\n    return this;\n  }\n\n  return this.options.gesture;\n};\n\nInteractEvent.signals.on('set-delta', function (_ref3) {\n  var interaction = _ref3.interaction,\n      iEvent = _ref3.iEvent,\n      action = _ref3.action,\n      event = _ref3.event,\n      starting = _ref3.starting,\n      ending = _ref3.ending,\n      deltaSource = _ref3.deltaSource;\n\n  if (action !== 'gesture') {\n    return;\n  }\n\n  var pointers = interaction.pointers;\n\n  iEvent.touches = [pointers[0], pointers[1]];\n\n  if (starting) {\n    iEvent.distance = utils.touchDistance(pointers, deltaSource);\n    iEvent.box = utils.touchBBox(pointers);\n    iEvent.scale = 1;\n    iEvent.ds = 0;\n    iEvent.angle = utils.touchAngle(pointers, undefined, deltaSource);\n    iEvent.da = 0;\n  } else if (ending || event instanceof InteractEvent) {\n    iEvent.distance = interaction.prevEvent.distance;\n    iEvent.box = interaction.prevEvent.box;\n    iEvent.scale = interaction.prevEvent.scale;\n    iEvent.ds = iEvent.scale - 1;\n    iEvent.angle = interaction.prevEvent.angle;\n    iEvent.da = iEvent.angle - interaction.gesture.startAngle;\n  } else {\n    iEvent.distance = utils.touchDistance(pointers, deltaSource);\n    iEvent.box = utils.touchBBox(pointers);\n    iEvent.scale = iEvent.distance / interaction.gesture.startDistance;\n    iEvent.angle = utils.touchAngle(pointers, interaction.gesture.prevAngle, deltaSource);\n\n    iEvent.ds = iEvent.scale - interaction.gesture.prevScale;\n    iEvent.da = iEvent.angle - interaction.gesture.prevAngle;\n  }\n});\n\nInteraction.signals.on('new', function (interaction) {\n  interaction.gesture = {\n    start: { x: 0, y: 0 },\n\n    startDistance: 0, // distance between two touches of touchStart\n    prevDistance: 0,\n    distance: 0,\n\n    scale: 1, // gesture.distance / gesture.startDistance\n\n    startAngle: 0, // angle of line joining two touches\n    prevAngle: 0 // angle of the previous gesture event\n  };\n});\n\nactions.gesture = gesture;\nactions.names.push('gesture');\nutils.merge(Interactable.eventTypes, ['gesturestart', 'gesturemove', 'gestureend']);\nactions.methodDict.gesture = 'gesturable';\n\ndefaultOptions.gesture = gesture.defaults;\n\nmodule.exports = gesture;\n\n},{\"../InteractEvent\":3,\"../Interactable\":4,\"../Interaction\":5,\"../defaultOptions\":18,\"../utils\":44,\"./base\":6}],10:[function(require,module,exports){\n'use strict';\n\nvar actions = require('./base');\nvar utils = require('../utils');\nvar browser = require('../utils/browser');\nvar InteractEvent = require('../InteractEvent');\nvar Interactable = require('../Interactable');\nvar Interaction = require('../Interaction');\nvar defaultOptions = require('../defaultOptions');\n\n// Less Precision with touch input\nvar defaultMargin = browser.supportsTouch || browser.supportsPointerEvent ? 20 : 10;\n\nvar resize = {\n  defaults: {\n    enabled: false,\n    mouseButtons: null,\n\n    origin: null,\n    snap: null,\n    restrict: null,\n    inertia: null,\n    autoScroll: null,\n\n    square: false,\n    preserveAspectRatio: false,\n    axis: 'xy',\n\n    // use default margin\n    margin: NaN,\n\n    // object with props left, right, top, bottom which are\n    // true/false values to resize when the pointer is over that edge,\n    // CSS selectors to match the handles for each direction\n    // or the Elements for each handle\n    edges: null,\n\n    // a value of 'none' will limit the resize rect to a minimum of 0x0\n    // 'negate' will alow the rect to have negative width/height\n    // 'reposition' will keep the width/height positive by swapping\n    // the top and bottom edges and/or swapping the left and right edges\n    invert: 'none'\n  },\n\n  checker: function checker(pointer, event, interactable, element, interaction, rect) {\n    if (!rect) {\n      return null;\n    }\n\n    var page = utils.extend({}, interaction.curCoords.page);\n    var options = interactable.options;\n\n    if (options.resize.enabled) {\n      var resizeOptions = options.resize;\n      var resizeEdges = { left: false, right: false, top: false, bottom: false };\n\n      // if using resize.edges\n      if (utils.is.object(resizeOptions.edges)) {\n        for (var edge in resizeEdges) {\n          resizeEdges[edge] = checkResizeEdge(edge, resizeOptions.edges[edge], page, interaction._eventTarget, element, rect, resizeOptions.margin || defaultMargin);\n        }\n\n        resizeEdges.left = resizeEdges.left && !resizeEdges.right;\n        resizeEdges.top = resizeEdges.top && !resizeEdges.bottom;\n\n        if (resizeEdges.left || resizeEdges.right || resizeEdges.top || resizeEdges.bottom) {\n          return {\n            name: 'resize',\n            edges: resizeEdges\n          };\n        }\n      } else {\n        var right = options.resize.axis !== 'y' && page.x > rect.right - defaultMargin;\n        var bottom = options.resize.axis !== 'x' && page.y > rect.bottom - defaultMargin;\n\n        if (right || bottom) {\n          return {\n            name: 'resize',\n            axes: (right ? 'x' : '') + (bottom ? 'y' : '')\n          };\n        }\n      }\n    }\n\n    return null;\n  },\n\n  cursors: browser.isIe9OrOlder ? {\n    x: 'e-resize',\n    y: 's-resize',\n    xy: 'se-resize',\n\n    top: 'n-resize',\n    left: 'w-resize',\n    bottom: 's-resize',\n    right: 'e-resize',\n    topleft: 'se-resize',\n    bottomright: 'se-resize',\n    topright: 'ne-resize',\n    bottomleft: 'ne-resize'\n  } : {\n    x: 'ew-resize',\n    y: 'ns-resize',\n    xy: 'nwse-resize',\n\n    top: 'ns-resize',\n    left: 'ew-resize',\n    bottom: 'ns-resize',\n    right: 'ew-resize',\n    topleft: 'nwse-resize',\n    bottomright: 'nwse-resize',\n    topright: 'nesw-resize',\n    bottomleft: 'nesw-resize'\n  },\n\n  getCursor: function getCursor(action) {\n    if (action.axis) {\n      return resize.cursors[action.name + action.axis];\n    } else if (action.edges) {\n      var cursorKey = '';\n      var edgeNames = ['top', 'bottom', 'left', 'right'];\n\n      for (var i = 0; i < 4; i++) {\n        if (action.edges[edgeNames[i]]) {\n          cursorKey += edgeNames[i];\n        }\n      }\n\n      return resize.cursors[cursorKey];\n    }\n  }\n};\n\n// resizestart\nInteractEvent.signals.on('new', function (_ref) {\n  var iEvent = _ref.iEvent,\n      interaction = _ref.interaction;\n\n  if (iEvent.type !== 'resizestart' || !interaction.prepared.edges) {\n    return;\n  }\n\n  var startRect = interaction.target.getRect(interaction.element);\n  var resizeOptions = interaction.target.options.resize;\n\n  /*\n   * When using the `resizable.square` or `resizable.preserveAspectRatio` options, resizing from one edge\n   * will affect another. E.g. with `resizable.square`, resizing to make the right edge larger will make\n   * the bottom edge larger by the same amount. We call these 'linked' edges. Any linked edges will depend\n   * on the active edges and the edge being interacted with.\n   */\n  if (resizeOptions.square || resizeOptions.preserveAspectRatio) {\n    var linkedEdges = utils.extend({}, interaction.prepared.edges);\n\n    linkedEdges.top = linkedEdges.top || linkedEdges.left && !linkedEdges.bottom;\n    linkedEdges.left = linkedEdges.left || linkedEdges.top && !linkedEdges.right;\n    linkedEdges.bottom = linkedEdges.bottom || linkedEdges.right && !linkedEdges.top;\n    linkedEdges.right = linkedEdges.right || linkedEdges.bottom && !linkedEdges.left;\n\n    interaction.prepared._linkedEdges = linkedEdges;\n  } else {\n    interaction.prepared._linkedEdges = null;\n  }\n\n  // if using `resizable.preserveAspectRatio` option, record aspect ratio at the start of the resize\n  if (resizeOptions.preserveAspectRatio) {\n    interaction.resizeStartAspectRatio = startRect.width / startRect.height;\n  }\n\n  interaction.resizeRects = {\n    start: startRect,\n    current: utils.extend({}, startRect),\n    inverted: utils.extend({}, startRect),\n    previous: utils.extend({}, startRect),\n    delta: {\n      left: 0, right: 0, width: 0,\n      top: 0, bottom: 0, height: 0\n    }\n  };\n\n  iEvent.rect = interaction.resizeRects.inverted;\n  iEvent.deltaRect = interaction.resizeRects.delta;\n});\n\n// resizemove\nInteractEvent.signals.on('new', function (_ref2) {\n  var iEvent = _ref2.iEvent,\n      phase = _ref2.phase,\n      interaction = _ref2.interaction;\n\n  if (phase !== 'move' || !interaction.prepared.edges) {\n    return;\n  }\n\n  var resizeOptions = interaction.target.options.resize;\n  var invert = resizeOptions.invert;\n  var invertible = invert === 'reposition' || invert === 'negate';\n\n  var edges = interaction.prepared.edges;\n\n  var start = interaction.resizeRects.start;\n  var current = interaction.resizeRects.current;\n  var inverted = interaction.resizeRects.inverted;\n  var delta = interaction.resizeRects.delta;\n  var previous = utils.extend(interaction.resizeRects.previous, inverted);\n  var originalEdges = edges;\n\n  var dx = iEvent.dx;\n  var dy = iEvent.dy;\n\n  if (resizeOptions.preserveAspectRatio || resizeOptions.square) {\n    // `resize.preserveAspectRatio` takes precedence over `resize.square`\n    var startAspectRatio = resizeOptions.preserveAspectRatio ? interaction.resizeStartAspectRatio : 1;\n\n    edges = interaction.prepared._linkedEdges;\n\n    if (originalEdges.left && originalEdges.bottom || originalEdges.right && originalEdges.top) {\n      dy = -dx / startAspectRatio;\n    } else if (originalEdges.left || originalEdges.right) {\n      dy = dx / startAspectRatio;\n    } else if (originalEdges.top || originalEdges.bottom) {\n      dx = dy * startAspectRatio;\n    }\n  }\n\n  // update the 'current' rect without modifications\n  if (edges.top) {\n    current.top += dy;\n  }\n  if (edges.bottom) {\n    current.bottom += dy;\n  }\n  if (edges.left) {\n    current.left += dx;\n  }\n  if (edges.right) {\n    current.right += dx;\n  }\n\n  if (invertible) {\n    // if invertible, copy the current rect\n    utils.extend(inverted, current);\n\n    if (invert === 'reposition') {\n      // swap edge values if necessary to keep width/height positive\n      var swap = void 0;\n\n      if (inverted.top > inverted.bottom) {\n        swap = inverted.top;\n\n        inverted.top = inverted.bottom;\n        inverted.bottom = swap;\n      }\n      if (inverted.left > inverted.right) {\n        swap = inverted.left;\n\n        inverted.left = inverted.right;\n        inverted.right = swap;\n      }\n    }\n  } else {\n    // if not invertible, restrict to minimum of 0x0 rect\n    inverted.top = Math.min(current.top, start.bottom);\n    inverted.bottom = Math.max(current.bottom, start.top);\n    inverted.left = Math.min(current.left, start.right);\n    inverted.right = Math.max(current.right, start.left);\n  }\n\n  inverted.width = inverted.right - inverted.left;\n  inverted.height = inverted.bottom - inverted.top;\n\n  for (var edge in inverted) {\n    delta[edge] = inverted[edge] - previous[edge];\n  }\n\n  iEvent.edges = interaction.prepared.edges;\n  iEvent.rect = inverted;\n  iEvent.deltaRect = delta;\n});\n\n/*\\\n * Interactable.resizable\n [ method ]\n *\n * Gets or sets whether resize actions can be performed on the\n * Interactable\n *\n = (boolean) Indicates if this can be the target of resize elements\n   | var isResizeable = interact('input[type=text]').resizable();\n * or\n - options (boolean | object) #optional true/false or An object with event listeners to be fired on resize events (object makes the Interactable resizable)\n = (object) This Interactable\n   | interact(element).resizable({\n   |   onstart: function (event) {},\n   |   onmove : function (event) {},\n   |   onend  : function (event) {},\n   |\n   |   edges: {\n   |     top   : true,       // Use pointer coords to check for resize.\n   |     left  : false,      // Disable resizing from left edge.\n   |     bottom: '.resize-s',// Resize if pointer target matches selector\n   |     right : handleEl    // Resize if pointer target is the given Element\n   |   },\n   |\n   |     // Width and height can be adjusted independently. When `true`, width and\n   |     // height are adjusted at a 1:1 ratio.\n   |     square: false,\n   |\n   |     // Width and height can be adjusted independently. When `true`, width and\n   |     // height maintain the aspect ratio they had when resizing started.\n   |     preserveAspectRatio: false,\n   |\n   |   // a value of 'none' will limit the resize rect to a minimum of 0x0\n   |   // 'negate' will allow the rect to have negative width/height\n   |   // 'reposition' will keep the width/height positive by swapping\n   |   // the top and bottom edges and/or swapping the left and right edges\n   |   invert: 'none' || 'negate' || 'reposition'\n   |\n   |   // limit multiple resizes.\n   |   // See the explanation in the @Interactable.draggable example\n   |   max: Infinity,\n   |   maxPerElement: 1,\n   | });\n  \\*/\nInteractable.prototype.resizable = function (options) {\n  if (utils.is.object(options)) {\n    this.options.resize.enabled = options.enabled === false ? false : true;\n    this.setPerAction('resize', options);\n    this.setOnEvents('resize', options);\n\n    if (/^x$|^y$|^xy$/.test(options.axis)) {\n      this.options.resize.axis = options.axis;\n    } else if (options.axis === null) {\n      this.options.resize.axis = defaultOptions.resize.axis;\n    }\n\n    if (utils.is.bool(options.preserveAspectRatio)) {\n      this.options.resize.preserveAspectRatio = options.preserveAspectRatio;\n    } else if (utils.is.bool(options.square)) {\n      this.options.resize.square = options.square;\n    }\n\n    return this;\n  }\n  if (utils.is.bool(options)) {\n    this.options.resize.enabled = options;\n\n    if (!options) {\n      this.onresizestart = this.onresizestart = this.onresizeend = null;\n    }\n\n    return this;\n  }\n  return this.options.resize;\n};\n\nfunction checkResizeEdge(name, value, page, element, interactableElement, rect, margin) {\n  // false, '', undefined, null\n  if (!value) {\n    return false;\n  }\n\n  // true value, use pointer coords and element rect\n  if (value === true) {\n    // if dimensions are negative, \"switch\" edges\n    var width = utils.is.number(rect.width) ? rect.width : rect.right - rect.left;\n    var height = utils.is.number(rect.height) ? rect.height : rect.bottom - rect.top;\n\n    if (width < 0) {\n      if (name === 'left') {\n        name = 'right';\n      } else if (name === 'right') {\n        name = 'left';\n      }\n    }\n    if (height < 0) {\n      if (name === 'top') {\n        name = 'bottom';\n      } else if (name === 'bottom') {\n        name = 'top';\n      }\n    }\n\n    if (name === 'left') {\n      return page.x < (width >= 0 ? rect.left : rect.right) + margin;\n    }\n    if (name === 'top') {\n      return page.y < (height >= 0 ? rect.top : rect.bottom) + margin;\n    }\n\n    if (name === 'right') {\n      return page.x > (width >= 0 ? rect.right : rect.left) - margin;\n    }\n    if (name === 'bottom') {\n      return page.y > (height >= 0 ? rect.bottom : rect.top) - margin;\n    }\n  }\n\n  // the remaining checks require an element\n  if (!utils.is.element(element)) {\n    return false;\n  }\n\n  return utils.is.element(value)\n  // the value is an element to use as a resize handle\n  ? value === element\n  // otherwise check if element matches value as selector\n  : utils.matchesUpTo(element, value, interactableElement);\n}\n\nInteraction.signals.on('new', function (interaction) {\n  interaction.resizeAxes = 'xy';\n});\n\nInteractEvent.signals.on('set-delta', function (_ref3) {\n  var interaction = _ref3.interaction,\n      iEvent = _ref3.iEvent,\n      action = _ref3.action;\n\n  if (action !== 'resize' || !interaction.resizeAxes) {\n    return;\n  }\n\n  var options = interaction.target.options;\n\n  if (options.resize.square) {\n    if (interaction.resizeAxes === 'y') {\n      iEvent.dx = iEvent.dy;\n    } else {\n      iEvent.dy = iEvent.dx;\n    }\n    iEvent.axes = 'xy';\n  } else {\n    iEvent.axes = interaction.resizeAxes;\n\n    if (interaction.resizeAxes === 'x') {\n      iEvent.dy = 0;\n    } else if (interaction.resizeAxes === 'y') {\n      iEvent.dx = 0;\n    }\n  }\n});\n\nactions.resize = resize;\nactions.names.push('resize');\nutils.merge(Interactable.eventTypes, ['resizestart', 'resizemove', 'resizeinertiastart', 'resizeinertiaresume', 'resizeend']);\nactions.methodDict.resize = 'resizable';\n\ndefaultOptions.resize = resize.defaults;\n\nmodule.exports = resize;\n\n},{\"../InteractEvent\":3,\"../Interactable\":4,\"../Interaction\":5,\"../defaultOptions\":18,\"../utils\":44,\"../utils/browser\":37,\"./base\":6}],11:[function(require,module,exports){\n'use strict';\n\nvar raf = require('./utils/raf');\nvar getWindow = require('./utils/window').getWindow;\nvar is = require('./utils/is');\nvar domUtils = require('./utils/domUtils');\nvar Interaction = require('./Interaction');\nvar defaultOptions = require('./defaultOptions');\n\nvar autoScroll = {\n  defaults: {\n    enabled: false,\n    container: null, // the item that is scrolled (Window or HTMLElement)\n    margin: 60,\n    speed: 300 // the scroll speed in pixels per second\n  },\n\n  interaction: null,\n  i: null, // the handle returned by window.setInterval\n  x: 0, y: 0, // Direction each pulse is to scroll in\n\n  isScrolling: false,\n  prevTime: 0,\n\n  start: function start(interaction) {\n    autoScroll.isScrolling = true;\n    raf.cancel(autoScroll.i);\n\n    autoScroll.interaction = interaction;\n    autoScroll.prevTime = new Date().getTime();\n    autoScroll.i = raf.request(autoScroll.scroll);\n  },\n\n  stop: function stop() {\n    autoScroll.isScrolling = false;\n    raf.cancel(autoScroll.i);\n  },\n\n  // scroll the window by the values in scroll.x/y\n  scroll: function scroll() {\n    var options = autoScroll.interaction.target.options[autoScroll.interaction.prepared.name].autoScroll;\n    var container = options.container || getWindow(autoScroll.interaction.element);\n    var now = new Date().getTime();\n    // change in time in seconds\n    var dt = (now - autoScroll.prevTime) / 1000;\n    // displacement\n    var s = options.speed * dt;\n\n    if (s >= 1) {\n      if (is.window(container)) {\n        container.scrollBy(autoScroll.x * s, autoScroll.y * s);\n      } else if (container) {\n        container.scrollLeft += autoScroll.x * s;\n        container.scrollTop += autoScroll.y * s;\n      }\n\n      autoScroll.prevTime = now;\n    }\n\n    if (autoScroll.isScrolling) {\n      raf.cancel(autoScroll.i);\n      autoScroll.i = raf.request(autoScroll.scroll);\n    }\n  },\n  check: function check(interactable, actionName) {\n    var options = interactable.options;\n\n    return options[actionName].autoScroll && options[actionName].autoScroll.enabled;\n  },\n  onInteractionMove: function onInteractionMove(_ref) {\n    var interaction = _ref.interaction,\n        pointer = _ref.pointer;\n\n    if (!(interaction.interacting() && autoScroll.check(interaction.target, interaction.prepared.name))) {\n      return;\n    }\n\n    if (interaction.simulation) {\n      autoScroll.x = autoScroll.y = 0;\n      return;\n    }\n\n    var top = void 0;\n    var right = void 0;\n    var bottom = void 0;\n    var left = void 0;\n\n    var options = interaction.target.options[interaction.prepared.name].autoScroll;\n    var container = options.container || getWindow(interaction.element);\n\n    if (is.window(container)) {\n      left = pointer.clientX < autoScroll.margin;\n      top = pointer.clientY < autoScroll.margin;\n      right = pointer.clientX > container.innerWidth - autoScroll.margin;\n      bottom = pointer.clientY > container.innerHeight - autoScroll.margin;\n    } else {\n      var rect = domUtils.getElementClientRect(container);\n\n      left = pointer.clientX < rect.left + autoScroll.margin;\n      top = pointer.clientY < rect.top + autoScroll.margin;\n      right = pointer.clientX > rect.right - autoScroll.margin;\n      bottom = pointer.clientY > rect.bottom - autoScroll.margin;\n    }\n\n    autoScroll.x = right ? 1 : left ? -1 : 0;\n    autoScroll.y = bottom ? 1 : top ? -1 : 0;\n\n    if (!autoScroll.isScrolling) {\n      // set the autoScroll properties to those of the target\n      autoScroll.margin = options.margin;\n      autoScroll.speed = options.speed;\n\n      autoScroll.start(interaction);\n    }\n  }\n};\n\nInteraction.signals.on('stop-active', function () {\n  autoScroll.stop();\n});\n\nInteraction.signals.on('action-move', autoScroll.onInteractionMove);\n\ndefaultOptions.perAction.autoScroll = autoScroll.defaults;\n\nmodule.exports = autoScroll;\n\n},{\"./Interaction\":5,\"./defaultOptions\":18,\"./utils/domUtils\":39,\"./utils/is\":46,\"./utils/raf\":50,\"./utils/window\":52}],12:[function(require,module,exports){\n'use strict';\n\nvar Interactable = require('../Interactable');\nvar actions = require('../actions/base');\nvar is = require('../utils/is');\nvar domUtils = require('../utils/domUtils');\n\nInteractable.prototype.getAction = function (pointer, event, interaction, element) {\n  var action = this.defaultActionChecker(pointer, event, interaction, element);\n\n  if (this.options.actionChecker) {\n    return this.options.actionChecker(pointer, event, action, this, element, interaction);\n  }\n\n  return action;\n};\n\n/*\\\n * Interactable.ignoreFrom\n [ method ]\n *\n * If the target of the `mousedown`, `pointerdown` or `touchstart`\n * event or any of it's parents match the given CSS selector or\n * Element, no drag/resize/gesture is started.\n *\n - newValue (string | Element | null) #optional a CSS selector string, an Element or `null` to not ignore any elements\n = (string | Element | object) The current ignoreFrom value or this Interactable\n **\n | interact(element, { ignoreFrom: document.getElementById('no-action') });\n | // or\n | interact(element).ignoreFrom('input, textarea, a');\n\\*/\nInteractable.prototype.ignoreFrom = function (newValue) {\n  return this._backCompatOption('ignoreFrom', newValue);\n};\n\n/*\\\n * Interactable.allowFrom\n [ method ]\n *\n * A drag/resize/gesture is started only If the target of the\n * `mousedown`, `pointerdown` or `touchstart` event or any of it's\n * parents match the given CSS selector or Element.\n *\n - newValue (string | Element | null) #optional a CSS selector string, an Element or `null` to allow from any element\n = (string | Element | object) The current allowFrom value or this Interactable\n **\n | interact(element, { allowFrom: document.getElementById('drag-handle') });\n | // or\n | interact(element).allowFrom('.handle');\n\\*/\nInteractable.prototype.allowFrom = function (newValue) {\n  return this._backCompatOption('allowFrom', newValue);\n};\n\nInteractable.prototype.testIgnore = function (ignoreFrom, interactableElement, element) {\n  if (!ignoreFrom || !is.element(element)) {\n    return false;\n  }\n\n  if (is.string(ignoreFrom)) {\n    return domUtils.matchesUpTo(element, ignoreFrom, interactableElement);\n  } else if (is.element(ignoreFrom)) {\n    return domUtils.nodeContains(ignoreFrom, element);\n  }\n\n  return false;\n};\n\nInteractable.prototype.testAllow = function (allowFrom, interactableElement, element) {\n  if (!allowFrom) {\n    return true;\n  }\n\n  if (!is.element(element)) {\n    return false;\n  }\n\n  if (is.string(allowFrom)) {\n    return domUtils.matchesUpTo(element, allowFrom, interactableElement);\n  } else if (is.element(allowFrom)) {\n    return domUtils.nodeContains(allowFrom, element);\n  }\n\n  return false;\n};\n\nInteractable.prototype.testIgnoreAllow = function (options, interactableElement, eventTarget) {\n  return !this.testIgnore(options.ignoreFrom, interactableElement, eventTarget) && this.testAllow(options.allowFrom, interactableElement, eventTarget);\n};\n\n/*\\\n * Interactable.actionChecker\n [ method ]\n *\n * Gets or sets the function used to check action to be performed on\n * pointerDown\n *\n - checker (function | null) #optional A function which takes a pointer event, defaultAction string, interactable, element and interaction as parameters and returns an object with name property 'drag' 'resize' or 'gesture' and optionally an `edges` object with boolean 'top', 'left', 'bottom' and right props.\n = (Function | Interactable) The checker function or this Interactable\n *\n | interact('.resize-drag')\n |   .resizable(true)\n |   .draggable(true)\n |   .actionChecker(function (pointer, event, action, interactable, element, interaction) {\n |\n |   if (interact.matchesSelector(event.target, '.drag-handle') {\n |     // force drag with handle target\n |     action.name = drag;\n |   }\n |   else {\n |     // resize from the top and right edges\n |     action.name  = 'resize';\n |     action.edges = { top: true, right: true };\n |   }\n |\n |   return action;\n | });\n\\*/\nInteractable.prototype.actionChecker = function (checker) {\n  if (is.function(checker)) {\n    this.options.actionChecker = checker;\n\n    return this;\n  }\n\n  if (checker === null) {\n    delete this.options.actionChecker;\n\n    return this;\n  }\n\n  return this.options.actionChecker;\n};\n\n/*\\\n * Interactable.styleCursor\n [ method ]\n *\n * Returns or sets whether the the cursor should be changed depending on the\n * action that would be performed if the mouse were pressed and dragged.\n *\n - newValue (boolean) #optional\n = (boolean | Interactable) The current setting or this Interactable\n\\*/\nInteractable.prototype.styleCursor = function (newValue) {\n  if (is.bool(newValue)) {\n    this.options.styleCursor = newValue;\n\n    return this;\n  }\n\n  if (newValue === null) {\n    delete this.options.styleCursor;\n\n    return this;\n  }\n\n  return this.options.styleCursor;\n};\n\nInteractable.prototype.defaultActionChecker = function (pointer, event, interaction, element) {\n  var rect = this.getRect(element);\n  var action = null;\n\n  for (var _iterator = actions.names, _isArray = Array.isArray(_iterator), _i = 0, _iterator = _isArray ? _iterator : _iterator[Symbol.iterator]();;) {\n    var _ref;\n\n    if (_isArray) {\n      if (_i >= _iterator.length) break;\n      _ref = _iterator[_i++];\n    } else {\n      _i = _iterator.next();\n      if (_i.done) break;\n      _ref = _i.value;\n    }\n\n    var actionName = _ref;\n\n    // check mouseButton setting if the pointer is down\n    if (interaction.pointerIsDown && interaction.mouse && (event.buttons & this.options[actionName].mouseButtons) === 0) {\n      continue;\n    }\n\n    action = actions[actionName].checker(pointer, event, this, element, interaction, rect);\n\n    if (action) {\n      return action;\n    }\n  }\n};\n\n},{\"../Interactable\":4,\"../actions/base\":6,\"../utils/domUtils\":39,\"../utils/is\":46}],13:[function(require,module,exports){\n'use strict';\n\nvar interact = require('../interact');\nvar Interactable = require('../Interactable');\nvar Interaction = require('../Interaction');\nvar actions = require('../actions/base');\nvar defaultOptions = require('../defaultOptions');\nvar browser = require('../utils/browser');\nvar scope = require('../scope');\nvar utils = require('../utils');\nvar signals = require('../utils/Signals').new();\n\nrequire('./InteractableMethods');\n\nvar autoStart = {\n  signals: signals,\n  withinInteractionLimit: withinInteractionLimit,\n  // Allow this many interactions to happen simultaneously\n  maxInteractions: Infinity,\n  defaults: {\n    perAction: {\n      manualStart: false,\n      max: Infinity,\n      maxPerElement: 1,\n      allowFrom: null,\n      ignoreFrom: null\n    }\n  },\n  setActionDefaults: function setActionDefaults(action) {\n    utils.extend(action.defaults, autoStart.defaults.perAction);\n  }\n};\n\n// set cursor style on mousedown\nInteraction.signals.on('down', function (_ref) {\n  var interaction = _ref.interaction,\n      pointer = _ref.pointer,\n      event = _ref.event,\n      eventTarget = _ref.eventTarget;\n\n  if (interaction.interacting()) {\n    return;\n  }\n\n  var actionInfo = getActionInfo(interaction, pointer, event, eventTarget);\n  prepare(interaction, actionInfo);\n});\n\n// set cursor style on mousemove\nInteraction.signals.on('move', function (_ref2) {\n  var interaction = _ref2.interaction,\n      pointer = _ref2.pointer,\n      event = _ref2.event,\n      eventTarget = _ref2.eventTarget;\n\n  if (!interaction.mouse || interaction.pointerIsDown || interaction.interacting()) {\n    return;\n  }\n\n  var actionInfo = getActionInfo(interaction, pointer, event, eventTarget);\n  prepare(interaction, actionInfo);\n});\n\nInteraction.signals.on('move', function (arg) {\n  var interaction = arg.interaction,\n      event = arg.event;\n\n\n  if (!interaction.pointerIsDown || interaction.interacting() || !interaction.pointerWasMoved || !interaction.prepared.name) {\n    return;\n  }\n\n  signals.fire('before-start', arg);\n\n  var target = interaction.target;\n\n  if (interaction.prepared.name && target) {\n    // check manualStart and interaction limit\n    if (target.options[interaction.prepared.name].manualStart || !withinInteractionLimit(target, interaction.element, interaction.prepared)) {\n      interaction.stop(event);\n    } else {\n      interaction.start(interaction.prepared, target, interaction.element);\n    }\n  }\n});\n\n// Check if the current target supports the action.\n// If so, return the validated action. Otherwise, return null\nfunction validateAction(action, interactable, element, eventTarget) {\n  if (utils.is.object(action) && interactable.testIgnoreAllow(interactable.options[action.name], element, eventTarget) && interactable.options[action.name].enabled && withinInteractionLimit(interactable, element, action)) {\n    return action;\n  }\n\n  return null;\n}\n\nfunction validateSelector(interaction, pointer, event, matches, matchElements, eventTarget) {\n  for (var i = 0, len = matches.length; i < len; i++) {\n    var match = matches[i];\n    var matchElement = matchElements[i];\n    var action = validateAction(match.getAction(pointer, event, interaction, matchElement), match, matchElement, eventTarget);\n\n    if (action) {\n      return {\n        action: action,\n        target: match,\n        element: matchElement\n      };\n    }\n  }\n\n  return {};\n}\n\nfunction getActionInfo(interaction, pointer, event, eventTarget) {\n  var matches = [];\n  var matchElements = [];\n\n  var element = eventTarget;\n  var action = null;\n\n  function pushMatches(interactable, selector, context) {\n    var elements = browser.useMatchesSelectorPolyfill ? context.querySelectorAll(selector) : undefined;\n\n    if (utils.matchesSelector(element, selector, elements)) {\n\n      matches.push(interactable);\n      matchElements.push(element);\n    }\n  }\n\n  while (utils.is.element(element)) {\n    matches = [];\n    matchElements = [];\n\n    var elementInteractable = scope.interactables.get(element);\n\n    if (elementInteractable && (action = validateAction(elementInteractable.getAction(pointer, event, interaction, element, eventTarget), elementInteractable, element, eventTarget)) && !elementInteractable.options[action.name].manualStart) {\n      return {\n        element: element,\n        action: action,\n        target: elementInteractable\n      };\n    } else {\n      scope.interactables.forEachSelector(pushMatches, element);\n\n      var actionInfo = validateSelector(interaction, pointer, event, matches, matchElements, eventTarget);\n\n      if (actionInfo.action && !actionInfo.target.options[actionInfo.action.name].manualStart) {\n        return actionInfo;\n      }\n    }\n\n    element = utils.parentNode(element);\n  }\n\n  return {};\n}\n\nfunction prepare(interaction, _ref3) {\n  var action = _ref3.action,\n      target = _ref3.target,\n      element = _ref3.element;\n\n  action = action || {};\n\n  if (interaction.target && interaction.target.options.styleCursor) {\n    interaction.target._doc.documentElement.style.cursor = '';\n  }\n\n  interaction.target = target;\n  interaction.element = element;\n  utils.copyAction(interaction.prepared, action);\n\n  if (target && target.options.styleCursor) {\n    var cursor = action ? actions[action.name].getCursor(action) : '';\n    interaction.target._doc.documentElement.style.cursor = cursor;\n  }\n\n  signals.fire('prepared', { interaction: interaction });\n}\n\nInteraction.signals.on('stop', function (_ref4) {\n  var interaction = _ref4.interaction;\n\n  var target = interaction.target;\n\n  if (target && target.options.styleCursor) {\n    target._doc.documentElement.style.cursor = '';\n  }\n});\n\nInteractable.prototype.getAction = function (pointer, event, interaction, element) {\n  var action = this.defaultActionChecker(pointer, event, interaction, element);\n\n  if (this.options.actionChecker) {\n    return this.options.actionChecker(pointer, event, action, this, element, interaction);\n  }\n\n  return action;\n};\n\n/*\\\n * Interactable.actionChecker\n [ method ]\n *\n * Gets or sets the function used to check action to be performed on\n * pointerDown\n *\n - checker (function | null) #optional A function which takes a pointer event, defaultAction string, interactable, element and interaction as parameters and returns an object with name property 'drag' 'resize' or 'gesture' and optionally an `edges` object with boolean 'top', 'left', 'bottom' and right props.\n = (Function | Interactable) The checker function or this Interactable\n *\n | interact('.resize-drag')\n |   .resizable(true)\n |   .draggable(true)\n |   .actionChecker(function (pointer, event, action, interactable, element, interaction) {\n |\n |   if (interact.matchesSelector(event.target, '.drag-handle') {\n |     // force drag with handle target\n |     action.name = drag;\n |   }\n |   else {\n |     // resize from the top and right edges\n |     action.name  = 'resize';\n |     action.edges = { top: true, right: true };\n |   }\n |\n |   return action;\n | });\n\\*/\nInteractable.prototype.actionChecker = function (checker) {\n  if (utils.is.function(checker)) {\n    this.options.actionChecker = checker;\n\n    return this;\n  }\n\n  if (checker === null) {\n    delete this.options.actionChecker;\n\n    return this;\n  }\n\n  return this.options.actionChecker;\n};\n\n/*\\\n * Interactable.styleCursor\n [ method ]\n *\n * Returns or sets whether the the cursor should be changed depending on the\n * action that would be performed if the mouse were pressed and dragged.\n *\n - newValue (boolean) #optional\n = (boolean | Interactable) The current setting or this Interactable\n\\*/\nInteractable.prototype.styleCursor = function (newValue) {\n  if (utils.is.bool(newValue)) {\n    this.options.styleCursor = newValue;\n\n    return this;\n  }\n\n  if (newValue === null) {\n    delete this.options.styleCursor;\n\n    return this;\n  }\n\n  return this.options.styleCursor;\n};\n\nInteractable.prototype.defaultActionChecker = function (pointer, event, interaction, element) {\n  var rect = this.getRect(element);\n  var buttons = event.buttons || {\n    0: 1,\n    1: 4,\n    3: 8,\n    4: 16\n  }[event.button];\n  var action = null;\n\n  for (var _iterator = actions.names, _isArray = Array.isArray(_iterator), _i = 0, _iterator = _isArray ? _iterator : _iterator[Symbol.iterator]();;) {\n    var _ref5;\n\n    if (_isArray) {\n      if (_i >= _iterator.length) break;\n      _ref5 = _iterator[_i++];\n    } else {\n      _i = _iterator.next();\n      if (_i.done) break;\n      _ref5 = _i.value;\n    }\n\n    var actionName = _ref5;\n\n    // check mouseButton setting if the pointer is down\n    if (interaction.pointerIsDown && interaction.mouse && (buttons & this.options[actionName].mouseButtons) === 0) {\n      continue;\n    }\n\n    action = actions[actionName].checker(pointer, event, this, element, interaction, rect);\n\n    if (action) {\n      return action;\n    }\n  }\n};\n\nfunction withinInteractionLimit(interactable, element, action) {\n  var options = interactable.options;\n  var maxActions = options[action.name].max;\n  var maxPerElement = options[action.name].maxPerElement;\n  var activeInteractions = 0;\n  var targetCount = 0;\n  var targetElementCount = 0;\n\n  // no actions if any of these values == 0\n  if (!(maxActions && maxPerElement && autoStart.maxInteractions)) {\n    return;\n  }\n\n  for (var i = 0, len = scope.interactions.length; i < len; i++) {\n    var interaction = scope.interactions[i];\n    var otherAction = interaction.prepared.name;\n\n    if (!interaction.interacting()) {\n      continue;\n    }\n\n    activeInteractions++;\n\n    if (activeInteractions >= autoStart.maxInteractions) {\n      return false;\n    }\n\n    if (interaction.target !== interactable) {\n      continue;\n    }\n\n    targetCount += otherAction === action.name | 0;\n\n    if (targetCount >= maxActions) {\n      return false;\n    }\n\n    if (interaction.element === element) {\n      targetElementCount++;\n\n      if (otherAction !== action.name || targetElementCount >= maxPerElement) {\n        return false;\n      }\n    }\n  }\n\n  return autoStart.maxInteractions > 0;\n}\n\n/*\\\n * interact.maxInteractions\n [ method ]\n **\n * Returns or sets the maximum number of concurrent interactions allowed.\n * By default only 1 interaction is allowed at a time (for backwards\n * compatibility). To allow multiple interactions on the same Interactables\n * and elements, you need to enable it in the draggable, resizable and\n * gesturable `'max'` and `'maxPerElement'` options.\n **\n - newValue (number) #optional Any number. newValue <= 0 means no interactions.\n\\*/\ninteract.maxInteractions = function (newValue) {\n  if (utils.is.number(newValue)) {\n    autoStart.maxInteractions = newValue;\n\n    return this;\n  }\n\n  return autoStart.maxInteractions;\n};\n\nInteractable.settingsMethods.push('styleCursor');\nInteractable.settingsMethods.push('actionChecker');\nInteractable.settingsMethods.push('ignoreFrom');\nInteractable.settingsMethods.push('allowFrom');\n\ndefaultOptions.base.actionChecker = null;\ndefaultOptions.base.styleCursor = true;\n\nutils.extend(defaultOptions.perAction, autoStart.defaults.perAction);\n\nmodule.exports = autoStart;\n\n},{\"../Interactable\":4,\"../Interaction\":5,\"../actions/base\":6,\"../defaultOptions\":18,\"../interact\":21,\"../scope\":34,\"../utils\":44,\"../utils/Signals\":35,\"../utils/browser\":37,\"./InteractableMethods\":12}],14:[function(require,module,exports){\n'use strict';\n\nvar autoStart = require('./base');\nvar Interaction = require('../Interaction');\n\nInteraction.signals.on('new', function (interaction) {\n  interaction.delayTimer = null;\n});\n\nautoStart.signals.on('prepared', function (_ref) {\n  var interaction = _ref.interaction;\n\n  var actionName = interaction.prepared.name;\n\n  if (!actionName) {\n    return;\n  }\n\n  var delay = interaction.target.options[actionName].delay;\n\n  if (delay > 0) {\n    interaction.delayTimer = setTimeout(function () {\n      interaction.start(interaction.prepared, interaction.target, interaction.element);\n    }, delay);\n  }\n});\n\nInteraction.signals.on('move', function (_ref2) {\n  var interaction = _ref2.interaction,\n      duplicate = _ref2.duplicate;\n\n  if (interaction.pointerWasMoved && !duplicate) {\n    clearTimeout(interaction.delayTimer);\n  }\n});\n\n// prevent regular down->move autoStart\nautoStart.signals.on('before-start', function (_ref3) {\n  var interaction = _ref3.interaction;\n\n  var actionName = interaction.prepared.name;\n\n  if (!actionName) {\n    return;\n  }\n\n  var delay = interaction.target.options[actionName].delay;\n\n  if (delay > 0) {\n    interaction.prepared.name = null;\n  }\n});\n\n},{\"../Interaction\":5,\"./base\":13}],15:[function(require,module,exports){\n'use strict';\n\nvar autoStart = require('./base');\nvar scope = require('../scope');\nvar browser = require('../utils/browser');\nvar is = require('../utils/is');\n\nvar _require = require('../utils/domUtils'),\n    matchesSelector = _require.matchesSelector,\n    parentNode = _require.parentNode;\n\nautoStart.setActionDefaults(require('../actions/drag'));\n\nautoStart.signals.on('before-start', function (_ref) {\n  var interaction = _ref.interaction,\n      eventTarget = _ref.eventTarget,\n      dx = _ref.dx,\n      dy = _ref.dy;\n\n  if (interaction.prepared.name !== 'drag') {\n    return;\n  }\n\n  // check if a drag is in the correct axis\n  var absX = Math.abs(dx);\n  var absY = Math.abs(dy);\n  var options = interaction.target.options.drag;\n  var startAxis = options.startAxis;\n  var currentAxis = absX > absY ? 'x' : absX < absY ? 'y' : 'xy';\n\n  interaction.prepared.axis = options.lockAxis === 'start' ? currentAxis[0] // always lock to one axis even if currentAxis === 'xy'\n  : options.lockAxis;\n\n  // if the movement isn't in the startAxis of the interactable\n  if (currentAxis !== 'xy' && startAxis !== 'xy' && startAxis !== currentAxis) {\n    // cancel the prepared action\n    interaction.prepared.name = null;\n\n    // then try to get a drag from another ineractable\n\n    if (!interaction.prepared.name) {\n\n      var element = eventTarget;\n\n      var getDraggable = function getDraggable(interactable, selector, context) {\n        var elements = browser.useMatchesSelectorPolyfill ? context.querySelectorAll(selector) : undefined;\n\n        if (interactable === interaction.target) {\n          return;\n        }\n\n        if (!options.manualStart && !interactable.testIgnoreAllow(options, element, eventTarget) && matchesSelector(element, selector, elements)) {\n\n          var _action = interactable.getAction(interaction.downPointer, interaction.downEvent, interaction, element);\n\n          if (_action && _action.name === 'drag' && checkStartAxis(currentAxis, interactable) && autoStart.validateAction(_action, interactable, element, eventTarget)) {\n\n            return interactable;\n          }\n        }\n      };\n\n      var action = null;\n\n      // check all interactables\n      while (is.element(element)) {\n        var elementInteractable = scope.interactables.get(element);\n\n        if (elementInteractable && elementInteractable !== interaction.target && !elementInteractable.options.drag.manualStart) {\n\n          action = elementInteractable.getAction(interaction.downPointer, interaction.downEvent, interaction, element);\n        }\n        if (action && action.name === 'drag' && checkStartAxis(currentAxis, elementInteractable)) {\n\n          interaction.prepared.name = 'drag';\n          interaction.target = elementInteractable;\n          interaction.element = element;\n          break;\n        }\n\n        var selectorInteractable = scope.interactables.forEachSelector(getDraggable, element);\n\n        if (selectorInteractable) {\n          interaction.prepared.name = 'drag';\n          interaction.target = selectorInteractable;\n          interaction.element = element;\n          break;\n        }\n\n        element = parentNode(element);\n      }\n    }\n  }\n});\n\nfunction checkStartAxis(startAxis, interactable) {\n  if (!interactable) {\n    return false;\n  }\n\n  var thisAxis = interactable.options.drag.startAxis;\n\n  return startAxis === 'xy' || thisAxis === 'xy' || thisAxis === startAxis;\n}\n\n},{\"../actions/drag\":7,\"../scope\":34,\"../utils/browser\":37,\"../utils/domUtils\":39,\"../utils/is\":46,\"./base\":13}],16:[function(require,module,exports){\n'use strict';\n\nrequire('./base').setActionDefaults(require('../actions/gesture'));\n\n},{\"../actions/gesture\":9,\"./base\":13}],17:[function(require,module,exports){\n'use strict';\n\nrequire('./base').setActionDefaults(require('../actions/resize'));\n\n},{\"../actions/resize\":10,\"./base\":13}],18:[function(require,module,exports){\n'use strict';\n\nmodule.exports = {\n  base: {\n    accept: null,\n    preventDefault: 'auto',\n    deltaSource: 'page'\n  },\n\n  perAction: {\n    origin: { x: 0, y: 0 },\n\n    // only allow left button by default\n    // see https://developer.mozilla.org/en-US/docs/Web/API/MouseEvent/buttons#Return_value\n    mouseButtons: 1,\n\n    inertia: {\n      enabled: false,\n      resistance: 10, // the lambda in exponential decay\n      minSpeed: 100, // target speed must be above this for inertia to start\n      endSpeed: 10, // the speed at which inertia is slow enough to stop\n      allowResume: true, // allow resuming an action in inertia phase\n      smoothEndDuration: 300 // animate to snap/restrict endOnly if there's no inertia\n    }\n  }\n};\n\n},{}],19:[function(require,module,exports){\n'use strict';\n\n/* browser entry point */\n\n// Legacy browser support\nrequire('./legacyBrowsers');\n\n// inertia\nrequire('./inertia');\n\n// modifiers\nrequire('./modifiers/snap');\nrequire('./modifiers/restrict');\n\n// pointerEvents\nrequire('./pointerEvents/base');\nrequire('./pointerEvents/holdRepeat');\nrequire('./pointerEvents/interactableTargets');\n\n// delay\nrequire('./autoStart/delay');\n\n// actions\nrequire('./actions/gesture');\nrequire('./actions/resize');\nrequire('./actions/drag');\nrequire('./actions/drop');\n\n// load these modifiers after resize is loaded\nrequire('./modifiers/snapSize');\nrequire('./modifiers/restrictEdges');\nrequire('./modifiers/restrictSize');\n\n// autoStart actions\nrequire('./autoStart/gesture');\nrequire('./autoStart/resize');\nrequire('./autoStart/drag');\n\n// Interactable preventDefault setting\nrequire('./interactablePreventDefault.js');\n\n// autoScroll\nrequire('./autoScroll');\n\n// export interact\nmodule.exports = require('./interact');\n\n},{\"./actions/drag\":7,\"./actions/drop\":8,\"./actions/gesture\":9,\"./actions/resize\":10,\"./autoScroll\":11,\"./autoStart/delay\":14,\"./autoStart/drag\":15,\"./autoStart/gesture\":16,\"./autoStart/resize\":17,\"./inertia\":20,\"./interact\":21,\"./interactablePreventDefault.js\":22,\"./legacyBrowsers\":23,\"./modifiers/restrict\":25,\"./modifiers/restrictEdges\":26,\"./modifiers/restrictSize\":27,\"./modifiers/snap\":28,\"./modifiers/snapSize\":29,\"./pointerEvents/base\":31,\"./pointerEvents/holdRepeat\":32,\"./pointerEvents/interactableTargets\":33}],20:[function(require,module,exports){\n'use strict';\n\nvar InteractEvent = require('./InteractEvent');\nvar Interaction = require('./Interaction');\nvar modifiers = require('./modifiers');\nvar utils = require('./utils');\nvar animationFrame = require('./utils/raf');\n\nInteraction.signals.on('new', function (interaction) {\n  interaction.inertiaStatus = {\n    active: false,\n    smoothEnd: false,\n    allowResume: false,\n\n    startEvent: null,\n    upCoords: {},\n\n    xe: 0, ye: 0,\n    sx: 0, sy: 0,\n\n    t0: 0,\n    vx0: 0, vys: 0,\n    duration: 0,\n\n    lambda_v0: 0,\n    one_ve_v0: 0,\n    i: null\n  };\n\n  interaction.boundInertiaFrame = function () {\n    return inertiaFrame.apply(interaction);\n  };\n  interaction.boundSmoothEndFrame = function () {\n    return smoothEndFrame.apply(interaction);\n  };\n});\n\nInteraction.signals.on('down', function (_ref) {\n  var interaction = _ref.interaction,\n      event = _ref.event,\n      pointer = _ref.pointer,\n      eventTarget = _ref.eventTarget;\n\n  var status = interaction.inertiaStatus;\n\n  // Check if the down event hits the current inertia target\n  if (status.active) {\n    var element = eventTarget;\n\n    // climb up the DOM tree from the event target\n    while (utils.is.element(element)) {\n\n      // if interaction element is the current inertia target element\n      if (element === interaction.element) {\n        // stop inertia\n        animationFrame.cancel(status.i);\n        status.active = false;\n        interaction.simulation = null;\n\n        // update pointers to the down event's coordinates\n        interaction.updatePointer(pointer);\n        utils.setCoords(interaction.curCoords, interaction.pointers);\n\n        // fire appropriate signals\n        var signalArg = { interaction: interaction };\n        Interaction.signals.fire('before-action-move', signalArg);\n        Interaction.signals.fire('action-resume', signalArg);\n\n        // fire a reume event\n        var resumeEvent = new InteractEvent(interaction, event, interaction.prepared.name, 'inertiaresume', interaction.element);\n\n        interaction.target.fire(resumeEvent);\n        interaction.prevEvent = resumeEvent;\n        modifiers.resetStatuses(interaction.modifierStatuses);\n\n        utils.copyCoords(interaction.prevCoords, interaction.curCoords);\n        break;\n      }\n\n      element = utils.parentNode(element);\n    }\n  }\n});\n\nInteraction.signals.on('up', function (_ref2) {\n  var interaction = _ref2.interaction,\n      event = _ref2.event;\n\n  var status = interaction.inertiaStatus;\n\n  if (!interaction.interacting() || status.active) {\n    return;\n  }\n\n  var target = interaction.target;\n  var options = target && target.options;\n  var inertiaOptions = options && interaction.prepared.name && options[interaction.prepared.name].inertia;\n\n  var now = new Date().getTime();\n  var statuses = {};\n  var page = utils.extend({}, interaction.curCoords.page);\n  var pointerSpeed = interaction.pointerDelta.client.speed;\n\n  var smoothEnd = false;\n  var modifierResult = void 0;\n\n  // check if inertia should be started\n  var inertiaPossible = inertiaOptions && inertiaOptions.enabled && interaction.prepared.name !== 'gesture' && event !== status.startEvent;\n\n  var inertia = inertiaPossible && now - interaction.curCoords.timeStamp < 50 && pointerSpeed > inertiaOptions.minSpeed && pointerSpeed > inertiaOptions.endSpeed;\n\n  var modifierArg = {\n    interaction: interaction,\n    pageCoords: page,\n    statuses: statuses,\n    preEnd: true,\n    requireEndOnly: true\n  };\n\n  // smoothEnd\n  if (inertiaPossible && !inertia) {\n    modifiers.resetStatuses(statuses);\n\n    modifierResult = modifiers.setAll(modifierArg);\n\n    if (modifierResult.shouldMove && modifierResult.locked) {\n      smoothEnd = true;\n    }\n  }\n\n  if (!(inertia || smoothEnd)) {\n    return;\n  }\n\n  utils.copyCoords(status.upCoords, interaction.curCoords);\n\n  interaction.pointers[0] = status.startEvent = new InteractEvent(interaction, event, interaction.prepared.name, 'inertiastart', interaction.element);\n\n  status.t0 = now;\n\n  status.active = true;\n  status.allowResume = inertiaOptions.allowResume;\n  interaction.simulation = status;\n\n  target.fire(status.startEvent);\n\n  if (inertia) {\n    status.vx0 = interaction.pointerDelta.client.vx;\n    status.vy0 = interaction.pointerDelta.client.vy;\n    status.v0 = pointerSpeed;\n\n    calcInertia(interaction, status);\n\n    utils.extend(page, interaction.curCoords.page);\n\n    page.x += status.xe;\n    page.y += status.ye;\n\n    modifiers.resetStatuses(statuses);\n\n    modifierResult = modifiers.setAll(modifierArg);\n\n    status.modifiedXe += modifierResult.dx;\n    status.modifiedYe += modifierResult.dy;\n\n    status.i = animationFrame.request(interaction.boundInertiaFrame);\n  } else {\n    status.smoothEnd = true;\n    status.xe = modifierResult.dx;\n    status.ye = modifierResult.dy;\n\n    status.sx = status.sy = 0;\n\n    status.i = animationFrame.request(interaction.boundSmoothEndFrame);\n  }\n});\n\nInteraction.signals.on('stop-active', function (_ref3) {\n  var interaction = _ref3.interaction;\n\n  var status = interaction.inertiaStatus;\n\n  if (status.active) {\n    animationFrame.cancel(status.i);\n    status.active = false;\n    interaction.simulation = null;\n  }\n});\n\nfunction calcInertia(interaction, status) {\n  var inertiaOptions = interaction.target.options[interaction.prepared.name].inertia;\n  var lambda = inertiaOptions.resistance;\n  var inertiaDur = -Math.log(inertiaOptions.endSpeed / status.v0) / lambda;\n\n  status.x0 = interaction.prevEvent.pageX;\n  status.y0 = interaction.prevEvent.pageY;\n  status.t0 = status.startEvent.timeStamp / 1000;\n  status.sx = status.sy = 0;\n\n  status.modifiedXe = status.xe = (status.vx0 - inertiaDur) / lambda;\n  status.modifiedYe = status.ye = (status.vy0 - inertiaDur) / lambda;\n  status.te = inertiaDur;\n\n  status.lambda_v0 = lambda / status.v0;\n  status.one_ve_v0 = 1 - inertiaOptions.endSpeed / status.v0;\n}\n\nfunction inertiaFrame() {\n  updateInertiaCoords(this);\n  utils.setCoordDeltas(this.pointerDelta, this.prevCoords, this.curCoords);\n\n  var status = this.inertiaStatus;\n  var options = this.target.options[this.prepared.name].inertia;\n  var lambda = options.resistance;\n  var t = new Date().getTime() / 1000 - status.t0;\n\n  if (t < status.te) {\n\n    var progress = 1 - (Math.exp(-lambda * t) - status.lambda_v0) / status.one_ve_v0;\n\n    if (status.modifiedXe === status.xe && status.modifiedYe === status.ye) {\n      status.sx = status.xe * progress;\n      status.sy = status.ye * progress;\n    } else {\n      var quadPoint = utils.getQuadraticCurvePoint(0, 0, status.xe, status.ye, status.modifiedXe, status.modifiedYe, progress);\n\n      status.sx = quadPoint.x;\n      status.sy = quadPoint.y;\n    }\n\n    this.doMove();\n\n    status.i = animationFrame.request(this.boundInertiaFrame);\n  } else {\n    status.sx = status.modifiedXe;\n    status.sy = status.modifiedYe;\n\n    this.doMove();\n    this.end(status.startEvent);\n    status.active = false;\n    this.simulation = null;\n  }\n\n  utils.copyCoords(this.prevCoords, this.curCoords);\n}\n\nfunction smoothEndFrame() {\n  updateInertiaCoords(this);\n\n  var status = this.inertiaStatus;\n  var t = new Date().getTime() - status.t0;\n  var duration = this.target.options[this.prepared.name].inertia.smoothEndDuration;\n\n  if (t < duration) {\n    status.sx = utils.easeOutQuad(t, 0, status.xe, duration);\n    status.sy = utils.easeOutQuad(t, 0, status.ye, duration);\n\n    this.pointerMove(status.startEvent, status.startEvent);\n\n    status.i = animationFrame.request(this.boundSmoothEndFrame);\n  } else {\n    status.sx = status.xe;\n    status.sy = status.ye;\n\n    this.pointerMove(status.startEvent, status.startEvent);\n    this.end(status.startEvent);\n\n    status.smoothEnd = status.active = false;\n    this.simulation = null;\n  }\n}\n\nfunction updateInertiaCoords(interaction) {\n  var status = interaction.inertiaStatus;\n\n  // return if inertia isn't running\n  if (!status.active) {\n    return;\n  }\n\n  var pageUp = status.upCoords.page;\n  var clientUp = status.upCoords.client;\n\n  utils.setCoords(interaction.curCoords, [{\n    pageX: pageUp.x + status.sx,\n    pageY: pageUp.y + status.sy,\n    clientX: clientUp.x + status.sx,\n    clientY: clientUp.y + status.sy\n  }]);\n}\n\n},{\"./InteractEvent\":3,\"./Interaction\":5,\"./modifiers\":24,\"./utils\":44,\"./utils/raf\":50}],21:[function(require,module,exports){\n'use strict';\n\nvar browser = require('./utils/browser');\nvar events = require('./utils/events');\nvar utils = require('./utils');\nvar scope = require('./scope');\nvar Interactable = require('./Interactable');\nvar Interaction = require('./Interaction');\n\nvar globalEvents = {};\n\n/*\\\n * interact\n [ method ]\n *\n * The methods of this variable can be used to set elements as\n * interactables and also to change various default settings.\n *\n * Calling it as a function and passing an element or a valid CSS selector\n * string returns an Interactable object which has various methods to\n * configure it.\n *\n - element (Element | string) The HTML or SVG Element to interact with or CSS selector\n = (object) An @Interactable\n *\n > Usage\n | interact('#draggable').draggable(true);\n |\n | var rectables = interact('rect');\n | rectables\n |     .gesturable(true)\n |     .on('gesturemove', function (event) {\n |         // ...\n |     });\n\\*/\nfunction interact(element, options) {\n  var interactable = scope.interactables.get(element, options);\n\n  if (!interactable) {\n    interactable = new Interactable(element, options);\n    interactable.events.global = globalEvents;\n  }\n\n  return interactable;\n}\n\n/*\\\n * interact.isSet\n [ method ]\n *\n * Check if an element has been set\n - element (Element) The Element being searched for\n = (boolean) Indicates if the element or CSS selector was previously passed to interact\n\\*/\ninteract.isSet = function (element, options) {\n  return scope.interactables.indexOfElement(element, options && options.context) !== -1;\n};\n\n/*\\\n * interact.on\n [ method ]\n *\n * Adds a global listener for an InteractEvent or adds a DOM event to\n * `document`\n *\n - type       (string | array | object) The types of events to listen for\n - listener   (function) The function event (s)\n - options    (object | boolean) #optional options object or useCapture flag for addEventListener\n = (object) interact\n\\*/\ninteract.on = function (type, listener, options) {\n  if (utils.is.string(type) && type.search(' ') !== -1) {\n    type = type.trim().split(/ +/);\n  }\n\n  if (utils.is.array(type)) {\n    for (var _iterator = type, _isArray = Array.isArray(_iterator), _i = 0, _iterator = _isArray ? _iterator : _iterator[Symbol.iterator]();;) {\n      var _ref;\n\n      if (_isArray) {\n        if (_i >= _iterator.length) break;\n        _ref = _iterator[_i++];\n      } else {\n        _i = _iterator.next();\n        if (_i.done) break;\n        _ref = _i.value;\n      }\n\n      var eventType = _ref;\n\n      interact.on(eventType, listener, options);\n    }\n\n    return interact;\n  }\n\n  if (utils.is.object(type)) {\n    for (var prop in type) {\n      interact.on(prop, type[prop], listener);\n    }\n\n    return interact;\n  }\n\n  // if it is an InteractEvent type, add listener to globalEvents\n  if (utils.contains(Interactable.eventTypes, type)) {\n    // if this type of event was never bound\n    if (!globalEvents[type]) {\n      globalEvents[type] = [listener];\n    } else {\n      globalEvents[type].push(listener);\n    }\n  }\n  // If non InteractEvent type, addEventListener to document\n  else {\n      events.add(scope.document, type, listener, { options: options });\n    }\n\n  return interact;\n};\n\n/*\\\n * interact.off\n [ method ]\n *\n * Removes a global InteractEvent listener or DOM event from `document`\n *\n - type       (string | array | object) The types of events that were listened for\n - listener   (function) The listener function to be removed\n - options    (object | boolean) #optional options object or useCapture flag for removeEventListener\n = (object) interact\n \\*/\ninteract.off = function (type, listener, options) {\n  if (utils.is.string(type) && type.search(' ') !== -1) {\n    type = type.trim().split(/ +/);\n  }\n\n  if (utils.is.array(type)) {\n    for (var _iterator2 = type, _isArray2 = Array.isArray(_iterator2), _i2 = 0, _iterator2 = _isArray2 ? _iterator2 : _iterator2[Symbol.iterator]();;) {\n      var _ref2;\n\n      if (_isArray2) {\n        if (_i2 >= _iterator2.length) break;\n        _ref2 = _iterator2[_i2++];\n      } else {\n        _i2 = _iterator2.next();\n        if (_i2.done) break;\n        _ref2 = _i2.value;\n      }\n\n      var eventType = _ref2;\n\n      interact.off(eventType, listener, options);\n    }\n\n    return interact;\n  }\n\n  if (utils.is.object(type)) {\n    for (var prop in type) {\n      interact.off(prop, type[prop], listener);\n    }\n\n    return interact;\n  }\n\n  if (!utils.contains(Interactable.eventTypes, type)) {\n    events.remove(scope.document, type, listener, options);\n  } else {\n    var index = void 0;\n\n    if (type in globalEvents && (index = utils.indexOf(globalEvents[type], listener)) !== -1) {\n      globalEvents[type].splice(index, 1);\n    }\n  }\n\n  return interact;\n};\n\n/*\\\n * interact.debug\n [ method ]\n *\n * Returns an object which exposes internal data\n = (object) An object with properties that outline the current state and expose internal functions and variables\n\\*/\ninteract.debug = function () {\n  return scope;\n};\n\n// expose the functions used to calculate multi-touch properties\ninteract.getPointerAverage = utils.pointerAverage;\ninteract.getTouchBBox = utils.touchBBox;\ninteract.getTouchDistance = utils.touchDistance;\ninteract.getTouchAngle = utils.touchAngle;\n\ninteract.getElementRect = utils.getElementRect;\ninteract.getElementClientRect = utils.getElementClientRect;\ninteract.matchesSelector = utils.matchesSelector;\ninteract.closest = utils.closest;\n\n/*\\\n * interact.supportsTouch\n [ method ]\n *\n = (boolean) Whether or not the browser supports touch input\n\\*/\ninteract.supportsTouch = function () {\n  return browser.supportsTouch;\n};\n\n/*\\\n * interact.supportsPointerEvent\n [ method ]\n *\n = (boolean) Whether or not the browser supports PointerEvents\n\\*/\ninteract.supportsPointerEvent = function () {\n  return browser.supportsPointerEvent;\n};\n\n/*\\\n * interact.stop\n [ method ]\n *\n * Cancels all interactions (end events are not fired)\n *\n - event (Event) An event on which to call preventDefault()\n = (object) interact\n\\*/\ninteract.stop = function (event) {\n  for (var i = scope.interactions.length - 1; i >= 0; i--) {\n    scope.interactions[i].stop(event);\n  }\n\n  return interact;\n};\n\n/*\\\n * interact.pointerMoveTolerance\n [ method ]\n * Returns or sets the distance the pointer must be moved before an action\n * sequence occurs. This also affects tolerance for tap events.\n *\n - newValue (number) #optional The movement from the start position must be greater than this value\n = (number | Interactable) The current setting or interact\n\\*/\ninteract.pointerMoveTolerance = function (newValue) {\n  if (utils.is.number(newValue)) {\n    Interaction.pointerMoveTolerance = newValue;\n\n    return this;\n  }\n\n  return Interaction.pointerMoveTolerance;\n};\n\ninteract.addDocument = scope.addDocument;\ninteract.removeDocument = scope.removeDocument;\n\nscope.interact = interact;\n\nmodule.exports = interact;\n\n},{\"./Interactable\":4,\"./Interaction\":5,\"./scope\":34,\"./utils\":44,\"./utils/browser\":37,\"./utils/events\":40}],22:[function(require,module,exports){\n'use strict';\n\nvar Interactable = require('./Interactable');\nvar Interaction = require('./Interaction');\nvar scope = require('./scope');\nvar is = require('./utils/is');\nvar events = require('./utils/events');\n\nvar _require = require('./utils/domUtils'),\n    nodeContains = _require.nodeContains,\n    matchesSelector = _require.matchesSelector;\n\n/*\\\n * Interactable.preventDefault\n [ method ]\n *\n * Returns or sets whether to prevent the browser's default behaviour\n * in response to pointer events. Can be set to:\n *  - `'always'` to always prevent\n *  - `'never'` to never prevent\n *  - `'auto'` to let interact.js try to determine what would be best\n *\n - newValue (string) #optional `true`, `false` or `'auto'`\n = (string | Interactable) The current setting or this Interactable\n\\*/\n\n\nInteractable.prototype.preventDefault = function (newValue) {\n  if (/^(always|never|auto)$/.test(newValue)) {\n    this.options.preventDefault = newValue;\n    return this;\n  }\n\n  if (is.bool(newValue)) {\n    this.options.preventDefault = newValue ? 'always' : 'never';\n    return this;\n  }\n\n  return this.options.preventDefault;\n};\n\nInteractable.prototype.checkAndPreventDefault = function (event) {\n  var setting = this.options.preventDefault;\n\n  if (setting === 'never') {\n    return;\n  }\n\n  if (setting === 'always') {\n    event.preventDefault();\n    return;\n  }\n\n  // setting === 'auto'\n\n  // don't preventDefault if the browser supports passiveEvents\n  // CSS touch-action and user-selecct should be used instead\n  if (events.supportsOptions) {\n    return;\n  }\n\n  // don't preventDefault of pointerdown events\n  if (/^(mouse|pointer|touch)*(down|start)/i.test(event.type)) {\n    return;\n  }\n\n  // don't preventDefault on editable elements\n  if (is.element(event.target) && matchesSelector(event.target, 'input,select,textarea,[contenteditable=true],[contenteditable=true] *')) {\n    return;\n  }\n\n  event.preventDefault();\n};\n\nfunction onInteractionEvent(_ref) {\n  var interaction = _ref.interaction,\n      event = _ref.event;\n\n  if (interaction.target) {\n    interaction.target.checkAndPreventDefault(event);\n  }\n}\n\nvar _arr = ['down', 'move', 'up', 'cancel'];\nfor (var _i = 0; _i < _arr.length; _i++) {\n  var eventSignal = _arr[_i];\n  Interaction.signals.on(eventSignal, onInteractionEvent);\n}\n\n// prevent native HTML5 drag on interact.js target elements\nInteraction.docEvents.dragstart = function preventNativeDrag(event) {\n  for (var _iterator = scope.interactions, _isArray = Array.isArray(_iterator), _i2 = 0, _iterator = _isArray ? _iterator : _iterator[Symbol.iterator]();;) {\n    var _ref2;\n\n    if (_isArray) {\n      if (_i2 >= _iterator.length) break;\n      _ref2 = _iterator[_i2++];\n    } else {\n      _i2 = _iterator.next();\n      if (_i2.done) break;\n      _ref2 = _i2.value;\n    }\n\n    var interaction = _ref2;\n\n\n    if (interaction.element && (interaction.element === event.target || nodeContains(interaction.element, event.target))) {\n\n      interaction.target.checkAndPreventDefault(event);\n      return;\n    }\n  }\n};\n\n},{\"./Interactable\":4,\"./Interaction\":5,\"./scope\":34,\"./utils/domUtils\":39,\"./utils/events\":40,\"./utils/is\":46}],23:[function(require,module,exports){\n'use strict';\n\nvar scope = require('./scope');\nvar events = require('./utils/events');\nvar browser = require('./utils/browser');\nvar iFinder = require('./utils/interactionFinder');\nvar pointerEvents = require('./pointerEvents/base');\n\nvar _require = require('./utils/window'),\n    window = _require.window;\n\nvar toString = Object.prototype.toString;\n\nif (!window.Array.isArray) {\n  window.Array.isArray = function (obj) {\n    return toString.call(obj) === '[object Array]';\n  };\n}\n\nif (!String.prototype.trim) {\n  String.prototype.trim = function () {\n    return this.replace(/^[\\s\\uFEFF\\xA0]+|[\\s\\uFEFF\\xA0]+$/g, '');\n  };\n}\n\n// http://www.quirksmode.org/dom/events/click.html\n// >Events leading to dblclick\n//\n// IE8 doesn't fire down event before dblclick.\n// This workaround tries to fire a tap and doubletap after dblclick\nfunction onIE8Dblclick(event) {\n  var eventTarget = event.target;\n  var interaction = iFinder.search(event, event.type, eventTarget);\n\n  if (!interaction) {\n    return;\n  }\n\n  if (interaction.prevTap && event.clientX === interaction.prevTap.clientX && event.clientY === interaction.prevTap.clientY && eventTarget === interaction.prevTap.target) {\n\n    interaction.downTargets[0] = eventTarget;\n    interaction.downTimes[0] = new Date().getTime();\n\n    pointerEvents.fire({\n      interaction: interaction,\n      event: event,\n      eventTarget: eventTarget,\n      pointer: event,\n      type: 'tap'\n    });\n  }\n}\n\nif (browser.isIE8) {\n  var selectFix = function selectFix(event) {\n    for (var _iterator = scope.interactions, _isArray = Array.isArray(_iterator), _i = 0, _iterator = _isArray ? _iterator : _iterator[Symbol.iterator]();;) {\n      var _ref;\n\n      if (_isArray) {\n        if (_i >= _iterator.length) break;\n        _ref = _iterator[_i++];\n      } else {\n        _i = _iterator.next();\n        if (_i.done) break;\n        _ref = _i.value;\n      }\n\n      var interaction = _ref;\n\n      if (interaction.interacting()) {\n        interaction.target.checkAndPreventDefault(event);\n      }\n    }\n  };\n\n  var onDocIE8 = function onDocIE8(_ref2, signalName) {\n    var doc = _ref2.doc,\n        win = _ref2.win;\n\n    var eventMethod = signalName.indexOf('listen') === 0 ? events.add : events.remove;\n\n    // For IE's lack of Event#preventDefault\n    eventMethod(doc, 'selectstart', selectFix);\n\n    if (pointerEvents) {\n      eventMethod(doc, 'dblclick', onIE8Dblclick);\n    }\n  };\n\n  scope.signals.on('add-document', onDocIE8);\n  scope.signals.on('remove-document', onDocIE8);\n}\n\nmodule.exports = null;\n\n},{\"./pointerEvents/base\":31,\"./scope\":34,\"./utils/browser\":37,\"./utils/events\":40,\"./utils/interactionFinder\":45,\"./utils/window\":52}],24:[function(require,module,exports){\n'use strict';\n\nvar InteractEvent = require('../InteractEvent');\nvar Interaction = require('../Interaction');\nvar extend = require('../utils/extend');\n\nvar modifiers = {\n  names: [],\n\n  setOffsets: function setOffsets(arg) {\n    var interaction = arg.interaction,\n        page = arg.pageCoords;\n    var target = interaction.target,\n        element = interaction.element,\n        startOffset = interaction.startOffset;\n\n    var rect = target.getRect(element);\n\n    if (rect) {\n      startOffset.left = page.x - rect.left;\n      startOffset.top = page.y - rect.top;\n\n      startOffset.right = rect.right - page.x;\n      startOffset.bottom = rect.bottom - page.y;\n\n      if (!('width' in rect)) {\n        rect.width = rect.right - rect.left;\n      }\n      if (!('height' in rect)) {\n        rect.height = rect.bottom - rect.top;\n      }\n    } else {\n      startOffset.left = startOffset.top = startOffset.right = startOffset.bottom = 0;\n    }\n\n    arg.rect = rect;\n    arg.interactable = target;\n    arg.element = element;\n\n    for (var i = 0; i < modifiers.names.length; i++) {\n      var modifierName = modifiers.names[i];\n\n      arg.options = target.options[interaction.prepared.name][modifierName];\n\n      if (!arg.options) {\n        continue;\n      }\n\n      interaction.modifierOffsets[modifierName] = modifiers[modifierName].setOffset(arg);\n    }\n  },\n\n  setAll: function setAll(arg) {\n    var interaction = arg.interaction,\n        statuses = arg.statuses,\n        preEnd = arg.preEnd,\n        requireEndOnly = arg.requireEndOnly;\n\n    var coords = extend({}, arg.pageCoords);\n    var result = {\n      dx: 0,\n      dy: 0,\n      changed: false,\n      locked: false,\n      shouldMove: true\n    };\n\n    for (var _iterator = modifiers.names, _isArray = Array.isArray(_iterator), _i = 0, _iterator = _isArray ? _iterator : _iterator[Symbol.iterator]();;) {\n      var _ref;\n\n      if (_isArray) {\n        if (_i >= _iterator.length) break;\n        _ref = _iterator[_i++];\n      } else {\n        _i = _iterator.next();\n        if (_i.done) break;\n        _ref = _i.value;\n      }\n\n      var modifierName = _ref;\n\n      var modifier = modifiers[modifierName];\n      var options = interaction.target.options[interaction.prepared.name][modifierName];\n\n      if (!shouldDo(options, preEnd, requireEndOnly)) {\n        continue;\n      }\n\n      arg.status = arg.status = statuses[modifierName];\n      arg.options = options;\n      arg.offset = arg.interaction.modifierOffsets[modifierName];\n\n      modifier.set(arg);\n\n      if (arg.status.locked) {\n        coords.x += arg.status.dx;\n        coords.y += arg.status.dy;\n\n        result.dx += arg.status.dx;\n        result.dy += arg.status.dy;\n\n        result.locked = true;\n      }\n    }\n\n    // a move should be fired if:\n    //  - there are no modifiers enabled,\n    //  - no modifiers are \"locked\" i.e. have changed the pointer's coordinates, or\n    //  - the locked coords have changed since the last pointer move\n    result.shouldMove = !arg.status || !result.locked || arg.status.changed;\n\n    return result;\n  },\n\n  resetStatuses: function resetStatuses(statuses) {\n    for (var _iterator2 = modifiers.names, _isArray2 = Array.isArray(_iterator2), _i2 = 0, _iterator2 = _isArray2 ? _iterator2 : _iterator2[Symbol.iterator]();;) {\n      var _ref2;\n\n      if (_isArray2) {\n        if (_i2 >= _iterator2.length) break;\n        _ref2 = _iterator2[_i2++];\n      } else {\n        _i2 = _iterator2.next();\n        if (_i2.done) break;\n        _ref2 = _i2.value;\n      }\n\n      var modifierName = _ref2;\n\n      var status = statuses[modifierName] || {};\n\n      status.dx = status.dy = 0;\n      status.modifiedX = status.modifiedY = NaN;\n      status.locked = false;\n      status.changed = true;\n\n      statuses[modifierName] = status;\n    }\n\n    return statuses;\n  },\n\n  start: function start(_ref3, signalName) {\n    var interaction = _ref3.interaction;\n\n    var arg = {\n      interaction: interaction,\n      pageCoords: (signalName === 'action-resume' ? interaction.curCoords : interaction.startCoords).page,\n      startOffset: interaction.startOffset,\n      statuses: interaction.modifierStatuses,\n      preEnd: false,\n      requireEndOnly: false\n    };\n\n    modifiers.setOffsets(arg);\n    modifiers.resetStatuses(arg.statuses);\n\n    arg.pageCoords = extend({}, interaction.startCoords.page);\n    interaction.modifierResult = modifiers.setAll(arg);\n  }\n};\n\nInteraction.signals.on('new', function (interaction) {\n  interaction.startOffset = { left: 0, right: 0, top: 0, bottom: 0 };\n  interaction.modifierOffsets = {};\n  interaction.modifierStatuses = modifiers.resetStatuses({});\n  interaction.modifierResult = null;\n});\n\nInteraction.signals.on('action-start', modifiers.start);\nInteraction.signals.on('action-resume', modifiers.start);\n\nInteraction.signals.on('before-action-move', function (_ref4) {\n  var interaction = _ref4.interaction,\n      preEnd = _ref4.preEnd,\n      interactingBeforeMove = _ref4.interactingBeforeMove;\n\n  var modifierResult = modifiers.setAll({\n    interaction: interaction,\n    preEnd: preEnd,\n    pageCoords: interaction.curCoords.page,\n    statuses: interaction.modifierStatuses,\n    requireEndOnly: false\n  });\n\n  // don't fire an action move if a modifier would keep the event in the same\n  // cordinates as before\n  if (!modifierResult.shouldMove && interactingBeforeMove) {\n    interaction._dontFireMove = true;\n  }\n\n  interaction.modifierResult = modifierResult;\n});\n\nInteraction.signals.on('action-end', function (_ref5) {\n  var interaction = _ref5.interaction,\n      event = _ref5.event;\n\n  for (var i = 0; i < modifiers.names.length; i++) {\n    var options = interaction.target.options[interaction.prepared.name][modifiers.names[i]];\n\n    // if the endOnly option is true for any modifier\n    if (shouldDo(options, true, true)) {\n      // fire a move event at the modified coordinates\n      interaction.doMove({ event: event, preEnd: true });\n      break;\n    }\n  }\n});\n\nInteractEvent.signals.on('set-xy', function (arg) {\n  var iEvent = arg.iEvent,\n      interaction = arg.interaction;\n\n  var modifierArg = extend({}, arg);\n\n  for (var i = 0; i < modifiers.names.length; i++) {\n    var modifierName = modifiers.names[i];\n    modifierArg.options = interaction.target.options[interaction.prepared.name][modifierName];\n\n    if (!modifierArg.options) {\n      continue;\n    }\n\n    var modifier = modifiers[modifierName];\n\n    modifierArg.status = interaction.modifierStatuses[modifierName];\n\n    iEvent[modifierName] = modifier.modifyCoords(modifierArg);\n  }\n});\n\nfunction shouldDo(options, preEnd, requireEndOnly) {\n  return options && options.enabled && (preEnd || !options.endOnly) && (!requireEndOnly || options.endOnly);\n}\n\nmodule.exports = modifiers;\n\n},{\"../InteractEvent\":3,\"../Interaction\":5,\"../utils/extend\":41}],25:[function(require,module,exports){\n'use strict';\n\nvar modifiers = require('./index');\nvar utils = require('../utils');\nvar defaultOptions = require('../defaultOptions');\n\nvar restrict = {\n  defaults: {\n    enabled: false,\n    endOnly: false,\n    restriction: null,\n    elementRect: null\n  },\n\n  setOffset: function setOffset(_ref) {\n    var rect = _ref.rect,\n        startOffset = _ref.startOffset,\n        options = _ref.options;\n\n    var elementRect = options && options.elementRect;\n    var offset = {};\n\n    if (rect && elementRect) {\n      offset.left = startOffset.left - rect.width * elementRect.left;\n      offset.top = startOffset.top - rect.height * elementRect.top;\n\n      offset.right = startOffset.right - rect.width * (1 - elementRect.right);\n      offset.bottom = startOffset.bottom - rect.height * (1 - elementRect.bottom);\n    } else {\n      offset.left = offset.top = offset.right = offset.bottom = 0;\n    }\n\n    return offset;\n  },\n\n  set: function set(_ref2) {\n    var pageCoords = _ref2.pageCoords,\n        interaction = _ref2.interaction,\n        status = _ref2.status,\n        options = _ref2.options;\n\n    if (!options) {\n      return status;\n    }\n\n    var page = status.useStatusXY ? { x: status.x, y: status.y } : utils.extend({}, pageCoords);\n\n    var restriction = getRestrictionRect(options.restriction, interaction, page);\n\n    if (!restriction) {\n      return status;\n    }\n\n    status.dx = 0;\n    status.dy = 0;\n    status.locked = false;\n\n    var rect = restriction;\n    var modifiedX = page.x;\n    var modifiedY = page.y;\n\n    var offset = interaction.modifierOffsets.restrict;\n\n    // object is assumed to have\n    // x, y, width, height or\n    // left, top, right, bottom\n    if ('x' in restriction && 'y' in restriction) {\n      modifiedX = Math.max(Math.min(rect.x + rect.width - offset.right, page.x), rect.x + offset.left);\n      modifiedY = Math.max(Math.min(rect.y + rect.height - offset.bottom, page.y), rect.y + offset.top);\n    } else {\n      modifiedX = Math.max(Math.min(rect.right - offset.right, page.x), rect.left + offset.left);\n      modifiedY = Math.max(Math.min(rect.bottom - offset.bottom, page.y), rect.top + offset.top);\n    }\n\n    status.dx = modifiedX - page.x;\n    status.dy = modifiedY - page.y;\n\n    status.changed = status.modifiedX !== modifiedX || status.modifiedY !== modifiedY;\n    status.locked = !!(status.dx || status.dy);\n\n    status.modifiedX = modifiedX;\n    status.modifiedY = modifiedY;\n  },\n\n  modifyCoords: function modifyCoords(_ref3) {\n    var page = _ref3.page,\n        client = _ref3.client,\n        status = _ref3.status,\n        phase = _ref3.phase,\n        options = _ref3.options;\n\n    var elementRect = options && options.elementRect;\n\n    if (options && options.enabled && !(phase === 'start' && elementRect && status.locked)) {\n\n      if (status.locked) {\n        page.x += status.dx;\n        page.y += status.dy;\n        client.x += status.dx;\n        client.y += status.dy;\n\n        return {\n          dx: status.dx,\n          dy: status.dy\n        };\n      }\n    }\n  },\n\n  getRestrictionRect: getRestrictionRect\n};\n\nfunction getRestrictionRect(value, interaction, page) {\n  if (utils.is.function(value)) {\n    return utils.resolveRectLike(value, interaction.target, interaction.element, [page.x, page.y, interaction]);\n  } else {\n    return utils.resolveRectLike(value, interaction.target, interaction.element);\n  }\n}\n\nmodifiers.restrict = restrict;\nmodifiers.names.push('restrict');\n\ndefaultOptions.perAction.restrict = restrict.defaults;\n\nmodule.exports = restrict;\n\n},{\"../defaultOptions\":18,\"../utils\":44,\"./index\":24}],26:[function(require,module,exports){\n'use strict';\n\n// This module adds the options.resize.restrictEdges setting which sets min and\n// max for the top, left, bottom and right edges of the target being resized.\n//\n// interact(target).resize({\n//   edges: { top: true, left: true },\n//   restrictEdges: {\n//     inner: { top: 200, left: 200, right: 400, bottom: 400 },\n//     outer: { top:   0, left:   0, right: 600, bottom: 600 },\n//   },\n// });\n\nvar modifiers = require('./index');\nvar utils = require('../utils');\nvar rectUtils = require('../utils/rect');\nvar defaultOptions = require('../defaultOptions');\nvar resize = require('../actions/resize');\n\nvar _require = require('./restrict'),\n    getRestrictionRect = _require.getRestrictionRect;\n\nvar noInner = { top: +Infinity, left: +Infinity, bottom: -Infinity, right: -Infinity };\nvar noOuter = { top: -Infinity, left: -Infinity, bottom: +Infinity, right: +Infinity };\n\nvar restrictEdges = {\n  defaults: {\n    enabled: false,\n    endOnly: false,\n    min: null,\n    max: null,\n    offset: null\n  },\n\n  setOffset: function setOffset(_ref) {\n    var interaction = _ref.interaction,\n        startOffset = _ref.startOffset,\n        options = _ref.options;\n\n    if (!options) {\n      return utils.extend({}, startOffset);\n    }\n\n    var offset = getRestrictionRect(options.offset, interaction, interaction.startCoords.page);\n\n    if (offset) {\n      return {\n        top: startOffset.top + offset.y,\n        left: startOffset.left + offset.x,\n        bottom: startOffset.bottom + offset.y,\n        right: startOffset.right + offset.x\n      };\n    }\n\n    return startOffset;\n  },\n\n  set: function set(_ref2) {\n    var pageCoords = _ref2.pageCoords,\n        interaction = _ref2.interaction,\n        status = _ref2.status,\n        offset = _ref2.offset,\n        options = _ref2.options;\n\n    var edges = interaction.prepared.linkedEdges || interaction.prepared.edges;\n\n    if (!interaction.interacting() || !edges) {\n      return;\n    }\n\n    var page = status.useStatusXY ? { x: status.x, y: status.y } : utils.extend({}, pageCoords);\n    var inner = rectUtils.xywhToTlbr(getRestrictionRect(options.inner, interaction, page)) || noInner;\n    var outer = rectUtils.xywhToTlbr(getRestrictionRect(options.outer, interaction, page)) || noOuter;\n\n    var modifiedX = page.x;\n    var modifiedY = page.y;\n\n    status.dx = 0;\n    status.dy = 0;\n    status.locked = false;\n\n    if (edges.top) {\n      modifiedY = Math.min(Math.max(outer.top + offset.top, page.y), inner.top + offset.top);\n    } else if (edges.bottom) {\n      modifiedY = Math.max(Math.min(outer.bottom - offset.bottom, page.y), inner.bottom - offset.bottom);\n    }\n    if (edges.left) {\n      modifiedX = Math.min(Math.max(outer.left + offset.left, page.x), inner.left + offset.left);\n    } else if (edges.right) {\n      modifiedX = Math.max(Math.min(outer.right - offset.right, page.x), inner.right - offset.right);\n    }\n\n    status.dx = modifiedX - page.x;\n    status.dy = modifiedY - page.y;\n\n    status.changed = status.modifiedX !== modifiedX || status.modifiedY !== modifiedY;\n    status.locked = !!(status.dx || status.dy);\n\n    status.modifiedX = modifiedX;\n    status.modifiedY = modifiedY;\n  },\n\n  modifyCoords: function modifyCoords(_ref3) {\n    var page = _ref3.page,\n        client = _ref3.client,\n        status = _ref3.status,\n        phase = _ref3.phase,\n        options = _ref3.options;\n\n    if (options && options.enabled && !(phase === 'start' && status.locked)) {\n\n      if (status.locked) {\n        page.x += status.dx;\n        page.y += status.dy;\n        client.x += status.dx;\n        client.y += status.dy;\n\n        return {\n          dx: status.dx,\n          dy: status.dy\n        };\n      }\n    }\n  },\n\n  noInner: noInner,\n  noOuter: noOuter,\n  getRestrictionRect: getRestrictionRect\n};\n\nmodifiers.restrictEdges = restrictEdges;\nmodifiers.names.push('restrictEdges');\n\ndefaultOptions.perAction.restrictEdges = restrictEdges.defaults;\nresize.defaults.restrictEdges = restrictEdges.defaults;\n\nmodule.exports = restrictEdges;\n\n},{\"../actions/resize\":10,\"../defaultOptions\":18,\"../utils\":44,\"../utils/rect\":51,\"./index\":24,\"./restrict\":25}],27:[function(require,module,exports){\n'use strict';\n\n// This module adds the options.resize.restrictSize setting which sets min and\n// max width and height for the target being resized.\n//\n// interact(target).resize({\n//   edges: { top: true, left: true },\n//   restrictSize: {\n//     min: { width: -600, height: -600 },\n//     max: { width:  600, height:  600 },\n//   },\n// });\n\nvar modifiers = require('./index');\nvar restrictEdges = require('./restrictEdges');\nvar utils = require('../utils');\nvar rectUtils = require('../utils/rect');\nvar defaultOptions = require('../defaultOptions');\nvar resize = require('../actions/resize');\n\nvar noMin = { width: -Infinity, height: -Infinity };\nvar noMax = { width: +Infinity, height: +Infinity };\n\nvar restrictSize = {\n  defaults: {\n    enabled: false,\n    endOnly: false,\n    min: null,\n    max: null\n  },\n\n  setOffset: function setOffset(_ref) {\n    var interaction = _ref.interaction;\n\n    return interaction.startOffset;\n  },\n\n  set: function set(arg) {\n    var interaction = arg.interaction,\n        options = arg.options;\n\n    var edges = interaction.prepared.linkedEdges || interaction.prepared.edges;\n\n    if (!interaction.interacting() || !edges) {\n      return;\n    }\n\n    var rect = rectUtils.xywhToTlbr(interaction.resizeRects.inverted);\n\n    var minSize = rectUtils.tlbrToXywh(restrictEdges.getRestrictionRect(options.min, interaction)) || noMin;\n    var maxSize = rectUtils.tlbrToXywh(restrictEdges.getRestrictionRect(options.max, interaction)) || noMax;\n\n    arg.options = {\n      enabled: options.enabled,\n      endOnly: options.endOnly,\n      inner: utils.extend({}, restrictEdges.noInner),\n      outer: utils.extend({}, restrictEdges.noOuter)\n    };\n\n    if (edges.top) {\n      arg.options.inner.top = rect.bottom - minSize.height;\n      arg.options.outer.top = rect.bottom - maxSize.height;\n    } else if (edges.bottom) {\n      arg.options.inner.bottom = rect.top + minSize.height;\n      arg.options.outer.bottom = rect.top + maxSize.height;\n    }\n    if (edges.left) {\n      arg.options.inner.left = rect.right - minSize.width;\n      arg.options.outer.left = rect.right - maxSize.width;\n    } else if (edges.right) {\n      arg.options.inner.right = rect.left + minSize.width;\n      arg.options.outer.right = rect.left + maxSize.width;\n    }\n\n    restrictEdges.set(arg);\n  },\n\n  modifyCoords: restrictEdges.modifyCoords\n};\n\nmodifiers.restrictSize = restrictSize;\nmodifiers.names.push('restrictSize');\n\ndefaultOptions.perAction.restrictSize = restrictSize.defaults;\nresize.defaults.restrictSize = restrictSize.defaults;\n\nmodule.exports = restrictSize;\n\n},{\"../actions/resize\":10,\"../defaultOptions\":18,\"../utils\":44,\"../utils/rect\":51,\"./index\":24,\"./restrictEdges\":26}],28:[function(require,module,exports){\n'use strict';\n\nvar modifiers = require('./index');\nvar interact = require('../interact');\nvar utils = require('../utils');\nvar defaultOptions = require('../defaultOptions');\n\nvar snap = {\n  defaults: {\n    enabled: false,\n    endOnly: false,\n    range: Infinity,\n    targets: null,\n    offsets: null,\n\n    relativePoints: null\n  },\n\n  setOffset: function setOffset(_ref) {\n    var interaction = _ref.interaction,\n        interactable = _ref.interactable,\n        element = _ref.element,\n        rect = _ref.rect,\n        startOffset = _ref.startOffset,\n        options = _ref.options;\n\n    var offsets = [];\n    var optionsOrigin = utils.rectToXY(utils.resolveRectLike(options.origin));\n    var origin = optionsOrigin || utils.getOriginXY(interactable, element, interaction.prepared.name);\n    options = options || interactable.options[interaction.prepared.name].snap || {};\n\n    var snapOffset = void 0;\n\n    if (options.offset === 'startCoords') {\n      snapOffset = {\n        x: interaction.startCoords.page.x - origin.x,\n        y: interaction.startCoords.page.y - origin.y\n      };\n    } else {\n      var offsetRect = utils.resolveRectLike(options.offset, interactable, element, [interaction]);\n\n      snapOffset = utils.rectToXY(offsetRect) || { x: 0, y: 0 };\n    }\n\n    if (rect && options.relativePoints && options.relativePoints.length) {\n      for (var _iterator = options.relativePoints, _isArray = Array.isArray(_iterator), _i = 0, _iterator = _isArray ? _iterator : _iterator[Symbol.iterator]();;) {\n        var _ref2;\n\n        if (_isArray) {\n          if (_i >= _iterator.length) break;\n          _ref2 = _iterator[_i++];\n        } else {\n          _i = _iterator.next();\n          if (_i.done) break;\n          _ref2 = _i.value;\n        }\n\n        var _ref3 = _ref2,\n            relativeX = _ref3.x,\n            relativeY = _ref3.y;\n\n        offsets.push({\n          x: startOffset.left - rect.width * relativeX + snapOffset.x,\n          y: startOffset.top - rect.height * relativeY + snapOffset.y\n        });\n      }\n    } else {\n      offsets.push(snapOffset);\n    }\n\n    return offsets;\n  },\n\n  set: function set(_ref4) {\n    var interaction = _ref4.interaction,\n        pageCoords = _ref4.pageCoords,\n        status = _ref4.status,\n        options = _ref4.options,\n        offsets = _ref4.offset;\n\n    var targets = [];\n    var target = void 0;\n    var page = void 0;\n    var i = void 0;\n\n    if (status.useStatusXY) {\n      page = { x: status.x, y: status.y };\n    } else {\n      var origin = utils.getOriginXY(interaction.target, interaction.element, interaction.prepared.name);\n\n      page = utils.extend({}, pageCoords);\n\n      page.x -= origin.x;\n      page.y -= origin.y;\n    }\n\n    status.realX = page.x;\n    status.realY = page.y;\n\n    var len = options.targets ? options.targets.length : 0;\n\n    for (var _iterator2 = offsets, _isArray2 = Array.isArray(_iterator2), _i2 = 0, _iterator2 = _isArray2 ? _iterator2 : _iterator2[Symbol.iterator]();;) {\n      var _ref5;\n\n      if (_isArray2) {\n        if (_i2 >= _iterator2.length) break;\n        _ref5 = _iterator2[_i2++];\n      } else {\n        _i2 = _iterator2.next();\n        if (_i2.done) break;\n        _ref5 = _i2.value;\n      }\n\n      var _ref6 = _ref5,\n          offsetX = _ref6.x,\n          offsetY = _ref6.y;\n\n      var relativeX = page.x - offsetX;\n      var relativeY = page.y - offsetY;\n\n      for (var _iterator3 = options.targets, _isArray3 = Array.isArray(_iterator3), _i3 = 0, _iterator3 = _isArray3 ? _iterator3 : _iterator3[Symbol.iterator]();;) {\n        var _ref7;\n\n        if (_isArray3) {\n          if (_i3 >= _iterator3.length) break;\n          _ref7 = _iterator3[_i3++];\n        } else {\n          _i3 = _iterator3.next();\n          if (_i3.done) break;\n          _ref7 = _i3.value;\n        }\n\n        var snapTarget = _ref7;\n\n        if (utils.is.function(snapTarget)) {\n          target = snapTarget(relativeX, relativeY, interaction);\n        } else {\n          target = snapTarget;\n        }\n\n        if (!target) {\n          continue;\n        }\n\n        targets.push({\n          x: utils.is.number(target.x) ? target.x + offsetX : relativeX,\n          y: utils.is.number(target.y) ? target.y + offsetY : relativeY,\n\n          range: utils.is.number(target.range) ? target.range : options.range\n        });\n      }\n    }\n\n    var closest = {\n      target: null,\n      inRange: false,\n      distance: 0,\n      range: 0,\n      dx: 0,\n      dy: 0\n    };\n\n    for (i = 0, len = targets.length; i < len; i++) {\n      target = targets[i];\n\n      var range = target.range;\n      var dx = target.x - page.x;\n      var dy = target.y - page.y;\n      var distance = utils.hypot(dx, dy);\n      var inRange = distance <= range;\n\n      // Infinite targets count as being out of range\n      // compared to non infinite ones that are in range\n      if (range === Infinity && closest.inRange && closest.range !== Infinity) {\n        inRange = false;\n      }\n\n      if (!closest.target || (inRange\n      // is the closest target in range?\n      ? closest.inRange && range !== Infinity\n      // the pointer is relatively deeper in this target\n      ? distance / range < closest.distance / closest.range\n      // this target has Infinite range and the closest doesn't\n      : range === Infinity && closest.range !== Infinity ||\n      // OR this target is closer that the previous closest\n      distance < closest.distance :\n      // The other is not in range and the pointer is closer to this target\n      !closest.inRange && distance < closest.distance)) {\n\n        closest.target = target;\n        closest.distance = distance;\n        closest.range = range;\n        closest.inRange = inRange;\n        closest.dx = dx;\n        closest.dy = dy;\n\n        status.range = range;\n      }\n    }\n\n    var snapChanged = void 0;\n\n    if (closest.target) {\n      snapChanged = status.modifiedX !== closest.target.x || status.modifiedY !== closest.target.y;\n\n      status.modifiedX = closest.target.x;\n      status.modifiedY = closest.target.y;\n    } else {\n      snapChanged = true;\n\n      status.modifiedX = NaN;\n      status.modifiedY = NaN;\n    }\n\n    status.dx = closest.dx;\n    status.dy = closest.dy;\n\n    status.changed = snapChanged || closest.inRange && !status.locked;\n    status.locked = closest.inRange;\n  },\n\n  modifyCoords: function modifyCoords(_ref8) {\n    var page = _ref8.page,\n        client = _ref8.client,\n        status = _ref8.status,\n        phase = _ref8.phase,\n        options = _ref8.options;\n\n    var relativePoints = options && options.relativePoints;\n\n    if (options && options.enabled && !(phase === 'start' && relativePoints && relativePoints.length)) {\n\n      if (status.locked) {\n        page.x += status.dx;\n        page.y += status.dy;\n        client.x += status.dx;\n        client.y += status.dy;\n      }\n\n      return {\n        range: status.range,\n        locked: status.locked,\n        x: status.modifiedX,\n        y: status.modifiedY,\n        realX: status.realX,\n        realY: status.realY,\n        dx: status.dx,\n        dy: status.dy\n      };\n    }\n  }\n};\n\ninteract.createSnapGrid = function (grid) {\n  return function (x, y) {\n    var limits = grid.limits || {\n      left: -Infinity,\n      right: Infinity,\n      top: -Infinity,\n      bottom: Infinity\n    };\n    var offsetX = 0;\n    var offsetY = 0;\n\n    if (utils.is.object(grid.offset)) {\n      offsetX = grid.offset.x;\n      offsetY = grid.offset.y;\n    }\n\n    var gridx = Math.round((x - offsetX) / grid.x);\n    var gridy = Math.round((y - offsetY) / grid.y);\n\n    var newX = Math.max(limits.left, Math.min(limits.right, gridx * grid.x + offsetX));\n    var newY = Math.max(limits.top, Math.min(limits.bottom, gridy * grid.y + offsetY));\n\n    return {\n      x: newX,\n      y: newY,\n      range: grid.range\n    };\n  };\n};\n\nmodifiers.snap = snap;\nmodifiers.names.push('snap');\n\ndefaultOptions.perAction.snap = snap.defaults;\n\nmodule.exports = snap;\n\n},{\"../defaultOptions\":18,\"../interact\":21,\"../utils\":44,\"./index\":24}],29:[function(require,module,exports){\n'use strict';\n\n// This module allows snapping of the size of targets during resize\n// interactions.\n\nvar modifiers = require('./index');\nvar snap = require('./snap');\nvar defaultOptions = require('../defaultOptions');\nvar resize = require('../actions/resize');\nvar utils = require('../utils/');\n\nvar snapSize = {\n  defaults: {\n    enabled: false,\n    endOnly: false,\n    range: Infinity,\n    targets: null,\n    offsets: null\n  },\n\n  setOffset: function setOffset(arg) {\n    var interaction = arg.interaction,\n        options = arg.options;\n\n    var edges = interaction.prepared.edges;\n\n    if (!edges) {\n      return;\n    }\n\n    arg.options = {\n      relativePoints: [{\n        x: edges.left ? 0 : 1,\n        y: edges.top ? 0 : 1\n      }],\n      origin: { x: 0, y: 0 },\n      offset: 'self',\n      range: options.range\n    };\n\n    var offsets = snap.setOffset(arg);\n    arg.options = options;\n\n    return offsets;\n  },\n\n  set: function set(arg) {\n    var interaction = arg.interaction,\n        options = arg.options,\n        offset = arg.offset,\n        pageCoords = arg.pageCoords;\n\n    var page = utils.extend({}, pageCoords);\n    var relativeX = page.x - offset[0].x;\n    var relativeY = page.y - offset[0].y;\n\n    arg.options = utils.extend({}, options);\n    arg.options.targets = [];\n\n    for (var _iterator = options.targets, _isArray = Array.isArray(_iterator), _i = 0, _iterator = _isArray ? _iterator : _iterator[Symbol.iterator]();;) {\n      var _ref;\n\n      if (_isArray) {\n        if (_i >= _iterator.length) break;\n        _ref = _iterator[_i++];\n      } else {\n        _i = _iterator.next();\n        if (_i.done) break;\n        _ref = _i.value;\n      }\n\n      var snapTarget = _ref;\n\n      var target = void 0;\n\n      if (utils.is.function(snapTarget)) {\n        target = snapTarget(relativeX, relativeY, interaction);\n      } else {\n        target = snapTarget;\n      }\n\n      if (!target) {\n        continue;\n      }\n\n      if ('width' in target && 'height' in target) {\n        target.x = target.width;\n        target.y = target.height;\n      }\n\n      arg.options.targets.push(target);\n    }\n\n    snap.set(arg);\n  },\n\n  modifyCoords: function modifyCoords(arg) {\n    var options = arg.options;\n\n\n    arg.options = utils.extend({}, options);\n    arg.options.enabled = options.enabled;\n    arg.options.relativePoints = [null];\n\n    snap.modifyCoords(arg);\n  }\n};\n\nmodifiers.snapSize = snapSize;\nmodifiers.names.push('snapSize');\n\ndefaultOptions.perAction.snapSize = snapSize.defaults;\nresize.defaults.snapSize = snapSize.defaults;\n\nmodule.exports = snapSize;\n\n},{\"../actions/resize\":10,\"../defaultOptions\":18,\"../utils/\":44,\"./index\":24,\"./snap\":28}],30:[function(require,module,exports){\n'use strict';\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nvar pointerUtils = require('../utils/pointerUtils');\n\nmodule.exports = function () {\n  function PointerEvent(type, pointer, event, eventTarget, interaction) {\n    _classCallCheck(this, PointerEvent);\n\n    pointerUtils.pointerExtend(this, event);\n\n    if (event !== pointer) {\n      pointerUtils.pointerExtend(this, pointer);\n    }\n\n    this.interaction = interaction;\n\n    this.timeStamp = new Date().getTime();\n    this.originalEvent = event;\n    this.type = type;\n    this.pointerId = pointerUtils.getPointerId(pointer);\n    this.pointerType = pointerUtils.getPointerType(pointer);\n    this.target = eventTarget;\n    this.currentTarget = null;\n\n    if (type === 'tap') {\n      var pointerIndex = interaction.getPointerIndex(pointer);\n      this.dt = this.timeStamp - interaction.downTimes[pointerIndex];\n\n      var interval = this.timeStamp - interaction.tapTime;\n\n      this.double = !!(interaction.prevTap && interaction.prevTap.type !== 'doubletap' && interaction.prevTap.target === this.target && interval < 500);\n    } else if (type === 'doubletap') {\n      this.dt = pointer.timeStamp - interaction.tapTime;\n    }\n  }\n\n  PointerEvent.prototype.subtractOrigin = function subtractOrigin(_ref) {\n    var originX = _ref.x,\n        originY = _ref.y;\n\n    this.pageX -= originX;\n    this.pageY -= originY;\n    this.clientX -= originX;\n    this.clientY -= originY;\n\n    return this;\n  };\n\n  PointerEvent.prototype.addOrigin = function addOrigin(_ref2) {\n    var originX = _ref2.x,\n        originY = _ref2.y;\n\n    this.pageX += originX;\n    this.pageY += originY;\n    this.clientX += originX;\n    this.clientY += originY;\n\n    return this;\n  };\n\n  PointerEvent.prototype.preventDefault = function preventDefault() {\n    this.originalEvent.preventDefault();\n  };\n\n  PointerEvent.prototype.stopPropagation = function stopPropagation() {\n    this.propagationStopped = true;\n  };\n\n  PointerEvent.prototype.stopImmediatePropagation = function stopImmediatePropagation() {\n    this.immediatePropagationStopped = this.propagationStopped = true;\n  };\n\n  return PointerEvent;\n}();\n\n},{\"../utils/pointerUtils\":49}],31:[function(require,module,exports){\n'use strict';\n\nvar PointerEvent = require('./PointerEvent');\nvar Interaction = require('../Interaction');\nvar utils = require('../utils');\nvar browser = require('../utils/browser');\nvar defaults = require('../defaultOptions');\nvar signals = require('../utils/Signals').new();\n\nvar _require = require('../utils/arr'),\n    filter = _require.filter;\n\nvar simpleSignals = ['down', 'up', 'cancel'];\nvar simpleEvents = ['down', 'up', 'cancel'];\n\nvar pointerEvents = {\n  PointerEvent: PointerEvent,\n  fire: fire,\n  collectEventTargets: collectEventTargets,\n  signals: signals,\n  defaults: {\n    holdDuration: 600,\n    ignoreFrom: null,\n    allowFrom: null,\n    origin: { x: 0, y: 0 }\n  },\n  types: ['down', 'move', 'up', 'cancel', 'tap', 'doubletap', 'hold']\n};\n\nfunction fire(arg) {\n  var interaction = arg.interaction,\n      pointer = arg.pointer,\n      event = arg.event,\n      eventTarget = arg.eventTarget,\n      _arg$type = arg.type,\n      type = _arg$type === undefined ? arg.pointerEvent.type : _arg$type,\n      _arg$targets = arg.targets,\n      targets = _arg$targets === undefined ? collectEventTargets(arg) : _arg$targets,\n      _arg$pointerEvent = arg.pointerEvent,\n      pointerEvent = _arg$pointerEvent === undefined ? new PointerEvent(type, pointer, event, eventTarget, interaction) : _arg$pointerEvent;\n\n\n  var signalArg = {\n    interaction: interaction,\n    pointer: pointer,\n    event: event,\n    eventTarget: eventTarget,\n    targets: targets,\n    type: type,\n    pointerEvent: pointerEvent\n  };\n\n  for (var i = 0; i < targets.length; i++) {\n    var target = targets[i];\n\n    for (var prop in target.props || {}) {\n      pointerEvent[prop] = target.props[prop];\n    }\n\n    var origin = utils.getOriginXY(target.eventable, target.element);\n\n    pointerEvent.subtractOrigin(origin);\n    pointerEvent.eventable = target.eventable;\n    pointerEvent.currentTarget = target.element;\n\n    target.eventable.fire(pointerEvent);\n\n    pointerEvent.addOrigin(origin);\n\n    if (pointerEvent.immediatePropagationStopped || pointerEvent.propagationStopped && i + 1 < targets.length && targets[i + 1].element !== pointerEvent.currentTarget) {\n      break;\n    }\n  }\n\n  signals.fire('fired', signalArg);\n\n  if (type === 'tap') {\n    // if pointerEvent should make a double tap, create and fire a doubletap\n    // PointerEvent and use that as the prevTap\n    var prevTap = pointerEvent.double ? fire({\n      interaction: interaction, pointer: pointer, event: event, eventTarget: eventTarget,\n      type: 'doubletap'\n    }) : pointerEvent;\n\n    interaction.prevTap = prevTap;\n    interaction.tapTime = prevTap.timeStamp;\n  }\n\n  return pointerEvent;\n}\n\nfunction collectEventTargets(_ref) {\n  var interaction = _ref.interaction,\n      pointer = _ref.pointer,\n      event = _ref.event,\n      eventTarget = _ref.eventTarget,\n      type = _ref.type;\n\n  var pointerIndex = interaction.getPointerIndex(pointer);\n\n  // do not fire a tap event if the pointer was moved before being lifted\n  if (type === 'tap' && (interaction.pointerWasMoved\n  // or if the pointerup target is different to the pointerdown target\n  || !(interaction.downTargets[pointerIndex] && interaction.downTargets[pointerIndex] === eventTarget))) {\n    return [];\n  }\n\n  var path = utils.getPath(eventTarget);\n  var signalArg = {\n    interaction: interaction,\n    pointer: pointer,\n    event: event,\n    eventTarget: eventTarget,\n    type: type,\n    path: path,\n    targets: [],\n    element: null\n  };\n\n  for (var _iterator = path, _isArray = Array.isArray(_iterator), _i = 0, _iterator = _isArray ? _iterator : _iterator[Symbol.iterator]();;) {\n    var _ref2;\n\n    if (_isArray) {\n      if (_i >= _iterator.length) break;\n      _ref2 = _iterator[_i++];\n    } else {\n      _i = _iterator.next();\n      if (_i.done) break;\n      _ref2 = _i.value;\n    }\n\n    var element = _ref2;\n\n    signalArg.element = element;\n\n    signals.fire('collect-targets', signalArg);\n  }\n\n  if (type === 'hold') {\n    signalArg.targets = filter(signalArg.targets, function (target) {\n      return target.eventable.options.holdDuration === interaction.holdTimers[pointerIndex].duration;\n    });\n  }\n\n  return signalArg.targets;\n}\n\nInteraction.signals.on('update-pointer-down', function (_ref3) {\n  var interaction = _ref3.interaction,\n      pointerIndex = _ref3.pointerIndex;\n\n  interaction.holdTimers[pointerIndex] = { duration: Infinity, timeout: null };\n});\n\nInteraction.signals.on('remove-pointer', function (_ref4) {\n  var interaction = _ref4.interaction,\n      pointerIndex = _ref4.pointerIndex;\n\n  interaction.holdTimers.splice(pointerIndex, 1);\n});\n\nInteraction.signals.on('move', function (_ref5) {\n  var interaction = _ref5.interaction,\n      pointer = _ref5.pointer,\n      event = _ref5.event,\n      eventTarget = _ref5.eventTarget,\n      duplicateMove = _ref5.duplicateMove;\n\n  var pointerIndex = interaction.getPointerIndex(pointer);\n\n  if (!duplicateMove && (!interaction.pointerIsDown || interaction.pointerWasMoved)) {\n    if (interaction.pointerIsDown) {\n      clearTimeout(interaction.holdTimers[pointerIndex].timeout);\n    }\n\n    fire({\n      interaction: interaction, pointer: pointer, event: event, eventTarget: eventTarget,\n      type: 'move'\n    });\n  }\n});\n\nInteraction.signals.on('down', function (_ref6) {\n  var interaction = _ref6.interaction,\n      pointer = _ref6.pointer,\n      event = _ref6.event,\n      eventTarget = _ref6.eventTarget,\n      pointerIndex = _ref6.pointerIndex;\n\n  // copy event to be used in timeout for IE8\n  var eventCopy = browser.isIE8 ? utils.extend({}, event) : event;\n\n  var timer = interaction.holdTimers[pointerIndex];\n  var path = utils.getPath(eventTarget);\n  var signalArg = {\n    interaction: interaction,\n    pointer: pointer,\n    event: event,\n    eventTarget: eventTarget,\n    type: 'hold',\n    targets: [],\n    path: path,\n    element: null\n  };\n\n  for (var _iterator2 = path, _isArray2 = Array.isArray(_iterator2), _i2 = 0, _iterator2 = _isArray2 ? _iterator2 : _iterator2[Symbol.iterator]();;) {\n    var _ref7;\n\n    if (_isArray2) {\n      if (_i2 >= _iterator2.length) break;\n      _ref7 = _iterator2[_i2++];\n    } else {\n      _i2 = _iterator2.next();\n      if (_i2.done) break;\n      _ref7 = _i2.value;\n    }\n\n    var element = _ref7;\n\n    signalArg.element = element;\n\n    signals.fire('collect-targets', signalArg);\n  }\n\n  if (!signalArg.targets.length) {\n    return;\n  }\n\n  var minDuration = Infinity;\n\n  for (var i = 0; i < signalArg.targets.length; i++) {\n    var target = signalArg.targets[i];\n    var holdDuration = target.eventable.options.holdDuration;\n\n    if (holdDuration < minDuration) {\n      minDuration = holdDuration;\n    }\n  }\n\n  timer.duration = minDuration;\n  timer.timeout = setTimeout(function () {\n    fire({\n      interaction: interaction,\n      eventTarget: eventTarget,\n      pointer: browser.isIE8 ? eventCopy : pointer,\n      event: eventCopy,\n      type: 'hold'\n    });\n  }, minDuration);\n});\n\nInteraction.signals.on('up', function (_ref8) {\n  var interaction = _ref8.interaction,\n      pointer = _ref8.pointer,\n      event = _ref8.event,\n      eventTarget = _ref8.eventTarget;\n\n  if (!interaction.pointerWasMoved) {\n    fire({ interaction: interaction, eventTarget: eventTarget, pointer: pointer, event: event, type: 'tap' });\n  }\n});\n\n['up', 'cancel'].forEach(function (signalName) {\n  Interaction.signals.on(signalName, function (_ref9) {\n    var interaction = _ref9.interaction,\n        pointerIndex = _ref9.pointerIndex;\n\n    if (interaction.holdTimers[pointerIndex]) {\n      clearTimeout(interaction.holdTimers[pointerIndex].timeout);\n    }\n  });\n});\n\nfunction createSignalListener(type) {\n  return function (_ref10) {\n    var interaction = _ref10.interaction,\n        pointer = _ref10.pointer,\n        event = _ref10.event,\n        eventTarget = _ref10.eventTarget;\n\n    fire({ interaction: interaction, eventTarget: eventTarget, pointer: pointer, event: event, type: type });\n  };\n}\n\nfor (var i = 0; i < simpleSignals.length; i++) {\n  Interaction.signals.on(simpleSignals[i], createSignalListener(simpleEvents[i]));\n}\n\nInteraction.signals.on('new', function (interaction) {\n  interaction.prevTap = null; // the most recent tap event on this interaction\n  interaction.tapTime = 0; // time of the most recent tap event\n  interaction.holdTimers = []; // [{ duration, timeout }]\n});\n\ndefaults.pointerEvents = pointerEvents.defaults;\nmodule.exports = pointerEvents;\n\n},{\"../Interaction\":5,\"../defaultOptions\":18,\"../utils\":44,\"../utils/Signals\":35,\"../utils/arr\":36,\"../utils/browser\":37,\"./PointerEvent\":30}],32:[function(require,module,exports){\n'use strict';\n\nvar pointerEvents = require('./base');\nvar Interaction = require('../Interaction');\n\npointerEvents.signals.on('new', onNew);\npointerEvents.signals.on('fired', onFired);\n\nvar _arr = ['move', 'up', 'cancel', 'endall'];\nfor (var _i = 0; _i < _arr.length; _i++) {\n  var signal = _arr[_i];\n  Interaction.signals.on(signal, endHoldRepeat);\n}\n\nfunction onNew(_ref) {\n  var pointerEvent = _ref.pointerEvent;\n\n  if (pointerEvent.type !== 'hold') {\n    return;\n  }\n\n  pointerEvent.count = (pointerEvent.count || 0) + 1;\n}\n\nfunction onFired(_ref2) {\n  var interaction = _ref2.interaction,\n      pointerEvent = _ref2.pointerEvent,\n      eventTarget = _ref2.eventTarget,\n      targets = _ref2.targets;\n\n  if (pointerEvent.type !== 'hold' || !targets.length) {\n    return;\n  }\n\n  // get the repeat interval from the first eventable\n  var interval = targets[0].eventable.options.holdRepeatInterval;\n\n  // don't repeat if the interval is 0 or less\n  if (interval <= 0) {\n    return;\n  }\n\n  // set a timeout to fire the holdrepeat event\n  interaction.holdIntervalHandle = setTimeout(function () {\n    pointerEvents.fire({\n      interaction: interaction,\n      eventTarget: eventTarget,\n      type: 'hold',\n      pointer: pointerEvent,\n      event: pointerEvent\n    });\n  }, interval);\n}\n\nfunction endHoldRepeat(_ref3) {\n  var interaction = _ref3.interaction;\n\n  // set the interaction's holdStopTime property\n  // to stop further holdRepeat events\n  if (interaction.holdIntervalHandle) {\n    clearInterval(interaction.holdIntervalHandle);\n    interaction.holdIntervalHandle = null;\n  }\n}\n\n// don't repeat by default\npointerEvents.defaults.holdRepeatInterval = 0;\npointerEvents.types.push('holdrepeat');\n\nmodule.exports = {\n  onNew: onNew,\n  onFired: onFired,\n  endHoldRepeat: endHoldRepeat\n};\n\n},{\"../Interaction\":5,\"./base\":31}],33:[function(require,module,exports){\n'use strict';\n\nvar pointerEvents = require('./base');\nvar Interactable = require('../Interactable');\nvar browser = require('../utils/browser');\nvar is = require('../utils/is');\nvar domUtils = require('../utils/domUtils');\nvar scope = require('../scope');\nvar extend = require('../utils/extend');\n\nvar _require = require('../utils/arr'),\n    merge = _require.merge;\n\npointerEvents.signals.on('collect-targets', function (_ref) {\n  var targets = _ref.targets,\n      element = _ref.element,\n      type = _ref.type,\n      eventTarget = _ref.eventTarget;\n\n  function collectSelectors(interactable, selector, context) {\n    var els = browser.useMatchesSelectorPolyfill ? context.querySelectorAll(selector) : undefined;\n\n    var eventable = interactable.events;\n    var options = eventable.options;\n\n    if (eventable[type] && is.element(element) && domUtils.matchesSelector(element, selector, els) && interactable.testIgnoreAllow(options, element, eventTarget)) {\n\n      targets.push({\n        element: element,\n        eventable: eventable,\n        props: { interactable: interactable }\n      });\n    }\n  }\n\n  var interactable = scope.interactables.get(element);\n\n  if (interactable) {\n    var eventable = interactable.events;\n    var options = eventable.options;\n\n    if (eventable[type] && interactable.testIgnoreAllow(options, element, eventTarget)) {\n      targets.push({\n        element: element,\n        eventable: eventable,\n        props: { interactable: interactable }\n      });\n    }\n  }\n\n  scope.interactables.forEachSelector(collectSelectors, element);\n});\n\nInteractable.signals.on('new', function (_ref2) {\n  var interactable = _ref2.interactable;\n\n  interactable.events.getRect = function (element) {\n    return interactable.getRect(element);\n  };\n});\n\nInteractable.signals.on('set', function (_ref3) {\n  var interactable = _ref3.interactable,\n      options = _ref3.options;\n\n  extend(interactable.events.options, pointerEvents.defaults);\n  extend(interactable.events.options, options);\n});\n\nmerge(Interactable.eventTypes, pointerEvents.types);\n\nInteractable.prototype.pointerEvents = function (options) {\n  extend(this.events.options, options);\n\n  return this;\n};\n\nvar __backCompatOption = Interactable.prototype._backCompatOption;\n\nInteractable.prototype._backCompatOption = function (optionName, newValue) {\n  var ret = __backCompatOption.call(this, optionName, newValue);\n\n  if (ret === this) {\n    this.events.options[optionName] = newValue;\n  }\n\n  return ret;\n};\n\nInteractable.settingsMethods.push('pointerEvents');\n\n},{\"../Interactable\":4,\"../scope\":34,\"../utils/arr\":36,\"../utils/browser\":37,\"../utils/domUtils\":39,\"../utils/extend\":41,\"../utils/is\":46,\"./base\":31}],34:[function(require,module,exports){\n'use strict';\n\nvar utils = require('./utils');\nvar events = require('./utils/events');\nvar signals = require('./utils/Signals').new();\n\nvar scope = {\n  signals: signals,\n  events: events,\n  utils: utils,\n\n  // main document\n  document: require('./utils/domObjects').document,\n  // all documents being listened to\n  documents: [],\n\n  addDocument: function addDocument(doc, win) {\n    // do nothing if document is already known\n    if (utils.contains(scope.documents, doc)) {\n      return false;\n    }\n\n    win = win || scope.getWindow(doc);\n\n    scope.documents.push(doc);\n    events.documents.push(doc);\n\n    // don't add an unload event for the main document\n    // so that the page may be cached in browser history\n    if (doc !== scope.document) {\n      events.add(win, 'unload', scope.onWindowUnload);\n    }\n\n    signals.fire('add-document', { doc: doc, win: win });\n  },\n\n  removeDocument: function removeDocument(doc, win) {\n    var index = utils.indexOf(scope.documents, doc);\n\n    win = win || scope.getWindow(doc);\n\n    events.remove(win, 'unload', scope.onWindowUnload);\n\n    scope.documents.splice(index, 1);\n    events.documents.splice(index, 1);\n\n    signals.fire('remove-document', { win: win, doc: doc });\n  },\n\n  onWindowUnload: function onWindowUnload() {\n    scope.removeDocument(this.document, this);\n  }\n};\n\nmodule.exports = scope;\n\n},{\"./utils\":44,\"./utils/Signals\":35,\"./utils/domObjects\":38,\"./utils/events\":40}],35:[function(require,module,exports){\n'use strict';\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nvar _require = require('./arr'),\n    indexOf = _require.indexOf;\n\nvar Signals = function () {\n  function Signals() {\n    _classCallCheck(this, Signals);\n\n    this.listeners = {\n      // signalName: [listeners],\n    };\n  }\n\n  Signals.prototype.on = function on(name, listener) {\n    if (!this.listeners[name]) {\n      this.listeners[name] = [listener];\n      return;\n    }\n\n    this.listeners[name].push(listener);\n  };\n\n  Signals.prototype.off = function off(name, listener) {\n    if (!this.listeners[name]) {\n      return;\n    }\n\n    var index = indexOf(this.listeners[name], listener);\n\n    if (index !== -1) {\n      this.listeners[name].splice(index, 1);\n    }\n  };\n\n  Signals.prototype.fire = function fire(name, arg) {\n    var targetListeners = this.listeners[name];\n\n    if (!targetListeners) {\n      return;\n    }\n\n    for (var i = 0; i < targetListeners.length; i++) {\n      if (targetListeners[i](arg, name) === false) {\n        return;\n      }\n    }\n  };\n\n  return Signals;\n}();\n\nSignals.new = function () {\n  return new Signals();\n};\n\nmodule.exports = Signals;\n\n},{\"./arr\":36}],36:[function(require,module,exports){\n\"use strict\";\n\nfunction indexOf(array, target) {\n  for (var i = 0, len = array.length; i < len; i++) {\n    if (array[i] === target) {\n      return i;\n    }\n  }\n\n  return -1;\n}\n\nfunction contains(array, target) {\n  return indexOf(array, target) !== -1;\n}\n\nfunction merge(target, source) {\n  for (var i = 0; i < source.length; i++) {\n    target.push(source[i]);\n  }\n\n  return target;\n}\n\nfunction filter(array, test) {\n  var result = [];\n\n  for (var i = 0; i < array.length; i++) {\n    if (test(array[i])) {\n      result.push(array[i]);\n    }\n  }\n\n  return result;\n}\n\nmodule.exports = {\n  indexOf: indexOf,\n  contains: contains,\n  merge: merge,\n  filter: filter\n};\n\n},{}],37:[function(require,module,exports){\n'use strict';\n\nvar _require = require('./window'),\n    window = _require.window;\n\nvar is = require('./is');\nvar domObjects = require('./domObjects');\n\nvar Element = domObjects.Element;\nvar navigator = window.navigator;\n\nvar browser = {\n  // Does the browser support touch input?\n  supportsTouch: !!('ontouchstart' in window || is.function(window.DocumentTouch) && domObjects.document instanceof window.DocumentTouch),\n\n  // Does the browser support PointerEvents\n  supportsPointerEvent: !!domObjects.PointerEvent,\n\n  isIE8: 'attachEvent' in window && !('addEventListener' in window),\n\n  // Opera Mobile must be handled differently\n  isOperaMobile: navigator.appName === 'Opera' && browser.supportsTouch && navigator.userAgent.match('Presto'),\n\n  // scrolling doesn't change the result of getClientRects on iOS 7\n  isIOS7: /iP(hone|od|ad)/.test(navigator.platform) && /OS 7[^\\d]/.test(navigator.appVersion),\n\n  isIe9OrOlder: /MSIE (8|9)/.test(navigator.userAgent),\n\n  // prefix matchesSelector\n  prefixedMatchesSelector: 'matches' in Element.prototype ? 'matches' : 'webkitMatchesSelector' in Element.prototype ? 'webkitMatchesSelector' : 'mozMatchesSelector' in Element.prototype ? 'mozMatchesSelector' : 'oMatchesSelector' in Element.prototype ? 'oMatchesSelector' : 'msMatchesSelector',\n\n  useMatchesSelectorPolyfill: false,\n\n  pEventTypes: domObjects.PointerEvent ? domObjects.PointerEvent === window.MSPointerEvent ? {\n    up: 'MSPointerUp',\n    down: 'MSPointerDown',\n    over: 'mouseover',\n    out: 'mouseout',\n    move: 'MSPointerMove',\n    cancel: 'MSPointerCancel'\n  } : {\n    up: 'pointerup',\n    down: 'pointerdown',\n    over: 'pointerover',\n    out: 'pointerout',\n    move: 'pointermove',\n    cancel: 'pointercancel'\n  } : null,\n\n  // because Webkit and Opera still use 'mousewheel' event type\n  wheelEvent: 'onmousewheel' in domObjects.document ? 'mousewheel' : 'wheel'\n\n};\n\nbrowser.useMatchesSelectorPolyfill = !is.function(Element.prototype[browser.prefixedMatchesSelector]);\n\nmodule.exports = browser;\n\n},{\"./domObjects\":38,\"./is\":46,\"./window\":52}],38:[function(require,module,exports){\n'use strict';\n\nvar domObjects = {};\nvar win = require('./window').window;\n\nfunction blank() {}\n\ndomObjects.document = win.document;\ndomObjects.DocumentFragment = win.DocumentFragment || blank;\ndomObjects.SVGElement = win.SVGElement || blank;\ndomObjects.SVGSVGElement = win.SVGSVGElement || blank;\ndomObjects.SVGElementInstance = win.SVGElementInstance || blank;\ndomObjects.Element = win.Element || blank;\ndomObjects.HTMLElement = win.HTMLElement || domObjects.Element;\n\ndomObjects.Event = win.Event;\ndomObjects.Touch = win.Touch || blank;\ndomObjects.PointerEvent = win.PointerEvent || win.MSPointerEvent;\n\nmodule.exports = domObjects;\n\n},{\"./window\":52}],39:[function(require,module,exports){\n'use strict';\n\nvar win = require('./window');\nvar browser = require('./browser');\nvar is = require('./is');\nvar domObjects = require('./domObjects');\n\nvar domUtils = {\n  nodeContains: function nodeContains(parent, child) {\n    while (child) {\n      if (child === parent) {\n        return true;\n      }\n\n      child = child.parentNode;\n    }\n\n    return false;\n  },\n\n  closest: function closest(element, selector) {\n    while (is.element(element)) {\n      if (domUtils.matchesSelector(element, selector)) {\n        return element;\n      }\n\n      element = domUtils.parentNode(element);\n    }\n\n    return null;\n  },\n\n  parentNode: function parentNode(node) {\n    var parent = node.parentNode;\n\n    if (is.docFrag(parent)) {\n      // skip past #shado-root fragments\n      while ((parent = parent.host) && is.docFrag(parent)) {\n        continue;\n      }\n\n      return parent;\n    }\n\n    return parent;\n  },\n\n  // taken from http://tanalin.com/en/blog/2012/12/matches-selector-ie8/ and modified\n  matchesSelectorPolyfill: browser.useMatchesSelectorPolyfill ? function (element, selector, elems) {\n    elems = elems || element.parentNode.querySelectorAll(selector);\n\n    for (var i = 0, len = elems.length; i < len; i++) {\n      if (elems[i] === element) {\n        return true;\n      }\n    }\n\n    return false;\n  } : null,\n\n  matchesSelector: function matchesSelector(element, selector, nodeList) {\n    if (browser.useMatchesSelectorPolyfill) {\n      return domUtils.matchesSelectorPolyfill(element, selector, nodeList);\n    }\n\n    // remove /deep/ from selectors if shadowDOM polyfill is used\n    if (win.window !== win.realWindow) {\n      selector = selector.replace(/\\/deep\\//g, ' ');\n    }\n\n    return element[browser.prefixedMatchesSelector](selector);\n  },\n\n  // Test for the element that's \"above\" all other qualifiers\n  indexOfDeepestElement: function indexOfDeepestElement(elements) {\n    var deepestZoneParents = [];\n    var dropzoneParents = [];\n    var dropzone = void 0;\n    var deepestZone = elements[0];\n    var index = deepestZone ? 0 : -1;\n    var parent = void 0;\n    var child = void 0;\n    var i = void 0;\n    var n = void 0;\n\n    for (i = 1; i < elements.length; i++) {\n      dropzone = elements[i];\n\n      // an element might belong to multiple selector dropzones\n      if (!dropzone || dropzone === deepestZone) {\n        continue;\n      }\n\n      if (!deepestZone) {\n        deepestZone = dropzone;\n        index = i;\n        continue;\n      }\n\n      // check if the deepest or current are document.documentElement or document.rootElement\n      // - if the current dropzone is, do nothing and continue\n      if (dropzone.parentNode === dropzone.ownerDocument) {\n        continue;\n      }\n      // - if deepest is, update with the current dropzone and continue to next\n      else if (deepestZone.parentNode === dropzone.ownerDocument) {\n          deepestZone = dropzone;\n          index = i;\n          continue;\n        }\n\n      if (!deepestZoneParents.length) {\n        parent = deepestZone;\n        while (parent.parentNode && parent.parentNode !== parent.ownerDocument) {\n          deepestZoneParents.unshift(parent);\n          parent = parent.parentNode;\n        }\n      }\n\n      // if this element is an svg element and the current deepest is\n      // an HTMLElement\n      if (deepestZone instanceof domObjects.HTMLElement && dropzone instanceof domObjects.SVGElement && !(dropzone instanceof domObjects.SVGSVGElement)) {\n\n        if (dropzone === deepestZone.parentNode) {\n          continue;\n        }\n\n        parent = dropzone.ownerSVGElement;\n      } else {\n        parent = dropzone;\n      }\n\n      dropzoneParents = [];\n\n      while (parent.parentNode !== parent.ownerDocument) {\n        dropzoneParents.unshift(parent);\n        parent = parent.parentNode;\n      }\n\n      n = 0;\n\n      // get (position of last common ancestor) + 1\n      while (dropzoneParents[n] && dropzoneParents[n] === deepestZoneParents[n]) {\n        n++;\n      }\n\n      var parents = [dropzoneParents[n - 1], dropzoneParents[n], deepestZoneParents[n]];\n\n      child = parents[0].lastChild;\n\n      while (child) {\n        if (child === parents[1]) {\n          deepestZone = dropzone;\n          index = i;\n          deepestZoneParents = [];\n\n          break;\n        } else if (child === parents[2]) {\n          break;\n        }\n\n        child = child.previousSibling;\n      }\n    }\n\n    return index;\n  },\n\n  matchesUpTo: function matchesUpTo(element, selector, limit) {\n    while (is.element(element)) {\n      if (domUtils.matchesSelector(element, selector)) {\n        return true;\n      }\n\n      element = domUtils.parentNode(element);\n\n      if (element === limit) {\n        return domUtils.matchesSelector(element, selector);\n      }\n    }\n\n    return false;\n  },\n\n  getActualElement: function getActualElement(element) {\n    return element instanceof domObjects.SVGElementInstance ? element.correspondingUseElement : element;\n  },\n\n  getScrollXY: function getScrollXY(relevantWindow) {\n    relevantWindow = relevantWindow || win.window;\n    return {\n      x: relevantWindow.scrollX || relevantWindow.document.documentElement.scrollLeft,\n      y: relevantWindow.scrollY || relevantWindow.document.documentElement.scrollTop\n    };\n  },\n\n  getElementClientRect: function getElementClientRect(element) {\n    var clientRect = element instanceof domObjects.SVGElement ? element.getBoundingClientRect() : element.getClientRects()[0];\n\n    return clientRect && {\n      left: clientRect.left,\n      right: clientRect.right,\n      top: clientRect.top,\n      bottom: clientRect.bottom,\n      width: clientRect.width || clientRect.right - clientRect.left,\n      height: clientRect.height || clientRect.bottom - clientRect.top\n    };\n  },\n\n  getElementRect: function getElementRect(element) {\n    var clientRect = domUtils.getElementClientRect(element);\n\n    if (!browser.isIOS7 && clientRect) {\n      var scroll = domUtils.getScrollXY(win.getWindow(element));\n\n      clientRect.left += scroll.x;\n      clientRect.right += scroll.x;\n      clientRect.top += scroll.y;\n      clientRect.bottom += scroll.y;\n    }\n\n    return clientRect;\n  },\n\n  getPath: function getPath(element) {\n    var path = [];\n\n    while (element) {\n      path.push(element);\n      element = domUtils.parentNode(element);\n    }\n\n    return path;\n  },\n\n  trySelector: function trySelector(value) {\n    if (!is.string(value)) {\n      return false;\n    }\n\n    // an exception will be raised if it is invalid\n    domObjects.document.querySelector(value);\n    return true;\n  }\n};\n\nmodule.exports = domUtils;\n\n},{\"./browser\":37,\"./domObjects\":38,\"./is\":46,\"./window\":52}],40:[function(require,module,exports){\n'use strict';\n\nvar is = require('./is');\nvar domUtils = require('./domUtils');\nvar pExtend = require('./pointerExtend');\n\nvar _require = require('./window'),\n    window = _require.window,\n    getWindow = _require.getWindow;\n\nvar _require2 = require('./arr'),\n    indexOf = _require2.indexOf,\n    contains = _require2.contains;\n\nvar useAttachEvent = 'attachEvent' in window && !('addEventListener' in window);\nvar addEvent = useAttachEvent ? 'attachEvent' : 'addEventListener';\nvar removeEvent = useAttachEvent ? 'detachEvent' : 'removeEventListener';\nvar on = useAttachEvent ? 'on' : '';\n\nvar elements = [];\nvar targets = [];\nvar attachedListeners = [];\n\n// {\n//   type: {\n//     selectors: ['selector', ...],\n//     contexts : [document, ...],\n//     listeners: [[listener, capture, passive], ...]\n//   }\n//  }\nvar delegatedEvents = {};\n\nvar documents = [];\n\nvar supportsOptions = !useAttachEvent && function () {\n  var supported = false;\n\n  window.document.createElement('div').addEventListener('test', null, {\n    get capture() {\n      supported = true;\n    }\n  });\n\n  return supported;\n}();\n\nfunction add(element, type, listener, optionalArg) {\n  var options = getOptions(optionalArg);\n  var elementIndex = indexOf(elements, element);\n  var target = targets[elementIndex];\n\n  if (!target) {\n    target = {\n      events: {},\n      typeCount: 0\n    };\n\n    elementIndex = elements.push(element) - 1;\n    targets.push(target);\n\n    attachedListeners.push(useAttachEvent ? {\n      supplied: [],\n      wrapped: [],\n      useCount: []\n    } : null);\n  }\n\n  if (!target.events[type]) {\n    target.events[type] = [];\n    target.typeCount++;\n  }\n\n  if (!contains(target.events[type], listener)) {\n    var ret = void 0;\n\n    if (useAttachEvent) {\n      var _attachedListeners$el = attachedListeners[elementIndex],\n          supplied = _attachedListeners$el.supplied,\n          wrapped = _attachedListeners$el.wrapped,\n          useCount = _attachedListeners$el.useCount;\n\n      var listenerIndex = indexOf(supplied, listener);\n\n      var wrappedListener = wrapped[listenerIndex] || function (event) {\n        if (!event.immediatePropagationStopped) {\n          event.target = event.srcElement;\n          event.currentTarget = element;\n\n          event.preventDefault = event.preventDefault || preventDef;\n          event.stopPropagation = event.stopPropagation || stopProp;\n          event.stopImmediatePropagation = event.stopImmediatePropagation || stopImmProp;\n\n          if (/mouse|click/.test(event.type)) {\n            event.pageX = event.clientX + getWindow(element).document.documentElement.scrollLeft;\n            event.pageY = event.clientY + getWindow(element).document.documentElement.scrollTop;\n          }\n\n          listener(event);\n        }\n      };\n\n      ret = element[addEvent](on + type, wrappedListener, !!options.capture);\n\n      if (listenerIndex === -1) {\n        supplied.push(listener);\n        wrapped.push(wrappedListener);\n        useCount.push(1);\n      } else {\n        useCount[listenerIndex]++;\n      }\n    } else {\n      ret = element[addEvent](type, listener, supportsOptions ? options : !!options.capture);\n    }\n    target.events[type].push(listener);\n\n    return ret;\n  }\n}\n\nfunction remove(element, type, listener, optionalArg) {\n  var options = getOptions(optionalArg);\n  var elementIndex = indexOf(elements, element);\n  var target = targets[elementIndex];\n\n  if (!target || !target.events) {\n    return;\n  }\n\n  var wrappedListener = listener;\n  var listeners = void 0;\n  var listenerIndex = void 0;\n\n  if (useAttachEvent) {\n    listeners = attachedListeners[elementIndex];\n    listenerIndex = indexOf(listeners.supplied, listener);\n    wrappedListener = listeners.wrapped[listenerIndex];\n  }\n\n  if (type === 'all') {\n    for (type in target.events) {\n      if (target.events.hasOwnProperty(type)) {\n        remove(element, type, 'all');\n      }\n    }\n    return;\n  }\n\n  if (target.events[type]) {\n    var len = target.events[type].length;\n\n    if (listener === 'all') {\n      for (var i = 0; i < len; i++) {\n        remove(element, type, target.events[type][i], options);\n      }\n      return;\n    } else {\n      for (var _i = 0; _i < len; _i++) {\n        if (target.events[type][_i] === listener) {\n          element[removeEvent](on + type, wrappedListener, supportsOptions ? options : !!options.capture);\n          target.events[type].splice(_i, 1);\n\n          if (useAttachEvent && listeners) {\n            listeners.useCount[listenerIndex]--;\n            if (listeners.useCount[listenerIndex] === 0) {\n              listeners.supplied.splice(listenerIndex, 1);\n              listeners.wrapped.splice(listenerIndex, 1);\n              listeners.useCount.splice(listenerIndex, 1);\n            }\n          }\n\n          break;\n        }\n      }\n    }\n\n    if (target.events[type] && target.events[type].length === 0) {\n      target.events[type] = null;\n      target.typeCount--;\n    }\n  }\n\n  if (!target.typeCount) {\n    targets.splice(elementIndex, 1);\n    elements.splice(elementIndex, 1);\n    attachedListeners.splice(elementIndex, 1);\n  }\n}\n\nfunction addDelegate(selector, context, type, listener, optionalArg) {\n  var options = getOptions(optionalArg);\n  if (!delegatedEvents[type]) {\n    delegatedEvents[type] = {\n      selectors: [],\n      contexts: [],\n      listeners: []\n    };\n\n    // add delegate listener functions\n    for (var i = 0; i < documents.length; i++) {\n      add(documents[i], type, delegateListener);\n      add(documents[i], type, delegateUseCapture, true);\n    }\n  }\n\n  var delegated = delegatedEvents[type];\n  var index = void 0;\n\n  for (index = delegated.selectors.length - 1; index >= 0; index--) {\n    if (delegated.selectors[index] === selector && delegated.contexts[index] === context) {\n      break;\n    }\n  }\n\n  if (index === -1) {\n    index = delegated.selectors.length;\n\n    delegated.selectors.push(selector);\n    delegated.contexts.push(context);\n    delegated.listeners.push([]);\n  }\n\n  // keep listener and capture and passive flags\n  delegated.listeners[index].push([listener, !!options.capture, options.passive]);\n}\n\nfunction removeDelegate(selector, context, type, listener, optionalArg) {\n  var options = getOptions(optionalArg);\n  var delegated = delegatedEvents[type];\n  var matchFound = false;\n  var index = void 0;\n\n  if (!delegated) {\n    return;\n  }\n\n  // count from last index of delegated to 0\n  for (index = delegated.selectors.length - 1; index >= 0; index--) {\n    // look for matching selector and context Node\n    if (delegated.selectors[index] === selector && delegated.contexts[index] === context) {\n\n      var listeners = delegated.listeners[index];\n\n      // each item of the listeners array is an array: [function, capture, passive]\n      for (var i = listeners.length - 1; i >= 0; i--) {\n        var _listeners$i = listeners[i],\n            fn = _listeners$i[0],\n            capture = _listeners$i[1],\n            passive = _listeners$i[2];\n\n        // check if the listener functions and capture and passive flags match\n\n        if (fn === listener && capture === !!options.capture && passive === options.passive) {\n          // remove the listener from the array of listeners\n          listeners.splice(i, 1);\n\n          // if all listeners for this interactable have been removed\n          // remove the interactable from the delegated arrays\n          if (!listeners.length) {\n            delegated.selectors.splice(index, 1);\n            delegated.contexts.splice(index, 1);\n            delegated.listeners.splice(index, 1);\n\n            // remove delegate function from context\n            remove(context, type, delegateListener);\n            remove(context, type, delegateUseCapture, true);\n\n            // remove the arrays if they are empty\n            if (!delegated.selectors.length) {\n              delegatedEvents[type] = null;\n            }\n          }\n\n          // only remove one listener\n          matchFound = true;\n          break;\n        }\n      }\n\n      if (matchFound) {\n        break;\n      }\n    }\n  }\n}\n\n// bound to the interactable context when a DOM event\n// listener is added to a selector interactable\nfunction delegateListener(event, optionalArg) {\n  var options = getOptions(optionalArg);\n  var fakeEvent = {};\n  var delegated = delegatedEvents[event.type];\n  var eventTarget = domUtils.getActualElement(event.path ? event.path[0] : event.target);\n  var element = eventTarget;\n\n  // duplicate the event so that currentTarget can be changed\n  pExtend(fakeEvent, event);\n\n  fakeEvent.originalEvent = event;\n  fakeEvent.preventDefault = preventOriginalDefault;\n\n  // climb up document tree looking for selector matches\n  while (is.element(element)) {\n    for (var i = 0; i < delegated.selectors.length; i++) {\n      var selector = delegated.selectors[i];\n      var context = delegated.contexts[i];\n\n      if (domUtils.matchesSelector(element, selector) && domUtils.nodeContains(context, eventTarget) && domUtils.nodeContains(context, element)) {\n\n        var listeners = delegated.listeners[i];\n\n        fakeEvent.currentTarget = element;\n\n        for (var j = 0; j < listeners.length; j++) {\n          var _listeners$j = listeners[j],\n              fn = _listeners$j[0],\n              capture = _listeners$j[1],\n              passive = _listeners$j[2];\n\n\n          if (capture === !!options.capture && passive === options.passive) {\n            fn(fakeEvent);\n          }\n        }\n      }\n    }\n\n    element = domUtils.parentNode(element);\n  }\n}\n\nfunction delegateUseCapture(event) {\n  return delegateListener.call(this, event, true);\n}\n\nfunction preventDef() {\n  this.returnValue = false;\n}\n\nfunction preventOriginalDefault() {\n  this.originalEvent.preventDefault();\n}\n\nfunction stopProp() {\n  this.cancelBubble = true;\n}\n\nfunction stopImmProp() {\n  this.cancelBubble = true;\n  this.immediatePropagationStopped = true;\n}\n\nfunction getOptions(param) {\n  return is.object(param) ? param : { capture: param };\n}\n\nmodule.exports = {\n  add: add,\n  remove: remove,\n\n  addDelegate: addDelegate,\n  removeDelegate: removeDelegate,\n\n  delegateListener: delegateListener,\n  delegateUseCapture: delegateUseCapture,\n  delegatedEvents: delegatedEvents,\n  documents: documents,\n\n  useAttachEvent: useAttachEvent,\n  supportsOptions: supportsOptions,\n\n  _elements: elements,\n  _targets: targets,\n  _attachedListeners: attachedListeners\n};\n\n},{\"./arr\":36,\"./domUtils\":39,\"./is\":46,\"./pointerExtend\":48,\"./window\":52}],41:[function(require,module,exports){\n\"use strict\";\n\nmodule.exports = function extend(dest, source) {\n  for (var prop in source) {\n    dest[prop] = source[prop];\n  }\n  return dest;\n};\n\n},{}],42:[function(require,module,exports){\n'use strict';\n\nvar _require = require('./rect'),\n    resolveRectLike = _require.resolveRectLike,\n    rectToXY = _require.rectToXY;\n\nmodule.exports = function (target, element, action) {\n  var actionOptions = target.options[action];\n  var actionOrigin = actionOptions && actionOptions.origin;\n  var origin = actionOrigin || target.options.origin;\n\n  var originRect = resolveRectLike(origin, target, element, [target && element]);\n\n  return rectToXY(originRect) || { x: 0, y: 0 };\n};\n\n},{\"./rect\":51}],43:[function(require,module,exports){\n\"use strict\";\n\nmodule.exports = function (x, y) {\n  return Math.sqrt(x * x + y * y);\n};\n\n},{}],44:[function(require,module,exports){\n'use strict';\n\nvar extend = require('./extend');\nvar win = require('./window');\n\nvar utils = {\n  warnOnce: function warnOnce(method, message) {\n    var warned = false;\n\n    return function () {\n      if (!warned) {\n        win.window.console.warn(message);\n        warned = true;\n      }\n\n      return method.apply(this, arguments);\n    };\n  },\n\n  // http://stackoverflow.com/a/5634528/2280888\n  _getQBezierValue: function _getQBezierValue(t, p1, p2, p3) {\n    var iT = 1 - t;\n    return iT * iT * p1 + 2 * iT * t * p2 + t * t * p3;\n  },\n\n  getQuadraticCurvePoint: function getQuadraticCurvePoint(startX, startY, cpX, cpY, endX, endY, position) {\n    return {\n      x: utils._getQBezierValue(position, startX, cpX, endX),\n      y: utils._getQBezierValue(position, startY, cpY, endY)\n    };\n  },\n\n  // http://gizma.com/easing/\n  easeOutQuad: function easeOutQuad(t, b, c, d) {\n    t /= d;\n    return -c * t * (t - 2) + b;\n  },\n\n  copyAction: function copyAction(dest, src) {\n    dest.name = src.name;\n    dest.axis = src.axis;\n    dest.edges = src.edges;\n\n    return dest;\n  },\n\n  is: require('./is'),\n  extend: extend,\n  hypot: require('./hypot'),\n  getOriginXY: require('./getOriginXY')\n};\n\nextend(utils, require('./arr'));\nextend(utils, require('./domUtils'));\nextend(utils, require('./pointerUtils'));\nextend(utils, require('./rect'));\n\nmodule.exports = utils;\n\n},{\"./arr\":36,\"./domUtils\":39,\"./extend\":41,\"./getOriginXY\":42,\"./hypot\":43,\"./is\":46,\"./pointerUtils\":49,\"./rect\":51,\"./window\":52}],45:[function(require,module,exports){\n'use strict';\n\nvar scope = require('../scope');\nvar utils = require('./index');\n\nvar finder = {\n  methodOrder: ['simulationResume', 'mouseOrPen', 'hasPointer', 'idle'],\n\n  search: function search(pointer, eventType, eventTarget) {\n    var pointerType = utils.getPointerType(pointer);\n    var pointerId = utils.getPointerId(pointer);\n    var details = { pointer: pointer, pointerId: pointerId, pointerType: pointerType, eventType: eventType, eventTarget: eventTarget };\n\n    for (var _iterator = finder.methodOrder, _isArray = Array.isArray(_iterator), _i = 0, _iterator = _isArray ? _iterator : _iterator[Symbol.iterator]();;) {\n      var _ref;\n\n      if (_isArray) {\n        if (_i >= _iterator.length) break;\n        _ref = _iterator[_i++];\n      } else {\n        _i = _iterator.next();\n        if (_i.done) break;\n        _ref = _i.value;\n      }\n\n      var method = _ref;\n\n      var interaction = finder[method](details);\n\n      if (interaction) {\n        return interaction;\n      }\n    }\n  },\n\n  // try to resume simulation with a new pointer\n  simulationResume: function simulationResume(_ref2) {\n    var pointerType = _ref2.pointerType,\n        eventType = _ref2.eventType,\n        eventTarget = _ref2.eventTarget;\n\n    if (!/down|start/i.test(eventType)) {\n      return null;\n    }\n\n    for (var _iterator2 = scope.interactions, _isArray2 = Array.isArray(_iterator2), _i2 = 0, _iterator2 = _isArray2 ? _iterator2 : _iterator2[Symbol.iterator]();;) {\n      var _ref3;\n\n      if (_isArray2) {\n        if (_i2 >= _iterator2.length) break;\n        _ref3 = _iterator2[_i2++];\n      } else {\n        _i2 = _iterator2.next();\n        if (_i2.done) break;\n        _ref3 = _i2.value;\n      }\n\n      var interaction = _ref3;\n\n      var element = eventTarget;\n\n      if (interaction.simulation && interaction.simulation.allowResume && interaction.pointerType === pointerType) {\n        while (element) {\n          // if the element is the interaction element\n          if (element === interaction.element) {\n            return interaction;\n          }\n          element = utils.parentNode(element);\n        }\n      }\n    }\n\n    return null;\n  },\n\n  // if it's a mouse or pen interaction\n  mouseOrPen: function mouseOrPen(_ref4) {\n    var pointerId = _ref4.pointerId,\n        pointerType = _ref4.pointerType,\n        eventType = _ref4.eventType;\n\n    if (pointerType !== 'mouse' && pointerType !== 'pen') {\n      return null;\n    }\n\n    var firstNonActive = void 0;\n\n    for (var _iterator3 = scope.interactions, _isArray3 = Array.isArray(_iterator3), _i3 = 0, _iterator3 = _isArray3 ? _iterator3 : _iterator3[Symbol.iterator]();;) {\n      var _ref5;\n\n      if (_isArray3) {\n        if (_i3 >= _iterator3.length) break;\n        _ref5 = _iterator3[_i3++];\n      } else {\n        _i3 = _iterator3.next();\n        if (_i3.done) break;\n        _ref5 = _i3.value;\n      }\n\n      var interaction = _ref5;\n\n      if (interaction.pointerType === pointerType) {\n        // if it's a down event, skip interactions with running simulations\n        if (interaction.simulation && !utils.contains(interaction.pointerIds, pointerId)) {\n          continue;\n        }\n\n        // if the interaction is active, return it immediately\n        if (interaction.interacting()) {\n          return interaction;\n        }\n        // otherwise save it and look for another active interaction\n        else if (!firstNonActive) {\n            firstNonActive = interaction;\n          }\n      }\n    }\n\n    // if no active mouse interaction was found use the first inactive mouse\n    // interaction\n    if (firstNonActive) {\n      return firstNonActive;\n    }\n\n    // find any mouse or pen interaction.\n    // ignore the interaction if the eventType is a *down, and a simulation\n    // is active\n    for (var _iterator4 = scope.interactions, _isArray4 = Array.isArray(_iterator4), _i4 = 0, _iterator4 = _isArray4 ? _iterator4 : _iterator4[Symbol.iterator]();;) {\n      var _ref6;\n\n      if (_isArray4) {\n        if (_i4 >= _iterator4.length) break;\n        _ref6 = _iterator4[_i4++];\n      } else {\n        _i4 = _iterator4.next();\n        if (_i4.done) break;\n        _ref6 = _i4.value;\n      }\n\n      var _interaction = _ref6;\n\n      if (_interaction.pointerType === pointerType && !(/down/i.test(eventType) && _interaction.simulation)) {\n        return _interaction;\n      }\n    }\n\n    return null;\n  },\n\n  // get interaction that has this pointer\n  hasPointer: function hasPointer(_ref7) {\n    var pointerId = _ref7.pointerId;\n\n    for (var _iterator5 = scope.interactions, _isArray5 = Array.isArray(_iterator5), _i5 = 0, _iterator5 = _isArray5 ? _iterator5 : _iterator5[Symbol.iterator]();;) {\n      var _ref8;\n\n      if (_isArray5) {\n        if (_i5 >= _iterator5.length) break;\n        _ref8 = _iterator5[_i5++];\n      } else {\n        _i5 = _iterator5.next();\n        if (_i5.done) break;\n        _ref8 = _i5.value;\n      }\n\n      var interaction = _ref8;\n\n      if (utils.contains(interaction.pointerIds, pointerId)) {\n        return interaction;\n      }\n    }\n  },\n\n  // get first idle interaction with a matching pointerType\n  idle: function idle(_ref9) {\n    var pointerType = _ref9.pointerType;\n\n    for (var _iterator6 = scope.interactions, _isArray6 = Array.isArray(_iterator6), _i6 = 0, _iterator6 = _isArray6 ? _iterator6 : _iterator6[Symbol.iterator]();;) {\n      var _ref10;\n\n      if (_isArray6) {\n        if (_i6 >= _iterator6.length) break;\n        _ref10 = _iterator6[_i6++];\n      } else {\n        _i6 = _iterator6.next();\n        if (_i6.done) break;\n        _ref10 = _i6.value;\n      }\n\n      var interaction = _ref10;\n\n      // if there's already a pointer held down\n      if (interaction.pointerIds.length === 1) {\n        var target = interaction.target;\n        // don't add this pointer if there is a target interactable and it\n        // isn't gesturable\n        if (target && !target.options.gesture.enabled) {\n          continue;\n        }\n      }\n      // maximum of 2 pointers per interaction\n      else if (interaction.pointerIds.length >= 2) {\n          continue;\n        }\n\n      if (!interaction.interacting() && pointerType === interaction.pointerType) {\n        return interaction;\n      }\n    }\n\n    return null;\n  }\n};\n\nmodule.exports = finder;\n\n},{\"../scope\":34,\"./index\":44}],46:[function(require,module,exports){\n'use strict';\n\nvar _typeof = typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; };\n\nvar win = require('./window');\nvar isWindow = require('./isWindow');\n\nvar is = {\n  array: function array() {},\n\n  window: function window(thing) {\n    return thing === win.window || isWindow(thing);\n  },\n\n  docFrag: function docFrag(thing) {\n    return is.object(thing) && thing.nodeType === 11;\n  },\n\n  object: function object(thing) {\n    return !!thing && (typeof thing === 'undefined' ? 'undefined' : _typeof(thing)) === 'object';\n  },\n\n  function: function _function(thing) {\n    return typeof thing === 'function';\n  },\n\n  number: function number(thing) {\n    return typeof thing === 'number';\n  },\n\n  bool: function bool(thing) {\n    return typeof thing === 'boolean';\n  },\n\n  string: function string(thing) {\n    return typeof thing === 'string';\n  },\n\n  element: function element(thing) {\n    if (!thing || (typeof thing === 'undefined' ? 'undefined' : _typeof(thing)) !== 'object') {\n      return false;\n    }\n\n    var _window = win.getWindow(thing) || win.window;\n\n    return (/object|function/.test(_typeof(_window.Element)) ? thing instanceof _window.Element //DOM2\n      : thing.nodeType === 1 && typeof thing.nodeName === 'string'\n    );\n  }\n};\n\nis.array = function (thing) {\n  return is.object(thing) && typeof thing.length !== 'undefined' && is.function(thing.splice);\n};\n\nmodule.exports = is;\n\n},{\"./isWindow\":47,\"./window\":52}],47:[function(require,module,exports){\n\"use strict\";\n\nmodule.exports = function (thing) {\n  return !!(thing && thing.Window) && thing instanceof thing.Window;\n};\n\n},{}],48:[function(require,module,exports){\n'use strict';\n\nfunction pointerExtend(dest, source) {\n  for (var prop in source) {\n    var prefixedPropREs = module.exports.prefixedPropREs;\n    var deprecated = false;\n\n    // skip deprecated prefixed properties\n    for (var vendor in prefixedPropREs) {\n      if (prop.indexOf(vendor) === 0 && prefixedPropREs[vendor].test(prop)) {\n        deprecated = true;\n        break;\n      }\n    }\n\n    if (!deprecated && typeof source[prop] !== 'function') {\n      dest[prop] = source[prop];\n    }\n  }\n  return dest;\n}\n\npointerExtend.prefixedPropREs = {\n  webkit: /(Movement[XY]|Radius[XY]|RotationAngle|Force)$/\n};\n\nmodule.exports = pointerExtend;\n\n},{}],49:[function(require,module,exports){\n'use strict';\n\nvar hypot = require('./hypot');\nvar browser = require('./browser');\nvar dom = require('./domObjects');\nvar domUtils = require('./domUtils');\nvar domObjects = require('./domObjects');\nvar is = require('./is');\nvar pointerExtend = require('./pointerExtend');\n\nvar pointerUtils = {\n  copyCoords: function copyCoords(dest, src) {\n    dest.page = dest.page || {};\n    dest.page.x = src.page.x;\n    dest.page.y = src.page.y;\n\n    dest.client = dest.client || {};\n    dest.client.x = src.client.x;\n    dest.client.y = src.client.y;\n\n    dest.timeStamp = src.timeStamp;\n  },\n\n  setCoordDeltas: function setCoordDeltas(targetObj, prev, cur) {\n    targetObj.page.x = cur.page.x - prev.page.x;\n    targetObj.page.y = cur.page.y - prev.page.y;\n    targetObj.client.x = cur.client.x - prev.client.x;\n    targetObj.client.y = cur.client.y - prev.client.y;\n    targetObj.timeStamp = cur.timeStamp - prev.timeStamp;\n\n    // set pointer velocity\n    var dt = Math.max(targetObj.timeStamp / 1000, 0.001);\n\n    targetObj.page.speed = hypot(targetObj.page.x, targetObj.page.y) / dt;\n    targetObj.page.vx = targetObj.page.x / dt;\n    targetObj.page.vy = targetObj.page.y / dt;\n\n    targetObj.client.speed = hypot(targetObj.client.x, targetObj.page.y) / dt;\n    targetObj.client.vx = targetObj.client.x / dt;\n    targetObj.client.vy = targetObj.client.y / dt;\n  },\n\n  isNativePointer: function isNativePointer(pointer) {\n    return pointer instanceof dom.Event || pointer instanceof dom.Touch;\n  },\n\n  // Get specified X/Y coords for mouse or event.touches[0]\n  getXY: function getXY(type, pointer, xy) {\n    xy = xy || {};\n    type = type || 'page';\n\n    xy.x = pointer[type + 'X'];\n    xy.y = pointer[type + 'Y'];\n\n    return xy;\n  },\n\n  getPageXY: function getPageXY(pointer, page) {\n    page = page || {};\n\n    // Opera Mobile handles the viewport and scrolling oddly\n    if (browser.isOperaMobile && pointerUtils.isNativePointer(pointer)) {\n      pointerUtils.getXY('screen', pointer, page);\n\n      page.x += window.scrollX;\n      page.y += window.scrollY;\n    } else {\n      pointerUtils.getXY('page', pointer, page);\n    }\n\n    return page;\n  },\n\n  getClientXY: function getClientXY(pointer, client) {\n    client = client || {};\n\n    if (browser.isOperaMobile && pointerUtils.isNativePointer(pointer)) {\n      // Opera Mobile handles the viewport and scrolling oddly\n      pointerUtils.getXY('screen', pointer, client);\n    } else {\n      pointerUtils.getXY('client', pointer, client);\n    }\n\n    return client;\n  },\n\n  getPointerId: function getPointerId(pointer) {\n    return is.number(pointer.pointerId) ? pointer.pointerId : pointer.identifier;\n  },\n\n  setCoords: function setCoords(targetObj, pointers, timeStamp) {\n    var pointer = pointers.length > 1 ? pointerUtils.pointerAverage(pointers) : pointers[0];\n\n    var tmpXY = {};\n\n    pointerUtils.getPageXY(pointer, tmpXY);\n    targetObj.page.x = tmpXY.x;\n    targetObj.page.y = tmpXY.y;\n\n    pointerUtils.getClientXY(pointer, tmpXY);\n    targetObj.client.x = tmpXY.x;\n    targetObj.client.y = tmpXY.y;\n\n    targetObj.timeStamp = is.number(timeStamp) ? timeStamp : new Date().getTime();\n  },\n\n  pointerExtend: pointerExtend,\n\n  getTouchPair: function getTouchPair(event) {\n    var touches = [];\n\n    // array of touches is supplied\n    if (is.array(event)) {\n      touches[0] = event[0];\n      touches[1] = event[1];\n    }\n    // an event\n    else {\n        if (event.type === 'touchend') {\n          if (event.touches.length === 1) {\n            touches[0] = event.touches[0];\n            touches[1] = event.changedTouches[0];\n          } else if (event.touches.length === 0) {\n            touches[0] = event.changedTouches[0];\n            touches[1] = event.changedTouches[1];\n          }\n        } else {\n          touches[0] = event.touches[0];\n          touches[1] = event.touches[1];\n        }\n      }\n\n    return touches;\n  },\n\n  pointerAverage: function pointerAverage(pointers) {\n    var average = {\n      pageX: 0,\n      pageY: 0,\n      clientX: 0,\n      clientY: 0,\n      screenX: 0,\n      screenY: 0\n    };\n\n    for (var _iterator = pointers, _isArray = Array.isArray(_iterator), _i = 0, _iterator = _isArray ? _iterator : _iterator[Symbol.iterator]();;) {\n      var _ref;\n\n      if (_isArray) {\n        if (_i >= _iterator.length) break;\n        _ref = _iterator[_i++];\n      } else {\n        _i = _iterator.next();\n        if (_i.done) break;\n        _ref = _i.value;\n      }\n\n      var pointer = _ref;\n\n      for (var _prop in average) {\n        average[_prop] += pointer[_prop];\n      }\n    }\n    for (var prop in average) {\n      average[prop] /= pointers.length;\n    }\n\n    return average;\n  },\n\n  touchBBox: function touchBBox(event) {\n    if (!event.length && !(event.touches && event.touches.length > 1)) {\n      return;\n    }\n\n    var touches = pointerUtils.getTouchPair(event);\n    var minX = Math.min(touches[0].pageX, touches[1].pageX);\n    var minY = Math.min(touches[0].pageY, touches[1].pageY);\n    var maxX = Math.max(touches[0].pageX, touches[1].pageX);\n    var maxY = Math.max(touches[0].pageY, touches[1].pageY);\n\n    return {\n      x: minX,\n      y: minY,\n      left: minX,\n      top: minY,\n      width: maxX - minX,\n      height: maxY - minY\n    };\n  },\n\n  touchDistance: function touchDistance(event, deltaSource) {\n    var sourceX = deltaSource + 'X';\n    var sourceY = deltaSource + 'Y';\n    var touches = pointerUtils.getTouchPair(event);\n\n    var dx = touches[0][sourceX] - touches[1][sourceX];\n    var dy = touches[0][sourceY] - touches[1][sourceY];\n\n    return hypot(dx, dy);\n  },\n\n  touchAngle: function touchAngle(event, prevAngle, deltaSource) {\n    var sourceX = deltaSource + 'X';\n    var sourceY = deltaSource + 'Y';\n    var touches = pointerUtils.getTouchPair(event);\n    var dx = touches[1][sourceX] - touches[0][sourceX];\n    var dy = touches[1][sourceY] - touches[0][sourceY];\n    var angle = 180 * Math.atan2(dy, dx) / Math.PI;\n\n    return angle;\n  },\n\n  getPointerType: function getPointerType(pointer) {\n    return is.string(pointer.pointerType) ? pointer.pointerType : is.number(pointer.pointerType) ? [undefined, undefined, 'touch', 'pen', 'mouse'][pointer.pointerType]\n    // if the PointerEvent API isn't available, then the \"pointer\" must\n    // be either a MouseEvent, TouchEvent, or Touch object\n    : /touch/.test(pointer.type) || pointer instanceof domObjects.Touch ? 'touch' : 'mouse';\n  },\n\n  // [ event.target, event.currentTarget ]\n  getEventTargets: function getEventTargets(event) {\n    return [domUtils.getActualElement(event.path ? event.path[0] : event.target), domUtils.getActualElement(event.currentTarget)];\n  }\n};\n\nmodule.exports = pointerUtils;\n\n},{\"./browser\":37,\"./domObjects\":38,\"./domUtils\":39,\"./hypot\":43,\"./is\":46,\"./pointerExtend\":48}],50:[function(require,module,exports){\n'use strict';\n\nvar _require = require('./window'),\n    window = _require.window;\n\nvar vendors = ['ms', 'moz', 'webkit', 'o'];\nvar lastTime = 0;\nvar request = void 0;\nvar cancel = void 0;\n\nfor (var x = 0; x < vendors.length && !window.requestAnimationFrame; x++) {\n  request = window[vendors[x] + 'RequestAnimationFrame'];\n  cancel = window[vendors[x] + 'CancelAnimationFrame'] || window[vendors[x] + 'CancelRequestAnimationFrame'];\n}\n\nif (!request) {\n  request = function request(callback) {\n    var currTime = new Date().getTime();\n    var timeToCall = Math.max(0, 16 - (currTime - lastTime));\n    var id = setTimeout(function () {\n      callback(currTime + timeToCall);\n    }, timeToCall);\n\n    lastTime = currTime + timeToCall;\n    return id;\n  };\n}\n\nif (!cancel) {\n  cancel = function cancel(id) {\n    clearTimeout(id);\n  };\n}\n\nmodule.exports = {\n  request: request,\n  cancel: cancel\n};\n\n},{\"./window\":52}],51:[function(require,module,exports){\n'use strict';\n\nvar extend = require('./extend');\nvar is = require('./is');\n\nvar _require = require('./domUtils'),\n    closest = _require.closest,\n    parentNode = _require.parentNode,\n    getElementRect = _require.getElementRect;\n\nvar rectUtils = {\n  getStringOptionResult: function getStringOptionResult(value, interactable, element) {\n    if (!is.string(value)) {\n      return null;\n    }\n\n    if (value === 'parent') {\n      value = parentNode(element);\n    } else if (value === 'self') {\n      value = interactable.getRect(element);\n    } else {\n      value = closest(element, value);\n    }\n\n    return value;\n  },\n\n  resolveRectLike: function resolveRectLike(value, interactable, element, functionArgs) {\n    value = rectUtils.getStringOptionResult(value, interactable, element) || value;\n\n    if (is.function(value)) {\n      value = value.apply(null, functionArgs);\n    }\n\n    if (is.element(value)) {\n      value = getElementRect(value);\n    }\n\n    return value;\n  },\n\n  rectToXY: function rectToXY(rect) {\n    return rect && {\n      x: 'x' in rect ? rect.x : rect.left,\n      y: 'y' in rect ? rect.y : rect.top\n    };\n  },\n\n  xywhToTlbr: function xywhToTlbr(rect) {\n    if (rect && !('left' in rect && 'top' in rect)) {\n      rect = extend({}, rect);\n\n      rect.left = rect.x || 0;\n      rect.top = rect.y || 0;\n      rect.right = rect.right || rect.left + rect.width;\n      rect.bottom = rect.bottom || rect.top + rect.height;\n    }\n\n    return rect;\n  },\n\n  tlbrToXywh: function tlbrToXywh(rect) {\n    if (rect && !('x' in rect && 'y' in rect)) {\n      rect = extend({}, rect);\n\n      rect.x = rect.left || 0;\n      rect.top = rect.top || 0;\n      rect.width = rect.width || rect.right - rect.x;\n      rect.height = rect.height || rect.bottom - rect.y;\n    }\n\n    return rect;\n  }\n};\n\nmodule.exports = rectUtils;\n\n},{\"./domUtils\":39,\"./extend\":41,\"./is\":46}],52:[function(require,module,exports){\n'use strict';\n\nvar win = module.exports;\nvar isWindow = require('./isWindow');\n\nfunction init(window) {\n  // get wrapped window if using Shadow DOM polyfill\n\n  win.realWindow = window;\n\n  // create a TextNode\n  var el = window.document.createTextNode('');\n\n  // check if it's wrapped by a polyfill\n  if (el.ownerDocument !== window.document && typeof window.wrap === 'function' && window.wrap(el) === el) {\n    // use wrapped window\n    window = window.wrap(window);\n  }\n\n  win.window = window;\n}\n\nif (typeof window === 'undefined') {\n  win.window = undefined;\n  win.realWindow = undefined;\n} else {\n  init(window);\n}\n\nwin.getWindow = function getWindow(node) {\n  if (isWindow(node)) {\n    return node;\n  }\n\n  var rootNode = node.ownerDocument || node;\n\n  return rootNode.defaultView || rootNode.parentWindow || win.window;\n};\n\nwin.init = init;\n\n},{\"./isWindow\":47}]},{},[1])(1)\n});\n\n\n//# sourceMappingURL=interact.js.map\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/interactjs/dist/interact.js\n// module id = 16\n// module chunks = 0"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///16\n"); +eval("module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('div', {\n ref: \"item\",\n staticClass: \"vue-grid-item\",\n class: {\n 'vue-resizable': _vm.resizable, 'resizing': _vm.isResizing, 'vue-draggable-dragging': _vm.isDragging, 'cssTransforms': _vm.useCssTransforms, 'render-rtl': _vm.renderRtl\n },\n style: (_vm.style)\n }, [_vm._t(\"default\"), _vm._v(\" \"), (_vm.resizable) ? _c('span', {\n ref: \"handle\",\n class: _vm.resizableHandleClass\n }) : _vm._e()], 2)\n},staticRenderFns: []}\nmodule.exports.render._withStripped = true\nif (false) {\n module.hot.accept()\n if (module.hot.data) {\n require(\"vue-hot-reload-api\").rerender(\"data-v-f2ef9cd2\", module.exports)\n }\n}\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vLi9zcmMvR3JpZEl0ZW0udnVlPzEyMDIiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsZ0JBQWdCLG1CQUFtQixhQUFhLDBCQUEwQjtBQUMxRTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsS0FBSztBQUNMO0FBQ0EsR0FBRztBQUNIO0FBQ0E7QUFDQSxHQUFHO0FBQ0gsQ0FBQztBQUNEO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBIiwiZmlsZSI6IjE2LmpzIiwic291cmNlc0NvbnRlbnQiOlsibW9kdWxlLmV4cG9ydHM9e3JlbmRlcjpmdW5jdGlvbiAoKXt2YXIgX3ZtPXRoaXM7dmFyIF9oPV92bS4kY3JlYXRlRWxlbWVudDt2YXIgX2M9X3ZtLl9zZWxmLl9jfHxfaDtcbiAgcmV0dXJuIF9jKCdkaXYnLCB7XG4gICAgcmVmOiBcIml0ZW1cIixcbiAgICBzdGF0aWNDbGFzczogXCJ2dWUtZ3JpZC1pdGVtXCIsXG4gICAgY2xhc3M6IHtcbiAgICAgICd2dWUtcmVzaXphYmxlJzogX3ZtLnJlc2l6YWJsZSwgJ3Jlc2l6aW5nJzogX3ZtLmlzUmVzaXppbmcsICd2dWUtZHJhZ2dhYmxlLWRyYWdnaW5nJzogX3ZtLmlzRHJhZ2dpbmcsICdjc3NUcmFuc2Zvcm1zJzogX3ZtLnVzZUNzc1RyYW5zZm9ybXMsICdyZW5kZXItcnRsJzogX3ZtLnJlbmRlclJ0bFxuICAgIH0sXG4gICAgc3R5bGU6IChfdm0uc3R5bGUpXG4gIH0sIFtfdm0uX3QoXCJkZWZhdWx0XCIpLCBfdm0uX3YoXCIgXCIpLCAoX3ZtLnJlc2l6YWJsZSkgPyBfYygnc3BhbicsIHtcbiAgICByZWY6IFwiaGFuZGxlXCIsXG4gICAgY2xhc3M6IF92bS5yZXNpemFibGVIYW5kbGVDbGFzc1xuICB9KSA6IF92bS5fZSgpXSwgMilcbn0sc3RhdGljUmVuZGVyRm5zOiBbXX1cbm1vZHVsZS5leHBvcnRzLnJlbmRlci5fd2l0aFN0cmlwcGVkID0gdHJ1ZVxuaWYgKG1vZHVsZS5ob3QpIHtcbiAgbW9kdWxlLmhvdC5hY2NlcHQoKVxuICBpZiAobW9kdWxlLmhvdC5kYXRhKSB7XG4gICAgIHJlcXVpcmUoXCJ2dWUtaG90LXJlbG9hZC1hcGlcIikucmVyZW5kZXIoXCJkYXRhLXYtZjJlZjljZDJcIiwgbW9kdWxlLmV4cG9ydHMpXG4gIH1cbn1cblxuXG4vLy8vLy8vLy8vLy8vLy8vLy9cbi8vIFdFQlBBQ0sgRk9PVEVSXG4vLyAuL25vZGVfbW9kdWxlcy92dWUtbG9hZGVyL2xpYi90ZW1wbGF0ZS1jb21waWxlcj97XCJpZFwiOlwiZGF0YS12LWYyZWY5Y2QyXCJ9IS4vbm9kZV9tb2R1bGVzL3Z1ZS1sb2FkZXIvbGliL3NlbGVjdG9yLmpzP3R5cGU9dGVtcGxhdGUmaW5kZXg9MCEuL3NyYy9HcmlkSXRlbS52dWVcbi8vIG1vZHVsZSBpZCA9IDE2XG4vLyBtb2R1bGUgY2h1bmtzID0gMCJdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///16\n"); /***/ }), /* 17 */ /***/ (function(module, exports, __webpack_require__) { -eval("module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('div', {\n ref: \"item\",\n staticClass: \"vue-grid-item\",\n class: {\n 'vue-resizable': _vm.resizable, 'resizing': _vm.isResizing, 'vue-draggable-dragging': _vm.isDragging, 'cssTransforms': _vm.useCssTransforms, 'render-rtl': _vm.renderRtl\n },\n style: (_vm.style)\n }, [_vm._t(\"default\"), _vm._v(\" \"), (_vm.resizable) ? _c('span', {\n ref: \"handle\",\n class: _vm.resizableHandleClass\n }) : _vm._e()], 2)\n},staticRenderFns: []}\nmodule.exports.render._withStripped = true\nif (false) {\n module.hot.accept()\n if (module.hot.data) {\n require(\"vue-hot-reload-api\").rerender(\"data-v-f2ef9cd2\", module.exports)\n }\n}\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vLi9zcmMvR3JpZEl0ZW0udnVlPzEyMDIiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsZ0JBQWdCLG1CQUFtQixhQUFhLDBCQUEwQjtBQUMxRTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsS0FBSztBQUNMO0FBQ0EsR0FBRztBQUNIO0FBQ0E7QUFDQSxHQUFHO0FBQ0gsQ0FBQztBQUNEO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBIiwiZmlsZSI6IjE3LmpzIiwic291cmNlc0NvbnRlbnQiOlsibW9kdWxlLmV4cG9ydHM9e3JlbmRlcjpmdW5jdGlvbiAoKXt2YXIgX3ZtPXRoaXM7dmFyIF9oPV92bS4kY3JlYXRlRWxlbWVudDt2YXIgX2M9X3ZtLl9zZWxmLl9jfHxfaDtcbiAgcmV0dXJuIF9jKCdkaXYnLCB7XG4gICAgcmVmOiBcIml0ZW1cIixcbiAgICBzdGF0aWNDbGFzczogXCJ2dWUtZ3JpZC1pdGVtXCIsXG4gICAgY2xhc3M6IHtcbiAgICAgICd2dWUtcmVzaXphYmxlJzogX3ZtLnJlc2l6YWJsZSwgJ3Jlc2l6aW5nJzogX3ZtLmlzUmVzaXppbmcsICd2dWUtZHJhZ2dhYmxlLWRyYWdnaW5nJzogX3ZtLmlzRHJhZ2dpbmcsICdjc3NUcmFuc2Zvcm1zJzogX3ZtLnVzZUNzc1RyYW5zZm9ybXMsICdyZW5kZXItcnRsJzogX3ZtLnJlbmRlclJ0bFxuICAgIH0sXG4gICAgc3R5bGU6IChfdm0uc3R5bGUpXG4gIH0sIFtfdm0uX3QoXCJkZWZhdWx0XCIpLCBfdm0uX3YoXCIgXCIpLCAoX3ZtLnJlc2l6YWJsZSkgPyBfYygnc3BhbicsIHtcbiAgICByZWY6IFwiaGFuZGxlXCIsXG4gICAgY2xhc3M6IF92bS5yZXNpemFibGVIYW5kbGVDbGFzc1xuICB9KSA6IF92bS5fZSgpXSwgMilcbn0sc3RhdGljUmVuZGVyRm5zOiBbXX1cbm1vZHVsZS5leHBvcnRzLnJlbmRlci5fd2l0aFN0cmlwcGVkID0gdHJ1ZVxuaWYgKG1vZHVsZS5ob3QpIHtcbiAgbW9kdWxlLmhvdC5hY2NlcHQoKVxuICBpZiAobW9kdWxlLmhvdC5kYXRhKSB7XG4gICAgIHJlcXVpcmUoXCJ2dWUtaG90LXJlbG9hZC1hcGlcIikucmVyZW5kZXIoXCJkYXRhLXYtZjJlZjljZDJcIiwgbW9kdWxlLmV4cG9ydHMpXG4gIH1cbn1cblxuXG4vLy8vLy8vLy8vLy8vLy8vLy9cbi8vIFdFQlBBQ0sgRk9PVEVSXG4vLyAuL25vZGVfbW9kdWxlcy92dWUtbG9hZGVyL2xpYi90ZW1wbGF0ZS1jb21waWxlcj97XCJpZFwiOlwiZGF0YS12LWYyZWY5Y2QyXCJ9IS4vbm9kZV9tb2R1bGVzL3Z1ZS1sb2FkZXIvbGliL3NlbGVjdG9yLmpzP3R5cGU9dGVtcGxhdGUmaW5kZXg9MCEuL3NyYy9HcmlkSXRlbS52dWVcbi8vIG1vZHVsZSBpZCA9IDE3XG4vLyBtb2R1bGUgY2h1bmtzID0gMCJdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///17\n"); +eval("\n/* styles */\n__webpack_require__(18)\n\nvar Component = __webpack_require__(4)(\n /* script */\n __webpack_require__(20),\n /* template */\n __webpack_require__(33),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\nComponent.options.__file = \"C:\\\\projects\\\\JBAY\\\\vue-grid-layout\\\\src\\\\GridLayout.vue\"\nif (Component.esModule && Object.keys(Component.esModule).some(function (key) {return key !== \"default\" && key !== \"__esModule\"})) {console.error(\"named exports are not supported in *.vue files.\")}\nif (Component.options.functional) {console.error(\"[vue-loader] GridLayout.vue: functional components are not supported with templates, they should use render functions.\")}\n\n/* hot reload */\nif (false) {(function () {\n var hotAPI = require(\"vue-hot-reload-api\")\n hotAPI.install(require(\"vue\"), false)\n if (!hotAPI.compatible) return\n module.hot.accept()\n if (!module.hot.data) {\n hotAPI.createRecord(\"data-v-3d4bb9a4\", Component.options)\n } else {\n hotAPI.reload(\"data-v-3d4bb9a4\", Component.options)\n }\n})()}\n\nmodule.exports = Component.exports\n\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vLi9zcmMvR3JpZExheW91dC52dWU/OGFiMCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQ0E7QUFDQSxzQkFBNEs7O0FBRTVLO0FBQ0E7QUFDQTtBQUNBO0FBQ0Esd0JBQWdHO0FBQ2hHO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLCtFQUErRSxpREFBaUQsSUFBSTtBQUNwSSxtQ0FBbUM7O0FBRW5DO0FBQ0EsWUFBaUI7QUFDakI7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsR0FBRztBQUNIO0FBQ0E7QUFDQSxDQUFDOztBQUVEIiwiZmlsZSI6IjE3LmpzIiwic291cmNlc0NvbnRlbnQiOlsiXG4vKiBzdHlsZXMgKi9cbnJlcXVpcmUoXCIhIXZ1ZS1zdHlsZS1sb2FkZXIhY3NzLWxvYWRlcj9zb3VyY2VNYXAhLi4vbm9kZV9tb2R1bGVzL3Z1ZS1sb2FkZXIvbGliL3N0eWxlLWNvbXBpbGVyL2luZGV4P3tcXFwiaWRcXFwiOlxcXCJkYXRhLXYtM2Q0YmI5YTRcXFwiLFxcXCJzY29wZWRcXFwiOmZhbHNlLFxcXCJoYXNJbmxpbmVDb25maWdcXFwiOmZhbHNlfSEuLi9ub2RlX21vZHVsZXMvdnVlLWxvYWRlci9saWIvc2VsZWN0b3I/dHlwZT1zdHlsZXMmaW5kZXg9MCEuL0dyaWRMYXlvdXQudnVlXCIpXG5cbnZhciBDb21wb25lbnQgPSByZXF1aXJlKFwiIS4uL25vZGVfbW9kdWxlcy92dWUtbG9hZGVyL2xpYi9jb21wb25lbnQtbm9ybWFsaXplclwiKShcbiAgLyogc2NyaXB0ICovXG4gIHJlcXVpcmUoXCIhIWJhYmVsLWxvYWRlciEuLi9ub2RlX21vZHVsZXMvdnVlLWxvYWRlci9saWIvc2VsZWN0b3I/dHlwZT1zY3JpcHQmaW5kZXg9MCEuL0dyaWRMYXlvdXQudnVlXCIpLFxuICAvKiB0ZW1wbGF0ZSAqL1xuICByZXF1aXJlKFwiISEuLi9ub2RlX21vZHVsZXMvdnVlLWxvYWRlci9saWIvdGVtcGxhdGUtY29tcGlsZXIvaW5kZXg/e1xcXCJpZFxcXCI6XFxcImRhdGEtdi0zZDRiYjlhNFxcXCJ9IS4uL25vZGVfbW9kdWxlcy92dWUtbG9hZGVyL2xpYi9zZWxlY3Rvcj90eXBlPXRlbXBsYXRlJmluZGV4PTAhLi9HcmlkTGF5b3V0LnZ1ZVwiKSxcbiAgLyogc2NvcGVJZCAqL1xuICBudWxsLFxuICAvKiBjc3NNb2R1bGVzICovXG4gIG51bGxcbilcbkNvbXBvbmVudC5vcHRpb25zLl9fZmlsZSA9IFwiQzpcXFxccHJvamVjdHNcXFxcSkJBWVxcXFx2dWUtZ3JpZC1sYXlvdXRcXFxcc3JjXFxcXEdyaWRMYXlvdXQudnVlXCJcbmlmIChDb21wb25lbnQuZXNNb2R1bGUgJiYgT2JqZWN0LmtleXMoQ29tcG9uZW50LmVzTW9kdWxlKS5zb21lKGZ1bmN0aW9uIChrZXkpIHtyZXR1cm4ga2V5ICE9PSBcImRlZmF1bHRcIiAmJiBrZXkgIT09IFwiX19lc01vZHVsZVwifSkpIHtjb25zb2xlLmVycm9yKFwibmFtZWQgZXhwb3J0cyBhcmUgbm90IHN1cHBvcnRlZCBpbiAqLnZ1ZSBmaWxlcy5cIil9XG5pZiAoQ29tcG9uZW50Lm9wdGlvbnMuZnVuY3Rpb25hbCkge2NvbnNvbGUuZXJyb3IoXCJbdnVlLWxvYWRlcl0gR3JpZExheW91dC52dWU6IGZ1bmN0aW9uYWwgY29tcG9uZW50cyBhcmUgbm90IHN1cHBvcnRlZCB3aXRoIHRlbXBsYXRlcywgdGhleSBzaG91bGQgdXNlIHJlbmRlciBmdW5jdGlvbnMuXCIpfVxuXG4vKiBob3QgcmVsb2FkICovXG5pZiAobW9kdWxlLmhvdCkgeyhmdW5jdGlvbiAoKSB7XG4gIHZhciBob3RBUEkgPSByZXF1aXJlKFwidnVlLWhvdC1yZWxvYWQtYXBpXCIpXG4gIGhvdEFQSS5pbnN0YWxsKHJlcXVpcmUoXCJ2dWVcIiksIGZhbHNlKVxuICBpZiAoIWhvdEFQSS5jb21wYXRpYmxlKSByZXR1cm5cbiAgbW9kdWxlLmhvdC5hY2NlcHQoKVxuICBpZiAoIW1vZHVsZS5ob3QuZGF0YSkge1xuICAgIGhvdEFQSS5jcmVhdGVSZWNvcmQoXCJkYXRhLXYtM2Q0YmI5YTRcIiwgQ29tcG9uZW50Lm9wdGlvbnMpXG4gIH0gZWxzZSB7XG4gICAgaG90QVBJLnJlbG9hZChcImRhdGEtdi0zZDRiYjlhNFwiLCBDb21wb25lbnQub3B0aW9ucylcbiAgfVxufSkoKX1cblxubW9kdWxlLmV4cG9ydHMgPSBDb21wb25lbnQuZXhwb3J0c1xuXG5cblxuLy8vLy8vLy8vLy8vLy8vLy8vXG4vLyBXRUJQQUNLIEZPT1RFUlxuLy8gLi9zcmMvR3JpZExheW91dC52dWVcbi8vIG1vZHVsZSBpZCA9IDE3XG4vLyBtb2R1bGUgY2h1bmtzID0gMCJdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///17\n"); /***/ }), /* 18 */ /***/ (function(module, exports, __webpack_require__) { -eval("\n/* styles */\n__webpack_require__(19)\n\nvar Component = __webpack_require__(4)(\n /* script */\n __webpack_require__(21),\n /* template */\n __webpack_require__(35),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\nComponent.options.__file = \"/Users/sunzongzheng/work/vue-grid-layout/src/GridLayout.vue\"\nif (Component.esModule && Object.keys(Component.esModule).some(function (key) {return key !== \"default\" && key !== \"__esModule\"})) {console.error(\"named exports are not supported in *.vue files.\")}\nif (Component.options.functional) {console.error(\"[vue-loader] GridLayout.vue: functional components are not supported with templates, they should use render functions.\")}\n\n/* hot reload */\nif (false) {(function () {\n var hotAPI = require(\"vue-hot-reload-api\")\n hotAPI.install(require(\"vue\"), false)\n if (!hotAPI.compatible) return\n module.hot.accept()\n if (!module.hot.data) {\n hotAPI.createRecord(\"data-v-3d4bb9a4\", Component.options)\n } else {\n hotAPI.reload(\"data-v-3d4bb9a4\", Component.options)\n }\n})()}\n\nmodule.exports = Component.exports\n\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vLi9zcmMvR3JpZExheW91dC52dWU/OGFiMCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQ0E7QUFDQSxzQkFBNEs7O0FBRTVLO0FBQ0E7QUFDQTtBQUNBO0FBQ0Esd0JBQWdHO0FBQ2hHO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBLCtFQUErRSxpREFBaUQsSUFBSTtBQUNwSSxtQ0FBbUM7O0FBRW5DO0FBQ0EsWUFBaUI7QUFDakI7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0EsR0FBRztBQUNIO0FBQ0E7QUFDQSxDQUFDOztBQUVEIiwiZmlsZSI6IjE4LmpzIiwic291cmNlc0NvbnRlbnQiOlsiXG4vKiBzdHlsZXMgKi9cbnJlcXVpcmUoXCIhIXZ1ZS1zdHlsZS1sb2FkZXIhY3NzLWxvYWRlcj9zb3VyY2VNYXAhLi4vbm9kZV9tb2R1bGVzL3Z1ZS1sb2FkZXIvbGliL3N0eWxlLWNvbXBpbGVyL2luZGV4P3tcXFwiaWRcXFwiOlxcXCJkYXRhLXYtM2Q0YmI5YTRcXFwiLFxcXCJzY29wZWRcXFwiOmZhbHNlLFxcXCJoYXNJbmxpbmVDb25maWdcXFwiOmZhbHNlfSEuLi9ub2RlX21vZHVsZXMvdnVlLWxvYWRlci9saWIvc2VsZWN0b3I/dHlwZT1zdHlsZXMmaW5kZXg9MCEuL0dyaWRMYXlvdXQudnVlXCIpXG5cbnZhciBDb21wb25lbnQgPSByZXF1aXJlKFwiIS4uL25vZGVfbW9kdWxlcy92dWUtbG9hZGVyL2xpYi9jb21wb25lbnQtbm9ybWFsaXplclwiKShcbiAgLyogc2NyaXB0ICovXG4gIHJlcXVpcmUoXCIhIWJhYmVsLWxvYWRlciEuLi9ub2RlX21vZHVsZXMvdnVlLWxvYWRlci9saWIvc2VsZWN0b3I/dHlwZT1zY3JpcHQmaW5kZXg9MCEuL0dyaWRMYXlvdXQudnVlXCIpLFxuICAvKiB0ZW1wbGF0ZSAqL1xuICByZXF1aXJlKFwiISEuLi9ub2RlX21vZHVsZXMvdnVlLWxvYWRlci9saWIvdGVtcGxhdGUtY29tcGlsZXIvaW5kZXg/e1xcXCJpZFxcXCI6XFxcImRhdGEtdi0zZDRiYjlhNFxcXCJ9IS4uL25vZGVfbW9kdWxlcy92dWUtbG9hZGVyL2xpYi9zZWxlY3Rvcj90eXBlPXRlbXBsYXRlJmluZGV4PTAhLi9HcmlkTGF5b3V0LnZ1ZVwiKSxcbiAgLyogc2NvcGVJZCAqL1xuICBudWxsLFxuICAvKiBjc3NNb2R1bGVzICovXG4gIG51bGxcbilcbkNvbXBvbmVudC5vcHRpb25zLl9fZmlsZSA9IFwiL1VzZXJzL3N1bnpvbmd6aGVuZy93b3JrL3Z1ZS1ncmlkLWxheW91dC9zcmMvR3JpZExheW91dC52dWVcIlxuaWYgKENvbXBvbmVudC5lc01vZHVsZSAmJiBPYmplY3Qua2V5cyhDb21wb25lbnQuZXNNb2R1bGUpLnNvbWUoZnVuY3Rpb24gKGtleSkge3JldHVybiBrZXkgIT09IFwiZGVmYXVsdFwiICYmIGtleSAhPT0gXCJfX2VzTW9kdWxlXCJ9KSkge2NvbnNvbGUuZXJyb3IoXCJuYW1lZCBleHBvcnRzIGFyZSBub3Qgc3VwcG9ydGVkIGluICoudnVlIGZpbGVzLlwiKX1cbmlmIChDb21wb25lbnQub3B0aW9ucy5mdW5jdGlvbmFsKSB7Y29uc29sZS5lcnJvcihcIlt2dWUtbG9hZGVyXSBHcmlkTGF5b3V0LnZ1ZTogZnVuY3Rpb25hbCBjb21wb25lbnRzIGFyZSBub3Qgc3VwcG9ydGVkIHdpdGggdGVtcGxhdGVzLCB0aGV5IHNob3VsZCB1c2UgcmVuZGVyIGZ1bmN0aW9ucy5cIil9XG5cbi8qIGhvdCByZWxvYWQgKi9cbmlmIChtb2R1bGUuaG90KSB7KGZ1bmN0aW9uICgpIHtcbiAgdmFyIGhvdEFQSSA9IHJlcXVpcmUoXCJ2dWUtaG90LXJlbG9hZC1hcGlcIilcbiAgaG90QVBJLmluc3RhbGwocmVxdWlyZShcInZ1ZVwiKSwgZmFsc2UpXG4gIGlmICghaG90QVBJLmNvbXBhdGlibGUpIHJldHVyblxuICBtb2R1bGUuaG90LmFjY2VwdCgpXG4gIGlmICghbW9kdWxlLmhvdC5kYXRhKSB7XG4gICAgaG90QVBJLmNyZWF0ZVJlY29yZChcImRhdGEtdi0zZDRiYjlhNFwiLCBDb21wb25lbnQub3B0aW9ucylcbiAgfSBlbHNlIHtcbiAgICBob3RBUEkucmVsb2FkKFwiZGF0YS12LTNkNGJiOWE0XCIsIENvbXBvbmVudC5vcHRpb25zKVxuICB9XG59KSgpfVxuXG5tb2R1bGUuZXhwb3J0cyA9IENvbXBvbmVudC5leHBvcnRzXG5cblxuXG4vLy8vLy8vLy8vLy8vLy8vLy9cbi8vIFdFQlBBQ0sgRk9PVEVSXG4vLyAuL3NyYy9HcmlkTGF5b3V0LnZ1ZVxuLy8gbW9kdWxlIGlkID0gMThcbi8vIG1vZHVsZSBjaHVua3MgPSAwIl0sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///18\n"); +eval("// style-loader: Adds some css to the DOM by adding a \\r\\n\\r\\n\"],\"sourceRoot\":\"webpack://\"}]);\n\n// exports\n\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack:///./src/GridLayout.vue?9a2a"],"names":[],"mappings":"AAAA;AACA;;;AAGA;AACA,6CAA8C,yBAAyB,oCAAoC,GAAG,UAAU,iFAAiF,KAAK,WAAW,WAAW,siBAAsiB,+BAA+B,0CAA0C,SAAS,sDAAsD,8EAA8E,oBAAoB,4DAA4D,gBAAgB,+CAA+C,yEAAyE,wDAAwD,wBAAwB,mDAAmD,aAAa,0BAA0B,sCAAsC,qBAAqB,gHAAgH,oFAAoF,0BAA0B,iFAAiF,6BAA6B,kFAAkF,2BAA2B,uFAAuF,0BAA0B,0EAA0E,wCAAwC,qBAAqB,iBAAiB,+BAA+B,oFAAoF,+BAA+B,oFAAoF,8BAA8B,qFAAqF,oCAAoC,oFAAoF,mCAAmC,oFAAoF,0BAA0B,oFAAoF,cAAc,gCAAgC,wBAAwB,mEAAmE,iHAAiH,sKAAsK,mBAAmB,aAAa,yBAAyB,gCAAgC,oKAAoK,+DAA+D,kBAAkB,gFAAgF,6DAA6D,kBAAkB,yDAAyD,wDAAwD,0EAA0E,sEAAsE,aAAa,uCAAuC,6GAA6G,uEAAuE,wFAAwF,kCAAkC,4CAA4C,gDAAgD,oCAAoC,+CAA+C,kDAAkD,kDAAkD,gEAAgE,mFAAmF,yBAAyB,mEAAmE,gDAAgD,oDAAoD,kEAAkE,6GAA6G,EAAE,8EAA8E,sDAAsD,6BAA6B,EAAE,yBAAyB,EAAE,qBAAqB,EAAE,gDAAgD,kDAAkD,kDAAkD,gEAAgE,mFAAmF,yBAAyB,mEAAmE,gDAAgD,oDAAoD,kEAAkE,6GAA6G,EAAE,8EAA8E,sDAAsD,6BAA6B,EAAE,yBAAyB,EAAE,0BAA0B,iBAAiB,EAAE,aAAa,qBAAqB,oCAAoC,gDAAgD,uEAAuE,yEAAyE,4CAA4C,qBAAqB,EAAE,iBAAiB,sCAAsC,wCAAwC,iBAAiB,wCAAwC,0EAA0E,iBAAiB,0CAA0C,4EAA4E,iBAAiB,0CAA0C,4EAA4E,iBAAiB,aAAa,uBAAuB,gCAAgC,oDAAoD,2EAA2E,kEAAkE,uEAAuE,yBAAyB,mEAAmE,yEAAyE,4CAA4C,qBAAqB,iBAAiB,4CAA4C,wCAAwC,4EAA4E,iBAAiB,8CAA8C,2GAA2G,iEAAiE,qBAAqB,iBAAiB,+CAA+C,+CAA+C,2GAA2G,iBAAiB,kEAAkE,oFAAoF,gDAAgD,+CAA+C,+CAA+C,+CAA+C,+CAA+C,mDAAmD,mDAAmD,yBAAyB,EAAE,uEAAuE,yEAAyE,qBAAqB,OAAO,mDAAmD,oDAAoD,yBAAyB,EAAE,qBAAqB,2FAA2F,2DAA2D,wHAAwH,6BAA6B,SAAS,qBAAqB,4BAA4B,4BAA4B,0IAA0I,+DAA+D,+IAA+I,wCAAwC,2FAA2F,iBAAiB,oEAAoE,wFAAwF,gDAAgD,+CAA+C,+CAA+C,+CAA+C,+CAA+C,mDAAmD,mDAAmD,yBAAyB,EAAE,uEAAuE,yEAAyE,yBAAyB,OAAO,mDAAmD,oDAAoD,yBAAyB,EAAE,qBAAqB,2DAA2D,uHAAuH,6BAA6B,SAAS,qBAAqB,4BAA4B,4BAA4B,+DAA+D,qDAAqD,wCAAwC,6FAA6F,iBAAiB,cAAc,UAAU,8CAA8C;;AAEpwW","file":"19.js","sourcesContent":["exports = module.exports = require(\"../node_modules/css-loader/lib/css-base.js\")();\n// imports\n\n\n// module\nexports.push([module.id, \"\\n.vue-grid-layout {\\n    position: relative;\\n    transition: height 200ms ease;\\n}\\n\", \"\", {\"version\":3,\"sources\":[\"/./src/GridLayout.vue?3470f332\"],\"names\":[],\"mappings\":\";AAaA;IACA,mBAAA;IACA,8BAAA;CACA\",\"file\":\"GridLayout.vue\",\"sourcesContent\":[\"<template>\\r\\n    <div ref=\\\"item\\\" class=\\\"vue-grid-layout\\\" :style=\\\"mergedStyle\\\">\\r\\n        <slot></slot>\\r\\n        <grid-item class=\\\"vue-grid-placeholder\\\"\\r\\n                   v-show=\\\"isDragging\\\"\\r\\n                   :x=\\\"placeholder.x\\\"\\r\\n                   :y=\\\"placeholder.y\\\"\\r\\n                   :w=\\\"placeholder.w\\\"\\r\\n                   :h=\\\"placeholder.h\\\"\\r\\n                   :i=\\\"placeholder.i\\\"></grid-item>\\r\\n    </div>\\r\\n</template>\\r\\n<style>\\r\\n    .vue-grid-layout {\\r\\n        position: relative;\\r\\n        transition: height 200ms ease;\\r\\n    }\\r\\n</style>\\r\\n<script>\\r\\n    import Vue from 'vue';\\r\\n    var elementResizeDetectorMaker = require(\\\"element-resize-detector\\\");\\r\\n\\r\\n    import {bottom, compact, getLayoutItem, moveElement, validateLayout} from './utils';\\r\\n    //var eventBus = require('./eventBus');\\r\\n    import GridItem from './GridItem.vue'\\r\\n\\r\\n    export default {\\r\\n        name: \\\"GridLayout\\\",\\r\\n        provide() {\\r\\n            return {\\r\\n                eventBus: null\\r\\n            }\\r\\n        },\\r\\n        components: {\\r\\n            GridItem,\\r\\n        },\\r\\n        props: {\\r\\n            // If true, the container height swells and contracts to fit contents\\r\\n            autoSize: {\\r\\n                type: Boolean,\\r\\n                default: true\\r\\n            },\\r\\n            colNum: {\\r\\n                type: Number,\\r\\n                default: 12\\r\\n            },\\r\\n            rowHeight: {\\r\\n                type: Number,\\r\\n                default: 150\\r\\n            },\\r\\n            maxRows: {\\r\\n                type: Number,\\r\\n                default: Infinity\\r\\n            },\\r\\n            margin: {\\r\\n                type: Array,\\r\\n                default: function () {\\r\\n                    return [10, 10];\\r\\n                }\\r\\n            },\\r\\n            isDraggable: {\\r\\n                type: Boolean,\\r\\n                default: true\\r\\n            },\\r\\n            isResizable: {\\r\\n                type: Boolean,\\r\\n                default: true\\r\\n            },\\r\\n            isMirrored: {\\r\\n                type: Boolean,\\r\\n                default: false\\r\\n            },\\r\\n            useCssTransforms: {\\r\\n                type: Boolean,\\r\\n                default: true\\r\\n            },\\r\\n            verticalCompact: {\\r\\n                type: Boolean,\\r\\n                default: true\\r\\n            },\\r\\n            layout: {\\r\\n                type: Array,\\r\\n                required: true,\\r\\n            },\\r\\n        },\\r\\n        data: function () {\\r\\n            return {\\r\\n                width: null,\\r\\n                mergedStyle: {},\\r\\n                lastLayoutLength: 0,\\r\\n                isDragging: false,\\r\\n                placeholder: {\\r\\n                    x: 0,\\r\\n                    y: 0,\\r\\n                    w: 0,\\r\\n                    h: 0,\\r\\n                    i: -1\\r\\n                },\\r\\n            };\\r\\n        },\\r\\n        created () {\\r\\n            var self = this;\\r\\n\\r\\n            // Accessible refernces of functions for removing in beforeDestroy\\r\\n            self.resizeEventHandler = function(eventType, i, x, y, h, w) {\\r\\n                self.resizeEvent(eventType, i, x, y, h, w);\\r\\n            };\\r\\n\\r\\n            self.dragEventHandler = function(eventType, i, x, y, h, w) {\\r\\n                self.dragEvent(eventType, i, x, y, h, w);\\r\\n            };\\r\\n\\r\\n            self._provided.eventBus =  new Vue();\\r\\n            self.eventBus = self._provided.eventBus;\\r\\n            self.eventBus.$on('resizeEvent', self.resizeEventHandler);\\r\\n            self.eventBus.$on('dragEvent', self.dragEventHandler);\\r\\n        },\\r\\n        beforeDestroy: function(){\\r\\n            //Remove listeners\\r\\n            this.eventBus.$off('resizeEvent', self.resizeEventHandler);\\r\\n            this.eventBus.$off('dragEvent', self.dragEventHandler);\\r\\n            window.removeEventListener(\\\"resize\\\", self.onWindowResize)\\r\\n        },\\r\\n        mounted: function() {\\r\\n            this.$nextTick(function () {\\r\\n                validateLayout(this.layout);\\r\\n                var self = this;\\r\\n                this.$nextTick(function() {\\r\\n                    if (self.width === null) {\\r\\n                        self.onWindowResize();\\r\\n                        //self.width = self.$el.offsetWidth;\\r\\n                        window.addEventListener('resize', self.onWindowResize);\\r\\n                    }\\r\\n                    compact(self.layout, self.verticalCompact);\\r\\n\\r\\n                    self.updateHeight();\\r\\n                    self.$nextTick(function () {\\r\\n                        var erd = elementResizeDetectorMaker({\\r\\n                            strategy: \\\"scroll\\\" //<- For ultra performance.\\r\\n                        });\\r\\n                        erd.listenTo(self.$refs.item, function (element) {\\r\\n                            self.onWindowResize();\\r\\n                        });\\r\\n                    });\\r\\n                });\\r\\n                window.onload = function() {\\r\\n                    if (self.width === null) {\\r\\n                        self.onWindowResize();\\r\\n                        //self.width = self.$el.offsetWidth;\\r\\n                        window.addEventListener('resize', self.onWindowResize);\\r\\n                    }\\r\\n                    compact(self.layout, self.verticalCompact);\\r\\n\\r\\n                    self.updateHeight();\\r\\n                    self.$nextTick(function () {\\r\\n                        var erd = elementResizeDetectorMaker({\\r\\n                            strategy: \\\"scroll\\\" //<- For ultra performance.\\r\\n                        });\\r\\n                        erd.listenTo(self.$refs.item, function (element) {\\r\\n                            self.onWindowResize();\\r\\n                        });\\r\\n                    });\\r\\n\\r\\n                };\\r\\n            });\\r\\n        },\\r\\n        watch: {\\r\\n            width: function () {\\r\\n                this.$nextTick(function () {\\r\\n                    //this.$broadcast(\\\"updateWidth\\\", this.width);\\r\\n                    this.eventBus.$emit(\\\"updateWidth\\\", this.width);\\r\\n                    this.updateHeight();\\r\\n                });\\r\\n            },\\r\\n            layout: function () {\\r\\n                this.layoutUpdate();\\r\\n            },\\r\\n            rowHeight: function() {\\r\\n                this.eventBus.$emit(\\\"setRowHeight\\\", this.rowHeight);\\r\\n            },\\r\\n            isDraggable: function() {\\r\\n                this.eventBus.$emit(\\\"setDraggable\\\", this.isDraggable);\\r\\n            },\\r\\n            isResizable: function() {\\r\\n                this.eventBus.$emit(\\\"setResizable\\\", this.isResizable);\\r\\n            }\\r\\n        },\\r\\n        methods: {\\r\\n            layoutUpdate() {\\r\\n                if (this.layout !== undefined) {\\r\\n                    if (this.layout.length !== this.lastLayoutLength) {\\r\\n                        //console.log(\\\"### LAYOUT UPDATE!\\\");\\r\\n                        this.lastLayoutLength = this.layout.length;\\r\\n                    }\\r\\n                    compact(this.layout, this.verticalCompact);\\r\\n                    this.eventBus.$emit(\\\"updateWidth\\\", this.width);\\r\\n                    this.updateHeight();\\r\\n                }\\r\\n            },\\r\\n            updateHeight: function () {\\r\\n                this.mergedStyle = {\\r\\n                    height: this.containerHeight()\\r\\n                };\\r\\n            },\\r\\n            onWindowResize: function () {\\r\\n                if (this.$refs !== null && this.$refs.item !== null && this.$refs.item !== undefined) {\\r\\n                    this.width = this.$refs.item.offsetWidth;\\r\\n                }\\r\\n            },\\r\\n            containerHeight: function () {\\r\\n                if (!this.autoSize) return;\\r\\n                return bottom(this.layout) * (this.rowHeight + this.margin[1]) + this.margin[1] + 'px';\\r\\n            },\\r\\n            dragEvent: function (eventName, id, x, y, h, w) {\\r\\n                if (eventName === \\\"dragmove\\\" || eventName === \\\"dragstart\\\") {\\r\\n                    this.placeholder.i = id;\\r\\n                    this.placeholder.x = x;\\r\\n                    this.placeholder.y = y;\\r\\n                    this.placeholder.w = w;\\r\\n                    this.placeholder.h = h;\\r\\n                    this.$nextTick(function() {\\r\\n                        this.isDragging = true;\\r\\n                    });\\r\\n                    //this.$broadcast(\\\"updateWidth\\\", this.width);\\r\\n                    this.eventBus.$emit(\\\"updateWidth\\\", this.width);\\r\\n                } else {\\r\\n                    this.$nextTick(function() {\\r\\n                        this.isDragging = false;\\r\\n                    });\\r\\n                }\\r\\n                //console.log(eventName + \\\" id=\\\" + id + \\\", x=\\\" + x + \\\", y=\\\" + y);\\r\\n                var l = getLayoutItem(this.layout, id);\\r\\n                //GetLayoutItem sometimes returns null object\\r\\n                if (l === undefined || l === null){\\r\\n                    l = {x:0, y:0}\\r\\n                }\\r\\n                l.x = x;\\r\\n                l.y = y;\\r\\n                // Move the element to the dragged location.\\r\\n                this.layout = moveElement(this.layout, l, x, y, true);\\r\\n                compact(this.layout, this.verticalCompact);\\r\\n                // needed because vue can't detect changes on array element properties\\r\\n                this.eventBus.$emit(\\\"compact\\\");\\r\\n                this.updateHeight();\\r\\n                if (eventName === 'dragend') this.$emit('layout-updated', this.layout);\\r\\n            },\\r\\n            resizeEvent: function (eventName, id, x, y, h, w) {\\r\\n                if (eventName === \\\"resizestart\\\" || eventName === \\\"resizemove\\\") {\\r\\n                    this.placeholder.i = id;\\r\\n                    this.placeholder.x = x;\\r\\n                    this.placeholder.y = y;\\r\\n                    this.placeholder.w = w;\\r\\n                    this.placeholder.h = h;\\r\\n                    this.$nextTick(function() {\\r\\n                        this.isDragging = true;\\r\\n                    });\\r\\n                    //this.$broadcast(\\\"updateWidth\\\", this.width);\\r\\n                    this.eventBus.$emit(\\\"updateWidth\\\", this.width);\\r\\n\\r\\n                } else {\\r\\n                    this.$nextTick(function() {\\r\\n                        this.isDragging = false;\\r\\n                    });\\r\\n                }\\r\\n                var l = getLayoutItem(this.layout, id);\\r\\n                //GetLayoutItem sometimes return null object\\r\\n                if (l === undefined || l === null){\\r\\n                    l = {h:0, w:0}\\r\\n                }\\r\\n                l.h = h;\\r\\n                l.w = w;\\r\\n                compact(this.layout, this.verticalCompact);\\r\\n                this.eventBus.$emit(\\\"compact\\\");\\r\\n                this.updateHeight();\\r\\n                if (eventName === 'resizeend') this.$emit('layout-updated', this.layout);\\r\\n            },\\r\\n        },\\r\\n    }\\r\\n</script>\\r\\n\"],\"sourceRoot\":\"webpack://\"}]);\n\n// exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/css-loader?sourceMap!./node_modules/vue-loader/lib/style-compiler?{\"id\":\"data-v-3d4bb9a4\",\"scoped\":false,\"hasInlineConfig\":false}!./node_modules/vue-loader/lib/selector.js?type=styles&index=0!./src/GridLayout.vue\n// module id = 19\n// module chunks = 0"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///19\n"); /***/ }), /* 20 */ /***/ (function(module, exports, __webpack_require__) { -eval("exports = module.exports = __webpack_require__(2)();\n// imports\n\n\n// module\nexports.push([module.i, \"\\n.vue-grid-layout {\\n position: relative;\\n transition: height 200ms ease;\\n}\\n\", \"\", {\"version\":3,\"sources\":[\"/./src/GridLayout.vue?6c736e29\"],\"names\":[],\"mappings\":\";AAaA;IACA,mBAAA;IACA,8BAAA;CACA\",\"file\":\"GridLayout.vue\",\"sourcesContent\":[\"\\n\\n\\n\"],\"sourceRoot\":\"webpack://\"}]);\n\n// exports\n\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack:///./src/GridLayout.vue?9a2a"],"names":[],"mappings":"AAAA;AACA;;;AAGA;AACA,6CAA8C,yBAAyB,oCAAoC,GAAG,UAAU,iFAAiF,KAAK,WAAW,WAAW,4gBAA4gB,6BAA6B,wCAAwC,OAAO,gDAAgD,4EAA4E,gBAAgB,4DAA4D,gBAAgB,6CAA6C,mEAAmE,oDAAoD,sBAAsB,+CAA+C,WAAW,wBAAwB,kCAAkC,mBAAmB,4GAA4G,8EAA8E,wBAAwB,2EAA2E,2BAA2B,4EAA4E,yBAAyB,iFAAiF,wBAAwB,sEAAsE,sCAAsC,mBAAmB,eAAe,6BAA6B,8EAA8E,6BAA6B,8EAA8E,4BAA4B,+EAA+E,kCAAkC,8EAA8E,iCAAiC,8EAA8E,wBAAwB,8EAA8E,YAAY,8BAA8B,sBAAsB,+DAA+D,2GAA2G,0JAA0J,iBAAiB,WAAW,uBAAuB,8BAA8B,8JAA8J,6DAA6D,gBAAgB,4EAA4E,2DAA2D,gBAAgB,qDAAqD,sDAAsD,wEAAwE,oEAAoE,WAAW,qCAAqC,yGAAyG,qEAAqE,oFAAoF,gCAAgC,0CAA0C,8CAA8C,kCAAkC,6CAA6C,gDAAgD,gDAAgD,8DAA8D,iFAAiF,uBAAuB,iEAAiE,4CAA4C,kDAAkD,gEAAgE,yGAAyG,EAAE,4EAA4E,oDAAoD,2BAA2B,EAAE,uBAAuB,EAAE,mBAAmB,EAAE,8CAA8C,gDAAgD,gDAAgD,8DAA8D,iFAAiF,uBAAuB,iEAAiE,4CAA4C,kDAAkD,gEAAgE,yGAAyG,EAAE,4EAA4E,oDAAoD,2BAA2B,EAAE,uBAAuB,EAAE,sBAAsB,eAAe,EAAE,WAAW,mBAAmB,kCAAkC,8CAA8C,qEAAqE,uEAAuE,0CAA0C,mBAAmB,EAAE,eAAe,oCAAoC,sCAAsC,eAAe,sCAAsC,wEAAwE,eAAe,wCAAwC,0EAA0E,eAAe,wCAAwC,0EAA0E,eAAe,WAAW,qBAAqB,8BAA8B,kGAAkG,4DAA4D,iEAAiE,iEAAiE,uEAAuE,uEAAuE,0CAA0C,mBAAmB,eAAe,0CAA0C,sCAAsC,wEAAwE,eAAe,4CAA4C,yGAAyG,+DAA+D,mBAAmB,eAAe,6CAA6C,6CAA6C,yGAAyG,eAAe,gEAAgE,kFAAkF,8CAA8C,6CAA6C,6CAA6C,6CAA6C,6CAA6C,iDAAiD,iDAAiD,uBAAuB,EAAE,qEAAqE,uEAAuE,mBAAmB,OAAO,iDAAiD,kDAAkD,uBAAuB,EAAE,mBAAmB,yFAAyF,yDAAyD,oHAAoH,2BAA2B,SAAS,mBAAmB,0BAA0B,0BAA0B,sIAAsI,6DAA6D,2IAA2I,sCAAsC,yFAAyF,eAAe,kEAAkE,sFAAsF,8CAA8C,6CAA6C,6CAA6C,6CAA6C,6CAA6C,iDAAiD,iDAAiD,uBAAuB,EAAE,qEAAqE,uEAAuE,qBAAqB,OAAO,iDAAiD,kDAAkD,uBAAuB,EAAE,mBAAmB,yDAAyD,mHAAmH,2BAA2B,SAAS,mBAAmB,0BAA0B,0BAA0B,6DAA6D,mDAAmD,sCAAsC,2FAA2F,eAAe,YAAY,QAAQ,0CAA0C;;AAEruV","file":"20.js","sourcesContent":["exports = module.exports = require(\"../node_modules/css-loader/lib/css-base.js\")();\n// imports\n\n\n// module\nexports.push([module.id, \"\\n.vue-grid-layout {\\n    position: relative;\\n    transition: height 200ms ease;\\n}\\n\", \"\", {\"version\":3,\"sources\":[\"/./src/GridLayout.vue?6c736e29\"],\"names\":[],\"mappings\":\";AAaA;IACA,mBAAA;IACA,8BAAA;CACA\",\"file\":\"GridLayout.vue\",\"sourcesContent\":[\"<template>\\n    <div ref=\\\"item\\\" class=\\\"vue-grid-layout\\\" :style=\\\"mergedStyle\\\">\\n        <slot></slot>\\n        <grid-item class=\\\"vue-grid-placeholder\\\"\\n                   v-show=\\\"isDragging\\\"\\n                   :x=\\\"placeholder.x\\\"\\n                   :y=\\\"placeholder.y\\\"\\n                   :w=\\\"placeholder.w\\\"\\n                   :h=\\\"placeholder.h\\\"\\n                   :i=\\\"placeholder.i\\\"></grid-item>\\n    </div>\\n</template>\\n<style>\\n    .vue-grid-layout {\\n        position: relative;\\n        transition: height 200ms ease;\\n    }\\n</style>\\n<script>\\n    import Vue from 'vue';\\n    var elementResizeDetectorMaker = require(\\\"element-resize-detector\\\");\\n\\n    import {bottom, compact, getLayoutItem, moveElement, validateLayout} from './utils';\\n    //var eventBus = require('./eventBus');\\n    import GridItem from './GridItem.vue'\\n\\n    export default {\\n        name: \\\"GridLayout\\\",\\n        provide() {\\n            return {\\n                eventBus: null\\n            }\\n        },\\n        components: {\\n            GridItem,\\n        },\\n        props: {\\n            // If true, the container height swells and contracts to fit contents\\n            autoSize: {\\n                type: Boolean,\\n                default: true\\n            },\\n            colNum: {\\n                type: Number,\\n                default: 12\\n            },\\n            rowHeight: {\\n                type: Number,\\n                default: 150\\n            },\\n            maxRows: {\\n                type: Number,\\n                default: Infinity\\n            },\\n            margin: {\\n                type: Array,\\n                default: function () {\\n                    return [10, 10];\\n                }\\n            },\\n            isDraggable: {\\n                type: Boolean,\\n                default: true\\n            },\\n            isResizable: {\\n                type: Boolean,\\n                default: true\\n            },\\n            isMirrored: {\\n                type: Boolean,\\n                default: false\\n            },\\n            useCssTransforms: {\\n                type: Boolean,\\n                default: true\\n            },\\n            verticalCompact: {\\n                type: Boolean,\\n                default: true\\n            },\\n            layout: {\\n                type: Array,\\n                required: true,\\n            },\\n        },\\n        data: function () {\\n            return {\\n                width: null,\\n                mergedStyle: {},\\n                lastLayoutLength: 0,\\n                isDragging: false,\\n                placeholder: {\\n                    x: 0,\\n                    y: 0,\\n                    w: 0,\\n                    h: 0,\\n                    i: -1\\n                },\\n            };\\n        },\\n        created () {\\n            var self = this;\\n\\n            // Accessible refernces of functions for removing in beforeDestroy\\n            self.resizeEventHandler = function(eventType, i, x, y, h, w) {\\n                self.resizeEvent(eventType, i, x, y, h, w);\\n            };\\n\\n            self.dragEventHandler = function(eventType, i, x, y, h, w) {\\n                self.dragEvent(eventType, i, x, y, h, w);\\n            };\\n\\n            self._provided.eventBus =  new Vue();\\n            self.eventBus = self._provided.eventBus;\\n            self.eventBus.$on('resizeEvent', self.resizeEventHandler);\\n            self.eventBus.$on('dragEvent', self.dragEventHandler);\\n        },\\n        beforeDestroy: function(){\\n            //Remove listeners\\n            this.eventBus.$off('resizeEvent', self.resizeEventHandler);\\n            this.eventBus.$off('dragEvent', self.dragEventHandler);\\n            window.removeEventListener(\\\"resize\\\", self.onWindowResize)\\n        },\\n        mounted: function() {\\n            this.$nextTick(function () {\\n                validateLayout(this.layout);\\n                var self = this;\\n                this.$nextTick(function() {\\n                    if (self.width === null) {\\n                        self.onWindowResize();\\n                        //self.width = self.$el.offsetWidth;\\n                        window.addEventListener('resize', self.onWindowResize);\\n                    }\\n                    compact(self.layout, self.verticalCompact);\\n\\n                    self.updateHeight();\\n                    self.$nextTick(function () {\\n                        var erd = elementResizeDetectorMaker({\\n                            strategy: \\\"scroll\\\" //<- For ultra performance.\\n                        });\\n                        erd.listenTo(self.$refs.item, function (element) {\\n                            self.onWindowResize();\\n                        });\\n                    });\\n                });\\n                window.onload = function() {\\n                    if (self.width === null) {\\n                        self.onWindowResize();\\n                        //self.width = self.$el.offsetWidth;\\n                        window.addEventListener('resize', self.onWindowResize);\\n                    }\\n                    compact(self.layout, self.verticalCompact);\\n\\n                    self.updateHeight();\\n                    self.$nextTick(function () {\\n                        var erd = elementResizeDetectorMaker({\\n                            strategy: \\\"scroll\\\" //<- For ultra performance.\\n                        });\\n                        erd.listenTo(self.$refs.item, function (element) {\\n                            self.onWindowResize();\\n                        });\\n                    });\\n\\n                };\\n            });\\n        },\\n        watch: {\\n            width: function () {\\n                this.$nextTick(function () {\\n                    //this.$broadcast(\\\"updateWidth\\\", this.width);\\n                    this.eventBus.$emit(\\\"updateWidth\\\", this.width);\\n                    this.updateHeight();\\n                });\\n            },\\n            layout: function () {\\n                this.layoutUpdate();\\n            },\\n            rowHeight: function() {\\n                this.eventBus.$emit(\\\"setRowHeight\\\", this.rowHeight);\\n            },\\n            isDraggable: function() {\\n                this.eventBus.$emit(\\\"setDraggable\\\", this.isDraggable);\\n            },\\n            isResizable: function() {\\n                this.eventBus.$emit(\\\"setResizable\\\", this.isResizable);\\n            }\\n        },\\n        methods: {\\n            layoutUpdate() {\\n                if (this.layout !== undefined && this.layout.length !== this.lastLayoutLength) {\\n//                    console.log(\\\"### LAYOUT UPDATE!\\\");\\n                    this.lastLayoutLength = this.layout.length;\\n                    compact(this.layout, this.verticalCompact);\\n\\n                    //this.$broadcast(\\\"updateWidth\\\", this.width);\\n                    this.eventBus.$emit(\\\"updateWidth\\\", this.width);\\n                    this.updateHeight();\\n                }\\n            },\\n            updateHeight: function () {\\n                this.mergedStyle = {\\n                    height: this.containerHeight()\\n                };\\n            },\\n            onWindowResize: function () {\\n                if (this.$refs !== null && this.$refs.item !== null && this.$refs.item !== undefined) {\\n                    this.width = this.$refs.item.offsetWidth;\\n                }\\n            },\\n            containerHeight: function () {\\n                if (!this.autoSize) return;\\n                return bottom(this.layout) * (this.rowHeight + this.margin[1]) + this.margin[1] + 'px';\\n            },\\n            dragEvent: function (eventName, id, x, y, h, w) {\\n                if (eventName === \\\"dragmove\\\" || eventName === \\\"dragstart\\\") {\\n                    this.placeholder.i = id;\\n                    this.placeholder.x = x;\\n                    this.placeholder.y = y;\\n                    this.placeholder.w = w;\\n                    this.placeholder.h = h;\\n                    this.$nextTick(function() {\\n                        this.isDragging = true;\\n                    });\\n                    //this.$broadcast(\\\"updateWidth\\\", this.width);\\n                    this.eventBus.$emit(\\\"updateWidth\\\", this.width);\\n                } else {\\n                    this.$nextTick(function() {\\n                        this.isDragging = false;\\n                    });\\n                }\\n                //console.log(eventName + \\\" id=\\\" + id + \\\", x=\\\" + x + \\\", y=\\\" + y);\\n                var l = getLayoutItem(this.layout, id);\\n                //GetLayoutItem sometimes returns null object\\n                if (l === undefined || l === null){\\n                    l = {x:0, y:0}\\n                }\\n                l.x = x;\\n                l.y = y;\\n                // Move the element to the dragged location.\\n                this.layout = moveElement(this.layout, l, x, y, true);\\n                compact(this.layout, this.verticalCompact);\\n                // needed because vue can't detect changes on array element properties\\n                this.eventBus.$emit(\\\"compact\\\");\\n                this.updateHeight();\\n                if (eventName === 'dragend') this.$emit('layout-updated', this.layout);\\n            },\\n            resizeEvent: function (eventName, id, x, y, h, w) {\\n                if (eventName === \\\"resizestart\\\" || eventName === \\\"resizemove\\\") {\\n                    this.placeholder.i = id;\\n                    this.placeholder.x = x;\\n                    this.placeholder.y = y;\\n                    this.placeholder.w = w;\\n                    this.placeholder.h = h;\\n                    this.$nextTick(function() {\\n                        this.isDragging = true;\\n                    });\\n                    //this.$broadcast(\\\"updateWidth\\\", this.width);\\n                    this.eventBus.$emit(\\\"updateWidth\\\", this.width);\\n\\n                } else {\\n                    this.$nextTick(function() {\\n                        this.isDragging = false;\\n                    });\\n                }\\n                var l = getLayoutItem(this.layout, id);\\n                //GetLayoutItem sometimes return null object\\n                if (l === undefined || l === null){\\n                    l = {h:0, w:0}\\n                }\\n                l.h = h;\\n                l.w = w;\\n                compact(this.layout, this.verticalCompact);\\n                this.eventBus.$emit(\\\"compact\\\");\\n                this.updateHeight();\\n                if (eventName === 'resizeend') this.$emit('layout-updated', this.layout);\\n            },\\n        },\\n    }\\n</script>\\n\"],\"sourceRoot\":\"webpack://\"}]);\n\n// exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/css-loader?sourceMap!./node_modules/vue-loader/lib/style-compiler?{\"id\":\"data-v-3d4bb9a4\",\"scoped\":false,\"hasInlineConfig\":false}!./node_modules/vue-loader/lib/selector.js?type=styles&index=0!./src/GridLayout.vue\n// module id = 20\n// module chunks = 0"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///20\n"); +"use strict"; +eval("\n\nexports.__esModule = true;\n\nvar _vue = __webpack_require__(21);\n\nvar _vue2 = _interopRequireDefault(_vue);\n\nvar _utils = __webpack_require__(0);\n\nvar _GridItem = __webpack_require__(1);\n\nvar _GridItem2 = _interopRequireDefault(_GridItem);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nvar elementResizeDetectorMaker = __webpack_require__(6); //\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n\n//var eventBus = require('./eventBus');\nexports.default = {\n name: \"GridLayout\",\n provide: function provide() {\n return {\n eventBus: null\n };\n },\n\n components: {\n GridItem: _GridItem2.default\n },\n props: {\n // If true, the container height swells and contracts to fit contents\n autoSize: {\n type: Boolean,\n default: true\n },\n colNum: {\n type: Number,\n default: 12\n },\n rowHeight: {\n type: Number,\n default: 150\n },\n maxRows: {\n type: Number,\n default: Infinity\n },\n margin: {\n type: Array,\n default: function _default() {\n return [10, 10];\n }\n },\n isDraggable: {\n type: Boolean,\n default: true\n },\n isResizable: {\n type: Boolean,\n default: true\n },\n isMirrored: {\n type: Boolean,\n default: false\n },\n useCssTransforms: {\n type: Boolean,\n default: true\n },\n verticalCompact: {\n type: Boolean,\n default: true\n },\n layout: {\n type: Array,\n required: true\n }\n },\n data: function data() {\n return {\n width: null,\n mergedStyle: {},\n lastLayoutLength: 0,\n isDragging: false,\n placeholder: {\n x: 0,\n y: 0,\n w: 0,\n h: 0,\n i: -1\n }\n };\n },\n created: function created() {\n var self = this;\n\n // Accessible refernces of functions for removing in beforeDestroy\n self.resizeEventHandler = function (eventType, i, x, y, h, w) {\n self.resizeEvent(eventType, i, x, y, h, w);\n };\n\n self.dragEventHandler = function (eventType, i, x, y, h, w) {\n self.dragEvent(eventType, i, x, y, h, w);\n };\n\n self._provided.eventBus = new _vue2.default();\n self.eventBus = self._provided.eventBus;\n self.eventBus.$on('resizeEvent', self.resizeEventHandler);\n self.eventBus.$on('dragEvent', self.dragEventHandler);\n },\n\n beforeDestroy: function beforeDestroy() {\n //Remove listeners\n this.eventBus.$off('resizeEvent', self.resizeEventHandler);\n this.eventBus.$off('dragEvent', self.dragEventHandler);\n window.removeEventListener(\"resize\", self.onWindowResize);\n },\n mounted: function mounted() {\n this.$nextTick(function () {\n (0, _utils.validateLayout)(this.layout);\n var self = this;\n this.$nextTick(function () {\n if (self.width === null) {\n self.onWindowResize();\n //self.width = self.$el.offsetWidth;\n window.addEventListener('resize', self.onWindowResize);\n }\n (0, _utils.compact)(self.layout, self.verticalCompact);\n\n self.updateHeight();\n self.$nextTick(function () {\n var erd = elementResizeDetectorMaker({\n strategy: \"scroll\" //<- For ultra performance.\n });\n erd.listenTo(self.$refs.item, function (element) {\n self.onWindowResize();\n });\n });\n });\n window.onload = function () {\n if (self.width === null) {\n self.onWindowResize();\n //self.width = self.$el.offsetWidth;\n window.addEventListener('resize', self.onWindowResize);\n }\n (0, _utils.compact)(self.layout, self.verticalCompact);\n\n self.updateHeight();\n self.$nextTick(function () {\n var erd = elementResizeDetectorMaker({\n strategy: \"scroll\" //<- For ultra performance.\n });\n erd.listenTo(self.$refs.item, function (element) {\n self.onWindowResize();\n });\n });\n };\n });\n },\n watch: {\n width: function width() {\n this.$nextTick(function () {\n //this.$broadcast(\"updateWidth\", this.width);\n this.eventBus.$emit(\"updateWidth\", this.width);\n this.updateHeight();\n });\n },\n layout: function layout() {\n this.layoutUpdate();\n },\n rowHeight: function rowHeight() {\n this.eventBus.$emit(\"setRowHeight\", this.rowHeight);\n },\n isDraggable: function isDraggable() {\n this.eventBus.$emit(\"setDraggable\", this.isDraggable);\n },\n isResizable: function isResizable() {\n this.eventBus.$emit(\"setResizable\", this.isResizable);\n }\n },\n methods: {\n layoutUpdate: function layoutUpdate() {\n if (this.layout !== undefined) {\n if (this.layout.length !== this.lastLayoutLength) {\n //console.log(\"### LAYOUT UPDATE!\");\n this.lastLayoutLength = this.layout.length;\n }\n (0, _utils.compact)(this.layout, this.verticalCompact);\n this.eventBus.$emit(\"updateWidth\", this.width);\n this.updateHeight();\n }\n },\n\n updateHeight: function updateHeight() {\n this.mergedStyle = {\n height: this.containerHeight()\n };\n },\n onWindowResize: function onWindowResize() {\n if (this.$refs !== null && this.$refs.item !== null && this.$refs.item !== undefined) {\n this.width = this.$refs.item.offsetWidth;\n }\n },\n containerHeight: function containerHeight() {\n if (!this.autoSize) return;\n return (0, _utils.bottom)(this.layout) * (this.rowHeight + this.margin[1]) + this.margin[1] + 'px';\n },\n dragEvent: function dragEvent(eventName, id, x, y, h, w) {\n if (eventName === \"dragmove\" || eventName === \"dragstart\") {\n this.placeholder.i = id;\n this.placeholder.x = x;\n this.placeholder.y = y;\n this.placeholder.w = w;\n this.placeholder.h = h;\n this.$nextTick(function () {\n this.isDragging = true;\n });\n //this.$broadcast(\"updateWidth\", this.width);\n this.eventBus.$emit(\"updateWidth\", this.width);\n } else {\n this.$nextTick(function () {\n this.isDragging = false;\n });\n }\n //console.log(eventName + \" id=\" + id + \", x=\" + x + \", y=\" + y);\n var l = (0, _utils.getLayoutItem)(this.layout, id);\n //GetLayoutItem sometimes returns null object\n if (l === undefined || l === null) {\n l = { x: 0, y: 0 };\n }\n l.x = x;\n l.y = y;\n // Move the element to the dragged location.\n this.layout = (0, _utils.moveElement)(this.layout, l, x, y, true);\n (0, _utils.compact)(this.layout, this.verticalCompact);\n // needed because vue can't detect changes on array element properties\n this.eventBus.$emit(\"compact\");\n this.updateHeight();\n if (eventName === 'dragend') this.$emit('layout-updated', this.layout);\n },\n resizeEvent: function resizeEvent(eventName, id, x, y, h, w) {\n if (eventName === \"resizestart\" || eventName === \"resizemove\") {\n this.placeholder.i = id;\n this.placeholder.x = x;\n this.placeholder.y = y;\n this.placeholder.w = w;\n this.placeholder.h = h;\n this.$nextTick(function () {\n this.isDragging = true;\n });\n //this.$broadcast(\"updateWidth\", this.width);\n this.eventBus.$emit(\"updateWidth\", this.width);\n } else {\n this.$nextTick(function () {\n this.isDragging = false;\n });\n }\n var l = (0, _utils.getLayoutItem)(this.layout, id);\n //GetLayoutItem sometimes return null object\n if (l === undefined || l === null) {\n l = { h: 0, w: 0 };\n }\n l.h = h;\n l.w = w;\n (0, _utils.compact)(this.layout, this.verticalCompact);\n this.eventBus.$emit(\"compact\");\n this.updateHeight();\n if (eventName === 'resizeend') this.$emit('layout-updated', this.layout);\n }\n }\n};\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack:///GridLayout.vue?1157"],"names":[],"mappings":";;;;AAmBA;;;;AAGA;;AAIA;;;;;;AANA;;;;;;;;;;;;;;;;;;;AAGA;;UAKA;gCACA;;sBAGA;AAFA;AAGA;;;AAGA;AAFA;;AAIA;;kBAEA;qBAEA;AAHA;;kBAKA;qBAEA;AAHA;;kBAKA;qBAEA;AAHA;;kBAKA;qBAEA;AAHA;;kBAKA;yCACA;4BACA;AAEA;AALA;;kBAOA;qBAEA;AAHA;;kBAKA;qBAEA;AAHA;;kBAKA;qBAEA;AAHA;;kBAKA;qBAEA;AAHA;;kBAKA;qBAEA;AAHA;;kBAKA;sBAGA;AAJA;AA5CA;0BAiDA;;mBAEA;yBACA;8BACA;wBACA;;mBAEA;mBACA;mBACA;mBACA;oBAGA;AAPA;AALA;AAaA;gCACA;mBAEA;;AACA;sEACA;oDACA;AAEA;;oEACA;kDACA;AAEA;;kCACA;uCACA;8CACA;4CACA;AACA;;4CACA;AACA;+CACA;6CACA;kDACA;AACA;gCACA;mCACA;4CACA;uBACA;uCACA;yCACA;yBACA;AACA;2DACA;AACA;sDAEA;;qBACA;2CACA;;2CAGA;AAFA;qEAGA;6BACA;AACA;AACA;AACA;wCACA;yCACA;yBACA;AACA;2DACA;AACA;sDAEA;;qBACA;2CACA;;2CAGA;AAFA;qEAGA;6BACA;AACA;AAEA;AACA;AACA;AACA;;gCAEA;uCACA;AACA;wDACA;qBACA;AACA;AACA;kCACA;iBACA;AACA;wCACA;qDACA;AACA;4CACA;qDACA;AACA;4CACA;qDACA;AAEA;AApBA;;8CAsBA;2CACA;kEACA;AACA;wDACA;AACA;sDACA;wDACA;qBACA;AACA;AACA;;8CACA;;6BAGA;AAFA;AAGA;kDACA;kGACA;6CACA;AACA;AACA;oDACA;gCACA;0GACA;AACA;iEACA;uEACA;qCACA;qCACA;qCACA;qCACA;qCACA;2CACA;sCACA;AACA;AACA;wDACA;mBACA;2CACA;sCACA;AACA;AACA;AACA;2DACA;AACA;+CACA;+BACA;AACA;kBACA;kBACA;AACA;wEACA;kDACA;AACA;gCACA;iBACA;2EACA;AACA;qEACA;2EACA;qCACA;qCACA;qCACA;qCACA;qCACA;2CACA;sCACA;AACA;AACA;wDAEA;mBACA;2CACA;sCACA;AACA;AACA;2DACA;AACA;+CACA;+BACA;AACA;kBACA;kBACA;kDACA;gCACA;iBACA;6EACA;AAEA;AAzFA;AAjKA","file":"20.js","sourcesContent":["<template>\r\n    <div ref=\"item\" class=\"vue-grid-layout\" :style=\"mergedStyle\">\r\n        <slot></slot>\r\n        <grid-item class=\"vue-grid-placeholder\"\r\n                   v-show=\"isDragging\"\r\n                   :x=\"placeholder.x\"\r\n                   :y=\"placeholder.y\"\r\n                   :w=\"placeholder.w\"\r\n                   :h=\"placeholder.h\"\r\n                   :i=\"placeholder.i\"></grid-item>\r\n    </div>\r\n</template>\r\n<style>\r\n    .vue-grid-layout {\r\n        position: relative;\r\n        transition: height 200ms ease;\r\n    }\r\n</style>\r\n<script>\r\n    import Vue from 'vue';\r\n    var elementResizeDetectorMaker = require(\"element-resize-detector\");\r\n\r\n    import {bottom, compact, getLayoutItem, moveElement, validateLayout} from './utils';\r\n    //var eventBus = require('./eventBus');\r\n    import GridItem from './GridItem.vue'\r\n\r\n    export default {\r\n        name: \"GridLayout\",\r\n        provide() {\r\n            return {\r\n                eventBus: null\r\n            }\r\n        },\r\n        components: {\r\n            GridItem,\r\n        },\r\n        props: {\r\n            // If true, the container height swells and contracts to fit contents\r\n            autoSize: {\r\n                type: Boolean,\r\n                default: true\r\n            },\r\n            colNum: {\r\n                type: Number,\r\n                default: 12\r\n            },\r\n            rowHeight: {\r\n                type: Number,\r\n                default: 150\r\n            },\r\n            maxRows: {\r\n                type: Number,\r\n                default: Infinity\r\n            },\r\n            margin: {\r\n                type: Array,\r\n                default: function () {\r\n                    return [10, 10];\r\n                }\r\n            },\r\n            isDraggable: {\r\n                type: Boolean,\r\n                default: true\r\n            },\r\n            isResizable: {\r\n                type: Boolean,\r\n                default: true\r\n            },\r\n            isMirrored: {\r\n                type: Boolean,\r\n                default: false\r\n            },\r\n            useCssTransforms: {\r\n                type: Boolean,\r\n                default: true\r\n            },\r\n            verticalCompact: {\r\n                type: Boolean,\r\n                default: true\r\n            },\r\n            layout: {\r\n                type: Array,\r\n                required: true,\r\n            },\r\n        },\r\n        data: function () {\r\n            return {\r\n                width: null,\r\n                mergedStyle: {},\r\n                lastLayoutLength: 0,\r\n                isDragging: false,\r\n                placeholder: {\r\n                    x: 0,\r\n                    y: 0,\r\n                    w: 0,\r\n                    h: 0,\r\n                    i: -1\r\n                },\r\n            };\r\n        },\r\n        created () {\r\n            var self = this;\r\n\r\n            // Accessible refernces of functions for removing in beforeDestroy\r\n            self.resizeEventHandler = function(eventType, i, x, y, h, w) {\r\n                self.resizeEvent(eventType, i, x, y, h, w);\r\n            };\r\n\r\n            self.dragEventHandler = function(eventType, i, x, y, h, w) {\r\n                self.dragEvent(eventType, i, x, y, h, w);\r\n            };\r\n\r\n            self._provided.eventBus =  new Vue();\r\n            self.eventBus = self._provided.eventBus;\r\n            self.eventBus.$on('resizeEvent', self.resizeEventHandler);\r\n            self.eventBus.$on('dragEvent', self.dragEventHandler);\r\n        },\r\n        beforeDestroy: function(){\r\n            //Remove listeners\r\n            this.eventBus.$off('resizeEvent', self.resizeEventHandler);\r\n            this.eventBus.$off('dragEvent', self.dragEventHandler);\r\n            window.removeEventListener(\"resize\", self.onWindowResize)\r\n        },\r\n        mounted: function() {\r\n            this.$nextTick(function () {\r\n                validateLayout(this.layout);\r\n                var self = this;\r\n                this.$nextTick(function() {\r\n                    if (self.width === null) {\r\n                        self.onWindowResize();\r\n                        //self.width = self.$el.offsetWidth;\r\n                        window.addEventListener('resize', self.onWindowResize);\r\n                    }\r\n                    compact(self.layout, self.verticalCompact);\r\n\r\n                    self.updateHeight();\r\n                    self.$nextTick(function () {\r\n                        var erd = elementResizeDetectorMaker({\r\n                            strategy: \"scroll\" //<- For ultra performance.\r\n                        });\r\n                        erd.listenTo(self.$refs.item, function (element) {\r\n                            self.onWindowResize();\r\n                        });\r\n                    });\r\n                });\r\n                window.onload = function() {\r\n                    if (self.width === null) {\r\n                        self.onWindowResize();\r\n                        //self.width = self.$el.offsetWidth;\r\n                        window.addEventListener('resize', self.onWindowResize);\r\n                    }\r\n                    compact(self.layout, self.verticalCompact);\r\n\r\n                    self.updateHeight();\r\n                    self.$nextTick(function () {\r\n                        var erd = elementResizeDetectorMaker({\r\n                            strategy: \"scroll\" //<- For ultra performance.\r\n                        });\r\n                        erd.listenTo(self.$refs.item, function (element) {\r\n                            self.onWindowResize();\r\n                        });\r\n                    });\r\n\r\n                };\r\n            });\r\n        },\r\n        watch: {\r\n            width: function () {\r\n                this.$nextTick(function () {\r\n                    //this.$broadcast(\"updateWidth\", this.width);\r\n                    this.eventBus.$emit(\"updateWidth\", this.width);\r\n                    this.updateHeight();\r\n                });\r\n            },\r\n            layout: function () {\r\n                this.layoutUpdate();\r\n            },\r\n            rowHeight: function() {\r\n                this.eventBus.$emit(\"setRowHeight\", this.rowHeight);\r\n            },\r\n            isDraggable: function() {\r\n                this.eventBus.$emit(\"setDraggable\", this.isDraggable);\r\n            },\r\n            isResizable: function() {\r\n                this.eventBus.$emit(\"setResizable\", this.isResizable);\r\n            }\r\n        },\r\n        methods: {\r\n            layoutUpdate() {\r\n                if (this.layout !== undefined) {\r\n                    if (this.layout.length !== this.lastLayoutLength) {\r\n                        //console.log(\"### LAYOUT UPDATE!\");\r\n                        this.lastLayoutLength = this.layout.length;\r\n                    }\r\n                    compact(this.layout, this.verticalCompact);\r\n                    this.eventBus.$emit(\"updateWidth\", this.width);\r\n                    this.updateHeight();\r\n                }\r\n            },\r\n            updateHeight: function () {\r\n                this.mergedStyle = {\r\n                    height: this.containerHeight()\r\n                };\r\n            },\r\n            onWindowResize: function () {\r\n                if (this.$refs !== null && this.$refs.item !== null && this.$refs.item !== undefined) {\r\n                    this.width = this.$refs.item.offsetWidth;\r\n                }\r\n            },\r\n            containerHeight: function () {\r\n                if (!this.autoSize) return;\r\n                return bottom(this.layout) * (this.rowHeight + this.margin[1]) + this.margin[1] + 'px';\r\n            },\r\n            dragEvent: function (eventName, id, x, y, h, w) {\r\n                if (eventName === \"dragmove\" || eventName === \"dragstart\") {\r\n                    this.placeholder.i = id;\r\n                    this.placeholder.x = x;\r\n                    this.placeholder.y = y;\r\n                    this.placeholder.w = w;\r\n                    this.placeholder.h = h;\r\n                    this.$nextTick(function() {\r\n                        this.isDragging = true;\r\n                    });\r\n                    //this.$broadcast(\"updateWidth\", this.width);\r\n                    this.eventBus.$emit(\"updateWidth\", this.width);\r\n                } else {\r\n                    this.$nextTick(function() {\r\n                        this.isDragging = false;\r\n                    });\r\n                }\r\n                //console.log(eventName + \" id=\" + id + \", x=\" + x + \", y=\" + y);\r\n                var l = getLayoutItem(this.layout, id);\r\n                //GetLayoutItem sometimes returns null object\r\n                if (l === undefined || l === null){\r\n                    l = {x:0, y:0}\r\n                }\r\n                l.x = x;\r\n                l.y = y;\r\n                // Move the element to the dragged location.\r\n                this.layout = moveElement(this.layout, l, x, y, true);\r\n                compact(this.layout, this.verticalCompact);\r\n                // needed because vue can't detect changes on array element properties\r\n                this.eventBus.$emit(\"compact\");\r\n                this.updateHeight();\r\n                if (eventName === 'dragend') this.$emit('layout-updated', this.layout);\r\n            },\r\n            resizeEvent: function (eventName, id, x, y, h, w) {\r\n                if (eventName === \"resizestart\" || eventName === \"resizemove\") {\r\n                    this.placeholder.i = id;\r\n                    this.placeholder.x = x;\r\n                    this.placeholder.y = y;\r\n                    this.placeholder.w = w;\r\n                    this.placeholder.h = h;\r\n                    this.$nextTick(function() {\r\n                        this.isDragging = true;\r\n                    });\r\n                    //this.$broadcast(\"updateWidth\", this.width);\r\n                    this.eventBus.$emit(\"updateWidth\", this.width);\r\n\r\n                } else {\r\n                    this.$nextTick(function() {\r\n                        this.isDragging = false;\r\n                    });\r\n                }\r\n                var l = getLayoutItem(this.layout, id);\r\n                //GetLayoutItem sometimes return null object\r\n                if (l === undefined || l === null){\r\n                    l = {h:0, w:0}\r\n                }\r\n                l.h = h;\r\n                l.w = w;\r\n                compact(this.layout, this.verticalCompact);\r\n                this.eventBus.$emit(\"compact\");\r\n                this.updateHeight();\r\n                if (eventName === 'resizeend') this.$emit('layout-updated', this.layout);\r\n            },\r\n        },\r\n    }\r\n</script>\r\n\n\n\n// WEBPACK FOOTER //\n// GridLayout.vue?3470f332"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///20\n"); /***/ }), /* 21 */ /***/ (function(module, exports, __webpack_require__) { "use strict"; -eval("\n\nexports.__esModule = true;\n\nvar _vue = __webpack_require__(22);\n\nvar _vue2 = _interopRequireDefault(_vue);\n\nvar _utils = __webpack_require__(0);\n\nvar _GridItem = __webpack_require__(1);\n\nvar _GridItem2 = _interopRequireDefault(_GridItem);\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nvar elementResizeDetectorMaker = __webpack_require__(7); //\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n\n//var eventBus = require('./eventBus');\nexports.default = {\n name: \"GridLayout\",\n provide: function provide() {\n return {\n eventBus: null\n };\n },\n\n components: {\n GridItem: _GridItem2.default\n },\n props: {\n // If true, the container height swells and contracts to fit contents\n autoSize: {\n type: Boolean,\n default: true\n },\n colNum: {\n type: Number,\n default: 12\n },\n rowHeight: {\n type: Number,\n default: 150\n },\n maxRows: {\n type: Number,\n default: Infinity\n },\n margin: {\n type: Array,\n default: function _default() {\n return [10, 10];\n }\n },\n isDraggable: {\n type: Boolean,\n default: true\n },\n isResizable: {\n type: Boolean,\n default: true\n },\n isMirrored: {\n type: Boolean,\n default: false\n },\n useCssTransforms: {\n type: Boolean,\n default: true\n },\n verticalCompact: {\n type: Boolean,\n default: true\n },\n layout: {\n type: Array,\n required: true\n }\n },\n data: function data() {\n return {\n width: null,\n mergedStyle: {},\n lastLayoutLength: 0,\n isDragging: false,\n placeholder: {\n x: 0,\n y: 0,\n w: 0,\n h: 0,\n i: -1\n }\n };\n },\n created: function created() {\n var self = this;\n\n // Accessible refernces of functions for removing in beforeDestroy\n self.resizeEventHandler = function (eventType, i, x, y, h, w) {\n self.resizeEvent(eventType, i, x, y, h, w);\n };\n\n self.dragEventHandler = function (eventType, i, x, y, h, w) {\n self.dragEvent(eventType, i, x, y, h, w);\n };\n\n self._provided.eventBus = new _vue2.default();\n self.eventBus = self._provided.eventBus;\n self.eventBus.$on('resizeEvent', self.resizeEventHandler);\n self.eventBus.$on('dragEvent', self.dragEventHandler);\n },\n\n beforeDestroy: function beforeDestroy() {\n //Remove listeners\n this.eventBus.$off('resizeEvent', self.resizeEventHandler);\n this.eventBus.$off('dragEvent', self.dragEventHandler);\n window.removeEventListener(\"resize\", self.onWindowResize);\n },\n mounted: function mounted() {\n this.$nextTick(function () {\n (0, _utils.validateLayout)(this.layout);\n var self = this;\n this.$nextTick(function () {\n if (self.width === null) {\n self.onWindowResize();\n //self.width = self.$el.offsetWidth;\n window.addEventListener('resize', self.onWindowResize);\n }\n (0, _utils.compact)(self.layout, self.verticalCompact);\n\n self.updateHeight();\n self.$nextTick(function () {\n var erd = elementResizeDetectorMaker({\n strategy: \"scroll\" //<- For ultra performance.\n });\n erd.listenTo(self.$refs.item, function (element) {\n self.onWindowResize();\n });\n });\n });\n window.onload = function () {\n if (self.width === null) {\n self.onWindowResize();\n //self.width = self.$el.offsetWidth;\n window.addEventListener('resize', self.onWindowResize);\n }\n (0, _utils.compact)(self.layout, self.verticalCompact);\n\n self.updateHeight();\n self.$nextTick(function () {\n var erd = elementResizeDetectorMaker({\n strategy: \"scroll\" //<- For ultra performance.\n });\n erd.listenTo(self.$refs.item, function (element) {\n self.onWindowResize();\n });\n });\n };\n });\n },\n watch: {\n width: function width() {\n this.$nextTick(function () {\n //this.$broadcast(\"updateWidth\", this.width);\n this.eventBus.$emit(\"updateWidth\", this.width);\n this.updateHeight();\n });\n },\n layout: function layout() {\n this.layoutUpdate();\n },\n rowHeight: function rowHeight() {\n this.eventBus.$emit(\"setRowHeight\", this.rowHeight);\n },\n isDraggable: function isDraggable() {\n this.eventBus.$emit(\"setDraggable\", this.isDraggable);\n },\n isResizable: function isResizable() {\n this.eventBus.$emit(\"setResizable\", this.isResizable);\n }\n },\n methods: {\n layoutUpdate: function layoutUpdate() {\n if (this.layout !== undefined && this.layout.length !== this.lastLayoutLength) {\n // console.log(\"### LAYOUT UPDATE!\");\n this.lastLayoutLength = this.layout.length;\n (0, _utils.compact)(this.layout, this.verticalCompact);\n\n //this.$broadcast(\"updateWidth\", this.width);\n this.eventBus.$emit(\"updateWidth\", this.width);\n this.updateHeight();\n }\n },\n\n updateHeight: function updateHeight() {\n this.mergedStyle = {\n height: this.containerHeight()\n };\n },\n onWindowResize: function onWindowResize() {\n if (this.$refs !== null && this.$refs.item !== null && this.$refs.item !== undefined) {\n this.width = this.$refs.item.offsetWidth;\n }\n },\n containerHeight: function containerHeight() {\n if (!this.autoSize) return;\n return (0, _utils.bottom)(this.layout) * (this.rowHeight + this.margin[1]) + this.margin[1] + 'px';\n },\n dragEvent: function dragEvent(eventName, id, x, y, h, w) {\n if (eventName === \"dragmove\" || eventName === \"dragstart\") {\n this.placeholder.i = id;\n this.placeholder.x = x;\n this.placeholder.y = y;\n this.placeholder.w = w;\n this.placeholder.h = h;\n this.$nextTick(function () {\n this.isDragging = true;\n });\n //this.$broadcast(\"updateWidth\", this.width);\n this.eventBus.$emit(\"updateWidth\", this.width);\n } else {\n this.$nextTick(function () {\n this.isDragging = false;\n });\n }\n //console.log(eventName + \" id=\" + id + \", x=\" + x + \", y=\" + y);\n var l = (0, _utils.getLayoutItem)(this.layout, id);\n //GetLayoutItem sometimes returns null object\n if (l === undefined || l === null) {\n l = { x: 0, y: 0 };\n }\n l.x = x;\n l.y = y;\n // Move the element to the dragged location.\n this.layout = (0, _utils.moveElement)(this.layout, l, x, y, true);\n (0, _utils.compact)(this.layout, this.verticalCompact);\n // needed because vue can't detect changes on array element properties\n this.eventBus.$emit(\"compact\");\n this.updateHeight();\n if (eventName === 'dragend') this.$emit('layout-updated', this.layout);\n },\n resizeEvent: function resizeEvent(eventName, id, x, y, h, w) {\n if (eventName === \"resizestart\" || eventName === \"resizemove\") {\n this.placeholder.i = id;\n this.placeholder.x = x;\n this.placeholder.y = y;\n this.placeholder.w = w;\n this.placeholder.h = h;\n this.$nextTick(function () {\n this.isDragging = true;\n });\n //this.$broadcast(\"updateWidth\", this.width);\n this.eventBus.$emit(\"updateWidth\", this.width);\n } else {\n this.$nextTick(function () {\n this.isDragging = false;\n });\n }\n var l = (0, _utils.getLayoutItem)(this.layout, id);\n //GetLayoutItem sometimes return null object\n if (l === undefined || l === null) {\n l = { h: 0, w: 0 };\n }\n l.h = h;\n l.w = w;\n (0, _utils.compact)(this.layout, this.verticalCompact);\n this.eventBus.$emit(\"compact\");\n this.updateHeight();\n if (eventName === 'resizeend') this.$emit('layout-updated', this.layout);\n }\n }\n};\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack:///GridLayout.vue?10c3"],"names":[],"mappings":";;;;AAoBA;;;;AAGA;;AAGA;;;;;;qDAJA;;;;;;;;;;;;;;;;;AAHA;;AAKA;;UAIA;gCACA;;sBAGA;AAFA;AAGA;;;AAGA;AAFA;;AAIA;;kBAEA;qBAEA;AAHA;;kBAKA;qBAEA;AAHA;;kBAKA;qBAEA;AAHA;;kBAKA;qBAEA;AAHA;;kBAKA;yCACA;4BACA;AAEA;AALA;;kBAOA;qBAEA;AAHA;;kBAKA;qBAEA;AAHA;;kBAKA;qBAEA;AAHA;;kBAKA;qBAEA;AAHA;;kBAKA;qBAEA;AAHA;;kBAKA;sBAGA;AAJA;AA5CA;0BAiDA;;mBAEA;yBACA;8BACA;wBACA;;mBAEA;mBACA;mBACA;mBACA;oBAGA;AAPA;AALA;AAaA;gCACA;mBAEA;;AACA;sEACA;oDACA;AAEA;;oEACA;kDACA;AAEA;;kCACA;uCACA;8CACA;4CACA;AACA;;4CACA;AACA;+CACA;6CACA;kDACA;AACA;gCACA;mCACA;4CACA;uBACA;uCACA;yCACA;yBACA;AACA;2DACA;AACA;sDAEA;;qBACA;2CACA;;2CAGA;AAFA;qEAGA;6BACA;AACA;AACA;AACA;wCACA;yCACA;yBACA;AACA;2DACA;AACA;sDAEA;;qBACA;2CACA;;2CAGA;AAFA;qEAGA;6BACA;AACA;AAEA;AACA;AACA;AACA;;gCAEA;uCACA;AACA;wDACA;qBACA;AACA;AACA;kCACA;iBACA;AACA;wCACA;qDACA;AACA;4CACA;qDACA;AACA;4CACA;qDACA;AAEA;AApBA;;8CAsBA;;AAEA;oDACA;sDAEA;;AACA;wDACA;qBACA;AACA;AACA;;8CACA;;6BAGA;AAFA;AAGA;kDACA;kGACA;6CACA;AACA;AACA;oDACA;gCACA;0GACA;AACA;iEACA;uEACA;qCACA;qCACA;qCACA;qCACA;qCACA;2CACA;sCACA;AACA;AACA;wDACA;mBACA;2CACA;sCACA;AACA;AACA;AACA;2DACA;AACA;+CACA;+BACA;AACA;kBACA;kBACA;AACA;wEACA;kDACA;AACA;gCACA;iBACA;2EACA;AACA;qEACA;2EACA;qCACA;qCACA;qCACA;qCACA;qCACA;2CACA;sCACA;AACA;AACA;wDAEA;mBACA;2CACA;sCACA;AACA;AACA;2DACA;AACA;+CACA;+BACA;AACA;kBACA;kBACA;kDACA;gCACA;iBACA;6EACA;AAEA;AAzFA;AAjKA","file":"21.js","sourcesContent":["<template>\n    <div ref=\"item\" class=\"vue-grid-layout\" :style=\"mergedStyle\">\n        <slot></slot>\n        <grid-item class=\"vue-grid-placeholder\"\n                   v-show=\"isDragging\"\n                   :x=\"placeholder.x\"\n                   :y=\"placeholder.y\"\n                   :w=\"placeholder.w\"\n                   :h=\"placeholder.h\"\n                   :i=\"placeholder.i\"></grid-item>\n    </div>\n</template>\n<style>\n    .vue-grid-layout {\n        position: relative;\n        transition: height 200ms ease;\n    }\n</style>\n<script>\n    import Vue from 'vue';\n    var elementResizeDetectorMaker = require(\"element-resize-detector\");\n\n    import {bottom, compact, getLayoutItem, moveElement, validateLayout} from './utils';\n    //var eventBus = require('./eventBus');\n    import GridItem from './GridItem.vue'\n\n    export default {\n        name: \"GridLayout\",\n        provide() {\n            return {\n                eventBus: null\n            }\n        },\n        components: {\n            GridItem,\n        },\n        props: {\n            // If true, the container height swells and contracts to fit contents\n            autoSize: {\n                type: Boolean,\n                default: true\n            },\n            colNum: {\n                type: Number,\n                default: 12\n            },\n            rowHeight: {\n                type: Number,\n                default: 150\n            },\n            maxRows: {\n                type: Number,\n                default: Infinity\n            },\n            margin: {\n                type: Array,\n                default: function () {\n                    return [10, 10];\n                }\n            },\n            isDraggable: {\n                type: Boolean,\n                default: true\n            },\n            isResizable: {\n                type: Boolean,\n                default: true\n            },\n            isMirrored: {\n                type: Boolean,\n                default: false\n            },\n            useCssTransforms: {\n                type: Boolean,\n                default: true\n            },\n            verticalCompact: {\n                type: Boolean,\n                default: true\n            },\n            layout: {\n                type: Array,\n                required: true,\n            },\n        },\n        data: function () {\n            return {\n                width: null,\n                mergedStyle: {},\n                lastLayoutLength: 0,\n                isDragging: false,\n                placeholder: {\n                    x: 0,\n                    y: 0,\n                    w: 0,\n                    h: 0,\n                    i: -1\n                },\n            };\n        },\n        created () {\n            var self = this;\n\n            // Accessible refernces of functions for removing in beforeDestroy\n            self.resizeEventHandler = function(eventType, i, x, y, h, w) {\n                self.resizeEvent(eventType, i, x, y, h, w);\n            };\n\n            self.dragEventHandler = function(eventType, i, x, y, h, w) {\n                self.dragEvent(eventType, i, x, y, h, w);\n            };\n\n            self._provided.eventBus =  new Vue();\n            self.eventBus = self._provided.eventBus;\n            self.eventBus.$on('resizeEvent', self.resizeEventHandler);\n            self.eventBus.$on('dragEvent', self.dragEventHandler);\n        },\n        beforeDestroy: function(){\n            //Remove listeners\n            this.eventBus.$off('resizeEvent', self.resizeEventHandler);\n            this.eventBus.$off('dragEvent', self.dragEventHandler);\n            window.removeEventListener(\"resize\", self.onWindowResize)\n        },\n        mounted: function() {\n            this.$nextTick(function () {\n                validateLayout(this.layout);\n                var self = this;\n                this.$nextTick(function() {\n                    if (self.width === null) {\n                        self.onWindowResize();\n                        //self.width = self.$el.offsetWidth;\n                        window.addEventListener('resize', self.onWindowResize);\n                    }\n                    compact(self.layout, self.verticalCompact);\n\n                    self.updateHeight();\n                    self.$nextTick(function () {\n                        var erd = elementResizeDetectorMaker({\n                            strategy: \"scroll\" //<- For ultra performance.\n                        });\n                        erd.listenTo(self.$refs.item, function (element) {\n                            self.onWindowResize();\n                        });\n                    });\n                });\n                window.onload = function() {\n                    if (self.width === null) {\n                        self.onWindowResize();\n                        //self.width = self.$el.offsetWidth;\n                        window.addEventListener('resize', self.onWindowResize);\n                    }\n                    compact(self.layout, self.verticalCompact);\n\n                    self.updateHeight();\n                    self.$nextTick(function () {\n                        var erd = elementResizeDetectorMaker({\n                            strategy: \"scroll\" //<- For ultra performance.\n                        });\n                        erd.listenTo(self.$refs.item, function (element) {\n                            self.onWindowResize();\n                        });\n                    });\n\n                };\n            });\n        },\n        watch: {\n            width: function () {\n                this.$nextTick(function () {\n                    //this.$broadcast(\"updateWidth\", this.width);\n                    this.eventBus.$emit(\"updateWidth\", this.width);\n                    this.updateHeight();\n                });\n            },\n            layout: function () {\n                this.layoutUpdate();\n            },\n            rowHeight: function() {\n                this.eventBus.$emit(\"setRowHeight\", this.rowHeight);\n            },\n            isDraggable: function() {\n                this.eventBus.$emit(\"setDraggable\", this.isDraggable);\n            },\n            isResizable: function() {\n                this.eventBus.$emit(\"setResizable\", this.isResizable);\n            }\n        },\n        methods: {\n            layoutUpdate() {\n                if (this.layout !== undefined && this.layout.length !== this.lastLayoutLength) {\n//                    console.log(\"### LAYOUT UPDATE!\");\n                    this.lastLayoutLength = this.layout.length;\n                    compact(this.layout, this.verticalCompact);\n\n                    //this.$broadcast(\"updateWidth\", this.width);\n                    this.eventBus.$emit(\"updateWidth\", this.width);\n                    this.updateHeight();\n                }\n            },\n            updateHeight: function () {\n                this.mergedStyle = {\n                    height: this.containerHeight()\n                };\n            },\n            onWindowResize: function () {\n                if (this.$refs !== null && this.$refs.item !== null && this.$refs.item !== undefined) {\n                    this.width = this.$refs.item.offsetWidth;\n                }\n            },\n            containerHeight: function () {\n                if (!this.autoSize) return;\n                return bottom(this.layout) * (this.rowHeight + this.margin[1]) + this.margin[1] + 'px';\n            },\n            dragEvent: function (eventName, id, x, y, h, w) {\n                if (eventName === \"dragmove\" || eventName === \"dragstart\") {\n                    this.placeholder.i = id;\n                    this.placeholder.x = x;\n                    this.placeholder.y = y;\n                    this.placeholder.w = w;\n                    this.placeholder.h = h;\n                    this.$nextTick(function() {\n                        this.isDragging = true;\n                    });\n                    //this.$broadcast(\"updateWidth\", this.width);\n                    this.eventBus.$emit(\"updateWidth\", this.width);\n                } else {\n                    this.$nextTick(function() {\n                        this.isDragging = false;\n                    });\n                }\n                //console.log(eventName + \" id=\" + id + \", x=\" + x + \", y=\" + y);\n                var l = getLayoutItem(this.layout, id);\n                //GetLayoutItem sometimes returns null object\n                if (l === undefined || l === null){\n                    l = {x:0, y:0}\n                }\n                l.x = x;\n                l.y = y;\n                // Move the element to the dragged location.\n                this.layout = moveElement(this.layout, l, x, y, true);\n                compact(this.layout, this.verticalCompact);\n                // needed because vue can't detect changes on array element properties\n                this.eventBus.$emit(\"compact\");\n                this.updateHeight();\n                if (eventName === 'dragend') this.$emit('layout-updated', this.layout);\n            },\n            resizeEvent: function (eventName, id, x, y, h, w) {\n                if (eventName === \"resizestart\" || eventName === \"resizemove\") {\n                    this.placeholder.i = id;\n                    this.placeholder.x = x;\n                    this.placeholder.y = y;\n                    this.placeholder.w = w;\n                    this.placeholder.h = h;\n                    this.$nextTick(function() {\n                        this.isDragging = true;\n                    });\n                    //this.$broadcast(\"updateWidth\", this.width);\n                    this.eventBus.$emit(\"updateWidth\", this.width);\n\n                } else {\n                    this.$nextTick(function() {\n                        this.isDragging = false;\n                    });\n                }\n                var l = getLayoutItem(this.layout, id);\n                //GetLayoutItem sometimes return null object\n                if (l === undefined || l === null){\n                    l = {h:0, w:0}\n                }\n                l.h = h;\n                l.w = w;\n                compact(this.layout, this.verticalCompact);\n                this.eventBus.$emit(\"compact\");\n                this.updateHeight();\n                if (eventName === 'resizeend') this.$emit('layout-updated', this.layout);\n            },\n        },\n    }\n</script>\n\n\n\n// WEBPACK FOOTER //\n// GridLayout.vue?6c736e29"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///21\n"); +eval("/* WEBPACK VAR INJECTION */(function(process, global) {/*!\n * Vue.js v2.4.2\n * (c) 2014-2017 Evan You\n * Released under the MIT License.\n */\n\n\n/* */\n\n// these helpers produces better vm code in JS engines due to their\n// explicitness and function inlining\nfunction isUndef (v) {\n return v === undefined || v === null\n}\n\nfunction isDef (v) {\n return v !== undefined && v !== null\n}\n\nfunction isTrue (v) {\n return v === true\n}\n\nfunction isFalse (v) {\n return v === false\n}\n\n/**\n * Check if value is primitive\n */\nfunction isPrimitive (value) {\n return (\n typeof value === 'string' ||\n typeof value === 'number' ||\n typeof value === 'boolean'\n )\n}\n\n/**\n * Quick object check - this is primarily used to tell\n * Objects from primitive values when we know the value\n * is a JSON-compliant type.\n */\nfunction isObject (obj) {\n return obj !== null && typeof obj === 'object'\n}\n\nvar _toString = Object.prototype.toString;\n\n/**\n * Strict object type check. Only returns true\n * for plain JavaScript objects.\n */\nfunction isPlainObject (obj) {\n return _toString.call(obj) === '[object Object]'\n}\n\nfunction isRegExp (v) {\n return _toString.call(v) === '[object RegExp]'\n}\n\n/**\n * Check if val is a valid array index.\n */\nfunction isValidArrayIndex (val) {\n var n = parseFloat(val);\n return n >= 0 && Math.floor(n) === n && isFinite(val)\n}\n\n/**\n * Convert a value to a string that is actually rendered.\n */\nfunction toString (val) {\n return val == null\n ? ''\n : typeof val === 'object'\n ? JSON.stringify(val, null, 2)\n : String(val)\n}\n\n/**\n * Convert a input value to a number for persistence.\n * If the conversion fails, return original string.\n */\nfunction toNumber (val) {\n var n = parseFloat(val);\n return isNaN(n) ? val : n\n}\n\n/**\n * Make a map and return a function for checking if a key\n * is in that map.\n */\nfunction makeMap (\n str,\n expectsLowerCase\n) {\n var map = Object.create(null);\n var list = str.split(',');\n for (var i = 0; i < list.length; i++) {\n map[list[i]] = true;\n }\n return expectsLowerCase\n ? function (val) { return map[val.toLowerCase()]; }\n : function (val) { return map[val]; }\n}\n\n/**\n * Check if a tag is a built-in tag.\n */\nvar isBuiltInTag = makeMap('slot,component', true);\n\n/**\n * Check if a attribute is a reserved attribute.\n */\nvar isReservedAttribute = makeMap('key,ref,slot,is');\n\n/**\n * Remove an item from an array\n */\nfunction remove (arr, item) {\n if (arr.length) {\n var index = arr.indexOf(item);\n if (index > -1) {\n return arr.splice(index, 1)\n }\n }\n}\n\n/**\n * Check whether the object has the property.\n */\nvar hasOwnProperty = Object.prototype.hasOwnProperty;\nfunction hasOwn (obj, key) {\n return hasOwnProperty.call(obj, key)\n}\n\n/**\n * Create a cached version of a pure function.\n */\nfunction cached (fn) {\n var cache = Object.create(null);\n return (function cachedFn (str) {\n var hit = cache[str];\n return hit || (cache[str] = fn(str))\n })\n}\n\n/**\n * Camelize a hyphen-delimited string.\n */\nvar camelizeRE = /-(\\w)/g;\nvar camelize = cached(function (str) {\n return str.replace(camelizeRE, function (_, c) { return c ? c.toUpperCase() : ''; })\n});\n\n/**\n * Capitalize a string.\n */\nvar capitalize = cached(function (str) {\n return str.charAt(0).toUpperCase() + str.slice(1)\n});\n\n/**\n * Hyphenate a camelCase string.\n */\nvar hyphenateRE = /([^-])([A-Z])/g;\nvar hyphenate = cached(function (str) {\n return str\n .replace(hyphenateRE, '$1-$2')\n .replace(hyphenateRE, '$1-$2')\n .toLowerCase()\n});\n\n/**\n * Simple bind, faster than native\n */\nfunction bind (fn, ctx) {\n function boundFn (a) {\n var l = arguments.length;\n return l\n ? l > 1\n ? fn.apply(ctx, arguments)\n : fn.call(ctx, a)\n : fn.call(ctx)\n }\n // record original fn length\n boundFn._length = fn.length;\n return boundFn\n}\n\n/**\n * Convert an Array-like object to a real Array.\n */\nfunction toArray (list, start) {\n start = start || 0;\n var i = list.length - start;\n var ret = new Array(i);\n while (i--) {\n ret[i] = list[i + start];\n }\n return ret\n}\n\n/**\n * Mix properties into target object.\n */\nfunction extend (to, _from) {\n for (var key in _from) {\n to[key] = _from[key];\n }\n return to\n}\n\n/**\n * Merge an Array of Objects into a single Object.\n */\nfunction toObject (arr) {\n var res = {};\n for (var i = 0; i < arr.length; i++) {\n if (arr[i]) {\n extend(res, arr[i]);\n }\n }\n return res\n}\n\n/**\n * Perform no operation.\n * Stubbing args to make Flow happy without leaving useless transpiled code\n * with ...rest (https://flow.org/blog/2017/05/07/Strict-Function-Call-Arity/)\n */\nfunction noop (a, b, c) {}\n\n/**\n * Always return false.\n */\nvar no = function (a, b, c) { return false; };\n\n/**\n * Return same value\n */\nvar identity = function (_) { return _; };\n\n/**\n * Generate a static keys string from compiler modules.\n */\nfunction genStaticKeys (modules) {\n return modules.reduce(function (keys, m) {\n return keys.concat(m.staticKeys || [])\n }, []).join(',')\n}\n\n/**\n * Check if two values are loosely equal - that is,\n * if they are plain objects, do they have the same shape?\n */\nfunction looseEqual (a, b) {\n if (a === b) { return true }\n var isObjectA = isObject(a);\n var isObjectB = isObject(b);\n if (isObjectA && isObjectB) {\n try {\n var isArrayA = Array.isArray(a);\n var isArrayB = Array.isArray(b);\n if (isArrayA && isArrayB) {\n return a.length === b.length && a.every(function (e, i) {\n return looseEqual(e, b[i])\n })\n } else if (!isArrayA && !isArrayB) {\n var keysA = Object.keys(a);\n var keysB = Object.keys(b);\n return keysA.length === keysB.length && keysA.every(function (key) {\n return looseEqual(a[key], b[key])\n })\n } else {\n /* istanbul ignore next */\n return false\n }\n } catch (e) {\n /* istanbul ignore next */\n return false\n }\n } else if (!isObjectA && !isObjectB) {\n return String(a) === String(b)\n } else {\n return false\n }\n}\n\nfunction looseIndexOf (arr, val) {\n for (var i = 0; i < arr.length; i++) {\n if (looseEqual(arr[i], val)) { return i }\n }\n return -1\n}\n\n/**\n * Ensure a function is called only once.\n */\nfunction once (fn) {\n var called = false;\n return function () {\n if (!called) {\n called = true;\n fn.apply(this, arguments);\n }\n }\n}\n\nvar SSR_ATTR = 'data-server-rendered';\n\nvar ASSET_TYPES = [\n 'component',\n 'directive',\n 'filter'\n];\n\nvar LIFECYCLE_HOOKS = [\n 'beforeCreate',\n 'created',\n 'beforeMount',\n 'mounted',\n 'beforeUpdate',\n 'updated',\n 'beforeDestroy',\n 'destroyed',\n 'activated',\n 'deactivated'\n];\n\n/* */\n\nvar config = ({\n /**\n * Option merge strategies (used in core/util/options)\n */\n optionMergeStrategies: Object.create(null),\n\n /**\n * Whether to suppress warnings.\n */\n silent: false,\n\n /**\n * Show production mode tip message on boot?\n */\n productionTip: process.env.NODE_ENV !== 'production',\n\n /**\n * Whether to enable devtools\n */\n devtools: process.env.NODE_ENV !== 'production',\n\n /**\n * Whether to record perf\n */\n performance: false,\n\n /**\n * Error handler for watcher errors\n */\n errorHandler: null,\n\n /**\n * Warn handler for watcher warns\n */\n warnHandler: null,\n\n /**\n * Ignore certain custom elements\n */\n ignoredElements: [],\n\n /**\n * Custom user key aliases for v-on\n */\n keyCodes: Object.create(null),\n\n /**\n * Check if a tag is reserved so that it cannot be registered as a\n * component. This is platform-dependent and may be overwritten.\n */\n isReservedTag: no,\n\n /**\n * Check if an attribute is reserved so that it cannot be used as a component\n * prop. This is platform-dependent and may be overwritten.\n */\n isReservedAttr: no,\n\n /**\n * Check if a tag is an unknown element.\n * Platform-dependent.\n */\n isUnknownElement: no,\n\n /**\n * Get the namespace of an element\n */\n getTagNamespace: noop,\n\n /**\n * Parse the real tag name for the specific platform.\n */\n parsePlatformTagName: identity,\n\n /**\n * Check if an attribute must be bound using property, e.g. value\n * Platform-dependent.\n */\n mustUseProp: no,\n\n /**\n * Exposed for legacy reasons\n */\n _lifecycleHooks: LIFECYCLE_HOOKS\n});\n\n/* */\n\nvar emptyObject = Object.freeze({});\n\n/**\n * Check if a string starts with $ or _\n */\nfunction isReserved (str) {\n var c = (str + '').charCodeAt(0);\n return c === 0x24 || c === 0x5F\n}\n\n/**\n * Define a property.\n */\nfunction def (obj, key, val, enumerable) {\n Object.defineProperty(obj, key, {\n value: val,\n enumerable: !!enumerable,\n writable: true,\n configurable: true\n });\n}\n\n/**\n * Parse simple path.\n */\nvar bailRE = /[^\\w.$]/;\nfunction parsePath (path) {\n if (bailRE.test(path)) {\n return\n }\n var segments = path.split('.');\n return function (obj) {\n for (var i = 0; i < segments.length; i++) {\n if (!obj) { return }\n obj = obj[segments[i]];\n }\n return obj\n }\n}\n\n/* */\n\nvar warn = noop;\nvar tip = noop;\nvar formatComponentName = (null); // work around flow check\n\nif (process.env.NODE_ENV !== 'production') {\n var hasConsole = typeof console !== 'undefined';\n var classifyRE = /(?:^|[-_])(\\w)/g;\n var classify = function (str) { return str\n .replace(classifyRE, function (c) { return c.toUpperCase(); })\n .replace(/[-_]/g, ''); };\n\n warn = function (msg, vm) {\n var trace = vm ? generateComponentTrace(vm) : '';\n\n if (config.warnHandler) {\n config.warnHandler.call(null, msg, vm, trace);\n } else if (hasConsole && (!config.silent)) {\n console.error((\"[Vue warn]: \" + msg + trace));\n }\n };\n\n tip = function (msg, vm) {\n if (hasConsole && (!config.silent)) {\n console.warn(\"[Vue tip]: \" + msg + (\n vm ? generateComponentTrace(vm) : ''\n ));\n }\n };\n\n formatComponentName = function (vm, includeFile) {\n if (vm.$root === vm) {\n return ''\n }\n var name = typeof vm === 'string'\n ? vm\n : typeof vm === 'function' && vm.options\n ? vm.options.name\n : vm._isVue\n ? vm.$options.name || vm.$options._componentTag\n : vm.name;\n\n var file = vm._isVue && vm.$options.__file;\n if (!name && file) {\n var match = file.match(/([^/\\\\]+)\\.vue$/);\n name = match && match[1];\n }\n\n return (\n (name ? (\"<\" + (classify(name)) + \">\") : \"\") +\n (file && includeFile !== false ? (\" at \" + file) : '')\n )\n };\n\n var repeat = function (str, n) {\n var res = '';\n while (n) {\n if (n % 2 === 1) { res += str; }\n if (n > 1) { str += str; }\n n >>= 1;\n }\n return res\n };\n\n var generateComponentTrace = function (vm) {\n if (vm._isVue && vm.$parent) {\n var tree = [];\n var currentRecursiveSequence = 0;\n while (vm) {\n if (tree.length > 0) {\n var last = tree[tree.length - 1];\n if (last.constructor === vm.constructor) {\n currentRecursiveSequence++;\n vm = vm.$parent;\n continue\n } else if (currentRecursiveSequence > 0) {\n tree[tree.length - 1] = [last, currentRecursiveSequence];\n currentRecursiveSequence = 0;\n }\n }\n tree.push(vm);\n vm = vm.$parent;\n }\n return '\\n\\nfound in\\n\\n' + tree\n .map(function (vm, i) { return (\"\" + (i === 0 ? '---> ' : repeat(' ', 5 + i * 2)) + (Array.isArray(vm)\n ? ((formatComponentName(vm[0])) + \"... (\" + (vm[1]) + \" recursive calls)\")\n : formatComponentName(vm))); })\n .join('\\n')\n } else {\n return (\"\\n\\n(found in \" + (formatComponentName(vm)) + \")\")\n }\n };\n}\n\n/* */\n\nfunction handleError (err, vm, info) {\n if (config.errorHandler) {\n config.errorHandler.call(null, err, vm, info);\n } else {\n if (process.env.NODE_ENV !== 'production') {\n warn((\"Error in \" + info + \": \\\"\" + (err.toString()) + \"\\\"\"), vm);\n }\n /* istanbul ignore else */\n if (inBrowser && typeof console !== 'undefined') {\n console.error(err);\n } else {\n throw err\n }\n }\n}\n\n/* */\n/* globals MutationObserver */\n\n// can we use __proto__?\nvar hasProto = '__proto__' in {};\n\n// Browser environment sniffing\nvar inBrowser = typeof window !== 'undefined';\nvar UA = inBrowser && window.navigator.userAgent.toLowerCase();\nvar isIE = UA && /msie|trident/.test(UA);\nvar isIE9 = UA && UA.indexOf('msie 9.0') > 0;\nvar isEdge = UA && UA.indexOf('edge/') > 0;\nvar isAndroid = UA && UA.indexOf('android') > 0;\nvar isIOS = UA && /iphone|ipad|ipod|ios/.test(UA);\nvar isChrome = UA && /chrome\\/\\d+/.test(UA) && !isEdge;\n\n// Firefix has a \"watch\" function on Object.prototype...\nvar nativeWatch = ({}).watch;\n\nvar supportsPassive = false;\nif (inBrowser) {\n try {\n var opts = {};\n Object.defineProperty(opts, 'passive', ({\n get: function get () {\n /* istanbul ignore next */\n supportsPassive = true;\n }\n })); // https://github.com/facebook/flow/issues/285\n window.addEventListener('test-passive', null, opts);\n } catch (e) {}\n}\n\n// this needs to be lazy-evaled because vue may be required before\n// vue-server-renderer can set VUE_ENV\nvar _isServer;\nvar isServerRendering = function () {\n if (_isServer === undefined) {\n /* istanbul ignore if */\n if (!inBrowser && typeof global !== 'undefined') {\n // detect presence of vue-server-renderer and avoid\n // Webpack shimming the process\n _isServer = global['process'].env.VUE_ENV === 'server';\n } else {\n _isServer = false;\n }\n }\n return _isServer\n};\n\n// detect devtools\nvar devtools = inBrowser && window.__VUE_DEVTOOLS_GLOBAL_HOOK__;\n\n/* istanbul ignore next */\nfunction isNative (Ctor) {\n return typeof Ctor === 'function' && /native code/.test(Ctor.toString())\n}\n\nvar hasSymbol =\n typeof Symbol !== 'undefined' && isNative(Symbol) &&\n typeof Reflect !== 'undefined' && isNative(Reflect.ownKeys);\n\n/**\n * Defer a task to execute it asynchronously.\n */\nvar nextTick = (function () {\n var callbacks = [];\n var pending = false;\n var timerFunc;\n\n function nextTickHandler () {\n pending = false;\n var copies = callbacks.slice(0);\n callbacks.length = 0;\n for (var i = 0; i < copies.length; i++) {\n copies[i]();\n }\n }\n\n // the nextTick behavior leverages the microtask queue, which can be accessed\n // via either native Promise.then or MutationObserver.\n // MutationObserver has wider support, however it is seriously bugged in\n // UIWebView in iOS >= 9.3.3 when triggered in touch event handlers. It\n // completely stops working after triggering a few times... so, if native\n // Promise is available, we will use it:\n /* istanbul ignore if */\n if (typeof Promise !== 'undefined' && isNative(Promise)) {\n var p = Promise.resolve();\n var logError = function (err) { console.error(err); };\n timerFunc = function () {\n p.then(nextTickHandler).catch(logError);\n // in problematic UIWebViews, Promise.then doesn't completely break, but\n // it can get stuck in a weird state where callbacks are pushed into the\n // microtask queue but the queue isn't being flushed, until the browser\n // needs to do some other work, e.g. handle a timer. Therefore we can\n // \"force\" the microtask queue to be flushed by adding an empty timer.\n if (isIOS) { setTimeout(noop); }\n };\n } else if (typeof MutationObserver !== 'undefined' && (\n isNative(MutationObserver) ||\n // PhantomJS and iOS 7.x\n MutationObserver.toString() === '[object MutationObserverConstructor]'\n )) {\n // use MutationObserver where native Promise is not available,\n // e.g. PhantomJS IE11, iOS7, Android 4.4\n var counter = 1;\n var observer = new MutationObserver(nextTickHandler);\n var textNode = document.createTextNode(String(counter));\n observer.observe(textNode, {\n characterData: true\n });\n timerFunc = function () {\n counter = (counter + 1) % 2;\n textNode.data = String(counter);\n };\n } else {\n // fallback to setTimeout\n /* istanbul ignore next */\n timerFunc = function () {\n setTimeout(nextTickHandler, 0);\n };\n }\n\n return function queueNextTick (cb, ctx) {\n var _resolve;\n callbacks.push(function () {\n if (cb) {\n try {\n cb.call(ctx);\n } catch (e) {\n handleError(e, ctx, 'nextTick');\n }\n } else if (_resolve) {\n _resolve(ctx);\n }\n });\n if (!pending) {\n pending = true;\n timerFunc();\n }\n if (!cb && typeof Promise !== 'undefined') {\n return new Promise(function (resolve, reject) {\n _resolve = resolve;\n })\n }\n }\n})();\n\nvar _Set;\n/* istanbul ignore if */\nif (typeof Set !== 'undefined' && isNative(Set)) {\n // use native Set when available.\n _Set = Set;\n} else {\n // a non-standard Set polyfill that only works with primitive keys.\n _Set = (function () {\n function Set () {\n this.set = Object.create(null);\n }\n Set.prototype.has = function has (key) {\n return this.set[key] === true\n };\n Set.prototype.add = function add (key) {\n this.set[key] = true;\n };\n Set.prototype.clear = function clear () {\n this.set = Object.create(null);\n };\n\n return Set;\n }());\n}\n\n/* */\n\n\nvar uid = 0;\n\n/**\n * A dep is an observable that can have multiple\n * directives subscribing to it.\n */\nvar Dep = function Dep () {\n this.id = uid++;\n this.subs = [];\n};\n\nDep.prototype.addSub = function addSub (sub) {\n this.subs.push(sub);\n};\n\nDep.prototype.removeSub = function removeSub (sub) {\n remove(this.subs, sub);\n};\n\nDep.prototype.depend = function depend () {\n if (Dep.target) {\n Dep.target.addDep(this);\n }\n};\n\nDep.prototype.notify = function notify () {\n // stabilize the subscriber list first\n var subs = this.subs.slice();\n for (var i = 0, l = subs.length; i < l; i++) {\n subs[i].update();\n }\n};\n\n// the current target watcher being evaluated.\n// this is globally unique because there could be only one\n// watcher being evaluated at any time.\nDep.target = null;\nvar targetStack = [];\n\nfunction pushTarget (_target) {\n if (Dep.target) { targetStack.push(Dep.target); }\n Dep.target = _target;\n}\n\nfunction popTarget () {\n Dep.target = targetStack.pop();\n}\n\n/*\n * not type checking this file because flow doesn't play well with\n * dynamically accessing methods on Array prototype\n */\n\nvar arrayProto = Array.prototype;\nvar arrayMethods = Object.create(arrayProto);[\n 'push',\n 'pop',\n 'shift',\n 'unshift',\n 'splice',\n 'sort',\n 'reverse'\n]\n.forEach(function (method) {\n // cache original method\n var original = arrayProto[method];\n def(arrayMethods, method, function mutator () {\n var args = [], len = arguments.length;\n while ( len-- ) args[ len ] = arguments[ len ];\n\n var result = original.apply(this, args);\n var ob = this.__ob__;\n var inserted;\n switch (method) {\n case 'push':\n case 'unshift':\n inserted = args;\n break\n case 'splice':\n inserted = args.slice(2);\n break\n }\n if (inserted) { ob.observeArray(inserted); }\n // notify change\n ob.dep.notify();\n return result\n });\n});\n\n/* */\n\nvar arrayKeys = Object.getOwnPropertyNames(arrayMethods);\n\n/**\n * By default, when a reactive property is set, the new value is\n * also converted to become reactive. However when passing down props,\n * we don't want to force conversion because the value may be a nested value\n * under a frozen data structure. Converting it would defeat the optimization.\n */\nvar observerState = {\n shouldConvert: true\n};\n\n/**\n * Observer class that are attached to each observed\n * object. Once attached, the observer converts target\n * object's property keys into getter/setters that\n * collect dependencies and dispatches updates.\n */\nvar Observer = function Observer (value) {\n this.value = value;\n this.dep = new Dep();\n this.vmCount = 0;\n def(value, '__ob__', this);\n if (Array.isArray(value)) {\n var augment = hasProto\n ? protoAugment\n : copyAugment;\n augment(value, arrayMethods, arrayKeys);\n this.observeArray(value);\n } else {\n this.walk(value);\n }\n};\n\n/**\n * Walk through each property and convert them into\n * getter/setters. This method should only be called when\n * value type is Object.\n */\nObserver.prototype.walk = function walk (obj) {\n var keys = Object.keys(obj);\n for (var i = 0; i < keys.length; i++) {\n defineReactive$$1(obj, keys[i], obj[keys[i]]);\n }\n};\n\n/**\n * Observe a list of Array items.\n */\nObserver.prototype.observeArray = function observeArray (items) {\n for (var i = 0, l = items.length; i < l; i++) {\n observe(items[i]);\n }\n};\n\n// helpers\n\n/**\n * Augment an target Object or Array by intercepting\n * the prototype chain using __proto__\n */\nfunction protoAugment (target, src, keys) {\n /* eslint-disable no-proto */\n target.__proto__ = src;\n /* eslint-enable no-proto */\n}\n\n/**\n * Augment an target Object or Array by defining\n * hidden properties.\n */\n/* istanbul ignore next */\nfunction copyAugment (target, src, keys) {\n for (var i = 0, l = keys.length; i < l; i++) {\n var key = keys[i];\n def(target, key, src[key]);\n }\n}\n\n/**\n * Attempt to create an observer instance for a value,\n * returns the new observer if successfully observed,\n * or the existing observer if the value already has one.\n */\nfunction observe (value, asRootData) {\n if (!isObject(value)) {\n return\n }\n var ob;\n if (hasOwn(value, '__ob__') && value.__ob__ instanceof Observer) {\n ob = value.__ob__;\n } else if (\n observerState.shouldConvert &&\n !isServerRendering() &&\n (Array.isArray(value) || isPlainObject(value)) &&\n Object.isExtensible(value) &&\n !value._isVue\n ) {\n ob = new Observer(value);\n }\n if (asRootData && ob) {\n ob.vmCount++;\n }\n return ob\n}\n\n/**\n * Define a reactive property on an Object.\n */\nfunction defineReactive$$1 (\n obj,\n key,\n val,\n customSetter,\n shallow\n) {\n var dep = new Dep();\n\n var property = Object.getOwnPropertyDescriptor(obj, key);\n if (property && property.configurable === false) {\n return\n }\n\n // cater for pre-defined getter/setters\n var getter = property && property.get;\n var setter = property && property.set;\n\n var childOb = !shallow && observe(val);\n Object.defineProperty(obj, key, {\n enumerable: true,\n configurable: true,\n get: function reactiveGetter () {\n var value = getter ? getter.call(obj) : val;\n if (Dep.target) {\n dep.depend();\n if (childOb) {\n childOb.dep.depend();\n }\n if (Array.isArray(value)) {\n dependArray(value);\n }\n }\n return value\n },\n set: function reactiveSetter (newVal) {\n var value = getter ? getter.call(obj) : val;\n /* eslint-disable no-self-compare */\n if (newVal === value || (newVal !== newVal && value !== value)) {\n return\n }\n /* eslint-enable no-self-compare */\n if (process.env.NODE_ENV !== 'production' && customSetter) {\n customSetter();\n }\n if (setter) {\n setter.call(obj, newVal);\n } else {\n val = newVal;\n }\n childOb = !shallow && observe(newVal);\n dep.notify();\n }\n });\n}\n\n/**\n * Set a property on an object. Adds the new property and\n * triggers change notification if the property doesn't\n * already exist.\n */\nfunction set (target, key, val) {\n if (Array.isArray(target) && isValidArrayIndex(key)) {\n target.length = Math.max(target.length, key);\n target.splice(key, 1, val);\n return val\n }\n if (hasOwn(target, key)) {\n target[key] = val;\n return val\n }\n var ob = (target).__ob__;\n if (target._isVue || (ob && ob.vmCount)) {\n process.env.NODE_ENV !== 'production' && warn(\n 'Avoid adding reactive properties to a Vue instance or its root $data ' +\n 'at runtime - declare it upfront in the data option.'\n );\n return val\n }\n if (!ob) {\n target[key] = val;\n return val\n }\n defineReactive$$1(ob.value, key, val);\n ob.dep.notify();\n return val\n}\n\n/**\n * Delete a property and trigger change if necessary.\n */\nfunction del (target, key) {\n if (Array.isArray(target) && isValidArrayIndex(key)) {\n target.splice(key, 1);\n return\n }\n var ob = (target).__ob__;\n if (target._isVue || (ob && ob.vmCount)) {\n process.env.NODE_ENV !== 'production' && warn(\n 'Avoid deleting properties on a Vue instance or its root $data ' +\n '- just set it to null.'\n );\n return\n }\n if (!hasOwn(target, key)) {\n return\n }\n delete target[key];\n if (!ob) {\n return\n }\n ob.dep.notify();\n}\n\n/**\n * Collect dependencies on array elements when the array is touched, since\n * we cannot intercept array element access like property getters.\n */\nfunction dependArray (value) {\n for (var e = (void 0), i = 0, l = value.length; i < l; i++) {\n e = value[i];\n e && e.__ob__ && e.__ob__.dep.depend();\n if (Array.isArray(e)) {\n dependArray(e);\n }\n }\n}\n\n/* */\n\n/**\n * Option overwriting strategies are functions that handle\n * how to merge a parent option value and a child option\n * value into the final value.\n */\nvar strats = config.optionMergeStrategies;\n\n/**\n * Options with restrictions\n */\nif (process.env.NODE_ENV !== 'production') {\n strats.el = strats.propsData = function (parent, child, vm, key) {\n if (!vm) {\n warn(\n \"option \\\"\" + key + \"\\\" can only be used during instance \" +\n 'creation with the `new` keyword.'\n );\n }\n return defaultStrat(parent, child)\n };\n}\n\n/**\n * Helper that recursively merges two data objects together.\n */\nfunction mergeData (to, from) {\n if (!from) { return to }\n var key, toVal, fromVal;\n var keys = Object.keys(from);\n for (var i = 0; i < keys.length; i++) {\n key = keys[i];\n toVal = to[key];\n fromVal = from[key];\n if (!hasOwn(to, key)) {\n set(to, key, fromVal);\n } else if (isPlainObject(toVal) && isPlainObject(fromVal)) {\n mergeData(toVal, fromVal);\n }\n }\n return to\n}\n\n/**\n * Data\n */\nfunction mergeDataOrFn (\n parentVal,\n childVal,\n vm\n) {\n if (!vm) {\n // in a Vue.extend merge, both should be functions\n if (!childVal) {\n return parentVal\n }\n if (!parentVal) {\n return childVal\n }\n // when parentVal & childVal are both present,\n // we need to return a function that returns the\n // merged result of both functions... no need to\n // check if parentVal is a function here because\n // it has to be a function to pass previous merges.\n return function mergedDataFn () {\n return mergeData(\n typeof childVal === 'function' ? childVal.call(this) : childVal,\n typeof parentVal === 'function' ? parentVal.call(this) : parentVal\n )\n }\n } else if (parentVal || childVal) {\n return function mergedInstanceDataFn () {\n // instance merge\n var instanceData = typeof childVal === 'function'\n ? childVal.call(vm)\n : childVal;\n var defaultData = typeof parentVal === 'function'\n ? parentVal.call(vm)\n : undefined;\n if (instanceData) {\n return mergeData(instanceData, defaultData)\n } else {\n return defaultData\n }\n }\n }\n}\n\nstrats.data = function (\n parentVal,\n childVal,\n vm\n) {\n if (!vm) {\n if (childVal && typeof childVal !== 'function') {\n process.env.NODE_ENV !== 'production' && warn(\n 'The \"data\" option should be a function ' +\n 'that returns a per-instance value in component ' +\n 'definitions.',\n vm\n );\n\n return parentVal\n }\n return mergeDataOrFn.call(this, parentVal, childVal)\n }\n\n return mergeDataOrFn(parentVal, childVal, vm)\n};\n\n/**\n * Hooks and props are merged as arrays.\n */\nfunction mergeHook (\n parentVal,\n childVal\n) {\n return childVal\n ? parentVal\n ? parentVal.concat(childVal)\n : Array.isArray(childVal)\n ? childVal\n : [childVal]\n : parentVal\n}\n\nLIFECYCLE_HOOKS.forEach(function (hook) {\n strats[hook] = mergeHook;\n});\n\n/**\n * Assets\n *\n * When a vm is present (instance creation), we need to do\n * a three-way merge between constructor options, instance\n * options and parent options.\n */\nfunction mergeAssets (parentVal, childVal) {\n var res = Object.create(parentVal || null);\n return childVal\n ? extend(res, childVal)\n : res\n}\n\nASSET_TYPES.forEach(function (type) {\n strats[type + 's'] = mergeAssets;\n});\n\n/**\n * Watchers.\n *\n * Watchers hashes should not overwrite one\n * another, so we merge them as arrays.\n */\nstrats.watch = function (parentVal, childVal) {\n // work around Firefox's Object.prototype.watch...\n if (parentVal === nativeWatch) { parentVal = undefined; }\n if (childVal === nativeWatch) { childVal = undefined; }\n /* istanbul ignore if */\n if (!childVal) { return Object.create(parentVal || null) }\n if (!parentVal) { return childVal }\n var ret = {};\n extend(ret, parentVal);\n for (var key in childVal) {\n var parent = ret[key];\n var child = childVal[key];\n if (parent && !Array.isArray(parent)) {\n parent = [parent];\n }\n ret[key] = parent\n ? parent.concat(child)\n : Array.isArray(child) ? child : [child];\n }\n return ret\n};\n\n/**\n * Other object hashes.\n */\nstrats.props =\nstrats.methods =\nstrats.inject =\nstrats.computed = function (parentVal, childVal) {\n if (!parentVal) { return childVal }\n var ret = Object.create(null);\n extend(ret, parentVal);\n if (childVal) { extend(ret, childVal); }\n return ret\n};\nstrats.provide = mergeDataOrFn;\n\n/**\n * Default strategy.\n */\nvar defaultStrat = function (parentVal, childVal) {\n return childVal === undefined\n ? parentVal\n : childVal\n};\n\n/**\n * Validate component names\n */\nfunction checkComponents (options) {\n for (var key in options.components) {\n var lower = key.toLowerCase();\n if (isBuiltInTag(lower) || config.isReservedTag(lower)) {\n warn(\n 'Do not use built-in or reserved HTML elements as component ' +\n 'id: ' + key\n );\n }\n }\n}\n\n/**\n * Ensure all props option syntax are normalized into the\n * Object-based format.\n */\nfunction normalizeProps (options) {\n var props = options.props;\n if (!props) { return }\n var res = {};\n var i, val, name;\n if (Array.isArray(props)) {\n i = props.length;\n while (i--) {\n val = props[i];\n if (typeof val === 'string') {\n name = camelize(val);\n res[name] = { type: null };\n } else if (process.env.NODE_ENV !== 'production') {\n warn('props must be strings when using array syntax.');\n }\n }\n } else if (isPlainObject(props)) {\n for (var key in props) {\n val = props[key];\n name = camelize(key);\n res[name] = isPlainObject(val)\n ? val\n : { type: val };\n }\n }\n options.props = res;\n}\n\n/**\n * Normalize all injections into Object-based format\n */\nfunction normalizeInject (options) {\n var inject = options.inject;\n if (Array.isArray(inject)) {\n var normalized = options.inject = {};\n for (var i = 0; i < inject.length; i++) {\n normalized[inject[i]] = inject[i];\n }\n }\n}\n\n/**\n * Normalize raw function directives into object format.\n */\nfunction normalizeDirectives (options) {\n var dirs = options.directives;\n if (dirs) {\n for (var key in dirs) {\n var def = dirs[key];\n if (typeof def === 'function') {\n dirs[key] = { bind: def, update: def };\n }\n }\n }\n}\n\n/**\n * Merge two option objects into a new one.\n * Core utility used in both instantiation and inheritance.\n */\nfunction mergeOptions (\n parent,\n child,\n vm\n) {\n if (process.env.NODE_ENV !== 'production') {\n checkComponents(child);\n }\n\n if (typeof child === 'function') {\n child = child.options;\n }\n\n normalizeProps(child);\n normalizeInject(child);\n normalizeDirectives(child);\n var extendsFrom = child.extends;\n if (extendsFrom) {\n parent = mergeOptions(parent, extendsFrom, vm);\n }\n if (child.mixins) {\n for (var i = 0, l = child.mixins.length; i < l; i++) {\n parent = mergeOptions(parent, child.mixins[i], vm);\n }\n }\n var options = {};\n var key;\n for (key in parent) {\n mergeField(key);\n }\n for (key in child) {\n if (!hasOwn(parent, key)) {\n mergeField(key);\n }\n }\n function mergeField (key) {\n var strat = strats[key] || defaultStrat;\n options[key] = strat(parent[key], child[key], vm, key);\n }\n return options\n}\n\n/**\n * Resolve an asset.\n * This function is used because child instances need access\n * to assets defined in its ancestor chain.\n */\nfunction resolveAsset (\n options,\n type,\n id,\n warnMissing\n) {\n /* istanbul ignore if */\n if (typeof id !== 'string') {\n return\n }\n var assets = options[type];\n // check local registration variations first\n if (hasOwn(assets, id)) { return assets[id] }\n var camelizedId = camelize(id);\n if (hasOwn(assets, camelizedId)) { return assets[camelizedId] }\n var PascalCaseId = capitalize(camelizedId);\n if (hasOwn(assets, PascalCaseId)) { return assets[PascalCaseId] }\n // fallback to prototype chain\n var res = assets[id] || assets[camelizedId] || assets[PascalCaseId];\n if (process.env.NODE_ENV !== 'production' && warnMissing && !res) {\n warn(\n 'Failed to resolve ' + type.slice(0, -1) + ': ' + id,\n options\n );\n }\n return res\n}\n\n/* */\n\nfunction validateProp (\n key,\n propOptions,\n propsData,\n vm\n) {\n var prop = propOptions[key];\n var absent = !hasOwn(propsData, key);\n var value = propsData[key];\n // handle boolean props\n if (isType(Boolean, prop.type)) {\n if (absent && !hasOwn(prop, 'default')) {\n value = false;\n } else if (!isType(String, prop.type) && (value === '' || value === hyphenate(key))) {\n value = true;\n }\n }\n // check default value\n if (value === undefined) {\n value = getPropDefaultValue(vm, prop, key);\n // since the default value is a fresh copy,\n // make sure to observe it.\n var prevShouldConvert = observerState.shouldConvert;\n observerState.shouldConvert = true;\n observe(value);\n observerState.shouldConvert = prevShouldConvert;\n }\n if (process.env.NODE_ENV !== 'production') {\n assertProp(prop, key, value, vm, absent);\n }\n return value\n}\n\n/**\n * Get the default value of a prop.\n */\nfunction getPropDefaultValue (vm, prop, key) {\n // no default, return undefined\n if (!hasOwn(prop, 'default')) {\n return undefined\n }\n var def = prop.default;\n // warn against non-factory defaults for Object & Array\n if (process.env.NODE_ENV !== 'production' && isObject(def)) {\n warn(\n 'Invalid default value for prop \"' + key + '\": ' +\n 'Props with type Object/Array must use a factory function ' +\n 'to return the default value.',\n vm\n );\n }\n // the raw prop value was also undefined from previous render,\n // return previous default value to avoid unnecessary watcher trigger\n if (vm && vm.$options.propsData &&\n vm.$options.propsData[key] === undefined &&\n vm._props[key] !== undefined\n ) {\n return vm._props[key]\n }\n // call factory function for non-Function types\n // a value is Function if its prototype is function even across different execution context\n return typeof def === 'function' && getType(prop.type) !== 'Function'\n ? def.call(vm)\n : def\n}\n\n/**\n * Assert whether a prop is valid.\n */\nfunction assertProp (\n prop,\n name,\n value,\n vm,\n absent\n) {\n if (prop.required && absent) {\n warn(\n 'Missing required prop: \"' + name + '\"',\n vm\n );\n return\n }\n if (value == null && !prop.required) {\n return\n }\n var type = prop.type;\n var valid = !type || type === true;\n var expectedTypes = [];\n if (type) {\n if (!Array.isArray(type)) {\n type = [type];\n }\n for (var i = 0; i < type.length && !valid; i++) {\n var assertedType = assertType(value, type[i]);\n expectedTypes.push(assertedType.expectedType || '');\n valid = assertedType.valid;\n }\n }\n if (!valid) {\n warn(\n 'Invalid prop: type check failed for prop \"' + name + '\".' +\n ' Expected ' + expectedTypes.map(capitalize).join(', ') +\n ', got ' + Object.prototype.toString.call(value).slice(8, -1) + '.',\n vm\n );\n return\n }\n var validator = prop.validator;\n if (validator) {\n if (!validator(value)) {\n warn(\n 'Invalid prop: custom validator check failed for prop \"' + name + '\".',\n vm\n );\n }\n }\n}\n\nvar simpleCheckRE = /^(String|Number|Boolean|Function|Symbol)$/;\n\nfunction assertType (value, type) {\n var valid;\n var expectedType = getType(type);\n if (simpleCheckRE.test(expectedType)) {\n valid = typeof value === expectedType.toLowerCase();\n } else if (expectedType === 'Object') {\n valid = isPlainObject(value);\n } else if (expectedType === 'Array') {\n valid = Array.isArray(value);\n } else {\n valid = value instanceof type;\n }\n return {\n valid: valid,\n expectedType: expectedType\n }\n}\n\n/**\n * Use function string name to check built-in types,\n * because a simple equality check will fail when running\n * across different vms / iframes.\n */\nfunction getType (fn) {\n var match = fn && fn.toString().match(/^\\s*function (\\w+)/);\n return match ? match[1] : ''\n}\n\nfunction isType (type, fn) {\n if (!Array.isArray(fn)) {\n return getType(fn) === getType(type)\n }\n for (var i = 0, len = fn.length; i < len; i++) {\n if (getType(fn[i]) === getType(type)) {\n return true\n }\n }\n /* istanbul ignore next */\n return false\n}\n\n/* */\n\nvar mark;\nvar measure;\n\nif (process.env.NODE_ENV !== 'production') {\n var perf = inBrowser && window.performance;\n /* istanbul ignore if */\n if (\n perf &&\n perf.mark &&\n perf.measure &&\n perf.clearMarks &&\n perf.clearMeasures\n ) {\n mark = function (tag) { return perf.mark(tag); };\n measure = function (name, startTag, endTag) {\n perf.measure(name, startTag, endTag);\n perf.clearMarks(startTag);\n perf.clearMarks(endTag);\n perf.clearMeasures(name);\n };\n }\n}\n\n/* not type checking this file because flow doesn't play well with Proxy */\n\nvar initProxy;\n\nif (process.env.NODE_ENV !== 'production') {\n var allowedGlobals = makeMap(\n 'Infinity,undefined,NaN,isFinite,isNaN,' +\n 'parseFloat,parseInt,decodeURI,decodeURIComponent,encodeURI,encodeURIComponent,' +\n 'Math,Number,Date,Array,Object,Boolean,String,RegExp,Map,Set,JSON,Intl,' +\n 'require' // for Webpack/Browserify\n );\n\n var warnNonPresent = function (target, key) {\n warn(\n \"Property or method \\\"\" + key + \"\\\" is not defined on the instance but \" +\n \"referenced during render. Make sure to declare reactive data \" +\n \"properties in the data option.\",\n target\n );\n };\n\n var hasProxy =\n typeof Proxy !== 'undefined' &&\n Proxy.toString().match(/native code/);\n\n if (hasProxy) {\n var isBuiltInModifier = makeMap('stop,prevent,self,ctrl,shift,alt,meta');\n config.keyCodes = new Proxy(config.keyCodes, {\n set: function set (target, key, value) {\n if (isBuiltInModifier(key)) {\n warn((\"Avoid overwriting built-in modifier in config.keyCodes: .\" + key));\n return false\n } else {\n target[key] = value;\n return true\n }\n }\n });\n }\n\n var hasHandler = {\n has: function has (target, key) {\n var has = key in target;\n var isAllowed = allowedGlobals(key) || key.charAt(0) === '_';\n if (!has && !isAllowed) {\n warnNonPresent(target, key);\n }\n return has || !isAllowed\n }\n };\n\n var getHandler = {\n get: function get (target, key) {\n if (typeof key === 'string' && !(key in target)) {\n warnNonPresent(target, key);\n }\n return target[key]\n }\n };\n\n initProxy = function initProxy (vm) {\n if (hasProxy) {\n // determine which proxy handler to use\n var options = vm.$options;\n var handlers = options.render && options.render._withStripped\n ? getHandler\n : hasHandler;\n vm._renderProxy = new Proxy(vm, handlers);\n } else {\n vm._renderProxy = vm;\n }\n };\n}\n\n/* */\n\nvar VNode = function VNode (\n tag,\n data,\n children,\n text,\n elm,\n context,\n componentOptions,\n asyncFactory\n) {\n this.tag = tag;\n this.data = data;\n this.children = children;\n this.text = text;\n this.elm = elm;\n this.ns = undefined;\n this.context = context;\n this.functionalContext = undefined;\n this.key = data && data.key;\n this.componentOptions = componentOptions;\n this.componentInstance = undefined;\n this.parent = undefined;\n this.raw = false;\n this.isStatic = false;\n this.isRootInsert = true;\n this.isComment = false;\n this.isCloned = false;\n this.isOnce = false;\n this.asyncFactory = asyncFactory;\n this.asyncMeta = undefined;\n this.isAsyncPlaceholder = false;\n};\n\nvar prototypeAccessors = { child: {} };\n\n// DEPRECATED: alias for componentInstance for backwards compat.\n/* istanbul ignore next */\nprototypeAccessors.child.get = function () {\n return this.componentInstance\n};\n\nObject.defineProperties( VNode.prototype, prototypeAccessors );\n\nvar createEmptyVNode = function (text) {\n if ( text === void 0 ) text = '';\n\n var node = new VNode();\n node.text = text;\n node.isComment = true;\n return node\n};\n\nfunction createTextVNode (val) {\n return new VNode(undefined, undefined, undefined, String(val))\n}\n\n// optimized shallow clone\n// used for static nodes and slot nodes because they may be reused across\n// multiple renders, cloning them avoids errors when DOM manipulations rely\n// on their elm reference.\nfunction cloneVNode (vnode) {\n var cloned = new VNode(\n vnode.tag,\n vnode.data,\n vnode.children,\n vnode.text,\n vnode.elm,\n vnode.context,\n vnode.componentOptions,\n vnode.asyncFactory\n );\n cloned.ns = vnode.ns;\n cloned.isStatic = vnode.isStatic;\n cloned.key = vnode.key;\n cloned.isComment = vnode.isComment;\n cloned.isCloned = true;\n return cloned\n}\n\nfunction cloneVNodes (vnodes) {\n var len = vnodes.length;\n var res = new Array(len);\n for (var i = 0; i < len; i++) {\n res[i] = cloneVNode(vnodes[i]);\n }\n return res\n}\n\n/* */\n\nvar normalizeEvent = cached(function (name) {\n var passive = name.charAt(0) === '&';\n name = passive ? name.slice(1) : name;\n var once$$1 = name.charAt(0) === '~'; // Prefixed last, checked first\n name = once$$1 ? name.slice(1) : name;\n var capture = name.charAt(0) === '!';\n name = capture ? name.slice(1) : name;\n return {\n name: name,\n once: once$$1,\n capture: capture,\n passive: passive\n }\n});\n\nfunction createFnInvoker (fns) {\n function invoker () {\n var arguments$1 = arguments;\n\n var fns = invoker.fns;\n if (Array.isArray(fns)) {\n var cloned = fns.slice();\n for (var i = 0; i < cloned.length; i++) {\n cloned[i].apply(null, arguments$1);\n }\n } else {\n // return handler return value for single handlers\n return fns.apply(null, arguments)\n }\n }\n invoker.fns = fns;\n return invoker\n}\n\nfunction updateListeners (\n on,\n oldOn,\n add,\n remove$$1,\n vm\n) {\n var name, cur, old, event;\n for (name in on) {\n cur = on[name];\n old = oldOn[name];\n event = normalizeEvent(name);\n if (isUndef(cur)) {\n process.env.NODE_ENV !== 'production' && warn(\n \"Invalid handler for event \\\"\" + (event.name) + \"\\\": got \" + String(cur),\n vm\n );\n } else if (isUndef(old)) {\n if (isUndef(cur.fns)) {\n cur = on[name] = createFnInvoker(cur);\n }\n add(event.name, cur, event.once, event.capture, event.passive);\n } else if (cur !== old) {\n old.fns = cur;\n on[name] = old;\n }\n }\n for (name in oldOn) {\n if (isUndef(on[name])) {\n event = normalizeEvent(name);\n remove$$1(event.name, oldOn[name], event.capture);\n }\n }\n}\n\n/* */\n\nfunction mergeVNodeHook (def, hookKey, hook) {\n var invoker;\n var oldHook = def[hookKey];\n\n function wrappedHook () {\n hook.apply(this, arguments);\n // important: remove merged hook to ensure it's called only once\n // and prevent memory leak\n remove(invoker.fns, wrappedHook);\n }\n\n if (isUndef(oldHook)) {\n // no existing hook\n invoker = createFnInvoker([wrappedHook]);\n } else {\n /* istanbul ignore if */\n if (isDef(oldHook.fns) && isTrue(oldHook.merged)) {\n // already a merged invoker\n invoker = oldHook;\n invoker.fns.push(wrappedHook);\n } else {\n // existing plain hook\n invoker = createFnInvoker([oldHook, wrappedHook]);\n }\n }\n\n invoker.merged = true;\n def[hookKey] = invoker;\n}\n\n/* */\n\nfunction extractPropsFromVNodeData (\n data,\n Ctor,\n tag\n) {\n // we are only extracting raw values here.\n // validation and default values are handled in the child\n // component itself.\n var propOptions = Ctor.options.props;\n if (isUndef(propOptions)) {\n return\n }\n var res = {};\n var attrs = data.attrs;\n var props = data.props;\n if (isDef(attrs) || isDef(props)) {\n for (var key in propOptions) {\n var altKey = hyphenate(key);\n if (process.env.NODE_ENV !== 'production') {\n var keyInLowerCase = key.toLowerCase();\n if (\n key !== keyInLowerCase &&\n attrs && hasOwn(attrs, keyInLowerCase)\n ) {\n tip(\n \"Prop \\\"\" + keyInLowerCase + \"\\\" is passed to component \" +\n (formatComponentName(tag || Ctor)) + \", but the declared prop name is\" +\n \" \\\"\" + key + \"\\\". \" +\n \"Note that HTML attributes are case-insensitive and camelCased \" +\n \"props need to use their kebab-case equivalents when using in-DOM \" +\n \"templates. You should probably use \\\"\" + altKey + \"\\\" instead of \\\"\" + key + \"\\\".\"\n );\n }\n }\n checkProp(res, props, key, altKey, true) ||\n checkProp(res, attrs, key, altKey, false);\n }\n }\n return res\n}\n\nfunction checkProp (\n res,\n hash,\n key,\n altKey,\n preserve\n) {\n if (isDef(hash)) {\n if (hasOwn(hash, key)) {\n res[key] = hash[key];\n if (!preserve) {\n delete hash[key];\n }\n return true\n } else if (hasOwn(hash, altKey)) {\n res[key] = hash[altKey];\n if (!preserve) {\n delete hash[altKey];\n }\n return true\n }\n }\n return false\n}\n\n/* */\n\n// The template compiler attempts to minimize the need for normalization by\n// statically analyzing the template at compile time.\n//\n// For plain HTML markup, normalization can be completely skipped because the\n// generated render function is guaranteed to return Array. There are\n// two cases where extra normalization is needed:\n\n// 1. When the children contains components - because a functional component\n// may return an Array instead of a single root. In this case, just a simple\n// normalization is needed - if any child is an Array, we flatten the whole\n// thing with Array.prototype.concat. It is guaranteed to be only 1-level deep\n// because functional components already normalize their own children.\nfunction simpleNormalizeChildren (children) {\n for (var i = 0; i < children.length; i++) {\n if (Array.isArray(children[i])) {\n return Array.prototype.concat.apply([], children)\n }\n }\n return children\n}\n\n// 2. When the children contains constructs that always generated nested Arrays,\n// e.g.