diff --git a/dist/react-grid-layout.min.js b/dist/react-grid-layout.min.js index f8f5d75a5..518b7e3b1 100644 --- a/dist/react-grid-layout.min.js +++ b/dist/react-grid-layout.min.js @@ -1,4 +1,4 @@ -!function(t,e){"object"==typeof exports&&"object"==typeof module?module.exports=e(require("react"),require("react-dom")):"function"==typeof define&&define.amd?define(["react","react-dom"],e):"object"==typeof exports?exports.ReactGridLayout=e(require("react"),require("react-dom")):t.ReactGridLayout=e(t.React,t.ReactDOM)}(window,(function(t,e){return function(t){var e={};function n(r){if(e[r])return e[r].exports;var o=e[r]={i:r,l:!1,exports:{}};return t[r].call(o.exports,o,o.exports,n),o.l=!0,o.exports}return n.m=t,n.c=e,n.d=function(t,e,r){n.o(t,e)||Object.defineProperty(t,e,{enumerable:!0,get:r})},n.r=function(t){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(t,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(t,"__esModule",{value:!0})},n.t=function(t,e){if(1&e&&(t=n(t)),8&e)return t;if(4&e&&"object"==typeof t&&t&&t.__esModule)return t;var r=Object.create(null);if(n.r(r),Object.defineProperty(r,"default",{enumerable:!0,value:t}),2&e&&"string"!=typeof t)for(var o in t)n.d(r,o,function(e){return t[e]}.bind(null,o));return r},n.n=function(t){var e=t&&t.__esModule?function(){return t.default}:function(){return t};return n.d(e,"a",e),e},n.o=function(t,e){return Object.prototype.hasOwnProperty.call(t,e)},n.p="",n(n.s=11)}([function(t,e,n){t.exports=n(15)()},function(t,e,n){"use strict";n.r(e),n.d(e,"bottom",(function(){return c})),n.d(e,"cloneLayout",(function(){return l})),n.d(e,"cloneLayoutItem",(function(){return p})),n.d(e,"childrenEqual",(function(){return f})),n.d(e,"fastRGLPropsEqual",(function(){return h})),n.d(e,"fastPositionEqual",(function(){return d})),n.d(e,"collides",(function(){return y})),n.d(e,"compact",(function(){return g})),n.d(e,"compactItem",(function(){return v})),n.d(e,"correctBounds",(function(){return w})),n.d(e,"getLayoutItem",(function(){return O})),n.d(e,"getFirstCollision",(function(){return S})),n.d(e,"getAllCollisions",(function(){return j})),n.d(e,"getStatics",(function(){return x})),n.d(e,"moveElement",(function(){return D})),n.d(e,"moveElementAwayFromCollision",(function(){return P})),n.d(e,"perc",(function(){return _})),n.d(e,"setTransform",(function(){return R})),n.d(e,"setTopLeft",(function(){return z})),n.d(e,"sortLayoutItems",(function(){return k})),n.d(e,"sortLayoutItemsByRowCol",(function(){return C})),n.d(e,"sortLayoutItemsByColRow",(function(){return E})),n.d(e,"synchronizeLayoutWithChildren",(function(){return T})),n.d(e,"validateLayout",(function(){return M})),n.d(e,"compactType",(function(){return L})),n.d(e,"autoBindHandlers",(function(){return N})),n.d(e,"noop",(function(){return W}));var r=n(3),o=n.n(r),a=n(2),i=n.n(a);function s(t,e){var n=Object.keys(t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(t);e&&(r=r.filter((function(e){return Object.getOwnPropertyDescriptor(t,e).enumerable}))),n.push.apply(n,r)}return n}function u(t,e,n){return e in t?Object.defineProperty(t,e,{value:n,enumerable:!0,configurable:!0,writable:!0}):t[e]=n,t}function c(t){for(var e,n=0,r=0,o=t.length;rn&&(n=e);return n}function l(t){for(var e=Array(t.length),n=0,r=t.length;n=e.x+e.w)&&(!(t.y+t.h<=e.y)&&!(t.y>=e.y+e.h))))}function g(t,e,n){for(var r=x(t),o=k(t,e),a=Array(t.length),i=0,s=o.length;ie.y+e.h)break;y(e,i)&&m(t,i,n+e[o],r)}}e[r]=n}function v(t,e,n,r,o){var a,i="horizontal"===n;if("vertical"===n)for(e.y=Math.min(c(t),e.y);e.y>0&&!S(t,e);)e.y--;else if(i)for(e.y=Math.min(c(t),e.y);e.x>0&&!S(t,e);)e.x--;for(;a=S(t,e);)i?m(o,e,a.x+a.w,"x"):m(o,e,a.y+a.h,"y"),i&&e.x+e.w>r&&(e.x=r-e.w,e.y++);return e}function w(t,e){for(var n=x(t),r=0,o=t.length;re.cols&&(a.x=e.cols-a.w),a.x<0&&(a.x=0,a.w=e.cols),a.static)for(;S(n,a);)a.y++;else n.push(a)}return t}function O(t,e){for(var n=0,r=t.length;n=r:"horizontal"===i&&"number"==typeof n&&u>=n)&&(l=l.reverse());var p=j(l,e);if(a&&p.length)return H("Collision prevented on ".concat(e.i,", reverting.")),e.x=u,e.y=c,e.moved=!1,t;for(var f=0,h=p.length;fe.y||t.y===e.y&&t.x>e.x?1:t.y===e.y&&t.x===e.x?0:-1}))}function E(t){return t.slice(0).sort((function(t,e){return t.x>e.x||t.x===e.x&&t.y>e.y?1:-1}))}function T(t,e,n,r){t=t||[];var o=[];return i.a.Children.forEach(e,(function(e,n){var r=O(t,String(e.key));if(r)o[n]=p(r);else{0;var a=e.props["data-grid"]||e.props._grid;o[n]=p(a?function(t){for(var e=1;e1&&void 0!==arguments[1]?arguments[1]:"Layout",n=["x","y","w","h"];if(!Array.isArray(t))throw new Error(e+" must be an array!");for(var r=0,o=t.length;rs))return!1;var c=a.get(t);if(c&&a.get(e))return c==e;var l=-1,p=!0,f=2&n?new at:void 0;for(a.set(t,e),a.set(e,t);++l-1},rt.prototype.set=function(t,e){var n=this.__data__,r=ut(n,t);return r<0?(++this.size,n.push([t,e])):n[r][1]=e,this},ot.prototype.clear=function(){this.size=0,this.__data__={hash:new nt,map:new(U||rt),string:new nt}},ot.prototype.delete=function(t){var e=gt(this,t).delete(t);return this.size-=e?1:0,e},ot.prototype.get=function(t){return gt(this,t).get(t)},ot.prototype.has=function(t){return gt(this,t).has(t)},ot.prototype.set=function(t,e){var n=gt(this,t),r=n.size;return n.set(t,e),this.size+=n.size==r?0:1,this},at.prototype.add=at.prototype.push=function(t){return this.__data__.set(t,"__lodash_hash_undefined__"),this},at.prototype.has=function(t){return this.__data__.has(t)},it.prototype.clear=function(){this.__data__=new rt,this.size=0},it.prototype.delete=function(t){var e=this.__data__,n=e.delete(t);return this.size=e.size,n},it.prototype.get=function(t){return this.__data__.get(t)},it.prototype.has=function(t){return this.__data__.has(t)},it.prototype.set=function(t,e){var n=this.__data__;if(n instanceof rt){var r=n.__data__;if(!U||r.length<199)return r.push([t,e]),this.size=++n.size,this;n=this.__data__=new ot(r)}return n.set(t,e),this.size=n.size,this};var mt=I?function(t){return null==t?[]:(t=Object(t),function(t,e){for(var n=-1,r=null==t?0:t.length,o=0,a=[];++n-1&&t%1==0&&t-1&&t%1==0&&t<=9007199254740991}function Rt(t){var e=typeof t;return null!=t&&("object"==e||"function"==e)}function zt(t){return null!=t&&"object"==typeof t}var kt=m?function(t){return function(e){return t(e)}}(m):function(t){return zt(t)&&_t(t.length)&&!!c[ct(t)]};function Ct(t){return null!=(e=t)&&_t(e.length)&&!Pt(e)?st(t):ht(t);var e}n.exports=function(t,e){return pt(t,e)}}).call(this,n(12),n(13)(t))},function(t,e,n){"use strict";n.r(e),n.d(e,"getBreakpointFromWidth",(function(){return o})),n.d(e,"getColsFromBreakpoint",(function(){return a})),n.d(e,"findOrGenerateResponsiveLayout",(function(){return i})),n.d(e,"sortBreakpoints",(function(){return s}));var r=n(1);function o(t,e){for(var n=s(t),r=n[0],o=1,a=n.length;ot[i]&&(r=i)}return r}function a(t,e){if(!e[t])throw new Error("ResponsiveReactGridLayout: `cols` entry for breakpoint "+t+" is missing!");return e[t]}function i(t,e,n,o,a,i){if(t[n])return Object(r.cloneLayout)(t[n]);for(var u=t[o],c=s(e),l=c.slice(c.indexOf(n)),p=0,f=l.length;pn&&(n=e);return n}function p(t){for(var e=Array(t.length),n=0,r=t.length;n=e.x+e.w)&&(!(t.y+t.h<=e.y)&&!(t.y>=e.y+e.h))))}function b(t,e,n){for(var r=D(t),o=C(t,e),a=Array(t.length),i=0,s=o.length;ie.y+e.h)break;g(e,i)&&v(t,i,n+e[o],r)}}e[r]=n}function w(t,e,n,r,o){var a,i="horizontal"===n;if("vertical"===n)for(e.y=Math.min(l(t),e.y);e.y>0&&!j(t,e);)e.y--;else if(i)for(e.y=Math.min(l(t),e.y);e.x>0&&!j(t,e);)e.x--;for(;a=j(t,e);)i?v(o,e,a.x+a.w,"x"):v(o,e,a.y+a.h,"y"),i&&e.x+e.w>r&&(e.x=r-e.w,e.y++);return e}function O(t,e){for(var n=D(t),r=0,o=t.length;re.cols&&(a.x=e.cols-a.w),a.x<0&&(a.x=0,a.w=e.cols),a.static)for(;j(n,a);)a.y++;else n.push(a)}return t}function S(t,e){for(var n=0,r=t.length;n=r:"horizontal"===i&&"number"==typeof n&&u>=n)&&(l=l.reverse());var p=x(l,e);if(a&&p.length)return W("Collision prevented on ".concat(e.i,", reverting.")),e.x=u,e.y=c,e.moved=!1,t;for(var f=0,d=p.length;fe.y||t.y===e.y&&t.x>e.x?1:t.y===e.y&&t.x===e.x?0:-1}))}function T(t){return t.slice(0).sort((function(t,e){return t.x>e.x||t.x===e.x&&t.y>e.y?1:-1}))}function M(t,e,n,r){t=t||[];var o=[];return i.a.Children.forEach(e,(function(e,n){var r=S(t,String(e.key));if(r)o[n]=f(r);else{0;var a=e.props["data-grid"]||e.props._grid;o[n]=f(a?u(u({},a),{},{i:e.key}):{w:1,h:1,x:0,y:l(o),i:String(e.key)})}})),b(O(o,{cols:n}),r,n)}function L(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:"Layout",n=["x","y","w","h"];if(!Array.isArray(t))throw new Error(e+" must be an array!");for(var r=0,o=t.length;rs))return!1;var c=a.get(t);if(c&&a.get(e))return c==e;var l=-1,p=!0,f=2&n?new at:void 0;for(a.set(t,e),a.set(e,t);++l-1},rt.prototype.set=function(t,e){var n=this.__data__,r=ut(n,t);return r<0?(++this.size,n.push([t,e])):n[r][1]=e,this},ot.prototype.clear=function(){this.size=0,this.__data__={hash:new nt,map:new(Y||rt),string:new nt}},ot.prototype.delete=function(t){var e=gt(this,t).delete(t);return this.size-=e?1:0,e},ot.prototype.get=function(t){return gt(this,t).get(t)},ot.prototype.has=function(t){return gt(this,t).has(t)},ot.prototype.set=function(t,e){var n=gt(this,t),r=n.size;return n.set(t,e),this.size+=n.size==r?0:1,this},at.prototype.add=at.prototype.push=function(t){return this.__data__.set(t,"__lodash_hash_undefined__"),this},at.prototype.has=function(t){return this.__data__.has(t)},it.prototype.clear=function(){this.__data__=new rt,this.size=0},it.prototype.delete=function(t){var e=this.__data__,n=e.delete(t);return this.size=e.size,n},it.prototype.get=function(t){return this.__data__.get(t)},it.prototype.has=function(t){return this.__data__.has(t)},it.prototype.set=function(t,e){var n=this.__data__;if(n instanceof rt){var r=n.__data__;if(!Y||r.length<199)return r.push([t,e]),this.size=++n.size,this;n=this.__data__=new ot(r)}return n.set(t,e),this.size=n.size,this};var mt=I?function(t){return null==t?[]:(t=Object(t),function(t,e){for(var n=-1,r=null==t?0:t.length,o=0,a=[];++n-1&&t%1==0&&t-1&&t%1==0&&t<=9007199254740991}function _t(t){var e=typeof t;return null!=t&&("object"==e||"function"==e)}function zt(t){return null!=t&&"object"==typeof t}var kt=m?function(t){return function(e){return t(e)}}(m):function(t){return zt(t)&&Rt(t.length)&&!!c[ct(t)]};function Ct(t){return null!=(e=t)&&Rt(e.length)&&!Pt(e)?st(t):dt(t);var e}n.exports=function(t,e){return pt(t,e)}}).call(this,n(12),n(13)(t))},function(t,e,n){"use strict";n.r(e),n.d(e,"getBreakpointFromWidth",(function(){return o})),n.d(e,"getColsFromBreakpoint",(function(){return a})),n.d(e,"findOrGenerateResponsiveLayout",(function(){return i})),n.d(e,"sortBreakpoints",(function(){return s}));var r=n(1);function o(t,e){for(var n=s(t),r=n[0],o=1,a=n.length;ot[i]&&(r=i)}return r}function a(t,e){if(!e[t])throw new Error("ResponsiveReactGridLayout: `cols` entry for breakpoint "+t+" is missing!");return e[t]}function i(t,e,n,o,a,i){if(t[n])return Object(r.cloneLayout)(t[n]);for(var u=t[o],c=s(e),l=c.slice(c.indexOf(n)),p=0,f=l.length;p0&&void 0!==arguments[0]?arguments[0]:"transform";if("undefined"==typeof window||void 0===window.document)return"";var e=window.document.documentElement.style;if(t in e)return"";for(var n=0;n0&&void 0!==arguments[0]?arguments[0]:{})}function M(t){return"both"===t.props.axis||"x"===t.props.axis}function L(t){return"both"===t.props.axis||"y"===t.props.axis}function N(t,e,n){var r="number"==typeof e?function(t,e){return t.targetTouches&&p(t.targetTouches,(function(t){return e===t.identifier}))||t.changedTouches&&p(t.changedTouches,(function(t){return e===t.identifier}))}(t,e):null;if("number"==typeof e&&!r)return null;var o=A(n);return function(t,e,n){var r=e===e.ownerDocument.body?{left:0,top:0}:e.getBoundingClientRect();return{x:(t.clientX+e.scrollLeft-r.left)/n,y:(t.clientY+e.scrollTop-r.top)/n}}(r||t,n.props.offsetParent||o.offsetParent||o.ownerDocument.body,n.props.scale)}function H(t,e,n){var r=t.state,o=!h(r.lastX),a=A(t);return o?{node:a,deltaX:0,deltaY:0,lastX:e,lastY:n,x:e,y:n}:{node:a,deltaX:e-r.lastX,deltaY:n-r.lastY,lastX:r.lastX,lastY:r.lastY,x:e,y:n}}function W(t,e){var n=t.props.scale;return{node:e.node,x:t.state.x+e.deltaX/n,y:t.state.y+e.deltaY/n,deltaX:e.deltaX/n,deltaY:e.deltaY/n,lastX:t.state.x,lastY:t.state.y}}function A(t){var e=u.a.findDOMNode(t);if(!e)throw new Error(": Unmounted during event!");return e}function I(t){return(I="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t})(t)}function B(t,e){return function(t){if(Array.isArray(t))return t}(t)||function(t,e){var n=[],r=!0,o=!1,a=void 0;try{for(var i,s=t[Symbol.iterator]();!(r=(i=s.next()).done)&&(n.push(i.value),!e||n.length!==e);r=!0);}catch(t){o=!0,a=t}finally{try{r||null==s.return||s.return()}finally{if(o)throw a}}return n}(t,e)||function(){throw new TypeError("Invalid attempt to destructure non-iterable instance")}()}function q(t,e){for(var n=0;n not mounted on DragStart!");var r=e.ownerDocument;if(!(n.props.disabled||!(t.target instanceof r.defaultView.Node)||n.props.handle&&!j(t.target,n.props.handle,e)||n.props.cancel&&j(t.target,n.props.cancel,e))){var o=function(t){return t.targetTouches&&t.targetTouches[0]?t.targetTouches[0].identifier:t.changedTouches&&t.changedTouches[0]?t.changedTouches[0].identifier:void 0}(t);n.setState({touchIdentifier:o});var a=N(t,o,U(n));if(null!=a){var i=a.x,s=a.y,c=H(U(n),i,s);n.props.onStart,!1!==n.props.onStart(t,c)&&(n.props.enableUserSelectHack&&C(r),n.setState({dragging:!0,lastX:i,lastY:s}),x(r,$.move,n.handleDrag),x(r,$.stop,n.handleDragStop))}}})),F(U(n),"handleDrag",(function(t){"touchmove"===t.type&&t.preventDefault();var e=N(t,n.state.touchIdentifier,U(n));if(null!=e){var r,o,a,i=e.x,s=e.y;if(Array.isArray(n.props.grid)){var u=i-n.state.lastX,c=s-n.state.lastY,l=B((r=n.props.grid,o=u,a=c,[Math.round(o/r[0])*r[0],Math.round(a/r[1])*r[1]]),2);if(u=l[0],c=l[1],!u&&!c)return;i=n.state.lastX+u,s=n.state.lastY+c}var p=H(U(n),i,s);if(!1!==n.props.onDrag(t,p))n.setState({lastX:i,lastY:s});else try{n.handleDragStop(new MouseEvent("mouseup"))}catch(t){var f=document.createEvent("MouseEvents");f.initMouseEvent("mouseup",!0,!0,window,0,0,0,0,0,!1,!1,!1,!1,0,null),n.handleDragStop(f)}}})),F(U(n),"handleDragStop",(function(t){if(n.state.dragging){var e=N(t,n.state.touchIdentifier,U(n));if(null!=e){var r=e.x,o=e.y,a=H(U(n),r,o),i=u.a.findDOMNode(U(n));i&&n.props.enableUserSelectHack&&E(i.ownerDocument),n.setState({dragging:!1,lastX:NaN,lastY:NaN}),n.props.onStop(t,a),i&&(D(i.ownerDocument,$.move,n.handleDrag),D(i.ownerDocument,$.stop,n.handleDragStop))}}})),F(U(n),"onMouseDown",(function(t){return $=V,n.handleDragStart(t)})),F(U(n),"onMouseUp",(function(t){return $=V,n.handleDragStop(t)})),F(U(n),"onTouchStart",(function(t){return $=G,n.handleDragStart(t)})),F(U(n),"onTouchEnd",(function(t){return $=G,n.handleDragStop(t)})),n}var n,r;return function(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function");t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,writable:!0,configurable:!0}}),e&&X(t,e)}(e,o.a.Component),n=e,(r=[{key:"componentWillUnmount",value:function(){var t=u.a.findDOMNode(this);if(t){var e=t.ownerDocument;D(e,V.move,this.handleDrag),D(e,G.move,this.handleDrag),D(e,V.stop,this.handleDragStop),D(e,G.stop,this.handleDragStop),this.props.enableUserSelectHack&&E(e)}}},{key:"render",value:function(){return o.a.cloneElement(o.a.Children.only(this.props.children),{style:T(this.props.children.props.style),onMouseDown:this.onMouseDown,onTouchStart:this.onTouchStart,onMouseUp:this.onMouseUp,onTouchEnd:this.onTouchEnd})}}])&&q(n.prototype,r),e}();function K(t){return(K="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t})(t)}function Q(){return(Q=Object.assign||function(t){for(var e=1;e, without drag handlers. This will make this component effectively undraggable. Please attach `onDrag` or `onStop` handlers so you can adjust the `position` of this element."),n}return function(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function");t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,writable:!0,configurable:!0}}),e&&at(t,e)}(e,o.a.Component),ot(e,null,[{key:"getDerivedStateFromProps",value:function(t,e){var n=t.position,r=e.prevPropsPosition;return!n||r&&n.x===r.x&&n.y===r.y?null:{x:n.x,y:n.y,prevPropsPosition:tt({},n)}}}]),ot(e,[{key:"componentDidMount",value:function(){void 0!==window.SVGElement&&u.a.findDOMNode(this)instanceof window.SVGElement&&this.setState({isElementSVG:!0})}},{key:"componentWillUnmount",value:function(){this.setState({dragging:!1})}},{key:"render",value:function(){var t,e=this.props,n=(e.axis,e.bounds,e.children),r=e.defaultPosition,a=e.defaultClassName,i=e.defaultClassNameDragging,s=e.defaultClassNameDragged,u=e.position,c=e.positionOffset,p=(e.scale,function(t,e){if(null==t)return{};var n,r,o=function(t,e){if(null==t)return{};var n,r,o={},a=Object.keys(t);for(r=0;r=0||(o[n]=t[n]);return o}(t,e);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(t);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(t,n)&&(o[n]=t[n])}return o}(e,["axis","bounds","children","defaultPosition","defaultClassName","defaultClassNameDragging","defaultClassNameDragged","position","positionOffset","scale"])),f={},h=null,d=!Boolean(u)||this.state.dragging,y=u||r,g={x:M(this)&&d?this.state.x:y.x,y:L(this)&&d?this.state.y:y.y};this.state.isElementSVG?h=function(t,e){return k(t,e,"")}(g,c):f=function(t,e){var n=k(t,e,"px");return w({},b("transform",m),n)}(g,c);var v=l()(n.props.className||"",a,(it(t={},i,this.state.dragging),it(t,s,this.state.dragged),t));return o.a.createElement(J,Q({},p,{onStart:this.onDragStart,onDrag:this.onDrag,onStop:this.onDragStop}),o.a.cloneElement(o.a.Children.only(n),{className:v,style:tt({},n.props.style,{},f),transform:h}))}}]),e}();it(st,"displayName","Draggable"),it(st,"propTypes",tt({},J.propTypes,{axis:i.a.oneOf(["both","x","y","none"]),bounds:i.a.oneOfType([i.a.shape({left:i.a.number,right:i.a.number,top:i.a.number,bottom:i.a.number}),i.a.string,i.a.oneOf([!1])]),defaultClassName:i.a.string,defaultClassNameDragging:i.a.string,defaultClassNameDragged:i.a.string,defaultPosition:i.a.shape({x:i.a.number,y:i.a.number}),positionOffset:i.a.shape({x:i.a.oneOfType([i.a.number,i.a.string]),y:i.a.oneOfType([i.a.number,i.a.string])}),position:i.a.shape({x:i.a.number,y:i.a.number}),className:y,style:y,transform:y})),it(st,"defaultProps",tt({},J.defaultProps,{axis:"both",bounds:!1,defaultClassName:"react-draggable",defaultClassNameDragging:"react-draggable-dragging",defaultClassNameDragged:"react-draggable-dragged",defaultPosition:{x:0,y:0},position:null,scale:1}))}]))},function(t,e,n){"use strict";n.r(e);var r=n(2),o=n.n(r),a=n(3),i=n.n(a),s=n(6),u=n.n(s),c=n(1);function l(t){var e=t.margin,n=t.containerPadding,r=t.containerWidth,o=t.cols;return(r-e[0]*(o-1)-2*n[0])/o}function p(t,e,n,r,o,a){var i=t.margin,s=t.containerPadding,u=t.rowHeight,c=l(t),p={};return a&&a.resizing?(p.width=Math.round(a.resizing.width),p.height=Math.round(a.resizing.height)):(p.width=r===1/0?r:Math.round(c*r+Math.max(0,r-1)*i[0]),p.height=o===1/0?o:Math.round(u*o+Math.max(0,o-1)*i[1])),a&&a.dragging?(p.top=Math.round(a.dragging.top),p.left=Math.round(a.dragging.left)):(p.top=Math.round((u+i[1])*n+s[1]),p.left=Math.round((c+i[0])*e+s[0])),p}function f(t,e,n,r,o){var a=t.margin,i=t.cols,s=t.rowHeight,u=t.maxRows,c=l(t),p=Math.round((n-a[0])/(c+a[0])),f=Math.round((e-a[1])/(s+a[1]));return{x:p=Math.max(Math.min(p,i-r),0),y:f=Math.max(Math.min(f,u-o),0)}}var h=n(5),d=n.n(h),y=n(0),g=n.n(y),b=n(7),m=n(10);function v(t){return(v="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t})(t)}function w(t,e){var n=Object.keys(t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(t);e&&(r=r.filter((function(e){return Object.getOwnPropertyDescriptor(t,e).enumerable}))),n.push.apply(n,r)}return n}function O(t){for(var e=1;e0&&void 0!==arguments[0]?arguments[0]:this.props;return{cols:t.cols,containerPadding:t.containerPadding,containerWidth:t.containerWidth,margin:t.margin,maxRows:t.maxRows,rowHeight:t.rowHeight}}},{key:"createStyle",value:function(t){var e,n=this.props,r=n.usePercentages,o=n.containerWidth;return n.useCSSTransforms?e=Object(c.setTransform)(t):(e=Object(c.setTopLeft)(t),r&&(e.left=Object(c.perc)(t.left/o),e.width=Object(c.perc)(t.width/o))),e}},{key:"mixinDraggable",value:function(t,e){return o.a.createElement(b.DraggableCore,{disabled:!e,onStart:this.onDragStart,onDrag:this.onDrag,onStop:this.onDragStop,handle:this.props.handle,cancel:".react-resizable-handle"+(this.props.cancel?","+this.props.cancel:""),scale:this.props.transformScale},t)}},{key:"mixinResizable",value:function(t,e,n){var r=this.props,a=r.cols,i=r.x,s=r.minW,u=r.minH,c=r.maxW,l=r.maxH,f=r.transformScale,h=this.getPositionParams(),d=p(h,0,0,a-i,0).width,y=p(h,0,0,s,u),g=p(h,0,0,c,l),b=[y.width,y.height],v=[Math.min(g.width,d),Math.min(g.height,1/0)];return o.a.createElement(m.Resizable,{draggableOpts:{disabled:!n},className:n?void 0:"react-resizable-hide",width:e.width,height:e.height,minConstraints:b,maxConstraints:v,onResizeStop:this.onResizeStop,onResizeStart:this.onResizeStart,onResize:this.onResize,transformScale:f},t)}},{key:"onResizeHandler",value:function(t,e,n){var r=e.node,o=e.size,a=this.props[n];if(a){var i=this.props,s=i.cols,u=i.x,c=i.y,p=i.i,f=i.maxW,h=i.minW,d=i.maxH,y=i.minH,g=function(t,e,n,r,o){var a=t.margin,i=t.maxRows,s=t.cols,u=t.rowHeight,c=l(t),p=Math.round((e+a[0])/(c+a[0])),f=Math.round((n+a[1])/(u+a[1]));return{w:p=Math.max(Math.min(p,s-r),0),h:f=Math.max(Math.min(f,i-o),0)}}(this.getPositionParams(),o.width,o.height,u,c),b=g.w,m=g.h;b=Math.min(b,s-u),b=Math.max(b,1),b=Math.max(Math.min(b,f),h),m=Math.max(Math.min(m,d),y),this.setState({resizing:"onResizeStop"===n?null:o}),a.call(this,p,b,m,{e:t,node:r,size:o})}}},{key:"render",value:function(){var t=this.props,e=t.x,n=t.y,r=t.w,a=t.h,i=t.isDraggable,s=t.isResizable,c=t.droppingPosition,l=t.useCSSTransforms,f=p(this.getPositionParams(),e,n,r,a,this.state),h=o.a.Children.only(this.props.children),d=o.a.cloneElement(h,{className:u()("react-grid-item",h.props.className,this.props.className,{static:this.props.static,resizing:Boolean(this.state.resizing),"react-draggable":i,"react-draggable-dragging":Boolean(this.state.dragging),dropping:Boolean(c),cssTransforms:l}),style:O({},this.props.style,{},h.props.style,{},this.createStyle(f))});return d=this.mixinResizable(d,f,s),d=this.mixinDraggable(d,i)}}])&&j(n.prototype,r),a&&j(n,a),e}(o.a.Component);R(z,"propTypes",{children:g.a.element,cols:g.a.number.isRequired,containerWidth:g.a.number.isRequired,rowHeight:g.a.number.isRequired,margin:g.a.array.isRequired,maxRows:g.a.number.isRequired,containerPadding:g.a.array.isRequired,x:g.a.number.isRequired,y:g.a.number.isRequired,w:g.a.number.isRequired,h:g.a.number.isRequired,minW:function(t,e){var n=t[e];return"number"!=typeof n?new Error("minWidth not Number"):n>t.w||n>t.maxW?new Error("minWidth larger than item width/maxWidth"):void 0},maxW:function(t,e){var n=t[e];return"number"!=typeof n?new Error("maxWidth not Number"):nt.h||n>t.maxH?new Error("minHeight larger than item height/maxHeight"):void 0},maxH:function(t,e){var n=t[e];return"number"!=typeof n?new Error("maxHeight not Number"):n0){var g=1/0,b=1/0;y.forEach((function(t){t.x>h.x&&(g=Math.min(g,t.x)),t.y>h.y&&(b=Math.min(b,t.y))})),Number.isFinite(g)&&(h.w=g-h.x),Number.isFinite(b)&&(h.h=b-h.y)}}d||(h.w=e,h.h=n);var m={w:h.w,h:h.h,x:h.x,y:h.y,static:!0,i:t};this.props.onResize(s,u,h,m,o,a),this.setState({layout:Object(c.compact)(s,Object(c.compactType)(this.props),p),activeDrag:m})}}},{key:"onResizeStop",value:function(t,e,n,r){var o=r.e,a=r.node,i=this.state,s=i.layout,u=i.oldResizeItem,l=this.props.cols,p=Object(c.getLayoutItem)(s,t);this.props.onResizeStop(s,u,p,null,o,a);var f=Object(c.compact)(s,Object(c.compactType)(this.props),l),h=this.state.oldLayout;this.setState({activeDrag:null,layout:f,oldResizeItem:null,oldLayout:null}),this.onLayoutMaybeChanged(f,h)}},{key:"placeholder",value:function(){var t=this.state.activeDrag;if(!t)return null;var e=this.props,n=e.width,r=e.cols,a=e.margin,i=e.containerPadding,s=e.rowHeight,u=e.maxRows,c=e.useCSSTransforms,l=e.transformScale;return o.a.createElement(z,{w:t.w,h:t.h,x:t.x,y:t.y,i:t.i,className:"react-grid-placeholder",containerWidth:n,cols:r,margin:a,containerPadding:i||a,maxRows:u,rowHeight:s,isDraggable:!1,isResizable:!1,useCSSTransforms:c,transformScale:l},o.a.createElement("div",null))}},{key:"processGridItem",value:function(t,e){if(t&&t.key){var n=Object(c.getLayoutItem)(this.state.layout,String(t.key));if(!n)return null;var r=this.props,a=r.width,i=r.cols,s=r.margin,u=r.containerPadding,l=r.rowHeight,p=r.maxRows,f=r.isDraggable,h=r.isResizable,d=r.useCSSTransforms,y=r.transformScale,g=r.draggableCancel,b=r.draggableHandle,m=this.state,v=m.mounted,w=m.droppingPosition,O="boolean"==typeof n.isDraggable?n.isDraggable:!n.static&&f,S="boolean"==typeof n.isResizable?n.isResizable:!n.static&&h;return o.a.createElement(z,{containerWidth:a,cols:i,margin:s,containerPadding:u||s,maxRows:p,rowHeight:l,cancel:g,handle:b,onDragStop:this.onDragStop,onDragStart:this.onDragStart,onDrag:this.onDrag,onResizeStart:this.onResizeStart,onResize:this.onResize,onResizeStop:this.onResizeStop,isDraggable:O,isResizable:S,useCSSTransforms:d&&v,usePercentages:!v,transformScale:y,w:n.w,h:n.h,x:n.x,y:n.y,i:n.i,minH:n.minH,minW:n.minW,maxH:n.maxH,maxW:n.maxW,static:n.static,droppingPosition:e?w:void 0},t)}}},{key:"render",value:function(){var t=this,e=this.props,n=e.className,r=e.style,a=e.isDroppable,i=u()("react-grid-layout",n),s=T({height:this.containerHeight()},r);return o.a.createElement("div",{className:i,style:s,onDrop:a?this.onDrop:c.noop,onDragLeave:a?this.onDragLeave:c.noop,onDragEnter:a?this.onDragEnter:c.noop,onDragOver:a?this.onDragOver:c.noop},o.a.Children.map(this.props.children,(function(e){return t.processGridItem(e)})),a&&this.state.droppingDOMNode&&this.processGridItem(this.state.droppingDOMNode,!0),this.placeholder())}}])&&L(n.prototype,r),a&&L(n,a),e}(o.a.Component);A(B,"displayName","ReactGridLayout"),A(B,"propTypes",k),A(B,"defaultProps",{autoSize:!0,cols:12,className:"",style:{},draggableHandle:"",draggableCancel:"",containerPadding:null,rowHeight:150,maxRows:1/0,layout:[],margin:[10,10],isDraggable:!0,isResizable:!0,isDroppable:!1,useCSSTransforms:!0,transformScale:1,verticalCompact:!0,compactType:"vertical",preventCollision:!1,droppingItem:{i:"__dropping-elem__",h:1,w:1},onLayoutChange:c.noop,onDragStart:c.noop,onDrag:c.noop,onDragStop:c.noop,onResizeStart:c.noop,onResize:c.noop,onResizeStop:c.noop,onDrop:c.noop})},function(t,e,n){"use strict";e.__esModule=!0,e.default=void 0;var r=s(n(2)),o=s(n(0)),a=n(7),i=n(17);function s(t){return t&&t.__esModule?t:{default:t}}function u(){return(u=Object.assign||function(t){for(var e=1;e=0||(o[n]=t[n]);return o}(e,["children","draggableOpts","width","height","handleSize","lockAspectRatio","axis","minConstraints","maxConstraints","onResize","onResizeStop","onResizeStart","resizeHandles","transformScale"])),f=l.className?l.className+" react-resizable":"react-resizable";return(0,i.cloneElement)(n,function(t){for(var e=1;e=0||(o[n]=t[n]);return o}(t,["handle","handleSize","onResize","onResizeStart","onResizeStop","draggableOpts","minConstraints","maxConstraints","lockAspectRatio","axis","width","height","resizeHandles"]);return r.default.createElement(a.default,{handle:e,handleSize:n,width:this.state.width,height:this.state.height,onResizeStart:o,onResize:this.onResize,onResizeStop:i,draggableOpts:u,minConstraints:c,maxConstraints:l,lockAspectRatio:p,axis:f,resizeHandles:h},r.default.createElement("div",s({style:{width:this.state.width+"px",height:this.state.height+"px"}},d)))},o}(r.default.Component);e.default=l,c(l,"propTypes",{height:o.default.number,width:o.default.number}),c(l,"defaultProps",{handleSize:[20,20]})},function(t,e,n){"use strict";n.r(e),n.d(e,"default",(function(){return D}));var r=n(2),o=n(0),a=n.n(o),i=n(3),s=n.n(i),u=n(1),c=n(4),l=n(8);function p(t){return(p="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t})(t)}function f(){return(f=Object.assign||function(t){for(var e=1;e=0||(o[n]=t[n]);return o}(t,e);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(t);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(t,n)&&(o[n]=t[n])}return o}function d(t,e){var n=Object.keys(t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(t);e&&(r=r.filter((function(e){return Object.getOwnPropertyDescriptor(t,e).enumerable}))),n.push.apply(n,r)}return n}function y(t){for(var e=1;e=0||(o[n]=t[n]);return o}(t,e);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(t);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(t,n)&&(o[n]=t[n])}return o}function p(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}function f(t,e){for(var n=0;n0&&void 0!==arguments[0]?arguments[0]:"transform";if("undefined"==typeof window||void 0===window.document)return"";var e=window.document.documentElement.style;if(t in e)return"";for(var n=0;n0&&void 0!==arguments[0]?arguments[0]:{})}function M(t){return"both"===t.props.axis||"x"===t.props.axis}function L(t){return"both"===t.props.axis||"y"===t.props.axis}function N(t,e,n){var r="number"==typeof e?function(t,e){return t.targetTouches&&p(t.targetTouches,(function(t){return e===t.identifier}))||t.changedTouches&&p(t.changedTouches,(function(t){return e===t.identifier}))}(t,e):null;if("number"==typeof e&&!r)return null;var o=A(n);return function(t,e,n){var r=e===e.ownerDocument.body?{left:0,top:0}:e.getBoundingClientRect();return{x:(t.clientX+e.scrollLeft-r.left)/n,y:(t.clientY+e.scrollTop-r.top)/n}}(r||t,n.props.offsetParent||o.offsetParent||o.ownerDocument.body,n.props.scale)}function H(t,e,n){var r=t.state,o=!d(r.lastX),a=A(t);return o?{node:a,deltaX:0,deltaY:0,lastX:e,lastY:n,x:e,y:n}:{node:a,deltaX:e-r.lastX,deltaY:n-r.lastY,lastX:r.lastX,lastY:r.lastY,x:e,y:n}}function W(t,e){var n=t.props.scale;return{node:e.node,x:t.state.x+e.deltaX/n,y:t.state.y+e.deltaY/n,deltaX:e.deltaX/n,deltaY:e.deltaY/n,lastX:t.state.x,lastY:t.state.y}}function A(t){var e=u.a.findDOMNode(t);if(!e)throw new Error(": Unmounted during event!");return e}function I(t){return(I="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t})(t)}function B(t,e){return function(t){if(Array.isArray(t))return t}(t)||function(t,e){var n=[],r=!0,o=!1,a=void 0;try{for(var i,s=t[Symbol.iterator]();!(r=(i=s.next()).done)&&(n.push(i.value),!e||n.length!==e);r=!0);}catch(t){o=!0,a=t}finally{try{r||null==s.return||s.return()}finally{if(o)throw a}}return n}(t,e)||function(){throw new TypeError("Invalid attempt to destructure non-iterable instance")}()}function q(t,e){for(var n=0;n not mounted on DragStart!");var r=e.ownerDocument;if(!(n.props.disabled||!(t.target instanceof r.defaultView.Node)||n.props.handle&&!j(t.target,n.props.handle,e)||n.props.cancel&&j(t.target,n.props.cancel,e))){var o=function(t){return t.targetTouches&&t.targetTouches[0]?t.targetTouches[0].identifier:t.changedTouches&&t.changedTouches[0]?t.changedTouches[0].identifier:void 0}(t);n.setState({touchIdentifier:o});var a=N(t,o,Y(n));if(null!=a){var i=a.x,s=a.y,c=H(Y(n),i,s);n.props.onStart,!1!==n.props.onStart(t,c)&&(n.props.enableUserSelectHack&&C(r),n.setState({dragging:!0,lastX:i,lastY:s}),x(r,$.move,n.handleDrag),x(r,$.stop,n.handleDragStop))}}})),F(Y(n),"handleDrag",(function(t){"touchmove"===t.type&&t.preventDefault();var e=N(t,n.state.touchIdentifier,Y(n));if(null!=e){var r,o,a,i=e.x,s=e.y;if(Array.isArray(n.props.grid)){var u=i-n.state.lastX,c=s-n.state.lastY,l=B((r=n.props.grid,o=u,a=c,[Math.round(o/r[0])*r[0],Math.round(a/r[1])*r[1]]),2);if(u=l[0],c=l[1],!u&&!c)return;i=n.state.lastX+u,s=n.state.lastY+c}var p=H(Y(n),i,s);if(!1!==n.props.onDrag(t,p))n.setState({lastX:i,lastY:s});else try{n.handleDragStop(new MouseEvent("mouseup"))}catch(t){var f=document.createEvent("MouseEvents");f.initMouseEvent("mouseup",!0,!0,window,0,0,0,0,0,!1,!1,!1,!1,0,null),n.handleDragStop(f)}}})),F(Y(n),"handleDragStop",(function(t){if(n.state.dragging){var e=N(t,n.state.touchIdentifier,Y(n));if(null!=e){var r=e.x,o=e.y,a=H(Y(n),r,o),i=u.a.findDOMNode(Y(n));i&&n.props.enableUserSelectHack&&E(i.ownerDocument),n.setState({dragging:!1,lastX:NaN,lastY:NaN}),n.props.onStop(t,a),i&&(D(i.ownerDocument,$.move,n.handleDrag),D(i.ownerDocument,$.stop,n.handleDragStop))}}})),F(Y(n),"onMouseDown",(function(t){return $=V,n.handleDragStart(t)})),F(Y(n),"onMouseUp",(function(t){return $=V,n.handleDragStop(t)})),F(Y(n),"onTouchStart",(function(t){return $=G,n.handleDragStart(t)})),F(Y(n),"onTouchEnd",(function(t){return $=G,n.handleDragStop(t)})),n}var n,r;return function(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function");t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,writable:!0,configurable:!0}}),e&&X(t,e)}(e,o.a.Component),n=e,(r=[{key:"componentWillUnmount",value:function(){var t=u.a.findDOMNode(this);if(t){var e=t.ownerDocument;D(e,V.move,this.handleDrag),D(e,G.move,this.handleDrag),D(e,V.stop,this.handleDragStop),D(e,G.stop,this.handleDragStop),this.props.enableUserSelectHack&&E(e)}}},{key:"render",value:function(){return o.a.cloneElement(o.a.Children.only(this.props.children),{style:T(this.props.children.props.style),onMouseDown:this.onMouseDown,onTouchStart:this.onTouchStart,onMouseUp:this.onMouseUp,onTouchEnd:this.onTouchEnd})}}])&&q(n.prototype,r),e}();function K(t){return(K="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t})(t)}function Q(){return(Q=Object.assign||function(t){for(var e=1;e, without drag handlers. This will make this component effectively undraggable. Please attach `onDrag` or `onStop` handlers so you can adjust the `position` of this element."),n}return function(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function");t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,writable:!0,configurable:!0}}),e&&at(t,e)}(e,o.a.Component),ot(e,null,[{key:"getDerivedStateFromProps",value:function(t,e){var n=t.position,r=e.prevPropsPosition;return!n||r&&n.x===r.x&&n.y===r.y?null:{x:n.x,y:n.y,prevPropsPosition:tt({},n)}}}]),ot(e,[{key:"componentDidMount",value:function(){void 0!==window.SVGElement&&u.a.findDOMNode(this)instanceof window.SVGElement&&this.setState({isElementSVG:!0})}},{key:"componentWillUnmount",value:function(){this.setState({dragging:!1})}},{key:"render",value:function(){var t,e=this.props,n=(e.axis,e.bounds,e.children),r=e.defaultPosition,a=e.defaultClassName,i=e.defaultClassNameDragging,s=e.defaultClassNameDragged,u=e.position,c=e.positionOffset,p=(e.scale,function(t,e){if(null==t)return{};var n,r,o=function(t,e){if(null==t)return{};var n,r,o={},a=Object.keys(t);for(r=0;r=0||(o[n]=t[n]);return o}(t,e);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(t);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(t,n)&&(o[n]=t[n])}return o}(e,["axis","bounds","children","defaultPosition","defaultClassName","defaultClassNameDragging","defaultClassNameDragged","position","positionOffset","scale"])),f={},d=null,h=!Boolean(u)||this.state.dragging,y=u||r,g={x:M(this)&&h?this.state.x:y.x,y:L(this)&&h?this.state.y:y.y};this.state.isElementSVG?d=function(t,e){return k(t,e,"")}(g,c):f=function(t,e){var n=k(t,e,"px");return w({},b("transform",m),n)}(g,c);var v=l()(n.props.className||"",a,(it(t={},i,this.state.dragging),it(t,s,this.state.dragged),t));return o.a.createElement(J,Q({},p,{onStart:this.onDragStart,onDrag:this.onDrag,onStop:this.onDragStop}),o.a.cloneElement(o.a.Children.only(n),{className:v,style:tt({},n.props.style,{},f),transform:d}))}}]),e}();it(st,"displayName","Draggable"),it(st,"propTypes",tt({},J.propTypes,{axis:i.a.oneOf(["both","x","y","none"]),bounds:i.a.oneOfType([i.a.shape({left:i.a.number,right:i.a.number,top:i.a.number,bottom:i.a.number}),i.a.string,i.a.oneOf([!1])]),defaultClassName:i.a.string,defaultClassNameDragging:i.a.string,defaultClassNameDragged:i.a.string,defaultPosition:i.a.shape({x:i.a.number,y:i.a.number}),positionOffset:i.a.shape({x:i.a.oneOfType([i.a.number,i.a.string]),y:i.a.oneOfType([i.a.number,i.a.string])}),position:i.a.shape({x:i.a.number,y:i.a.number}),className:y,style:y,transform:y})),it(st,"defaultProps",tt({},J.defaultProps,{axis:"both",bounds:!1,defaultClassName:"react-draggable",defaultClassNameDragging:"react-draggable-dragging",defaultClassNameDragged:"react-draggable-dragged",defaultPosition:{x:0,y:0},position:null,scale:1}))}]))},function(t,e,n){"use strict";n.r(e),n.d(e,"default",(function(){return G}));var r=n(2),o=n.n(r),a=n(3),i=n.n(a),s=n(6),u=n.n(s),c=n(1);function l(t){var e=t.margin,n=t.containerPadding,r=t.containerWidth,o=t.cols;return(r-e[0]*(o-1)-2*n[0])/o}function p(t,e,n){return Number.isFinite(t)?Math.round(e*t+Math.max(0,t-1)*n):t}function f(t,e,n,r,o,a){var i=t.margin,s=t.containerPadding,u=t.rowHeight,c=l(t),f={};return a&&a.resizing?(f.width=Math.round(a.resizing.width),f.height=Math.round(a.resizing.height)):(f.width=p(r,c,i[0]),f.height=p(o,u,i[1])),a&&a.dragging?(f.top=Math.round(a.dragging.top),f.left=Math.round(a.dragging.left)):(f.top=Math.round((u+i[1])*n+s[1]),f.left=Math.round((c+i[0])*e+s[0])),f}function d(t,e,n,r,o){var a=t.margin,i=t.cols,s=t.rowHeight,u=t.maxRows,c=l(t),p=Math.round((n-a[0])/(c+a[0])),f=Math.round((e-a[1])/(s+a[1]));return{x:p=h(p,0,i-r),y:f=h(f,0,u-o)}}function h(t,e,n){return Math.max(Math.min(t,n),e)}var y=n(5),g=n.n(y),b=n(0),m=n.n(b),v=n(7),w=n(10);function O(t){return(O="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t})(t)}function S(t,e){var n=Object.keys(t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(t);e&&(r=r.filter((function(e){return Object.getOwnPropertyDescriptor(t,e).enumerable}))),n.push.apply(n,r)}return n}function j(t){for(var e=1;e0&&void 0!==arguments[0]?arguments[0]:this.props;return{cols:t.cols,containerPadding:t.containerPadding,containerWidth:t.containerWidth,margin:t.margin,maxRows:t.maxRows,rowHeight:t.rowHeight}}},{key:"createStyle",value:function(t){var e,n=this.props,r=n.usePercentages,o=n.containerWidth;return n.useCSSTransforms?e=Object(c.setTransform)(t):(e=Object(c.setTopLeft)(t),r&&(e.left=Object(c.perc)(t.left/o),e.width=Object(c.perc)(t.width/o))),e}},{key:"mixinDraggable",value:function(t,e){return o.a.createElement(v.DraggableCore,{disabled:!e,onStart:this.onDragStart,onDrag:this.onDrag,onStop:this.onDragStop,handle:this.props.handle,cancel:".react-resizable-handle"+(this.props.cancel?","+this.props.cancel:""),scale:this.props.transformScale},t)}},{key:"mixinResizable",value:function(t,e,n){var r=this.props,a=r.cols,i=r.x,s=r.minW,u=r.minH,c=r.maxW,l=r.maxH,p=r.transformScale,d=this.getPositionParams(),h=f(d,0,0,a-i,0).width,y=f(d,0,0,s,u),g=f(d,0,0,c,l),b=[y.width,y.height],m=[Math.min(g.width,h),Math.min(g.height,1/0)];return o.a.createElement(w.Resizable,{draggableOpts:{disabled:!n},className:n?void 0:"react-resizable-hide",width:e.width,height:e.height,minConstraints:b,maxConstraints:m,onResizeStop:this.onResizeStop,onResizeStart:this.onResizeStart,onResize:this.onResize,transformScale:p},t)}},{key:"onResizeHandler",value:function(t,e,n){var r=e.node,o=e.size,a=this.props[n];if(a){var i=this.props,s=i.cols,u=i.x,c=i.y,p=i.i,f=i.maxH,d=i.minH,y=this.props,g=y.minW,b=y.maxW,m=function(t,e,n,r,o){var a=t.margin,i=t.maxRows,s=t.cols,u=t.rowHeight,c=l(t),p=Math.round((e+a[0])/(c+a[0])),f=Math.round((n+a[1])/(u+a[1]));return{w:p=h(p,0,s-r),h:f=h(f,0,i-o)}}(this.getPositionParams(),o.width,o.height,u,c),v=m.w,w=m.h;v=h(v,g=Math.max(g,1),b=Math.min(b,s-u)),w=h(w,d,f),this.setState({resizing:"onResizeStop"===n?null:o}),a.call(this,p,v,w,{e:t,node:r,size:o})}}},{key:"render",value:function(){var t=this.props,e=t.x,n=t.y,r=t.w,a=t.h,i=t.isDraggable,s=t.isResizable,c=t.droppingPosition,l=t.useCSSTransforms,p=f(this.getPositionParams(),e,n,r,a,this.state),d=o.a.Children.only(this.props.children),h=o.a.cloneElement(d,{className:u()("react-grid-item",d.props.className,this.props.className,{static:this.props.static,resizing:Boolean(this.state.resizing),"react-draggable":i,"react-draggable-dragging":Boolean(this.state.dragging),dropping:Boolean(c),cssTransforms:l}),style:j(j(j({},this.props.style),d.props.style),this.createStyle(p))});return h=this.mixinResizable(h,p,s),h=this.mixinDraggable(h,i)}}])&&D(e.prototype,n),r&&D(e,r),i}(o.a.Component);C(E,"propTypes",{children:m.a.element,cols:m.a.number.isRequired,containerWidth:m.a.number.isRequired,rowHeight:m.a.number.isRequired,margin:m.a.array.isRequired,maxRows:m.a.number.isRequired,containerPadding:m.a.array.isRequired,x:m.a.number.isRequired,y:m.a.number.isRequired,w:m.a.number.isRequired,h:m.a.number.isRequired,minW:function(t,e){var n=t[e];return"number"!=typeof n?new Error("minWidth not Number"):n>t.w||n>t.maxW?new Error("minWidth larger than item width/maxWidth"):void 0},maxW:function(t,e){var n=t[e];return"number"!=typeof n?new Error("maxWidth not Number"):nt.h||n>t.maxH?new Error("minHeight larger than item height/maxHeight"):void 0},maxH:function(t,e){var n=t[e];return"number"!=typeof n?new Error("maxHeight not Number"):nt.length)&&(e=t.length);for(var n=0,r=new Array(e);n0){var g=1/0,b=1/0;y.forEach((function(t){t.x>d.x&&(g=Math.min(g,t.x)),t.y>d.y&&(b=Math.min(b,t.y))})),Number.isFinite(g)&&(d.w=g-d.x),Number.isFinite(b)&&(d.h=b-d.y)}}h||(d.w=e,d.h=n);var m={w:d.w,h:d.h,x:d.x,y:d.y,static:!0,i:t};this.props.onResize(s,u,d,m,o,a),this.setState({layout:Object(c.compact)(s,Object(c.compactType)(this.props),p),activeDrag:m})}}},{key:"onResizeStop",value:function(t,e,n,r){var o=r.e,a=r.node,i=this.state,s=i.layout,u=i.oldResizeItem,l=this.props.cols,p=Object(c.getLayoutItem)(s,t);this.props.onResizeStop(s,u,p,null,o,a);var f=Object(c.compact)(s,Object(c.compactType)(this.props),l),d=this.state.oldLayout;this.setState({activeDrag:null,layout:f,oldResizeItem:null,oldLayout:null}),this.onLayoutMaybeChanged(f,d)}},{key:"placeholder",value:function(){var t=this.state.activeDrag;if(!t)return null;var e=this.props,n=e.width,r=e.cols,a=e.margin,i=e.containerPadding,s=e.rowHeight,u=e.maxRows,c=e.useCSSTransforms,l=e.transformScale;return(o.a.createElement(E,{w:t.w,h:t.h,x:t.x,y:t.y,i:t.i,className:"react-grid-placeholder",containerWidth:n,cols:r,margin:a,containerPadding:i||a,maxRows:u,rowHeight:s,isDraggable:!1,isResizable:!1,isBounded:!1,useCSSTransforms:c,transformScale:l},o.a.createElement("div",null)))}},{key:"processGridItem",value:function(t,e){if(t&&t.key){var n=Object(c.getLayoutItem)(this.state.layout,String(t.key));if(!n)return null;var r=this.props,a=r.width,i=r.cols,s=r.margin,u=r.containerPadding,l=r.rowHeight,p=r.maxRows,f=r.isDraggable,d=r.isResizable,h=r.isBounded,y=r.useCSSTransforms,g=r.transformScale,b=r.draggableCancel,m=r.draggableHandle,v=this.state,w=v.mounted,O=v.droppingPosition,S="boolean"==typeof n.isDraggable?n.isDraggable:!n.static&&f,j="boolean"==typeof n.isResizable?n.isResizable:!n.static&&d,x=S&&h&&!1!==n.isBounded;return o.a.createElement(E,{containerWidth:a,cols:i,margin:s,containerPadding:u||s,maxRows:p,rowHeight:l,cancel:b,handle:m,onDragStop:this.onDragStop,onDragStart:this.onDragStart,onDrag:this.onDrag,onResizeStart:this.onResizeStart,onResize:this.onResize,onResizeStop:this.onResizeStop,isDraggable:S,isResizable:j,isBounded:x,useCSSTransforms:y&&w,usePercentages:!w,transformScale:g,w:n.w,h:n.h,x:n.x,y:n.y,i:n.i,minH:n.minH,minW:n.minW,maxH:n.maxH,maxW:n.maxW,static:n.static,droppingPosition:e?O:void 0},t)}}},{key:"render",value:function(){var t=this,e=this.props,n=e.className,r=e.style,a=e.isDroppable,i=e.innerRef,s=u()("react-grid-layout",n),l=N({height:this.containerHeight()},r);return o.a.createElement("div",{ref:i,className:s,style:l,onDrop:a?this.onDrop:c.noop,onDragLeave:a?this.onDragLeave:c.noop,onDragEnter:a?this.onDragEnter:c.noop,onDragOver:a?this.onDragOver:c.noop},o.a.Children.map(this.props.children,(function(e){return t.processGridItem(e)})),a&&this.state.droppingDOMNode&&this.processGridItem(this.state.droppingDOMNode,!0),this.placeholder())}}])&&A(e.prototype,n),r&&A(e,r),s}(o.a.Component);X(G,"displayName","ReactGridLayout"),X(G,"propTypes",T),X(G,"defaultProps",{autoSize:!0,cols:12,className:"",style:{},draggableHandle:"",draggableCancel:"",containerPadding:null,rowHeight:150,maxRows:1/0,layout:[],margin:[10,10],isBounded:!1,isDraggable:!0,isResizable:!0,isDroppable:!1,useCSSTransforms:!0,transformScale:1,verticalCompact:!0,compactType:"vertical",preventCollision:!1,droppingItem:{i:"__dropping-elem__",h:1,w:1},onLayoutChange:c.noop,onDragStart:c.noop,onDrag:c.noop,onDragStop:c.noop,onResizeStart:c.noop,onResize:c.noop,onResizeStop:c.noop,onDrop:c.noop})},function(t,e,n){"use strict";e.__esModule=!0,e.default=void 0;var r=s(n(2)),o=s(n(0)),a=n(7),i=n(17);function s(t){return t&&t.__esModule?t:{default:t}}function u(){return(u=Object.assign||function(t){for(var e=1;e=0||(o[n]=t[n]);return o}(e,["children","draggableOpts","width","height","handleSize","lockAspectRatio","axis","minConstraints","maxConstraints","onResize","onResizeStop","onResizeStart","resizeHandles","transformScale"])),f=l.className?l.className+" react-resizable":"react-resizable";return(0,i.cloneElement)(n,function(t){for(var e=1;e=0||(o[n]=t[n]);return o}(t,["handle","handleSize","onResize","onResizeStart","onResizeStop","draggableOpts","minConstraints","maxConstraints","lockAspectRatio","axis","width","height","resizeHandles"]);return r.default.createElement(a.default,{handle:e,handleSize:n,width:this.state.width,height:this.state.height,onResizeStart:o,onResize:this.onResize,onResizeStop:i,draggableOpts:u,minConstraints:c,maxConstraints:l,lockAspectRatio:p,axis:f,resizeHandles:d},r.default.createElement("div",s({style:{width:this.state.width+"px",height:this.state.height+"px"}},h)))},o}(r.default.Component);e.default=l,c(l,"propTypes",{height:o.default.number,width:o.default.number}),c(l,"defaultProps",{handleSize:[20,20]})},function(t,e,n){"use strict";n.r(e),n.d(e,"default",(function(){return P}));var r=n(2),o=n(0),a=n.n(o),i=n(3),s=n.n(i),u=n(1),c=n(4),l=n(8);function p(t){return(p="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t})(t)}function f(){return(f=Object.assign||function(t){for(var e=1;e=0||(o[n]=t[n]);return o}(t,e);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(t);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(t,n)&&(o[n]=t[n])}return o}function h(t,e){var n=Object.keys(t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(t);e&&(r=r.filter((function(e){return Object.getOwnPropertyDescriptor(t,e).enumerable}))),n.push.apply(n,r)}return n}function y(t){for(var e=1;e=0||(o[n]=t[n]);return o}(t,e);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(t);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(t,n)&&(o[n]=t[n])}return o}function p(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}function f(t,e){for(var n=0;n;\nexport type Position = {\n left: number,\n top: number,\n width: number,\n height: number\n};\nexport type ReactDraggableCallbackData = {\n node: HTMLElement,\n x?: number,\n y?: number,\n deltaX: number,\n deltaY: number,\n lastX?: number,\n lastY?: number\n};\n\nexport type PartialPosition = { left: number, top: number };\nexport type DroppingPosition = { left: number, top: number, e: Event };\nexport type Size = { width: number, height: number };\nexport type GridDragEvent = {\n e: Event,\n node: HTMLElement,\n newPosition: PartialPosition\n};\nexport type GridResizeEvent = { e: Event, node: HTMLElement, size: Size };\nexport type DragOverEvent = MouseEvent & {\n nativeEvent: {\n layerX: number,\n layerY: number,\n target: {\n className: String\n }\n }\n};\n\ntype REl = ReactElement;\nexport type ReactChildren = ReactChildrenArray;\n\n// All callbacks are of the signature (layout, oldItem, newItem, placeholder, e).\nexport type EventCallback = (\n Layout,\n oldItem: ?LayoutItem,\n newItem: ?LayoutItem,\n placeholder: ?LayoutItem,\n Event,\n ?HTMLElement\n) => void;\nexport type CompactType = ?(\"horizontal\" | \"vertical\");\n\nconst isProduction = process.env.NODE_ENV === \"production\";\nconst DEBUG = false;\n\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,\n 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,\n h: layoutItem.h,\n x: layoutItem.x,\n y: layoutItem.y,\n i: layoutItem.i,\n minW: layoutItem.minW,\n maxW: layoutItem.maxW,\n minH: layoutItem.minH,\n maxH: layoutItem.maxH,\n moved: Boolean(layoutItem.moved),\n static: Boolean(layoutItem.static),\n // These can be null\n isDraggable: layoutItem.isDraggable,\n isResizable: layoutItem.isResizable\n };\n}\n\n/**\n * Comparing React `children` is a bit difficult. This is a good way to compare them.\n * This will catch differences in keys, order, and length.\n */\nexport function childrenEqual(a: ReactChildren, b: ReactChildren): boolean {\n return isEqual(\n React.Children.map(a, c => c.key),\n React.Children.map(b, c => c.key)\n );\n}\n\n/**\n * See `fastRGLPropsEqual.js`.\n * We want this to run as fast as possible - it is called often - and to be\n * resilient to new props that we add. So rather than call lodash.isEqual,\n * which isn't suited to comparing props very well, we use this specialized\n * function in conjunction with preval to generate the fastest possible comparison\n * function, tuned for exactly our props.\n */\ntype FastRGLPropsEqual = (Object, Object, Function) => boolean;\nexport const fastRGLPropsEqual: FastRGLPropsEqual = require(\"./fastRGLPropsEqual\");\n\n// Like the above, but a lot simpler.\nexport function fastPositionEqual(a: Position, b: Position) {\n return (\n a.left === b.left &&\n a.top === b.top &&\n a.width === b.width &&\n a.height === b.height\n );\n}\n\n/**\n * Given two layoutitems, check if they collide.\n */\nexport function collides(l1: LayoutItem, l2: LayoutItem): boolean {\n if (l1.i === l2.i) 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 * Does not modify layout items (clones). Creates a new layout array.\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(\n layout: Layout,\n compactType: CompactType,\n cols: number\n): 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 = sortLayoutItems(layout, compactType);\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 = cloneLayoutItem(sorted[i]);\n\n // Don't move static elements\n if (!l.static) {\n l = compactItem(compareWith, l, compactType, cols, sorted);\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(sorted[i])] = l;\n\n // Clear moved flag, if it exists.\n l.moved = false;\n }\n\n return out;\n}\n\nconst heightWidth = { x: \"w\", y: \"h\" };\n/**\n * Before moving item down, it will check if the movement will cause collisions and move those items down before.\n */\nfunction resolveCompactionCollision(\n layout: Layout,\n item: LayoutItem,\n moveToCoord: number,\n axis: \"x\" | \"y\"\n) {\n const sizeProp = heightWidth[axis];\n item[axis] += 1;\n const itemIndex = layout\n .map(layoutItem => {\n return layoutItem.i;\n })\n .indexOf(item.i);\n\n // Go through each item we collide with.\n for (let i = itemIndex + 1; i < layout.length; i++) {\n const otherItem = layout[i];\n // Ignore static items\n if (otherItem.static) continue;\n\n // Optimization: we can break early if we know we're past this el\n // We can do this b/c it's a sorted layout\n if (otherItem.y > item.y + item.h) break;\n\n if (collides(item, otherItem)) {\n resolveCompactionCollision(\n layout,\n otherItem,\n moveToCoord + item[sizeProp],\n axis\n );\n }\n }\n\n item[axis] = moveToCoord;\n}\n\n/**\n * Compact an item in the layout.\n *\n * Modifies item.\n *\n */\nexport function compactItem(\n compareWith: Layout,\n l: LayoutItem,\n compactType: CompactType,\n cols: number,\n fullLayout: Layout\n): LayoutItem {\n const compactV = compactType === \"vertical\";\n const compactH = compactType === \"horizontal\";\n if (compactV) {\n // Bottom 'y' possible is the bottom of the layout.\n // This allows you to do nice stuff like specify {y: Infinity}\n // This is here because the layout must be sorted in order to get the correct bottom `y`.\n l.y = Math.min(bottom(compareWith), l.y);\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 } else if (compactH) {\n l.y = Math.min(bottom(compareWith), l.y);\n // Move the element left as far as it can go without colliding.\n while (l.x > 0 && !getFirstCollision(compareWith, l)) {\n l.x--;\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 if (compactH) {\n resolveCompactionCollision(fullLayout, l, collides.x + collides.w, \"x\");\n } else {\n resolveCompactionCollision(fullLayout, l, collides.y + collides.h, \"y\");\n }\n // Since we can't grow without bounds horizontally, if we've overflown, let's move it down and try again.\n if (compactH && l.x + l.w > cols) {\n l.x = cols - l.w;\n l.y++;\n }\n }\n return l;\n}\n\n/**\n * Given a layout, make sure all elements fit within its bounds.\n *\n * Modifies layout items.\n *\n * @param {Array} layout Layout array.\n * @param {Number} bounds Number of columns.\n */\nexport function correctBounds(\n layout: Layout,\n bounds: { cols: number }\n): 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(\n layout: Layout,\n layoutItem: LayoutItem\n): ?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(\n layout: Layout,\n layoutItem: LayoutItem\n): Array {\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 {\n return layout.filter(l => l.static);\n}\n\n/**\n * Move an element. Responsible for doing cascading movements of other elements.\n *\n * Modifies layout items.\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 */\nexport function moveElement(\n layout: Layout,\n l: LayoutItem,\n x: ?number,\n y: ?number,\n isUserAction: ?boolean,\n preventCollision: ?boolean,\n compactType: CompactType,\n cols: number\n): Layout {\n // If this is static and not explicitly enabled as draggable,\n // no move is possible, so we can short-circuit this immediately.\n if (l.static && l.isDraggable !== true) return layout;\n\n // Short-circuit if nothing to do.\n if (l.y === y && l.x === x) return layout;\n\n log(\n `Moving element ${l.i} to [${String(x)},${String(y)}] from [${l.x},${l.y}]`\n );\n const oldX = l.x;\n const oldY = l.y;\n\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 = sortLayoutItems(layout, compactType);\n const movingUp =\n compactType === \"vertical\" && typeof y === \"number\"\n ? oldY >= y\n : compactType === \"horizontal\" && typeof x === \"number\"\n ? oldX >= x\n : false;\n // $FlowIgnore acceptable modification of read-only array as it was recently cloned\n if (movingUp) sorted = sorted.reverse();\n const collisions = getAllCollisions(sorted, l);\n\n // There was a collision; abort\n if (preventCollision && collisions.length) {\n log(`Collision prevented on ${l.i}, reverting.`);\n l.x = oldX;\n l.y = oldY;\n l.moved = false;\n return layout;\n }\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 log(\n `Resolving collision between ${l.i} at [${l.x},${l.y}] and ${collision.i} at [${collision.x},${collision.y}]`\n );\n\n // Short circuit so we can't infinite loop\n if (collision.moved) continue;\n\n // Don't move static items - we have to move *this* element away\n if (collision.static) {\n layout = moveElementAwayFromCollision(\n layout,\n collision,\n l,\n isUserAction,\n compactType,\n cols\n );\n } else {\n layout = moveElementAwayFromCollision(\n layout,\n l,\n collision,\n isUserAction,\n compactType,\n cols\n );\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 */\nexport function moveElementAwayFromCollision(\n layout: Layout,\n collidesWith: LayoutItem,\n itemToMove: LayoutItem,\n isUserAction: ?boolean,\n compactType: CompactType,\n cols: number\n): Layout {\n const compactH = compactType === \"horizontal\";\n // Compact vertically if not set to horizontal\n const compactV = compactType !== \"horizontal\";\n const preventCollision = collidesWith.static; // we're already colliding (not for static items)\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 // Reset isUserAction flag because we're not in the main collision anymore.\n isUserAction = false;\n\n // Make a mock item so we don't modify the item here, only modify in moveElement.\n const fakeItem: LayoutItem = {\n x: compactH ? Math.max(collidesWith.x - itemToMove.w, 0) : itemToMove.x,\n y: compactV ? Math.max(collidesWith.y - itemToMove.h, 0) : itemToMove.y,\n w: itemToMove.w,\n h: itemToMove.h,\n i: \"-1\"\n };\n\n // No collision? If so, we can go up there; otherwise, we'll end up moving down as normal\n if (!getFirstCollision(layout, fakeItem)) {\n log(\n `Doing reverse collision on ${itemToMove.i} up to [${fakeItem.x},${fakeItem.y}].`\n );\n return moveElement(\n layout,\n itemToMove,\n compactH ? fakeItem.x : undefined,\n compactV ? fakeItem.y : undefined,\n isUserAction,\n preventCollision,\n compactType,\n cols\n );\n }\n }\n\n return moveElement(\n layout,\n itemToMove,\n compactH ? itemToMove.x + 1 : undefined,\n compactV ? itemToMove.y + 1 : undefined,\n isUserAction,\n preventCollision,\n compactType,\n cols\n );\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 }: Position): Object {\n // Replace unitless items with px\n const translate = `translate(${left}px,${top}px)`;\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 }: Position): 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/**\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 sortLayoutItems(\n layout: Layout,\n compactType: CompactType\n): Layout {\n if (compactType === \"horizontal\") return sortLayoutItemsByColRow(layout);\n else return sortLayoutItemsByRowCol(layout);\n}\n\n/**\n * Sort layout items by row ascending and column ascending.\n *\n * Does not modify Layout.\n */\nexport function sortLayoutItemsByRowCol(layout: Layout): Layout {\n // Slice to clone array as sort modifies\n return layout.slice(0).sort(function(a, b) {\n if (a.y > b.y || (a.y === b.y && a.x > b.x)) {\n return 1;\n } else if (a.y === b.y && a.x === b.x) {\n // Without this, we can get different sort results in IE vs. Chrome/FF\n return 0;\n }\n return -1;\n });\n}\n\n/**\n * Sort layout items by column ascending then row ascending.\n *\n * Does not modify Layout.\n */\nexport function sortLayoutItemsByColRow(layout: Layout): Layout {\n return layout.slice(0).sort(function(a, b) {\n if (a.x > b.x || (a.x === b.x && a.y > b.y)) {\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 * Does not modify initialLayout.\n *\n * @param {Array} initialLayout Layout passed in through props.\n * @param {String} breakpoint Current responsive breakpoint.\n * @param {?String} compact Compaction option.\n * @return {Array} Working layout.\n */\nexport function synchronizeLayoutWithChildren(\n initialLayout: Layout,\n children: ReactChildren,\n cols: number,\n compactType: CompactType\n): Layout {\n initialLayout = initialLayout || [];\n\n // Generate one layout item per child.\n const layout: LayoutItem[] = [];\n React.Children.forEach(children, (child: ReactElement, i: number) => {\n // Don't overwrite if it already exists.\n const exists = getLayoutItem(initialLayout, String(child.key));\n if (exists) {\n layout[i] = cloneLayoutItem(exists);\n } else {\n if (!isProduction && child.props._grid) {\n console.warn(\n \"`_grid` properties on children have been deprecated as of React 15.2. \" + // eslint-disable-line\n \"Please use `data-grid` or add your properties directly to the `layout`.\"\n );\n }\n const g = child.props[\"data-grid\"] || child.props._grid;\n\n // Hey, this item has a data-grid property, use it.\n if (g) {\n if (!isProduction) {\n validateLayout([g], \"ReactGridLayout.children\");\n }\n layout[i] = cloneLayoutItem({ ...g, i: child.key });\n } else {\n // Nothing provided: ensure this is added to the bottom\n layout[i] = cloneLayoutItem({\n w: 1,\n h: 1,\n x: 0,\n y: bottom(layout),\n i: String(child.key)\n });\n }\n }\n });\n\n // Correct the layout.\n const correctedLayout = correctBounds(layout, { cols: cols });\n return compact(correctedLayout, compactType, cols);\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(\n layout: Layout,\n contextName: string = \"Layout\"\n): void {\n const subProps = [\"x\", \"y\", \"w\", \"h\"];\n if (!Array.isArray(layout))\n 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(\n \"ReactGridLayout: \" +\n contextName +\n \"[\" +\n i +\n \"].\" +\n subProps[j] +\n \" must be a number!\"\n );\n }\n }\n if (item.i && typeof item.i !== \"string\") {\n throw new Error(\n \"ReactGridLayout: \" + contextName + \"[\" + i + \"].i must be a string!\"\n );\n }\n if (item.static !== undefined && typeof item.static !== \"boolean\") {\n throw new Error(\n \"ReactGridLayout: \" +\n contextName +\n \"[\" +\n i +\n \"].static must be a boolean!\"\n );\n }\n }\n}\n\n// Legacy support for verticalCompact: false\nexport function compactType(\n props: ?{ verticalCompact: boolean, compactType: CompactType }\n): CompactType {\n const { verticalCompact, compactType } = props || {};\n return verticalCompact === false ? null : compactType;\n}\n\n// Flow can't really figure this out, so we just use Object\nexport function autoBindHandlers(el: Object, fns: Array): void {\n fns.forEach(key => (el[key] = el[key].bind(el)));\n}\n\nfunction log(...args) {\n if (!DEBUG) return;\n // eslint-disable-next-line no-console\n console.log(...args);\n}\n\nexport const noop = () => {};\n","module.exports = __WEBPACK_EXTERNAL_MODULE__2__;","/**\n * Lodash (Custom Build) \n * Build: `lodash modularize exports=\"npm\" -o ./`\n * Copyright JS Foundation and other contributors \n * Released under MIT license \n * Based on Underscore.js 1.8.3 \n * Copyright Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors\n */\n\n/** Used as the size to enable large array optimizations. */\nvar LARGE_ARRAY_SIZE = 200;\n\n/** Used to stand-in for `undefined` hash values. */\nvar HASH_UNDEFINED = '__lodash_hash_undefined__';\n\n/** Used to compose bitmasks for value comparisons. */\nvar COMPARE_PARTIAL_FLAG = 1,\n COMPARE_UNORDERED_FLAG = 2;\n\n/** Used as references for various `Number` constants. */\nvar MAX_SAFE_INTEGER = 9007199254740991;\n\n/** `Object#toString` result references. */\nvar argsTag = '[object Arguments]',\n arrayTag = '[object Array]',\n asyncTag = '[object AsyncFunction]',\n boolTag = '[object Boolean]',\n dateTag = '[object Date]',\n errorTag = '[object Error]',\n funcTag = '[object Function]',\n genTag = '[object GeneratorFunction]',\n mapTag = '[object Map]',\n numberTag = '[object Number]',\n nullTag = '[object Null]',\n objectTag = '[object Object]',\n promiseTag = '[object Promise]',\n proxyTag = '[object Proxy]',\n regexpTag = '[object RegExp]',\n setTag = '[object Set]',\n stringTag = '[object String]',\n symbolTag = '[object Symbol]',\n undefinedTag = '[object Undefined]',\n weakMapTag = '[object WeakMap]';\n\nvar arrayBufferTag = '[object ArrayBuffer]',\n dataViewTag = '[object DataView]',\n float32Tag = '[object Float32Array]',\n float64Tag = '[object Float64Array]',\n int8Tag = '[object Int8Array]',\n int16Tag = '[object Int16Array]',\n int32Tag = '[object Int32Array]',\n uint8Tag = '[object Uint8Array]',\n uint8ClampedTag = '[object Uint8ClampedArray]',\n uint16Tag = '[object Uint16Array]',\n uint32Tag = '[object Uint32Array]';\n\n/**\n * Used to match `RegExp`\n * [syntax characters](http://ecma-international.org/ecma-262/7.0/#sec-patterns).\n */\nvar reRegExpChar = /[\\\\^$.*+?()[\\]{}|]/g;\n\n/** Used to detect host constructors (Safari). */\nvar reIsHostCtor = /^\\[object .+?Constructor\\]$/;\n\n/** Used to detect unsigned integer values. */\nvar reIsUint = /^(?:0|[1-9]\\d*)$/;\n\n/** Used to identify `toStringTag` values of typed arrays. */\nvar typedArrayTags = {};\ntypedArrayTags[float32Tag] = typedArrayTags[float64Tag] =\ntypedArrayTags[int8Tag] = typedArrayTags[int16Tag] =\ntypedArrayTags[int32Tag] = typedArrayTags[uint8Tag] =\ntypedArrayTags[uint8ClampedTag] = typedArrayTags[uint16Tag] =\ntypedArrayTags[uint32Tag] = true;\ntypedArrayTags[argsTag] = typedArrayTags[arrayTag] =\ntypedArrayTags[arrayBufferTag] = typedArrayTags[boolTag] =\ntypedArrayTags[dataViewTag] = typedArrayTags[dateTag] =\ntypedArrayTags[errorTag] = typedArrayTags[funcTag] =\ntypedArrayTags[mapTag] = typedArrayTags[numberTag] =\ntypedArrayTags[objectTag] = typedArrayTags[regexpTag] =\ntypedArrayTags[setTag] = typedArrayTags[stringTag] =\ntypedArrayTags[weakMapTag] = false;\n\n/** Detect free variable `global` from Node.js. */\nvar freeGlobal = typeof global == 'object' && global && global.Object === Object && global;\n\n/** Detect free variable `self`. */\nvar freeSelf = typeof self == 'object' && self && self.Object === Object && self;\n\n/** Used as a reference to the global object. */\nvar root = freeGlobal || freeSelf || Function('return this')();\n\n/** Detect free variable `exports`. */\nvar freeExports = typeof exports == 'object' && exports && !exports.nodeType && exports;\n\n/** Detect free variable `module`. */\nvar freeModule = freeExports && typeof module == 'object' && module && !module.nodeType && module;\n\n/** Detect the popular CommonJS extension `module.exports`. */\nvar moduleExports = freeModule && freeModule.exports === freeExports;\n\n/** Detect free variable `process` from Node.js. */\nvar freeProcess = moduleExports && freeGlobal.process;\n\n/** Used to access faster Node.js helpers. */\nvar nodeUtil = (function() {\n try {\n return freeProcess && freeProcess.binding && freeProcess.binding('util');\n } catch (e) {}\n}());\n\n/* Node.js helper references. */\nvar nodeIsTypedArray = nodeUtil && nodeUtil.isTypedArray;\n\n/**\n * A specialized version of `_.filter` for arrays without support for\n * iteratee shorthands.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} predicate The function invoked per iteration.\n * @returns {Array} Returns the new filtered array.\n */\nfunction arrayFilter(array, predicate) {\n var index = -1,\n length = array == null ? 0 : array.length,\n resIndex = 0,\n result = [];\n\n while (++index < length) {\n var value = array[index];\n if (predicate(value, index, array)) {\n result[resIndex++] = value;\n }\n }\n return result;\n}\n\n/**\n * Appends the elements of `values` to `array`.\n *\n * @private\n * @param {Array} array The array to modify.\n * @param {Array} values The values to append.\n * @returns {Array} Returns `array`.\n */\nfunction arrayPush(array, values) {\n var index = -1,\n length = values.length,\n offset = array.length;\n\n while (++index < length) {\n array[offset + index] = values[index];\n }\n return array;\n}\n\n/**\n * A specialized version of `_.some` for arrays without support for iteratee\n * shorthands.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} predicate The function invoked per iteration.\n * @returns {boolean} Returns `true` if any element passes the predicate check,\n * else `false`.\n */\nfunction arraySome(array, predicate) {\n var index = -1,\n length = array == null ? 0 : array.length;\n\n while (++index < length) {\n if (predicate(array[index], index, array)) {\n return true;\n }\n }\n return false;\n}\n\n/**\n * The base implementation of `_.times` without support for iteratee shorthands\n * or max array length checks.\n *\n * @private\n * @param {number} n The number of times to invoke `iteratee`.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Array} Returns the array of results.\n */\nfunction baseTimes(n, iteratee) {\n var index = -1,\n result = Array(n);\n\n while (++index < n) {\n result[index] = iteratee(index);\n }\n return result;\n}\n\n/**\n * The base implementation of `_.unary` without support for storing metadata.\n *\n * @private\n * @param {Function} func The function to cap arguments for.\n * @returns {Function} Returns the new capped function.\n */\nfunction baseUnary(func) {\n return function(value) {\n return func(value);\n };\n}\n\n/**\n * Checks if a `cache` value for `key` exists.\n *\n * @private\n * @param {Object} cache The cache to query.\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction cacheHas(cache, key) {\n return cache.has(key);\n}\n\n/**\n * Gets the value at `key` of `object`.\n *\n * @private\n * @param {Object} [object] The object to query.\n * @param {string} key The key of the property to get.\n * @returns {*} Returns the property value.\n */\nfunction getValue(object, key) {\n return object == null ? undefined : object[key];\n}\n\n/**\n * Converts `map` to its key-value pairs.\n *\n * @private\n * @param {Object} map The map to convert.\n * @returns {Array} Returns the key-value pairs.\n */\nfunction mapToArray(map) {\n var index = -1,\n result = Array(map.size);\n\n map.forEach(function(value, key) {\n result[++index] = [key, value];\n });\n return result;\n}\n\n/**\n * Creates a unary function that invokes `func` with its argument transformed.\n *\n * @private\n * @param {Function} func The function to wrap.\n * @param {Function} transform The argument transform.\n * @returns {Function} Returns the new function.\n */\nfunction overArg(func, transform) {\n return function(arg) {\n return func(transform(arg));\n };\n}\n\n/**\n * Converts `set` to an array of its values.\n *\n * @private\n * @param {Object} set The set to convert.\n * @returns {Array} Returns the values.\n */\nfunction setToArray(set) {\n var index = -1,\n result = Array(set.size);\n\n set.forEach(function(value) {\n result[++index] = value;\n });\n return result;\n}\n\n/** Used for built-in method references. */\nvar arrayProto = Array.prototype,\n funcProto = Function.prototype,\n objectProto = Object.prototype;\n\n/** Used to detect overreaching core-js shims. */\nvar coreJsData = root['__core-js_shared__'];\n\n/** Used to resolve the decompiled source of functions. */\nvar funcToString = funcProto.toString;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/** Used to detect methods masquerading as native. */\nvar maskSrcKey = (function() {\n var uid = /[^.]+$/.exec(coreJsData && coreJsData.keys && coreJsData.keys.IE_PROTO || '');\n return uid ? ('Symbol(src)_1.' + uid) : '';\n}());\n\n/**\n * Used to resolve the\n * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar nativeObjectToString = objectProto.toString;\n\n/** Used to detect if a method is native. */\nvar reIsNative = RegExp('^' +\n funcToString.call(hasOwnProperty).replace(reRegExpChar, '\\\\$&')\n .replace(/hasOwnProperty|(function).*?(?=\\\\\\()| for .+?(?=\\\\\\])/g, '$1.*?') + '$'\n);\n\n/** Built-in value references. */\nvar Buffer = moduleExports ? root.Buffer : undefined,\n Symbol = root.Symbol,\n Uint8Array = root.Uint8Array,\n propertyIsEnumerable = objectProto.propertyIsEnumerable,\n splice = arrayProto.splice,\n symToStringTag = Symbol ? Symbol.toStringTag : undefined;\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeGetSymbols = Object.getOwnPropertySymbols,\n nativeIsBuffer = Buffer ? Buffer.isBuffer : undefined,\n nativeKeys = overArg(Object.keys, Object);\n\n/* Built-in method references that are verified to be native. */\nvar DataView = getNative(root, 'DataView'),\n Map = getNative(root, 'Map'),\n Promise = getNative(root, 'Promise'),\n Set = getNative(root, 'Set'),\n WeakMap = getNative(root, 'WeakMap'),\n nativeCreate = getNative(Object, 'create');\n\n/** Used to detect maps, sets, and weakmaps. */\nvar dataViewCtorString = toSource(DataView),\n mapCtorString = toSource(Map),\n promiseCtorString = toSource(Promise),\n setCtorString = toSource(Set),\n weakMapCtorString = toSource(WeakMap);\n\n/** Used to convert symbols to primitives and strings. */\nvar symbolProto = Symbol ? Symbol.prototype : undefined,\n symbolValueOf = symbolProto ? symbolProto.valueOf : undefined;\n\n/**\n * Creates a hash object.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction Hash(entries) {\n var index = -1,\n length = entries == null ? 0 : entries.length;\n\n this.clear();\n while (++index < length) {\n var entry = entries[index];\n this.set(entry[0], entry[1]);\n }\n}\n\n/**\n * Removes all key-value entries from the hash.\n *\n * @private\n * @name clear\n * @memberOf Hash\n */\nfunction hashClear() {\n this.__data__ = nativeCreate ? nativeCreate(null) : {};\n this.size = 0;\n}\n\n/**\n * Removes `key` and its value from the hash.\n *\n * @private\n * @name delete\n * @memberOf Hash\n * @param {Object} hash The hash to modify.\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction hashDelete(key) {\n var result = this.has(key) && delete this.__data__[key];\n this.size -= result ? 1 : 0;\n return result;\n}\n\n/**\n * Gets the hash value for `key`.\n *\n * @private\n * @name get\n * @memberOf Hash\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction hashGet(key) {\n var data = this.__data__;\n if (nativeCreate) {\n var result = data[key];\n return result === HASH_UNDEFINED ? undefined : result;\n }\n return hasOwnProperty.call(data, key) ? data[key] : undefined;\n}\n\n/**\n * Checks if a hash value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf Hash\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction hashHas(key) {\n var data = this.__data__;\n return nativeCreate ? (data[key] !== undefined) : hasOwnProperty.call(data, key);\n}\n\n/**\n * Sets the hash `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf Hash\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the hash instance.\n */\nfunction hashSet(key, value) {\n var data = this.__data__;\n this.size += this.has(key) ? 0 : 1;\n data[key] = (nativeCreate && value === undefined) ? HASH_UNDEFINED : value;\n return this;\n}\n\n// Add methods to `Hash`.\nHash.prototype.clear = hashClear;\nHash.prototype['delete'] = hashDelete;\nHash.prototype.get = hashGet;\nHash.prototype.has = hashHas;\nHash.prototype.set = hashSet;\n\n/**\n * Creates an list cache object.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction ListCache(entries) {\n var index = -1,\n length = entries == null ? 0 : entries.length;\n\n this.clear();\n while (++index < length) {\n var entry = entries[index];\n this.set(entry[0], entry[1]);\n }\n}\n\n/**\n * Removes all key-value entries from the list cache.\n *\n * @private\n * @name clear\n * @memberOf ListCache\n */\nfunction listCacheClear() {\n this.__data__ = [];\n this.size = 0;\n}\n\n/**\n * Removes `key` and its value from the list cache.\n *\n * @private\n * @name delete\n * @memberOf ListCache\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction listCacheDelete(key) {\n var data = this.__data__,\n index = assocIndexOf(data, key);\n\n if (index < 0) {\n return false;\n }\n var lastIndex = data.length - 1;\n if (index == lastIndex) {\n data.pop();\n } else {\n splice.call(data, index, 1);\n }\n --this.size;\n return true;\n}\n\n/**\n * Gets the list cache value for `key`.\n *\n * @private\n * @name get\n * @memberOf ListCache\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction listCacheGet(key) {\n var data = this.__data__,\n index = assocIndexOf(data, key);\n\n return index < 0 ? undefined : data[index][1];\n}\n\n/**\n * Checks if a list cache value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf ListCache\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction listCacheHas(key) {\n return assocIndexOf(this.__data__, key) > -1;\n}\n\n/**\n * Sets the list cache `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf ListCache\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the list cache instance.\n */\nfunction listCacheSet(key, value) {\n var data = this.__data__,\n index = assocIndexOf(data, key);\n\n if (index < 0) {\n ++this.size;\n data.push([key, value]);\n } else {\n data[index][1] = value;\n }\n return this;\n}\n\n// Add methods to `ListCache`.\nListCache.prototype.clear = listCacheClear;\nListCache.prototype['delete'] = listCacheDelete;\nListCache.prototype.get = listCacheGet;\nListCache.prototype.has = listCacheHas;\nListCache.prototype.set = listCacheSet;\n\n/**\n * Creates a map cache object to store key-value pairs.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction MapCache(entries) {\n var index = -1,\n length = entries == null ? 0 : entries.length;\n\n this.clear();\n while (++index < length) {\n var entry = entries[index];\n this.set(entry[0], entry[1]);\n }\n}\n\n/**\n * Removes all key-value entries from the map.\n *\n * @private\n * @name clear\n * @memberOf MapCache\n */\nfunction mapCacheClear() {\n this.size = 0;\n this.__data__ = {\n 'hash': new Hash,\n 'map': new (Map || ListCache),\n 'string': new Hash\n };\n}\n\n/**\n * Removes `key` and its value from the map.\n *\n * @private\n * @name delete\n * @memberOf MapCache\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction mapCacheDelete(key) {\n var result = getMapData(this, key)['delete'](key);\n this.size -= result ? 1 : 0;\n return result;\n}\n\n/**\n * Gets the map value for `key`.\n *\n * @private\n * @name get\n * @memberOf MapCache\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction mapCacheGet(key) {\n return getMapData(this, key).get(key);\n}\n\n/**\n * Checks if a map value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf MapCache\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction mapCacheHas(key) {\n return getMapData(this, key).has(key);\n}\n\n/**\n * Sets the map `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf MapCache\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the map cache instance.\n */\nfunction mapCacheSet(key, value) {\n var data = getMapData(this, key),\n size = data.size;\n\n data.set(key, value);\n this.size += data.size == size ? 0 : 1;\n return this;\n}\n\n// Add methods to `MapCache`.\nMapCache.prototype.clear = mapCacheClear;\nMapCache.prototype['delete'] = mapCacheDelete;\nMapCache.prototype.get = mapCacheGet;\nMapCache.prototype.has = mapCacheHas;\nMapCache.prototype.set = mapCacheSet;\n\n/**\n *\n * Creates an array cache object to store unique values.\n *\n * @private\n * @constructor\n * @param {Array} [values] The values to cache.\n */\nfunction SetCache(values) {\n var index = -1,\n length = values == null ? 0 : values.length;\n\n this.__data__ = new MapCache;\n while (++index < length) {\n this.add(values[index]);\n }\n}\n\n/**\n * Adds `value` to the array cache.\n *\n * @private\n * @name add\n * @memberOf SetCache\n * @alias push\n * @param {*} value The value to cache.\n * @returns {Object} Returns the cache instance.\n */\nfunction setCacheAdd(value) {\n this.__data__.set(value, HASH_UNDEFINED);\n return this;\n}\n\n/**\n * Checks if `value` is in the array cache.\n *\n * @private\n * @name has\n * @memberOf SetCache\n * @param {*} value The value to search for.\n * @returns {number} Returns `true` if `value` is found, else `false`.\n */\nfunction setCacheHas(value) {\n return this.__data__.has(value);\n}\n\n// Add methods to `SetCache`.\nSetCache.prototype.add = SetCache.prototype.push = setCacheAdd;\nSetCache.prototype.has = setCacheHas;\n\n/**\n * Creates a stack cache object to store key-value pairs.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction Stack(entries) {\n var data = this.__data__ = new ListCache(entries);\n this.size = data.size;\n}\n\n/**\n * Removes all key-value entries from the stack.\n *\n * @private\n * @name clear\n * @memberOf Stack\n */\nfunction stackClear() {\n this.__data__ = new ListCache;\n this.size = 0;\n}\n\n/**\n * Removes `key` and its value from the stack.\n *\n * @private\n * @name delete\n * @memberOf Stack\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction stackDelete(key) {\n var data = this.__data__,\n result = data['delete'](key);\n\n this.size = data.size;\n return result;\n}\n\n/**\n * Gets the stack value for `key`.\n *\n * @private\n * @name get\n * @memberOf Stack\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction stackGet(key) {\n return this.__data__.get(key);\n}\n\n/**\n * Checks if a stack value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf Stack\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction stackHas(key) {\n return this.__data__.has(key);\n}\n\n/**\n * Sets the stack `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf Stack\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the stack cache instance.\n */\nfunction stackSet(key, value) {\n var data = this.__data__;\n if (data instanceof ListCache) {\n var pairs = data.__data__;\n if (!Map || (pairs.length < LARGE_ARRAY_SIZE - 1)) {\n pairs.push([key, value]);\n this.size = ++data.size;\n return this;\n }\n data = this.__data__ = new MapCache(pairs);\n }\n data.set(key, value);\n this.size = data.size;\n return this;\n}\n\n// Add methods to `Stack`.\nStack.prototype.clear = stackClear;\nStack.prototype['delete'] = stackDelete;\nStack.prototype.get = stackGet;\nStack.prototype.has = stackHas;\nStack.prototype.set = stackSet;\n\n/**\n * Creates an array of the enumerable property names of the array-like `value`.\n *\n * @private\n * @param {*} value The value to query.\n * @param {boolean} inherited Specify returning inherited property names.\n * @returns {Array} Returns the array of property names.\n */\nfunction arrayLikeKeys(value, inherited) {\n var isArr = isArray(value),\n isArg = !isArr && isArguments(value),\n isBuff = !isArr && !isArg && isBuffer(value),\n isType = !isArr && !isArg && !isBuff && isTypedArray(value),\n skipIndexes = isArr || isArg || isBuff || isType,\n result = skipIndexes ? baseTimes(value.length, String) : [],\n length = result.length;\n\n for (var key in value) {\n if ((inherited || hasOwnProperty.call(value, key)) &&\n !(skipIndexes && (\n // Safari 9 has enumerable `arguments.length` in strict mode.\n key == 'length' ||\n // Node.js 0.10 has enumerable non-index properties on buffers.\n (isBuff && (key == 'offset' || key == 'parent')) ||\n // PhantomJS 2 has enumerable non-index properties on typed arrays.\n (isType && (key == 'buffer' || key == 'byteLength' || key == 'byteOffset')) ||\n // Skip index properties.\n isIndex(key, length)\n ))) {\n result.push(key);\n }\n }\n return result;\n}\n\n/**\n * Gets the index at which the `key` is found in `array` of key-value pairs.\n *\n * @private\n * @param {Array} array The array to inspect.\n * @param {*} key The key to search for.\n * @returns {number} Returns the index of the matched value, else `-1`.\n */\nfunction assocIndexOf(array, key) {\n var length = array.length;\n while (length--) {\n if (eq(array[length][0], key)) {\n return length;\n }\n }\n return -1;\n}\n\n/**\n * The base implementation of `getAllKeys` and `getAllKeysIn` which uses\n * `keysFunc` and `symbolsFunc` to get the enumerable property names and\n * symbols of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {Function} keysFunc The function to get the keys of `object`.\n * @param {Function} symbolsFunc The function to get the symbols of `object`.\n * @returns {Array} Returns the array of property names and symbols.\n */\nfunction baseGetAllKeys(object, keysFunc, symbolsFunc) {\n var result = keysFunc(object);\n return isArray(object) ? result : arrayPush(result, symbolsFunc(object));\n}\n\n/**\n * The base implementation of `getTag` without fallbacks for buggy environments.\n *\n * @private\n * @param {*} value The value to query.\n * @returns {string} Returns the `toStringTag`.\n */\nfunction baseGetTag(value) {\n if (value == null) {\n return value === undefined ? undefinedTag : nullTag;\n }\n return (symToStringTag && symToStringTag in Object(value))\n ? getRawTag(value)\n : objectToString(value);\n}\n\n/**\n * The base implementation of `_.isArguments`.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an `arguments` object,\n */\nfunction baseIsArguments(value) {\n return isObjectLike(value) && baseGetTag(value) == argsTag;\n}\n\n/**\n * The base implementation of `_.isEqual` which supports partial comparisons\n * and tracks traversed objects.\n *\n * @private\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @param {boolean} bitmask The bitmask flags.\n * 1 - Unordered comparison\n * 2 - Partial comparison\n * @param {Function} [customizer] The function to customize comparisons.\n * @param {Object} [stack] Tracks traversed `value` and `other` objects.\n * @returns {boolean} Returns `true` if the values are equivalent, else `false`.\n */\nfunction baseIsEqual(value, other, bitmask, customizer, stack) {\n if (value === other) {\n return true;\n }\n if (value == null || other == null || (!isObjectLike(value) && !isObjectLike(other))) {\n return value !== value && other !== other;\n }\n return baseIsEqualDeep(value, other, bitmask, customizer, baseIsEqual, stack);\n}\n\n/**\n * A specialized version of `baseIsEqual` for arrays and objects which performs\n * deep comparisons and tracks traversed objects enabling objects with circular\n * references to be compared.\n *\n * @private\n * @param {Object} object The object to compare.\n * @param {Object} other The other object to compare.\n * @param {number} bitmask The bitmask flags. See `baseIsEqual` for more details.\n * @param {Function} customizer The function to customize comparisons.\n * @param {Function} equalFunc The function to determine equivalents of values.\n * @param {Object} [stack] Tracks traversed `object` and `other` objects.\n * @returns {boolean} Returns `true` if the objects are equivalent, else `false`.\n */\nfunction baseIsEqualDeep(object, other, bitmask, customizer, equalFunc, stack) {\n var objIsArr = isArray(object),\n othIsArr = isArray(other),\n objTag = objIsArr ? arrayTag : getTag(object),\n othTag = othIsArr ? arrayTag : getTag(other);\n\n objTag = objTag == argsTag ? objectTag : objTag;\n othTag = othTag == argsTag ? objectTag : othTag;\n\n var objIsObj = objTag == objectTag,\n othIsObj = othTag == objectTag,\n isSameTag = objTag == othTag;\n\n if (isSameTag && isBuffer(object)) {\n if (!isBuffer(other)) {\n return false;\n }\n objIsArr = true;\n objIsObj = false;\n }\n if (isSameTag && !objIsObj) {\n stack || (stack = new Stack);\n return (objIsArr || isTypedArray(object))\n ? equalArrays(object, other, bitmask, customizer, equalFunc, stack)\n : equalByTag(object, other, objTag, bitmask, customizer, equalFunc, stack);\n }\n if (!(bitmask & COMPARE_PARTIAL_FLAG)) {\n var objIsWrapped = objIsObj && hasOwnProperty.call(object, '__wrapped__'),\n othIsWrapped = othIsObj && hasOwnProperty.call(other, '__wrapped__');\n\n if (objIsWrapped || othIsWrapped) {\n var objUnwrapped = objIsWrapped ? object.value() : object,\n othUnwrapped = othIsWrapped ? other.value() : other;\n\n stack || (stack = new Stack);\n return equalFunc(objUnwrapped, othUnwrapped, bitmask, customizer, stack);\n }\n }\n if (!isSameTag) {\n return false;\n }\n stack || (stack = new Stack);\n return equalObjects(object, other, bitmask, customizer, equalFunc, stack);\n}\n\n/**\n * The base implementation of `_.isNative` without bad shim checks.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a native function,\n * else `false`.\n */\nfunction baseIsNative(value) {\n if (!isObject(value) || isMasked(value)) {\n return false;\n }\n var pattern = isFunction(value) ? reIsNative : reIsHostCtor;\n return pattern.test(toSource(value));\n}\n\n/**\n * The base implementation of `_.isTypedArray` without Node.js optimizations.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a typed array, else `false`.\n */\nfunction baseIsTypedArray(value) {\n return isObjectLike(value) &&\n isLength(value.length) && !!typedArrayTags[baseGetTag(value)];\n}\n\n/**\n * The base implementation of `_.keys` which doesn't treat sparse arrays as dense.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names.\n */\nfunction baseKeys(object) {\n if (!isPrototype(object)) {\n return nativeKeys(object);\n }\n var result = [];\n for (var key in Object(object)) {\n if (hasOwnProperty.call(object, key) && key != 'constructor') {\n result.push(key);\n }\n }\n return result;\n}\n\n/**\n * A specialized version of `baseIsEqualDeep` for arrays with support for\n * partial deep comparisons.\n *\n * @private\n * @param {Array} array The array to compare.\n * @param {Array} other The other array to compare.\n * @param {number} bitmask The bitmask flags. See `baseIsEqual` for more details.\n * @param {Function} customizer The function to customize comparisons.\n * @param {Function} equalFunc The function to determine equivalents of values.\n * @param {Object} stack Tracks traversed `array` and `other` objects.\n * @returns {boolean} Returns `true` if the arrays are equivalent, else `false`.\n */\nfunction equalArrays(array, other, bitmask, customizer, equalFunc, stack) {\n var isPartial = bitmask & COMPARE_PARTIAL_FLAG,\n arrLength = array.length,\n othLength = other.length;\n\n if (arrLength != othLength && !(isPartial && othLength > arrLength)) {\n return false;\n }\n // Assume cyclic values are equal.\n var stacked = stack.get(array);\n if (stacked && stack.get(other)) {\n return stacked == other;\n }\n var index = -1,\n result = true,\n seen = (bitmask & COMPARE_UNORDERED_FLAG) ? new SetCache : undefined;\n\n stack.set(array, other);\n stack.set(other, array);\n\n // Ignore non-index properties.\n while (++index < arrLength) {\n var arrValue = array[index],\n othValue = other[index];\n\n if (customizer) {\n var compared = isPartial\n ? customizer(othValue, arrValue, index, other, array, stack)\n : customizer(arrValue, othValue, index, array, other, stack);\n }\n if (compared !== undefined) {\n if (compared) {\n continue;\n }\n result = false;\n break;\n }\n // Recursively compare arrays (susceptible to call stack limits).\n if (seen) {\n if (!arraySome(other, function(othValue, othIndex) {\n if (!cacheHas(seen, othIndex) &&\n (arrValue === othValue || equalFunc(arrValue, othValue, bitmask, customizer, stack))) {\n return seen.push(othIndex);\n }\n })) {\n result = false;\n break;\n }\n } else if (!(\n arrValue === othValue ||\n equalFunc(arrValue, othValue, bitmask, customizer, stack)\n )) {\n result = false;\n break;\n }\n }\n stack['delete'](array);\n stack['delete'](other);\n return result;\n}\n\n/**\n * A specialized version of `baseIsEqualDeep` for comparing objects of\n * the same `toStringTag`.\n *\n * **Note:** This function only supports comparing values with tags of\n * `Boolean`, `Date`, `Error`, `Number`, `RegExp`, or `String`.\n *\n * @private\n * @param {Object} object The object to compare.\n * @param {Object} other The other object to compare.\n * @param {string} tag The `toStringTag` of the objects to compare.\n * @param {number} bitmask The bitmask flags. See `baseIsEqual` for more details.\n * @param {Function} customizer The function to customize comparisons.\n * @param {Function} equalFunc The function to determine equivalents of values.\n * @param {Object} stack Tracks traversed `object` and `other` objects.\n * @returns {boolean} Returns `true` if the objects are equivalent, else `false`.\n */\nfunction equalByTag(object, other, tag, bitmask, customizer, equalFunc, stack) {\n switch (tag) {\n case dataViewTag:\n if ((object.byteLength != other.byteLength) ||\n (object.byteOffset != other.byteOffset)) {\n return false;\n }\n object = object.buffer;\n other = other.buffer;\n\n case arrayBufferTag:\n if ((object.byteLength != other.byteLength) ||\n !equalFunc(new Uint8Array(object), new Uint8Array(other))) {\n return false;\n }\n return true;\n\n case boolTag:\n case dateTag:\n case numberTag:\n // Coerce booleans to `1` or `0` and dates to milliseconds.\n // Invalid dates are coerced to `NaN`.\n return eq(+object, +other);\n\n case errorTag:\n return object.name == other.name && object.message == other.message;\n\n case regexpTag:\n case stringTag:\n // Coerce regexes to strings and treat strings, primitives and objects,\n // as equal. See http://www.ecma-international.org/ecma-262/7.0/#sec-regexp.prototype.tostring\n // for more details.\n return object == (other + '');\n\n case mapTag:\n var convert = mapToArray;\n\n case setTag:\n var isPartial = bitmask & COMPARE_PARTIAL_FLAG;\n convert || (convert = setToArray);\n\n if (object.size != other.size && !isPartial) {\n return false;\n }\n // Assume cyclic values are equal.\n var stacked = stack.get(object);\n if (stacked) {\n return stacked == other;\n }\n bitmask |= COMPARE_UNORDERED_FLAG;\n\n // Recursively compare objects (susceptible to call stack limits).\n stack.set(object, other);\n var result = equalArrays(convert(object), convert(other), bitmask, customizer, equalFunc, stack);\n stack['delete'](object);\n return result;\n\n case symbolTag:\n if (symbolValueOf) {\n return symbolValueOf.call(object) == symbolValueOf.call(other);\n }\n }\n return false;\n}\n\n/**\n * A specialized version of `baseIsEqualDeep` for objects with support for\n * partial deep comparisons.\n *\n * @private\n * @param {Object} object The object to compare.\n * @param {Object} other The other object to compare.\n * @param {number} bitmask The bitmask flags. See `baseIsEqual` for more details.\n * @param {Function} customizer The function to customize comparisons.\n * @param {Function} equalFunc The function to determine equivalents of values.\n * @param {Object} stack Tracks traversed `object` and `other` objects.\n * @returns {boolean} Returns `true` if the objects are equivalent, else `false`.\n */\nfunction equalObjects(object, other, bitmask, customizer, equalFunc, stack) {\n var isPartial = bitmask & COMPARE_PARTIAL_FLAG,\n objProps = getAllKeys(object),\n objLength = objProps.length,\n othProps = getAllKeys(other),\n othLength = othProps.length;\n\n if (objLength != othLength && !isPartial) {\n return false;\n }\n var index = objLength;\n while (index--) {\n var key = objProps[index];\n if (!(isPartial ? key in other : hasOwnProperty.call(other, key))) {\n return false;\n }\n }\n // Assume cyclic values are equal.\n var stacked = stack.get(object);\n if (stacked && stack.get(other)) {\n return stacked == other;\n }\n var result = true;\n stack.set(object, other);\n stack.set(other, object);\n\n var skipCtor = isPartial;\n while (++index < objLength) {\n key = objProps[index];\n var objValue = object[key],\n othValue = other[key];\n\n if (customizer) {\n var compared = isPartial\n ? customizer(othValue, objValue, key, other, object, stack)\n : customizer(objValue, othValue, key, object, other, stack);\n }\n // Recursively compare objects (susceptible to call stack limits).\n if (!(compared === undefined\n ? (objValue === othValue || equalFunc(objValue, othValue, bitmask, customizer, stack))\n : compared\n )) {\n result = false;\n break;\n }\n skipCtor || (skipCtor = key == 'constructor');\n }\n if (result && !skipCtor) {\n var objCtor = object.constructor,\n othCtor = other.constructor;\n\n // Non `Object` object instances with different constructors are not equal.\n if (objCtor != othCtor &&\n ('constructor' in object && 'constructor' in other) &&\n !(typeof objCtor == 'function' && objCtor instanceof objCtor &&\n typeof othCtor == 'function' && othCtor instanceof othCtor)) {\n result = false;\n }\n }\n stack['delete'](object);\n stack['delete'](other);\n return result;\n}\n\n/**\n * Creates an array of own enumerable property names and symbols of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names and symbols.\n */\nfunction getAllKeys(object) {\n return baseGetAllKeys(object, keys, getSymbols);\n}\n\n/**\n * Gets the data for `map`.\n *\n * @private\n * @param {Object} map The map to query.\n * @param {string} key The reference key.\n * @returns {*} Returns the map data.\n */\nfunction getMapData(map, key) {\n var data = map.__data__;\n return isKeyable(key)\n ? data[typeof key == 'string' ? 'string' : 'hash']\n : data.map;\n}\n\n/**\n * Gets the native function at `key` of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {string} key The key of the method to get.\n * @returns {*} Returns the function if it's native, else `undefined`.\n */\nfunction getNative(object, key) {\n var value = getValue(object, key);\n return baseIsNative(value) ? value : undefined;\n}\n\n/**\n * A specialized version of `baseGetTag` which ignores `Symbol.toStringTag` values.\n *\n * @private\n * @param {*} value The value to query.\n * @returns {string} Returns the raw `toStringTag`.\n */\nfunction getRawTag(value) {\n var isOwn = hasOwnProperty.call(value, symToStringTag),\n tag = value[symToStringTag];\n\n try {\n value[symToStringTag] = undefined;\n var unmasked = true;\n } catch (e) {}\n\n var result = nativeObjectToString.call(value);\n if (unmasked) {\n if (isOwn) {\n value[symToStringTag] = tag;\n } else {\n delete value[symToStringTag];\n }\n }\n return result;\n}\n\n/**\n * Creates an array of the own enumerable symbols of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of symbols.\n */\nvar getSymbols = !nativeGetSymbols ? stubArray : function(object) {\n if (object == null) {\n return [];\n }\n object = Object(object);\n return arrayFilter(nativeGetSymbols(object), function(symbol) {\n return propertyIsEnumerable.call(object, symbol);\n });\n};\n\n/**\n * Gets the `toStringTag` of `value`.\n *\n * @private\n * @param {*} value The value to query.\n * @returns {string} Returns the `toStringTag`.\n */\nvar getTag = baseGetTag;\n\n// Fallback for data views, maps, sets, and weak maps in IE 11 and promises in Node.js < 6.\nif ((DataView && getTag(new DataView(new ArrayBuffer(1))) != dataViewTag) ||\n (Map && getTag(new Map) != mapTag) ||\n (Promise && getTag(Promise.resolve()) != promiseTag) ||\n (Set && getTag(new Set) != setTag) ||\n (WeakMap && getTag(new WeakMap) != weakMapTag)) {\n getTag = function(value) {\n var result = baseGetTag(value),\n Ctor = result == objectTag ? value.constructor : undefined,\n ctorString = Ctor ? toSource(Ctor) : '';\n\n if (ctorString) {\n switch (ctorString) {\n case dataViewCtorString: return dataViewTag;\n case mapCtorString: return mapTag;\n case promiseCtorString: return promiseTag;\n case setCtorString: return setTag;\n case weakMapCtorString: return weakMapTag;\n }\n }\n return result;\n };\n}\n\n/**\n * Checks if `value` is a valid array-like index.\n *\n * @private\n * @param {*} value The value to check.\n * @param {number} [length=MAX_SAFE_INTEGER] The upper bounds of a valid index.\n * @returns {boolean} Returns `true` if `value` is a valid index, else `false`.\n */\nfunction isIndex(value, length) {\n length = length == null ? MAX_SAFE_INTEGER : length;\n return !!length &&\n (typeof value == 'number' || reIsUint.test(value)) &&\n (value > -1 && value % 1 == 0 && value < length);\n}\n\n/**\n * Checks if `value` is suitable for use as unique object key.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is suitable, else `false`.\n */\nfunction isKeyable(value) {\n var type = typeof value;\n return (type == 'string' || type == 'number' || type == 'symbol' || type == 'boolean')\n ? (value !== '__proto__')\n : (value === null);\n}\n\n/**\n * Checks if `func` has its source masked.\n *\n * @private\n * @param {Function} func The function to check.\n * @returns {boolean} Returns `true` if `func` is masked, else `false`.\n */\nfunction isMasked(func) {\n return !!maskSrcKey && (maskSrcKey in func);\n}\n\n/**\n * Checks if `value` is likely a prototype object.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a prototype, else `false`.\n */\nfunction isPrototype(value) {\n var Ctor = value && value.constructor,\n proto = (typeof Ctor == 'function' && Ctor.prototype) || objectProto;\n\n return value === proto;\n}\n\n/**\n * Converts `value` to a string using `Object.prototype.toString`.\n *\n * @private\n * @param {*} value The value to convert.\n * @returns {string} Returns the converted string.\n */\nfunction objectToString(value) {\n return nativeObjectToString.call(value);\n}\n\n/**\n * Converts `func` to its source code.\n *\n * @private\n * @param {Function} func The function to convert.\n * @returns {string} Returns the source code.\n */\nfunction toSource(func) {\n if (func != null) {\n try {\n return funcToString.call(func);\n } catch (e) {}\n try {\n return (func + '');\n } catch (e) {}\n }\n return '';\n}\n\n/**\n * Performs a\n * [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\n * comparison between two values to determine if they are equivalent.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @returns {boolean} Returns `true` if the values are equivalent, else `false`.\n * @example\n *\n * var object = { 'a': 1 };\n * var other = { 'a': 1 };\n *\n * _.eq(object, object);\n * // => true\n *\n * _.eq(object, other);\n * // => false\n *\n * _.eq('a', 'a');\n * // => true\n *\n * _.eq('a', Object('a'));\n * // => false\n *\n * _.eq(NaN, NaN);\n * // => true\n */\nfunction eq(value, other) {\n return value === other || (value !== value && other !== other);\n}\n\n/**\n * Checks if `value` is likely an `arguments` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an `arguments` object,\n * else `false`.\n * @example\n *\n * _.isArguments(function() { return arguments; }());\n * // => true\n *\n * _.isArguments([1, 2, 3]);\n * // => false\n */\nvar isArguments = baseIsArguments(function() { return arguments; }()) ? baseIsArguments : function(value) {\n return isObjectLike(value) && hasOwnProperty.call(value, 'callee') &&\n !propertyIsEnumerable.call(value, 'callee');\n};\n\n/**\n * Checks if `value` is classified as an `Array` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an array, else `false`.\n * @example\n *\n * _.isArray([1, 2, 3]);\n * // => true\n *\n * _.isArray(document.body.children);\n * // => false\n *\n * _.isArray('abc');\n * // => false\n *\n * _.isArray(_.noop);\n * // => false\n */\nvar isArray = Array.isArray;\n\n/**\n * Checks if `value` is array-like. A value is considered array-like if it's\n * not a function and has a `value.length` that's an integer greater than or\n * equal to `0` and less than or equal to `Number.MAX_SAFE_INTEGER`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is array-like, else `false`.\n * @example\n *\n * _.isArrayLike([1, 2, 3]);\n * // => true\n *\n * _.isArrayLike(document.body.children);\n * // => true\n *\n * _.isArrayLike('abc');\n * // => true\n *\n * _.isArrayLike(_.noop);\n * // => false\n */\nfunction isArrayLike(value) {\n return value != null && isLength(value.length) && !isFunction(value);\n}\n\n/**\n * Checks if `value` is a buffer.\n *\n * @static\n * @memberOf _\n * @since 4.3.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a buffer, else `false`.\n * @example\n *\n * _.isBuffer(new Buffer(2));\n * // => true\n *\n * _.isBuffer(new Uint8Array(2));\n * // => false\n */\nvar isBuffer = nativeIsBuffer || stubFalse;\n\n/**\n * Performs a deep comparison between two values to determine if they are\n * equivalent.\n *\n * **Note:** This method supports comparing arrays, array buffers, booleans,\n * date objects, error objects, maps, numbers, `Object` objects, regexes,\n * sets, strings, symbols, and typed arrays. `Object` objects are compared\n * by their own, not inherited, enumerable properties. Functions and DOM\n * nodes are compared by strict equality, i.e. `===`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @returns {boolean} Returns `true` if the values are equivalent, else `false`.\n * @example\n *\n * var object = { 'a': 1 };\n * var other = { 'a': 1 };\n *\n * _.isEqual(object, other);\n * // => true\n *\n * object === other;\n * // => false\n */\nfunction isEqual(value, other) {\n return baseIsEqual(value, other);\n}\n\n/**\n * Checks if `value` is classified as a `Function` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a function, else `false`.\n * @example\n *\n * _.isFunction(_);\n * // => true\n *\n * _.isFunction(/abc/);\n * // => false\n */\nfunction isFunction(value) {\n if (!isObject(value)) {\n return false;\n }\n // The use of `Object#toString` avoids issues with the `typeof` operator\n // in Safari 9 which returns 'object' for typed arrays and other constructors.\n var tag = baseGetTag(value);\n return tag == funcTag || tag == genTag || tag == asyncTag || tag == proxyTag;\n}\n\n/**\n * Checks if `value` is a valid array-like length.\n *\n * **Note:** This method is loosely based on\n * [`ToLength`](http://ecma-international.org/ecma-262/7.0/#sec-tolength).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a valid length, else `false`.\n * @example\n *\n * _.isLength(3);\n * // => true\n *\n * _.isLength(Number.MIN_VALUE);\n * // => false\n *\n * _.isLength(Infinity);\n * // => false\n *\n * _.isLength('3');\n * // => false\n */\nfunction isLength(value) {\n return typeof value == 'number' &&\n value > -1 && value % 1 == 0 && value <= MAX_SAFE_INTEGER;\n}\n\n/**\n * Checks if `value` is the\n * [language type](http://www.ecma-international.org/ecma-262/7.0/#sec-ecmascript-language-types)\n * of `Object`. (e.g. arrays, functions, objects, regexes, `new Number(0)`, and `new String('')`)\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an object, else `false`.\n * @example\n *\n * _.isObject({});\n * // => true\n *\n * _.isObject([1, 2, 3]);\n * // => true\n *\n * _.isObject(_.noop);\n * // => true\n *\n * _.isObject(null);\n * // => false\n */\nfunction isObject(value) {\n var type = typeof value;\n return value != null && (type == 'object' || type == 'function');\n}\n\n/**\n * Checks if `value` is object-like. A value is object-like if it's not `null`\n * and has a `typeof` result of \"object\".\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is object-like, else `false`.\n * @example\n *\n * _.isObjectLike({});\n * // => true\n *\n * _.isObjectLike([1, 2, 3]);\n * // => true\n *\n * _.isObjectLike(_.noop);\n * // => false\n *\n * _.isObjectLike(null);\n * // => false\n */\nfunction isObjectLike(value) {\n return value != null && typeof value == 'object';\n}\n\n/**\n * Checks if `value` is classified as a typed array.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a typed array, else `false`.\n * @example\n *\n * _.isTypedArray(new Uint8Array);\n * // => true\n *\n * _.isTypedArray([]);\n * // => false\n */\nvar isTypedArray = nodeIsTypedArray ? baseUnary(nodeIsTypedArray) : baseIsTypedArray;\n\n/**\n * Creates an array of the own enumerable property names of `object`.\n *\n * **Note:** Non-object values are coerced to objects. See the\n * [ES spec](http://ecma-international.org/ecma-262/7.0/#sec-object.keys)\n * for more details.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Object\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names.\n * @example\n *\n * function Foo() {\n * this.a = 1;\n * this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.keys(new Foo);\n * // => ['a', 'b'] (iteration order is not guaranteed)\n *\n * _.keys('hi');\n * // => ['0', '1']\n */\nfunction keys(object) {\n return isArrayLike(object) ? arrayLikeKeys(object) : baseKeys(object);\n}\n\n/**\n * This method returns a new empty array.\n *\n * @static\n * @memberOf _\n * @since 4.13.0\n * @category Util\n * @returns {Array} Returns the new empty array.\n * @example\n *\n * var arrays = _.times(2, _.stubArray);\n *\n * console.log(arrays);\n * // => [[], []]\n *\n * console.log(arrays[0] === arrays[1]);\n * // => false\n */\nfunction stubArray() {\n return [];\n}\n\n/**\n * This method returns `false`.\n *\n * @static\n * @memberOf _\n * @since 4.13.0\n * @category Util\n * @returns {boolean} Returns `false`.\n * @example\n *\n * _.times(2, _.stubFalse);\n * // => [false, false]\n */\nfunction stubFalse() {\n return false;\n}\n\nmodule.exports = isEqual;\n","// @flow\n\nimport { cloneLayout, compact, correctBounds } from \"./utils\";\n\nimport type { CompactType, Layout } from \"./utils\";\n\nexport type Breakpoint = string;\nexport type DefaultBreakpoints = 'lg' | 'md' | 'sm' | 'xs' | 'xxs';\n\n// + indicates read-only\nexport type ResponsiveLayout = {\n +[breakpoint: T]: Layout\n};\nexport type Breakpoints = {\n +[breakpoint: T]: number\n};\n\n/**\n * Given a width, find the highest breakpoint that matches is valid for it (width > breakpoint).\n *\n * @param {Object} breakpoints Breakpoints object (e.g. {lg: 1200, md: 960, ...})\n * @param {Number} width Screen width.\n * @return {String} Highest breakpoint that is less than width.\n */\nexport function getBreakpointFromWidth(\n breakpoints: Breakpoints,\n width: number\n): Breakpoint {\n const sorted = sortBreakpoints(breakpoints);\n let matching = sorted[0];\n for (let i = 1, len = sorted.length; i < len; i++) {\n const breakpointName = sorted[i];\n if (width > breakpoints[breakpointName]) matching = breakpointName;\n }\n return matching;\n}\n\n/**\n * Given a breakpoint, get the # of cols set for it.\n * @param {String} breakpoint Breakpoint name.\n * @param {Object} cols Map of breakpoints to cols.\n * @return {Number} Number of cols.\n */\nexport function getColsFromBreakpoint(\n breakpoint: Breakpoint,\n cols: Breakpoints\n): number {\n if (!cols[breakpoint]) {\n throw new Error(\n \"ResponsiveReactGridLayout: `cols` entry for breakpoint \" +\n breakpoint +\n \" is missing!\"\n );\n }\n return cols[breakpoint];\n}\n\n/**\n * Given existing layouts and a new breakpoint, find or generate a new layout.\n *\n * This finds the layout above the new one and generates from it, if it exists.\n *\n * @param {Object} layouts Existing layouts.\n * @param {Array} breakpoints All breakpoints.\n * @param {String} breakpoint New breakpoint.\n * @param {String} breakpoint Last breakpoint (for fallback).\n * @param {Number} cols Column count at new breakpoint.\n * @param {Boolean} verticalCompact Whether or not to compact the layout\n * vertically.\n * @return {Array} New layout.\n */\nexport function findOrGenerateResponsiveLayout(\n layouts: ResponsiveLayout,\n breakpoints: Breakpoints,\n breakpoint: Breakpoint,\n lastBreakpoint: Breakpoint,\n cols: number,\n compactType: CompactType\n): Layout {\n // If it already exists, just return it.\n if (layouts[breakpoint]) return cloneLayout(layouts[breakpoint]);\n // Find or generate the next layout\n let layout = layouts[lastBreakpoint];\n const breakpointsSorted = sortBreakpoints(breakpoints);\n const breakpointsAbove = breakpointsSorted.slice(\n breakpointsSorted.indexOf(breakpoint)\n );\n for (let i = 0, len = breakpointsAbove.length; i < len; i++) {\n const b = breakpointsAbove[i];\n if (layouts[b]) {\n layout = layouts[b];\n break;\n }\n }\n layout = cloneLayout(layout || []); // clone layout so we don't modify existing items\n return compact(correctBounds(layout, { cols: cols }), compactType, cols);\n}\n\n/**\n * Given breakpoints, return an array of breakpoints sorted by width. This is usually\n * e.g. ['xxs', 'xs', 'sm', ...]\n *\n * @param {Object} breakpoints Key/value pair of breakpoint names to widths.\n * @return {Array} Sorted breakpoints.\n */\nexport function sortBreakpoints(breakpoints: Breakpoints): Array {\n const keys: Array = Object.keys(breakpoints);\n return keys.sort(function(a, b) {\n return breakpoints[a] - breakpoints[b];\n });\n}\n","module.exports = __WEBPACK_EXTERNAL_MODULE__5__;","/*!\n Copyright (c) 2017 Jed Watson.\n Licensed under the MIT License (MIT), see\n http://jedwatson.github.io/classnames\n*/\n/* global define */\n\n(function () {\n\t'use strict';\n\n\tvar hasOwn = {}.hasOwnProperty;\n\n\tfunction classNames () {\n\t\tvar classes = [];\n\n\t\tfor (var i = 0; i < arguments.length; i++) {\n\t\t\tvar arg = arguments[i];\n\t\t\tif (!arg) continue;\n\n\t\t\tvar argType = typeof arg;\n\n\t\t\tif (argType === 'string' || argType === 'number') {\n\t\t\t\tclasses.push(arg);\n\t\t\t} else if (Array.isArray(arg) && arg.length) {\n\t\t\t\tvar inner = classNames.apply(null, arg);\n\t\t\t\tif (inner) {\n\t\t\t\t\tclasses.push(inner);\n\t\t\t\t}\n\t\t\t} else if (argType === 'object') {\n\t\t\t\tfor (var key in arg) {\n\t\t\t\t\tif (hasOwn.call(arg, key) && arg[key]) {\n\t\t\t\t\t\tclasses.push(key);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\treturn classes.join(' ');\n\t}\n\n\tif (typeof module !== 'undefined' && module.exports) {\n\t\tclassNames.default = classNames;\n\t\tmodule.exports = classNames;\n\t} else if (typeof define === 'function' && typeof define.amd === 'object' && define.amd) {\n\t\t// register as 'classnames', consistent with npm package name\n\t\tdefine('classnames', [], function () {\n\t\t\treturn classNames;\n\t\t});\n\t} else {\n\t\twindow.classNames = classNames;\n\t}\n}());\n","!function(t,e){\"object\"==typeof exports&&\"object\"==typeof module?module.exports=e(require(\"react\"),require(\"react-dom\")):\"function\"==typeof define&&define.amd?define([\"react\",\"react-dom\"],e):\"object\"==typeof exports?exports.ReactDraggable=e(require(\"react\"),require(\"react-dom\")):t.ReactDraggable=e(t.React,t.ReactDOM)}(window,function(t,e){return function(t){var e={};function n(r){if(e[r])return e[r].exports;var o=e[r]={i:r,l:!1,exports:{}};return t[r].call(o.exports,o,o.exports,n),o.l=!0,o.exports}return n.m=t,n.c=e,n.d=function(t,e,r){n.o(t,e)||Object.defineProperty(t,e,{enumerable:!0,get:r})},n.r=function(t){\"undefined\"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(t,Symbol.toStringTag,{value:\"Module\"}),Object.defineProperty(t,\"__esModule\",{value:!0})},n.t=function(t,e){if(1&e&&(t=n(t)),8&e)return t;if(4&e&&\"object\"==typeof t&&t&&t.__esModule)return t;var r=Object.create(null);if(n.r(r),Object.defineProperty(r,\"default\",{enumerable:!0,value:t}),2&e&&\"string\"!=typeof t)for(var o in t)n.d(r,o,function(e){return t[e]}.bind(null,o));return r},n.n=function(t){var e=t&&t.__esModule?function(){return t.default}:function(){return t};return n.d(e,\"a\",e),e},n.o=function(t,e){return Object.prototype.hasOwnProperty.call(t,e)},n.p=\"\",n(n.s=4)}([function(t,e,n){t.exports=n(5)()},function(e,n){e.exports=t},function(t,n){t.exports=e},function(t,e,n){var r;\n/*!\n Copyright (c) 2017 Jed Watson.\n Licensed under the MIT License (MIT), see\n http://jedwatson.github.io/classnames\n*/!function(){\"use strict\";var n={}.hasOwnProperty;function o(){for(var t=[],e=0;e0&&void 0!==arguments[0]?arguments[0]:\"transform\";if(\"undefined\"==typeof window||void 0===window.document)return\"\";var e=window.document.documentElement.style;if(t in e)return\"\";for(var n=0;n0&&void 0!==arguments[0]?arguments[0]:{})}function X(t){return\"both\"===t.props.axis||\"x\"===t.props.axis}function Y(t){return\"both\"===t.props.axis||\"y\"===t.props.axis}function L(t,e,n){var r=\"number\"==typeof e?function(t,e){return t.targetTouches&&f(t.targetTouches,function(t){return e===t.identifier})||t.changedTouches&&f(t.changedTouches,function(t){return e===t.identifier})}(t,e):null;if(\"number\"==typeof e&&!r)return null;var o=I(n);return function(t,e,n){var r=e===e.ownerDocument.body?{left:0,top:0}:e.getBoundingClientRect();return{x:(t.clientX+e.scrollLeft-r.left)/n,y:(t.clientY+e.scrollTop-r.top)/n}}(r||t,n.props.offsetParent||o.offsetParent||o.ownerDocument.body,n.props.scale)}function R(t,e,n){var r=t.state,o=!d(r.lastX),a=I(t);return o?{node:a,deltaX:0,deltaY:0,lastX:e,lastY:n,x:e,y:n}:{node:a,deltaX:e-r.lastX,deltaY:n-r.lastY,lastX:r.lastX,lastY:r.lastY,x:e,y:n}}function A(t,e){var n=t.props.scale;return{node:e.node,x:t.state.x+e.deltaX/n,y:t.state.y+e.deltaY/n,deltaX:e.deltaX/n,deltaY:e.deltaY/n,lastX:t.state.x,lastY:t.state.y}}function I(t){var e=u.a.findDOMNode(t);if(!e)throw new Error(\": Unmounted during event!\");return e}function U(t){return(U=\"function\"==typeof Symbol&&\"symbol\"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&\"function\"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?\"symbol\":typeof t})(t)}function V(t,e){return function(t){if(Array.isArray(t))return t}(t)||function(t,e){var n=[],r=!0,o=!1,a=void 0;try{for(var i,s=t[Symbol.iterator]();!(r=(i=s.next()).done)&&(n.push(i.value),!e||n.length!==e);r=!0);}catch(t){o=!0,a=t}finally{try{r||null==s.return||s.return()}finally{if(o)throw a}}return n}(t,e)||function(){throw new TypeError(\"Invalid attempt to destructure non-iterable instance\")}()}function W(t,e){for(var n=0;n not mounted on DragStart!\");var r=e.ownerDocument;if(!(n.props.disabled||!(t.target instanceof r.defaultView.Node)||n.props.handle&&!D(t.target,n.props.handle,e)||n.props.cancel&&D(t.target,n.props.cancel,e))){var o=function(t){return t.targetTouches&&t.targetTouches[0]?t.targetTouches[0].identifier:t.changedTouches&&t.changedTouches[0]?t.changedTouches[0].identifier:void 0}(t);n.setState({touchIdentifier:o});var a=L(t,o,H(n));if(null!=a){var i=a.x,s=a.y,c=R(H(n),i,s);n.props.onStart,!1!==n.props.onStart(t,c)&&(n.props.enableUserSelectHack&&M(r),n.setState({dragging:!0,lastX:i,lastY:s}),x(r,F.move,n.handleDrag),x(r,F.stop,n.handleDragStop))}}}),G(H(n),\"handleDrag\",function(t){\"touchmove\"===t.type&&t.preventDefault();var e=L(t,n.state.touchIdentifier,H(n));if(null!=e){var r,o,a,i=e.x,s=e.y;if(Array.isArray(n.props.grid)){var u=i-n.state.lastX,c=s-n.state.lastY,l=V((r=n.props.grid,o=u,a=c,[Math.round(o/r[0])*r[0],Math.round(a/r[1])*r[1]]),2);if(u=l[0],c=l[1],!u&&!c)return;i=n.state.lastX+u,s=n.state.lastY+c}var f=R(H(n),i,s);if(!1!==n.props.onDrag(t,f))n.setState({lastX:i,lastY:s});else try{n.handleDragStop(new MouseEvent(\"mouseup\"))}catch(t){var p=document.createEvent(\"MouseEvents\");p.initMouseEvent(\"mouseup\",!0,!0,window,0,0,0,0,0,!1,!1,!1,!1,0,null),n.handleDragStop(p)}}}),G(H(n),\"handleDragStop\",function(t){if(n.state.dragging){var e=L(t,n.state.touchIdentifier,H(n));if(null!=e){var r=e.x,o=e.y,a=R(H(n),r,o),i=u.a.findDOMNode(H(n));i&&n.props.enableUserSelectHack&&k(i.ownerDocument),n.setState({dragging:!1,lastX:NaN,lastY:NaN}),n.props.onStop(t,a),i&&(P(i.ownerDocument,F.move,n.handleDrag),P(i.ownerDocument,F.stop,n.handleDragStop))}}}),G(H(n),\"onMouseDown\",function(t){return F=z.mouse,n.handleDragStart(t)}),G(H(n),\"onMouseUp\",function(t){return F=z.mouse,n.handleDragStop(t)}),G(H(n),\"onTouchStart\",function(t){return F=z.touch,n.handleDragStart(t)}),G(H(n),\"onTouchEnd\",function(t){return F=z.touch,n.handleDragStop(t)}),n}var n,r,a;return function(t,e){if(\"function\"!=typeof e&&null!==e)throw new TypeError(\"Super expression must either be null or a function\");t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,writable:!0,configurable:!0}}),e&&q(t,e)}(e,o.a.Component),n=e,(r=[{key:\"componentWillUnmount\",value:function(){var t=u.a.findDOMNode(this);if(t){var e=t.ownerDocument;P(e,z.mouse.move,this.handleDrag),P(e,z.touch.move,this.handleDrag),P(e,z.mouse.stop,this.handleDragStop),P(e,z.touch.stop,this.handleDragStop),this.props.enableUserSelectHack&&k(e)}}},{key:\"render\",value:function(){return o.a.cloneElement(o.a.Children.only(this.props.children),{style:_(this.props.children.props.style),onMouseDown:this.onMouseDown,onTouchStart:this.onTouchStart,onMouseUp:this.onMouseUp,onTouchEnd:this.onTouchEnd})}}])&&W(n.prototype,r),a&&W(n,a),e}();function K(t){return(K=\"function\"==typeof Symbol&&\"symbol\"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&\"function\"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?\"symbol\":typeof t})(t)}function Q(){return(Q=Object.assign||function(t){for(var e=1;e=0||(o[n]=t[n]);return o}(t,e);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(t);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(t,n)&&(o[n]=t[n])}return o}function $(t,e){return function(t){if(Array.isArray(t))return t}(t)||function(t,e){var n=[],r=!0,o=!1,a=void 0;try{for(var i,s=t[Symbol.iterator]();!(r=(i=s.next()).done)&&(n.push(i.value),!e||n.length!==e);r=!0);}catch(t){o=!0,a=t}finally{try{r||null==s.return||s.return()}finally{if(o)throw a}}return n}(t,e)||function(){throw new TypeError(\"Invalid attempt to destructure non-iterable instance\")}()}function tt(t,e){var n=Object.keys(t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(t);e&&(r=r.filter(function(e){return Object.getOwnPropertyDescriptor(t,e).enumerable})),n.push.apply(n,r)}return n}function et(t){for(var e=1;e, without drag handlers. This will make this component effectively undraggable. Please attach `onDrag` or `onStop` handlers so you can adjust the `position` of this element.\"),n}return function(t,e){if(\"function\"!=typeof e&&null!==e)throw new TypeError(\"Super expression must either be null or a function\");t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,writable:!0,configurable:!0}}),e&&it(t,e)}(e,o.a.Component),at(e,null,[{key:\"getDerivedStateFromProps\",value:function(t,e){var n=t.position,r=e.prevPropsPosition;return!n||r&&n.x===r.x&&n.y===r.y?null:{x:n.x,y:n.y,prevPropsPosition:et({},n)}}}]),at(e,[{key:\"componentDidMount\",value:function(){void 0!==window.SVGElement&&u.a.findDOMNode(this)instanceof window.SVGElement&&this.setState({isElementSVG:!0})}},{key:\"componentWillUnmount\",value:function(){this.setState({dragging:!1})}},{key:\"render\",value:function(){var t,e=this.props,n=(e.axis,e.bounds,e.children),r=e.defaultPosition,a=e.defaultClassName,i=e.defaultClassNameDragging,s=e.defaultClassNameDragged,u=e.position,c=e.positionOffset,f=(e.scale,Z(e,[\"axis\",\"bounds\",\"children\",\"defaultPosition\",\"defaultClassName\",\"defaultClassNameDragging\",\"defaultClassNameDragged\",\"position\",\"positionOffset\",\"scale\"])),p={},d=null,g=!Boolean(u)||this.state.dragging,y=u||r,h={x:X(this)&&g?this.state.x:y.x,y:Y(this)&&g?this.state.y:y.y};this.state.isElementSVG?d=function(t,e){return C(t,e,\"\")}(h,c):p=function(t,e){var n=C(t,e,\"px\");return w({},b(\"transform\",m),n)}(h,c);var v=l()(n.props.className||\"\",a,(st(t={},i,this.state.dragging),st(t,s,this.state.dragged),t));return o.a.createElement(J,Q({},f,{onStart:this.onDragStart,onDrag:this.onDrag,onStop:this.onDragStop}),o.a.cloneElement(o.a.Children.only(n),{className:v,style:et({},n.props.style,{},p),transform:d}))}}]),e}();st(ut,\"displayName\",\"Draggable\"),st(ut,\"propTypes\",et({},J.propTypes,{axis:i.a.oneOf([\"both\",\"x\",\"y\",\"none\"]),bounds:i.a.oneOfType([i.a.shape({left:i.a.number,right:i.a.number,top:i.a.number,bottom:i.a.number}),i.a.string,i.a.oneOf([!1])]),defaultClassName:i.a.string,defaultClassNameDragging:i.a.string,defaultClassNameDragged:i.a.string,defaultPosition:i.a.shape({x:i.a.number,y:i.a.number}),positionOffset:i.a.shape({x:i.a.oneOfType([i.a.number,i.a.string]),y:i.a.oneOfType([i.a.number,i.a.string])}),position:i.a.shape({x:i.a.number,y:i.a.number}),className:y,style:y,transform:y})),st(ut,\"defaultProps\",et({},J.defaultProps,{axis:\"both\",bounds:!1,defaultClassName:\"react-draggable\",defaultClassNameDragging:\"react-draggable-dragging\",defaultClassNameDragged:\"react-draggable-dragged\",defaultPosition:{x:0,y:0},position:null,scale:1}))}])});\n//# sourceMappingURL=react-draggable.min.js.map","// @flow\nimport type { Position } from \"./utils\";\n\nexport type PositionParams = {\n margin: [number, number],\n containerPadding: [number, number],\n containerWidth: number,\n cols: number,\n rowHeight: number,\n maxRows: number\n};\n\n// Helper for generating column width\nexport function calcGridColWidth(positionParams: PositionParams): number {\n const { margin, containerPadding, containerWidth, cols } = positionParams;\n return (\n (containerWidth - margin[0] * (cols - 1) - containerPadding[0] * 2) / cols\n );\n}\n\n/**\n * Return position on the page given an x, y, w, h.\n * left, top, width, height are all in pixels.\n * @param {PositionParams} positionParams Parameters of grid needed for coordinates calculations.\n * @param {Number} x X coordinate in grid units.\n * @param {Number} y Y coordinate in grid units.\n * @param {Number} w W coordinate in grid units.\n * @param {Number} h H coordinate in grid units.\n * @return {Position} Object containing coords.\n */\nexport function calcGridItemPosition(\n positionParams: PositionParams,\n x: number,\n y: number,\n w: number,\n h: number,\n state: ?Object\n): Position {\n const { margin, containerPadding, rowHeight } = positionParams;\n const colWidth = calcGridColWidth(positionParams);\n const out = {};\n\n // If resizing, use the exact width and height as returned from resizing callbacks.\n if (state && state.resizing) {\n out.width = Math.round(state.resizing.width);\n out.height = Math.round(state.resizing.height);\n }\n // Otherwise, calculate from grid units.\n else {\n // 0 * Infinity === NaN, which causes problems with resize constraints;\n // Fix this if it occurs.\n // Note we do it here rather than later because Math.round(Infinity) causes deopt\n out.width =\n w === Infinity\n ? w\n : Math.round(colWidth * w + Math.max(0, w - 1) * margin[0]);\n out.height =\n h === Infinity\n ? h\n : Math.round(rowHeight * h + Math.max(0, h - 1) * margin[1]);\n }\n\n // If dragging, use the exact width and height as returned from dragging callbacks.\n if (state && state.dragging) {\n out.top = Math.round(state.dragging.top);\n out.left = Math.round(state.dragging.left);\n }\n // Otherwise, calculate from grid units.\n else {\n out.top = Math.round((rowHeight + margin[1]) * y + containerPadding[1]);\n out.left = Math.round((colWidth + margin[0]) * x + containerPadding[0]);\n }\n\n return out;\n}\n\n/**\n * Translate x and y coordinates from pixels to grid units.\n * @param {PositionParams} positionParams Parameters of grid needed for coordinates calculations.\n * @param {Number} top Top position (relative to parent) in pixels.\n * @param {Number} left Left position (relative to parent) in pixels.\n * @param {Number} w W coordinate in grid units.\n * @param {Number} h H coordinate in grid units.\n * @return {Object} x and y in grid units.\n */\nexport function calcXY(\n positionParams: PositionParams,\n top: number,\n left: number,\n w: number,\n h: number\n): { x: number, y: number } {\n const { margin, cols, rowHeight, maxRows } = positionParams;\n const colWidth = calcGridColWidth(positionParams);\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 - margin[0]) / (colWidth + margin[0]));\n let y = Math.round((top - margin[1]) / (rowHeight + margin[1]));\n\n // Capping\n x = Math.max(Math.min(x, cols - w), 0);\n y = Math.max(Math.min(y, maxRows - h), 0);\n\n return { x, y };\n}\n\n/**\n * Given a height and width in pixel values, calculate grid units.\n * @param {PositionParams} positionParams Parameters of grid needed for coordinates calcluations.\n * @param {Number} height Height in pixels.\n * @param {Number} width Width in pixels.\n * @param {Number} x X coordinate in grid units.\n * @param {Number} y Y coordinate in grid units.\n * @return {Object} w, h as grid units.\n */\nexport function calcWH(\n positionParams: PositionParams,\n width: number,\n height: number,\n x: number,\n y: number\n): { w: number, h: number } {\n const { margin, maxRows, cols, rowHeight } = positionParams;\n const colWidth = calcGridColWidth(positionParams);\n\n // width = colWidth * w - (margin * (w - 1))\n // ...\n // w = (width + margin) / (colWidth + margin)\n let w = Math.round((width + margin[0]) / (colWidth + margin[0]));\n let h = Math.round((height + margin[1]) / (rowHeight + margin[1]));\n\n // Capping\n w = Math.max(Math.min(w, cols - x), 0);\n h = Math.max(Math.min(h, maxRows - y), 0);\n return { w, h };\n}\n","// @flow\nimport React from \"react\";\nimport ReactDOM from \"react-dom\";\nimport PropTypes from \"prop-types\";\nimport { DraggableCore } from \"react-draggable\";\nimport { Resizable } from \"react-resizable\";\nimport { fastPositionEqual, perc, setTopLeft, setTransform } from \"./utils\";\nimport { calcGridItemPosition, calcXY, calcWH } from \"./calculateUtils\";\nimport classNames from \"classnames\";\nimport type { Element as ReactElement, Node as ReactNode } from \"react\";\n\nimport type {\n ReactDraggableCallbackData,\n GridDragEvent,\n GridResizeEvent,\n DroppingPosition,\n Position\n} from \"./utils\";\n\nimport type { PositionParams } from \"./calculateUtils\";\n\ntype PartialPosition = { top: number, left: number };\ntype GridItemCallback = (\n i: string,\n w: number,\n h: number,\n Data\n) => void;\n\ntype State = {\n resizing: ?{ width: number, height: number },\n dragging: ?{ top: number, left: number },\n className: string\n};\n\ntype Props = {\n children: ReactElement,\n cols: number,\n containerWidth: number,\n margin: [number, number],\n containerPadding: [number, number],\n rowHeight: number,\n maxRows: number,\n isDraggable: boolean,\n isResizable: boolean,\n static?: boolean,\n useCSSTransforms?: boolean,\n usePercentages?: boolean,\n transformScale: number,\n droppingPosition?: DroppingPosition,\n\n className: string,\n style?: Object,\n // Draggability\n cancel: string,\n handle: string,\n\n x: number,\n y: number,\n w: number,\n h: number,\n\n minW: number,\n maxW: number,\n minH: number,\n maxH: number,\n i: string,\n\n onDrag?: GridItemCallback,\n onDragStart?: GridItemCallback,\n onDragStop?: GridItemCallback,\n onResize?: GridItemCallback,\n onResizeStart?: GridItemCallback,\n onResizeStop?: GridItemCallback\n};\n\n/**\n * An individual item within a ReactGridLayout.\n */\nexport default class GridItem extends React.Component {\n static propTypes = {\n // Children must be only a single element\n children: PropTypes.element,\n\n // General grid attributes\n cols: PropTypes.number.isRequired,\n containerWidth: PropTypes.number.isRequired,\n rowHeight: PropTypes.number.isRequired,\n margin: PropTypes.array.isRequired,\n maxRows: PropTypes.number.isRequired,\n containerPadding: PropTypes.array.isRequired,\n\n // These are all in grid units\n x: PropTypes.number.isRequired,\n y: PropTypes.number.isRequired,\n w: PropTypes.number.isRequired,\n h: PropTypes.number.isRequired,\n\n // All optional\n minW: function(props: Props, propName: string) {\n const value = props[propName];\n if (typeof value !== \"number\") return new Error(\"minWidth not Number\");\n if (value > props.w || value > props.maxW)\n return new Error(\"minWidth larger than item width/maxWidth\");\n },\n\n maxW: function(props: Props, propName: string) {\n const value = props[propName];\n if (typeof value !== \"number\") return new Error(\"maxWidth not Number\");\n if (value < props.w || value < props.minW)\n return new Error(\"maxWidth smaller than item width/minWidth\");\n },\n\n minH: function(props: Props, propName: string) {\n const value = props[propName];\n if (typeof value !== \"number\") return new Error(\"minHeight not Number\");\n if (value > props.h || value > props.maxH)\n return new Error(\"minHeight larger than item height/maxHeight\");\n },\n\n maxH: function(props: Props, propName: string) {\n const value = props[propName];\n if (typeof value !== \"number\") return new Error(\"maxHeight not Number\");\n if (value < props.h || value < props.minH)\n return new Error(\"maxHeight smaller than item height/minHeight\");\n },\n\n // ID is nice to have for callbacks\n i: PropTypes.string.isRequired,\n\n // Functions\n onDragStop: PropTypes.func,\n onDragStart: PropTypes.func,\n onDrag: PropTypes.func,\n onResizeStop: PropTypes.func,\n onResizeStart: PropTypes.func,\n onResize: PropTypes.func,\n\n // Flags\n isDraggable: PropTypes.bool.isRequired,\n isResizable: PropTypes.bool.isRequired,\n static: PropTypes.bool,\n\n // Use CSS transforms instead of top/left\n useCSSTransforms: PropTypes.bool.isRequired,\n transformScale: PropTypes.number,\n\n // Others\n className: PropTypes.string,\n // Selector for draggable handle\n handle: PropTypes.string,\n // Selector for draggable cancel (see react-draggable)\n cancel: PropTypes.string,\n // Current position of a dropping element\n droppingPosition: PropTypes.shape({\n e: PropTypes.object.isRequired,\n left: PropTypes.number.isRequired,\n top: PropTypes.number.isRequired\n })\n };\n\n static defaultProps = {\n className: \"\",\n cancel: \"\",\n handle: \"\",\n minH: 1,\n minW: 1,\n maxH: Infinity,\n maxW: Infinity,\n transformScale: 1\n };\n\n state: State = {\n resizing: null,\n dragging: null,\n className: \"\"\n };\n\n currentNode: HTMLElement;\n\n shouldComponentUpdate(nextProps: Props, nextState: State) {\n // We can't deeply compare children. If the developer memoizes them, we can\n // use this optimization.\n if (this.props.children !== nextProps.children) return true;\n if (this.props.droppingPosition !== nextProps.droppingPosition) return true;\n // TODO memoize these calculations so they don't take so long?\n const oldPosition = calcGridItemPosition(\n this.getPositionParams(this.props),\n this.props.x,\n this.props.y,\n this.props.w,\n this.props.h,\n this.state\n );\n const newPosition = calcGridItemPosition(\n this.getPositionParams(nextProps),\n nextProps.x,\n nextProps.y,\n nextProps.w,\n nextProps.h,\n nextState\n );\n return (\n !fastPositionEqual(oldPosition, newPosition) ||\n this.props.useCSSTransforms !== nextProps.useCSSTransforms\n );\n }\n\n componentDidMount() {\n this.moveDroppingItem({});\n }\n\n componentDidUpdate(prevProps: Props) {\n this.moveDroppingItem(prevProps);\n }\n\n // When a droppingPosition is present, this means we should fire a move event, as if we had moved\n // this element by `x, y` pixels.\n moveDroppingItem(prevProps: Props) {\n const { droppingPosition } = this.props;\n if (!droppingPosition) return;\n\n const prevDroppingPosition = prevProps.droppingPosition || {\n left: 0,\n top: 0\n };\n const { dragging } = this.state;\n\n if (!this.currentNode) {\n // eslint-disable-next-line react/no-find-dom-node\n this.currentNode = ((ReactDOM.findDOMNode(this): any): HTMLElement);\n }\n\n const shouldDrag =\n (dragging && droppingPosition.left !== prevDroppingPosition.left) ||\n droppingPosition.top !== prevDroppingPosition.top;\n\n if (!dragging) {\n this.onDragStart(droppingPosition.e, {\n node: this.currentNode,\n deltaX: droppingPosition.left,\n deltaY: droppingPosition.top\n });\n } else if (shouldDrag) {\n const deltaX = droppingPosition.left - dragging.left;\n const deltaY = droppingPosition.top - dragging.top;\n\n this.onDrag(droppingPosition.e, {\n node: this.currentNode,\n deltaX,\n deltaY\n });\n }\n }\n\n getPositionParams(props: Props = this.props): PositionParams {\n return {\n cols: props.cols,\n containerPadding: props.containerPadding,\n containerWidth: props.containerWidth,\n margin: props.margin,\n maxRows: props.maxRows,\n rowHeight: props.rowHeight\n };\n }\n\n /**\n * This is where we set the grid item's absolute placement. It gets a little tricky because we want to do it\n * well when server rendering, and the only way to do that properly is to use percentage width/left because\n * we don't know exactly what the browser viewport is.\n * Unfortunately, CSS Transforms, which are great for performance, break in this instance because a percentage\n * left is relative to the item itself, not its container! So we cannot use them on the server rendering pass.\n *\n * @param {Object} pos Position object with width, height, left, top.\n * @return {Object} Style object.\n */\n createStyle(pos: Position): { [key: string]: ?string } {\n const { usePercentages, containerWidth, useCSSTransforms } = this.props;\n\n let style;\n // CSS Transforms support (default)\n if (useCSSTransforms) {\n style = setTransform(pos);\n } else {\n // top,left (slow)\n style = setTopLeft(pos);\n\n // This is used for server rendering.\n if (usePercentages) {\n style.left = perc(pos.left / containerWidth);\n style.width = perc(pos.width / containerWidth);\n }\n }\n\n return style;\n }\n\n /**\n * Mix a Draggable instance into a child.\n * @param {Element} child Child element.\n * @return {Element} Child wrapped in Draggable.\n */\n mixinDraggable(\n child: ReactElement,\n isDraggable: boolean\n ): ReactElement {\n return (\n \n {child}\n \n );\n }\n\n /**\n * Mix a Resizable instance into a child.\n * @param {Element} child Child element.\n * @param {Object} position Position object (pixel values)\n * @return {Element} Child wrapped in Resizable.\n */\n mixinResizable(\n child: ReactElement,\n position: Position,\n isResizable: boolean\n ): ReactElement {\n const { cols, x, minW, minH, maxW, maxH, transformScale } = this.props;\n const positionParams = this.getPositionParams();\n\n // This is the max possible width - doesn't go to infinity because of the width of the window\n const maxWidth = calcGridItemPosition(positionParams, 0, 0, cols - x, 0)\n .width;\n\n // Calculate min/max constraints using our min & maxes\n const mins = calcGridItemPosition(positionParams, 0, 0, minW, minH);\n const maxes = calcGridItemPosition(positionParams, 0, 0, maxW, maxH);\n const minConstraints = [mins.width, mins.height];\n const maxConstraints = [\n Math.min(maxes.width, maxWidth),\n Math.min(maxes.height, Infinity)\n ];\n return (\n \n {child}\n \n );\n }\n\n /**\n * onDragStart event handler\n * @param {Event} e event data\n * @param {Object} callbackData an object with node, delta and position information\n */\n onDragStart = (e: Event, { node }: ReactDraggableCallbackData) => {\n if (!this.props.onDragStart) return;\n\n const newPosition: PartialPosition = { top: 0, left: 0 };\n\n // TODO: this wont work on nested parents\n const { offsetParent } = node;\n if (!offsetParent) return;\n const parentRect = offsetParent.getBoundingClientRect();\n const clientRect = node.getBoundingClientRect();\n const cLeft = clientRect.left / this.props.transformScale;\n const pLeft = parentRect.left / this.props.transformScale;\n const cTop = clientRect.top / this.props.transformScale;\n const pTop = parentRect.top / this.props.transformScale;\n newPosition.left = cLeft - pLeft + offsetParent.scrollLeft;\n newPosition.top = cTop - pTop + offsetParent.scrollTop;\n this.setState({ dragging: newPosition });\n\n const { x, y } = calcXY(\n this.getPositionParams(),\n newPosition.top,\n newPosition.left,\n this.props.w,\n this.props.h\n );\n\n return (\n this.props.onDragStart &&\n this.props.onDragStart.call(this, this.props.i, x, y, {\n e,\n node,\n newPosition\n })\n );\n };\n\n /**\n * onDrag event handler\n * @param {Event} e event data\n * @param {Object} callbackData an object with node, delta and position information\n */\n onDrag = (e: Event, { node, deltaX, deltaY }: ReactDraggableCallbackData) => {\n const { onDrag, transformScale } = this.props;\n if (!onDrag) return;\n deltaX /= transformScale;\n deltaY /= transformScale;\n\n const newPosition: PartialPosition = { top: 0, left: 0 };\n\n if (!this.state.dragging)\n throw new Error(\"onDrag called before onDragStart.\");\n newPosition.left = this.state.dragging.left + deltaX;\n newPosition.top = this.state.dragging.top + deltaY;\n this.setState({ dragging: newPosition });\n\n const { x, y } = calcXY(\n this.getPositionParams(),\n newPosition.top,\n newPosition.left,\n this.props.w,\n this.props.h\n );\n\n return (\n onDrag &&\n onDrag.call(this, this.props.i, x, y, {\n e,\n node,\n newPosition\n })\n );\n };\n\n /**\n * onDragStop event handler\n * @param {Event} e event data\n * @param {Object} callbackData an object with node, delta and position information\n */\n onDragStop = (e: Event, { node }: ReactDraggableCallbackData) => {\n if (!this.props.onDragStop) return;\n\n const newPosition: PartialPosition = { top: 0, left: 0 };\n\n if (!this.state.dragging)\n throw new Error(\"onDragEnd called before onDragStart.\");\n newPosition.left = this.state.dragging.left;\n newPosition.top = this.state.dragging.top;\n this.setState({ dragging: null });\n\n const { x, y } = calcXY(\n this.getPositionParams(),\n newPosition.top,\n newPosition.left,\n this.props.w,\n this.props.h\n );\n\n return (\n this.props.onDragStop &&\n this.props.onDragStop.call(this, this.props.i, x, y, {\n e,\n node,\n newPosition\n })\n );\n };\n\n /**\n * onResizeStop event handler\n * @param {Event} e event data\n * @param {Object} callbackData an object with node and size information\n */\n onResizeStop = (\n e: Event,\n callbackData: { node: HTMLElement, size: Position }\n ) => {\n this.onResizeHandler(e, callbackData, \"onResizeStop\");\n };\n\n /**\n * onResizeStart event handler\n * @param {Event} e event data\n * @param {Object} callbackData an object with node and size information\n */\n onResizeStart = (\n e: Event,\n callbackData: { node: HTMLElement, size: Position }\n ) => {\n this.onResizeHandler(e, callbackData, \"onResizeStart\");\n };\n\n /**\n * onResize event handler\n * @param {Event} e event data\n * @param {Object} callbackData an object with node and size information\n */\n onResize = (\n e: Event,\n callbackData: { node: HTMLElement, size: Position }\n ) => {\n this.onResizeHandler(e, callbackData, \"onResize\");\n };\n\n /**\n * Wrapper around drag events to provide more useful data.\n * All drag events call the function with the given handler name,\n * with the signature (index, x, y).\n *\n * @param {String} handlerName Handler name to wrap.\n * @return {Function} Handler function.\n */\n onResizeHandler(\n e: Event,\n { node, size }: { node: HTMLElement, size: Position },\n handlerName: string\n ) {\n const handler = this.props[handlerName];\n if (!handler) return;\n const { cols, x, y, i, maxW, minW, maxH, minH } = this.props;\n\n // Get new XY\n let { w, h } = calcWH(\n this.getPositionParams(),\n size.width,\n size.height,\n x,\n y\n );\n\n // Cap w at numCols\n w = Math.min(w, cols - x);\n // Ensure w is at least 1\n w = Math.max(w, 1);\n\n // Min/max capping\n w = Math.max(Math.min(w, maxW), minW);\n h = Math.max(Math.min(h, maxH), minH);\n\n this.setState({ resizing: handlerName === \"onResizeStop\" ? null : size });\n\n handler.call(this, i, w, h, { e, node, size });\n }\n\n render(): ReactNode {\n const {\n x,\n y,\n w,\n h,\n isDraggable,\n isResizable,\n droppingPosition,\n useCSSTransforms\n } = this.props;\n\n const pos = calcGridItemPosition(\n this.getPositionParams(),\n x,\n y,\n w,\n h,\n this.state\n );\n const child = React.Children.only(this.props.children);\n\n // Create the child element. We clone the existing element but modify its className and style.\n let newChild = React.cloneElement(child, {\n className: classNames(\n \"react-grid-item\",\n child.props.className,\n this.props.className,\n {\n static: this.props.static,\n resizing: Boolean(this.state.resizing),\n \"react-draggable\": isDraggable,\n \"react-draggable-dragging\": Boolean(this.state.dragging),\n dropping: Boolean(droppingPosition),\n cssTransforms: useCSSTransforms\n }\n ),\n // We can set the width and height on the child, but unfortunately we can't set the position.\n style: {\n ...this.props.style,\n ...child.props.style,\n ...this.createStyle(pos)\n }\n });\n\n // Resizable support. This is usually on but the user can toggle it off.\n newChild = this.mixinResizable(newChild, pos, isResizable);\n\n // Draggable support. This is always on, except for with placeholders.\n newChild = this.mixinDraggable(newChild, isDraggable);\n\n return newChild;\n }\n}\n","// @flow\nimport PropTypes from \"prop-types\";\nimport React from \"react\";\nimport type {\n ChildrenArray as ReactChildrenArray,\n Element as ReactElement\n} from \"react\";\nimport type { EventCallback, CompactType, Layout, LayoutItem } from \"./utils\";\n\nexport type Props = {|\n className: string,\n style: Object,\n width: number,\n autoSize: boolean,\n cols: number,\n draggableCancel: string,\n draggableHandle: string,\n verticalCompact: boolean,\n compactType: CompactType,\n layout: Layout,\n margin: [number, number],\n containerPadding: [number, number] | null,\n rowHeight: number,\n maxRows: number,\n isDraggable: boolean,\n isResizable: boolean,\n isDroppable: boolean,\n preventCollision: boolean,\n useCSSTransforms: boolean,\n transformScale: number,\n droppingItem: $Shape,\n\n // Callbacks\n onLayoutChange: Layout => void,\n onDrag: EventCallback,\n onDragStart: EventCallback,\n onDragStop: EventCallback,\n onResize: EventCallback,\n onResizeStart: EventCallback,\n onResizeStop: EventCallback,\n onDrop: (itemPosition: {\n x: number,\n y: number,\n w: number,\n h: number,\n e: Event\n }) => void,\n children: ReactChildrenArray>\n|};\n\nexport default {\n //\n // Basic props\n //\n className: PropTypes.string,\n style: PropTypes.object,\n\n // This can be set explicitly. If it is not set, it will automatically\n // be set to the container width. Note that resizes will *not* cause this to adjust.\n // If you need that behavior, use WidthProvider.\n width: PropTypes.number,\n\n // If true, the container height swells and contracts to fit contents\n autoSize: PropTypes.bool,\n // # of cols.\n cols: PropTypes.number,\n\n // A selector that will not be draggable.\n draggableCancel: PropTypes.string,\n // A selector for the draggable handler\n draggableHandle: PropTypes.string,\n\n // Deprecated\n verticalCompact: function(props: Props) {\n if (\n props.verticalCompact === false &&\n process.env.NODE_ENV !== \"production\"\n ) {\n console.warn(\n // eslint-disable-line no-console\n \"`verticalCompact` on is deprecated and will be removed soon. \" +\n 'Use `compactType`: \"horizontal\" | \"vertical\" | null.'\n );\n }\n },\n // Choose vertical or hotizontal compaction\n compactType: PropTypes.oneOf([\"vertical\", \"horizontal\"]),\n\n // layout is an array of object with the format:\n // {x: Number, y: Number, w: Number, h: Number, i: String}\n layout: function(props: Props) {\n var layout = props.layout;\n // I hope you're setting the data-grid property on the grid items\n if (layout === undefined) return;\n require(\"./utils\").validateLayout(layout, \"layout\");\n },\n\n //\n // Grid Dimensions\n //\n\n // Margin between items [x, y] in px\n margin: PropTypes.arrayOf(PropTypes.number),\n // Padding inside the container [x, y] in px\n containerPadding: PropTypes.arrayOf(PropTypes.number),\n // Rows have a static height, but you can change this based on breakpoints if you like\n rowHeight: PropTypes.number,\n // Default Infinity, but you can specify a max here if you like.\n // Note that this isn't fully fleshed out and won't error if you specify a layout that\n // extends beyond the row capacity. It will, however, not allow users to drag/resize\n // an item past the barrier. They can push items beyond the barrier, though.\n // Intentionally not documented for this reason.\n maxRows: PropTypes.number,\n\n //\n // Flags\n //\n isDraggable: PropTypes.bool,\n isResizable: PropTypes.bool,\n // If true, grid items won't change position when being dragged over.\n preventCollision: PropTypes.bool,\n // Use CSS transforms instead of top/left\n useCSSTransforms: PropTypes.bool,\n // parent layout transform scale\n transformScale: PropTypes.number,\n // If true, an external element can trigger onDrop callback with a specific grid position as a parameter\n isDroppable: PropTypes.bool,\n\n //\n // Callbacks\n //\n\n // Callback so you can save the layout. Calls after each drag & resize stops.\n onLayoutChange: PropTypes.func,\n\n // Calls when drag starts. Callback is of the signature (layout, oldItem, newItem, placeholder, e, ?node).\n // All callbacks below have the same signature. 'start' and 'stop' callbacks omit the 'placeholder'.\n onDragStart: PropTypes.func,\n // Calls on each drag movement.\n onDrag: PropTypes.func,\n // Calls when drag is complete.\n onDragStop: PropTypes.func,\n //Calls when resize starts.\n onResizeStart: PropTypes.func,\n // Calls when resize movement happens.\n onResize: PropTypes.func,\n // Calls when resize is complete.\n onResizeStop: PropTypes.func,\n // Calls when some element is dropped.\n onDrop: PropTypes.func,\n\n //\n // Other validations\n //\n\n droppingItem: PropTypes.shape({\n i: PropTypes.string.isRequired,\n w: PropTypes.number.isRequired,\n h: PropTypes.number.isRequired\n }),\n\n // Children must not have duplicate keys.\n children: function(props: Props, propName: string) {\n var children = props[propName];\n\n // Check children keys for duplicates. Throw if found.\n var keys = {};\n React.Children.forEach(children, function(child) {\n if (keys[child.key]) {\n throw new Error(\n 'Duplicate child key \"' +\n child.key +\n '\" found! This will cause problems in ReactGridLayout.'\n );\n }\n keys[child.key] = true;\n });\n }\n};\n","// @flow\nimport React from \"react\";\n\nimport isEqual from \"lodash.isequal\";\nimport classNames from \"classnames\";\nimport {\n autoBindHandlers,\n bottom,\n childrenEqual,\n cloneLayoutItem,\n compact,\n getLayoutItem,\n moveElement,\n synchronizeLayoutWithChildren,\n getAllCollisions,\n compactType,\n noop,\n fastRGLPropsEqual\n} from \"./utils\";\n\nimport { calcXY } from \"./calculateUtils\";\n\nimport GridItem from \"./GridItem\";\nimport ReactGridLayoutPropTypes from \"./ReactGridLayoutPropTypes\";\nimport type {\n ChildrenArray as ReactChildrenArray,\n Element as ReactElement\n} from \"react\";\n\n// Types\nimport type {\n CompactType,\n GridResizeEvent,\n GridDragEvent,\n DragOverEvent,\n Layout,\n DroppingPosition,\n LayoutItem\n} from \"./utils\";\n\nimport type { PositionParams } from \"./calculateUtils\";\n\ntype State = {\n activeDrag: ?LayoutItem,\n layout: Layout,\n mounted: boolean,\n oldDragItem: ?LayoutItem,\n oldLayout: ?Layout,\n oldResizeItem: ?LayoutItem,\n droppingDOMNode: ?ReactElement,\n droppingPosition?: DroppingPosition,\n // Mirrored props\n children: ReactChildrenArray>,\n compactType?: CompactType,\n propsLayout?: Layout\n};\n\nimport type { Props } from \"./ReactGridLayoutPropTypes\";\n\n// End Types\n\nconst layoutClassName = \"react-grid-layout\";\nlet isFirefox = false;\n// Try...catch will protect from navigator not existing (e.g. node) or a bad implementation of navigator\ntry {\n isFirefox = /firefox/i.test(navigator.userAgent);\n} catch (e) {\n /* Ignore */\n}\n\n/**\n * A reactive, fluid grid layout with draggable, resizable components.\n */\n\nexport default class ReactGridLayout extends React.Component {\n // TODO publish internal ReactClass displayName transform\n static displayName = \"ReactGridLayout\";\n\n // Refactored to another module to make way for preval\n static propTypes = ReactGridLayoutPropTypes;\n\n static defaultProps = {\n autoSize: true,\n cols: 12,\n className: \"\",\n style: {},\n draggableHandle: \"\",\n draggableCancel: \"\",\n containerPadding: null,\n rowHeight: 150,\n maxRows: Infinity, // infinite vertical growth\n layout: [],\n margin: [10, 10],\n isDraggable: true,\n isResizable: true,\n isDroppable: false,\n useCSSTransforms: true,\n transformScale: 1,\n verticalCompact: true,\n compactType: \"vertical\",\n preventCollision: false,\n droppingItem: {\n i: \"__dropping-elem__\",\n h: 1,\n w: 1\n },\n onLayoutChange: noop,\n onDragStart: noop,\n onDrag: noop,\n onDragStop: noop,\n onResizeStart: noop,\n onResize: noop,\n onResizeStop: noop,\n onDrop: noop\n };\n\n state: State = {\n activeDrag: null,\n layout: synchronizeLayoutWithChildren(\n this.props.layout,\n this.props.children,\n this.props.cols,\n // Legacy support for verticalCompact: false\n compactType(this.props)\n ),\n mounted: false,\n oldDragItem: null,\n oldLayout: null,\n oldResizeItem: null,\n droppingDOMNode: null,\n children: []\n };\n\n dragEnterCounter = 0;\n\n constructor(props: Props, context: any): void {\n super(props, context);\n autoBindHandlers(this, [\n \"onDragStart\",\n \"onDrag\",\n \"onDragStop\",\n \"onResizeStart\",\n \"onResize\",\n \"onResizeStop\"\n ]);\n }\n\n componentDidMount() {\n this.setState({ mounted: true });\n // Possibly call back with layout on mount. This should be done after correcting the layout width\n // to ensure we don't rerender with the wrong width.\n this.onLayoutMaybeChanged(this.state.layout, this.props.layout);\n }\n\n static getDerivedStateFromProps(nextProps: Props, prevState: State) {\n let newLayoutBase;\n\n if (prevState.activeDrag) {\n return null;\n }\n\n // Legacy support for compactType\n // Allow parent to set layout directly.\n if (\n !isEqual(nextProps.layout, prevState.propsLayout) ||\n nextProps.compactType !== prevState.compactType\n ) {\n newLayoutBase = nextProps.layout;\n } else if (!childrenEqual(nextProps.children, prevState.children)) {\n // If children change, also regenerate the layout. Use our state\n // as the base in case because it may be more up to date than\n // what is in props.\n newLayoutBase = prevState.layout;\n }\n\n // We need to regenerate the layout.\n if (newLayoutBase) {\n const newLayout = synchronizeLayoutWithChildren(\n newLayoutBase,\n nextProps.children,\n nextProps.cols,\n compactType(nextProps)\n );\n\n return {\n layout: newLayout,\n // We need to save these props to state for using\n // getDerivedStateFromProps instead of componentDidMount (in which we would get extra rerender)\n compactType: nextProps.compactType,\n children: nextProps.children,\n propsLayout: nextProps.layout\n };\n }\n\n return null;\n }\n\n shouldComponentUpdate(nextProps: Props, nextState: State) {\n return (\n // NOTE: this is almost always unequal. Therefore the only way to get better performance\n // from SCU is if the user intentionally memoizes children. If they do, and they can\n // handle changes properly, performance will increase.\n this.props.children !== nextProps.children ||\n !fastRGLPropsEqual(this.props, nextProps, isEqual) ||\n this.state.activeDrag !== nextState.activeDrag ||\n this.state.droppingPosition !== nextState.droppingPosition\n );\n }\n\n componentDidUpdate(prevProps: Props, prevState: State) {\n if (!this.state.activeDrag) {\n const newLayout = this.state.layout;\n const oldLayout = prevState.layout;\n\n this.onLayoutMaybeChanged(newLayout, oldLayout);\n }\n }\n\n /**\n * Calculates a pixel value for the container.\n * @return {String} Container height in pixels.\n */\n containerHeight() {\n if (!this.props.autoSize) return;\n const nbRow = bottom(this.state.layout);\n const containerPaddingY = this.props.containerPadding\n ? this.props.containerPadding[1]\n : this.props.margin[1];\n return (\n nbRow * this.props.rowHeight +\n (nbRow - 1) * this.props.margin[1] +\n containerPaddingY * 2 +\n \"px\"\n );\n }\n\n /**\n * When dragging starts\n * @param {String} i Id of the child\n * @param {Number} x X position of the move\n * @param {Number} y Y position of the move\n * @param {Event} e The mousedown event\n * @param {Element} node The current dragging DOM element\n */\n onDragStart(i: string, x: number, y: number, { e, node }: GridDragEvent) {\n const { layout } = this.state;\n var l = getLayoutItem(layout, i);\n if (!l) return;\n\n this.setState({\n oldDragItem: cloneLayoutItem(l),\n oldLayout: this.state.layout\n });\n\n return this.props.onDragStart(layout, l, l, null, e, node);\n }\n\n /**\n * Each drag movement create a new dragelement and move the element to the dragged location\n * @param {String} i Id of the child\n * @param {Number} x X position of the move\n * @param {Number} y Y position of the move\n * @param {Event} e The mousedown event\n * @param {Element} node The current dragging DOM element\n */\n onDrag(i: string, x: number, y: number, { e, node }: GridDragEvent) {\n const { oldDragItem } = this.state;\n let { layout } = this.state;\n const { cols } = this.props;\n var l = getLayoutItem(layout, i);\n if (!l) return;\n\n // Create placeholder (display only)\n var placeholder = {\n w: l.w,\n h: l.h,\n x: l.x,\n y: l.y,\n placeholder: true,\n i: i\n };\n\n // Move the element to the dragged location.\n const isUserAction = true;\n layout = moveElement(\n layout,\n l,\n x,\n y,\n isUserAction,\n this.props.preventCollision,\n compactType(this.props),\n cols\n );\n\n this.props.onDrag(layout, oldDragItem, l, placeholder, e, node);\n\n this.setState({\n layout: compact(layout, compactType(this.props), cols),\n activeDrag: placeholder\n });\n }\n\n /**\n * When dragging stops, figure out which position the element is closest to and update its x and y.\n * @param {String} i Index of the child.\n * @param {Number} x X position of the move\n * @param {Number} y Y position of the move\n * @param {Event} e The mousedown event\n * @param {Element} node The current dragging DOM element\n */\n onDragStop(i: string, x: number, y: number, { e, node }: GridDragEvent) {\n if (!this.state.activeDrag) return;\n\n const { oldDragItem } = this.state;\n let { layout } = this.state;\n const { cols, preventCollision } = this.props;\n const l = getLayoutItem(layout, i);\n if (!l) return;\n\n // Move the element here\n const isUserAction = true;\n layout = moveElement(\n layout,\n l,\n x,\n y,\n isUserAction,\n preventCollision,\n compactType(this.props),\n cols\n );\n\n this.props.onDragStop(layout, oldDragItem, l, null, e, node);\n\n // Set state\n const newLayout = compact(layout, compactType(this.props), cols);\n const { oldLayout } = this.state;\n this.setState({\n activeDrag: null,\n layout: newLayout,\n oldDragItem: null,\n oldLayout: null\n });\n\n this.onLayoutMaybeChanged(newLayout, oldLayout);\n }\n\n onLayoutMaybeChanged(newLayout: Layout, oldLayout: ?Layout) {\n if (!oldLayout) oldLayout = this.state.layout;\n\n if (!isEqual(oldLayout, newLayout)) {\n this.props.onLayoutChange(newLayout);\n }\n }\n\n onResizeStart(i: string, w: number, h: number, { e, node }: GridResizeEvent) {\n const { layout } = this.state;\n var l = getLayoutItem(layout, i);\n if (!l) return;\n\n this.setState({\n oldResizeItem: cloneLayoutItem(l),\n oldLayout: this.state.layout\n });\n\n this.props.onResizeStart(layout, l, l, null, e, node);\n }\n\n onResize(i: string, w: number, h: number, { e, node }: GridResizeEvent) {\n const { layout, oldResizeItem } = this.state;\n const { cols, preventCollision } = this.props;\n const l: ?LayoutItem = getLayoutItem(layout, i);\n if (!l) return;\n\n // Something like quad tree should be used\n // to find collisions faster\n let hasCollisions;\n if (preventCollision) {\n const collisions = getAllCollisions(layout, { ...l, w, h }).filter(\n layoutItem => layoutItem.i !== l.i\n );\n hasCollisions = collisions.length > 0;\n\n // If we're colliding, we need adjust the placeholder.\n if (hasCollisions) {\n // adjust w && h to maximum allowed space\n let leastX = Infinity,\n leastY = Infinity;\n collisions.forEach(layoutItem => {\n if (layoutItem.x > l.x) leastX = Math.min(leastX, layoutItem.x);\n if (layoutItem.y > l.y) leastY = Math.min(leastY, layoutItem.y);\n });\n\n if (Number.isFinite(leastX)) l.w = leastX - l.x;\n if (Number.isFinite(leastY)) l.h = leastY - l.y;\n }\n }\n\n if (!hasCollisions) {\n // Set new width and height.\n l.w = w;\n l.h = h;\n }\n\n // Create placeholder element (display only)\n var placeholder = {\n w: l.w,\n h: l.h,\n x: l.x,\n y: l.y,\n static: true,\n i: i\n };\n\n this.props.onResize(layout, oldResizeItem, l, placeholder, e, node);\n\n // Re-compact the layout and set the drag placeholder.\n this.setState({\n layout: compact(layout, compactType(this.props), cols),\n activeDrag: placeholder\n });\n }\n\n onResizeStop(i: string, w: number, h: number, { e, node }: GridResizeEvent) {\n const { layout, oldResizeItem } = this.state;\n const { cols } = this.props;\n var l = getLayoutItem(layout, i);\n\n this.props.onResizeStop(layout, oldResizeItem, l, null, e, node);\n\n // Set state\n const newLayout = compact(layout, compactType(this.props), cols);\n const { oldLayout } = this.state;\n this.setState({\n activeDrag: null,\n layout: newLayout,\n oldResizeItem: null,\n oldLayout: null\n });\n\n this.onLayoutMaybeChanged(newLayout, oldLayout);\n }\n\n /**\n * Create a placeholder object.\n * @return {Element} Placeholder div.\n */\n placeholder(): ?ReactElement {\n const { activeDrag } = this.state;\n if (!activeDrag) return null;\n const {\n width,\n cols,\n margin,\n containerPadding,\n rowHeight,\n maxRows,\n useCSSTransforms,\n transformScale\n } = this.props;\n\n // {...this.state.activeDrag} is pretty slow, actually\n return (\n \n
\n \n );\n }\n\n /**\n * Given a grid item, set its style attributes & surround in a .\n * @param {Element} child React element.\n * @return {Element} Element wrapped in draggable and properly placed.\n */\n processGridItem(\n child: ReactElement,\n isDroppingItem?: boolean\n ): ?ReactElement {\n if (!child || !child.key) return;\n const l = getLayoutItem(this.state.layout, String(child.key));\n if (!l) return null;\n const {\n width,\n cols,\n margin,\n containerPadding,\n rowHeight,\n maxRows,\n isDraggable,\n isResizable,\n useCSSTransforms,\n transformScale,\n draggableCancel,\n draggableHandle\n } = this.props;\n const { mounted, droppingPosition } = this.state;\n\n // Determine user manipulations possible.\n // If an item is static, it can't be manipulated by default.\n // Any properties defined directly on the grid item will take precedence.\n const draggable =\n typeof l.isDraggable === \"boolean\"\n ? l.isDraggable\n : !l.static && isDraggable;\n const resizable =\n typeof l.isResizable === \"boolean\"\n ? l.isResizable\n : !l.static && isResizable;\n\n return (\n \n {child}\n \n );\n }\n\n // Called while dragging an element. Part of browser native drag/drop API.\n // Native event target might be the layout itself, or an element within the layout.\n onDragOver = (e: DragOverEvent) => {\n // we should ignore events from layout's children in Firefox\n // to avoid unpredictable jumping of a dropping placeholder\n // FIXME remove this hack\n if (\n isFirefox &&\n e.nativeEvent.target.className.indexOf(layoutClassName) === -1\n ) {\n return false;\n }\n\n const {\n droppingItem,\n margin,\n cols,\n rowHeight,\n maxRows,\n width,\n containerPadding\n } = this.props;\n const { layout } = this.state;\n // This is relative to the DOM element that this event fired for.\n const { layerX, layerY } = e.nativeEvent;\n const droppingPosition = { left: layerX, top: layerY, e };\n\n if (!this.state.droppingDOMNode) {\n const positionParams: PositionParams = {\n cols,\n margin,\n maxRows,\n rowHeight,\n containerWidth: width,\n containerPadding: containerPadding || margin\n };\n\n const calculatedPosition = calcXY(\n positionParams,\n layerY,\n layerX,\n droppingItem.w,\n droppingItem.h\n );\n\n this.setState({\n droppingDOMNode:
,\n droppingPosition,\n layout: [\n ...layout,\n {\n ...droppingItem,\n x: calculatedPosition.x,\n y: calculatedPosition.y,\n static: false,\n isDraggable: true\n }\n ]\n });\n } else if (this.state.droppingPosition) {\n const { left, top } = this.state.droppingPosition;\n const shouldUpdatePosition = left != layerX || top != layerY;\n if (shouldUpdatePosition) {\n this.setState({ droppingPosition });\n }\n }\n\n e.stopPropagation();\n e.preventDefault();\n };\n\n removeDroppingPlaceholder = () => {\n const { droppingItem, cols } = this.props;\n const { layout } = this.state;\n\n const newLayout = compact(\n layout.filter(l => l.i !== droppingItem.i),\n compactType(this.props),\n cols\n );\n\n this.setState({\n layout: newLayout,\n droppingDOMNode: null,\n activeDrag: null,\n droppingPosition: undefined\n });\n };\n\n onDragLeave = () => {\n this.dragEnterCounter--;\n\n // onDragLeave can be triggered on each layout's child.\n // But we know that count of dragEnter and dragLeave events\n // will be balanced after leaving the layout's container\n // so we can increase and decrease count of dragEnter and\n // when it'll be equal to 0 we'll remove the placeholder\n if (this.dragEnterCounter === 0) {\n this.removeDroppingPlaceholder();\n }\n };\n\n onDragEnter = () => {\n this.dragEnterCounter++;\n };\n\n onDrop = (e: Event) => {\n const { droppingItem } = this.props;\n const { layout } = this.state;\n const { x, y, w, h } = layout.find(l => l.i === droppingItem.i) || {};\n\n // reset gragEnter counter on drop\n this.dragEnterCounter = 0;\n\n this.removeDroppingPlaceholder();\n\n this.props.onDrop({ x, y, w, h, e });\n };\n\n render() {\n const { className, style, isDroppable } = this.props;\n\n const mergedClassName = classNames(layoutClassName, className);\n const mergedStyle = {\n height: this.containerHeight(),\n ...style\n };\n\n return (\n \n {React.Children.map(this.props.children, child =>\n this.processGridItem(child)\n )}\n {isDroppable &&\n this.state.droppingDOMNode &&\n this.processGridItem(this.state.droppingDOMNode, true)}\n {this.placeholder()}\n
\n );\n }\n}\n","\"use strict\";\n\nexports.__esModule = true;\nexports.default = void 0;\n\nvar _react = _interopRequireDefault(require(\"react\"));\n\nvar _propTypes = _interopRequireDefault(require(\"prop-types\"));\n\nvar _reactDraggable = require(\"react-draggable\");\n\nvar _utils = require(\"./utils\");\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(source, true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(source).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }\n\nfunction _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }\n\nfunction _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return self; }\n\nfunction _inheritsLoose(subClass, superClass) { subClass.prototype = Object.create(superClass.prototype); subClass.prototype.constructor = subClass; subClass.__proto__ = superClass; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nvar Resizable =\n/*#__PURE__*/\nfunction (_React$Component) {\n _inheritsLoose(Resizable, _React$Component);\n\n function Resizable() {\n var _this;\n\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n _this = _React$Component.call.apply(_React$Component, [this].concat(args)) || this;\n\n _defineProperty(_assertThisInitialized(_this), \"state\", {\n slackW: 0,\n slackH: 0\n });\n\n return _this;\n }\n\n var _proto = Resizable.prototype;\n\n _proto.lockAspectRatio = function lockAspectRatio(width, height, aspectRatio) {\n height = width / aspectRatio;\n width = height * aspectRatio;\n return [width, height];\n } // If you do this, be careful of constraints\n ;\n\n _proto.runConstraints = function runConstraints(width, height) {\n var _ref = [this.props.minConstraints, this.props.maxConstraints],\n min = _ref[0],\n max = _ref[1];\n if (!min && !max) return [width, height]; // Fit width & height to aspect ratio\n\n if (this.props.lockAspectRatio) {\n if (height === this.props.height) {\n var ratio = this.props.width / this.props.height;\n height = width / ratio;\n width = height * ratio;\n } else {\n // Take into account vertical resize with N/S handles on locked aspect\n // ratio. Calculate the change height-first, instead of width-first\n var _ratio = this.props.height / this.props.width;\n\n width = height / _ratio;\n height = width * _ratio;\n }\n }\n\n var oldW = width,\n oldH = height; // Add slack to the values used to calculate bound position. This will ensure that if\n // we start removing slack, the element won't react to it right away until it's been\n // completely removed.\n\n var _this$state = this.state,\n slackW = _this$state.slackW,\n slackH = _this$state.slackH;\n width += slackW;\n height += slackH;\n\n if (min) {\n width = Math.max(min[0], width);\n height = Math.max(min[1], height);\n }\n\n if (max) {\n width = Math.min(max[0], width);\n height = Math.min(max[1], height);\n } // If the numbers changed, we must have introduced some slack. Record it for the next iteration.\n\n\n slackW += oldW - width;\n slackH += oldH - height;\n\n if (slackW !== this.state.slackW || slackH !== this.state.slackH) {\n this.setState({\n slackW: slackW,\n slackH: slackH\n });\n }\n\n return [width, height];\n }\n /**\n * Wrapper around drag events to provide more useful data.\n *\n * @param {String} handlerName Handler name to wrap.\n * @return {Function} Handler function.\n */\n ;\n\n _proto.resizeHandler = function resizeHandler(handlerName, axis) {\n var _this2 = this;\n\n return function (e, _ref2) {\n var node = _ref2.node,\n deltaX = _ref2.deltaX,\n deltaY = _ref2.deltaY;\n deltaX /= _this2.props.transformScale;\n deltaY /= _this2.props.transformScale; // Axis restrictions\n\n var canDragX = (_this2.props.axis === 'both' || _this2.props.axis === 'x') && ['n', 's'].indexOf(axis) === -1;\n var canDragY = (_this2.props.axis === 'both' || _this2.props.axis === 'y') && ['e', 'w'].indexOf(axis) === -1; // reverse delta if using top or left drag handles\n\n if (canDragX && axis[axis.length - 1] === 'w') {\n deltaX = -deltaX;\n }\n\n if (canDragY && axis[0] === 'n') {\n deltaY = -deltaY;\n } // Update w/h\n\n\n var width = _this2.props.width + (canDragX ? deltaX : 0);\n var height = _this2.props.height + (canDragY ? deltaY : 0); // Early return if no change\n\n var widthChanged = width !== _this2.props.width,\n heightChanged = height !== _this2.props.height;\n if (handlerName === 'onResize' && !widthChanged && !heightChanged) return;\n\n var _this2$runConstraints = _this2.runConstraints(width, height);\n\n width = _this2$runConstraints[0];\n height = _this2$runConstraints[1];\n // Set the appropriate state for this handler.\n var newState = {};\n\n if (handlerName === 'onResizeStart') {// nothing\n } else if (handlerName === 'onResizeStop') {\n newState.slackW = newState.slackH = 0;\n } else {\n // Early return if no change after constraints\n if (width === _this2.props.width && height === _this2.props.height) return;\n }\n\n var hasCb = typeof _this2.props[handlerName] === 'function';\n\n if (hasCb) {\n // $FlowIgnore isn't refining this correctly to SyntheticEvent\n if (typeof e.persist === 'function') e.persist();\n\n _this2.setState(newState, function () {\n return _this2.props[handlerName](e, {\n node: node,\n size: {\n width: width,\n height: height\n },\n handle: axis\n });\n });\n } else {\n _this2.setState(newState);\n }\n };\n };\n\n _proto.renderResizeHandle = function renderResizeHandle(resizeHandle) {\n var handle = this.props.handle;\n\n if (handle) {\n if (typeof handle === 'function') {\n return handle(resizeHandle);\n }\n\n return handle;\n }\n\n return _react.default.createElement(\"span\", {\n className: \"react-resizable-handle react-resizable-handle-\" + resizeHandle\n });\n };\n\n _proto.render = function render() {\n var _this3 = this;\n\n // eslint-disable-next-line no-unused-vars\n var _this$props = this.props,\n children = _this$props.children,\n draggableOpts = _this$props.draggableOpts,\n width = _this$props.width,\n height = _this$props.height,\n handleSize = _this$props.handleSize,\n lockAspectRatio = _this$props.lockAspectRatio,\n axis = _this$props.axis,\n minConstraints = _this$props.minConstraints,\n maxConstraints = _this$props.maxConstraints,\n onResize = _this$props.onResize,\n onResizeStop = _this$props.onResizeStop,\n onResizeStart = _this$props.onResizeStart,\n resizeHandles = _this$props.resizeHandles,\n transformScale = _this$props.transformScale,\n p = _objectWithoutPropertiesLoose(_this$props, [\"children\", \"draggableOpts\", \"width\", \"height\", \"handleSize\", \"lockAspectRatio\", \"axis\", \"minConstraints\", \"maxConstraints\", \"onResize\", \"onResizeStop\", \"onResizeStart\", \"resizeHandles\", \"transformScale\"]);\n\n var className = p.className ? p.className + \" react-resizable\" : 'react-resizable'; // What we're doing here is getting the child of this element, and cloning it with this element's props.\n // We are then defining its children as:\n // Its original children (resizable's child's children), and\n // One or more draggable handles.\n\n return (0, _utils.cloneElement)(children, _objectSpread({}, p, {\n className: className,\n children: [children.props.children, resizeHandles.map(function (h) {\n return _react.default.createElement(_reactDraggable.DraggableCore, _extends({}, draggableOpts, {\n key: \"resizableHandle-\" + h,\n onStop: _this3.resizeHandler('onResizeStop', h),\n onStart: _this3.resizeHandler('onResizeStart', h),\n onDrag: _this3.resizeHandler('onResize', h)\n }), _this3.renderResizeHandle(h));\n })]\n }));\n };\n\n return Resizable;\n}(_react.default.Component);\n\nexports.default = Resizable;\n\n_defineProperty(Resizable, \"propTypes\", {\n //\n // Required Props\n //\n // Require that one and only one child be present.\n children: _propTypes.default.element.isRequired,\n // Initial w/h\n width: _propTypes.default.number.isRequired,\n height: _propTypes.default.number.isRequired,\n //\n // Optional props\n //\n // Custom resize handle\n handle: _propTypes.default.element,\n // If you change this, be sure to update your css\n handleSize: _propTypes.default.array,\n // Defines which resize handles should be rendered (default: 'se')\n // Allows for any combination of:\n // 's' - South handle (bottom-center)\n // 'w' - West handle (left-center)\n // 'e' - East handle (right-center)\n // 'n' - North handle (top-center)\n // 'sw' - Southwest handle (bottom-left)\n // 'nw' - Northwest handle (top-left)\n // 'se' - Southeast handle (bottom-right)\n // 'ne' - Northeast handle (top-center)\n resizeHandles: _propTypes.default.arrayOf(_propTypes.default.oneOf(['s', 'w', 'e', 'n', 'sw', 'nw', 'se', 'ne'])),\n transformScale: _propTypes.default.number,\n // If true, will only allow width/height to move in lockstep\n lockAspectRatio: _propTypes.default.bool,\n // Restricts resizing to a particular axis (default: 'both')\n // 'both' - allows resizing by width or height\n // 'x' - only allows the width to be changed\n // 'y' - only allows the height to be changed\n // 'none' - disables resizing altogether\n axis: _propTypes.default.oneOf(['both', 'x', 'y', 'none']),\n // Min/max size\n minConstraints: _propTypes.default.arrayOf(_propTypes.default.number),\n maxConstraints: _propTypes.default.arrayOf(_propTypes.default.number),\n // Callbacks\n onResizeStop: _propTypes.default.func,\n onResizeStart: _propTypes.default.func,\n onResize: _propTypes.default.func,\n // These will be passed wholesale to react-draggable's DraggableCore\n draggableOpts: _propTypes.default.object\n});\n\n_defineProperty(Resizable, \"defaultProps\", {\n handleSize: [20, 20],\n lockAspectRatio: false,\n axis: 'both',\n minConstraints: [20, 20],\n maxConstraints: [Infinity, Infinity],\n resizeHandles: ['se'],\n transformScale: 1\n});","'use strict';\nmodule.exports = function() {\n throw new Error(\"Don't instantiate Resizable directly! Use require('react-resizable').Resizable\");\n};\n\nmodule.exports.Resizable = require('./build/Resizable').default;\nmodule.exports.ResizableBox = require('./build/ResizableBox').default;\n","module.exports = require(\"./lib/ReactGridLayout\").default;\nmodule.exports.utils = require(\"./lib/utils\");\nmodule.exports.Responsive = require(\"./lib/ResponsiveReactGridLayout\").default;\nmodule.exports.Responsive.utils = require(\"./lib/responsiveUtils\");\nmodule.exports.WidthProvider = require(\"./lib/components/WidthProvider\").default;\n","var g;\n\n// This works in non-strict mode\ng = (function() {\n\treturn this;\n})();\n\ntry {\n\t// This works if eval is allowed (see CSP)\n\tg = g || new Function(\"return this\")();\n} catch (e) {\n\t// This works if the window reference is available\n\tif (typeof window === \"object\") g = window;\n}\n\n// g can still be undefined, but nothing to do about it...\n// We return undefined, instead of nothing here, so it's\n// easier to handle this case. if(!global) { ...}\n\nmodule.exports = g;\n","module.exports = function(module) {\n\tif (!module.webpackPolyfill) {\n\t\tmodule.deprecate = function() {};\n\t\tmodule.paths = [];\n\t\t// module.parent = undefined by default\n\t\tif (!module.children) module.children = [];\n\t\tObject.defineProperty(module, \"loaded\", {\n\t\t\tenumerable: true,\n\t\t\tget: function() {\n\t\t\t\treturn module.l;\n\t\t\t}\n\t\t});\n\t\tObject.defineProperty(module, \"id\", {\n\t\t\tenumerable: true,\n\t\t\tget: function() {\n\t\t\t\treturn module.i;\n\t\t\t}\n\t\t});\n\t\tmodule.webpackPolyfill = 1;\n\t}\n\treturn module;\n};\n","/**\n * Copyright (c) 2013-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n'use strict';\n\nvar ReactPropTypesSecret = require('./lib/ReactPropTypesSecret');\n\nfunction emptyFunction() {}\nfunction emptyFunctionWithReset() {}\nemptyFunctionWithReset.resetWarningCache = emptyFunction;\n\nmodule.exports = function() {\n function shim(props, propName, componentName, location, propFullName, secret) {\n if (secret === ReactPropTypesSecret) {\n // It is still safe when called from React.\n return;\n }\n var err = new Error(\n 'Calling PropTypes validators directly is not supported by the `prop-types` package. ' +\n 'Use PropTypes.checkPropTypes() to call them. ' +\n 'Read more at http://fb.me/use-check-prop-types'\n );\n err.name = 'Invariant Violation';\n throw err;\n };\n shim.isRequired = shim;\n function getShim() {\n return shim;\n };\n // Important!\n // Keep this list in sync with production version in `./factoryWithTypeCheckers.js`.\n var ReactPropTypes = {\n array: shim,\n bool: shim,\n func: shim,\n number: shim,\n object: shim,\n string: shim,\n symbol: shim,\n\n any: shim,\n arrayOf: getShim,\n element: shim,\n elementType: shim,\n instanceOf: getShim,\n node: shim,\n objectOf: getShim,\n oneOf: getShim,\n oneOfType: getShim,\n shape: getShim,\n exact: getShim,\n\n checkPropTypes: emptyFunctionWithReset,\n resetWarningCache: emptyFunction\n };\n\n ReactPropTypes.PropTypes = ReactPropTypes;\n\n return ReactPropTypes;\n};\n","/**\n * Copyright (c) 2013-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n'use strict';\n\nvar ReactPropTypesSecret = 'SECRET_DO_NOT_PASS_THIS_OR_YOU_WILL_BE_FIRED';\n\nmodule.exports = ReactPropTypesSecret;\n","\"use strict\";\n\nexports.__esModule = true;\nexports.cloneElement = cloneElement;\n\nvar _react = _interopRequireDefault(require(\"react\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(source, true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(source).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n// React.addons.cloneWithProps look-alike that merges style & className.\nfunction cloneElement(element, props) {\n if (props.style && element.props.style) {\n props.style = _objectSpread({}, element.props.style, {}, props.style);\n }\n\n if (props.className && element.props.className) {\n props.className = element.props.className + \" \" + props.className;\n }\n\n return _react.default.cloneElement(element, props);\n}","\"use strict\";\n\nexports.__esModule = true;\nexports.default = void 0;\n\nvar _react = _interopRequireDefault(require(\"react\"));\n\nvar _propTypes = _interopRequireDefault(require(\"prop-types\"));\n\nvar _Resizable = _interopRequireDefault(require(\"./Resizable\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nfunction _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }\n\nfunction _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return self; }\n\nfunction _inheritsLoose(subClass, superClass) { subClass.prototype = Object.create(superClass.prototype); subClass.prototype.constructor = subClass; subClass.__proto__ = superClass; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n// An example use of Resizable.\nvar ResizableBox =\n/*#__PURE__*/\nfunction (_React$Component) {\n _inheritsLoose(ResizableBox, _React$Component);\n\n function ResizableBox() {\n var _this;\n\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n _this = _React$Component.call.apply(_React$Component, [this].concat(args)) || this;\n\n _defineProperty(_assertThisInitialized(_this), \"state\", {\n width: _this.props.width,\n height: _this.props.height,\n propsWidth: _this.props.width,\n propsHeight: _this.props.height\n });\n\n _defineProperty(_assertThisInitialized(_this), \"onResize\", function (e, data) {\n var size = data.size;\n var width = size.width,\n height = size.height;\n\n if (_this.props.onResize) {\n e.persist && e.persist();\n\n _this.setState(size, function () {\n return _this.props.onResize && _this.props.onResize(e, data);\n });\n } else {\n _this.setState(size);\n }\n });\n\n return _this;\n }\n\n ResizableBox.getDerivedStateFromProps = function getDerivedStateFromProps(props, state) {\n // If parent changes height/width, set that in our state.\n if (state.propsWidth !== props.width || state.propsHeight !== props.height) {\n return {\n width: props.width,\n height: props.height,\n propsWidth: props.width,\n propsHeight: props.height\n };\n }\n\n return null;\n };\n\n var _proto = ResizableBox.prototype;\n\n _proto.render = function render() {\n // Basic wrapper around a Resizable instance.\n // If you use Resizable directly, you are responsible for updating the child component\n // with a new width and height.\n var _this$props = this.props,\n handle = _this$props.handle,\n handleSize = _this$props.handleSize,\n onResize = _this$props.onResize,\n onResizeStart = _this$props.onResizeStart,\n onResizeStop = _this$props.onResizeStop,\n draggableOpts = _this$props.draggableOpts,\n minConstraints = _this$props.minConstraints,\n maxConstraints = _this$props.maxConstraints,\n lockAspectRatio = _this$props.lockAspectRatio,\n axis = _this$props.axis,\n width = _this$props.width,\n height = _this$props.height,\n resizeHandles = _this$props.resizeHandles,\n props = _objectWithoutPropertiesLoose(_this$props, [\"handle\", \"handleSize\", \"onResize\", \"onResizeStart\", \"onResizeStop\", \"draggableOpts\", \"minConstraints\", \"maxConstraints\", \"lockAspectRatio\", \"axis\", \"width\", \"height\", \"resizeHandles\"]);\n\n return _react.default.createElement(_Resizable.default, {\n handle: handle,\n handleSize: handleSize,\n width: this.state.width,\n height: this.state.height,\n onResizeStart: onResizeStart,\n onResize: this.onResize,\n onResizeStop: onResizeStop,\n draggableOpts: draggableOpts,\n minConstraints: minConstraints,\n maxConstraints: maxConstraints,\n lockAspectRatio: lockAspectRatio,\n axis: axis,\n resizeHandles: resizeHandles\n }, _react.default.createElement(\"div\", _extends({\n style: {\n width: this.state.width + 'px',\n height: this.state.height + 'px'\n }\n }, props)));\n };\n\n return ResizableBox;\n}(_react.default.Component);\n\nexports.default = ResizableBox;\n\n_defineProperty(ResizableBox, \"propTypes\", {\n height: _propTypes.default.number,\n width: _propTypes.default.number\n});\n\n_defineProperty(ResizableBox, \"defaultProps\", {\n handleSize: [20, 20]\n});","// @flow\nimport * as React from \"react\";\nimport PropTypes from \"prop-types\";\nimport isEqual from \"lodash.isequal\";\n\nimport {\n cloneLayout,\n synchronizeLayoutWithChildren,\n validateLayout,\n noop,\n type Layout\n} from \"./utils\";\nimport {\n getBreakpointFromWidth,\n getColsFromBreakpoint,\n findOrGenerateResponsiveLayout,\n type ResponsiveLayout,\n type Breakpoints,\n} from \"./responsiveUtils\";\nimport ReactGridLayout from \"./ReactGridLayout\";\n\nconst type = obj => Object.prototype.toString.call(obj);\n\n/**\n * Get a value of margin or containerPadding.\n *\n * @param {Array | Object} param Margin | containerPadding, e.g. [10, 10] | {lg: [10, 10], ...}.\n * @param {String} breakpoint Breakpoint: lg, md, sm, xs and etc.\n * @return {Array}\n */\n\nfunction getIndentationValue(\n param: { [key: string]: [number, number] } | [number, number],\n breakpoint: string\n) {\n return Array.isArray(param) ? param : param[breakpoint];\n}\n\ntype State = {\n layout: Layout,\n breakpoint: string,\n cols: number,\n layouts?: { [key: string]: Layout }\n};\n\ntype Props = {|\n ...React.ElementConfig,\n\n // Responsive config\n breakpoint?: ?Breakpoint,\n breakpoints: Breakpoints,\n cols: { [key: Breakpoint]: number },\n layouts: ResponsiveLayout,\n width: number,\n margin: { [key: Breakpoint]: [number, number] } | [number, number],\n containerPadding: { [key: Breakpoint]: [number, number] } | [number, number],\n\n // Callbacks\n onBreakpointChange: (Breakpoint, cols: number) => void,\n onLayoutChange: (Layout, { [key: Breakpoint]: Layout }) => void,\n onWidthChange: (\n containerWidth: number,\n margin: [number, number],\n cols: number,\n containerPadding: [number, number] | null\n ) => void\n|};\n\nexport default class ResponsiveReactGridLayout extends React.Component<\n Props<>,\n State\n> {\n // This should only include propTypes needed in this code; RGL itself\n // will do validation of the rest props passed to it.\n static propTypes = {\n //\n // Basic props\n //\n\n // Optional, but if you are managing width yourself you may want to set the breakpoint\n // yourself as well.\n breakpoint: PropTypes.string,\n\n // {name: pxVal}, e.g. {lg: 1200, md: 996, sm: 768, xs: 480}\n breakpoints: PropTypes.object,\n\n // # of cols. This is a breakpoint -> cols map\n cols: PropTypes.object,\n\n // # of margin. This is a breakpoint -> margin map\n // e.g. { lg: [5, 5], md: [10, 10], sm: [15, 15] }\n // Margin between items [x, y] in px\n // e.g. [10, 10]\n margin: PropTypes.oneOfType([PropTypes.array, PropTypes.object]),\n\n // # of containerPadding. This is a breakpoint -> containerPadding map\n // e.g. { lg: [5, 5], md: [10, 10], sm: [15, 15] }\n // Padding inside the container [x, y] in px\n // e.g. [10, 10]\n containerPadding: PropTypes.oneOfType([PropTypes.array, PropTypes.object]),\n\n // layouts is an object mapping breakpoints to layouts.\n // e.g. {lg: Layout, md: Layout, ...}\n layouts(props: Props<>, propName: string) {\n if (type(props[propName]) !== \"[object Object]\") {\n throw new Error(\n \"Layout property must be an object. Received: \" +\n type(props[propName])\n );\n }\n Object.keys(props[propName]).forEach(key => {\n if (!(key in props.breakpoints)) {\n throw new Error(\n \"Each key in layouts must align with a key in breakpoints.\"\n );\n }\n validateLayout(props.layouts[key], \"layouts.\" + key);\n });\n },\n\n // The width of this component.\n // Required in this propTypes stanza because generateInitialState() will fail without it.\n width: PropTypes.number.isRequired,\n\n //\n // Callbacks\n //\n\n // Calls back with breakpoint and new # cols\n onBreakpointChange: PropTypes.func,\n\n // Callback so you can save the layout.\n // Calls back with (currentLayout, allLayouts). allLayouts are keyed by breakpoint.\n onLayoutChange: PropTypes.func,\n\n // Calls back with (containerWidth, margin, cols, containerPadding)\n onWidthChange: PropTypes.func\n };\n\n static defaultProps = {\n breakpoints: { lg: 1200, md: 996, sm: 768, xs: 480, xxs: 0 },\n cols: { lg: 12, md: 10, sm: 6, xs: 4, xxs: 2 },\n layouts: {},\n margin: [10, 10],\n containerPadding: {\n lg: [0, 0],\n md: [0, 0],\n sm: [0, 0],\n xs: [0, 0],\n xxs: [0, 0]\n },\n onBreakpointChange: noop,\n onLayoutChange: noop,\n onWidthChange: noop\n };\n\n state = this.generateInitialState();\n\n generateInitialState(): State {\n const { width, breakpoints, layouts, cols } = this.props;\n const breakpoint = getBreakpointFromWidth(breakpoints, width);\n const colNo = getColsFromBreakpoint(breakpoint, cols);\n // verticalCompact compatibility, now deprecated\n const compactType =\n this.props.verticalCompact === false ? null : this.props.compactType;\n // Get the initial layout. This can tricky; we try to generate one however possible if one doesn't exist\n // for this layout.\n const initialLayout = findOrGenerateResponsiveLayout(\n layouts,\n breakpoints,\n breakpoint,\n breakpoint,\n colNo,\n compactType\n );\n\n return {\n layout: initialLayout,\n breakpoint: breakpoint,\n cols: colNo\n };\n }\n\n static getDerivedStateFromProps(nextProps: Props<*>, prevState: State) {\n if (!isEqual(nextProps.layouts, prevState.layouts)) {\n // Allow parent to set layouts directly.\n const { breakpoint, cols } = prevState;\n\n // Since we're setting an entirely new layout object, we must generate a new responsive layout\n // if one does not exist.\n const newLayout = findOrGenerateResponsiveLayout(\n nextProps.layouts,\n nextProps.breakpoints,\n breakpoint,\n breakpoint,\n cols,\n nextProps.compactType\n );\n return { layout: newLayout, layouts: nextProps.layouts };\n }\n\n return null;\n }\n\n componentDidUpdate(prevProps: Props<*>) {\n // Allow parent to set width or breakpoint directly.\n if (\n this.props.width != prevProps.width ||\n this.props.breakpoint !== prevProps.breakpoint ||\n !isEqual(this.props.breakpoints, prevProps.breakpoints) ||\n !isEqual(this.props.cols, prevProps.cols)\n ) {\n this.onWidthChange(prevProps);\n }\n }\n\n // wrap layouts so we do not need to pass layouts to child\n onLayoutChange = (layout: Layout) => {\n this.props.onLayoutChange(layout, {\n ...this.props.layouts,\n [this.state.breakpoint]: layout\n });\n };\n\n /**\n * When the width changes work through breakpoints and reset state with the new width & breakpoint.\n * Width changes are necessary to figure out the widget widths.\n */\n onWidthChange(prevProps: Props<*>) {\n const { breakpoints, cols, layouts, compactType } = this.props;\n const newBreakpoint =\n this.props.breakpoint ||\n getBreakpointFromWidth(this.props.breakpoints, this.props.width);\n\n const lastBreakpoint = this.state.breakpoint;\n const newCols: number = getColsFromBreakpoint(newBreakpoint, cols);\n const newLayouts = { ...layouts };\n\n // Breakpoint change\n if (\n lastBreakpoint !== newBreakpoint ||\n prevProps.breakpoints !== breakpoints ||\n prevProps.cols !== cols\n ) {\n // Preserve the current layout if the current breakpoint is not present in the next layouts.\n if (!(lastBreakpoint in newLayouts))\n newLayouts[lastBreakpoint] = cloneLayout(this.state.layout);\n\n // Find or generate a new layout.\n let layout = findOrGenerateResponsiveLayout(\n newLayouts,\n breakpoints,\n newBreakpoint,\n lastBreakpoint,\n newCols,\n compactType\n );\n\n // This adds missing items.\n layout = synchronizeLayoutWithChildren(\n layout,\n this.props.children,\n newCols,\n compactType\n );\n\n // Store the new layout.\n newLayouts[newBreakpoint] = layout;\n\n // callbacks\n this.props.onLayoutChange(layout, newLayouts);\n this.props.onBreakpointChange(newBreakpoint, newCols);\n\n this.setState({\n breakpoint: newBreakpoint,\n layout: layout,\n cols: newCols\n });\n }\n\n const margin = getIndentationValue(this.props.margin, newBreakpoint);\n const containerPadding = getIndentationValue(\n this.props.containerPadding,\n newBreakpoint\n );\n\n //call onWidthChange on every change of width, not only on breakpoint changes\n this.props.onWidthChange(\n this.props.width,\n margin,\n newCols,\n containerPadding\n );\n }\n\n render() {\n /* eslint-disable no-unused-vars */\n const {\n breakpoint,\n breakpoints,\n cols,\n layouts,\n margin,\n containerPadding,\n onBreakpointChange,\n onLayoutChange,\n onWidthChange,\n ...other\n } = this.props;\n /* eslint-enable no-unused-vars */\n\n return (\n \n );\n }\n}\n","// @flow\nimport * as React from \"react\";\nimport PropTypes from \"prop-types\";\nimport ReactDOM from \"react-dom\";\n\ntype WPDefaultProps = {|\n measureBeforeMount: boolean\n|};\n\n// eslint-disable-next-line no-unused-vars\ntype WPProps = {|\n className?: string,\n style?: Object,\n ...WPDefaultProps\n|};\n\ntype WPState = {|\n width: number\n|};\n\n/*\n * A simple HOC that provides facility for listening to container resizes.\n *\n * The Flow type is pretty janky here. I can't just spread `WPProps` into this returned object - I wish I could - but it triggers\n * a flow bug of some sort that causes it to stop typechecking.\n */\nexport default function WidthProvider(\n ComposedComponent: React.AbstractComponent\n): React.AbstractComponent<{|\n ...Config,\n measureBeforeMount?: boolean,\n className?: string,\n style?: Object,\n width?: number\n|}> {\n return class WidthProvider extends React.Component<\n {|\n ...Config,\n measureBeforeMount?: boolean,\n className?: string,\n style?: Object,\n width?: number\n |},\n WPState\n > {\n static defaultProps: WPDefaultProps = {\n measureBeforeMount: false\n };\n\n static propTypes = {\n // If true, will not render children until mounted. Useful for getting the exact width before\n // rendering, to prevent any unsightly resizing.\n measureBeforeMount: PropTypes.bool\n };\n\n state = {\n width: 1280\n };\n\n mounted: boolean = false;\n\n componentDidMount() {\n this.mounted = true;\n\n window.addEventListener(\"resize\", this.onWindowResize);\n // Call to properly set the breakpoint and resize the elements.\n // Note that if you're doing a full-width element, this can get a little wonky if a scrollbar\n // appears because of the grid. In that case, fire your own resize event, or set `overflow: scroll` on your body.\n this.onWindowResize();\n }\n\n componentWillUnmount() {\n this.mounted = false;\n window.removeEventListener(\"resize\", this.onWindowResize);\n }\n\n onWindowResize = () => {\n if (!this.mounted) return;\n // eslint-disable-next-line react/no-find-dom-node\n const node = ReactDOM.findDOMNode(this); // Flow casts this to Text | Element\n if (node instanceof HTMLElement)\n this.setState({ width: node.offsetWidth });\n };\n\n render() {\n const { measureBeforeMount, ...rest } = this.props;\n if (measureBeforeMount && !this.mounted) {\n return (\n
\n );\n }\n\n return ;\n }\n };\n}\n"],"sourceRoot":""} \ No newline at end of file +{"version":3,"sources":["webpack://ReactGridLayout/webpack/universalModuleDefinition","webpack://ReactGridLayout/webpack/bootstrap","webpack://ReactGridLayout/./node_modules/prop-types/index.js","webpack://ReactGridLayout/./lib/utils.js","webpack://ReactGridLayout/external {\"commonjs\":\"react\",\"commonjs2\":\"react\",\"amd\":\"react\",\"root\":\"React\"}","webpack://ReactGridLayout/./node_modules/lodash.isequal/index.js","webpack://ReactGridLayout/./lib/responsiveUtils.js","webpack://ReactGridLayout/external {\"commonjs\":\"react-dom\",\"commonjs2\":\"react-dom\",\"amd\":\"react-dom\",\"root\":\"ReactDOM\"}","webpack://ReactGridLayout/./node_modules/classnames/index.js","webpack://ReactGridLayout/./node_modules/react-draggable/build/web/react-draggable.min.js","webpack://ReactGridLayout/./lib/calculateUtils.js","webpack://ReactGridLayout/./lib/GridItem.jsx","webpack://ReactGridLayout/./lib/ReactGridLayoutPropTypes.js","webpack://ReactGridLayout/./lib/ReactGridLayout.jsx","webpack://ReactGridLayout/./node_modules/react-resizable/build/Resizable.js","webpack://ReactGridLayout/./node_modules/react-resizable/index.js","webpack://ReactGridLayout/./index-dev.js","webpack://ReactGridLayout/(webpack)/buildin/global.js","webpack://ReactGridLayout/(webpack)/buildin/module.js","webpack://ReactGridLayout/./node_modules/prop-types/factoryWithThrowingShims.js","webpack://ReactGridLayout/./node_modules/prop-types/lib/ReactPropTypesSecret.js","webpack://ReactGridLayout/./node_modules/react-resizable/build/utils.js","webpack://ReactGridLayout/./node_modules/react-resizable/build/ResizableBox.js","webpack://ReactGridLayout/./lib/ResponsiveReactGridLayout.jsx","webpack://ReactGridLayout/./lib/components/WidthProvider.jsx"],"names":["root","factory","exports","module","require","define","amd","window","__WEBPACK_EXTERNAL_MODULE__2__","__WEBPACK_EXTERNAL_MODULE__5__","installedModules","__webpack_require__","moduleId","i","l","modules","call","m","c","d","name","getter","o","Object","defineProperty","enumerable","get","r","Symbol","toStringTag","value","t","mode","__esModule","ns","create","key","bind","n","object","property","prototype","hasOwnProperty","p","s","bottom","layout","bottomY","max","len","length","y","h","cloneLayout","newLayout","Array","cloneLayoutItem","layoutItem","w","x","minW","maxW","minH","maxH","moved","Boolean","static","isDraggable","isResizable","isBounded","childrenEqual","a","b","isEqual","React","Children","map","fastRGLPropsEqual","fastPositionEqual","left","top","width","height","collides","l1","l2","compact","compactType","cols","compareWith","getStatics","sorted","sortLayoutItems","out","compactItem","push","indexOf","heightWidth","resolveCompactionCollision","item","moveToCoord","axis","sizeProp","otherItem","fullLayout","compactH","Math","min","getFirstCollision","correctBounds","bounds","collidesWith","getLayoutItem","id","getAllCollisions","filter","moveElement","isUserAction","preventCollision","log","String","oldX","oldY","reverse","collisions","collision","moveElementAwayFromCollision","itemToMove","compactV","fakeItem","undefined","perc","num","setTransform","translate","transform","WebkitTransform","MozTransform","msTransform","OTransform","position","setTopLeft","sortLayoutItemsByColRow","sortLayoutItemsByRowCol","slice","sort","synchronizeLayoutWithChildren","initialLayout","children","forEach","child","exists","g","props","_grid","validateLayout","contextName","subProps","isArray","Error","j","verticalCompact","autoBindHandlers","el","fns","noop","argsTag","mapTag","objectTag","setTag","reIsHostCtor","reIsUint","typedArrayTags","freeGlobal","global","freeSelf","self","Function","freeExports","nodeType","freeModule","moduleExports","freeProcess","process","nodeUtil","binding","e","nodeIsTypedArray","isTypedArray","arraySome","array","predicate","index","mapToArray","result","size","setToArray","set","uid","func","arrayProto","funcProto","objectProto","coreJsData","funcToString","toString","maskSrcKey","exec","keys","IE_PROTO","nativeObjectToString","reIsNative","RegExp","replace","Buffer","Uint8Array","propertyIsEnumerable","splice","symToStringTag","nativeGetSymbols","getOwnPropertySymbols","nativeIsBuffer","isBuffer","nativeKeys","arg","DataView","getNative","Map","Promise","Set","WeakMap","nativeCreate","dataViewCtorString","toSource","mapCtorString","promiseCtorString","setCtorString","weakMapCtorString","symbolProto","symbolValueOf","valueOf","Hash","entries","this","clear","entry","ListCache","MapCache","SetCache","values","__data__","add","Stack","data","arrayLikeKeys","inherited","isArr","isArg","isArguments","isBuff","isType","skipIndexes","iteratee","baseTimes","isIndex","assocIndexOf","eq","baseGetTag","isOwn","tag","unmasked","getRawTag","objectToString","baseIsArguments","isObjectLike","baseIsEqual","other","bitmask","customizer","stack","equalFunc","objIsArr","othIsArr","objTag","getTag","othTag","objIsObj","othIsObj","isSameTag","equalArrays","byteLength","byteOffset","buffer","message","convert","isPartial","stacked","equalByTag","objIsWrapped","othIsWrapped","objUnwrapped","othUnwrapped","objProps","getAllKeys","objLength","othLength","skipCtor","objValue","othValue","compared","objCtor","constructor","othCtor","equalObjects","baseIsEqualDeep","baseIsNative","isObject","isMasked","isFunction","test","baseKeys","Ctor","proto","arrLength","seen","arrValue","othIndex","has","keysFunc","symbolsFunc","offset","arrayPush","baseGetAllKeys","getSymbols","getMapData","type","getValue","pop","pairs","LARGE_ARRAY_SIZE","resIndex","arrayFilter","symbol","ArrayBuffer","resolve","ctorString","arguments","isLength","baseUnary","getBreakpointFromWidth","breakpoints","sortBreakpoints","matching","breakpointName","getColsFromBreakpoint","breakpoint","findOrGenerateResponsiveLayout","layouts","lastBreakpoint","breakpointsSorted","breakpointsAbove","hasOwn","classNames","classes","argType","inner","apply","join","default","DraggableCore","resetWarningCache","isRequired","bool","number","string","any","arrayOf","element","elementType","instanceOf","node","objectOf","oneOf","oneOfType","shape","exact","checkPropTypes","PropTypes","u","f","isNaN","parseInt","concat","toUpperCase","document","documentElement","style","v","getOwnPropertyDescriptor","configurable","writable","O","S","D","parentNode","attachEvent","addEventListener","P","detachEvent","removeEventListener","clientHeight","ownerDocument","defaultView","getComputedStyle","borderTopWidth","borderBottomWidth","E","clientWidth","borderLeftWidth","borderRightWidth","T","paddingTop","paddingBottom","N","paddingLeft","paddingRight","C","M","getElementById","createElement","innerHTML","getElementsByTagName","appendChild","body","classList","className","match","k","remove","selection","empty","getSelection","removeAllRanges","_","getOwnPropertyDescriptors","defineProperties","touchAction","X","Y","L","targetTouches","identifier","changedTouches","I","getBoundingClientRect","clientX","scrollLeft","clientY","scrollTop","offsetParent","scale","R","state","lastX","deltaX","deltaY","lastY","A","findDOMNode","U","iterator","V","next","done","return","TypeError","W","B","setPrototypeOf","getPrototypeOf","__proto__","H","ReferenceError","q","G","z","start","move","stop","F","J","dragging","NaN","touchIdentifier","onMouseDown","allowAnyClick","button","disabled","target","Node","handle","cancel","setState","onStart","enableUserSelectHack","handleDrag","handleDragStop","preventDefault","grid","round","onDrag","MouseEvent","createEvent","initMouseEvent","onStop","handleDragStart","Component","cloneElement","only","onTouchStart","onMouseUp","onTouchEnd","K","Q","assign","tt","et","st","nt","rt","ot","at","it","ut","dragged","slackX","slackY","$","right","querySelector","HTMLElement","offsetLeft","marginLeft","offsetTop","marginTop","marginRight","marginBottom","defaultPosition","prevPropsPosition","isElementSVG","console","warn","SVGElement","defaultClassName","defaultClassNameDragging","defaultClassNameDragged","positionOffset","Z","onDragStart","onDragStop","propTypes","defaultProps","calcGridColWidth","positionParams","margin","containerPadding","containerWidth","calcGridItemWHPx","gridUnits","colOrRowSize","marginPx","Number","isFinite","calcGridItemPosition","rowHeight","colWidth","resizing","calcXY","maxRows","clamp","lowerBound","upperBound","GridItem","newPosition","parentRect","clientRect","cLeft","transformScale","pLeft","cTop","pTop","getPositionParams","callbackData","onResizeHandler","nextProps","nextState","droppingPosition","oldPosition","useCSSTransforms","moveDroppingItem","prevProps","prevDroppingPosition","currentNode","ReactDOM","shouldDrag","pos","usePercentages","maxWidth","mins","maxes","minConstraints","maxConstraints","Infinity","draggableOpts","onResizeStop","onResizeStart","onResize","handlerName","handler","calcWH","newChild","dropping","cssTransforms","createStyle","mixinResizable","mixinDraggable","propName","autoSize","draggableCancel","draggableHandle","isDroppable","onLayoutChange","onDrop","droppingItem","innerRef","isFirefox","navigator","userAgent","ReactGridLayout","context","activeDrag","mounted","oldDragItem","oldLayout","oldResizeItem","droppingDOMNode","nativeEvent","layerX","layerY","calculatedPosition","stopPropagation","dragEnterCounter","removeDroppingPlaceholder","find","prevState","newLayoutBase","propsLayout","onLayoutMaybeChanged","nbRow","containerPaddingY","placeholder","hasCollisions","leastX","leastY","isDroppingItem","draggable","resizable","bounded","mergedClassName","mergedStyle","containerHeight","ref","onDragLeave","onDragEnter","onDragOver","processGridItem","ReactGridLayoutPropTypes","_react","_interopRequireDefault","_propTypes","_reactDraggable","_utils","obj","_extends","source","ownKeys","enumerableOnly","symbols","sym","_assertThisInitialized","_defineProperty","Resizable","_React$Component","subClass","superClass","_this","_len","args","_key","slackW","slackH","_proto","lockAspectRatio","aspectRatio","runConstraints","_ref","ratio","_ratio","oldW","oldH","_this$state","resizeHandler","_this2","_ref2","canDragX","canDragY","widthChanged","heightChanged","_this2$runConstraints","newState","persist","renderResizeHandle","resizeHandle","render","_this3","_this$props","resizeHandles","handleSize","excluded","sourceKeys","_objectWithoutPropertiesLoose","_objectSpread","ResizableBox","utils","Responsive","WidthProvider","webpackPolyfill","deprecate","paths","ReactPropTypesSecret","emptyFunction","emptyFunctionWithReset","shim","componentName","location","propFullName","secret","err","getShim","ReactPropTypes","_Resizable","propsWidth","propsHeight","getDerivedStateFromProps","getIndentationValue","param","ResponsiveReactGridLayout","generateInitialState","colNo","onWidthChange","newBreakpoint","newCols","newLayouts","onBreakpointChange","lg","md","sm","xs","xxs","ComposedComponent","offsetWidth","onWindowResize","measureBeforeMount","rest"],"mappings":"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","file":"react-grid-layout.min.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory(require(\"react\"), require(\"react-dom\"));\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([\"react\", \"react-dom\"], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"ReactGridLayout\"] = factory(require(\"react\"), require(\"react-dom\"));\n\telse\n\t\troot[\"ReactGridLayout\"] = factory(root[\"React\"], root[\"ReactDOM\"]);\n})(window, function(__WEBPACK_EXTERNAL_MODULE__2__, __WEBPACK_EXTERNAL_MODULE__5__) {\nreturn "," \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n \t\t}\n \t};\n\n \t// define __esModule on exports\n \t__webpack_require__.r = function(exports) {\n \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n \t\t}\n \t\tObject.defineProperty(exports, '__esModule', { value: true });\n \t};\n\n \t// create a fake namespace object\n \t// mode & 1: value is a module id, require it\n \t// mode & 2: merge all properties of value into the ns\n \t// mode & 4: return value when already ns object\n \t// mode & 8|1: behave like require\n \t__webpack_require__.t = function(value, mode) {\n \t\tif(mode & 1) value = __webpack_require__(value);\n \t\tif(mode & 8) return value;\n \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n \t\tvar ns = Object.create(null);\n \t\t__webpack_require__.r(ns);\n \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n \t\treturn ns;\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = 11);\n","/**\n * Copyright (c) 2013-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\nif (process.env.NODE_ENV !== 'production') {\n var ReactIs = require('react-is');\n\n // By explicitly using `prop-types` you are opting into new development behavior.\n // http://fb.me/prop-types-in-prod\n var throwOnDirectAccess = true;\n module.exports = require('./factoryWithTypeCheckers')(ReactIs.isElement, throwOnDirectAccess);\n} else {\n // By explicitly using `prop-types` you are opting into new production behavior.\n // http://fb.me/prop-types-in-prod\n module.exports = require('./factoryWithThrowingShims')();\n}\n","// @flow\nimport isEqual from \"lodash.isequal\";\nimport React from \"react\";\nimport type {\n ChildrenArray as ReactChildrenArray,\n Element as ReactElement\n} from \"react\";\nexport type LayoutItem = {\n w: number,\n h: number,\n x: number,\n y: number,\n i: string,\n minW?: number,\n minH?: number,\n maxW?: number,\n maxH?: number,\n moved?: boolean,\n static?: boolean,\n isDraggable?: ?boolean,\n isResizable?: ?boolean,\n isBounded?: ?boolean\n};\nexport type Layout = $ReadOnlyArray;\nexport type Position = {\n left: number,\n top: number,\n width: number,\n height: number\n};\nexport type ReactDraggableCallbackData = {\n node: HTMLElement,\n x?: number,\n y?: number,\n deltaX: number,\n deltaY: number,\n lastX?: number,\n lastY?: number\n};\n\nexport type PartialPosition = { left: number, top: number };\nexport type DroppingPosition = { left: number, top: number, e: Event };\nexport type Size = { width: number, height: number };\nexport type GridDragEvent = {\n e: Event,\n node: HTMLElement,\n newPosition: PartialPosition\n};\nexport type GridResizeEvent = { e: Event, node: HTMLElement, size: Size };\nexport type DragOverEvent = MouseEvent & {\n nativeEvent: {\n layerX: number,\n layerY: number,\n target: {\n className: String\n }\n }\n};\n\ntype REl = ReactElement;\nexport type ReactChildren = ReactChildrenArray;\n\n// All callbacks are of the signature (layout, oldItem, newItem, placeholder, e).\nexport type EventCallback = (\n Layout,\n oldItem: ?LayoutItem,\n newItem: ?LayoutItem,\n placeholder: ?LayoutItem,\n Event,\n ?HTMLElement\n) => void;\nexport type CompactType = ?(\"horizontal\" | \"vertical\");\n\nconst isProduction = process.env.NODE_ENV === \"production\";\nconst DEBUG = false;\n\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,\n 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,\n h: layoutItem.h,\n x: layoutItem.x,\n y: layoutItem.y,\n i: layoutItem.i,\n minW: layoutItem.minW,\n maxW: layoutItem.maxW,\n minH: layoutItem.minH,\n maxH: layoutItem.maxH,\n moved: Boolean(layoutItem.moved),\n static: Boolean(layoutItem.static),\n // These can be null/undefined\n isDraggable: layoutItem.isDraggable,\n isResizable: layoutItem.isResizable,\n isBounded: layoutItem.isBounded\n };\n}\n\n/**\n * Comparing React `children` is a bit difficult. This is a good way to compare them.\n * This will catch differences in keys, order, and length.\n */\nexport function childrenEqual(a: ReactChildren, b: ReactChildren): boolean {\n return isEqual(\n React.Children.map(a, c => c.key),\n React.Children.map(b, c => c.key)\n );\n}\n\n/**\n * See `fastRGLPropsEqual.js`.\n * We want this to run as fast as possible - it is called often - and to be\n * resilient to new props that we add. So rather than call lodash.isEqual,\n * which isn't suited to comparing props very well, we use this specialized\n * function in conjunction with preval to generate the fastest possible comparison\n * function, tuned for exactly our props.\n */\ntype FastRGLPropsEqual = (Object, Object, Function) => boolean;\nexport const fastRGLPropsEqual: FastRGLPropsEqual = require(\"./fastRGLPropsEqual\");\n\n// Like the above, but a lot simpler.\nexport function fastPositionEqual(a: Position, b: Position) {\n return (\n a.left === b.left &&\n a.top === b.top &&\n a.width === b.width &&\n a.height === b.height\n );\n}\n\n/**\n * Given two layoutitems, check if they collide.\n */\nexport function collides(l1: LayoutItem, l2: LayoutItem): boolean {\n if (l1.i === l2.i) 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 * Does not modify layout items (clones). Creates a new layout array.\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(\n layout: Layout,\n compactType: CompactType,\n cols: number\n): 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 = sortLayoutItems(layout, compactType);\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 = cloneLayoutItem(sorted[i]);\n\n // Don't move static elements\n if (!l.static) {\n l = compactItem(compareWith, l, compactType, cols, sorted);\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(sorted[i])] = l;\n\n // Clear moved flag, if it exists.\n l.moved = false;\n }\n\n return out;\n}\n\nconst heightWidth = { x: \"w\", y: \"h\" };\n/**\n * Before moving item down, it will check if the movement will cause collisions and move those items down before.\n */\nfunction resolveCompactionCollision(\n layout: Layout,\n item: LayoutItem,\n moveToCoord: number,\n axis: \"x\" | \"y\"\n) {\n const sizeProp = heightWidth[axis];\n item[axis] += 1;\n const itemIndex = layout\n .map(layoutItem => {\n return layoutItem.i;\n })\n .indexOf(item.i);\n\n // Go through each item we collide with.\n for (let i = itemIndex + 1; i < layout.length; i++) {\n const otherItem = layout[i];\n // Ignore static items\n if (otherItem.static) continue;\n\n // Optimization: we can break early if we know we're past this el\n // We can do this b/c it's a sorted layout\n if (otherItem.y > item.y + item.h) break;\n\n if (collides(item, otherItem)) {\n resolveCompactionCollision(\n layout,\n otherItem,\n moveToCoord + item[sizeProp],\n axis\n );\n }\n }\n\n item[axis] = moveToCoord;\n}\n\n/**\n * Compact an item in the layout.\n *\n * Modifies item.\n *\n */\nexport function compactItem(\n compareWith: Layout,\n l: LayoutItem,\n compactType: CompactType,\n cols: number,\n fullLayout: Layout\n): LayoutItem {\n const compactV = compactType === \"vertical\";\n const compactH = compactType === \"horizontal\";\n if (compactV) {\n // Bottom 'y' possible is the bottom of the layout.\n // This allows you to do nice stuff like specify {y: Infinity}\n // This is here because the layout must be sorted in order to get the correct bottom `y`.\n l.y = Math.min(bottom(compareWith), l.y);\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 } else if (compactH) {\n l.y = Math.min(bottom(compareWith), l.y);\n // Move the element left as far as it can go without colliding.\n while (l.x > 0 && !getFirstCollision(compareWith, l)) {\n l.x--;\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 if (compactH) {\n resolveCompactionCollision(fullLayout, l, collides.x + collides.w, \"x\");\n } else {\n resolveCompactionCollision(fullLayout, l, collides.y + collides.h, \"y\");\n }\n // Since we can't grow without bounds horizontally, if we've overflown, let's move it down and try again.\n if (compactH && l.x + l.w > cols) {\n l.x = cols - l.w;\n l.y++;\n }\n }\n return l;\n}\n\n/**\n * Given a layout, make sure all elements fit within its bounds.\n *\n * Modifies layout items.\n *\n * @param {Array} layout Layout array.\n * @param {Number} bounds Number of columns.\n */\nexport function correctBounds(\n layout: Layout,\n bounds: { cols: number }\n): 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(\n layout: Layout,\n layoutItem: LayoutItem\n): ?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(\n layout: Layout,\n layoutItem: LayoutItem\n): Array {\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 {\n return layout.filter(l => l.static);\n}\n\n/**\n * Move an element. Responsible for doing cascading movements of other elements.\n *\n * Modifies layout items.\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 */\nexport function moveElement(\n layout: Layout,\n l: LayoutItem,\n x: ?number,\n y: ?number,\n isUserAction: ?boolean,\n preventCollision: ?boolean,\n compactType: CompactType,\n cols: number\n): Layout {\n // If this is static and not explicitly enabled as draggable,\n // no move is possible, so we can short-circuit this immediately.\n if (l.static && l.isDraggable !== true) return layout;\n\n // Short-circuit if nothing to do.\n if (l.y === y && l.x === x) return layout;\n\n log(\n `Moving element ${l.i} to [${String(x)},${String(y)}] from [${l.x},${l.y}]`\n );\n const oldX = l.x;\n const oldY = l.y;\n\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 = sortLayoutItems(layout, compactType);\n const movingUp =\n compactType === \"vertical\" && typeof y === \"number\"\n ? oldY >= y\n : compactType === \"horizontal\" && typeof x === \"number\"\n ? oldX >= x\n : false;\n // $FlowIgnore acceptable modification of read-only array as it was recently cloned\n if (movingUp) sorted = sorted.reverse();\n const collisions = getAllCollisions(sorted, l);\n\n // There was a collision; abort\n if (preventCollision && collisions.length) {\n log(`Collision prevented on ${l.i}, reverting.`);\n l.x = oldX;\n l.y = oldY;\n l.moved = false;\n return layout;\n }\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 log(\n `Resolving collision between ${l.i} at [${l.x},${l.y}] and ${collision.i} at [${collision.x},${collision.y}]`\n );\n\n // Short circuit so we can't infinite loop\n if (collision.moved) continue;\n\n // Don't move static items - we have to move *this* element away\n if (collision.static) {\n layout = moveElementAwayFromCollision(\n layout,\n collision,\n l,\n isUserAction,\n compactType,\n cols\n );\n } else {\n layout = moveElementAwayFromCollision(\n layout,\n l,\n collision,\n isUserAction,\n compactType,\n cols\n );\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 */\nexport function moveElementAwayFromCollision(\n layout: Layout,\n collidesWith: LayoutItem,\n itemToMove: LayoutItem,\n isUserAction: ?boolean,\n compactType: CompactType,\n cols: number\n): Layout {\n const compactH = compactType === \"horizontal\";\n // Compact vertically if not set to horizontal\n const compactV = compactType !== \"horizontal\";\n const preventCollision = collidesWith.static; // we're already colliding (not for static items)\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 // Reset isUserAction flag because we're not in the main collision anymore.\n isUserAction = false;\n\n // Make a mock item so we don't modify the item here, only modify in moveElement.\n const fakeItem: LayoutItem = {\n x: compactH ? Math.max(collidesWith.x - itemToMove.w, 0) : itemToMove.x,\n y: compactV ? Math.max(collidesWith.y - itemToMove.h, 0) : itemToMove.y,\n w: itemToMove.w,\n h: itemToMove.h,\n i: \"-1\"\n };\n\n // No collision? If so, we can go up there; otherwise, we'll end up moving down as normal\n if (!getFirstCollision(layout, fakeItem)) {\n log(\n `Doing reverse collision on ${itemToMove.i} up to [${fakeItem.x},${fakeItem.y}].`\n );\n return moveElement(\n layout,\n itemToMove,\n compactH ? fakeItem.x : undefined,\n compactV ? fakeItem.y : undefined,\n isUserAction,\n preventCollision,\n compactType,\n cols\n );\n }\n }\n\n return moveElement(\n layout,\n itemToMove,\n compactH ? itemToMove.x + 1 : undefined,\n compactV ? itemToMove.y + 1 : undefined,\n isUserAction,\n preventCollision,\n compactType,\n cols\n );\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 }: Position): Object {\n // Replace unitless items with px\n const translate = `translate(${left}px,${top}px)`;\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 }: Position): 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/**\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 sortLayoutItems(\n layout: Layout,\n compactType: CompactType\n): Layout {\n if (compactType === \"horizontal\") return sortLayoutItemsByColRow(layout);\n else return sortLayoutItemsByRowCol(layout);\n}\n\n/**\n * Sort layout items by row ascending and column ascending.\n *\n * Does not modify Layout.\n */\nexport function sortLayoutItemsByRowCol(layout: Layout): Layout {\n // Slice to clone array as sort modifies\n return layout.slice(0).sort(function (a, b) {\n if (a.y > b.y || (a.y === b.y && a.x > b.x)) {\n return 1;\n } else if (a.y === b.y && a.x === b.x) {\n // Without this, we can get different sort results in IE vs. Chrome/FF\n return 0;\n }\n return -1;\n });\n}\n\n/**\n * Sort layout items by column ascending then row ascending.\n *\n * Does not modify Layout.\n */\nexport function sortLayoutItemsByColRow(layout: Layout): Layout {\n return layout.slice(0).sort(function (a, b) {\n if (a.x > b.x || (a.x === b.x && a.y > b.y)) {\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 * Does not modify initialLayout.\n *\n * @param {Array} initialLayout Layout passed in through props.\n * @param {String} breakpoint Current responsive breakpoint.\n * @param {?String} compact Compaction option.\n * @return {Array} Working layout.\n */\nexport function synchronizeLayoutWithChildren(\n initialLayout: Layout,\n children: ReactChildren,\n cols: number,\n compactType: CompactType\n): Layout {\n initialLayout = initialLayout || [];\n\n // Generate one layout item per child.\n const layout: LayoutItem[] = [];\n React.Children.forEach(children, (child: ReactElement, i: number) => {\n // Don't overwrite if it already exists.\n const exists = getLayoutItem(initialLayout, String(child.key));\n if (exists) {\n layout[i] = cloneLayoutItem(exists);\n } else {\n if (!isProduction && child.props._grid) {\n console.warn(\n \"`_grid` properties on children have been deprecated as of React 15.2. \" + // eslint-disable-line\n \"Please use `data-grid` or add your properties directly to the `layout`.\"\n );\n }\n const g = child.props[\"data-grid\"] || child.props._grid;\n\n // Hey, this item has a data-grid property, use it.\n if (g) {\n if (!isProduction) {\n validateLayout([g], \"ReactGridLayout.children\");\n }\n layout[i] = cloneLayoutItem({ ...g, i: child.key });\n } else {\n // Nothing provided: ensure this is added to the bottom\n layout[i] = cloneLayoutItem({\n w: 1,\n h: 1,\n x: 0,\n y: bottom(layout),\n i: String(child.key)\n });\n }\n }\n });\n\n // Correct the layout.\n const correctedLayout = correctBounds(layout, { cols: cols });\n return compact(correctedLayout, compactType, cols);\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(\n layout: Layout,\n contextName: string = \"Layout\"\n): void {\n const subProps = [\"x\", \"y\", \"w\", \"h\"];\n if (!Array.isArray(layout))\n 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(\n \"ReactGridLayout: \" +\n contextName +\n \"[\" +\n i +\n \"].\" +\n subProps[j] +\n \" must be a number!\"\n );\n }\n }\n if (item.i && typeof item.i !== \"string\") {\n throw new Error(\n \"ReactGridLayout: \" + contextName + \"[\" + i + \"].i must be a string!\"\n );\n }\n if (item.static !== undefined && typeof item.static !== \"boolean\") {\n throw new Error(\n \"ReactGridLayout: \" +\n contextName +\n \"[\" +\n i +\n \"].static must be a boolean!\"\n );\n }\n }\n}\n\n// Legacy support for verticalCompact: false\nexport function compactType(\n props: ?{ verticalCompact: boolean, compactType: CompactType }\n): CompactType {\n const { verticalCompact, compactType } = props || {};\n return verticalCompact === false ? null : compactType;\n}\n\n// Flow can't really figure this out, so we just use Object\nexport function autoBindHandlers(el: Object, fns: Array): void {\n fns.forEach(key => (el[key] = el[key].bind(el)));\n}\n\nfunction log(...args) {\n if (!DEBUG) return;\n // eslint-disable-next-line no-console\n console.log(...args);\n}\n\nexport const noop = () => {};\n","module.exports = __WEBPACK_EXTERNAL_MODULE__2__;","/**\n * Lodash (Custom Build) \n * Build: `lodash modularize exports=\"npm\" -o ./`\n * Copyright JS Foundation and other contributors \n * Released under MIT license \n * Based on Underscore.js 1.8.3 \n * Copyright Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors\n */\n\n/** Used as the size to enable large array optimizations. */\nvar LARGE_ARRAY_SIZE = 200;\n\n/** Used to stand-in for `undefined` hash values. */\nvar HASH_UNDEFINED = '__lodash_hash_undefined__';\n\n/** Used to compose bitmasks for value comparisons. */\nvar COMPARE_PARTIAL_FLAG = 1,\n COMPARE_UNORDERED_FLAG = 2;\n\n/** Used as references for various `Number` constants. */\nvar MAX_SAFE_INTEGER = 9007199254740991;\n\n/** `Object#toString` result references. */\nvar argsTag = '[object Arguments]',\n arrayTag = '[object Array]',\n asyncTag = '[object AsyncFunction]',\n boolTag = '[object Boolean]',\n dateTag = '[object Date]',\n errorTag = '[object Error]',\n funcTag = '[object Function]',\n genTag = '[object GeneratorFunction]',\n mapTag = '[object Map]',\n numberTag = '[object Number]',\n nullTag = '[object Null]',\n objectTag = '[object Object]',\n promiseTag = '[object Promise]',\n proxyTag = '[object Proxy]',\n regexpTag = '[object RegExp]',\n setTag = '[object Set]',\n stringTag = '[object String]',\n symbolTag = '[object Symbol]',\n undefinedTag = '[object Undefined]',\n weakMapTag = '[object WeakMap]';\n\nvar arrayBufferTag = '[object ArrayBuffer]',\n dataViewTag = '[object DataView]',\n float32Tag = '[object Float32Array]',\n float64Tag = '[object Float64Array]',\n int8Tag = '[object Int8Array]',\n int16Tag = '[object Int16Array]',\n int32Tag = '[object Int32Array]',\n uint8Tag = '[object Uint8Array]',\n uint8ClampedTag = '[object Uint8ClampedArray]',\n uint16Tag = '[object Uint16Array]',\n uint32Tag = '[object Uint32Array]';\n\n/**\n * Used to match `RegExp`\n * [syntax characters](http://ecma-international.org/ecma-262/7.0/#sec-patterns).\n */\nvar reRegExpChar = /[\\\\^$.*+?()[\\]{}|]/g;\n\n/** Used to detect host constructors (Safari). */\nvar reIsHostCtor = /^\\[object .+?Constructor\\]$/;\n\n/** Used to detect unsigned integer values. */\nvar reIsUint = /^(?:0|[1-9]\\d*)$/;\n\n/** Used to identify `toStringTag` values of typed arrays. */\nvar typedArrayTags = {};\ntypedArrayTags[float32Tag] = typedArrayTags[float64Tag] =\ntypedArrayTags[int8Tag] = typedArrayTags[int16Tag] =\ntypedArrayTags[int32Tag] = typedArrayTags[uint8Tag] =\ntypedArrayTags[uint8ClampedTag] = typedArrayTags[uint16Tag] =\ntypedArrayTags[uint32Tag] = true;\ntypedArrayTags[argsTag] = typedArrayTags[arrayTag] =\ntypedArrayTags[arrayBufferTag] = typedArrayTags[boolTag] =\ntypedArrayTags[dataViewTag] = typedArrayTags[dateTag] =\ntypedArrayTags[errorTag] = typedArrayTags[funcTag] =\ntypedArrayTags[mapTag] = typedArrayTags[numberTag] =\ntypedArrayTags[objectTag] = typedArrayTags[regexpTag] =\ntypedArrayTags[setTag] = typedArrayTags[stringTag] =\ntypedArrayTags[weakMapTag] = false;\n\n/** Detect free variable `global` from Node.js. */\nvar freeGlobal = typeof global == 'object' && global && global.Object === Object && global;\n\n/** Detect free variable `self`. */\nvar freeSelf = typeof self == 'object' && self && self.Object === Object && self;\n\n/** Used as a reference to the global object. */\nvar root = freeGlobal || freeSelf || Function('return this')();\n\n/** Detect free variable `exports`. */\nvar freeExports = typeof exports == 'object' && exports && !exports.nodeType && exports;\n\n/** Detect free variable `module`. */\nvar freeModule = freeExports && typeof module == 'object' && module && !module.nodeType && module;\n\n/** Detect the popular CommonJS extension `module.exports`. */\nvar moduleExports = freeModule && freeModule.exports === freeExports;\n\n/** Detect free variable `process` from Node.js. */\nvar freeProcess = moduleExports && freeGlobal.process;\n\n/** Used to access faster Node.js helpers. */\nvar nodeUtil = (function() {\n try {\n return freeProcess && freeProcess.binding && freeProcess.binding('util');\n } catch (e) {}\n}());\n\n/* Node.js helper references. */\nvar nodeIsTypedArray = nodeUtil && nodeUtil.isTypedArray;\n\n/**\n * A specialized version of `_.filter` for arrays without support for\n * iteratee shorthands.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} predicate The function invoked per iteration.\n * @returns {Array} Returns the new filtered array.\n */\nfunction arrayFilter(array, predicate) {\n var index = -1,\n length = array == null ? 0 : array.length,\n resIndex = 0,\n result = [];\n\n while (++index < length) {\n var value = array[index];\n if (predicate(value, index, array)) {\n result[resIndex++] = value;\n }\n }\n return result;\n}\n\n/**\n * Appends the elements of `values` to `array`.\n *\n * @private\n * @param {Array} array The array to modify.\n * @param {Array} values The values to append.\n * @returns {Array} Returns `array`.\n */\nfunction arrayPush(array, values) {\n var index = -1,\n length = values.length,\n offset = array.length;\n\n while (++index < length) {\n array[offset + index] = values[index];\n }\n return array;\n}\n\n/**\n * A specialized version of `_.some` for arrays without support for iteratee\n * shorthands.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} predicate The function invoked per iteration.\n * @returns {boolean} Returns `true` if any element passes the predicate check,\n * else `false`.\n */\nfunction arraySome(array, predicate) {\n var index = -1,\n length = array == null ? 0 : array.length;\n\n while (++index < length) {\n if (predicate(array[index], index, array)) {\n return true;\n }\n }\n return false;\n}\n\n/**\n * The base implementation of `_.times` without support for iteratee shorthands\n * or max array length checks.\n *\n * @private\n * @param {number} n The number of times to invoke `iteratee`.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Array} Returns the array of results.\n */\nfunction baseTimes(n, iteratee) {\n var index = -1,\n result = Array(n);\n\n while (++index < n) {\n result[index] = iteratee(index);\n }\n return result;\n}\n\n/**\n * The base implementation of `_.unary` without support for storing metadata.\n *\n * @private\n * @param {Function} func The function to cap arguments for.\n * @returns {Function} Returns the new capped function.\n */\nfunction baseUnary(func) {\n return function(value) {\n return func(value);\n };\n}\n\n/**\n * Checks if a `cache` value for `key` exists.\n *\n * @private\n * @param {Object} cache The cache to query.\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction cacheHas(cache, key) {\n return cache.has(key);\n}\n\n/**\n * Gets the value at `key` of `object`.\n *\n * @private\n * @param {Object} [object] The object to query.\n * @param {string} key The key of the property to get.\n * @returns {*} Returns the property value.\n */\nfunction getValue(object, key) {\n return object == null ? undefined : object[key];\n}\n\n/**\n * Converts `map` to its key-value pairs.\n *\n * @private\n * @param {Object} map The map to convert.\n * @returns {Array} Returns the key-value pairs.\n */\nfunction mapToArray(map) {\n var index = -1,\n result = Array(map.size);\n\n map.forEach(function(value, key) {\n result[++index] = [key, value];\n });\n return result;\n}\n\n/**\n * Creates a unary function that invokes `func` with its argument transformed.\n *\n * @private\n * @param {Function} func The function to wrap.\n * @param {Function} transform The argument transform.\n * @returns {Function} Returns the new function.\n */\nfunction overArg(func, transform) {\n return function(arg) {\n return func(transform(arg));\n };\n}\n\n/**\n * Converts `set` to an array of its values.\n *\n * @private\n * @param {Object} set The set to convert.\n * @returns {Array} Returns the values.\n */\nfunction setToArray(set) {\n var index = -1,\n result = Array(set.size);\n\n set.forEach(function(value) {\n result[++index] = value;\n });\n return result;\n}\n\n/** Used for built-in method references. */\nvar arrayProto = Array.prototype,\n funcProto = Function.prototype,\n objectProto = Object.prototype;\n\n/** Used to detect overreaching core-js shims. */\nvar coreJsData = root['__core-js_shared__'];\n\n/** Used to resolve the decompiled source of functions. */\nvar funcToString = funcProto.toString;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/** Used to detect methods masquerading as native. */\nvar maskSrcKey = (function() {\n var uid = /[^.]+$/.exec(coreJsData && coreJsData.keys && coreJsData.keys.IE_PROTO || '');\n return uid ? ('Symbol(src)_1.' + uid) : '';\n}());\n\n/**\n * Used to resolve the\n * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar nativeObjectToString = objectProto.toString;\n\n/** Used to detect if a method is native. */\nvar reIsNative = RegExp('^' +\n funcToString.call(hasOwnProperty).replace(reRegExpChar, '\\\\$&')\n .replace(/hasOwnProperty|(function).*?(?=\\\\\\()| for .+?(?=\\\\\\])/g, '$1.*?') + '$'\n);\n\n/** Built-in value references. */\nvar Buffer = moduleExports ? root.Buffer : undefined,\n Symbol = root.Symbol,\n Uint8Array = root.Uint8Array,\n propertyIsEnumerable = objectProto.propertyIsEnumerable,\n splice = arrayProto.splice,\n symToStringTag = Symbol ? Symbol.toStringTag : undefined;\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeGetSymbols = Object.getOwnPropertySymbols,\n nativeIsBuffer = Buffer ? Buffer.isBuffer : undefined,\n nativeKeys = overArg(Object.keys, Object);\n\n/* Built-in method references that are verified to be native. */\nvar DataView = getNative(root, 'DataView'),\n Map = getNative(root, 'Map'),\n Promise = getNative(root, 'Promise'),\n Set = getNative(root, 'Set'),\n WeakMap = getNative(root, 'WeakMap'),\n nativeCreate = getNative(Object, 'create');\n\n/** Used to detect maps, sets, and weakmaps. */\nvar dataViewCtorString = toSource(DataView),\n mapCtorString = toSource(Map),\n promiseCtorString = toSource(Promise),\n setCtorString = toSource(Set),\n weakMapCtorString = toSource(WeakMap);\n\n/** Used to convert symbols to primitives and strings. */\nvar symbolProto = Symbol ? Symbol.prototype : undefined,\n symbolValueOf = symbolProto ? symbolProto.valueOf : undefined;\n\n/**\n * Creates a hash object.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction Hash(entries) {\n var index = -1,\n length = entries == null ? 0 : entries.length;\n\n this.clear();\n while (++index < length) {\n var entry = entries[index];\n this.set(entry[0], entry[1]);\n }\n}\n\n/**\n * Removes all key-value entries from the hash.\n *\n * @private\n * @name clear\n * @memberOf Hash\n */\nfunction hashClear() {\n this.__data__ = nativeCreate ? nativeCreate(null) : {};\n this.size = 0;\n}\n\n/**\n * Removes `key` and its value from the hash.\n *\n * @private\n * @name delete\n * @memberOf Hash\n * @param {Object} hash The hash to modify.\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction hashDelete(key) {\n var result = this.has(key) && delete this.__data__[key];\n this.size -= result ? 1 : 0;\n return result;\n}\n\n/**\n * Gets the hash value for `key`.\n *\n * @private\n * @name get\n * @memberOf Hash\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction hashGet(key) {\n var data = this.__data__;\n if (nativeCreate) {\n var result = data[key];\n return result === HASH_UNDEFINED ? undefined : result;\n }\n return hasOwnProperty.call(data, key) ? data[key] : undefined;\n}\n\n/**\n * Checks if a hash value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf Hash\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction hashHas(key) {\n var data = this.__data__;\n return nativeCreate ? (data[key] !== undefined) : hasOwnProperty.call(data, key);\n}\n\n/**\n * Sets the hash `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf Hash\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the hash instance.\n */\nfunction hashSet(key, value) {\n var data = this.__data__;\n this.size += this.has(key) ? 0 : 1;\n data[key] = (nativeCreate && value === undefined) ? HASH_UNDEFINED : value;\n return this;\n}\n\n// Add methods to `Hash`.\nHash.prototype.clear = hashClear;\nHash.prototype['delete'] = hashDelete;\nHash.prototype.get = hashGet;\nHash.prototype.has = hashHas;\nHash.prototype.set = hashSet;\n\n/**\n * Creates an list cache object.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction ListCache(entries) {\n var index = -1,\n length = entries == null ? 0 : entries.length;\n\n this.clear();\n while (++index < length) {\n var entry = entries[index];\n this.set(entry[0], entry[1]);\n }\n}\n\n/**\n * Removes all key-value entries from the list cache.\n *\n * @private\n * @name clear\n * @memberOf ListCache\n */\nfunction listCacheClear() {\n this.__data__ = [];\n this.size = 0;\n}\n\n/**\n * Removes `key` and its value from the list cache.\n *\n * @private\n * @name delete\n * @memberOf ListCache\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction listCacheDelete(key) {\n var data = this.__data__,\n index = assocIndexOf(data, key);\n\n if (index < 0) {\n return false;\n }\n var lastIndex = data.length - 1;\n if (index == lastIndex) {\n data.pop();\n } else {\n splice.call(data, index, 1);\n }\n --this.size;\n return true;\n}\n\n/**\n * Gets the list cache value for `key`.\n *\n * @private\n * @name get\n * @memberOf ListCache\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction listCacheGet(key) {\n var data = this.__data__,\n index = assocIndexOf(data, key);\n\n return index < 0 ? undefined : data[index][1];\n}\n\n/**\n * Checks if a list cache value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf ListCache\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction listCacheHas(key) {\n return assocIndexOf(this.__data__, key) > -1;\n}\n\n/**\n * Sets the list cache `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf ListCache\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the list cache instance.\n */\nfunction listCacheSet(key, value) {\n var data = this.__data__,\n index = assocIndexOf(data, key);\n\n if (index < 0) {\n ++this.size;\n data.push([key, value]);\n } else {\n data[index][1] = value;\n }\n return this;\n}\n\n// Add methods to `ListCache`.\nListCache.prototype.clear = listCacheClear;\nListCache.prototype['delete'] = listCacheDelete;\nListCache.prototype.get = listCacheGet;\nListCache.prototype.has = listCacheHas;\nListCache.prototype.set = listCacheSet;\n\n/**\n * Creates a map cache object to store key-value pairs.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction MapCache(entries) {\n var index = -1,\n length = entries == null ? 0 : entries.length;\n\n this.clear();\n while (++index < length) {\n var entry = entries[index];\n this.set(entry[0], entry[1]);\n }\n}\n\n/**\n * Removes all key-value entries from the map.\n *\n * @private\n * @name clear\n * @memberOf MapCache\n */\nfunction mapCacheClear() {\n this.size = 0;\n this.__data__ = {\n 'hash': new Hash,\n 'map': new (Map || ListCache),\n 'string': new Hash\n };\n}\n\n/**\n * Removes `key` and its value from the map.\n *\n * @private\n * @name delete\n * @memberOf MapCache\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction mapCacheDelete(key) {\n var result = getMapData(this, key)['delete'](key);\n this.size -= result ? 1 : 0;\n return result;\n}\n\n/**\n * Gets the map value for `key`.\n *\n * @private\n * @name get\n * @memberOf MapCache\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction mapCacheGet(key) {\n return getMapData(this, key).get(key);\n}\n\n/**\n * Checks if a map value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf MapCache\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction mapCacheHas(key) {\n return getMapData(this, key).has(key);\n}\n\n/**\n * Sets the map `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf MapCache\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the map cache instance.\n */\nfunction mapCacheSet(key, value) {\n var data = getMapData(this, key),\n size = data.size;\n\n data.set(key, value);\n this.size += data.size == size ? 0 : 1;\n return this;\n}\n\n// Add methods to `MapCache`.\nMapCache.prototype.clear = mapCacheClear;\nMapCache.prototype['delete'] = mapCacheDelete;\nMapCache.prototype.get = mapCacheGet;\nMapCache.prototype.has = mapCacheHas;\nMapCache.prototype.set = mapCacheSet;\n\n/**\n *\n * Creates an array cache object to store unique values.\n *\n * @private\n * @constructor\n * @param {Array} [values] The values to cache.\n */\nfunction SetCache(values) {\n var index = -1,\n length = values == null ? 0 : values.length;\n\n this.__data__ = new MapCache;\n while (++index < length) {\n this.add(values[index]);\n }\n}\n\n/**\n * Adds `value` to the array cache.\n *\n * @private\n * @name add\n * @memberOf SetCache\n * @alias push\n * @param {*} value The value to cache.\n * @returns {Object} Returns the cache instance.\n */\nfunction setCacheAdd(value) {\n this.__data__.set(value, HASH_UNDEFINED);\n return this;\n}\n\n/**\n * Checks if `value` is in the array cache.\n *\n * @private\n * @name has\n * @memberOf SetCache\n * @param {*} value The value to search for.\n * @returns {number} Returns `true` if `value` is found, else `false`.\n */\nfunction setCacheHas(value) {\n return this.__data__.has(value);\n}\n\n// Add methods to `SetCache`.\nSetCache.prototype.add = SetCache.prototype.push = setCacheAdd;\nSetCache.prototype.has = setCacheHas;\n\n/**\n * Creates a stack cache object to store key-value pairs.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction Stack(entries) {\n var data = this.__data__ = new ListCache(entries);\n this.size = data.size;\n}\n\n/**\n * Removes all key-value entries from the stack.\n *\n * @private\n * @name clear\n * @memberOf Stack\n */\nfunction stackClear() {\n this.__data__ = new ListCache;\n this.size = 0;\n}\n\n/**\n * Removes `key` and its value from the stack.\n *\n * @private\n * @name delete\n * @memberOf Stack\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction stackDelete(key) {\n var data = this.__data__,\n result = data['delete'](key);\n\n this.size = data.size;\n return result;\n}\n\n/**\n * Gets the stack value for `key`.\n *\n * @private\n * @name get\n * @memberOf Stack\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction stackGet(key) {\n return this.__data__.get(key);\n}\n\n/**\n * Checks if a stack value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf Stack\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction stackHas(key) {\n return this.__data__.has(key);\n}\n\n/**\n * Sets the stack `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf Stack\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the stack cache instance.\n */\nfunction stackSet(key, value) {\n var data = this.__data__;\n if (data instanceof ListCache) {\n var pairs = data.__data__;\n if (!Map || (pairs.length < LARGE_ARRAY_SIZE - 1)) {\n pairs.push([key, value]);\n this.size = ++data.size;\n return this;\n }\n data = this.__data__ = new MapCache(pairs);\n }\n data.set(key, value);\n this.size = data.size;\n return this;\n}\n\n// Add methods to `Stack`.\nStack.prototype.clear = stackClear;\nStack.prototype['delete'] = stackDelete;\nStack.prototype.get = stackGet;\nStack.prototype.has = stackHas;\nStack.prototype.set = stackSet;\n\n/**\n * Creates an array of the enumerable property names of the array-like `value`.\n *\n * @private\n * @param {*} value The value to query.\n * @param {boolean} inherited Specify returning inherited property names.\n * @returns {Array} Returns the array of property names.\n */\nfunction arrayLikeKeys(value, inherited) {\n var isArr = isArray(value),\n isArg = !isArr && isArguments(value),\n isBuff = !isArr && !isArg && isBuffer(value),\n isType = !isArr && !isArg && !isBuff && isTypedArray(value),\n skipIndexes = isArr || isArg || isBuff || isType,\n result = skipIndexes ? baseTimes(value.length, String) : [],\n length = result.length;\n\n for (var key in value) {\n if ((inherited || hasOwnProperty.call(value, key)) &&\n !(skipIndexes && (\n // Safari 9 has enumerable `arguments.length` in strict mode.\n key == 'length' ||\n // Node.js 0.10 has enumerable non-index properties on buffers.\n (isBuff && (key == 'offset' || key == 'parent')) ||\n // PhantomJS 2 has enumerable non-index properties on typed arrays.\n (isType && (key == 'buffer' || key == 'byteLength' || key == 'byteOffset')) ||\n // Skip index properties.\n isIndex(key, length)\n ))) {\n result.push(key);\n }\n }\n return result;\n}\n\n/**\n * Gets the index at which the `key` is found in `array` of key-value pairs.\n *\n * @private\n * @param {Array} array The array to inspect.\n * @param {*} key The key to search for.\n * @returns {number} Returns the index of the matched value, else `-1`.\n */\nfunction assocIndexOf(array, key) {\n var length = array.length;\n while (length--) {\n if (eq(array[length][0], key)) {\n return length;\n }\n }\n return -1;\n}\n\n/**\n * The base implementation of `getAllKeys` and `getAllKeysIn` which uses\n * `keysFunc` and `symbolsFunc` to get the enumerable property names and\n * symbols of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {Function} keysFunc The function to get the keys of `object`.\n * @param {Function} symbolsFunc The function to get the symbols of `object`.\n * @returns {Array} Returns the array of property names and symbols.\n */\nfunction baseGetAllKeys(object, keysFunc, symbolsFunc) {\n var result = keysFunc(object);\n return isArray(object) ? result : arrayPush(result, symbolsFunc(object));\n}\n\n/**\n * The base implementation of `getTag` without fallbacks for buggy environments.\n *\n * @private\n * @param {*} value The value to query.\n * @returns {string} Returns the `toStringTag`.\n */\nfunction baseGetTag(value) {\n if (value == null) {\n return value === undefined ? undefinedTag : nullTag;\n }\n return (symToStringTag && symToStringTag in Object(value))\n ? getRawTag(value)\n : objectToString(value);\n}\n\n/**\n * The base implementation of `_.isArguments`.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an `arguments` object,\n */\nfunction baseIsArguments(value) {\n return isObjectLike(value) && baseGetTag(value) == argsTag;\n}\n\n/**\n * The base implementation of `_.isEqual` which supports partial comparisons\n * and tracks traversed objects.\n *\n * @private\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @param {boolean} bitmask The bitmask flags.\n * 1 - Unordered comparison\n * 2 - Partial comparison\n * @param {Function} [customizer] The function to customize comparisons.\n * @param {Object} [stack] Tracks traversed `value` and `other` objects.\n * @returns {boolean} Returns `true` if the values are equivalent, else `false`.\n */\nfunction baseIsEqual(value, other, bitmask, customizer, stack) {\n if (value === other) {\n return true;\n }\n if (value == null || other == null || (!isObjectLike(value) && !isObjectLike(other))) {\n return value !== value && other !== other;\n }\n return baseIsEqualDeep(value, other, bitmask, customizer, baseIsEqual, stack);\n}\n\n/**\n * A specialized version of `baseIsEqual` for arrays and objects which performs\n * deep comparisons and tracks traversed objects enabling objects with circular\n * references to be compared.\n *\n * @private\n * @param {Object} object The object to compare.\n * @param {Object} other The other object to compare.\n * @param {number} bitmask The bitmask flags. See `baseIsEqual` for more details.\n * @param {Function} customizer The function to customize comparisons.\n * @param {Function} equalFunc The function to determine equivalents of values.\n * @param {Object} [stack] Tracks traversed `object` and `other` objects.\n * @returns {boolean} Returns `true` if the objects are equivalent, else `false`.\n */\nfunction baseIsEqualDeep(object, other, bitmask, customizer, equalFunc, stack) {\n var objIsArr = isArray(object),\n othIsArr = isArray(other),\n objTag = objIsArr ? arrayTag : getTag(object),\n othTag = othIsArr ? arrayTag : getTag(other);\n\n objTag = objTag == argsTag ? objectTag : objTag;\n othTag = othTag == argsTag ? objectTag : othTag;\n\n var objIsObj = objTag == objectTag,\n othIsObj = othTag == objectTag,\n isSameTag = objTag == othTag;\n\n if (isSameTag && isBuffer(object)) {\n if (!isBuffer(other)) {\n return false;\n }\n objIsArr = true;\n objIsObj = false;\n }\n if (isSameTag && !objIsObj) {\n stack || (stack = new Stack);\n return (objIsArr || isTypedArray(object))\n ? equalArrays(object, other, bitmask, customizer, equalFunc, stack)\n : equalByTag(object, other, objTag, bitmask, customizer, equalFunc, stack);\n }\n if (!(bitmask & COMPARE_PARTIAL_FLAG)) {\n var objIsWrapped = objIsObj && hasOwnProperty.call(object, '__wrapped__'),\n othIsWrapped = othIsObj && hasOwnProperty.call(other, '__wrapped__');\n\n if (objIsWrapped || othIsWrapped) {\n var objUnwrapped = objIsWrapped ? object.value() : object,\n othUnwrapped = othIsWrapped ? other.value() : other;\n\n stack || (stack = new Stack);\n return equalFunc(objUnwrapped, othUnwrapped, bitmask, customizer, stack);\n }\n }\n if (!isSameTag) {\n return false;\n }\n stack || (stack = new Stack);\n return equalObjects(object, other, bitmask, customizer, equalFunc, stack);\n}\n\n/**\n * The base implementation of `_.isNative` without bad shim checks.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a native function,\n * else `false`.\n */\nfunction baseIsNative(value) {\n if (!isObject(value) || isMasked(value)) {\n return false;\n }\n var pattern = isFunction(value) ? reIsNative : reIsHostCtor;\n return pattern.test(toSource(value));\n}\n\n/**\n * The base implementation of `_.isTypedArray` without Node.js optimizations.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a typed array, else `false`.\n */\nfunction baseIsTypedArray(value) {\n return isObjectLike(value) &&\n isLength(value.length) && !!typedArrayTags[baseGetTag(value)];\n}\n\n/**\n * The base implementation of `_.keys` which doesn't treat sparse arrays as dense.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names.\n */\nfunction baseKeys(object) {\n if (!isPrototype(object)) {\n return nativeKeys(object);\n }\n var result = [];\n for (var key in Object(object)) {\n if (hasOwnProperty.call(object, key) && key != 'constructor') {\n result.push(key);\n }\n }\n return result;\n}\n\n/**\n * A specialized version of `baseIsEqualDeep` for arrays with support for\n * partial deep comparisons.\n *\n * @private\n * @param {Array} array The array to compare.\n * @param {Array} other The other array to compare.\n * @param {number} bitmask The bitmask flags. See `baseIsEqual` for more details.\n * @param {Function} customizer The function to customize comparisons.\n * @param {Function} equalFunc The function to determine equivalents of values.\n * @param {Object} stack Tracks traversed `array` and `other` objects.\n * @returns {boolean} Returns `true` if the arrays are equivalent, else `false`.\n */\nfunction equalArrays(array, other, bitmask, customizer, equalFunc, stack) {\n var isPartial = bitmask & COMPARE_PARTIAL_FLAG,\n arrLength = array.length,\n othLength = other.length;\n\n if (arrLength != othLength && !(isPartial && othLength > arrLength)) {\n return false;\n }\n // Assume cyclic values are equal.\n var stacked = stack.get(array);\n if (stacked && stack.get(other)) {\n return stacked == other;\n }\n var index = -1,\n result = true,\n seen = (bitmask & COMPARE_UNORDERED_FLAG) ? new SetCache : undefined;\n\n stack.set(array, other);\n stack.set(other, array);\n\n // Ignore non-index properties.\n while (++index < arrLength) {\n var arrValue = array[index],\n othValue = other[index];\n\n if (customizer) {\n var compared = isPartial\n ? customizer(othValue, arrValue, index, other, array, stack)\n : customizer(arrValue, othValue, index, array, other, stack);\n }\n if (compared !== undefined) {\n if (compared) {\n continue;\n }\n result = false;\n break;\n }\n // Recursively compare arrays (susceptible to call stack limits).\n if (seen) {\n if (!arraySome(other, function(othValue, othIndex) {\n if (!cacheHas(seen, othIndex) &&\n (arrValue === othValue || equalFunc(arrValue, othValue, bitmask, customizer, stack))) {\n return seen.push(othIndex);\n }\n })) {\n result = false;\n break;\n }\n } else if (!(\n arrValue === othValue ||\n equalFunc(arrValue, othValue, bitmask, customizer, stack)\n )) {\n result = false;\n break;\n }\n }\n stack['delete'](array);\n stack['delete'](other);\n return result;\n}\n\n/**\n * A specialized version of `baseIsEqualDeep` for comparing objects of\n * the same `toStringTag`.\n *\n * **Note:** This function only supports comparing values with tags of\n * `Boolean`, `Date`, `Error`, `Number`, `RegExp`, or `String`.\n *\n * @private\n * @param {Object} object The object to compare.\n * @param {Object} other The other object to compare.\n * @param {string} tag The `toStringTag` of the objects to compare.\n * @param {number} bitmask The bitmask flags. See `baseIsEqual` for more details.\n * @param {Function} customizer The function to customize comparisons.\n * @param {Function} equalFunc The function to determine equivalents of values.\n * @param {Object} stack Tracks traversed `object` and `other` objects.\n * @returns {boolean} Returns `true` if the objects are equivalent, else `false`.\n */\nfunction equalByTag(object, other, tag, bitmask, customizer, equalFunc, stack) {\n switch (tag) {\n case dataViewTag:\n if ((object.byteLength != other.byteLength) ||\n (object.byteOffset != other.byteOffset)) {\n return false;\n }\n object = object.buffer;\n other = other.buffer;\n\n case arrayBufferTag:\n if ((object.byteLength != other.byteLength) ||\n !equalFunc(new Uint8Array(object), new Uint8Array(other))) {\n return false;\n }\n return true;\n\n case boolTag:\n case dateTag:\n case numberTag:\n // Coerce booleans to `1` or `0` and dates to milliseconds.\n // Invalid dates are coerced to `NaN`.\n return eq(+object, +other);\n\n case errorTag:\n return object.name == other.name && object.message == other.message;\n\n case regexpTag:\n case stringTag:\n // Coerce regexes to strings and treat strings, primitives and objects,\n // as equal. See http://www.ecma-international.org/ecma-262/7.0/#sec-regexp.prototype.tostring\n // for more details.\n return object == (other + '');\n\n case mapTag:\n var convert = mapToArray;\n\n case setTag:\n var isPartial = bitmask & COMPARE_PARTIAL_FLAG;\n convert || (convert = setToArray);\n\n if (object.size != other.size && !isPartial) {\n return false;\n }\n // Assume cyclic values are equal.\n var stacked = stack.get(object);\n if (stacked) {\n return stacked == other;\n }\n bitmask |= COMPARE_UNORDERED_FLAG;\n\n // Recursively compare objects (susceptible to call stack limits).\n stack.set(object, other);\n var result = equalArrays(convert(object), convert(other), bitmask, customizer, equalFunc, stack);\n stack['delete'](object);\n return result;\n\n case symbolTag:\n if (symbolValueOf) {\n return symbolValueOf.call(object) == symbolValueOf.call(other);\n }\n }\n return false;\n}\n\n/**\n * A specialized version of `baseIsEqualDeep` for objects with support for\n * partial deep comparisons.\n *\n * @private\n * @param {Object} object The object to compare.\n * @param {Object} other The other object to compare.\n * @param {number} bitmask The bitmask flags. See `baseIsEqual` for more details.\n * @param {Function} customizer The function to customize comparisons.\n * @param {Function} equalFunc The function to determine equivalents of values.\n * @param {Object} stack Tracks traversed `object` and `other` objects.\n * @returns {boolean} Returns `true` if the objects are equivalent, else `false`.\n */\nfunction equalObjects(object, other, bitmask, customizer, equalFunc, stack) {\n var isPartial = bitmask & COMPARE_PARTIAL_FLAG,\n objProps = getAllKeys(object),\n objLength = objProps.length,\n othProps = getAllKeys(other),\n othLength = othProps.length;\n\n if (objLength != othLength && !isPartial) {\n return false;\n }\n var index = objLength;\n while (index--) {\n var key = objProps[index];\n if (!(isPartial ? key in other : hasOwnProperty.call(other, key))) {\n return false;\n }\n }\n // Assume cyclic values are equal.\n var stacked = stack.get(object);\n if (stacked && stack.get(other)) {\n return stacked == other;\n }\n var result = true;\n stack.set(object, other);\n stack.set(other, object);\n\n var skipCtor = isPartial;\n while (++index < objLength) {\n key = objProps[index];\n var objValue = object[key],\n othValue = other[key];\n\n if (customizer) {\n var compared = isPartial\n ? customizer(othValue, objValue, key, other, object, stack)\n : customizer(objValue, othValue, key, object, other, stack);\n }\n // Recursively compare objects (susceptible to call stack limits).\n if (!(compared === undefined\n ? (objValue === othValue || equalFunc(objValue, othValue, bitmask, customizer, stack))\n : compared\n )) {\n result = false;\n break;\n }\n skipCtor || (skipCtor = key == 'constructor');\n }\n if (result && !skipCtor) {\n var objCtor = object.constructor,\n othCtor = other.constructor;\n\n // Non `Object` object instances with different constructors are not equal.\n if (objCtor != othCtor &&\n ('constructor' in object && 'constructor' in other) &&\n !(typeof objCtor == 'function' && objCtor instanceof objCtor &&\n typeof othCtor == 'function' && othCtor instanceof othCtor)) {\n result = false;\n }\n }\n stack['delete'](object);\n stack['delete'](other);\n return result;\n}\n\n/**\n * Creates an array of own enumerable property names and symbols of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names and symbols.\n */\nfunction getAllKeys(object) {\n return baseGetAllKeys(object, keys, getSymbols);\n}\n\n/**\n * Gets the data for `map`.\n *\n * @private\n * @param {Object} map The map to query.\n * @param {string} key The reference key.\n * @returns {*} Returns the map data.\n */\nfunction getMapData(map, key) {\n var data = map.__data__;\n return isKeyable(key)\n ? data[typeof key == 'string' ? 'string' : 'hash']\n : data.map;\n}\n\n/**\n * Gets the native function at `key` of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {string} key The key of the method to get.\n * @returns {*} Returns the function if it's native, else `undefined`.\n */\nfunction getNative(object, key) {\n var value = getValue(object, key);\n return baseIsNative(value) ? value : undefined;\n}\n\n/**\n * A specialized version of `baseGetTag` which ignores `Symbol.toStringTag` values.\n *\n * @private\n * @param {*} value The value to query.\n * @returns {string} Returns the raw `toStringTag`.\n */\nfunction getRawTag(value) {\n var isOwn = hasOwnProperty.call(value, symToStringTag),\n tag = value[symToStringTag];\n\n try {\n value[symToStringTag] = undefined;\n var unmasked = true;\n } catch (e) {}\n\n var result = nativeObjectToString.call(value);\n if (unmasked) {\n if (isOwn) {\n value[symToStringTag] = tag;\n } else {\n delete value[symToStringTag];\n }\n }\n return result;\n}\n\n/**\n * Creates an array of the own enumerable symbols of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of symbols.\n */\nvar getSymbols = !nativeGetSymbols ? stubArray : function(object) {\n if (object == null) {\n return [];\n }\n object = Object(object);\n return arrayFilter(nativeGetSymbols(object), function(symbol) {\n return propertyIsEnumerable.call(object, symbol);\n });\n};\n\n/**\n * Gets the `toStringTag` of `value`.\n *\n * @private\n * @param {*} value The value to query.\n * @returns {string} Returns the `toStringTag`.\n */\nvar getTag = baseGetTag;\n\n// Fallback for data views, maps, sets, and weak maps in IE 11 and promises in Node.js < 6.\nif ((DataView && getTag(new DataView(new ArrayBuffer(1))) != dataViewTag) ||\n (Map && getTag(new Map) != mapTag) ||\n (Promise && getTag(Promise.resolve()) != promiseTag) ||\n (Set && getTag(new Set) != setTag) ||\n (WeakMap && getTag(new WeakMap) != weakMapTag)) {\n getTag = function(value) {\n var result = baseGetTag(value),\n Ctor = result == objectTag ? value.constructor : undefined,\n ctorString = Ctor ? toSource(Ctor) : '';\n\n if (ctorString) {\n switch (ctorString) {\n case dataViewCtorString: return dataViewTag;\n case mapCtorString: return mapTag;\n case promiseCtorString: return promiseTag;\n case setCtorString: return setTag;\n case weakMapCtorString: return weakMapTag;\n }\n }\n return result;\n };\n}\n\n/**\n * Checks if `value` is a valid array-like index.\n *\n * @private\n * @param {*} value The value to check.\n * @param {number} [length=MAX_SAFE_INTEGER] The upper bounds of a valid index.\n * @returns {boolean} Returns `true` if `value` is a valid index, else `false`.\n */\nfunction isIndex(value, length) {\n length = length == null ? MAX_SAFE_INTEGER : length;\n return !!length &&\n (typeof value == 'number' || reIsUint.test(value)) &&\n (value > -1 && value % 1 == 0 && value < length);\n}\n\n/**\n * Checks if `value` is suitable for use as unique object key.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is suitable, else `false`.\n */\nfunction isKeyable(value) {\n var type = typeof value;\n return (type == 'string' || type == 'number' || type == 'symbol' || type == 'boolean')\n ? (value !== '__proto__')\n : (value === null);\n}\n\n/**\n * Checks if `func` has its source masked.\n *\n * @private\n * @param {Function} func The function to check.\n * @returns {boolean} Returns `true` if `func` is masked, else `false`.\n */\nfunction isMasked(func) {\n return !!maskSrcKey && (maskSrcKey in func);\n}\n\n/**\n * Checks if `value` is likely a prototype object.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a prototype, else `false`.\n */\nfunction isPrototype(value) {\n var Ctor = value && value.constructor,\n proto = (typeof Ctor == 'function' && Ctor.prototype) || objectProto;\n\n return value === proto;\n}\n\n/**\n * Converts `value` to a string using `Object.prototype.toString`.\n *\n * @private\n * @param {*} value The value to convert.\n * @returns {string} Returns the converted string.\n */\nfunction objectToString(value) {\n return nativeObjectToString.call(value);\n}\n\n/**\n * Converts `func` to its source code.\n *\n * @private\n * @param {Function} func The function to convert.\n * @returns {string} Returns the source code.\n */\nfunction toSource(func) {\n if (func != null) {\n try {\n return funcToString.call(func);\n } catch (e) {}\n try {\n return (func + '');\n } catch (e) {}\n }\n return '';\n}\n\n/**\n * Performs a\n * [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\n * comparison between two values to determine if they are equivalent.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @returns {boolean} Returns `true` if the values are equivalent, else `false`.\n * @example\n *\n * var object = { 'a': 1 };\n * var other = { 'a': 1 };\n *\n * _.eq(object, object);\n * // => true\n *\n * _.eq(object, other);\n * // => false\n *\n * _.eq('a', 'a');\n * // => true\n *\n * _.eq('a', Object('a'));\n * // => false\n *\n * _.eq(NaN, NaN);\n * // => true\n */\nfunction eq(value, other) {\n return value === other || (value !== value && other !== other);\n}\n\n/**\n * Checks if `value` is likely an `arguments` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an `arguments` object,\n * else `false`.\n * @example\n *\n * _.isArguments(function() { return arguments; }());\n * // => true\n *\n * _.isArguments([1, 2, 3]);\n * // => false\n */\nvar isArguments = baseIsArguments(function() { return arguments; }()) ? baseIsArguments : function(value) {\n return isObjectLike(value) && hasOwnProperty.call(value, 'callee') &&\n !propertyIsEnumerable.call(value, 'callee');\n};\n\n/**\n * Checks if `value` is classified as an `Array` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an array, else `false`.\n * @example\n *\n * _.isArray([1, 2, 3]);\n * // => true\n *\n * _.isArray(document.body.children);\n * // => false\n *\n * _.isArray('abc');\n * // => false\n *\n * _.isArray(_.noop);\n * // => false\n */\nvar isArray = Array.isArray;\n\n/**\n * Checks if `value` is array-like. A value is considered array-like if it's\n * not a function and has a `value.length` that's an integer greater than or\n * equal to `0` and less than or equal to `Number.MAX_SAFE_INTEGER`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is array-like, else `false`.\n * @example\n *\n * _.isArrayLike([1, 2, 3]);\n * // => true\n *\n * _.isArrayLike(document.body.children);\n * // => true\n *\n * _.isArrayLike('abc');\n * // => true\n *\n * _.isArrayLike(_.noop);\n * // => false\n */\nfunction isArrayLike(value) {\n return value != null && isLength(value.length) && !isFunction(value);\n}\n\n/**\n * Checks if `value` is a buffer.\n *\n * @static\n * @memberOf _\n * @since 4.3.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a buffer, else `false`.\n * @example\n *\n * _.isBuffer(new Buffer(2));\n * // => true\n *\n * _.isBuffer(new Uint8Array(2));\n * // => false\n */\nvar isBuffer = nativeIsBuffer || stubFalse;\n\n/**\n * Performs a deep comparison between two values to determine if they are\n * equivalent.\n *\n * **Note:** This method supports comparing arrays, array buffers, booleans,\n * date objects, error objects, maps, numbers, `Object` objects, regexes,\n * sets, strings, symbols, and typed arrays. `Object` objects are compared\n * by their own, not inherited, enumerable properties. Functions and DOM\n * nodes are compared by strict equality, i.e. `===`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @returns {boolean} Returns `true` if the values are equivalent, else `false`.\n * @example\n *\n * var object = { 'a': 1 };\n * var other = { 'a': 1 };\n *\n * _.isEqual(object, other);\n * // => true\n *\n * object === other;\n * // => false\n */\nfunction isEqual(value, other) {\n return baseIsEqual(value, other);\n}\n\n/**\n * Checks if `value` is classified as a `Function` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a function, else `false`.\n * @example\n *\n * _.isFunction(_);\n * // => true\n *\n * _.isFunction(/abc/);\n * // => false\n */\nfunction isFunction(value) {\n if (!isObject(value)) {\n return false;\n }\n // The use of `Object#toString` avoids issues with the `typeof` operator\n // in Safari 9 which returns 'object' for typed arrays and other constructors.\n var tag = baseGetTag(value);\n return tag == funcTag || tag == genTag || tag == asyncTag || tag == proxyTag;\n}\n\n/**\n * Checks if `value` is a valid array-like length.\n *\n * **Note:** This method is loosely based on\n * [`ToLength`](http://ecma-international.org/ecma-262/7.0/#sec-tolength).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a valid length, else `false`.\n * @example\n *\n * _.isLength(3);\n * // => true\n *\n * _.isLength(Number.MIN_VALUE);\n * // => false\n *\n * _.isLength(Infinity);\n * // => false\n *\n * _.isLength('3');\n * // => false\n */\nfunction isLength(value) {\n return typeof value == 'number' &&\n value > -1 && value % 1 == 0 && value <= MAX_SAFE_INTEGER;\n}\n\n/**\n * Checks if `value` is the\n * [language type](http://www.ecma-international.org/ecma-262/7.0/#sec-ecmascript-language-types)\n * of `Object`. (e.g. arrays, functions, objects, regexes, `new Number(0)`, and `new String('')`)\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an object, else `false`.\n * @example\n *\n * _.isObject({});\n * // => true\n *\n * _.isObject([1, 2, 3]);\n * // => true\n *\n * _.isObject(_.noop);\n * // => true\n *\n * _.isObject(null);\n * // => false\n */\nfunction isObject(value) {\n var type = typeof value;\n return value != null && (type == 'object' || type == 'function');\n}\n\n/**\n * Checks if `value` is object-like. A value is object-like if it's not `null`\n * and has a `typeof` result of \"object\".\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is object-like, else `false`.\n * @example\n *\n * _.isObjectLike({});\n * // => true\n *\n * _.isObjectLike([1, 2, 3]);\n * // => true\n *\n * _.isObjectLike(_.noop);\n * // => false\n *\n * _.isObjectLike(null);\n * // => false\n */\nfunction isObjectLike(value) {\n return value != null && typeof value == 'object';\n}\n\n/**\n * Checks if `value` is classified as a typed array.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a typed array, else `false`.\n * @example\n *\n * _.isTypedArray(new Uint8Array);\n * // => true\n *\n * _.isTypedArray([]);\n * // => false\n */\nvar isTypedArray = nodeIsTypedArray ? baseUnary(nodeIsTypedArray) : baseIsTypedArray;\n\n/**\n * Creates an array of the own enumerable property names of `object`.\n *\n * **Note:** Non-object values are coerced to objects. See the\n * [ES spec](http://ecma-international.org/ecma-262/7.0/#sec-object.keys)\n * for more details.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Object\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names.\n * @example\n *\n * function Foo() {\n * this.a = 1;\n * this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.keys(new Foo);\n * // => ['a', 'b'] (iteration order is not guaranteed)\n *\n * _.keys('hi');\n * // => ['0', '1']\n */\nfunction keys(object) {\n return isArrayLike(object) ? arrayLikeKeys(object) : baseKeys(object);\n}\n\n/**\n * This method returns a new empty array.\n *\n * @static\n * @memberOf _\n * @since 4.13.0\n * @category Util\n * @returns {Array} Returns the new empty array.\n * @example\n *\n * var arrays = _.times(2, _.stubArray);\n *\n * console.log(arrays);\n * // => [[], []]\n *\n * console.log(arrays[0] === arrays[1]);\n * // => false\n */\nfunction stubArray() {\n return [];\n}\n\n/**\n * This method returns `false`.\n *\n * @static\n * @memberOf _\n * @since 4.13.0\n * @category Util\n * @returns {boolean} Returns `false`.\n * @example\n *\n * _.times(2, _.stubFalse);\n * // => [false, false]\n */\nfunction stubFalse() {\n return false;\n}\n\nmodule.exports = isEqual;\n","// @flow\n\nimport { cloneLayout, compact, correctBounds } from \"./utils\";\n\nimport type { CompactType, Layout } from \"./utils\";\n\nexport type Breakpoint = string;\nexport type DefaultBreakpoints = \"lg\" | \"md\" | \"sm\" | \"xs\" | \"xxs\";\n\n// + indicates read-only\nexport type ResponsiveLayout = {\n +[breakpoint: T]: Layout\n};\nexport type Breakpoints = {\n +[breakpoint: T]: number\n};\n\n/**\n * Given a width, find the highest breakpoint that matches is valid for it (width > breakpoint).\n *\n * @param {Object} breakpoints Breakpoints object (e.g. {lg: 1200, md: 960, ...})\n * @param {Number} width Screen width.\n * @return {String} Highest breakpoint that is less than width.\n */\nexport function getBreakpointFromWidth(\n breakpoints: Breakpoints,\n width: number\n): Breakpoint {\n const sorted = sortBreakpoints(breakpoints);\n let matching = sorted[0];\n for (let i = 1, len = sorted.length; i < len; i++) {\n const breakpointName = sorted[i];\n if (width > breakpoints[breakpointName]) matching = breakpointName;\n }\n return matching;\n}\n\n/**\n * Given a breakpoint, get the # of cols set for it.\n * @param {String} breakpoint Breakpoint name.\n * @param {Object} cols Map of breakpoints to cols.\n * @return {Number} Number of cols.\n */\nexport function getColsFromBreakpoint(\n breakpoint: Breakpoint,\n cols: Breakpoints\n): number {\n if (!cols[breakpoint]) {\n throw new Error(\n \"ResponsiveReactGridLayout: `cols` entry for breakpoint \" +\n breakpoint +\n \" is missing!\"\n );\n }\n return cols[breakpoint];\n}\n\n/**\n * Given existing layouts and a new breakpoint, find or generate a new layout.\n *\n * This finds the layout above the new one and generates from it, if it exists.\n *\n * @param {Object} layouts Existing layouts.\n * @param {Array} breakpoints All breakpoints.\n * @param {String} breakpoint New breakpoint.\n * @param {String} breakpoint Last breakpoint (for fallback).\n * @param {Number} cols Column count at new breakpoint.\n * @param {Boolean} verticalCompact Whether or not to compact the layout\n * vertically.\n * @return {Array} New layout.\n */\nexport function findOrGenerateResponsiveLayout(\n layouts: ResponsiveLayout,\n breakpoints: Breakpoints,\n breakpoint: Breakpoint,\n lastBreakpoint: Breakpoint,\n cols: number,\n compactType: CompactType\n): Layout {\n // If it already exists, just return it.\n if (layouts[breakpoint]) return cloneLayout(layouts[breakpoint]);\n // Find or generate the next layout\n let layout = layouts[lastBreakpoint];\n const breakpointsSorted = sortBreakpoints(breakpoints);\n const breakpointsAbove = breakpointsSorted.slice(\n breakpointsSorted.indexOf(breakpoint)\n );\n for (let i = 0, len = breakpointsAbove.length; i < len; i++) {\n const b = breakpointsAbove[i];\n if (layouts[b]) {\n layout = layouts[b];\n break;\n }\n }\n layout = cloneLayout(layout || []); // clone layout so we don't modify existing items\n return compact(correctBounds(layout, { cols: cols }), compactType, cols);\n}\n\n/**\n * Given breakpoints, return an array of breakpoints sorted by width. This is usually\n * e.g. ['xxs', 'xs', 'sm', ...]\n *\n * @param {Object} breakpoints Key/value pair of breakpoint names to widths.\n * @return {Array} Sorted breakpoints.\n */\nexport function sortBreakpoints(\n breakpoints: Breakpoints\n): Array {\n const keys: Array = Object.keys(breakpoints);\n return keys.sort(function (a, b) {\n return breakpoints[a] - breakpoints[b];\n });\n}\n","module.exports = __WEBPACK_EXTERNAL_MODULE__5__;","/*!\n Copyright (c) 2017 Jed Watson.\n Licensed under the MIT License (MIT), see\n http://jedwatson.github.io/classnames\n*/\n/* global define */\n\n(function () {\n\t'use strict';\n\n\tvar hasOwn = {}.hasOwnProperty;\n\n\tfunction classNames () {\n\t\tvar classes = [];\n\n\t\tfor (var i = 0; i < arguments.length; i++) {\n\t\t\tvar arg = arguments[i];\n\t\t\tif (!arg) continue;\n\n\t\t\tvar argType = typeof arg;\n\n\t\t\tif (argType === 'string' || argType === 'number') {\n\t\t\t\tclasses.push(arg);\n\t\t\t} else if (Array.isArray(arg) && arg.length) {\n\t\t\t\tvar inner = classNames.apply(null, arg);\n\t\t\t\tif (inner) {\n\t\t\t\t\tclasses.push(inner);\n\t\t\t\t}\n\t\t\t} else if (argType === 'object') {\n\t\t\t\tfor (var key in arg) {\n\t\t\t\t\tif (hasOwn.call(arg, key) && arg[key]) {\n\t\t\t\t\t\tclasses.push(key);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\treturn classes.join(' ');\n\t}\n\n\tif (typeof module !== 'undefined' && module.exports) {\n\t\tclassNames.default = classNames;\n\t\tmodule.exports = classNames;\n\t} else if (typeof define === 'function' && typeof define.amd === 'object' && define.amd) {\n\t\t// register as 'classnames', consistent with npm package name\n\t\tdefine('classnames', [], function () {\n\t\t\treturn classNames;\n\t\t});\n\t} else {\n\t\twindow.classNames = classNames;\n\t}\n}());\n","!function(t,e){\"object\"==typeof exports&&\"object\"==typeof module?module.exports=e(require(\"react\"),require(\"react-dom\")):\"function\"==typeof define&&define.amd?define([\"react\",\"react-dom\"],e):\"object\"==typeof exports?exports.ReactDraggable=e(require(\"react\"),require(\"react-dom\")):t.ReactDraggable=e(t.React,t.ReactDOM)}(window,function(t,e){return function(t){var e={};function n(r){if(e[r])return e[r].exports;var o=e[r]={i:r,l:!1,exports:{}};return t[r].call(o.exports,o,o.exports,n),o.l=!0,o.exports}return n.m=t,n.c=e,n.d=function(t,e,r){n.o(t,e)||Object.defineProperty(t,e,{enumerable:!0,get:r})},n.r=function(t){\"undefined\"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(t,Symbol.toStringTag,{value:\"Module\"}),Object.defineProperty(t,\"__esModule\",{value:!0})},n.t=function(t,e){if(1&e&&(t=n(t)),8&e)return t;if(4&e&&\"object\"==typeof t&&t&&t.__esModule)return t;var r=Object.create(null);if(n.r(r),Object.defineProperty(r,\"default\",{enumerable:!0,value:t}),2&e&&\"string\"!=typeof t)for(var o in t)n.d(r,o,function(e){return t[e]}.bind(null,o));return r},n.n=function(t){var e=t&&t.__esModule?function(){return t.default}:function(){return t};return n.d(e,\"a\",e),e},n.o=function(t,e){return Object.prototype.hasOwnProperty.call(t,e)},n.p=\"\",n(n.s=4)}([function(t,e,n){t.exports=n(5)()},function(e,n){e.exports=t},function(t,n){t.exports=e},function(t,e,n){var r;\n/*!\n Copyright (c) 2017 Jed Watson.\n Licensed under the MIT License (MIT), see\n http://jedwatson.github.io/classnames\n*/!function(){\"use strict\";var n={}.hasOwnProperty;function o(){for(var t=[],e=0;e0&&void 0!==arguments[0]?arguments[0]:\"transform\";if(\"undefined\"==typeof window||void 0===window.document)return\"\";var e=window.document.documentElement.style;if(t in e)return\"\";for(var n=0;n0&&void 0!==arguments[0]?arguments[0]:{})}function X(t){return\"both\"===t.props.axis||\"x\"===t.props.axis}function Y(t){return\"both\"===t.props.axis||\"y\"===t.props.axis}function L(t,e,n){var r=\"number\"==typeof e?function(t,e){return t.targetTouches&&f(t.targetTouches,function(t){return e===t.identifier})||t.changedTouches&&f(t.changedTouches,function(t){return e===t.identifier})}(t,e):null;if(\"number\"==typeof e&&!r)return null;var o=I(n);return function(t,e,n){var r=e===e.ownerDocument.body?{left:0,top:0}:e.getBoundingClientRect();return{x:(t.clientX+e.scrollLeft-r.left)/n,y:(t.clientY+e.scrollTop-r.top)/n}}(r||t,n.props.offsetParent||o.offsetParent||o.ownerDocument.body,n.props.scale)}function R(t,e,n){var r=t.state,o=!d(r.lastX),a=I(t);return o?{node:a,deltaX:0,deltaY:0,lastX:e,lastY:n,x:e,y:n}:{node:a,deltaX:e-r.lastX,deltaY:n-r.lastY,lastX:r.lastX,lastY:r.lastY,x:e,y:n}}function A(t,e){var n=t.props.scale;return{node:e.node,x:t.state.x+e.deltaX/n,y:t.state.y+e.deltaY/n,deltaX:e.deltaX/n,deltaY:e.deltaY/n,lastX:t.state.x,lastY:t.state.y}}function I(t){var e=u.a.findDOMNode(t);if(!e)throw new Error(\": Unmounted during event!\");return e}function U(t){return(U=\"function\"==typeof Symbol&&\"symbol\"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&\"function\"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?\"symbol\":typeof t})(t)}function V(t,e){return function(t){if(Array.isArray(t))return t}(t)||function(t,e){var n=[],r=!0,o=!1,a=void 0;try{for(var i,s=t[Symbol.iterator]();!(r=(i=s.next()).done)&&(n.push(i.value),!e||n.length!==e);r=!0);}catch(t){o=!0,a=t}finally{try{r||null==s.return||s.return()}finally{if(o)throw a}}return n}(t,e)||function(){throw new TypeError(\"Invalid attempt to destructure non-iterable instance\")}()}function W(t,e){for(var n=0;n not mounted on DragStart!\");var r=e.ownerDocument;if(!(n.props.disabled||!(t.target instanceof r.defaultView.Node)||n.props.handle&&!D(t.target,n.props.handle,e)||n.props.cancel&&D(t.target,n.props.cancel,e))){var o=function(t){return t.targetTouches&&t.targetTouches[0]?t.targetTouches[0].identifier:t.changedTouches&&t.changedTouches[0]?t.changedTouches[0].identifier:void 0}(t);n.setState({touchIdentifier:o});var a=L(t,o,H(n));if(null!=a){var i=a.x,s=a.y,c=R(H(n),i,s);n.props.onStart,!1!==n.props.onStart(t,c)&&(n.props.enableUserSelectHack&&M(r),n.setState({dragging:!0,lastX:i,lastY:s}),x(r,F.move,n.handleDrag),x(r,F.stop,n.handleDragStop))}}}),G(H(n),\"handleDrag\",function(t){\"touchmove\"===t.type&&t.preventDefault();var e=L(t,n.state.touchIdentifier,H(n));if(null!=e){var r,o,a,i=e.x,s=e.y;if(Array.isArray(n.props.grid)){var u=i-n.state.lastX,c=s-n.state.lastY,l=V((r=n.props.grid,o=u,a=c,[Math.round(o/r[0])*r[0],Math.round(a/r[1])*r[1]]),2);if(u=l[0],c=l[1],!u&&!c)return;i=n.state.lastX+u,s=n.state.lastY+c}var f=R(H(n),i,s);if(!1!==n.props.onDrag(t,f))n.setState({lastX:i,lastY:s});else try{n.handleDragStop(new MouseEvent(\"mouseup\"))}catch(t){var p=document.createEvent(\"MouseEvents\");p.initMouseEvent(\"mouseup\",!0,!0,window,0,0,0,0,0,!1,!1,!1,!1,0,null),n.handleDragStop(p)}}}),G(H(n),\"handleDragStop\",function(t){if(n.state.dragging){var e=L(t,n.state.touchIdentifier,H(n));if(null!=e){var r=e.x,o=e.y,a=R(H(n),r,o),i=u.a.findDOMNode(H(n));i&&n.props.enableUserSelectHack&&k(i.ownerDocument),n.setState({dragging:!1,lastX:NaN,lastY:NaN}),n.props.onStop(t,a),i&&(P(i.ownerDocument,F.move,n.handleDrag),P(i.ownerDocument,F.stop,n.handleDragStop))}}}),G(H(n),\"onMouseDown\",function(t){return F=z.mouse,n.handleDragStart(t)}),G(H(n),\"onMouseUp\",function(t){return F=z.mouse,n.handleDragStop(t)}),G(H(n),\"onTouchStart\",function(t){return F=z.touch,n.handleDragStart(t)}),G(H(n),\"onTouchEnd\",function(t){return F=z.touch,n.handleDragStop(t)}),n}var n,r,a;return function(t,e){if(\"function\"!=typeof e&&null!==e)throw new TypeError(\"Super expression must either be null or a function\");t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,writable:!0,configurable:!0}}),e&&q(t,e)}(e,o.a.Component),n=e,(r=[{key:\"componentWillUnmount\",value:function(){var t=u.a.findDOMNode(this);if(t){var e=t.ownerDocument;P(e,z.mouse.move,this.handleDrag),P(e,z.touch.move,this.handleDrag),P(e,z.mouse.stop,this.handleDragStop),P(e,z.touch.stop,this.handleDragStop),this.props.enableUserSelectHack&&k(e)}}},{key:\"render\",value:function(){return o.a.cloneElement(o.a.Children.only(this.props.children),{style:_(this.props.children.props.style),onMouseDown:this.onMouseDown,onTouchStart:this.onTouchStart,onMouseUp:this.onMouseUp,onTouchEnd:this.onTouchEnd})}}])&&W(n.prototype,r),a&&W(n,a),e}();function K(t){return(K=\"function\"==typeof Symbol&&\"symbol\"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&\"function\"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?\"symbol\":typeof t})(t)}function Q(){return(Q=Object.assign||function(t){for(var e=1;e=0||(o[n]=t[n]);return o}(t,e);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(t);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(t,n)&&(o[n]=t[n])}return o}function $(t,e){return function(t){if(Array.isArray(t))return t}(t)||function(t,e){var n=[],r=!0,o=!1,a=void 0;try{for(var i,s=t[Symbol.iterator]();!(r=(i=s.next()).done)&&(n.push(i.value),!e||n.length!==e);r=!0);}catch(t){o=!0,a=t}finally{try{r||null==s.return||s.return()}finally{if(o)throw a}}return n}(t,e)||function(){throw new TypeError(\"Invalid attempt to destructure non-iterable instance\")}()}function tt(t,e){var n=Object.keys(t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(t);e&&(r=r.filter(function(e){return Object.getOwnPropertyDescriptor(t,e).enumerable})),n.push.apply(n,r)}return n}function et(t){for(var e=1;e, without drag handlers. This will make this component effectively undraggable. Please attach `onDrag` or `onStop` handlers so you can adjust the `position` of this element.\"),n}return function(t,e){if(\"function\"!=typeof e&&null!==e)throw new TypeError(\"Super expression must either be null or a function\");t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,writable:!0,configurable:!0}}),e&&it(t,e)}(e,o.a.Component),at(e,null,[{key:\"getDerivedStateFromProps\",value:function(t,e){var n=t.position,r=e.prevPropsPosition;return!n||r&&n.x===r.x&&n.y===r.y?null:{x:n.x,y:n.y,prevPropsPosition:et({},n)}}}]),at(e,[{key:\"componentDidMount\",value:function(){void 0!==window.SVGElement&&u.a.findDOMNode(this)instanceof window.SVGElement&&this.setState({isElementSVG:!0})}},{key:\"componentWillUnmount\",value:function(){this.setState({dragging:!1})}},{key:\"render\",value:function(){var t,e=this.props,n=(e.axis,e.bounds,e.children),r=e.defaultPosition,a=e.defaultClassName,i=e.defaultClassNameDragging,s=e.defaultClassNameDragged,u=e.position,c=e.positionOffset,f=(e.scale,Z(e,[\"axis\",\"bounds\",\"children\",\"defaultPosition\",\"defaultClassName\",\"defaultClassNameDragging\",\"defaultClassNameDragged\",\"position\",\"positionOffset\",\"scale\"])),p={},d=null,g=!Boolean(u)||this.state.dragging,y=u||r,h={x:X(this)&&g?this.state.x:y.x,y:Y(this)&&g?this.state.y:y.y};this.state.isElementSVG?d=function(t,e){return C(t,e,\"\")}(h,c):p=function(t,e){var n=C(t,e,\"px\");return w({},b(\"transform\",m),n)}(h,c);var v=l()(n.props.className||\"\",a,(st(t={},i,this.state.dragging),st(t,s,this.state.dragged),t));return o.a.createElement(J,Q({},f,{onStart:this.onDragStart,onDrag:this.onDrag,onStop:this.onDragStop}),o.a.cloneElement(o.a.Children.only(n),{className:v,style:et({},n.props.style,{},p),transform:d}))}}]),e}();st(ut,\"displayName\",\"Draggable\"),st(ut,\"propTypes\",et({},J.propTypes,{axis:i.a.oneOf([\"both\",\"x\",\"y\",\"none\"]),bounds:i.a.oneOfType([i.a.shape({left:i.a.number,right:i.a.number,top:i.a.number,bottom:i.a.number}),i.a.string,i.a.oneOf([!1])]),defaultClassName:i.a.string,defaultClassNameDragging:i.a.string,defaultClassNameDragged:i.a.string,defaultPosition:i.a.shape({x:i.a.number,y:i.a.number}),positionOffset:i.a.shape({x:i.a.oneOfType([i.a.number,i.a.string]),y:i.a.oneOfType([i.a.number,i.a.string])}),position:i.a.shape({x:i.a.number,y:i.a.number}),className:y,style:y,transform:y})),st(ut,\"defaultProps\",et({},J.defaultProps,{axis:\"both\",bounds:!1,defaultClassName:\"react-draggable\",defaultClassNameDragging:\"react-draggable-dragging\",defaultClassNameDragged:\"react-draggable-dragged\",defaultPosition:{x:0,y:0},position:null,scale:1}))}])});\n//# sourceMappingURL=react-draggable.min.js.map","// @flow\nimport type { Position } from \"./utils\";\n\nexport type PositionParams = {\n margin: [number, number],\n containerPadding: [number, number],\n containerWidth: number,\n cols: number,\n rowHeight: number,\n maxRows: number\n};\n\n// Helper for generating column width\nexport function calcGridColWidth(positionParams: PositionParams): number {\n const { margin, containerPadding, containerWidth, cols } = positionParams;\n return (\n (containerWidth - margin[0] * (cols - 1) - containerPadding[0] * 2) / cols\n );\n}\n\n// This can either be called:\n// calcGridItemWHPx(w, colWidth, margin[0])\n// or\n// calcGridItemWHPx(h, rowHeight, margin[1])\nexport function calcGridItemWHPx(\n gridUnits: number,\n colOrRowSize: number,\n marginPx: number\n) {\n // 0 * Infinity === NaN, which causes problems with resize contraints\n if (!Number.isFinite(gridUnits)) return gridUnits;\n return Math.round(\n colOrRowSize * gridUnits + Math.max(0, gridUnits - 1) * marginPx\n );\n}\n\n/**\n * Return position on the page given an x, y, w, h.\n * left, top, width, height are all in pixels.\n * @param {PositionParams} positionParams Parameters of grid needed for coordinates calculations.\n * @param {Number} x X coordinate in grid units.\n * @param {Number} y Y coordinate in grid units.\n * @param {Number} w W coordinate in grid units.\n * @param {Number} h H coordinate in grid units.\n * @return {Position} Object containing coords.\n */\nexport function calcGridItemPosition(\n positionParams: PositionParams,\n x: number,\n y: number,\n w: number,\n h: number,\n state: ?Object\n): Position {\n const { margin, containerPadding, rowHeight } = positionParams;\n const colWidth = calcGridColWidth(positionParams);\n const out = {};\n\n // If resizing, use the exact width and height as returned from resizing callbacks.\n if (state && state.resizing) {\n out.width = Math.round(state.resizing.width);\n out.height = Math.round(state.resizing.height);\n }\n // Otherwise, calculate from grid units.\n else {\n out.width = calcGridItemWHPx(w, colWidth, margin[0]);\n out.height = calcGridItemWHPx(h, rowHeight, margin[1]);\n }\n\n // If dragging, use the exact width and height as returned from dragging callbacks.\n if (state && state.dragging) {\n out.top = Math.round(state.dragging.top);\n out.left = Math.round(state.dragging.left);\n }\n // Otherwise, calculate from grid units.\n else {\n out.top = Math.round((rowHeight + margin[1]) * y + containerPadding[1]);\n out.left = Math.round((colWidth + margin[0]) * x + containerPadding[0]);\n }\n\n return out;\n}\n\n/**\n * Translate x and y coordinates from pixels to grid units.\n * @param {PositionParams} positionParams Parameters of grid needed for coordinates calculations.\n * @param {Number} top Top position (relative to parent) in pixels.\n * @param {Number} left Left position (relative to parent) in pixels.\n * @param {Number} w W coordinate in grid units.\n * @param {Number} h H coordinate in grid units.\n * @return {Object} x and y in grid units.\n */\nexport function calcXY(\n positionParams: PositionParams,\n top: number,\n left: number,\n w: number,\n h: number\n): { x: number, y: number } {\n const { margin, cols, rowHeight, maxRows } = positionParams;\n const colWidth = calcGridColWidth(positionParams);\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 - margin[0]) / (colWidth + margin[0]));\n let y = Math.round((top - margin[1]) / (rowHeight + margin[1]));\n\n // Capping\n x = clamp(x, 0, cols - w);\n y = clamp(y, 0, maxRows - h);\n return { x, y };\n}\n\n/**\n * Given a height and width in pixel values, calculate grid units.\n * @param {PositionParams} positionParams Parameters of grid needed for coordinates calcluations.\n * @param {Number} height Height in pixels.\n * @param {Number} width Width in pixels.\n * @param {Number} x X coordinate in grid units.\n * @param {Number} y Y coordinate in grid units.\n * @return {Object} w, h as grid units.\n */\nexport function calcWH(\n positionParams: PositionParams,\n width: number,\n height: number,\n x: number,\n y: number\n): { w: number, h: number } {\n const { margin, maxRows, cols, rowHeight } = positionParams;\n const colWidth = calcGridColWidth(positionParams);\n\n // width = colWidth * w - (margin * (w - 1))\n // ...\n // w = (width + margin) / (colWidth + margin)\n let w = Math.round((width + margin[0]) / (colWidth + margin[0]));\n let h = Math.round((height + margin[1]) / (rowHeight + margin[1]));\n\n // Capping\n w = clamp(w, 0, cols - x);\n h = clamp(h, 0, maxRows - y);\n return { w, h };\n}\n\n// Similar to _.clamp\nexport function clamp(num: number, lowerBound: number, upperBound: number) {\n return Math.max(Math.min(num, upperBound), lowerBound);\n}\n","// @flow\nimport React from \"react\";\nimport ReactDOM from \"react-dom\";\nimport PropTypes from \"prop-types\";\nimport { DraggableCore } from \"react-draggable\";\nimport { Resizable } from \"react-resizable\";\nimport { fastPositionEqual, perc, setTopLeft, setTransform } from \"./utils\";\nimport {\n calcGridItemPosition,\n calcGridItemWHPx,\n calcGridColWidth,\n calcXY,\n calcWH,\n clamp\n} from \"./calculateUtils\";\nimport classNames from \"classnames\";\nimport type { Element as ReactElement, Node as ReactNode } from \"react\";\n\nimport type {\n ReactDraggableCallbackData,\n GridDragEvent,\n GridResizeEvent,\n DroppingPosition,\n Position\n} from \"./utils\";\n\nimport type { PositionParams } from \"./calculateUtils\";\n\ntype PartialPosition = { top: number, left: number };\ntype GridItemCallback = (\n i: string,\n w: number,\n h: number,\n Data\n) => void;\n\ntype State = {\n resizing: ?{ width: number, height: number },\n dragging: ?{ top: number, left: number },\n className: string\n};\n\ntype Props = {\n children: ReactElement,\n cols: number,\n containerWidth: number,\n margin: [number, number],\n containerPadding: [number, number],\n rowHeight: number,\n maxRows: number,\n isDraggable: boolean,\n isResizable: boolean,\n isBounded: boolean,\n static?: boolean,\n useCSSTransforms?: boolean,\n usePercentages?: boolean,\n transformScale: number,\n droppingPosition?: DroppingPosition,\n\n className: string,\n style?: Object,\n // Draggability\n cancel: string,\n handle: string,\n\n x: number,\n y: number,\n w: number,\n h: number,\n\n minW: number,\n maxW: number,\n minH: number,\n maxH: number,\n i: string,\n\n onDrag?: GridItemCallback,\n onDragStart?: GridItemCallback,\n onDragStop?: GridItemCallback,\n onResize?: GridItemCallback,\n onResizeStart?: GridItemCallback,\n onResizeStop?: GridItemCallback\n};\n\n/**\n * An individual item within a ReactGridLayout.\n */\nexport default class GridItem extends React.Component {\n static propTypes = {\n // Children must be only a single element\n children: PropTypes.element,\n\n // General grid attributes\n cols: PropTypes.number.isRequired,\n containerWidth: PropTypes.number.isRequired,\n rowHeight: PropTypes.number.isRequired,\n margin: PropTypes.array.isRequired,\n maxRows: PropTypes.number.isRequired,\n containerPadding: PropTypes.array.isRequired,\n\n // These are all in grid units\n x: PropTypes.number.isRequired,\n y: PropTypes.number.isRequired,\n w: PropTypes.number.isRequired,\n h: PropTypes.number.isRequired,\n\n // All optional\n minW: function (props: Props, propName: string) {\n const value = props[propName];\n if (typeof value !== \"number\") return new Error(\"minWidth not Number\");\n if (value > props.w || value > props.maxW)\n return new Error(\"minWidth larger than item width/maxWidth\");\n },\n\n maxW: function (props: Props, propName: string) {\n const value = props[propName];\n if (typeof value !== \"number\") return new Error(\"maxWidth not Number\");\n if (value < props.w || value < props.minW)\n return new Error(\"maxWidth smaller than item width/minWidth\");\n },\n\n minH: function (props: Props, propName: string) {\n const value = props[propName];\n if (typeof value !== \"number\") return new Error(\"minHeight not Number\");\n if (value > props.h || value > props.maxH)\n return new Error(\"minHeight larger than item height/maxHeight\");\n },\n\n maxH: function (props: Props, propName: string) {\n const value = props[propName];\n if (typeof value !== \"number\") return new Error(\"maxHeight not Number\");\n if (value < props.h || value < props.minH)\n return new Error(\"maxHeight smaller than item height/minHeight\");\n },\n\n // ID is nice to have for callbacks\n i: PropTypes.string.isRequired,\n\n // Functions\n onDragStop: PropTypes.func,\n onDragStart: PropTypes.func,\n onDrag: PropTypes.func,\n onResizeStop: PropTypes.func,\n onResizeStart: PropTypes.func,\n onResize: PropTypes.func,\n\n // Flags\n isDraggable: PropTypes.bool.isRequired,\n isResizable: PropTypes.bool.isRequired,\n isBounded: PropTypes.bool.isRequired,\n static: PropTypes.bool,\n\n // Use CSS transforms instead of top/left\n useCSSTransforms: PropTypes.bool.isRequired,\n transformScale: PropTypes.number,\n\n // Others\n className: PropTypes.string,\n // Selector for draggable handle\n handle: PropTypes.string,\n // Selector for draggable cancel (see react-draggable)\n cancel: PropTypes.string,\n // Current position of a dropping element\n droppingPosition: PropTypes.shape({\n e: PropTypes.object.isRequired,\n left: PropTypes.number.isRequired,\n top: PropTypes.number.isRequired\n })\n };\n\n static defaultProps = {\n className: \"\",\n cancel: \"\",\n handle: \"\",\n minH: 1,\n minW: 1,\n maxH: Infinity,\n maxW: Infinity,\n transformScale: 1\n };\n\n state: State = {\n resizing: null,\n dragging: null,\n className: \"\"\n };\n\n currentNode: HTMLElement;\n\n shouldComponentUpdate(nextProps: Props, nextState: State) {\n // We can't deeply compare children. If the developer memoizes them, we can\n // use this optimization.\n if (this.props.children !== nextProps.children) return true;\n if (this.props.droppingPosition !== nextProps.droppingPosition) return true;\n // TODO memoize these calculations so they don't take so long?\n const oldPosition = calcGridItemPosition(\n this.getPositionParams(this.props),\n this.props.x,\n this.props.y,\n this.props.w,\n this.props.h,\n this.state\n );\n const newPosition = calcGridItemPosition(\n this.getPositionParams(nextProps),\n nextProps.x,\n nextProps.y,\n nextProps.w,\n nextProps.h,\n nextState\n );\n return (\n !fastPositionEqual(oldPosition, newPosition) ||\n this.props.useCSSTransforms !== nextProps.useCSSTransforms\n );\n }\n\n componentDidMount() {\n this.moveDroppingItem({});\n }\n\n componentDidUpdate(prevProps: Props) {\n this.moveDroppingItem(prevProps);\n }\n\n // When a droppingPosition is present, this means we should fire a move event, as if we had moved\n // this element by `x, y` pixels.\n moveDroppingItem(prevProps: Props) {\n const { droppingPosition } = this.props;\n if (!droppingPosition) return;\n\n const prevDroppingPosition = prevProps.droppingPosition || {\n left: 0,\n top: 0\n };\n const { dragging } = this.state;\n\n if (!this.currentNode) {\n // eslint-disable-next-line react/no-find-dom-node\n this.currentNode = ((ReactDOM.findDOMNode(this): any): HTMLElement);\n }\n\n const shouldDrag =\n (dragging && droppingPosition.left !== prevDroppingPosition.left) ||\n droppingPosition.top !== prevDroppingPosition.top;\n\n if (!dragging) {\n this.onDragStart(droppingPosition.e, {\n node: this.currentNode,\n deltaX: droppingPosition.left,\n deltaY: droppingPosition.top\n });\n } else if (shouldDrag) {\n const deltaX = droppingPosition.left - dragging.left;\n const deltaY = droppingPosition.top - dragging.top;\n\n this.onDrag(droppingPosition.e, {\n node: this.currentNode,\n deltaX,\n deltaY\n });\n }\n }\n\n getPositionParams(props: Props = this.props): PositionParams {\n return {\n cols: props.cols,\n containerPadding: props.containerPadding,\n containerWidth: props.containerWidth,\n margin: props.margin,\n maxRows: props.maxRows,\n rowHeight: props.rowHeight\n };\n }\n\n /**\n * This is where we set the grid item's absolute placement. It gets a little tricky because we want to do it\n * well when server rendering, and the only way to do that properly is to use percentage width/left because\n * we don't know exactly what the browser viewport is.\n * Unfortunately, CSS Transforms, which are great for performance, break in this instance because a percentage\n * left is relative to the item itself, not its container! So we cannot use them on the server rendering pass.\n *\n * @param {Object} pos Position object with width, height, left, top.\n * @return {Object} Style object.\n */\n createStyle(pos: Position): { [key: string]: ?string } {\n const { usePercentages, containerWidth, useCSSTransforms } = this.props;\n\n let style;\n // CSS Transforms support (default)\n if (useCSSTransforms) {\n style = setTransform(pos);\n } else {\n // top,left (slow)\n style = setTopLeft(pos);\n\n // This is used for server rendering.\n if (usePercentages) {\n style.left = perc(pos.left / containerWidth);\n style.width = perc(pos.width / containerWidth);\n }\n }\n\n return style;\n }\n\n /**\n * Mix a Draggable instance into a child.\n * @param {Element} child Child element.\n * @return {Element} Child wrapped in Draggable.\n */\n mixinDraggable(\n child: ReactElement,\n isDraggable: boolean\n ): ReactElement {\n return (\n \n {child}\n \n );\n }\n\n /**\n * Mix a Resizable instance into a child.\n * @param {Element} child Child element.\n * @param {Object} position Position object (pixel values)\n * @return {Element} Child wrapped in Resizable.\n */\n mixinResizable(\n child: ReactElement,\n position: Position,\n isResizable: boolean\n ): ReactElement {\n const { cols, x, minW, minH, maxW, maxH, transformScale } = this.props;\n const positionParams = this.getPositionParams();\n\n // This is the max possible width - doesn't go to infinity because of the width of the window\n const maxWidth = calcGridItemPosition(positionParams, 0, 0, cols - x, 0)\n .width;\n\n // Calculate min/max constraints using our min & maxes\n const mins = calcGridItemPosition(positionParams, 0, 0, minW, minH);\n const maxes = calcGridItemPosition(positionParams, 0, 0, maxW, maxH);\n const minConstraints = [mins.width, mins.height];\n const maxConstraints = [\n Math.min(maxes.width, maxWidth),\n Math.min(maxes.height, Infinity)\n ];\n return (\n \n {child}\n \n );\n }\n\n /**\n * onDragStart event handler\n * @param {Event} e event data\n * @param {Object} callbackData an object with node, delta and position information\n */\n onDragStart = (e: Event, { node }: ReactDraggableCallbackData) => {\n const { onDragStart } = this.props;\n if (!onDragStart) return;\n\n const newPosition: PartialPosition = { top: 0, left: 0 };\n\n // TODO: this wont work on nested parents\n const { offsetParent } = node;\n if (!offsetParent) return;\n const parentRect = offsetParent.getBoundingClientRect();\n const clientRect = node.getBoundingClientRect();\n const cLeft = clientRect.left / this.props.transformScale;\n const pLeft = parentRect.left / this.props.transformScale;\n const cTop = clientRect.top / this.props.transformScale;\n const pTop = parentRect.top / this.props.transformScale;\n newPosition.left = cLeft - pLeft + offsetParent.scrollLeft;\n newPosition.top = cTop - pTop + offsetParent.scrollTop;\n this.setState({ dragging: newPosition });\n\n // Call callback with this data\n const { x, y } = calcXY(\n this.getPositionParams(),\n newPosition.top,\n newPosition.left,\n this.props.w,\n this.props.h\n );\n\n return onDragStart.call(this, this.props.i, x, y, {\n e,\n node,\n newPosition\n });\n };\n\n /**\n * onDrag event handler\n * @param {Event} e event data\n * @param {Object} callbackData an object with node, delta and position information\n */\n onDrag = (e: Event, { node, deltaX, deltaY }: ReactDraggableCallbackData) => {\n const { onDrag, transformScale } = this.props;\n if (!onDrag) return;\n deltaX /= transformScale;\n deltaY /= transformScale;\n\n if (!this.state.dragging) {\n throw new Error(\"onDrag called before onDragStart.\");\n }\n let top = this.state.dragging.top + deltaY;\n let left = this.state.dragging.left + deltaX;\n\n const { isBounded, i, w, h, containerWidth } = this.props;\n const positionParams = this.getPositionParams();\n\n // Boundary calculations; keeps items within the grid\n if (isBounded) {\n const { offsetParent } = node;\n\n if (offsetParent) {\n const { margin, rowHeight } = this.props;\n const bottomBoundary =\n offsetParent.clientHeight - calcGridItemWHPx(h, rowHeight, margin[1]);\n top = clamp(top, 0, bottomBoundary);\n\n const colWidth = calcGridColWidth(positionParams);\n const rightBoundary =\n containerWidth - calcGridItemWHPx(w, colWidth, margin[0]);\n left = clamp(left, 0, rightBoundary);\n }\n }\n\n const newPosition: PartialPosition = { top, left };\n this.setState({ dragging: newPosition });\n\n // Call callback with this data\n const { x, y } = calcXY(positionParams, top, left, w, h);\n return onDrag.call(this, i, x, y, {\n e,\n node,\n newPosition\n });\n };\n\n /**\n * onDragStop event handler\n * @param {Event} e event data\n * @param {Object} callbackData an object with node, delta and position information\n */\n onDragStop = (e: Event, { node }: ReactDraggableCallbackData) => {\n const { onDragStop } = this.props;\n if (!onDragStop) return;\n\n if (!this.state.dragging) {\n throw new Error(\"onDragEnd called before onDragStart.\");\n }\n const { w, h, i } = this.props;\n const { left, top } = this.state.dragging;\n const newPosition: PartialPosition = { top, left };\n this.setState({ dragging: null });\n\n const { x, y } = calcXY(this.getPositionParams(), top, left, w, h);\n\n return onDragStop.call(this, i, x, y, {\n e,\n node,\n newPosition\n });\n };\n\n /**\n * onResizeStop event handler\n * @param {Event} e event data\n * @param {Object} callbackData an object with node and size information\n */\n onResizeStop = (\n e: Event,\n callbackData: { node: HTMLElement, size: Position }\n ) => {\n this.onResizeHandler(e, callbackData, \"onResizeStop\");\n };\n\n /**\n * onResizeStart event handler\n * @param {Event} e event data\n * @param {Object} callbackData an object with node and size information\n */\n onResizeStart = (\n e: Event,\n callbackData: { node: HTMLElement, size: Position }\n ) => {\n this.onResizeHandler(e, callbackData, \"onResizeStart\");\n };\n\n /**\n * onResize event handler\n * @param {Event} e event data\n * @param {Object} callbackData an object with node and size information\n */\n onResize = (\n e: Event,\n callbackData: { node: HTMLElement, size: Position }\n ) => {\n this.onResizeHandler(e, callbackData, \"onResize\");\n };\n\n /**\n * Wrapper around drag events to provide more useful data.\n * All drag events call the function with the given handler name,\n * with the signature (index, x, y).\n *\n * @param {String} handlerName Handler name to wrap.\n * @return {Function} Handler function.\n */\n onResizeHandler(\n e: Event,\n { node, size }: { node: HTMLElement, size: Position },\n handlerName: string\n ) {\n const handler = this.props[handlerName];\n if (!handler) return;\n const { cols, x, y, i, maxH, minH } = this.props;\n let { minW, maxW } = this.props;\n\n // Get new XY\n let { w, h } = calcWH(\n this.getPositionParams(),\n size.width,\n size.height,\n x,\n y\n );\n\n // minW should be at least 1 (TODO propTypes validation?)\n minW = Math.max(minW, 1);\n\n // maxW should be at most (cols - x)\n maxW = Math.min(maxW, cols - x);\n\n // Min/max capping\n w = clamp(w, minW, maxW);\n h = clamp(h, minH, maxH);\n\n this.setState({ resizing: handlerName === \"onResizeStop\" ? null : size });\n\n handler.call(this, i, w, h, { e, node, size });\n }\n\n render(): ReactNode {\n const {\n x,\n y,\n w,\n h,\n isDraggable,\n isResizable,\n droppingPosition,\n useCSSTransforms\n } = this.props;\n\n const pos = calcGridItemPosition(\n this.getPositionParams(),\n x,\n y,\n w,\n h,\n this.state\n );\n const child = React.Children.only(this.props.children);\n\n // Create the child element. We clone the existing element but modify its className and style.\n let newChild = React.cloneElement(child, {\n className: classNames(\n \"react-grid-item\",\n child.props.className,\n this.props.className,\n {\n static: this.props.static,\n resizing: Boolean(this.state.resizing),\n \"react-draggable\": isDraggable,\n \"react-draggable-dragging\": Boolean(this.state.dragging),\n dropping: Boolean(droppingPosition),\n cssTransforms: useCSSTransforms\n }\n ),\n // We can set the width and height on the child, but unfortunately we can't set the position.\n style: {\n ...this.props.style,\n ...child.props.style,\n ...this.createStyle(pos)\n }\n });\n\n // Resizable support. This is usually on but the user can toggle it off.\n newChild = this.mixinResizable(newChild, pos, isResizable);\n\n // Draggable support. This is always on, except for with placeholders.\n newChild = this.mixinDraggable(newChild, isDraggable);\n\n return newChild;\n }\n}\n","// @flow\nimport PropTypes from \"prop-types\";\nimport React from \"react\";\nimport type {\n Ref,\n ChildrenArray as ReactChildrenArray,\n Element as ReactElement\n} from \"react\";\nimport type { EventCallback, CompactType, Layout, LayoutItem } from \"./utils\";\n\nexport type Props = {|\n className: string,\n style: Object,\n width: number,\n autoSize: boolean,\n cols: number,\n draggableCancel: string,\n draggableHandle: string,\n verticalCompact: boolean,\n compactType: CompactType,\n layout: Layout,\n margin: [number, number],\n containerPadding: [number, number] | null,\n rowHeight: number,\n maxRows: number,\n isBounded: boolean,\n isDraggable: boolean,\n isResizable: boolean,\n isDroppable: boolean,\n preventCollision: boolean,\n useCSSTransforms: boolean,\n transformScale: number,\n droppingItem: $Shape,\n\n // Callbacks\n onLayoutChange: Layout => void,\n onDrag: EventCallback,\n onDragStart: EventCallback,\n onDragStop: EventCallback,\n onResize: EventCallback,\n onResizeStart: EventCallback,\n onResizeStop: EventCallback,\n onDrop: (layout: Layout, item: ?LayoutItem, e: Event) => void,\n children: ReactChildrenArray>,\n innerRef?: Ref<\"div\">\n|};\n\nexport default {\n //\n // Basic props\n //\n className: PropTypes.string,\n style: PropTypes.object,\n\n // This can be set explicitly. If it is not set, it will automatically\n // be set to the container width. Note that resizes will *not* cause this to adjust.\n // If you need that behavior, use WidthProvider.\n width: PropTypes.number,\n\n // If true, the container height swells and contracts to fit contents\n autoSize: PropTypes.bool,\n // # of cols.\n cols: PropTypes.number,\n\n // A selector that will not be draggable.\n draggableCancel: PropTypes.string,\n // A selector for the draggable handler\n draggableHandle: PropTypes.string,\n\n // Deprecated\n verticalCompact: function (props: Props) {\n if (\n props.verticalCompact === false &&\n process.env.NODE_ENV !== \"production\"\n ) {\n console.warn(\n // eslint-disable-line no-console\n \"`verticalCompact` on is deprecated and will be removed soon. \" +\n 'Use `compactType`: \"horizontal\" | \"vertical\" | null.'\n );\n }\n },\n // Choose vertical or hotizontal compaction\n compactType: PropTypes.oneOf([\"vertical\", \"horizontal\"]),\n\n // layout is an array of object with the format:\n // {x: Number, y: Number, w: Number, h: Number, i: String}\n layout: function (props: Props) {\n var layout = props.layout;\n // I hope you're setting the data-grid property on the grid items\n if (layout === undefined) return;\n require(\"./utils\").validateLayout(layout, \"layout\");\n },\n\n //\n // Grid Dimensions\n //\n\n // Margin between items [x, y] in px\n margin: PropTypes.arrayOf(PropTypes.number),\n // Padding inside the container [x, y] in px\n containerPadding: PropTypes.arrayOf(PropTypes.number),\n // Rows have a static height, but you can change this based on breakpoints if you like\n rowHeight: PropTypes.number,\n // Default Infinity, but you can specify a max here if you like.\n // Note that this isn't fully fleshed out and won't error if you specify a layout that\n // extends beyond the row capacity. It will, however, not allow users to drag/resize\n // an item past the barrier. They can push items beyond the barrier, though.\n // Intentionally not documented for this reason.\n maxRows: PropTypes.number,\n\n //\n // Flags\n //\n isBounded: PropTypes.bool,\n isDraggable: PropTypes.bool,\n isResizable: PropTypes.bool,\n // If true, grid items won't change position when being dragged over.\n preventCollision: PropTypes.bool,\n // Use CSS transforms instead of top/left\n useCSSTransforms: PropTypes.bool,\n // parent layout transform scale\n transformScale: PropTypes.number,\n // If true, an external element can trigger onDrop callback with a specific grid position as a parameter\n isDroppable: PropTypes.bool,\n\n //\n // Callbacks\n //\n\n // Callback so you can save the layout. Calls after each drag & resize stops.\n onLayoutChange: PropTypes.func,\n\n // Calls when drag starts. Callback is of the signature (layout, oldItem, newItem, placeholder, e, ?node).\n // All callbacks below have the same signature. 'start' and 'stop' callbacks omit the 'placeholder'.\n onDragStart: PropTypes.func,\n // Calls on each drag movement.\n onDrag: PropTypes.func,\n // Calls when drag is complete.\n onDragStop: PropTypes.func,\n //Calls when resize starts.\n onResizeStart: PropTypes.func,\n // Calls when resize movement happens.\n onResize: PropTypes.func,\n // Calls when resize is complete.\n onResizeStop: PropTypes.func,\n // Calls when some element is dropped.\n onDrop: PropTypes.func,\n\n //\n // Other validations\n //\n\n droppingItem: PropTypes.shape({\n i: PropTypes.string.isRequired,\n w: PropTypes.number.isRequired,\n h: PropTypes.number.isRequired\n }),\n\n // Children must not have duplicate keys.\n children: function (props: Props, propName: string) {\n var children = props[propName];\n\n // Check children keys for duplicates. Throw if found.\n var keys = {};\n React.Children.forEach(children, function (child) {\n if (keys[child.key]) {\n throw new Error(\n 'Duplicate child key \"' +\n child.key +\n '\" found! This will cause problems in ReactGridLayout.'\n );\n }\n keys[child.key] = true;\n });\n },\n\n // Optional ref for getting a reference for the wrapping div.\n innerRef: PropTypes.any\n};\n","// @flow\nimport React from \"react\";\n\nimport isEqual from \"lodash.isequal\";\nimport classNames from \"classnames\";\nimport {\n autoBindHandlers,\n bottom,\n childrenEqual,\n cloneLayoutItem,\n compact,\n getLayoutItem,\n moveElement,\n synchronizeLayoutWithChildren,\n getAllCollisions,\n compactType,\n noop,\n fastRGLPropsEqual\n} from \"./utils\";\n\nimport { calcXY } from \"./calculateUtils\";\n\nimport GridItem from \"./GridItem\";\nimport ReactGridLayoutPropTypes from \"./ReactGridLayoutPropTypes\";\nimport type {\n ChildrenArray as ReactChildrenArray,\n Element as ReactElement\n} from \"react\";\n\n// Types\nimport type {\n CompactType,\n GridResizeEvent,\n GridDragEvent,\n DragOverEvent,\n Layout,\n DroppingPosition,\n LayoutItem\n} from \"./utils\";\n\nimport type { PositionParams } from \"./calculateUtils\";\n\ntype State = {\n activeDrag: ?LayoutItem,\n layout: Layout,\n mounted: boolean,\n oldDragItem: ?LayoutItem,\n oldLayout: ?Layout,\n oldResizeItem: ?LayoutItem,\n droppingDOMNode: ?ReactElement,\n droppingPosition?: DroppingPosition,\n // Mirrored props\n children: ReactChildrenArray>,\n compactType?: CompactType,\n propsLayout?: Layout\n};\n\nimport type { Props } from \"./ReactGridLayoutPropTypes\";\n\n// End Types\n\nconst layoutClassName = \"react-grid-layout\";\nlet isFirefox = false;\n// Try...catch will protect from navigator not existing (e.g. node) or a bad implementation of navigator\ntry {\n isFirefox = /firefox/i.test(navigator.userAgent);\n} catch (e) {\n /* Ignore */\n}\n\n/**\n * A reactive, fluid grid layout with draggable, resizable components.\n */\n\nexport default class ReactGridLayout extends React.Component {\n // TODO publish internal ReactClass displayName transform\n static displayName = \"ReactGridLayout\";\n\n // Refactored to another module to make way for preval\n static propTypes = ReactGridLayoutPropTypes;\n\n static defaultProps = {\n autoSize: true,\n cols: 12,\n className: \"\",\n style: {},\n draggableHandle: \"\",\n draggableCancel: \"\",\n containerPadding: null,\n rowHeight: 150,\n maxRows: Infinity, // infinite vertical growth\n layout: [],\n margin: [10, 10],\n isBounded: false,\n isDraggable: true,\n isResizable: true,\n isDroppable: false,\n useCSSTransforms: true,\n transformScale: 1,\n verticalCompact: true,\n compactType: \"vertical\",\n preventCollision: false,\n droppingItem: {\n i: \"__dropping-elem__\",\n h: 1,\n w: 1\n },\n onLayoutChange: noop,\n onDragStart: noop,\n onDrag: noop,\n onDragStop: noop,\n onResizeStart: noop,\n onResize: noop,\n onResizeStop: noop,\n onDrop: noop\n };\n\n state: State = {\n activeDrag: null,\n layout: synchronizeLayoutWithChildren(\n this.props.layout,\n this.props.children,\n this.props.cols,\n // Legacy support for verticalCompact: false\n compactType(this.props)\n ),\n mounted: false,\n oldDragItem: null,\n oldLayout: null,\n oldResizeItem: null,\n droppingDOMNode: null,\n children: []\n };\n\n dragEnterCounter = 0;\n\n constructor(props: Props, context: any): void {\n super(props, context);\n autoBindHandlers(this, [\n \"onDragStart\",\n \"onDrag\",\n \"onDragStop\",\n \"onResizeStart\",\n \"onResize\",\n \"onResizeStop\"\n ]);\n }\n\n componentDidMount() {\n this.setState({ mounted: true });\n // Possibly call back with layout on mount. This should be done after correcting the layout width\n // to ensure we don't rerender with the wrong width.\n this.onLayoutMaybeChanged(this.state.layout, this.props.layout);\n }\n\n static getDerivedStateFromProps(nextProps: Props, prevState: State) {\n let newLayoutBase;\n\n if (prevState.activeDrag) {\n return null;\n }\n\n // Legacy support for compactType\n // Allow parent to set layout directly.\n if (\n !isEqual(nextProps.layout, prevState.propsLayout) ||\n nextProps.compactType !== prevState.compactType\n ) {\n newLayoutBase = nextProps.layout;\n } else if (!childrenEqual(nextProps.children, prevState.children)) {\n // If children change, also regenerate the layout. Use our state\n // as the base in case because it may be more up to date than\n // what is in props.\n newLayoutBase = prevState.layout;\n }\n\n // We need to regenerate the layout.\n if (newLayoutBase) {\n const newLayout = synchronizeLayoutWithChildren(\n newLayoutBase,\n nextProps.children,\n nextProps.cols,\n compactType(nextProps)\n );\n\n return {\n layout: newLayout,\n // We need to save these props to state for using\n // getDerivedStateFromProps instead of componentDidMount (in which we would get extra rerender)\n compactType: nextProps.compactType,\n children: nextProps.children,\n propsLayout: nextProps.layout\n };\n }\n\n return null;\n }\n\n shouldComponentUpdate(nextProps: Props, nextState: State) {\n return (\n // NOTE: this is almost always unequal. Therefore the only way to get better performance\n // from SCU is if the user intentionally memoizes children. If they do, and they can\n // handle changes properly, performance will increase.\n this.props.children !== nextProps.children ||\n !fastRGLPropsEqual(this.props, nextProps, isEqual) ||\n this.state.activeDrag !== nextState.activeDrag ||\n this.state.mounted !== nextState.mounted ||\n this.state.droppingPosition !== nextState.droppingPosition\n );\n }\n\n componentDidUpdate(prevProps: Props, prevState: State) {\n if (!this.state.activeDrag) {\n const newLayout = this.state.layout;\n const oldLayout = prevState.layout;\n\n this.onLayoutMaybeChanged(newLayout, oldLayout);\n }\n }\n\n /**\n * Calculates a pixel value for the container.\n * @return {String} Container height in pixels.\n */\n containerHeight() {\n if (!this.props.autoSize) return;\n const nbRow = bottom(this.state.layout);\n const containerPaddingY = this.props.containerPadding\n ? this.props.containerPadding[1]\n : this.props.margin[1];\n return (\n nbRow * this.props.rowHeight +\n (nbRow - 1) * this.props.margin[1] +\n containerPaddingY * 2 +\n \"px\"\n );\n }\n\n /**\n * When dragging starts\n * @param {String} i Id of the child\n * @param {Number} x X position of the move\n * @param {Number} y Y position of the move\n * @param {Event} e The mousedown event\n * @param {Element} node The current dragging DOM element\n */\n onDragStart(i: string, x: number, y: number, { e, node }: GridDragEvent) {\n const { layout } = this.state;\n var l = getLayoutItem(layout, i);\n if (!l) return;\n\n this.setState({\n oldDragItem: cloneLayoutItem(l),\n oldLayout: this.state.layout\n });\n\n return this.props.onDragStart(layout, l, l, null, e, node);\n }\n\n /**\n * Each drag movement create a new dragelement and move the element to the dragged location\n * @param {String} i Id of the child\n * @param {Number} x X position of the move\n * @param {Number} y Y position of the move\n * @param {Event} e The mousedown event\n * @param {Element} node The current dragging DOM element\n */\n onDrag(i: string, x: number, y: number, { e, node }: GridDragEvent) {\n const { oldDragItem } = this.state;\n let { layout } = this.state;\n const { cols } = this.props;\n var l = getLayoutItem(layout, i);\n if (!l) return;\n\n // Create placeholder (display only)\n var placeholder = {\n w: l.w,\n h: l.h,\n x: l.x,\n y: l.y,\n placeholder: true,\n i: i\n };\n\n // Move the element to the dragged location.\n const isUserAction = true;\n layout = moveElement(\n layout,\n l,\n x,\n y,\n isUserAction,\n this.props.preventCollision,\n compactType(this.props),\n cols\n );\n\n this.props.onDrag(layout, oldDragItem, l, placeholder, e, node);\n\n this.setState({\n layout: compact(layout, compactType(this.props), cols),\n activeDrag: placeholder\n });\n }\n\n /**\n * When dragging stops, figure out which position the element is closest to and update its x and y.\n * @param {String} i Index of the child.\n * @param {Number} x X position of the move\n * @param {Number} y Y position of the move\n * @param {Event} e The mousedown event\n * @param {Element} node The current dragging DOM element\n */\n onDragStop(i: string, x: number, y: number, { e, node }: GridDragEvent) {\n if (!this.state.activeDrag) return;\n\n const { oldDragItem } = this.state;\n let { layout } = this.state;\n const { cols, preventCollision } = this.props;\n const l = getLayoutItem(layout, i);\n if (!l) return;\n\n // Move the element here\n const isUserAction = true;\n layout = moveElement(\n layout,\n l,\n x,\n y,\n isUserAction,\n preventCollision,\n compactType(this.props),\n cols\n );\n\n this.props.onDragStop(layout, oldDragItem, l, null, e, node);\n\n // Set state\n const newLayout = compact(layout, compactType(this.props), cols);\n const { oldLayout } = this.state;\n this.setState({\n activeDrag: null,\n layout: newLayout,\n oldDragItem: null,\n oldLayout: null\n });\n\n this.onLayoutMaybeChanged(newLayout, oldLayout);\n }\n\n onLayoutMaybeChanged(newLayout: Layout, oldLayout: ?Layout) {\n if (!oldLayout) oldLayout = this.state.layout;\n\n if (!isEqual(oldLayout, newLayout)) {\n this.props.onLayoutChange(newLayout);\n }\n }\n\n onResizeStart(i: string, w: number, h: number, { e, node }: GridResizeEvent) {\n const { layout } = this.state;\n var l = getLayoutItem(layout, i);\n if (!l) return;\n\n this.setState({\n oldResizeItem: cloneLayoutItem(l),\n oldLayout: this.state.layout\n });\n\n this.props.onResizeStart(layout, l, l, null, e, node);\n }\n\n onResize(i: string, w: number, h: number, { e, node }: GridResizeEvent) {\n const { layout, oldResizeItem } = this.state;\n const { cols, preventCollision } = this.props;\n const l: ?LayoutItem = getLayoutItem(layout, i);\n if (!l) return;\n\n // Something like quad tree should be used\n // to find collisions faster\n let hasCollisions;\n if (preventCollision) {\n const collisions = getAllCollisions(layout, { ...l, w, h }).filter(\n layoutItem => layoutItem.i !== l.i\n );\n hasCollisions = collisions.length > 0;\n\n // If we're colliding, we need adjust the placeholder.\n if (hasCollisions) {\n // adjust w && h to maximum allowed space\n let leastX = Infinity,\n leastY = Infinity;\n collisions.forEach(layoutItem => {\n if (layoutItem.x > l.x) leastX = Math.min(leastX, layoutItem.x);\n if (layoutItem.y > l.y) leastY = Math.min(leastY, layoutItem.y);\n });\n\n if (Number.isFinite(leastX)) l.w = leastX - l.x;\n if (Number.isFinite(leastY)) l.h = leastY - l.y;\n }\n }\n\n if (!hasCollisions) {\n // Set new width and height.\n l.w = w;\n l.h = h;\n }\n\n // Create placeholder element (display only)\n var placeholder = {\n w: l.w,\n h: l.h,\n x: l.x,\n y: l.y,\n static: true,\n i: i\n };\n\n this.props.onResize(layout, oldResizeItem, l, placeholder, e, node);\n\n // Re-compact the layout and set the drag placeholder.\n this.setState({\n layout: compact(layout, compactType(this.props), cols),\n activeDrag: placeholder\n });\n }\n\n onResizeStop(i: string, w: number, h: number, { e, node }: GridResizeEvent) {\n const { layout, oldResizeItem } = this.state;\n const { cols } = this.props;\n var l = getLayoutItem(layout, i);\n\n this.props.onResizeStop(layout, oldResizeItem, l, null, e, node);\n\n // Set state\n const newLayout = compact(layout, compactType(this.props), cols);\n const { oldLayout } = this.state;\n this.setState({\n activeDrag: null,\n layout: newLayout,\n oldResizeItem: null,\n oldLayout: null\n });\n\n this.onLayoutMaybeChanged(newLayout, oldLayout);\n }\n\n /**\n * Create a placeholder object.\n * @return {Element} Placeholder div.\n */\n placeholder(): ?ReactElement {\n const { activeDrag } = this.state;\n if (!activeDrag) return null;\n const {\n width,\n cols,\n margin,\n containerPadding,\n rowHeight,\n maxRows,\n useCSSTransforms,\n transformScale\n } = this.props;\n\n // {...this.state.activeDrag} is pretty slow, actually\n return (\n \n
\n \n );\n }\n\n /**\n * Given a grid item, set its style attributes & surround in a .\n * @param {Element} child React element.\n * @return {Element} Element wrapped in draggable and properly placed.\n */\n processGridItem(\n child: ReactElement,\n isDroppingItem?: boolean\n ): ?ReactElement {\n if (!child || !child.key) return;\n const l = getLayoutItem(this.state.layout, String(child.key));\n if (!l) return null;\n const {\n width,\n cols,\n margin,\n containerPadding,\n rowHeight,\n maxRows,\n isDraggable,\n isResizable,\n isBounded,\n useCSSTransforms,\n transformScale,\n draggableCancel,\n draggableHandle\n } = this.props;\n const { mounted, droppingPosition } = this.state;\n\n // Determine user manipulations possible.\n // If an item is static, it can't be manipulated by default.\n // Any properties defined directly on the grid item will take precedence.\n const draggable =\n typeof l.isDraggable === \"boolean\"\n ? l.isDraggable\n : !l.static && isDraggable;\n const resizable =\n typeof l.isResizable === \"boolean\"\n ? l.isResizable\n : !l.static && isResizable;\n\n // isBounded set on child if set on parent, and child is not explicitly false\n const bounded = draggable && isBounded && l.isBounded !== false;\n\n return (\n \n {child}\n \n );\n }\n\n // Called while dragging an element. Part of browser native drag/drop API.\n // Native event target might be the layout itself, or an element within the layout.\n onDragOver = (e: DragOverEvent) => {\n // we should ignore events from layout's children in Firefox\n // to avoid unpredictable jumping of a dropping placeholder\n // FIXME remove this hack\n if (\n isFirefox &&\n e.nativeEvent.target.className.indexOf(layoutClassName) === -1\n ) {\n return false;\n }\n\n const {\n droppingItem,\n margin,\n cols,\n rowHeight,\n maxRows,\n width,\n containerPadding\n } = this.props;\n const { layout } = this.state;\n // This is relative to the DOM element that this event fired for.\n const { layerX, layerY } = e.nativeEvent;\n const droppingPosition = { left: layerX, top: layerY, e };\n\n if (!this.state.droppingDOMNode) {\n const positionParams: PositionParams = {\n cols,\n margin,\n maxRows,\n rowHeight,\n containerWidth: width,\n containerPadding: containerPadding || margin\n };\n\n const calculatedPosition = calcXY(\n positionParams,\n layerY,\n layerX,\n droppingItem.w,\n droppingItem.h\n );\n\n this.setState({\n droppingDOMNode:
,\n droppingPosition,\n layout: [\n ...layout,\n {\n ...droppingItem,\n x: calculatedPosition.x,\n y: calculatedPosition.y,\n static: false,\n isDraggable: true\n }\n ]\n });\n } else if (this.state.droppingPosition) {\n const { left, top } = this.state.droppingPosition;\n const shouldUpdatePosition = left != layerX || top != layerY;\n if (shouldUpdatePosition) {\n this.setState({ droppingPosition });\n }\n }\n\n e.stopPropagation();\n e.preventDefault();\n };\n\n removeDroppingPlaceholder = () => {\n const { droppingItem, cols } = this.props;\n const { layout } = this.state;\n\n const newLayout = compact(\n layout.filter(l => l.i !== droppingItem.i),\n compactType(this.props),\n cols\n );\n\n this.setState({\n layout: newLayout,\n droppingDOMNode: null,\n activeDrag: null,\n droppingPosition: undefined\n });\n };\n\n onDragLeave = () => {\n this.dragEnterCounter--;\n\n // onDragLeave can be triggered on each layout's child.\n // But we know that count of dragEnter and dragLeave events\n // will be balanced after leaving the layout's container\n // so we can increase and decrease count of dragEnter and\n // when it'll be equal to 0 we'll remove the placeholder\n if (this.dragEnterCounter === 0) {\n this.removeDroppingPlaceholder();\n }\n };\n\n onDragEnter = () => {\n this.dragEnterCounter++;\n };\n\n onDrop = (e: Event) => {\n const { droppingItem } = this.props;\n const { layout } = this.state;\n const item = layout.find(l => l.i === droppingItem.i);\n\n // reset gragEnter counter on drop\n this.dragEnterCounter = 0;\n\n this.removeDroppingPlaceholder();\n\n this.props.onDrop(layout, item, e);\n };\n\n render() {\n const { className, style, isDroppable, innerRef } = this.props;\n\n const mergedClassName = classNames(layoutClassName, className);\n const mergedStyle = {\n height: this.containerHeight(),\n ...style\n };\n\n return (\n \n {React.Children.map(this.props.children, child =>\n this.processGridItem(child)\n )}\n {isDroppable &&\n this.state.droppingDOMNode &&\n this.processGridItem(this.state.droppingDOMNode, true)}\n {this.placeholder()}\n
\n );\n }\n}\n","\"use strict\";\n\nexports.__esModule = true;\nexports.default = void 0;\n\nvar _react = _interopRequireDefault(require(\"react\"));\n\nvar _propTypes = _interopRequireDefault(require(\"prop-types\"));\n\nvar _reactDraggable = require(\"react-draggable\");\n\nvar _utils = require(\"./utils\");\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(source, true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(source).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }\n\nfunction _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }\n\nfunction _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return self; }\n\nfunction _inheritsLoose(subClass, superClass) { subClass.prototype = Object.create(superClass.prototype); subClass.prototype.constructor = subClass; subClass.__proto__ = superClass; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\nvar Resizable =\n/*#__PURE__*/\nfunction (_React$Component) {\n _inheritsLoose(Resizable, _React$Component);\n\n function Resizable() {\n var _this;\n\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n _this = _React$Component.call.apply(_React$Component, [this].concat(args)) || this;\n\n _defineProperty(_assertThisInitialized(_this), \"state\", {\n slackW: 0,\n slackH: 0\n });\n\n return _this;\n }\n\n var _proto = Resizable.prototype;\n\n _proto.lockAspectRatio = function lockAspectRatio(width, height, aspectRatio) {\n height = width / aspectRatio;\n width = height * aspectRatio;\n return [width, height];\n } // If you do this, be careful of constraints\n ;\n\n _proto.runConstraints = function runConstraints(width, height) {\n var _ref = [this.props.minConstraints, this.props.maxConstraints],\n min = _ref[0],\n max = _ref[1];\n if (!min && !max) return [width, height]; // Fit width & height to aspect ratio\n\n if (this.props.lockAspectRatio) {\n if (height === this.props.height) {\n var ratio = this.props.width / this.props.height;\n height = width / ratio;\n width = height * ratio;\n } else {\n // Take into account vertical resize with N/S handles on locked aspect\n // ratio. Calculate the change height-first, instead of width-first\n var _ratio = this.props.height / this.props.width;\n\n width = height / _ratio;\n height = width * _ratio;\n }\n }\n\n var oldW = width,\n oldH = height; // Add slack to the values used to calculate bound position. This will ensure that if\n // we start removing slack, the element won't react to it right away until it's been\n // completely removed.\n\n var _this$state = this.state,\n slackW = _this$state.slackW,\n slackH = _this$state.slackH;\n width += slackW;\n height += slackH;\n\n if (min) {\n width = Math.max(min[0], width);\n height = Math.max(min[1], height);\n }\n\n if (max) {\n width = Math.min(max[0], width);\n height = Math.min(max[1], height);\n } // If the numbers changed, we must have introduced some slack. Record it for the next iteration.\n\n\n slackW += oldW - width;\n slackH += oldH - height;\n\n if (slackW !== this.state.slackW || slackH !== this.state.slackH) {\n this.setState({\n slackW: slackW,\n slackH: slackH\n });\n }\n\n return [width, height];\n }\n /**\n * Wrapper around drag events to provide more useful data.\n *\n * @param {String} handlerName Handler name to wrap.\n * @return {Function} Handler function.\n */\n ;\n\n _proto.resizeHandler = function resizeHandler(handlerName, axis) {\n var _this2 = this;\n\n return function (e, _ref2) {\n var node = _ref2.node,\n deltaX = _ref2.deltaX,\n deltaY = _ref2.deltaY;\n deltaX /= _this2.props.transformScale;\n deltaY /= _this2.props.transformScale; // Axis restrictions\n\n var canDragX = (_this2.props.axis === 'both' || _this2.props.axis === 'x') && ['n', 's'].indexOf(axis) === -1;\n var canDragY = (_this2.props.axis === 'both' || _this2.props.axis === 'y') && ['e', 'w'].indexOf(axis) === -1; // reverse delta if using top or left drag handles\n\n if (canDragX && axis[axis.length - 1] === 'w') {\n deltaX = -deltaX;\n }\n\n if (canDragY && axis[0] === 'n') {\n deltaY = -deltaY;\n } // Update w/h\n\n\n var width = _this2.props.width + (canDragX ? deltaX : 0);\n var height = _this2.props.height + (canDragY ? deltaY : 0); // Early return if no change\n\n var widthChanged = width !== _this2.props.width,\n heightChanged = height !== _this2.props.height;\n if (handlerName === 'onResize' && !widthChanged && !heightChanged) return;\n\n var _this2$runConstraints = _this2.runConstraints(width, height);\n\n width = _this2$runConstraints[0];\n height = _this2$runConstraints[1];\n // Set the appropriate state for this handler.\n var newState = {};\n\n if (handlerName === 'onResizeStart') {// nothing\n } else if (handlerName === 'onResizeStop') {\n newState.slackW = newState.slackH = 0;\n } else {\n // Early return if no change after constraints\n if (width === _this2.props.width && height === _this2.props.height) return;\n }\n\n var hasCb = typeof _this2.props[handlerName] === 'function';\n\n if (hasCb) {\n // $FlowIgnore isn't refining this correctly to SyntheticEvent\n if (typeof e.persist === 'function') e.persist();\n\n _this2.setState(newState, function () {\n return _this2.props[handlerName](e, {\n node: node,\n size: {\n width: width,\n height: height\n },\n handle: axis\n });\n });\n } else {\n _this2.setState(newState);\n }\n };\n };\n\n _proto.renderResizeHandle = function renderResizeHandle(resizeHandle) {\n var handle = this.props.handle;\n\n if (handle) {\n if (typeof handle === 'function') {\n return handle(resizeHandle);\n }\n\n return handle;\n }\n\n return _react.default.createElement(\"span\", {\n className: \"react-resizable-handle react-resizable-handle-\" + resizeHandle\n });\n };\n\n _proto.render = function render() {\n var _this3 = this;\n\n // eslint-disable-next-line no-unused-vars\n var _this$props = this.props,\n children = _this$props.children,\n draggableOpts = _this$props.draggableOpts,\n width = _this$props.width,\n height = _this$props.height,\n handleSize = _this$props.handleSize,\n lockAspectRatio = _this$props.lockAspectRatio,\n axis = _this$props.axis,\n minConstraints = _this$props.minConstraints,\n maxConstraints = _this$props.maxConstraints,\n onResize = _this$props.onResize,\n onResizeStop = _this$props.onResizeStop,\n onResizeStart = _this$props.onResizeStart,\n resizeHandles = _this$props.resizeHandles,\n transformScale = _this$props.transformScale,\n p = _objectWithoutPropertiesLoose(_this$props, [\"children\", \"draggableOpts\", \"width\", \"height\", \"handleSize\", \"lockAspectRatio\", \"axis\", \"minConstraints\", \"maxConstraints\", \"onResize\", \"onResizeStop\", \"onResizeStart\", \"resizeHandles\", \"transformScale\"]);\n\n var className = p.className ? p.className + \" react-resizable\" : 'react-resizable'; // What we're doing here is getting the child of this element, and cloning it with this element's props.\n // We are then defining its children as:\n // Its original children (resizable's child's children), and\n // One or more draggable handles.\n\n return (0, _utils.cloneElement)(children, _objectSpread({}, p, {\n className: className,\n children: [children.props.children, resizeHandles.map(function (h) {\n return _react.default.createElement(_reactDraggable.DraggableCore, _extends({}, draggableOpts, {\n key: \"resizableHandle-\" + h,\n onStop: _this3.resizeHandler('onResizeStop', h),\n onStart: _this3.resizeHandler('onResizeStart', h),\n onDrag: _this3.resizeHandler('onResize', h)\n }), _this3.renderResizeHandle(h));\n })]\n }));\n };\n\n return Resizable;\n}(_react.default.Component);\n\nexports.default = Resizable;\n\n_defineProperty(Resizable, \"propTypes\", {\n //\n // Required Props\n //\n // Require that one and only one child be present.\n children: _propTypes.default.element.isRequired,\n // Initial w/h\n width: _propTypes.default.number.isRequired,\n height: _propTypes.default.number.isRequired,\n //\n // Optional props\n //\n // Custom resize handle\n handle: _propTypes.default.element,\n // If you change this, be sure to update your css\n handleSize: _propTypes.default.array,\n // Defines which resize handles should be rendered (default: 'se')\n // Allows for any combination of:\n // 's' - South handle (bottom-center)\n // 'w' - West handle (left-center)\n // 'e' - East handle (right-center)\n // 'n' - North handle (top-center)\n // 'sw' - Southwest handle (bottom-left)\n // 'nw' - Northwest handle (top-left)\n // 'se' - Southeast handle (bottom-right)\n // 'ne' - Northeast handle (top-center)\n resizeHandles: _propTypes.default.arrayOf(_propTypes.default.oneOf(['s', 'w', 'e', 'n', 'sw', 'nw', 'se', 'ne'])),\n transformScale: _propTypes.default.number,\n // If true, will only allow width/height to move in lockstep\n lockAspectRatio: _propTypes.default.bool,\n // Restricts resizing to a particular axis (default: 'both')\n // 'both' - allows resizing by width or height\n // 'x' - only allows the width to be changed\n // 'y' - only allows the height to be changed\n // 'none' - disables resizing altogether\n axis: _propTypes.default.oneOf(['both', 'x', 'y', 'none']),\n // Min/max size\n minConstraints: _propTypes.default.arrayOf(_propTypes.default.number),\n maxConstraints: _propTypes.default.arrayOf(_propTypes.default.number),\n // Callbacks\n onResizeStop: _propTypes.default.func,\n onResizeStart: _propTypes.default.func,\n onResize: _propTypes.default.func,\n // These will be passed wholesale to react-draggable's DraggableCore\n draggableOpts: _propTypes.default.object\n});\n\n_defineProperty(Resizable, \"defaultProps\", {\n handleSize: [20, 20],\n lockAspectRatio: false,\n axis: 'both',\n minConstraints: [20, 20],\n maxConstraints: [Infinity, Infinity],\n resizeHandles: ['se'],\n transformScale: 1\n});","'use strict';\nmodule.exports = function() {\n throw new Error(\"Don't instantiate Resizable directly! Use require('react-resizable').Resizable\");\n};\n\nmodule.exports.Resizable = require('./build/Resizable').default;\nmodule.exports.ResizableBox = require('./build/ResizableBox').default;\n","module.exports = require(\"./lib/ReactGridLayout\").default;\nmodule.exports.utils = require(\"./lib/utils\");\nmodule.exports.Responsive = require(\"./lib/ResponsiveReactGridLayout\").default;\nmodule.exports.Responsive.utils = require(\"./lib/responsiveUtils\");\nmodule.exports.WidthProvider = require(\"./lib/components/WidthProvider\").default;\n","var g;\n\n// This works in non-strict mode\ng = (function() {\n\treturn this;\n})();\n\ntry {\n\t// This works if eval is allowed (see CSP)\n\tg = g || new Function(\"return this\")();\n} catch (e) {\n\t// This works if the window reference is available\n\tif (typeof window === \"object\") g = window;\n}\n\n// g can still be undefined, but nothing to do about it...\n// We return undefined, instead of nothing here, so it's\n// easier to handle this case. if(!global) { ...}\n\nmodule.exports = g;\n","module.exports = function(module) {\n\tif (!module.webpackPolyfill) {\n\t\tmodule.deprecate = function() {};\n\t\tmodule.paths = [];\n\t\t// module.parent = undefined by default\n\t\tif (!module.children) module.children = [];\n\t\tObject.defineProperty(module, \"loaded\", {\n\t\t\tenumerable: true,\n\t\t\tget: function() {\n\t\t\t\treturn module.l;\n\t\t\t}\n\t\t});\n\t\tObject.defineProperty(module, \"id\", {\n\t\t\tenumerable: true,\n\t\t\tget: function() {\n\t\t\t\treturn module.i;\n\t\t\t}\n\t\t});\n\t\tmodule.webpackPolyfill = 1;\n\t}\n\treturn module;\n};\n","/**\n * Copyright (c) 2013-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n'use strict';\n\nvar ReactPropTypesSecret = require('./lib/ReactPropTypesSecret');\n\nfunction emptyFunction() {}\nfunction emptyFunctionWithReset() {}\nemptyFunctionWithReset.resetWarningCache = emptyFunction;\n\nmodule.exports = function() {\n function shim(props, propName, componentName, location, propFullName, secret) {\n if (secret === ReactPropTypesSecret) {\n // It is still safe when called from React.\n return;\n }\n var err = new Error(\n 'Calling PropTypes validators directly is not supported by the `prop-types` package. ' +\n 'Use PropTypes.checkPropTypes() to call them. ' +\n 'Read more at http://fb.me/use-check-prop-types'\n );\n err.name = 'Invariant Violation';\n throw err;\n };\n shim.isRequired = shim;\n function getShim() {\n return shim;\n };\n // Important!\n // Keep this list in sync with production version in `./factoryWithTypeCheckers.js`.\n var ReactPropTypes = {\n array: shim,\n bool: shim,\n func: shim,\n number: shim,\n object: shim,\n string: shim,\n symbol: shim,\n\n any: shim,\n arrayOf: getShim,\n element: shim,\n elementType: shim,\n instanceOf: getShim,\n node: shim,\n objectOf: getShim,\n oneOf: getShim,\n oneOfType: getShim,\n shape: getShim,\n exact: getShim,\n\n checkPropTypes: emptyFunctionWithReset,\n resetWarningCache: emptyFunction\n };\n\n ReactPropTypes.PropTypes = ReactPropTypes;\n\n return ReactPropTypes;\n};\n","/**\n * Copyright (c) 2013-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n'use strict';\n\nvar ReactPropTypesSecret = 'SECRET_DO_NOT_PASS_THIS_OR_YOU_WILL_BE_FIRED';\n\nmodule.exports = ReactPropTypesSecret;\n","\"use strict\";\n\nexports.__esModule = true;\nexports.cloneElement = cloneElement;\n\nvar _react = _interopRequireDefault(require(\"react\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(source, true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(source).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n// React.addons.cloneWithProps look-alike that merges style & className.\nfunction cloneElement(element, props) {\n if (props.style && element.props.style) {\n props.style = _objectSpread({}, element.props.style, {}, props.style);\n }\n\n if (props.className && element.props.className) {\n props.className = element.props.className + \" \" + props.className;\n }\n\n return _react.default.cloneElement(element, props);\n}","\"use strict\";\n\nexports.__esModule = true;\nexports.default = void 0;\n\nvar _react = _interopRequireDefault(require(\"react\"));\n\nvar _propTypes = _interopRequireDefault(require(\"prop-types\"));\n\nvar _Resizable = _interopRequireDefault(require(\"./Resizable\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\n\nfunction _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }\n\nfunction _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return self; }\n\nfunction _inheritsLoose(subClass, superClass) { subClass.prototype = Object.create(superClass.prototype); subClass.prototype.constructor = subClass; subClass.__proto__ = superClass; }\n\nfunction _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\n\n// An example use of Resizable.\nvar ResizableBox =\n/*#__PURE__*/\nfunction (_React$Component) {\n _inheritsLoose(ResizableBox, _React$Component);\n\n function ResizableBox() {\n var _this;\n\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n _this = _React$Component.call.apply(_React$Component, [this].concat(args)) || this;\n\n _defineProperty(_assertThisInitialized(_this), \"state\", {\n width: _this.props.width,\n height: _this.props.height,\n propsWidth: _this.props.width,\n propsHeight: _this.props.height\n });\n\n _defineProperty(_assertThisInitialized(_this), \"onResize\", function (e, data) {\n var size = data.size;\n var width = size.width,\n height = size.height;\n\n if (_this.props.onResize) {\n e.persist && e.persist();\n\n _this.setState(size, function () {\n return _this.props.onResize && _this.props.onResize(e, data);\n });\n } else {\n _this.setState(size);\n }\n });\n\n return _this;\n }\n\n ResizableBox.getDerivedStateFromProps = function getDerivedStateFromProps(props, state) {\n // If parent changes height/width, set that in our state.\n if (state.propsWidth !== props.width || state.propsHeight !== props.height) {\n return {\n width: props.width,\n height: props.height,\n propsWidth: props.width,\n propsHeight: props.height\n };\n }\n\n return null;\n };\n\n var _proto = ResizableBox.prototype;\n\n _proto.render = function render() {\n // Basic wrapper around a Resizable instance.\n // If you use Resizable directly, you are responsible for updating the child component\n // with a new width and height.\n var _this$props = this.props,\n handle = _this$props.handle,\n handleSize = _this$props.handleSize,\n onResize = _this$props.onResize,\n onResizeStart = _this$props.onResizeStart,\n onResizeStop = _this$props.onResizeStop,\n draggableOpts = _this$props.draggableOpts,\n minConstraints = _this$props.minConstraints,\n maxConstraints = _this$props.maxConstraints,\n lockAspectRatio = _this$props.lockAspectRatio,\n axis = _this$props.axis,\n width = _this$props.width,\n height = _this$props.height,\n resizeHandles = _this$props.resizeHandles,\n props = _objectWithoutPropertiesLoose(_this$props, [\"handle\", \"handleSize\", \"onResize\", \"onResizeStart\", \"onResizeStop\", \"draggableOpts\", \"minConstraints\", \"maxConstraints\", \"lockAspectRatio\", \"axis\", \"width\", \"height\", \"resizeHandles\"]);\n\n return _react.default.createElement(_Resizable.default, {\n handle: handle,\n handleSize: handleSize,\n width: this.state.width,\n height: this.state.height,\n onResizeStart: onResizeStart,\n onResize: this.onResize,\n onResizeStop: onResizeStop,\n draggableOpts: draggableOpts,\n minConstraints: minConstraints,\n maxConstraints: maxConstraints,\n lockAspectRatio: lockAspectRatio,\n axis: axis,\n resizeHandles: resizeHandles\n }, _react.default.createElement(\"div\", _extends({\n style: {\n width: this.state.width + 'px',\n height: this.state.height + 'px'\n }\n }, props)));\n };\n\n return ResizableBox;\n}(_react.default.Component);\n\nexports.default = ResizableBox;\n\n_defineProperty(ResizableBox, \"propTypes\", {\n height: _propTypes.default.number,\n width: _propTypes.default.number\n});\n\n_defineProperty(ResizableBox, \"defaultProps\", {\n handleSize: [20, 20]\n});","// @flow\nimport * as React from \"react\";\nimport PropTypes from \"prop-types\";\nimport isEqual from \"lodash.isequal\";\n\nimport {\n cloneLayout,\n synchronizeLayoutWithChildren,\n validateLayout,\n noop,\n type Layout\n} from \"./utils\";\nimport {\n getBreakpointFromWidth,\n getColsFromBreakpoint,\n findOrGenerateResponsiveLayout,\n type ResponsiveLayout,\n type Breakpoints\n} from \"./responsiveUtils\";\nimport ReactGridLayout from \"./ReactGridLayout\";\n\nconst type = obj => Object.prototype.toString.call(obj);\n\n/**\n * Get a value of margin or containerPadding.\n *\n * @param {Array | Object} param Margin | containerPadding, e.g. [10, 10] | {lg: [10, 10], ...}.\n * @param {String} breakpoint Breakpoint: lg, md, sm, xs and etc.\n * @return {Array}\n */\n\nfunction getIndentationValue(\n param: { [key: string]: [number, number] } | [number, number],\n breakpoint: string\n) {\n return Array.isArray(param) ? param : param[breakpoint];\n}\n\ntype State = {\n layout: Layout,\n breakpoint: string,\n cols: number,\n layouts?: { [key: string]: Layout }\n};\n\ntype Props = {|\n ...React.ElementConfig,\n\n // Responsive config\n breakpoint?: ?Breakpoint,\n breakpoints: Breakpoints,\n cols: { [key: Breakpoint]: number },\n layouts: ResponsiveLayout,\n width: number,\n margin: { [key: Breakpoint]: [number, number] } | [number, number],\n containerPadding: { [key: Breakpoint]: [number, number] } | [number, number],\n\n // Callbacks\n onBreakpointChange: (Breakpoint, cols: number) => void,\n onLayoutChange: (Layout, { [key: Breakpoint]: Layout }) => void,\n onWidthChange: (\n containerWidth: number,\n margin: [number, number],\n cols: number,\n containerPadding: [number, number] | null\n ) => void\n|};\n\nexport default class ResponsiveReactGridLayout extends React.Component<\n Props<>,\n State\n> {\n // This should only include propTypes needed in this code; RGL itself\n // will do validation of the rest props passed to it.\n static propTypes = {\n //\n // Basic props\n //\n\n // Optional, but if you are managing width yourself you may want to set the breakpoint\n // yourself as well.\n breakpoint: PropTypes.string,\n\n // {name: pxVal}, e.g. {lg: 1200, md: 996, sm: 768, xs: 480}\n breakpoints: PropTypes.object,\n\n // # of cols. This is a breakpoint -> cols map\n cols: PropTypes.object,\n\n // # of margin. This is a breakpoint -> margin map\n // e.g. { lg: [5, 5], md: [10, 10], sm: [15, 15] }\n // Margin between items [x, y] in px\n // e.g. [10, 10]\n margin: PropTypes.oneOfType([PropTypes.array, PropTypes.object]),\n\n // # of containerPadding. This is a breakpoint -> containerPadding map\n // e.g. { lg: [5, 5], md: [10, 10], sm: [15, 15] }\n // Padding inside the container [x, y] in px\n // e.g. [10, 10]\n containerPadding: PropTypes.oneOfType([PropTypes.array, PropTypes.object]),\n\n // layouts is an object mapping breakpoints to layouts.\n // e.g. {lg: Layout, md: Layout, ...}\n layouts(props: Props<>, propName: string) {\n if (type(props[propName]) !== \"[object Object]\") {\n throw new Error(\n \"Layout property must be an object. Received: \" +\n type(props[propName])\n );\n }\n Object.keys(props[propName]).forEach(key => {\n if (!(key in props.breakpoints)) {\n throw new Error(\n \"Each key in layouts must align with a key in breakpoints.\"\n );\n }\n validateLayout(props.layouts[key], \"layouts.\" + key);\n });\n },\n\n // The width of this component.\n // Required in this propTypes stanza because generateInitialState() will fail without it.\n width: PropTypes.number.isRequired,\n\n //\n // Callbacks\n //\n\n // Calls back with breakpoint and new # cols\n onBreakpointChange: PropTypes.func,\n\n // Callback so you can save the layout.\n // Calls back with (currentLayout, allLayouts). allLayouts are keyed by breakpoint.\n onLayoutChange: PropTypes.func,\n\n // Calls back with (containerWidth, margin, cols, containerPadding)\n onWidthChange: PropTypes.func\n };\n\n static defaultProps = {\n breakpoints: { lg: 1200, md: 996, sm: 768, xs: 480, xxs: 0 },\n cols: { lg: 12, md: 10, sm: 6, xs: 4, xxs: 2 },\n layouts: {},\n margin: [10, 10],\n containerPadding: {\n lg: [0, 0],\n md: [0, 0],\n sm: [0, 0],\n xs: [0, 0],\n xxs: [0, 0]\n },\n onBreakpointChange: noop,\n onLayoutChange: noop,\n onWidthChange: noop\n };\n\n state = this.generateInitialState();\n\n generateInitialState(): State {\n const { width, breakpoints, layouts, cols } = this.props;\n const breakpoint = getBreakpointFromWidth(breakpoints, width);\n const colNo = getColsFromBreakpoint(breakpoint, cols);\n // verticalCompact compatibility, now deprecated\n const compactType =\n this.props.verticalCompact === false ? null : this.props.compactType;\n // Get the initial layout. This can tricky; we try to generate one however possible if one doesn't exist\n // for this layout.\n const initialLayout = findOrGenerateResponsiveLayout(\n layouts,\n breakpoints,\n breakpoint,\n breakpoint,\n colNo,\n compactType\n );\n\n return {\n layout: initialLayout,\n breakpoint: breakpoint,\n cols: colNo\n };\n }\n\n static getDerivedStateFromProps(nextProps: Props<*>, prevState: State) {\n if (!isEqual(nextProps.layouts, prevState.layouts)) {\n // Allow parent to set layouts directly.\n const { breakpoint, cols } = prevState;\n\n // Since we're setting an entirely new layout object, we must generate a new responsive layout\n // if one does not exist.\n const newLayout = findOrGenerateResponsiveLayout(\n nextProps.layouts,\n nextProps.breakpoints,\n breakpoint,\n breakpoint,\n cols,\n nextProps.compactType\n );\n return { layout: newLayout, layouts: nextProps.layouts };\n }\n\n return null;\n }\n\n componentDidUpdate(prevProps: Props<*>) {\n // Allow parent to set width or breakpoint directly.\n if (\n this.props.width != prevProps.width ||\n this.props.breakpoint !== prevProps.breakpoint ||\n !isEqual(this.props.breakpoints, prevProps.breakpoints) ||\n !isEqual(this.props.cols, prevProps.cols)\n ) {\n this.onWidthChange(prevProps);\n }\n }\n\n // wrap layouts so we do not need to pass layouts to child\n onLayoutChange = (layout: Layout) => {\n this.props.onLayoutChange(layout, {\n ...this.props.layouts,\n [this.state.breakpoint]: layout\n });\n };\n\n /**\n * When the width changes work through breakpoints and reset state with the new width & breakpoint.\n * Width changes are necessary to figure out the widget widths.\n */\n onWidthChange(prevProps: Props<*>) {\n const { breakpoints, cols, layouts, compactType } = this.props;\n const newBreakpoint =\n this.props.breakpoint ||\n getBreakpointFromWidth(this.props.breakpoints, this.props.width);\n\n const lastBreakpoint = this.state.breakpoint;\n const newCols: number = getColsFromBreakpoint(newBreakpoint, cols);\n const newLayouts = { ...layouts };\n\n // Breakpoint change\n if (\n lastBreakpoint !== newBreakpoint ||\n prevProps.breakpoints !== breakpoints ||\n prevProps.cols !== cols\n ) {\n // Preserve the current layout if the current breakpoint is not present in the next layouts.\n if (!(lastBreakpoint in newLayouts))\n newLayouts[lastBreakpoint] = cloneLayout(this.state.layout);\n\n // Find or generate a new layout.\n let layout = findOrGenerateResponsiveLayout(\n newLayouts,\n breakpoints,\n newBreakpoint,\n lastBreakpoint,\n newCols,\n compactType\n );\n\n // This adds missing items.\n layout = synchronizeLayoutWithChildren(\n layout,\n this.props.children,\n newCols,\n compactType\n );\n\n // Store the new layout.\n newLayouts[newBreakpoint] = layout;\n\n // callbacks\n this.props.onLayoutChange(layout, newLayouts);\n this.props.onBreakpointChange(newBreakpoint, newCols);\n\n this.setState({\n breakpoint: newBreakpoint,\n layout: layout,\n cols: newCols\n });\n }\n\n const margin = getIndentationValue(this.props.margin, newBreakpoint);\n const containerPadding = getIndentationValue(\n this.props.containerPadding,\n newBreakpoint\n );\n\n //call onWidthChange on every change of width, not only on breakpoint changes\n this.props.onWidthChange(\n this.props.width,\n margin,\n newCols,\n containerPadding\n );\n }\n\n render() {\n /* eslint-disable no-unused-vars */\n const {\n breakpoint,\n breakpoints,\n cols,\n layouts,\n margin,\n containerPadding,\n onBreakpointChange,\n onLayoutChange,\n onWidthChange,\n ...other\n } = this.props;\n /* eslint-enable no-unused-vars */\n\n return (\n \n );\n }\n}\n","// @flow\nimport * as React from \"react\";\nimport PropTypes from \"prop-types\";\nimport ReactDOM from \"react-dom\";\n\ntype WPDefaultProps = {|\n measureBeforeMount: boolean\n|};\n\n// eslint-disable-next-line no-unused-vars\ntype WPProps = {|\n className?: string,\n style?: Object,\n ...WPDefaultProps\n|};\n\ntype WPState = {|\n width: number\n|};\n\n/*\n * A simple HOC that provides facility for listening to container resizes.\n *\n * The Flow type is pretty janky here. I can't just spread `WPProps` into this returned object - I wish I could - but it triggers\n * a flow bug of some sort that causes it to stop typechecking.\n */\nexport default function WidthProvider(\n ComposedComponent: React.AbstractComponent\n): React.AbstractComponent<{|\n ...Config,\n measureBeforeMount?: boolean,\n className?: string,\n style?: Object,\n width?: number\n|}> {\n return class WidthProvider extends React.Component<\n {|\n ...Config,\n measureBeforeMount?: boolean,\n className?: string,\n style?: Object,\n width?: number\n |},\n WPState\n > {\n static defaultProps: WPDefaultProps = {\n measureBeforeMount: false\n };\n\n static propTypes = {\n // If true, will not render children until mounted. Useful for getting the exact width before\n // rendering, to prevent any unsightly resizing.\n measureBeforeMount: PropTypes.bool\n };\n\n state = {\n width: 1280\n };\n\n mounted: boolean = false;\n\n componentDidMount() {\n this.mounted = true;\n\n window.addEventListener(\"resize\", this.onWindowResize);\n // Call to properly set the breakpoint and resize the elements.\n // Note that if you're doing a full-width element, this can get a little wonky if a scrollbar\n // appears because of the grid. In that case, fire your own resize event, or set `overflow: scroll` on your body.\n this.onWindowResize();\n }\n\n componentWillUnmount() {\n this.mounted = false;\n window.removeEventListener(\"resize\", this.onWindowResize);\n }\n\n onWindowResize = () => {\n if (!this.mounted) return;\n // eslint-disable-next-line react/no-find-dom-node\n const node = ReactDOM.findDOMNode(this); // Flow casts this to Text | Element\n if (node instanceof HTMLElement)\n this.setState({ width: node.offsetWidth });\n };\n\n render() {\n const { measureBeforeMount, ...rest } = this.props;\n if (measureBeforeMount && !this.mounted) {\n return (\n
\n );\n }\n\n return ;\n }\n };\n}\n"],"sourceRoot":""} \ No newline at end of file diff --git a/package.json b/package.json index fb01645ea..0f8818df0 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "react-grid-layout", - "version": "0.18.3", + "version": "1.0.0", "description": "A draggable and resizable grid layout with responsive breakpoints, for React.", "main": "index.js", "scripts": { @@ -108,4 +108,4 @@ "pre-commit": "lint-staged && make lint && make test" } } -} +} \ No newline at end of file