From eba75d87a51b8fbcb67c02461b5513bbbe35b74f Mon Sep 17 00:00:00 2001 From: Jeff Watson Date: Fri, 8 Dec 2023 15:03:31 -0600 Subject: [PATCH 1/2] Expose updated full list of items in confirmChange function Signed-off-by: Jeff Watson --- README.md | 44 +++++++++++++++++------------------ dist/Nestable/Nestable.js | 4 ++-- dist/Nestable/Nestable.js.map | 2 +- dist/example/example.js | 4 ++-- dist/types.d.ts | 1 + src/Nestable/Nestable.tsx | 2 +- src/types.ts | 1 + 7 files changed, 30 insertions(+), 28 deletions(-) diff --git a/README.md b/README.md index e5f2cda..8254af2 100644 --- a/README.md +++ b/README.md @@ -53,31 +53,31 @@ const Example = () => ( ## Options -| Property | Type | Default | Description | -|----------|------|---------|-------------| -| childrenProp | string | `"children"` | Name of a property for children. | -| className | string | `undefined` | Extra class name which can be passed to a root element. | -| collapsed | boolean | `false` | Makes groups collapsed by default. | -| confirmChange | function | `() => true` | Callback which has a single parameter with keys: `dragItem` - item which is being dragged, `destinationParent` - item where dragItem is about to land (or `null` if moving to root). Let function return `false` if this movement should not happen. | -| disableCollapse | boolean | `false` | Disable toggling a collapsed state of items with children. If you need to set a specific initial state, then it is still possible to do so with the public method `collapse`. | -| disableDrag | boolean or function | `false` | Disable dragging. Pass boolean to apply to all items. Pass a callback to target individual items. It has a single parameter with keys: `item` - item from your array, `index` - number, index of the item, `depth` - number, depth of the item. | -| group | string or number | `random string` | Different group names may be passed if you have more than one nestable component on a page and want some extra styles for portal instances. | -| handler | node | `undefined` | If you pass it, it will get wrapped with drag handlers and you may use it in your render method. | -| idProp | string | `"id"` | Name of a property for id. | -| items | array | `[]` | Array of items. Every item must be of shape `{id: @uniq}` to distinguish elements. | -| maxDepth | number | `10` | Maximum available level of nesting. | -| onChange | function | `() => {}` | Callback which has a single parameter with keys: `items` - new array after position was changed, `dragItem` - item which has been moved, `targetPath` - array of numbers, those numbers are indices and they make path to a location, to where item has been moved. | -| onCollapseChange | function | `() => {}` | Callback which has a single parameter with one of two possible keys: `openIds` - array of ids which are open if `collapsed` is set to `ture`, or `closedIds` - array of ids which are closed if `collapsed` is set to `false`. **Note:** this callback is triggered not only when user explicitly opens or closes an item, but when implicit events happen as well, like when the only child of open item is moved out. | -| onDragEnd | function | `() => {}` | Callback which has no parameters. It is invoked when dragging ends via drop or cancel. | -| onDragStart | function | `() => {}` | Callback which has a single parameter with keys: `dragItem` - item which has been moved. | -| renderCollapseIcon | function | `() => ` | Function for rendering collapse icon. Has a single parameter with keys: `isCollapsed` - boolean, true if this group has children and is collapsed. | -| renderItem | function | `({item}) => String(item)` | Function for rendering every item. Has a single parameter with keys: `item` - item from your array, `index` - number, index of the item, `depth` - number, depth of the item, `collapseIcon` - node, icon for items with children (allows you to collapse the group), `handler` - node, which you have passed via the same property, but wrapped with some additional events, `isDraggable` - boolean, tells if dragging is allowed for this item (see `disableDrag` prop for details). | -| threshold | number | `30` | Amount of pixels which mouse should move horizontally before increasing/decreasing level (nesting) of current element. | +| Property | Type | Default | Description | +|--------------------|---------------------|----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| +| childrenProp | string | `"children"` | Name of a property for children. | +| className | string | `undefined` | Extra class name which can be passed to a root element. | +| collapsed | boolean | `false` | Makes groups collapsed by default. | +| confirmChange | function | `() => true` | Callback which has a single parameter with keys: `dragItem` - item which is being dragged, `destinationParent` - item where dragItem is about to land (or `null` if moving to root), `items` - new array after position change. Let function return `false` if this movement should not happen. | +| disableCollapse | boolean | `false` | Disable toggling a collapsed state of items with children. If you need to set a specific initial state, then it is still possible to do so with the public method `collapse`. | +| disableDrag | boolean or function | `false` | Disable dragging. Pass boolean to apply to all items. Pass a callback to target individual items. It has a single parameter with keys: `item` - item from your array, `index` - number, index of the item, `depth` - number, depth of the item. | +| group | string or number | `random string` | Different group names may be passed if you have more than one nestable component on a page and want some extra styles for portal instances. | +| handler | node | `undefined` | If you pass it, it will get wrapped with drag handlers and you may use it in your render method. | +| idProp | string | `"id"` | Name of a property for id. | +| items | array | `[]` | Array of items. Every item must be of shape `{id: @uniq}` to distinguish elements. | +| maxDepth | number | `10` | Maximum available level of nesting. | +| onChange | function | `() => {}` | Callback which has a single parameter with keys: `items` - new array after position was changed, `dragItem` - item which has been moved, `targetPath` - array of numbers, those numbers are indices and they make path to a location, to where item has been moved. | +| onCollapseChange | function | `() => {}` | Callback which has a single parameter with one of two possible keys: `openIds` - array of ids which are open if `collapsed` is set to `ture`, or `closedIds` - array of ids which are closed if `collapsed` is set to `false`. **Note:** this callback is triggered not only when user explicitly opens or closes an item, but when implicit events happen as well, like when the only child of open item is moved out. | +| onDragEnd | function | `() => {}` | Callback which has no parameters. It is invoked when dragging ends via drop or cancel. | +| onDragStart | function | `() => {}` | Callback which has a single parameter with keys: `dragItem` - item which has been moved. | +| renderCollapseIcon | function | `() => ` | Function for rendering collapse icon. Has a single parameter with keys: `isCollapsed` - boolean, true if this group has children and is collapsed. | +| renderItem | function | `({item}) => String(item)` | Function for rendering every item. Has a single parameter with keys: `item` - item from your array, `index` - number, index of the item, `depth` - number, depth of the item, `collapseIcon` - node, icon for items with children (allows you to collapse the group), `handler` - node, which you have passed via the same property, but wrapped with some additional events, `isDraggable` - boolean, tells if dragging is allowed for this item (see `disableDrag` prop for details). | +| threshold | number | `30` | Amount of pixels which mouse should move horizontally before increasing/decreasing level (nesting) of current element. | #### Public methods -| Method | Accepts | Description | -|--------|---------|-------------| +| Method | Accepts | Description | +|----------|-----------------|--------------------------------------------------------------------------------------------------------------------| | collapse | string or array | `"NONE"` - expand all groups; `"ALL"` - collapse all groups; `[]` - collapse all groups with ids from given array. | ## Todo diff --git a/dist/Nestable/Nestable.js b/dist/Nestable/Nestable.js index e5f2183..341dfe6 100644 --- a/dist/Nestable/Nestable.js +++ b/dist/Nestable/Nestable.js @@ -294,8 +294,6 @@ var Nestable = /** @class */ (function (_super) { ? pathTo : pathTo.slice(0, -1); var destinationParent = this.getItemByPath(destinationPath); - if (!confirmChange({ dragItem: dragItem, destinationParent: destinationParent })) - return; var removePath = this.getSplicePath(pathFrom, { numToRemove: 1, childrenProp: childrenProp, @@ -307,6 +305,8 @@ var Nestable = /** @class */ (function (_super) { }); items = (0, react_addons_update_1.default)(items, removePath); items = (0, react_addons_update_1.default)(items, insertPath); + if (!confirmChange({ dragItem: dragItem, destinationParent: destinationParent, items: items })) + return; this.setState(function (prevState) { return (__assign(__assign(__assign({}, prevState), { items: items, isDirty: true }), extraProps)); }); if (extraProps.collapsedItems !== this.state.collapsedItems) { this.onCollapseChange(extraProps.collapsedItems); diff --git a/dist/Nestable/Nestable.js.map b/dist/Nestable/Nestable.js.map index 47e361d..760371d 100644 --- a/dist/Nestable/Nestable.js.map +++ b/dist/Nestable/Nestable.js.map @@ -1 +1 @@ -{"version":3,"file":"Nestable.js","sourceRoot":"","sources":["../../src/Nestable/Nestable.tsx"],"names":[],"mappings":"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"} \ No newline at end of file +{"version":3,"file":"Nestable.js","sourceRoot":"","sources":["../../src/Nestable/Nestable.tsx"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/dist/example/example.js b/dist/example/example.js index 680a4a7..94189c0 100644 --- a/dist/example/example.js +++ b/dist/example/example.js @@ -279,7 +279,7 @@ eval("\nvar __importDefault = (this && this.__importDefault) || function (mod) { /***/ (function(__unused_webpack_module, exports, __webpack_require__) { "use strict"; -eval("\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __assign = (this && this.__assign) || function () {\n __assign = Object.assign || function(t) {\n for (var s, i = 1, n = arguments.length; i < n; i++) {\n s = arguments[i];\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))\n t[p] = s[p];\n }\n return t;\n };\n return __assign.apply(this, arguments);\n};\nvar __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n var desc = Object.getOwnPropertyDescriptor(m, k);\n if (!desc || (\"get\" in desc ? !m.__esModule : desc.writable || desc.configurable)) {\n desc = { enumerable: true, get: function() { return m[k]; } };\n }\n Object.defineProperty(o, k2, desc);\n}) : (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n o[k2] = m[k];\n}));\nvar __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {\n Object.defineProperty(o, \"default\", { enumerable: true, value: v });\n}) : function(o, v) {\n o[\"default\"] = v;\n});\nvar __importStar = (this && this.__importStar) || function (mod) {\n if (mod && mod.__esModule) return mod;\n var result = {};\n if (mod != null) for (var k in mod) if (k !== \"default\" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);\n __setModuleDefault(result, mod);\n return result;\n};\nvar __spreadArray = (this && this.__spreadArray) || function (to, from, pack) {\n if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {\n if (ar || !(i in from)) {\n if (!ar) ar = Array.prototype.slice.call(from, 0, i);\n ar[i] = from[i];\n }\n }\n return to.concat(ar || Array.prototype.slice.call(from));\n};\nvar __importDefault = (this && this.__importDefault) || function (mod) {\n return (mod && mod.__esModule) ? mod : { \"default\": mod };\n};\nObject.defineProperty(exports, \"__esModule\", ({ value: true }));\nvar react_1 = __importStar(__webpack_require__(/*! react */ \"./node_modules/react/index.js\"));\nvar react_addons_shallow_compare_1 = __importDefault(__webpack_require__(/*! react-addons-shallow-compare */ \"./node_modules/react-addons-shallow-compare/index.js\"));\nvar react_addons_update_1 = __importDefault(__webpack_require__(/*! react-addons-update */ \"./node_modules/react-addons-update/index.js\"));\nvar classnames_1 = __importDefault(__webpack_require__(/*! classnames */ \"./node_modules/classnames/index.js\"));\nvar utils_1 = __webpack_require__(/*! ../utils */ \"./src/utils.ts\");\nvar NestableItem_1 = __importDefault(__webpack_require__(/*! ./NestableItem */ \"./src/Nestable/NestableItem.tsx\"));\nvar Nestable = /** @class */ (function (_super) {\n __extends(Nestable, _super);\n function Nestable(props) {\n var _this = _super.call(this, props) || this;\n _this.el = null;\n _this.elCopyStyles = null;\n _this.mouse = {\n last: { x: 0 },\n shift: { x: 0 },\n };\n // ––––––––––––––––––––––––––––––––––––\n // Public Methods\n // ––––––––––––––––––––––––––––––––––––\n _this.collapse = function (itemIds) {\n var _a = _this.props, idProp = _a.idProp, childrenProp = _a.childrenProp, collapsed = _a.collapsed;\n var items = _this.state.items;\n if (itemIds === 'NONE') {\n _this.setState({\n collapsedItems: collapsed\n ? (0, utils_1.getAllNonEmptyNodesIds)(items, { idProp: idProp, childrenProp: childrenProp })\n : [],\n });\n }\n else if (itemIds === 'ALL') {\n _this.setState({\n collapsedItems: collapsed\n ? []\n : (0, utils_1.getAllNonEmptyNodesIds)(items, { idProp: idProp, childrenProp: childrenProp }),\n });\n }\n else if ((0, utils_1.isArray)(itemIds)) {\n _this.setState({\n collapsedItems: (0, utils_1.getAllNonEmptyNodesIds)(items, { idProp: idProp, childrenProp: childrenProp })\n .filter(function (id) { return (itemIds.indexOf(id) > -1) !== collapsed; }),\n });\n }\n };\n // ––––––––––––––––––––––––––––––––––––\n // Methods\n // ––––––––––––––––––––––––––––––––––––\n _this.startTrackMouse = function () {\n document.addEventListener('mousemove', _this.onMouseMove);\n document.addEventListener('mouseup', _this.onDragEnd);\n document.addEventListener('keydown', _this.onKeyDown);\n };\n _this.stopTrackMouse = function () {\n document.removeEventListener('mousemove', _this.onMouseMove);\n document.removeEventListener('mouseup', _this.onDragEnd);\n document.removeEventListener('keydown', _this.onKeyDown);\n _this.elCopyStyles = null;\n };\n _this.getItemDepth = function (item) {\n var childrenProp = _this.props.childrenProp;\n var level = 1;\n if (item[childrenProp].length > 0) {\n var childrenDepths = item[childrenProp].map(_this.getItemDepth);\n level += Math.max.apply(Math, childrenDepths);\n }\n return level;\n };\n _this.checkIfCollapsed = function (item) {\n var _a = _this.props, collapsed = _a.collapsed, idProp = _a.idProp;\n var collapsedItems = _this.state.collapsedItems;\n return !!((collapsedItems.indexOf(item[idProp]) > -1) !== collapsed);\n };\n // ––––––––––––––––––––––––––––––––––––\n // Click handlers or event handlers\n // ––––––––––––––––––––––––––––––––––––\n _this.onDragStart = function (e, item) {\n var onDragStart = _this.props.onDragStart;\n e.preventDefault();\n e.stopPropagation();\n if (!(e.target instanceof Element))\n return;\n _this.el = (0, utils_1.closest)(e.target, '.nestable-item');\n _this.startTrackMouse();\n _this.onMouseMove(e);\n onDragStart({ dragItem: item });\n _this.setState({\n dragItem: item,\n itemsOld: _this.state.items,\n });\n };\n _this.onDragEnd = function (e, isCancel) {\n var onDragEnd = _this.props.onDragEnd;\n e === null || e === void 0 ? void 0 : e.preventDefault();\n _this.stopTrackMouse();\n _this.el = null;\n onDragEnd();\n isCancel\n ? _this.dragRevert()\n : _this.dragApply();\n };\n _this.onMouseMove = function (e) {\n var _a = _this.props, group = _a.group, threshold = _a.threshold;\n var dragItem = _this.state.dragItem;\n var clientX = e.clientX, clientY = e.clientY;\n var transformProps = (0, utils_1.getTransformProps)(clientX, clientY);\n var elCopy = document.querySelector(\".nestable-\".concat(group, \" .nestable-drag-layer > .nestable-list\"));\n if (!_this.elCopyStyles) {\n var offset = (0, utils_1.getOffsetRect)(_this.el);\n var scroll_1 = (0, utils_1.getTotalScroll)(_this.el);\n _this.elCopyStyles = __assign({ marginTop: offset.top - clientY - scroll_1.top, marginLeft: offset.left - clientX - scroll_1.left }, transformProps);\n }\n else {\n _this.elCopyStyles = __assign(__assign({}, _this.elCopyStyles), transformProps);\n Object.keys(transformProps).forEach(function (key) {\n elCopy.style[key] = transformProps[key];\n });\n var diffX = clientX - _this.mouse.last.x;\n if ((diffX >= 0 && _this.mouse.shift.x >= 0) ||\n (diffX <= 0 && _this.mouse.shift.x <= 0)) {\n _this.mouse.shift.x += diffX;\n }\n else {\n _this.mouse.shift.x = 0;\n }\n _this.mouse.last.x = clientX;\n if (Math.abs(_this.mouse.shift.x) > threshold) {\n if (_this.mouse.shift.x > 0) {\n _this.tryIncreaseDepth(dragItem);\n }\n else {\n _this.tryDecreaseDepth(dragItem);\n }\n _this.mouse.shift.x = 0;\n }\n }\n };\n _this.onMouseEnter = function (e, item) {\n e.preventDefault();\n e.stopPropagation();\n var _a = _this.props, collapsed = _a.collapsed, idProp = _a.idProp, childrenProp = _a.childrenProp;\n var dragItem = _this.state.dragItem;\n if (dragItem[idProp] === item[idProp])\n return;\n var pathFrom = _this.getPathById(dragItem[idProp]);\n var pathTo = _this.getPathById(item[idProp]);\n // if collapsed by default\n // and move out the only child\n // remove parent node from list of open nodes\n var collapseProps = {};\n if (collapsed && pathFrom.length > 1) {\n var parent_1 = _this.getItemByPath(pathFrom.slice(0, -1));\n if (parent_1[childrenProp].length === 1) {\n collapseProps = _this.onToggleCollapse(parent_1, true);\n }\n }\n _this.moveItem({ dragItem: dragItem, pathFrom: pathFrom, pathTo: pathTo }, collapseProps);\n };\n _this.onToggleCollapse = function (item, isGetter) {\n var _a = _this.props, collapsed = _a.collapsed, idProp = _a.idProp;\n var collapsedItems = _this.state.collapsedItems;\n var isCollapsed = _this.checkIfCollapsed(item);\n var newState = {\n collapsedItems: (isCollapsed !== collapsed)\n ? collapsedItems.filter(function (id) { return id !== item[idProp]; })\n : collapsedItems.concat(item[idProp]),\n };\n if (isGetter) {\n return newState;\n }\n else {\n _this.setState(newState);\n _this.onCollapseChange(newState.collapsedItems);\n }\n };\n _this.onCollapseChange = function (ids) {\n var _a = _this.props, collapsed = _a.collapsed, onCollapseChange = _a.onCollapseChange;\n onCollapseChange(collapsed ? { openIds: ids } : { closedIds: ids });\n };\n _this.onKeyDown = function (e) {\n if (e.which === 27) {\n // ESC\n _this.onDragEnd(null, true);\n }\n };\n _this.state = {\n items: [],\n itemsOld: null,\n dragItem: null,\n isDirty: false,\n collapsedItems: [],\n };\n return _this;\n }\n Nestable.prototype.componentDidMount = function () {\n var _a = this.props, items = _a.items, childrenProp = _a.childrenProp;\n // make sure every item has property 'children'\n items = (0, utils_1.listWithChildren)(items, childrenProp);\n this.setState({ items: items });\n };\n Nestable.prototype.componentDidUpdate = function (prevProps) {\n var _this = this;\n var _a = this, _b = _a.props, itemsNew = _b.items, childrenProp = _b.childrenProp, state = _a.state;\n var isPropsChanged = (0, react_addons_shallow_compare_1.default)(__assign(__assign({}, this), { props: prevProps, state: state }), this.props, state);\n if (isPropsChanged) {\n this.stopTrackMouse();\n this.setState(function (prevState) {\n var newState = __assign(__assign({}, prevState), { items: (0, utils_1.listWithChildren)(itemsNew, childrenProp), dragItem: null, isDirty: false });\n if (prevProps.collapsed !== _this.props.collapsed) {\n newState.collapsedItems = [];\n _this.onCollapseChange(newState.collapsedItems);\n }\n return newState;\n });\n }\n };\n Nestable.prototype.componentWillUnmount = function () {\n this.stopTrackMouse();\n };\n Nestable.prototype.moveItem = function (_a, extraProps) {\n var dragItem = _a.dragItem, pathFrom = _a.pathFrom, pathTo = _a.pathTo;\n if (extraProps === void 0) { extraProps = {}; }\n var _b = this.props, childrenProp = _b.childrenProp, confirmChange = _b.confirmChange;\n var dragItemSize = this.getItemDepth(dragItem);\n var items = this.state.items;\n // the remove action might affect the next position,\n // so update next coordinates accordingly\n var realPathTo = this.getRealNextPath(pathFrom, pathTo, dragItemSize);\n if (realPathTo.length === 0)\n return;\n // user can validate every movement\n var destinationPath = realPathTo.length > pathTo.length\n ? pathTo\n : pathTo.slice(0, -1);\n var destinationParent = this.getItemByPath(destinationPath);\n if (!confirmChange({ dragItem: dragItem, destinationParent: destinationParent }))\n return;\n var removePath = this.getSplicePath(pathFrom, {\n numToRemove: 1,\n childrenProp: childrenProp,\n });\n var insertPath = this.getSplicePath(realPathTo, {\n numToRemove: 0,\n itemsToInsert: [dragItem],\n childrenProp: childrenProp,\n });\n items = (0, react_addons_update_1.default)(items, removePath);\n items = (0, react_addons_update_1.default)(items, insertPath);\n this.setState(function (prevState) { return (__assign(__assign(__assign({}, prevState), { items: items, isDirty: true }), extraProps)); });\n if (extraProps.collapsedItems !== this.state.collapsedItems) {\n this.onCollapseChange(extraProps.collapsedItems);\n }\n };\n Nestable.prototype.tryIncreaseDepth = function (dragItem) {\n var _a = this.props, maxDepth = _a.maxDepth, idProp = _a.idProp, childrenProp = _a.childrenProp, collapsed = _a.collapsed;\n var pathFrom = this.getPathById(dragItem[idProp]);\n var itemIndex = pathFrom[pathFrom.length - 1];\n var newDepth = pathFrom.length + this.getItemDepth(dragItem);\n // has previous sibling and isn't at max depth\n if (itemIndex > 0 && newDepth <= maxDepth) {\n var prevSibling = this.getItemByPath(pathFrom.slice(0, -1).concat(itemIndex - 1));\n // previous sibling is not collapsed\n if (!prevSibling[childrenProp].length || !this.checkIfCollapsed(prevSibling)) {\n var pathTo = pathFrom\n .slice(0, -1)\n .concat(itemIndex - 1)\n .concat(prevSibling[childrenProp].length);\n // if collapsed by default\n // and was no children here\n // open this node\n var collapseProps = {};\n if (collapsed && !prevSibling[childrenProp].length) {\n collapseProps = this.onToggleCollapse(prevSibling, true);\n }\n this.moveItem({ dragItem: dragItem, pathFrom: pathFrom, pathTo: pathTo }, collapseProps);\n }\n }\n };\n Nestable.prototype.tryDecreaseDepth = function (dragItem) {\n var _a = this.props, idProp = _a.idProp, childrenProp = _a.childrenProp, collapsed = _a.collapsed;\n var pathFrom = this.getPathById(dragItem[idProp]);\n var itemIndex = pathFrom[pathFrom.length - 1];\n // has parent\n if (pathFrom.length > 1) {\n var parent_2 = this.getItemByPath(pathFrom.slice(0, -1));\n // is last (by order) item in array\n if (itemIndex + 1 === parent_2[childrenProp].length) {\n var pathTo = pathFrom.slice(0, -1);\n pathTo[pathTo.length - 1] += 1;\n // if collapsed by default\n // and is last (by count) item in array\n // remove this node from list of open nodes\n var collapseProps = {};\n if (collapsed && parent_2[childrenProp].length === 1) {\n collapseProps = this.onToggleCollapse(parent_2, true);\n }\n this.moveItem({ dragItem: dragItem, pathFrom: pathFrom, pathTo: pathTo }, collapseProps);\n }\n }\n };\n Nestable.prototype.dragApply = function () {\n var _a = this.props, onChange = _a.onChange, idProp = _a.idProp;\n var _b = this.state, items = _b.items, isDirty = _b.isDirty, dragItem = _b.dragItem;\n this.setState({\n itemsOld: null,\n dragItem: null,\n isDirty: false,\n });\n if (onChange && isDirty) {\n var targetPath = this.getPathById(dragItem[idProp], items);\n onChange({ items: items, dragItem: dragItem, targetPath: targetPath });\n }\n };\n Nestable.prototype.dragRevert = function () {\n var itemsOld = this.state.itemsOld;\n this.setState({\n items: itemsOld,\n itemsOld: null,\n dragItem: null,\n isDirty: false,\n });\n };\n // ––––––––––––––––––––––––––––––––––––\n // Getter methods\n // ––––––––––––––––––––––––––––––––––––\n Nestable.prototype.getPathById = function (id, items) {\n var _this = this;\n if (items === void 0) { items = this.state.items; }\n var _a = this.props, idProp = _a.idProp, childrenProp = _a.childrenProp;\n var path = [];\n items.every(function (item, i) {\n if (item[idProp] === id) {\n path.push(i);\n }\n else if (item[childrenProp]) {\n var childrenPath = _this.getPathById(id, item[childrenProp]);\n if (childrenPath.length) {\n path = path.concat(i).concat(childrenPath);\n }\n }\n return path.length === 0;\n });\n return path;\n };\n Nestable.prototype.getItemByPath = function (path, items) {\n if (items === void 0) { items = this.state.items; }\n var childrenProp = this.props.childrenProp;\n var item = null;\n path.forEach(function (index) {\n var list = item ? item[childrenProp] : items;\n item = list[index];\n });\n return item;\n };\n Nestable.prototype.getSplicePath = function (path, options) {\n if (options === void 0) { options = {}; }\n var splicePath = {};\n var numToRemove = options.numToRemove || 0;\n var itemsToInsert = options.itemsToInsert || [];\n var lastIndex = path.length - 1;\n var currentPath = splicePath;\n path.forEach(function (index, i) {\n var _a;\n if (i === lastIndex) {\n currentPath.$splice = [__spreadArray([index, numToRemove], itemsToInsert, true)];\n }\n else {\n var nextPath = {};\n currentPath[index] = (_a = {}, _a[options.childrenProp] = nextPath, _a);\n currentPath = nextPath;\n }\n });\n return splicePath;\n };\n Nestable.prototype.getRealNextPath = function (prevPath, nextPath, dragItemSize) {\n var _a = this.props, childrenProp = _a.childrenProp, maxDepth = _a.maxDepth;\n var ppLastIndex = prevPath.length - 1;\n var npLastIndex = nextPath.length - 1;\n var newDepth = nextPath.length + dragItemSize - 1;\n if (prevPath.length < nextPath.length) {\n // move into depth\n var wasShifted_1 = false;\n // if new depth exceeds max, try to put after item instead of into item\n if (newDepth > maxDepth && nextPath.length) {\n return this.getRealNextPath(prevPath, nextPath.slice(0, -1), dragItemSize);\n }\n return nextPath.map(function (nextIndex, i) {\n if (wasShifted_1) {\n return i === npLastIndex\n ? nextIndex + 1\n : nextIndex;\n }\n if (typeof prevPath[i] !== 'number') {\n return nextIndex;\n }\n if (nextPath[i] > prevPath[i] && i === ppLastIndex) {\n wasShifted_1 = true;\n return nextIndex - 1;\n }\n return nextIndex;\n });\n }\n else if (prevPath.length === nextPath.length) {\n // if move bottom + move to item with children --> make it a first child instead of swap\n if (nextPath[npLastIndex] > prevPath[npLastIndex]) {\n var target = this.getItemByPath(nextPath);\n if (newDepth < maxDepth &&\n target[childrenProp] &&\n target[childrenProp].length &&\n !this.checkIfCollapsed(target)) {\n return nextPath\n .slice(0, -1)\n .concat(nextPath[npLastIndex] - 1)\n .concat(0);\n }\n }\n }\n return nextPath;\n };\n Nestable.prototype.getItemOptions = function () {\n var _a = this.props, renderItem = _a.renderItem, renderCollapseIcon = _a.renderCollapseIcon, handler = _a.handler, disableCollapse = _a.disableCollapse, disableDrag = _a.disableDrag, idProp = _a.idProp, childrenProp = _a.childrenProp;\n var dragItem = this.state.dragItem;\n return {\n dragItem: dragItem,\n idProp: idProp,\n childrenProp: childrenProp,\n disableCollapse: disableCollapse,\n disableDrag: disableDrag,\n renderItem: renderItem,\n renderCollapseIcon: renderCollapseIcon,\n handler: handler,\n checkIfCollapsed: this.checkIfCollapsed,\n onDragStart: this.onDragStart,\n onMouseEnter: this.onMouseEnter,\n onToggleCollapse: this.onToggleCollapse,\n };\n };\n // ––––––––––––––––––––––––––––––––––––\n // Render methods\n // ––––––––––––––––––––––––––––––––––––\n Nestable.prototype.renderDragLayer = function () {\n var _a = this.props, group = _a.group, idProp = _a.idProp;\n var dragItem = this.state.dragItem;\n var el = document.querySelector(\".nestable-\".concat(group, \" .nestable-item-\").concat(dragItem[idProp]));\n var listStyles = {};\n if (el) {\n listStyles.width = el.clientWidth;\n }\n if (this.elCopyStyles) {\n listStyles = __assign(__assign({}, listStyles), this.elCopyStyles);\n }\n var options = this.getItemOptions();\n return (react_1.default.createElement(\"div\", { className: \"nestable-drag-layer\" },\n react_1.default.createElement(\"ol\", { className: \"nestable-list\", style: listStyles },\n react_1.default.createElement(NestableItem_1.default, { item: dragItem, options: options, isCopy: true }))));\n };\n Nestable.prototype.render = function () {\n var _a = this.props, group = _a.group, className = _a.className, idProp = _a.idProp;\n var _b = this.state, items = _b.items, dragItem = _b.dragItem;\n var options = this.getItemOptions();\n return (react_1.default.createElement(\"div\", { className: (0, classnames_1.default)(className, 'nestable', \"nestable-\".concat(group), { 'is-drag-active': dragItem }) },\n react_1.default.createElement(\"ol\", { className: \"nestable-list\" }, items.map(function (item, i) {\n return (react_1.default.createElement(NestableItem_1.default, { key: item[idProp], index: i, item: item, options: options }));\n })),\n dragItem && this.renderDragLayer()));\n };\n Nestable.defaultProps = {\n childrenProp: 'children',\n collapsed: false,\n confirmChange: function () { return true; },\n disableCollapse: false,\n disableDrag: false,\n group: Math.random().toString(36).slice(2),\n idProp: 'id',\n items: [],\n maxDepth: 10,\n onChange: function () { },\n onCollapseChange: function () { },\n onDragEnd: function () { },\n onDragStart: function () { },\n renderItem: function (_a) {\n var item = _a.item;\n return String(item);\n },\n threshold: 30,\n };\n return Nestable;\n}(react_1.Component));\nexports[\"default\"] = Nestable;\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./src/Nestable/Nestable.tsx","mappings":"AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","sources":["webpack://react-nestable/./src/Nestable/Nestable.tsx?1b20"],"sourcesContent":["\"use strict\";\nvar __extends = (this && this.__extends) || (function () {\n    var extendStatics = function (d, b) {\n        extendStatics = Object.setPrototypeOf ||\n            ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n            function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n        return extendStatics(d, b);\n    };\n    return function (d, b) {\n        if (typeof b !== \"function\" && b !== null)\n            throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n        extendStatics(d, b);\n        function __() { this.constructor = d; }\n        d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n    };\n})();\nvar __assign = (this && this.__assign) || function () {\n    __assign = Object.assign || function(t) {\n        for (var s, i = 1, n = arguments.length; i < n; i++) {\n            s = arguments[i];\n            for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))\n                t[p] = s[p];\n        }\n        return t;\n    };\n    return __assign.apply(this, arguments);\n};\nvar __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {\n    if (k2 === undefined) k2 = k;\n    var desc = Object.getOwnPropertyDescriptor(m, k);\n    if (!desc || (\"get\" in desc ? !m.__esModule : desc.writable || desc.configurable)) {\n      desc = { enumerable: true, get: function() { return m[k]; } };\n    }\n    Object.defineProperty(o, k2, desc);\n}) : (function(o, m, k, k2) {\n    if (k2 === undefined) k2 = k;\n    o[k2] = m[k];\n}));\nvar __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {\n    Object.defineProperty(o, \"default\", { enumerable: true, value: v });\n}) : function(o, v) {\n    o[\"default\"] = v;\n});\nvar __importStar = (this && this.__importStar) || function (mod) {\n    if (mod && mod.__esModule) return mod;\n    var result = {};\n    if (mod != null) for (var k in mod) if (k !== \"default\" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);\n    __setModuleDefault(result, mod);\n    return result;\n};\nvar __spreadArray = (this && this.__spreadArray) || function (to, from, pack) {\n    if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {\n        if (ar || !(i in from)) {\n            if (!ar) ar = Array.prototype.slice.call(from, 0, i);\n            ar[i] = from[i];\n        }\n    }\n    return to.concat(ar || Array.prototype.slice.call(from));\n};\nvar __importDefault = (this && this.__importDefault) || function (mod) {\n    return (mod && mod.__esModule) ? mod : { \"default\": mod };\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\nvar react_1 = __importStar(require(\"react\"));\nvar react_addons_shallow_compare_1 = __importDefault(require(\"react-addons-shallow-compare\"));\nvar react_addons_update_1 = __importDefault(require(\"react-addons-update\"));\nvar classnames_1 = __importDefault(require(\"classnames\"));\nvar utils_1 = require(\"../utils\");\nvar NestableItem_1 = __importDefault(require(\"./NestableItem\"));\nvar Nestable = /** @class */ (function (_super) {\n    __extends(Nestable, _super);\n    function Nestable(props) {\n        var _this = _super.call(this, props) || this;\n        _this.el = null;\n        _this.elCopyStyles = null;\n        _this.mouse = {\n            last: { x: 0 },\n            shift: { x: 0 },\n        };\n        // ––––––––––––––––––––––––––––––––––––\n        // Public Methods\n        // ––––––––––––––––––––––––––––––––––––\n        _this.collapse = function (itemIds) {\n            var _a = _this.props, idProp = _a.idProp, childrenProp = _a.childrenProp, collapsed = _a.collapsed;\n            var items = _this.state.items;\n            if (itemIds === 'NONE') {\n                _this.setState({\n                    collapsedItems: collapsed\n                        ? (0, utils_1.getAllNonEmptyNodesIds)(items, { idProp: idProp, childrenProp: childrenProp })\n                        : [],\n                });\n            }\n            else if (itemIds === 'ALL') {\n                _this.setState({\n                    collapsedItems: collapsed\n                        ? []\n                        : (0, utils_1.getAllNonEmptyNodesIds)(items, { idProp: idProp, childrenProp: childrenProp }),\n                });\n            }\n            else if ((0, utils_1.isArray)(itemIds)) {\n                _this.setState({\n                    collapsedItems: (0, utils_1.getAllNonEmptyNodesIds)(items, { idProp: idProp, childrenProp: childrenProp })\n                        .filter(function (id) { return (itemIds.indexOf(id) > -1) !== collapsed; }),\n                });\n            }\n        };\n        // ––––––––––––––––––––––––––––––––––––\n        // Methods\n        // ––––––––––––––––––––––––––––––––––––\n        _this.startTrackMouse = function () {\n            document.addEventListener('mousemove', _this.onMouseMove);\n            document.addEventListener('mouseup', _this.onDragEnd);\n            document.addEventListener('keydown', _this.onKeyDown);\n        };\n        _this.stopTrackMouse = function () {\n            document.removeEventListener('mousemove', _this.onMouseMove);\n            document.removeEventListener('mouseup', _this.onDragEnd);\n            document.removeEventListener('keydown', _this.onKeyDown);\n            _this.elCopyStyles = null;\n        };\n        _this.getItemDepth = function (item) {\n            var childrenProp = _this.props.childrenProp;\n            var level = 1;\n            if (item[childrenProp].length > 0) {\n                var childrenDepths = item[childrenProp].map(_this.getItemDepth);\n                level += Math.max.apply(Math, childrenDepths);\n            }\n            return level;\n        };\n        _this.checkIfCollapsed = function (item) {\n            var _a = _this.props, collapsed = _a.collapsed, idProp = _a.idProp;\n            var collapsedItems = _this.state.collapsedItems;\n            return !!((collapsedItems.indexOf(item[idProp]) > -1) !== collapsed);\n        };\n        // ––––––––––––––––––––––––––––––––––––\n        // Click handlers or event handlers\n        // ––––––––––––––––––––––––––––––––––––\n        _this.onDragStart = function (e, item) {\n            var onDragStart = _this.props.onDragStart;\n            e.preventDefault();\n            e.stopPropagation();\n            if (!(e.target instanceof Element))\n                return;\n            _this.el = (0, utils_1.closest)(e.target, '.nestable-item');\n            _this.startTrackMouse();\n            _this.onMouseMove(e);\n            onDragStart({ dragItem: item });\n            _this.setState({\n                dragItem: item,\n                itemsOld: _this.state.items,\n            });\n        };\n        _this.onDragEnd = function (e, isCancel) {\n            var onDragEnd = _this.props.onDragEnd;\n            e === null || e === void 0 ? void 0 : e.preventDefault();\n            _this.stopTrackMouse();\n            _this.el = null;\n            onDragEnd();\n            isCancel\n                ? _this.dragRevert()\n                : _this.dragApply();\n        };\n        _this.onMouseMove = function (e) {\n            var _a = _this.props, group = _a.group, threshold = _a.threshold;\n            var dragItem = _this.state.dragItem;\n            var clientX = e.clientX, clientY = e.clientY;\n            var transformProps = (0, utils_1.getTransformProps)(clientX, clientY);\n            var elCopy = document.querySelector(\".nestable-\".concat(group, \" .nestable-drag-layer > .nestable-list\"));\n            if (!_this.elCopyStyles) {\n                var offset = (0, utils_1.getOffsetRect)(_this.el);\n                var scroll_1 = (0, utils_1.getTotalScroll)(_this.el);\n                _this.elCopyStyles = __assign({ marginTop: offset.top - clientY - scroll_1.top, marginLeft: offset.left - clientX - scroll_1.left }, transformProps);\n            }\n            else {\n                _this.elCopyStyles = __assign(__assign({}, _this.elCopyStyles), transformProps);\n                Object.keys(transformProps).forEach(function (key) {\n                    elCopy.style[key] = transformProps[key];\n                });\n                var diffX = clientX - _this.mouse.last.x;\n                if ((diffX >= 0 && _this.mouse.shift.x >= 0) ||\n                    (diffX <= 0 && _this.mouse.shift.x <= 0)) {\n                    _this.mouse.shift.x += diffX;\n                }\n                else {\n                    _this.mouse.shift.x = 0;\n                }\n                _this.mouse.last.x = clientX;\n                if (Math.abs(_this.mouse.shift.x) > threshold) {\n                    if (_this.mouse.shift.x > 0) {\n                        _this.tryIncreaseDepth(dragItem);\n                    }\n                    else {\n                        _this.tryDecreaseDepth(dragItem);\n                    }\n                    _this.mouse.shift.x = 0;\n                }\n            }\n        };\n        _this.onMouseEnter = function (e, item) {\n            e.preventDefault();\n            e.stopPropagation();\n            var _a = _this.props, collapsed = _a.collapsed, idProp = _a.idProp, childrenProp = _a.childrenProp;\n            var dragItem = _this.state.dragItem;\n            if (dragItem[idProp] === item[idProp])\n                return;\n            var pathFrom = _this.getPathById(dragItem[idProp]);\n            var pathTo = _this.getPathById(item[idProp]);\n            // if collapsed by default\n            // and move out the only child\n            // remove parent node from list of open nodes\n            var collapseProps = {};\n            if (collapsed && pathFrom.length > 1) {\n                var parent_1 = _this.getItemByPath(pathFrom.slice(0, -1));\n                if (parent_1[childrenProp].length === 1) {\n                    collapseProps = _this.onToggleCollapse(parent_1, true);\n                }\n            }\n            _this.moveItem({ dragItem: dragItem, pathFrom: pathFrom, pathTo: pathTo }, collapseProps);\n        };\n        _this.onToggleCollapse = function (item, isGetter) {\n            var _a = _this.props, collapsed = _a.collapsed, idProp = _a.idProp;\n            var collapsedItems = _this.state.collapsedItems;\n            var isCollapsed = _this.checkIfCollapsed(item);\n            var newState = {\n                collapsedItems: (isCollapsed !== collapsed)\n                    ? collapsedItems.filter(function (id) { return id !== item[idProp]; })\n                    : collapsedItems.concat(item[idProp]),\n            };\n            if (isGetter) {\n                return newState;\n            }\n            else {\n                _this.setState(newState);\n                _this.onCollapseChange(newState.collapsedItems);\n            }\n        };\n        _this.onCollapseChange = function (ids) {\n            var _a = _this.props, collapsed = _a.collapsed, onCollapseChange = _a.onCollapseChange;\n            onCollapseChange(collapsed ? { openIds: ids } : { closedIds: ids });\n        };\n        _this.onKeyDown = function (e) {\n            if (e.which === 27) {\n                // ESC\n                _this.onDragEnd(null, true);\n            }\n        };\n        _this.state = {\n            items: [],\n            itemsOld: null,\n            dragItem: null,\n            isDirty: false,\n            collapsedItems: [],\n        };\n        return _this;\n    }\n    Nestable.prototype.componentDidMount = function () {\n        var _a = this.props, items = _a.items, childrenProp = _a.childrenProp;\n        // make sure every item has property 'children'\n        items = (0, utils_1.listWithChildren)(items, childrenProp);\n        this.setState({ items: items });\n    };\n    Nestable.prototype.componentDidUpdate = function (prevProps) {\n        var _this = this;\n        var _a = this, _b = _a.props, itemsNew = _b.items, childrenProp = _b.childrenProp, state = _a.state;\n        var isPropsChanged = (0, react_addons_shallow_compare_1.default)(__assign(__assign({}, this), { props: prevProps, state: state }), this.props, state);\n        if (isPropsChanged) {\n            this.stopTrackMouse();\n            this.setState(function (prevState) {\n                var newState = __assign(__assign({}, prevState), { items: (0, utils_1.listWithChildren)(itemsNew, childrenProp), dragItem: null, isDirty: false });\n                if (prevProps.collapsed !== _this.props.collapsed) {\n                    newState.collapsedItems = [];\n                    _this.onCollapseChange(newState.collapsedItems);\n                }\n                return newState;\n            });\n        }\n    };\n    Nestable.prototype.componentWillUnmount = function () {\n        this.stopTrackMouse();\n    };\n    Nestable.prototype.moveItem = function (_a, extraProps) {\n        var dragItem = _a.dragItem, pathFrom = _a.pathFrom, pathTo = _a.pathTo;\n        if (extraProps === void 0) { extraProps = {}; }\n        var _b = this.props, childrenProp = _b.childrenProp, confirmChange = _b.confirmChange;\n        var dragItemSize = this.getItemDepth(dragItem);\n        var items = this.state.items;\n        // the remove action might affect the next position,\n        // so update next coordinates accordingly\n        var realPathTo = this.getRealNextPath(pathFrom, pathTo, dragItemSize);\n        if (realPathTo.length === 0)\n            return;\n        // user can validate every movement\n        var destinationPath = realPathTo.length > pathTo.length\n            ? pathTo\n            : pathTo.slice(0, -1);\n        var destinationParent = this.getItemByPath(destinationPath);\n        if (!confirmChange({ dragItem: dragItem, destinationParent: destinationParent }))\n            return;\n        var removePath = this.getSplicePath(pathFrom, {\n            numToRemove: 1,\n            childrenProp: childrenProp,\n        });\n        var insertPath = this.getSplicePath(realPathTo, {\n            numToRemove: 0,\n            itemsToInsert: [dragItem],\n            childrenProp: childrenProp,\n        });\n        items = (0, react_addons_update_1.default)(items, removePath);\n        items = (0, react_addons_update_1.default)(items, insertPath);\n        this.setState(function (prevState) { return (__assign(__assign(__assign({}, prevState), { items: items, isDirty: true }), extraProps)); });\n        if (extraProps.collapsedItems !== this.state.collapsedItems) {\n            this.onCollapseChange(extraProps.collapsedItems);\n        }\n    };\n    Nestable.prototype.tryIncreaseDepth = function (dragItem) {\n        var _a = this.props, maxDepth = _a.maxDepth, idProp = _a.idProp, childrenProp = _a.childrenProp, collapsed = _a.collapsed;\n        var pathFrom = this.getPathById(dragItem[idProp]);\n        var itemIndex = pathFrom[pathFrom.length - 1];\n        var newDepth = pathFrom.length + this.getItemDepth(dragItem);\n        // has previous sibling and isn't at max depth\n        if (itemIndex > 0 && newDepth <= maxDepth) {\n            var prevSibling = this.getItemByPath(pathFrom.slice(0, -1).concat(itemIndex - 1));\n            // previous sibling is not collapsed\n            if (!prevSibling[childrenProp].length || !this.checkIfCollapsed(prevSibling)) {\n                var pathTo = pathFrom\n                    .slice(0, -1)\n                    .concat(itemIndex - 1)\n                    .concat(prevSibling[childrenProp].length);\n                // if collapsed by default\n                // and was no children here\n                // open this node\n                var collapseProps = {};\n                if (collapsed && !prevSibling[childrenProp].length) {\n                    collapseProps = this.onToggleCollapse(prevSibling, true);\n                }\n                this.moveItem({ dragItem: dragItem, pathFrom: pathFrom, pathTo: pathTo }, collapseProps);\n            }\n        }\n    };\n    Nestable.prototype.tryDecreaseDepth = function (dragItem) {\n        var _a = this.props, idProp = _a.idProp, childrenProp = _a.childrenProp, collapsed = _a.collapsed;\n        var pathFrom = this.getPathById(dragItem[idProp]);\n        var itemIndex = pathFrom[pathFrom.length - 1];\n        // has parent\n        if (pathFrom.length > 1) {\n            var parent_2 = this.getItemByPath(pathFrom.slice(0, -1));\n            // is last (by order) item in array\n            if (itemIndex + 1 === parent_2[childrenProp].length) {\n                var pathTo = pathFrom.slice(0, -1);\n                pathTo[pathTo.length - 1] += 1;\n                // if collapsed by default\n                // and is last (by count) item in array\n                // remove this node from list of open nodes\n                var collapseProps = {};\n                if (collapsed && parent_2[childrenProp].length === 1) {\n                    collapseProps = this.onToggleCollapse(parent_2, true);\n                }\n                this.moveItem({ dragItem: dragItem, pathFrom: pathFrom, pathTo: pathTo }, collapseProps);\n            }\n        }\n    };\n    Nestable.prototype.dragApply = function () {\n        var _a = this.props, onChange = _a.onChange, idProp = _a.idProp;\n        var _b = this.state, items = _b.items, isDirty = _b.isDirty, dragItem = _b.dragItem;\n        this.setState({\n            itemsOld: null,\n            dragItem: null,\n            isDirty: false,\n        });\n        if (onChange && isDirty) {\n            var targetPath = this.getPathById(dragItem[idProp], items);\n            onChange({ items: items, dragItem: dragItem, targetPath: targetPath });\n        }\n    };\n    Nestable.prototype.dragRevert = function () {\n        var itemsOld = this.state.itemsOld;\n        this.setState({\n            items: itemsOld,\n            itemsOld: null,\n            dragItem: null,\n            isDirty: false,\n        });\n    };\n    // ––––––––––––––––––––––––––––––––––––\n    // Getter methods\n    // ––––––––––––––––––––––––––––––––––––\n    Nestable.prototype.getPathById = function (id, items) {\n        var _this = this;\n        if (items === void 0) { items = this.state.items; }\n        var _a = this.props, idProp = _a.idProp, childrenProp = _a.childrenProp;\n        var path = [];\n        items.every(function (item, i) {\n            if (item[idProp] === id) {\n                path.push(i);\n            }\n            else if (item[childrenProp]) {\n                var childrenPath = _this.getPathById(id, item[childrenProp]);\n                if (childrenPath.length) {\n                    path = path.concat(i).concat(childrenPath);\n                }\n            }\n            return path.length === 0;\n        });\n        return path;\n    };\n    Nestable.prototype.getItemByPath = function (path, items) {\n        if (items === void 0) { items = this.state.items; }\n        var childrenProp = this.props.childrenProp;\n        var item = null;\n        path.forEach(function (index) {\n            var list = item ? item[childrenProp] : items;\n            item = list[index];\n        });\n        return item;\n    };\n    Nestable.prototype.getSplicePath = function (path, options) {\n        if (options === void 0) { options = {}; }\n        var splicePath = {};\n        var numToRemove = options.numToRemove || 0;\n        var itemsToInsert = options.itemsToInsert || [];\n        var lastIndex = path.length - 1;\n        var currentPath = splicePath;\n        path.forEach(function (index, i) {\n            var _a;\n            if (i === lastIndex) {\n                currentPath.$splice = [__spreadArray([index, numToRemove], itemsToInsert, true)];\n            }\n            else {\n                var nextPath = {};\n                currentPath[index] = (_a = {}, _a[options.childrenProp] = nextPath, _a);\n                currentPath = nextPath;\n            }\n        });\n        return splicePath;\n    };\n    Nestable.prototype.getRealNextPath = function (prevPath, nextPath, dragItemSize) {\n        var _a = this.props, childrenProp = _a.childrenProp, maxDepth = _a.maxDepth;\n        var ppLastIndex = prevPath.length - 1;\n        var npLastIndex = nextPath.length - 1;\n        var newDepth = nextPath.length + dragItemSize - 1;\n        if (prevPath.length < nextPath.length) {\n            // move into depth\n            var wasShifted_1 = false;\n            // if new depth exceeds max, try to put after item instead of into item\n            if (newDepth > maxDepth && nextPath.length) {\n                return this.getRealNextPath(prevPath, nextPath.slice(0, -1), dragItemSize);\n            }\n            return nextPath.map(function (nextIndex, i) {\n                if (wasShifted_1) {\n                    return i === npLastIndex\n                        ? nextIndex + 1\n                        : nextIndex;\n                }\n                if (typeof prevPath[i] !== 'number') {\n                    return nextIndex;\n                }\n                if (nextPath[i] > prevPath[i] && i === ppLastIndex) {\n                    wasShifted_1 = true;\n                    return nextIndex - 1;\n                }\n                return nextIndex;\n            });\n        }\n        else if (prevPath.length === nextPath.length) {\n            // if move bottom + move to item with children --> make it a first child instead of swap\n            if (nextPath[npLastIndex] > prevPath[npLastIndex]) {\n                var target = this.getItemByPath(nextPath);\n                if (newDepth < maxDepth &&\n                    target[childrenProp] &&\n                    target[childrenProp].length &&\n                    !this.checkIfCollapsed(target)) {\n                    return nextPath\n                        .slice(0, -1)\n                        .concat(nextPath[npLastIndex] - 1)\n                        .concat(0);\n                }\n            }\n        }\n        return nextPath;\n    };\n    Nestable.prototype.getItemOptions = function () {\n        var _a = this.props, renderItem = _a.renderItem, renderCollapseIcon = _a.renderCollapseIcon, handler = _a.handler, disableCollapse = _a.disableCollapse, disableDrag = _a.disableDrag, idProp = _a.idProp, childrenProp = _a.childrenProp;\n        var dragItem = this.state.dragItem;\n        return {\n            dragItem: dragItem,\n            idProp: idProp,\n            childrenProp: childrenProp,\n            disableCollapse: disableCollapse,\n            disableDrag: disableDrag,\n            renderItem: renderItem,\n            renderCollapseIcon: renderCollapseIcon,\n            handler: handler,\n            checkIfCollapsed: this.checkIfCollapsed,\n            onDragStart: this.onDragStart,\n            onMouseEnter: this.onMouseEnter,\n            onToggleCollapse: this.onToggleCollapse,\n        };\n    };\n    // ––––––––––––––––––––––––––––––––––––\n    // Render methods\n    // ––––––––––––––––––––––––––––––––––––\n    Nestable.prototype.renderDragLayer = function () {\n        var _a = this.props, group = _a.group, idProp = _a.idProp;\n        var dragItem = this.state.dragItem;\n        var el = document.querySelector(\".nestable-\".concat(group, \" .nestable-item-\").concat(dragItem[idProp]));\n        var listStyles = {};\n        if (el) {\n            listStyles.width = el.clientWidth;\n        }\n        if (this.elCopyStyles) {\n            listStyles = __assign(__assign({}, listStyles), this.elCopyStyles);\n        }\n        var options = this.getItemOptions();\n        return (react_1.default.createElement(\"div\", { className: \"nestable-drag-layer\" },\n            react_1.default.createElement(\"ol\", { className: \"nestable-list\", style: listStyles },\n                react_1.default.createElement(NestableItem_1.default, { item: dragItem, options: options, isCopy: true }))));\n    };\n    Nestable.prototype.render = function () {\n        var _a = this.props, group = _a.group, className = _a.className, idProp = _a.idProp;\n        var _b = this.state, items = _b.items, dragItem = _b.dragItem;\n        var options = this.getItemOptions();\n        return (react_1.default.createElement(\"div\", { className: (0, classnames_1.default)(className, 'nestable', \"nestable-\".concat(group), { 'is-drag-active': dragItem }) },\n            react_1.default.createElement(\"ol\", { className: \"nestable-list\" }, items.map(function (item, i) {\n                return (react_1.default.createElement(NestableItem_1.default, { key: item[idProp], index: i, item: item, options: options }));\n            })),\n            dragItem && this.renderDragLayer()));\n    };\n    Nestable.defaultProps = {\n        childrenProp: 'children',\n        collapsed: false,\n        confirmChange: function () { return true; },\n        disableCollapse: false,\n        disableDrag: false,\n        group: Math.random().toString(36).slice(2),\n        idProp: 'id',\n        items: [],\n        maxDepth: 10,\n        onChange: function () { },\n        onCollapseChange: function () { },\n        onDragEnd: function () { },\n        onDragStart: function () { },\n        renderItem: function (_a) {\n            var item = _a.item;\n            return String(item);\n        },\n        threshold: 30,\n    };\n    return Nestable;\n}(react_1.Component));\nexports.default = Nestable;\n"],"names":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///./src/Nestable/Nestable.tsx\n"); +eval("\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __assign = (this && this.__assign) || function () {\n __assign = Object.assign || function(t) {\n for (var s, i = 1, n = arguments.length; i < n; i++) {\n s = arguments[i];\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))\n t[p] = s[p];\n }\n return t;\n };\n return __assign.apply(this, arguments);\n};\nvar __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n var desc = Object.getOwnPropertyDescriptor(m, k);\n if (!desc || (\"get\" in desc ? !m.__esModule : desc.writable || desc.configurable)) {\n desc = { enumerable: true, get: function() { return m[k]; } };\n }\n Object.defineProperty(o, k2, desc);\n}) : (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n o[k2] = m[k];\n}));\nvar __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {\n Object.defineProperty(o, \"default\", { enumerable: true, value: v });\n}) : function(o, v) {\n o[\"default\"] = v;\n});\nvar __importStar = (this && this.__importStar) || function (mod) {\n if (mod && mod.__esModule) return mod;\n var result = {};\n if (mod != null) for (var k in mod) if (k !== \"default\" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);\n __setModuleDefault(result, mod);\n return result;\n};\nvar __spreadArray = (this && this.__spreadArray) || function (to, from, pack) {\n if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {\n if (ar || !(i in from)) {\n if (!ar) ar = Array.prototype.slice.call(from, 0, i);\n ar[i] = from[i];\n }\n }\n return to.concat(ar || Array.prototype.slice.call(from));\n};\nvar __importDefault = (this && this.__importDefault) || function (mod) {\n return (mod && mod.__esModule) ? mod : { \"default\": mod };\n};\nObject.defineProperty(exports, \"__esModule\", ({ value: true }));\nvar react_1 = __importStar(__webpack_require__(/*! react */ \"./node_modules/react/index.js\"));\nvar react_addons_shallow_compare_1 = __importDefault(__webpack_require__(/*! react-addons-shallow-compare */ \"./node_modules/react-addons-shallow-compare/index.js\"));\nvar react_addons_update_1 = __importDefault(__webpack_require__(/*! react-addons-update */ \"./node_modules/react-addons-update/index.js\"));\nvar classnames_1 = __importDefault(__webpack_require__(/*! classnames */ \"./node_modules/classnames/index.js\"));\nvar utils_1 = __webpack_require__(/*! ../utils */ \"./src/utils.ts\");\nvar NestableItem_1 = __importDefault(__webpack_require__(/*! ./NestableItem */ \"./src/Nestable/NestableItem.tsx\"));\nvar Nestable = /** @class */ (function (_super) {\n __extends(Nestable, _super);\n function Nestable(props) {\n var _this = _super.call(this, props) || this;\n _this.el = null;\n _this.elCopyStyles = null;\n _this.mouse = {\n last: { x: 0 },\n shift: { x: 0 },\n };\n // ––––––––––––––––––––––––––––––––––––\n // Public Methods\n // ––––––––––––––––––––––––––––––––––––\n _this.collapse = function (itemIds) {\n var _a = _this.props, idProp = _a.idProp, childrenProp = _a.childrenProp, collapsed = _a.collapsed;\n var items = _this.state.items;\n if (itemIds === 'NONE') {\n _this.setState({\n collapsedItems: collapsed\n ? (0, utils_1.getAllNonEmptyNodesIds)(items, { idProp: idProp, childrenProp: childrenProp })\n : [],\n });\n }\n else if (itemIds === 'ALL') {\n _this.setState({\n collapsedItems: collapsed\n ? []\n : (0, utils_1.getAllNonEmptyNodesIds)(items, { idProp: idProp, childrenProp: childrenProp }),\n });\n }\n else if ((0, utils_1.isArray)(itemIds)) {\n _this.setState({\n collapsedItems: (0, utils_1.getAllNonEmptyNodesIds)(items, { idProp: idProp, childrenProp: childrenProp })\n .filter(function (id) { return (itemIds.indexOf(id) > -1) !== collapsed; }),\n });\n }\n };\n // ––––––––––––––––––––––––––––––––––––\n // Methods\n // ––––––––––––––––––––––––––––––––––––\n _this.startTrackMouse = function () {\n document.addEventListener('mousemove', _this.onMouseMove);\n document.addEventListener('mouseup', _this.onDragEnd);\n document.addEventListener('keydown', _this.onKeyDown);\n };\n _this.stopTrackMouse = function () {\n document.removeEventListener('mousemove', _this.onMouseMove);\n document.removeEventListener('mouseup', _this.onDragEnd);\n document.removeEventListener('keydown', _this.onKeyDown);\n _this.elCopyStyles = null;\n };\n _this.getItemDepth = function (item) {\n var childrenProp = _this.props.childrenProp;\n var level = 1;\n if (item[childrenProp].length > 0) {\n var childrenDepths = item[childrenProp].map(_this.getItemDepth);\n level += Math.max.apply(Math, childrenDepths);\n }\n return level;\n };\n _this.checkIfCollapsed = function (item) {\n var _a = _this.props, collapsed = _a.collapsed, idProp = _a.idProp;\n var collapsedItems = _this.state.collapsedItems;\n return !!((collapsedItems.indexOf(item[idProp]) > -1) !== collapsed);\n };\n // ––––––––––––––––––––––––––––––––––––\n // Click handlers or event handlers\n // ––––––––––––––––––––––––––––––––––––\n _this.onDragStart = function (e, item) {\n var onDragStart = _this.props.onDragStart;\n e.preventDefault();\n e.stopPropagation();\n if (!(e.target instanceof Element))\n return;\n _this.el = (0, utils_1.closest)(e.target, '.nestable-item');\n _this.startTrackMouse();\n _this.onMouseMove(e);\n onDragStart({ dragItem: item });\n _this.setState({\n dragItem: item,\n itemsOld: _this.state.items,\n });\n };\n _this.onDragEnd = function (e, isCancel) {\n var onDragEnd = _this.props.onDragEnd;\n e === null || e === void 0 ? void 0 : e.preventDefault();\n _this.stopTrackMouse();\n _this.el = null;\n onDragEnd();\n isCancel\n ? _this.dragRevert()\n : _this.dragApply();\n };\n _this.onMouseMove = function (e) {\n var _a = _this.props, group = _a.group, threshold = _a.threshold;\n var dragItem = _this.state.dragItem;\n var clientX = e.clientX, clientY = e.clientY;\n var transformProps = (0, utils_1.getTransformProps)(clientX, clientY);\n var elCopy = document.querySelector(\".nestable-\".concat(group, \" .nestable-drag-layer > .nestable-list\"));\n if (!_this.elCopyStyles) {\n var offset = (0, utils_1.getOffsetRect)(_this.el);\n var scroll_1 = (0, utils_1.getTotalScroll)(_this.el);\n _this.elCopyStyles = __assign({ marginTop: offset.top - clientY - scroll_1.top, marginLeft: offset.left - clientX - scroll_1.left }, transformProps);\n }\n else {\n _this.elCopyStyles = __assign(__assign({}, _this.elCopyStyles), transformProps);\n Object.keys(transformProps).forEach(function (key) {\n elCopy.style[key] = transformProps[key];\n });\n var diffX = clientX - _this.mouse.last.x;\n if ((diffX >= 0 && _this.mouse.shift.x >= 0) ||\n (diffX <= 0 && _this.mouse.shift.x <= 0)) {\n _this.mouse.shift.x += diffX;\n }\n else {\n _this.mouse.shift.x = 0;\n }\n _this.mouse.last.x = clientX;\n if (Math.abs(_this.mouse.shift.x) > threshold) {\n if (_this.mouse.shift.x > 0) {\n _this.tryIncreaseDepth(dragItem);\n }\n else {\n _this.tryDecreaseDepth(dragItem);\n }\n _this.mouse.shift.x = 0;\n }\n }\n };\n _this.onMouseEnter = function (e, item) {\n e.preventDefault();\n e.stopPropagation();\n var _a = _this.props, collapsed = _a.collapsed, idProp = _a.idProp, childrenProp = _a.childrenProp;\n var dragItem = _this.state.dragItem;\n if (dragItem[idProp] === item[idProp])\n return;\n var pathFrom = _this.getPathById(dragItem[idProp]);\n var pathTo = _this.getPathById(item[idProp]);\n // if collapsed by default\n // and move out the only child\n // remove parent node from list of open nodes\n var collapseProps = {};\n if (collapsed && pathFrom.length > 1) {\n var parent_1 = _this.getItemByPath(pathFrom.slice(0, -1));\n if (parent_1[childrenProp].length === 1) {\n collapseProps = _this.onToggleCollapse(parent_1, true);\n }\n }\n _this.moveItem({ dragItem: dragItem, pathFrom: pathFrom, pathTo: pathTo }, collapseProps);\n };\n _this.onToggleCollapse = function (item, isGetter) {\n var _a = _this.props, collapsed = _a.collapsed, idProp = _a.idProp;\n var collapsedItems = _this.state.collapsedItems;\n var isCollapsed = _this.checkIfCollapsed(item);\n var newState = {\n collapsedItems: (isCollapsed !== collapsed)\n ? collapsedItems.filter(function (id) { return id !== item[idProp]; })\n : collapsedItems.concat(item[idProp]),\n };\n if (isGetter) {\n return newState;\n }\n else {\n _this.setState(newState);\n _this.onCollapseChange(newState.collapsedItems);\n }\n };\n _this.onCollapseChange = function (ids) {\n var _a = _this.props, collapsed = _a.collapsed, onCollapseChange = _a.onCollapseChange;\n onCollapseChange(collapsed ? { openIds: ids } : { closedIds: ids });\n };\n _this.onKeyDown = function (e) {\n if (e.which === 27) {\n // ESC\n _this.onDragEnd(null, true);\n }\n };\n _this.state = {\n items: [],\n itemsOld: null,\n dragItem: null,\n isDirty: false,\n collapsedItems: [],\n };\n return _this;\n }\n Nestable.prototype.componentDidMount = function () {\n var _a = this.props, items = _a.items, childrenProp = _a.childrenProp;\n // make sure every item has property 'children'\n items = (0, utils_1.listWithChildren)(items, childrenProp);\n this.setState({ items: items });\n };\n Nestable.prototype.componentDidUpdate = function (prevProps) {\n var _this = this;\n var _a = this, _b = _a.props, itemsNew = _b.items, childrenProp = _b.childrenProp, state = _a.state;\n var isPropsChanged = (0, react_addons_shallow_compare_1.default)(__assign(__assign({}, this), { props: prevProps, state: state }), this.props, state);\n if (isPropsChanged) {\n this.stopTrackMouse();\n this.setState(function (prevState) {\n var newState = __assign(__assign({}, prevState), { items: (0, utils_1.listWithChildren)(itemsNew, childrenProp), dragItem: null, isDirty: false });\n if (prevProps.collapsed !== _this.props.collapsed) {\n newState.collapsedItems = [];\n _this.onCollapseChange(newState.collapsedItems);\n }\n return newState;\n });\n }\n };\n Nestable.prototype.componentWillUnmount = function () {\n this.stopTrackMouse();\n };\n Nestable.prototype.moveItem = function (_a, extraProps) {\n var dragItem = _a.dragItem, pathFrom = _a.pathFrom, pathTo = _a.pathTo;\n if (extraProps === void 0) { extraProps = {}; }\n var _b = this.props, childrenProp = _b.childrenProp, confirmChange = _b.confirmChange;\n var dragItemSize = this.getItemDepth(dragItem);\n var items = this.state.items;\n // the remove action might affect the next position,\n // so update next coordinates accordingly\n var realPathTo = this.getRealNextPath(pathFrom, pathTo, dragItemSize);\n if (realPathTo.length === 0)\n return;\n // user can validate every movement\n var destinationPath = realPathTo.length > pathTo.length\n ? pathTo\n : pathTo.slice(0, -1);\n var destinationParent = this.getItemByPath(destinationPath);\n var removePath = this.getSplicePath(pathFrom, {\n numToRemove: 1,\n childrenProp: childrenProp,\n });\n var insertPath = this.getSplicePath(realPathTo, {\n numToRemove: 0,\n itemsToInsert: [dragItem],\n childrenProp: childrenProp,\n });\n items = (0, react_addons_update_1.default)(items, removePath);\n items = (0, react_addons_update_1.default)(items, insertPath);\n if (!confirmChange({ dragItem: dragItem, destinationParent: destinationParent, items: items }))\n return;\n this.setState(function (prevState) { return (__assign(__assign(__assign({}, prevState), { items: items, isDirty: true }), extraProps)); });\n if (extraProps.collapsedItems !== this.state.collapsedItems) {\n this.onCollapseChange(extraProps.collapsedItems);\n }\n };\n Nestable.prototype.tryIncreaseDepth = function (dragItem) {\n var _a = this.props, maxDepth = _a.maxDepth, idProp = _a.idProp, childrenProp = _a.childrenProp, collapsed = _a.collapsed;\n var pathFrom = this.getPathById(dragItem[idProp]);\n var itemIndex = pathFrom[pathFrom.length - 1];\n var newDepth = pathFrom.length + this.getItemDepth(dragItem);\n // has previous sibling and isn't at max depth\n if (itemIndex > 0 && newDepth <= maxDepth) {\n var prevSibling = this.getItemByPath(pathFrom.slice(0, -1).concat(itemIndex - 1));\n // previous sibling is not collapsed\n if (!prevSibling[childrenProp].length || !this.checkIfCollapsed(prevSibling)) {\n var pathTo = pathFrom\n .slice(0, -1)\n .concat(itemIndex - 1)\n .concat(prevSibling[childrenProp].length);\n // if collapsed by default\n // and was no children here\n // open this node\n var collapseProps = {};\n if (collapsed && !prevSibling[childrenProp].length) {\n collapseProps = this.onToggleCollapse(prevSibling, true);\n }\n this.moveItem({ dragItem: dragItem, pathFrom: pathFrom, pathTo: pathTo }, collapseProps);\n }\n }\n };\n Nestable.prototype.tryDecreaseDepth = function (dragItem) {\n var _a = this.props, idProp = _a.idProp, childrenProp = _a.childrenProp, collapsed = _a.collapsed;\n var pathFrom = this.getPathById(dragItem[idProp]);\n var itemIndex = pathFrom[pathFrom.length - 1];\n // has parent\n if (pathFrom.length > 1) {\n var parent_2 = this.getItemByPath(pathFrom.slice(0, -1));\n // is last (by order) item in array\n if (itemIndex + 1 === parent_2[childrenProp].length) {\n var pathTo = pathFrom.slice(0, -1);\n pathTo[pathTo.length - 1] += 1;\n // if collapsed by default\n // and is last (by count) item in array\n // remove this node from list of open nodes\n var collapseProps = {};\n if (collapsed && parent_2[childrenProp].length === 1) {\n collapseProps = this.onToggleCollapse(parent_2, true);\n }\n this.moveItem({ dragItem: dragItem, pathFrom: pathFrom, pathTo: pathTo }, collapseProps);\n }\n }\n };\n Nestable.prototype.dragApply = function () {\n var _a = this.props, onChange = _a.onChange, idProp = _a.idProp;\n var _b = this.state, items = _b.items, isDirty = _b.isDirty, dragItem = _b.dragItem;\n this.setState({\n itemsOld: null,\n dragItem: null,\n isDirty: false,\n });\n if (onChange && isDirty) {\n var targetPath = this.getPathById(dragItem[idProp], items);\n onChange({ items: items, dragItem: dragItem, targetPath: targetPath });\n }\n };\n Nestable.prototype.dragRevert = function () {\n var itemsOld = this.state.itemsOld;\n this.setState({\n items: itemsOld,\n itemsOld: null,\n dragItem: null,\n isDirty: false,\n });\n };\n // ––––––––––––––––––––––––––––––––––––\n // Getter methods\n // ––––––––––––––––––––––––––––––––––––\n Nestable.prototype.getPathById = function (id, items) {\n var _this = this;\n if (items === void 0) { items = this.state.items; }\n var _a = this.props, idProp = _a.idProp, childrenProp = _a.childrenProp;\n var path = [];\n items.every(function (item, i) {\n if (item[idProp] === id) {\n path.push(i);\n }\n else if (item[childrenProp]) {\n var childrenPath = _this.getPathById(id, item[childrenProp]);\n if (childrenPath.length) {\n path = path.concat(i).concat(childrenPath);\n }\n }\n return path.length === 0;\n });\n return path;\n };\n Nestable.prototype.getItemByPath = function (path, items) {\n if (items === void 0) { items = this.state.items; }\n var childrenProp = this.props.childrenProp;\n var item = null;\n path.forEach(function (index) {\n var list = item ? item[childrenProp] : items;\n item = list[index];\n });\n return item;\n };\n Nestable.prototype.getSplicePath = function (path, options) {\n if (options === void 0) { options = {}; }\n var splicePath = {};\n var numToRemove = options.numToRemove || 0;\n var itemsToInsert = options.itemsToInsert || [];\n var lastIndex = path.length - 1;\n var currentPath = splicePath;\n path.forEach(function (index, i) {\n var _a;\n if (i === lastIndex) {\n currentPath.$splice = [__spreadArray([index, numToRemove], itemsToInsert, true)];\n }\n else {\n var nextPath = {};\n currentPath[index] = (_a = {}, _a[options.childrenProp] = nextPath, _a);\n currentPath = nextPath;\n }\n });\n return splicePath;\n };\n Nestable.prototype.getRealNextPath = function (prevPath, nextPath, dragItemSize) {\n var _a = this.props, childrenProp = _a.childrenProp, maxDepth = _a.maxDepth;\n var ppLastIndex = prevPath.length - 1;\n var npLastIndex = nextPath.length - 1;\n var newDepth = nextPath.length + dragItemSize - 1;\n if (prevPath.length < nextPath.length) {\n // move into depth\n var wasShifted_1 = false;\n // if new depth exceeds max, try to put after item instead of into item\n if (newDepth > maxDepth && nextPath.length) {\n return this.getRealNextPath(prevPath, nextPath.slice(0, -1), dragItemSize);\n }\n return nextPath.map(function (nextIndex, i) {\n if (wasShifted_1) {\n return i === npLastIndex\n ? nextIndex + 1\n : nextIndex;\n }\n if (typeof prevPath[i] !== 'number') {\n return nextIndex;\n }\n if (nextPath[i] > prevPath[i] && i === ppLastIndex) {\n wasShifted_1 = true;\n return nextIndex - 1;\n }\n return nextIndex;\n });\n }\n else if (prevPath.length === nextPath.length) {\n // if move bottom + move to item with children --> make it a first child instead of swap\n if (nextPath[npLastIndex] > prevPath[npLastIndex]) {\n var target = this.getItemByPath(nextPath);\n if (newDepth < maxDepth &&\n target[childrenProp] &&\n target[childrenProp].length &&\n !this.checkIfCollapsed(target)) {\n return nextPath\n .slice(0, -1)\n .concat(nextPath[npLastIndex] - 1)\n .concat(0);\n }\n }\n }\n return nextPath;\n };\n Nestable.prototype.getItemOptions = function () {\n var _a = this.props, renderItem = _a.renderItem, renderCollapseIcon = _a.renderCollapseIcon, handler = _a.handler, disableCollapse = _a.disableCollapse, disableDrag = _a.disableDrag, idProp = _a.idProp, childrenProp = _a.childrenProp;\n var dragItem = this.state.dragItem;\n return {\n dragItem: dragItem,\n idProp: idProp,\n childrenProp: childrenProp,\n disableCollapse: disableCollapse,\n disableDrag: disableDrag,\n renderItem: renderItem,\n renderCollapseIcon: renderCollapseIcon,\n handler: handler,\n checkIfCollapsed: this.checkIfCollapsed,\n onDragStart: this.onDragStart,\n onMouseEnter: this.onMouseEnter,\n onToggleCollapse: this.onToggleCollapse,\n };\n };\n // ––––––––––––––––––––––––––––––––––––\n // Render methods\n // ––––––––––––––––––––––––––––––––––––\n Nestable.prototype.renderDragLayer = function () {\n var _a = this.props, group = _a.group, idProp = _a.idProp;\n var dragItem = this.state.dragItem;\n var el = document.querySelector(\".nestable-\".concat(group, \" .nestable-item-\").concat(dragItem[idProp]));\n var listStyles = {};\n if (el) {\n listStyles.width = el.clientWidth;\n }\n if (this.elCopyStyles) {\n listStyles = __assign(__assign({}, listStyles), this.elCopyStyles);\n }\n var options = this.getItemOptions();\n return (react_1.default.createElement(\"div\", { className: \"nestable-drag-layer\" },\n react_1.default.createElement(\"ol\", { className: \"nestable-list\", style: listStyles },\n react_1.default.createElement(NestableItem_1.default, { item: dragItem, options: options, isCopy: true }))));\n };\n Nestable.prototype.render = function () {\n var _a = this.props, group = _a.group, className = _a.className, idProp = _a.idProp;\n var _b = this.state, items = _b.items, dragItem = _b.dragItem;\n var options = this.getItemOptions();\n return (react_1.default.createElement(\"div\", { className: (0, classnames_1.default)(className, 'nestable', \"nestable-\".concat(group), { 'is-drag-active': dragItem }) },\n react_1.default.createElement(\"ol\", { className: \"nestable-list\" }, items.map(function (item, i) {\n return (react_1.default.createElement(NestableItem_1.default, { key: item[idProp], index: i, item: item, options: options }));\n })),\n dragItem && this.renderDragLayer()));\n };\n Nestable.defaultProps = {\n childrenProp: 'children',\n collapsed: false,\n confirmChange: function () { return true; },\n disableCollapse: false,\n disableDrag: false,\n group: Math.random().toString(36).slice(2),\n idProp: 'id',\n items: [],\n maxDepth: 10,\n onChange: function () { },\n onCollapseChange: function () { },\n onDragEnd: function () { },\n onDragStart: function () { },\n renderItem: function (_a) {\n var item = _a.item;\n return String(item);\n },\n threshold: 30,\n };\n return Nestable;\n}(react_1.Component));\nexports[\"default\"] = Nestable;\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./src/Nestable/Nestable.tsx","mappings":"AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","sources":["webpack://react-nestable/./src/Nestable/Nestable.tsx?1b20"],"sourcesContent":["\"use strict\";\nvar __extends = (this && this.__extends) || (function () {\n    var extendStatics = function (d, b) {\n        extendStatics = Object.setPrototypeOf ||\n            ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n            function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n        return extendStatics(d, b);\n    };\n    return function (d, b) {\n        if (typeof b !== \"function\" && b !== null)\n            throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n        extendStatics(d, b);\n        function __() { this.constructor = d; }\n        d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n    };\n})();\nvar __assign = (this && this.__assign) || function () {\n    __assign = Object.assign || function(t) {\n        for (var s, i = 1, n = arguments.length; i < n; i++) {\n            s = arguments[i];\n            for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))\n                t[p] = s[p];\n        }\n        return t;\n    };\n    return __assign.apply(this, arguments);\n};\nvar __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {\n    if (k2 === undefined) k2 = k;\n    var desc = Object.getOwnPropertyDescriptor(m, k);\n    if (!desc || (\"get\" in desc ? !m.__esModule : desc.writable || desc.configurable)) {\n      desc = { enumerable: true, get: function() { return m[k]; } };\n    }\n    Object.defineProperty(o, k2, desc);\n}) : (function(o, m, k, k2) {\n    if (k2 === undefined) k2 = k;\n    o[k2] = m[k];\n}));\nvar __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {\n    Object.defineProperty(o, \"default\", { enumerable: true, value: v });\n}) : function(o, v) {\n    o[\"default\"] = v;\n});\nvar __importStar = (this && this.__importStar) || function (mod) {\n    if (mod && mod.__esModule) return mod;\n    var result = {};\n    if (mod != null) for (var k in mod) if (k !== \"default\" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);\n    __setModuleDefault(result, mod);\n    return result;\n};\nvar __spreadArray = (this && this.__spreadArray) || function (to, from, pack) {\n    if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {\n        if (ar || !(i in from)) {\n            if (!ar) ar = Array.prototype.slice.call(from, 0, i);\n            ar[i] = from[i];\n        }\n    }\n    return to.concat(ar || Array.prototype.slice.call(from));\n};\nvar __importDefault = (this && this.__importDefault) || function (mod) {\n    return (mod && mod.__esModule) ? mod : { \"default\": mod };\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\nvar react_1 = __importStar(require(\"react\"));\nvar react_addons_shallow_compare_1 = __importDefault(require(\"react-addons-shallow-compare\"));\nvar react_addons_update_1 = __importDefault(require(\"react-addons-update\"));\nvar classnames_1 = __importDefault(require(\"classnames\"));\nvar utils_1 = require(\"../utils\");\nvar NestableItem_1 = __importDefault(require(\"./NestableItem\"));\nvar Nestable = /** @class */ (function (_super) {\n    __extends(Nestable, _super);\n    function Nestable(props) {\n        var _this = _super.call(this, props) || this;\n        _this.el = null;\n        _this.elCopyStyles = null;\n        _this.mouse = {\n            last: { x: 0 },\n            shift: { x: 0 },\n        };\n        // ––––––––––––––––––––––––––––––––––––\n        // Public Methods\n        // ––––––––––––––––––––––––––––––––––––\n        _this.collapse = function (itemIds) {\n            var _a = _this.props, idProp = _a.idProp, childrenProp = _a.childrenProp, collapsed = _a.collapsed;\n            var items = _this.state.items;\n            if (itemIds === 'NONE') {\n                _this.setState({\n                    collapsedItems: collapsed\n                        ? (0, utils_1.getAllNonEmptyNodesIds)(items, { idProp: idProp, childrenProp: childrenProp })\n                        : [],\n                });\n            }\n            else if (itemIds === 'ALL') {\n                _this.setState({\n                    collapsedItems: collapsed\n                        ? []\n                        : (0, utils_1.getAllNonEmptyNodesIds)(items, { idProp: idProp, childrenProp: childrenProp }),\n                });\n            }\n            else if ((0, utils_1.isArray)(itemIds)) {\n                _this.setState({\n                    collapsedItems: (0, utils_1.getAllNonEmptyNodesIds)(items, { idProp: idProp, childrenProp: childrenProp })\n                        .filter(function (id) { return (itemIds.indexOf(id) > -1) !== collapsed; }),\n                });\n            }\n        };\n        // ––––––––––––––––––––––––––––––––––––\n        // Methods\n        // ––––––––––––––––––––––––––––––––––––\n        _this.startTrackMouse = function () {\n            document.addEventListener('mousemove', _this.onMouseMove);\n            document.addEventListener('mouseup', _this.onDragEnd);\n            document.addEventListener('keydown', _this.onKeyDown);\n        };\n        _this.stopTrackMouse = function () {\n            document.removeEventListener('mousemove', _this.onMouseMove);\n            document.removeEventListener('mouseup', _this.onDragEnd);\n            document.removeEventListener('keydown', _this.onKeyDown);\n            _this.elCopyStyles = null;\n        };\n        _this.getItemDepth = function (item) {\n            var childrenProp = _this.props.childrenProp;\n            var level = 1;\n            if (item[childrenProp].length > 0) {\n                var childrenDepths = item[childrenProp].map(_this.getItemDepth);\n                level += Math.max.apply(Math, childrenDepths);\n            }\n            return level;\n        };\n        _this.checkIfCollapsed = function (item) {\n            var _a = _this.props, collapsed = _a.collapsed, idProp = _a.idProp;\n            var collapsedItems = _this.state.collapsedItems;\n            return !!((collapsedItems.indexOf(item[idProp]) > -1) !== collapsed);\n        };\n        // ––––––––––––––––––––––––––––––––––––\n        // Click handlers or event handlers\n        // ––––––––––––––––––––––––––––––––––––\n        _this.onDragStart = function (e, item) {\n            var onDragStart = _this.props.onDragStart;\n            e.preventDefault();\n            e.stopPropagation();\n            if (!(e.target instanceof Element))\n                return;\n            _this.el = (0, utils_1.closest)(e.target, '.nestable-item');\n            _this.startTrackMouse();\n            _this.onMouseMove(e);\n            onDragStart({ dragItem: item });\n            _this.setState({\n                dragItem: item,\n                itemsOld: _this.state.items,\n            });\n        };\n        _this.onDragEnd = function (e, isCancel) {\n            var onDragEnd = _this.props.onDragEnd;\n            e === null || e === void 0 ? void 0 : e.preventDefault();\n            _this.stopTrackMouse();\n            _this.el = null;\n            onDragEnd();\n            isCancel\n                ? _this.dragRevert()\n                : _this.dragApply();\n        };\n        _this.onMouseMove = function (e) {\n            var _a = _this.props, group = _a.group, threshold = _a.threshold;\n            var dragItem = _this.state.dragItem;\n            var clientX = e.clientX, clientY = e.clientY;\n            var transformProps = (0, utils_1.getTransformProps)(clientX, clientY);\n            var elCopy = document.querySelector(\".nestable-\".concat(group, \" .nestable-drag-layer > .nestable-list\"));\n            if (!_this.elCopyStyles) {\n                var offset = (0, utils_1.getOffsetRect)(_this.el);\n                var scroll_1 = (0, utils_1.getTotalScroll)(_this.el);\n                _this.elCopyStyles = __assign({ marginTop: offset.top - clientY - scroll_1.top, marginLeft: offset.left - clientX - scroll_1.left }, transformProps);\n            }\n            else {\n                _this.elCopyStyles = __assign(__assign({}, _this.elCopyStyles), transformProps);\n                Object.keys(transformProps).forEach(function (key) {\n                    elCopy.style[key] = transformProps[key];\n                });\n                var diffX = clientX - _this.mouse.last.x;\n                if ((diffX >= 0 && _this.mouse.shift.x >= 0) ||\n                    (diffX <= 0 && _this.mouse.shift.x <= 0)) {\n                    _this.mouse.shift.x += diffX;\n                }\n                else {\n                    _this.mouse.shift.x = 0;\n                }\n                _this.mouse.last.x = clientX;\n                if (Math.abs(_this.mouse.shift.x) > threshold) {\n                    if (_this.mouse.shift.x > 0) {\n                        _this.tryIncreaseDepth(dragItem);\n                    }\n                    else {\n                        _this.tryDecreaseDepth(dragItem);\n                    }\n                    _this.mouse.shift.x = 0;\n                }\n            }\n        };\n        _this.onMouseEnter = function (e, item) {\n            e.preventDefault();\n            e.stopPropagation();\n            var _a = _this.props, collapsed = _a.collapsed, idProp = _a.idProp, childrenProp = _a.childrenProp;\n            var dragItem = _this.state.dragItem;\n            if (dragItem[idProp] === item[idProp])\n                return;\n            var pathFrom = _this.getPathById(dragItem[idProp]);\n            var pathTo = _this.getPathById(item[idProp]);\n            // if collapsed by default\n            // and move out the only child\n            // remove parent node from list of open nodes\n            var collapseProps = {};\n            if (collapsed && pathFrom.length > 1) {\n                var parent_1 = _this.getItemByPath(pathFrom.slice(0, -1));\n                if (parent_1[childrenProp].length === 1) {\n                    collapseProps = _this.onToggleCollapse(parent_1, true);\n                }\n            }\n            _this.moveItem({ dragItem: dragItem, pathFrom: pathFrom, pathTo: pathTo }, collapseProps);\n        };\n        _this.onToggleCollapse = function (item, isGetter) {\n            var _a = _this.props, collapsed = _a.collapsed, idProp = _a.idProp;\n            var collapsedItems = _this.state.collapsedItems;\n            var isCollapsed = _this.checkIfCollapsed(item);\n            var newState = {\n                collapsedItems: (isCollapsed !== collapsed)\n                    ? collapsedItems.filter(function (id) { return id !== item[idProp]; })\n                    : collapsedItems.concat(item[idProp]),\n            };\n            if (isGetter) {\n                return newState;\n            }\n            else {\n                _this.setState(newState);\n                _this.onCollapseChange(newState.collapsedItems);\n            }\n        };\n        _this.onCollapseChange = function (ids) {\n            var _a = _this.props, collapsed = _a.collapsed, onCollapseChange = _a.onCollapseChange;\n            onCollapseChange(collapsed ? { openIds: ids } : { closedIds: ids });\n        };\n        _this.onKeyDown = function (e) {\n            if (e.which === 27) {\n                // ESC\n                _this.onDragEnd(null, true);\n            }\n        };\n        _this.state = {\n            items: [],\n            itemsOld: null,\n            dragItem: null,\n            isDirty: false,\n            collapsedItems: [],\n        };\n        return _this;\n    }\n    Nestable.prototype.componentDidMount = function () {\n        var _a = this.props, items = _a.items, childrenProp = _a.childrenProp;\n        // make sure every item has property 'children'\n        items = (0, utils_1.listWithChildren)(items, childrenProp);\n        this.setState({ items: items });\n    };\n    Nestable.prototype.componentDidUpdate = function (prevProps) {\n        var _this = this;\n        var _a = this, _b = _a.props, itemsNew = _b.items, childrenProp = _b.childrenProp, state = _a.state;\n        var isPropsChanged = (0, react_addons_shallow_compare_1.default)(__assign(__assign({}, this), { props: prevProps, state: state }), this.props, state);\n        if (isPropsChanged) {\n            this.stopTrackMouse();\n            this.setState(function (prevState) {\n                var newState = __assign(__assign({}, prevState), { items: (0, utils_1.listWithChildren)(itemsNew, childrenProp), dragItem: null, isDirty: false });\n                if (prevProps.collapsed !== _this.props.collapsed) {\n                    newState.collapsedItems = [];\n                    _this.onCollapseChange(newState.collapsedItems);\n                }\n                return newState;\n            });\n        }\n    };\n    Nestable.prototype.componentWillUnmount = function () {\n        this.stopTrackMouse();\n    };\n    Nestable.prototype.moveItem = function (_a, extraProps) {\n        var dragItem = _a.dragItem, pathFrom = _a.pathFrom, pathTo = _a.pathTo;\n        if (extraProps === void 0) { extraProps = {}; }\n        var _b = this.props, childrenProp = _b.childrenProp, confirmChange = _b.confirmChange;\n        var dragItemSize = this.getItemDepth(dragItem);\n        var items = this.state.items;\n        // the remove action might affect the next position,\n        // so update next coordinates accordingly\n        var realPathTo = this.getRealNextPath(pathFrom, pathTo, dragItemSize);\n        if (realPathTo.length === 0)\n            return;\n        // user can validate every movement\n        var destinationPath = realPathTo.length > pathTo.length\n            ? pathTo\n            : pathTo.slice(0, -1);\n        var destinationParent = this.getItemByPath(destinationPath);\n        var removePath = this.getSplicePath(pathFrom, {\n            numToRemove: 1,\n            childrenProp: childrenProp,\n        });\n        var insertPath = this.getSplicePath(realPathTo, {\n            numToRemove: 0,\n            itemsToInsert: [dragItem],\n            childrenProp: childrenProp,\n        });\n        items = (0, react_addons_update_1.default)(items, removePath);\n        items = (0, react_addons_update_1.default)(items, insertPath);\n        if (!confirmChange({ dragItem: dragItem, destinationParent: destinationParent, items: items }))\n            return;\n        this.setState(function (prevState) { return (__assign(__assign(__assign({}, prevState), { items: items, isDirty: true }), extraProps)); });\n        if (extraProps.collapsedItems !== this.state.collapsedItems) {\n            this.onCollapseChange(extraProps.collapsedItems);\n        }\n    };\n    Nestable.prototype.tryIncreaseDepth = function (dragItem) {\n        var _a = this.props, maxDepth = _a.maxDepth, idProp = _a.idProp, childrenProp = _a.childrenProp, collapsed = _a.collapsed;\n        var pathFrom = this.getPathById(dragItem[idProp]);\n        var itemIndex = pathFrom[pathFrom.length - 1];\n        var newDepth = pathFrom.length + this.getItemDepth(dragItem);\n        // has previous sibling and isn't at max depth\n        if (itemIndex > 0 && newDepth <= maxDepth) {\n            var prevSibling = this.getItemByPath(pathFrom.slice(0, -1).concat(itemIndex - 1));\n            // previous sibling is not collapsed\n            if (!prevSibling[childrenProp].length || !this.checkIfCollapsed(prevSibling)) {\n                var pathTo = pathFrom\n                    .slice(0, -1)\n                    .concat(itemIndex - 1)\n                    .concat(prevSibling[childrenProp].length);\n                // if collapsed by default\n                // and was no children here\n                // open this node\n                var collapseProps = {};\n                if (collapsed && !prevSibling[childrenProp].length) {\n                    collapseProps = this.onToggleCollapse(prevSibling, true);\n                }\n                this.moveItem({ dragItem: dragItem, pathFrom: pathFrom, pathTo: pathTo }, collapseProps);\n            }\n        }\n    };\n    Nestable.prototype.tryDecreaseDepth = function (dragItem) {\n        var _a = this.props, idProp = _a.idProp, childrenProp = _a.childrenProp, collapsed = _a.collapsed;\n        var pathFrom = this.getPathById(dragItem[idProp]);\n        var itemIndex = pathFrom[pathFrom.length - 1];\n        // has parent\n        if (pathFrom.length > 1) {\n            var parent_2 = this.getItemByPath(pathFrom.slice(0, -1));\n            // is last (by order) item in array\n            if (itemIndex + 1 === parent_2[childrenProp].length) {\n                var pathTo = pathFrom.slice(0, -1);\n                pathTo[pathTo.length - 1] += 1;\n                // if collapsed by default\n                // and is last (by count) item in array\n                // remove this node from list of open nodes\n                var collapseProps = {};\n                if (collapsed && parent_2[childrenProp].length === 1) {\n                    collapseProps = this.onToggleCollapse(parent_2, true);\n                }\n                this.moveItem({ dragItem: dragItem, pathFrom: pathFrom, pathTo: pathTo }, collapseProps);\n            }\n        }\n    };\n    Nestable.prototype.dragApply = function () {\n        var _a = this.props, onChange = _a.onChange, idProp = _a.idProp;\n        var _b = this.state, items = _b.items, isDirty = _b.isDirty, dragItem = _b.dragItem;\n        this.setState({\n            itemsOld: null,\n            dragItem: null,\n            isDirty: false,\n        });\n        if (onChange && isDirty) {\n            var targetPath = this.getPathById(dragItem[idProp], items);\n            onChange({ items: items, dragItem: dragItem, targetPath: targetPath });\n        }\n    };\n    Nestable.prototype.dragRevert = function () {\n        var itemsOld = this.state.itemsOld;\n        this.setState({\n            items: itemsOld,\n            itemsOld: null,\n            dragItem: null,\n            isDirty: false,\n        });\n    };\n    // ––––––––––––––––––––––––––––––––––––\n    // Getter methods\n    // ––––––––––––––––––––––––––––––––––––\n    Nestable.prototype.getPathById = function (id, items) {\n        var _this = this;\n        if (items === void 0) { items = this.state.items; }\n        var _a = this.props, idProp = _a.idProp, childrenProp = _a.childrenProp;\n        var path = [];\n        items.every(function (item, i) {\n            if (item[idProp] === id) {\n                path.push(i);\n            }\n            else if (item[childrenProp]) {\n                var childrenPath = _this.getPathById(id, item[childrenProp]);\n                if (childrenPath.length) {\n                    path = path.concat(i).concat(childrenPath);\n                }\n            }\n            return path.length === 0;\n        });\n        return path;\n    };\n    Nestable.prototype.getItemByPath = function (path, items) {\n        if (items === void 0) { items = this.state.items; }\n        var childrenProp = this.props.childrenProp;\n        var item = null;\n        path.forEach(function (index) {\n            var list = item ? item[childrenProp] : items;\n            item = list[index];\n        });\n        return item;\n    };\n    Nestable.prototype.getSplicePath = function (path, options) {\n        if (options === void 0) { options = {}; }\n        var splicePath = {};\n        var numToRemove = options.numToRemove || 0;\n        var itemsToInsert = options.itemsToInsert || [];\n        var lastIndex = path.length - 1;\n        var currentPath = splicePath;\n        path.forEach(function (index, i) {\n            var _a;\n            if (i === lastIndex) {\n                currentPath.$splice = [__spreadArray([index, numToRemove], itemsToInsert, true)];\n            }\n            else {\n                var nextPath = {};\n                currentPath[index] = (_a = {}, _a[options.childrenProp] = nextPath, _a);\n                currentPath = nextPath;\n            }\n        });\n        return splicePath;\n    };\n    Nestable.prototype.getRealNextPath = function (prevPath, nextPath, dragItemSize) {\n        var _a = this.props, childrenProp = _a.childrenProp, maxDepth = _a.maxDepth;\n        var ppLastIndex = prevPath.length - 1;\n        var npLastIndex = nextPath.length - 1;\n        var newDepth = nextPath.length + dragItemSize - 1;\n        if (prevPath.length < nextPath.length) {\n            // move into depth\n            var wasShifted_1 = false;\n            // if new depth exceeds max, try to put after item instead of into item\n            if (newDepth > maxDepth && nextPath.length) {\n                return this.getRealNextPath(prevPath, nextPath.slice(0, -1), dragItemSize);\n            }\n            return nextPath.map(function (nextIndex, i) {\n                if (wasShifted_1) {\n                    return i === npLastIndex\n                        ? nextIndex + 1\n                        : nextIndex;\n                }\n                if (typeof prevPath[i] !== 'number') {\n                    return nextIndex;\n                }\n                if (nextPath[i] > prevPath[i] && i === ppLastIndex) {\n                    wasShifted_1 = true;\n                    return nextIndex - 1;\n                }\n                return nextIndex;\n            });\n        }\n        else if (prevPath.length === nextPath.length) {\n            // if move bottom + move to item with children --> make it a first child instead of swap\n            if (nextPath[npLastIndex] > prevPath[npLastIndex]) {\n                var target = this.getItemByPath(nextPath);\n                if (newDepth < maxDepth &&\n                    target[childrenProp] &&\n                    target[childrenProp].length &&\n                    !this.checkIfCollapsed(target)) {\n                    return nextPath\n                        .slice(0, -1)\n                        .concat(nextPath[npLastIndex] - 1)\n                        .concat(0);\n                }\n            }\n        }\n        return nextPath;\n    };\n    Nestable.prototype.getItemOptions = function () {\n        var _a = this.props, renderItem = _a.renderItem, renderCollapseIcon = _a.renderCollapseIcon, handler = _a.handler, disableCollapse = _a.disableCollapse, disableDrag = _a.disableDrag, idProp = _a.idProp, childrenProp = _a.childrenProp;\n        var dragItem = this.state.dragItem;\n        return {\n            dragItem: dragItem,\n            idProp: idProp,\n            childrenProp: childrenProp,\n            disableCollapse: disableCollapse,\n            disableDrag: disableDrag,\n            renderItem: renderItem,\n            renderCollapseIcon: renderCollapseIcon,\n            handler: handler,\n            checkIfCollapsed: this.checkIfCollapsed,\n            onDragStart: this.onDragStart,\n            onMouseEnter: this.onMouseEnter,\n            onToggleCollapse: this.onToggleCollapse,\n        };\n    };\n    // ––––––––––––––––––––––––––––––––––––\n    // Render methods\n    // ––––––––––––––––––––––––––––––––––––\n    Nestable.prototype.renderDragLayer = function () {\n        var _a = this.props, group = _a.group, idProp = _a.idProp;\n        var dragItem = this.state.dragItem;\n        var el = document.querySelector(\".nestable-\".concat(group, \" .nestable-item-\").concat(dragItem[idProp]));\n        var listStyles = {};\n        if (el) {\n            listStyles.width = el.clientWidth;\n        }\n        if (this.elCopyStyles) {\n            listStyles = __assign(__assign({}, listStyles), this.elCopyStyles);\n        }\n        var options = this.getItemOptions();\n        return (react_1.default.createElement(\"div\", { className: \"nestable-drag-layer\" },\n            react_1.default.createElement(\"ol\", { className: \"nestable-list\", style: listStyles },\n                react_1.default.createElement(NestableItem_1.default, { item: dragItem, options: options, isCopy: true }))));\n    };\n    Nestable.prototype.render = function () {\n        var _a = this.props, group = _a.group, className = _a.className, idProp = _a.idProp;\n        var _b = this.state, items = _b.items, dragItem = _b.dragItem;\n        var options = this.getItemOptions();\n        return (react_1.default.createElement(\"div\", { className: (0, classnames_1.default)(className, 'nestable', \"nestable-\".concat(group), { 'is-drag-active': dragItem }) },\n            react_1.default.createElement(\"ol\", { className: \"nestable-list\" }, items.map(function (item, i) {\n                return (react_1.default.createElement(NestableItem_1.default, { key: item[idProp], index: i, item: item, options: options }));\n            })),\n            dragItem && this.renderDragLayer()));\n    };\n    Nestable.defaultProps = {\n        childrenProp: 'children',\n        collapsed: false,\n        confirmChange: function () { return true; },\n        disableCollapse: false,\n        disableDrag: false,\n        group: Math.random().toString(36).slice(2),\n        idProp: 'id',\n        items: [],\n        maxDepth: 10,\n        onChange: function () { },\n        onCollapseChange: function () { },\n        onDragEnd: function () { },\n        onDragStart: function () { },\n        renderItem: function (_a) {\n            var item = _a.item;\n            return String(item);\n        },\n        threshold: 30,\n    };\n    return Nestable;\n}(react_1.Component));\nexports.default = Nestable;\n"],"names":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///./src/Nestable/Nestable.tsx\n"); /***/ }), @@ -459,7 +459,7 @@ module.exports = "data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGlu /******/ /******/ /* webpack/runtime/getFullHash */ /******/ (() => { -/******/ __webpack_require__.h = () => ("cdb2482319946aafcd82") +/******/ __webpack_require__.h = () => ("610d98a9912d7f0a78f3") /******/ })(); /******/ /******/ /* webpack/runtime/hasOwnProperty shorthand */ diff --git a/dist/types.d.ts b/dist/types.d.ts index 2c26ad4..7acf9d3 100644 --- a/dist/types.d.ts +++ b/dist/types.d.ts @@ -30,6 +30,7 @@ export type Item = Record; export type ConfirmChange = (options: { dragItem: Item; destinationParent: Item | null; + items: Item[]; }) => boolean; export type DisableDragFn = (options: { item: Item; diff --git a/src/Nestable/Nestable.tsx b/src/Nestable/Nestable.tsx index babc473..ec4c773 100644 --- a/src/Nestable/Nestable.tsx +++ b/src/Nestable/Nestable.tsx @@ -155,7 +155,6 @@ class Nestable extends Component { ? pathTo : pathTo.slice(0, -1); const destinationParent = this.getItemByPath(destinationPath); - if (!confirmChange({dragItem, destinationParent})) return; const removePath = this.getSplicePath(pathFrom, { numToRemove: 1, @@ -170,6 +169,7 @@ class Nestable extends Component { items = update(items, removePath); items = update(items, insertPath); + if (!confirmChange({dragItem, destinationParent, items})) return; this.setState(prevState => ({ ...prevState, diff --git a/src/types.ts b/src/types.ts index 969b4e7..2356612 100644 --- a/src/types.ts +++ b/src/types.ts @@ -38,6 +38,7 @@ export type ConfirmChange = ( options: { dragItem: Item; destinationParent: Item | null; + items: Item[]; } ) => boolean; From defcc69401848950ca7adf5f01eaa47e01182a8b Mon Sep 17 00:00:00 2001 From: Jeff Watson Date: Wed, 13 Dec 2023 09:24:30 -0600 Subject: [PATCH 2/2] rebuild after merge Signed-off-by: Jeff Watson --- dist/example/example.js | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/dist/example/example.js b/dist/example/example.js index 445be19..865d7b6 100644 --- a/dist/example/example.js +++ b/dist/example/example.js @@ -279,7 +279,7 @@ eval("\nvar __importDefault = (this && this.__importDefault) || function (mod) { /***/ (function(__unused_webpack_module, exports, __webpack_require__) { "use strict"; -eval("\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __assign = (this && this.__assign) || function () {\n __assign = Object.assign || function(t) {\n for (var s, i = 1, n = arguments.length; i < n; i++) {\n s = arguments[i];\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))\n t[p] = s[p];\n }\n return t;\n };\n return __assign.apply(this, arguments);\n};\nvar __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n var desc = Object.getOwnPropertyDescriptor(m, k);\n if (!desc || (\"get\" in desc ? !m.__esModule : desc.writable || desc.configurable)) {\n desc = { enumerable: true, get: function() { return m[k]; } };\n }\n Object.defineProperty(o, k2, desc);\n}) : (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n o[k2] = m[k];\n}));\nvar __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {\n Object.defineProperty(o, \"default\", { enumerable: true, value: v });\n}) : function(o, v) {\n o[\"default\"] = v;\n});\nvar __importStar = (this && this.__importStar) || function (mod) {\n if (mod && mod.__esModule) return mod;\n var result = {};\n if (mod != null) for (var k in mod) if (k !== \"default\" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);\n __setModuleDefault(result, mod);\n return result;\n};\nvar __spreadArray = (this && this.__spreadArray) || function (to, from, pack) {\n if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {\n if (ar || !(i in from)) {\n if (!ar) ar = Array.prototype.slice.call(from, 0, i);\n ar[i] = from[i];\n }\n }\n return to.concat(ar || Array.prototype.slice.call(from));\n};\nvar __importDefault = (this && this.__importDefault) || function (mod) {\n return (mod && mod.__esModule) ? mod : { \"default\": mod };\n};\nObject.defineProperty(exports, \"__esModule\", ({ value: true }));\nvar react_1 = __importStar(__webpack_require__(/*! react */ \"./node_modules/react/index.js\"));\nvar react_addons_shallow_compare_1 = __importDefault(__webpack_require__(/*! react-addons-shallow-compare */ \"./node_modules/react-addons-shallow-compare/index.js\"));\nvar react_addons_update_1 = __importDefault(__webpack_require__(/*! react-addons-update */ \"./node_modules/react-addons-update/index.js\"));\nvar classnames_1 = __importDefault(__webpack_require__(/*! classnames */ \"./node_modules/classnames/index.js\"));\nvar utils_1 = __webpack_require__(/*! ../utils */ \"./src/utils.ts\");\nvar NestableItem_1 = __importDefault(__webpack_require__(/*! ./NestableItem */ \"./src/Nestable/NestableItem.tsx\"));\nvar Nestable = /** @class */ (function (_super) {\n __extends(Nestable, _super);\n function Nestable(props) {\n var _this = _super.call(this, props) || this;\n _this.el = null;\n _this.elCopyStyles = null;\n _this.mouse = {\n last: { x: 0 },\n shift: { x: 0 },\n };\n // ––––––––––––––––––––––––––––––––––––\n // Public Methods\n // ––––––––––––––––––––––––––––––––––––\n _this.collapse = function (itemIds) {\n var _a = _this.props, idProp = _a.idProp, childrenProp = _a.childrenProp, collapsed = _a.collapsed;\n var items = _this.state.items;\n if (itemIds === 'NONE') {\n _this.setState({\n collapsedItems: collapsed\n ? (0, utils_1.getAllNonEmptyNodesIds)(items, { idProp: idProp, childrenProp: childrenProp })\n : [],\n });\n }\n else if (itemIds === 'ALL') {\n _this.setState({\n collapsedItems: collapsed\n ? []\n : (0, utils_1.getAllNonEmptyNodesIds)(items, { idProp: idProp, childrenProp: childrenProp }),\n });\n }\n else if ((0, utils_1.isArray)(itemIds)) {\n _this.setState({\n collapsedItems: (0, utils_1.getAllNonEmptyNodesIds)(items, { idProp: idProp, childrenProp: childrenProp })\n .filter(function (id) { return (itemIds.indexOf(id) > -1) !== collapsed; }),\n });\n }\n };\n // ––––––––––––––––––––––––––––––––––––\n // Methods\n // ––––––––––––––––––––––––––––––––––––\n _this.startTrackMouse = function () {\n document.addEventListener('mousemove', _this.onMouseMove);\n document.addEventListener('mouseup', _this.onDragEnd);\n document.addEventListener('keydown', _this.onKeyDown);\n };\n _this.stopTrackMouse = function () {\n document.removeEventListener('mousemove', _this.onMouseMove);\n document.removeEventListener('mouseup', _this.onDragEnd);\n document.removeEventListener('keydown', _this.onKeyDown);\n _this.elCopyStyles = null;\n };\n _this.getItemDepth = function (item) {\n var childrenProp = _this.props.childrenProp;\n var level = 1;\n if (item[childrenProp].length > 0) {\n var childrenDepths = item[childrenProp].map(_this.getItemDepth);\n level += Math.max.apply(Math, childrenDepths);\n }\n return level;\n };\n _this.checkIfCollapsed = function (item) {\n var _a = _this.props, collapsed = _a.collapsed, idProp = _a.idProp;\n var collapsedItems = _this.state.collapsedItems;\n return !!((collapsedItems.indexOf(item[idProp]) > -1) !== collapsed);\n };\n // ––––––––––––––––––––––––––––––––––––\n // Click handlers or event handlers\n // ––––––––––––––––––––––––––––––––––––\n _this.onDragStart = function (e, item) {\n var onDragStart = _this.props.onDragStart;\n e.preventDefault();\n e.stopPropagation();\n if (!(e.target instanceof Element))\n return;\n _this.el = (0, utils_1.closest)(e.target, '.nestable-item');\n _this.startTrackMouse();\n _this.onMouseMove(e);\n onDragStart({ dragItem: item });\n _this.setState({\n dragItem: item,\n itemsOld: _this.state.items,\n });\n };\n _this.onDragEnd = function (e, isCancel) {\n var onDragEnd = _this.props.onDragEnd;\n e === null || e === void 0 ? void 0 : e.preventDefault();\n _this.stopTrackMouse();\n _this.el = null;\n onDragEnd();\n isCancel\n ? _this.dragRevert()\n : _this.dragApply();\n };\n _this.onMouseMove = function (e) {\n var _a = _this.props, group = _a.group, threshold = _a.threshold;\n var dragItem = _this.state.dragItem;\n var clientX = e.clientX, clientY = e.clientY;\n var transformProps = (0, utils_1.getTransformProps)(clientX, clientY);\n var elCopy = document.querySelector(\".nestable-\".concat(group, \" .nestable-drag-layer > .nestable-list\"));\n if (!_this.elCopyStyles) {\n var offset = (0, utils_1.getOffsetRect)(_this.el);\n var scroll_1 = (0, utils_1.getTotalScroll)(_this.el);\n _this.elCopyStyles = __assign({ marginTop: offset.top - clientY - scroll_1.top, marginLeft: offset.left - clientX - scroll_1.left }, transformProps);\n }\n else {\n _this.elCopyStyles = __assign(__assign({}, _this.elCopyStyles), transformProps);\n Object.keys(transformProps).forEach(function (key) {\n elCopy.style[key] = transformProps[key];\n });\n var diffX = clientX - _this.mouse.last.x;\n if ((diffX >= 0 && _this.mouse.shift.x >= 0) ||\n (diffX <= 0 && _this.mouse.shift.x <= 0)) {\n _this.mouse.shift.x += diffX;\n }\n else {\n _this.mouse.shift.x = 0;\n }\n _this.mouse.last.x = clientX;\n if (Math.abs(_this.mouse.shift.x) > threshold) {\n if (_this.mouse.shift.x > 0) {\n _this.tryIncreaseDepth(dragItem);\n }\n else {\n _this.tryDecreaseDepth(dragItem);\n }\n _this.mouse.shift.x = 0;\n }\n }\n };\n _this.onMouseEnter = function (e, item) {\n e.preventDefault();\n e.stopPropagation();\n var _a = _this.props, collapsed = _a.collapsed, idProp = _a.idProp, childrenProp = _a.childrenProp;\n var dragItem = _this.state.dragItem;\n if (dragItem[idProp] === item[idProp])\n return;\n var pathFrom = _this.getPathById(dragItem[idProp]);\n var pathTo = _this.getPathById(item[idProp]);\n // if collapsed by default\n // and move out the only child\n // remove parent node from list of open nodes\n var collapseProps = {};\n if (collapsed && pathFrom.length > 1) {\n var parent_1 = _this.getItemByPath(pathFrom.slice(0, -1));\n if (parent_1[childrenProp].length === 1) {\n collapseProps = _this.onToggleCollapse(parent_1, true);\n }\n }\n _this.moveItem({ dragItem: dragItem, pathFrom: pathFrom, pathTo: pathTo }, collapseProps);\n };\n _this.onToggleCollapse = function (item, isGetter) {\n var _a = _this.props, collapsed = _a.collapsed, idProp = _a.idProp;\n var collapsedItems = _this.state.collapsedItems;\n var isCollapsed = _this.checkIfCollapsed(item);\n var newState = {\n collapsedItems: (isCollapsed !== collapsed)\n ? collapsedItems.filter(function (id) { return id !== item[idProp]; })\n : collapsedItems.concat(item[idProp]),\n };\n if (isGetter) {\n return newState;\n }\n else {\n _this.setState(newState);\n _this.onCollapseChange(newState.collapsedItems);\n }\n };\n _this.onCollapseChange = function (ids) {\n var _a = _this.props, collapsed = _a.collapsed, onCollapseChange = _a.onCollapseChange;\n onCollapseChange(collapsed ? { openIds: ids } : { closedIds: ids });\n };\n _this.onKeyDown = function (e) {\n if (e.which === 27) {\n // ESC\n _this.onDragEnd(null, true);\n }\n };\n _this.state = {\n items: [],\n itemsOld: null,\n dragItem: null,\n isDirty: false,\n collapsedItems: [],\n };\n return _this;\n }\n Nestable.prototype.componentDidMount = function () {\n var _a = this.props, items = _a.items, childrenProp = _a.childrenProp;\n // make sure every item has property 'children'\n items = (0, utils_1.listWithChildren)(items, childrenProp);\n this.setState({ items: items });\n };\n Nestable.prototype.componentDidUpdate = function (prevProps) {\n var _this = this;\n var _a = this, _b = _a.props, itemsNew = _b.items, childrenProp = _b.childrenProp, state = _a.state;\n var isPropsChanged = (0, react_addons_shallow_compare_1.default)(__assign(__assign({}, this), { props: prevProps, state: state }), this.props, state);\n if (isPropsChanged) {\n this.stopTrackMouse();\n this.setState(function (prevState) {\n var newState = __assign(__assign({}, prevState), { items: (0, utils_1.listWithChildren)(itemsNew, childrenProp), dragItem: null, isDirty: false });\n if (prevProps.collapsed !== _this.props.collapsed) {\n newState.collapsedItems = [];\n _this.onCollapseChange(newState.collapsedItems);\n }\n return newState;\n });\n }\n };\n Nestable.prototype.componentWillUnmount = function () {\n this.stopTrackMouse();\n };\n Nestable.prototype.moveItem = function (_a, extraProps) {\n var dragItem = _a.dragItem, pathFrom = _a.pathFrom, pathTo = _a.pathTo;\n if (extraProps === void 0) { extraProps = {}; }\n var _b = this.props, childrenProp = _b.childrenProp, confirmChange = _b.confirmChange;\n var dragItemSize = this.getItemDepth(dragItem);\n var items = this.state.items;\n // the remove action might affect the next position,\n // so update next coordinates accordingly\n var realPathTo = this.getRealNextPath(pathFrom, pathTo, dragItemSize);\n if (realPathTo.length === 0)\n return;\n // user can validate every movement\n var destinationPath = realPathTo.length > pathTo.length\n ? pathTo\n : pathTo.slice(0, -1);\n var destinationParent = this.getItemByPath(destinationPath);\n if (!confirmChange({ dragItem: dragItem, destinationParent: destinationParent }))\n return;\n var removePath = this.getSplicePath(pathFrom, {\n numToRemove: 1,\n childrenProp: childrenProp,\n });\n var insertPath = this.getSplicePath(realPathTo, {\n numToRemove: 0,\n itemsToInsert: [dragItem],\n childrenProp: childrenProp,\n });\n items = (0, react_addons_update_1.default)(items, removePath);\n items = (0, react_addons_update_1.default)(items, insertPath);\n this.setState(function (prevState) { return (__assign(__assign(__assign({}, prevState), { items: items, isDirty: true }), extraProps)); });\n if (extraProps.collapsedItems !== this.state.collapsedItems) {\n this.onCollapseChange(extraProps.collapsedItems);\n }\n };\n Nestable.prototype.tryIncreaseDepth = function (dragItem) {\n var _a = this.props, maxDepth = _a.maxDepth, idProp = _a.idProp, childrenProp = _a.childrenProp, collapsed = _a.collapsed;\n var pathFrom = this.getPathById(dragItem[idProp]);\n var itemIndex = pathFrom[pathFrom.length - 1];\n var newDepth = pathFrom.length + this.getItemDepth(dragItem);\n // has previous sibling and isn't at max depth\n if (itemIndex > 0 && newDepth <= maxDepth) {\n var prevSibling = this.getItemByPath(pathFrom.slice(0, -1).concat(itemIndex - 1));\n // previous sibling is not collapsed\n if (!prevSibling[childrenProp].length || !this.checkIfCollapsed(prevSibling)) {\n var pathTo = pathFrom\n .slice(0, -1)\n .concat(itemIndex - 1)\n .concat(prevSibling[childrenProp].length);\n // if collapsed by default\n // and was no children here\n // open this node\n var collapseProps = {};\n if (collapsed && !prevSibling[childrenProp].length) {\n collapseProps = this.onToggleCollapse(prevSibling, true);\n }\n this.moveItem({ dragItem: dragItem, pathFrom: pathFrom, pathTo: pathTo }, collapseProps);\n }\n }\n };\n Nestable.prototype.tryDecreaseDepth = function (dragItem) {\n var _a = this.props, idProp = _a.idProp, childrenProp = _a.childrenProp, collapsed = _a.collapsed;\n var pathFrom = this.getPathById(dragItem[idProp]);\n var itemIndex = pathFrom[pathFrom.length - 1];\n // has parent\n if (pathFrom.length > 1) {\n var parent_2 = this.getItemByPath(pathFrom.slice(0, -1));\n // is last (by order) item in array\n if (itemIndex + 1 === parent_2[childrenProp].length) {\n var pathTo = pathFrom.slice(0, -1);\n pathTo[pathTo.length - 1] += 1;\n // if collapsed by default\n // and is last (by count) item in array\n // remove this node from list of open nodes\n var collapseProps = {};\n if (collapsed && parent_2[childrenProp].length === 1) {\n collapseProps = this.onToggleCollapse(parent_2, true);\n }\n this.moveItem({ dragItem: dragItem, pathFrom: pathFrom, pathTo: pathTo }, collapseProps);\n }\n }\n };\n Nestable.prototype.dragApply = function () {\n var _a = this.props, onChange = _a.onChange, idProp = _a.idProp;\n var _b = this.state, items = _b.items, isDirty = _b.isDirty, dragItem = _b.dragItem;\n this.setState({\n itemsOld: null,\n dragItem: null,\n isDirty: false,\n });\n if (onChange && isDirty) {\n var targetPath = this.getPathById(dragItem[idProp], items);\n onChange({ items: items, dragItem: dragItem, targetPath: targetPath });\n }\n };\n Nestable.prototype.dragRevert = function () {\n var itemsOld = this.state.itemsOld;\n this.setState({\n items: itemsOld,\n itemsOld: null,\n dragItem: null,\n isDirty: false,\n });\n };\n // ––––––––––––––––––––––––––––––––––––\n // Getter methods\n // ––––––––––––––––––––––––––––––––––––\n Nestable.prototype.getPathById = function (id, items) {\n var _this = this;\n if (items === void 0) { items = this.state.items; }\n var _a = this.props, idProp = _a.idProp, childrenProp = _a.childrenProp;\n var path = [];\n items.every(function (item, i) {\n if (item[idProp] === id) {\n path.push(i);\n }\n else if (item[childrenProp]) {\n var childrenPath = _this.getPathById(id, item[childrenProp]);\n if (childrenPath.length) {\n path = path.concat(i).concat(childrenPath);\n }\n }\n return path.length === 0;\n });\n return path;\n };\n Nestable.prototype.getItemByPath = function (path, items) {\n if (items === void 0) { items = this.state.items; }\n var childrenProp = this.props.childrenProp;\n var item = null;\n path.forEach(function (index) {\n var list = item ? item[childrenProp] : items;\n item = list[index];\n });\n return item;\n };\n Nestable.prototype.getSplicePath = function (path, options) {\n if (options === void 0) { options = {}; }\n var splicePath = {};\n var numToRemove = options.numToRemove || 0;\n var itemsToInsert = options.itemsToInsert || [];\n var lastIndex = path.length - 1;\n var currentPath = splicePath;\n path.forEach(function (index, i) {\n var _a;\n if (i === lastIndex) {\n currentPath.$splice = [__spreadArray([index, numToRemove], itemsToInsert, true)];\n }\n else {\n var nextPath = {};\n currentPath[index] = (_a = {}, _a[options.childrenProp] = nextPath, _a);\n currentPath = nextPath;\n }\n });\n return splicePath;\n };\n Nestable.prototype.getRealNextPath = function (prevPath, nextPath, dragItemSize) {\n var _a = this.props, childrenProp = _a.childrenProp, maxDepth = _a.maxDepth;\n var ppLastIndex = prevPath.length - 1;\n var npLastIndex = nextPath.length - 1;\n var newDepth = nextPath.length + dragItemSize - 1;\n if (prevPath.length < nextPath.length) {\n // move into depth\n var wasShifted_1 = false;\n // if new depth exceeds max, try to put after item instead of into item\n if (newDepth > maxDepth && nextPath.length) {\n return this.getRealNextPath(prevPath, nextPath.slice(0, -1), dragItemSize);\n }\n return nextPath.map(function (nextIndex, i) {\n if (wasShifted_1) {\n return i === npLastIndex\n ? nextIndex + 1\n : nextIndex;\n }\n if (typeof prevPath[i] !== 'number') {\n return nextIndex;\n }\n if (nextPath[i] > prevPath[i] && i === ppLastIndex) {\n wasShifted_1 = true;\n return nextIndex - 1;\n }\n return nextIndex;\n });\n }\n else if (prevPath.length === nextPath.length) {\n // if move bottom + move to item with children --> make it a first child instead of swap\n if (nextPath[npLastIndex] > prevPath[npLastIndex]) {\n var target = this.getItemByPath(nextPath);\n if (newDepth < maxDepth &&\n target[childrenProp] &&\n target[childrenProp].length &&\n !this.checkIfCollapsed(target)) {\n return nextPath\n .slice(0, -1)\n .concat(nextPath[npLastIndex] - 1)\n .concat(0);\n }\n }\n }\n return nextPath;\n };\n Nestable.prototype.getItemOptions = function () {\n var _a = this.props, renderItem = _a.renderItem, renderCollapseIcon = _a.renderCollapseIcon, handler = _a.handler, disableCollapse = _a.disableCollapse, disableDrag = _a.disableDrag, idProp = _a.idProp, childrenProp = _a.childrenProp;\n var dragItem = this.state.dragItem;\n return {\n dragItem: dragItem,\n idProp: idProp,\n childrenProp: childrenProp,\n disableCollapse: disableCollapse,\n disableDrag: disableDrag,\n renderItem: renderItem,\n renderCollapseIcon: renderCollapseIcon,\n handler: handler,\n checkIfCollapsed: this.checkIfCollapsed,\n onDragStart: this.onDragStart,\n onMouseEnter: this.onMouseEnter,\n onToggleCollapse: this.onToggleCollapse,\n };\n };\n // ––––––––––––––––––––––––––––––––––––\n // Render methods\n // ––––––––––––––––––––––––––––––––––––\n Nestable.prototype.renderDragLayer = function () {\n var _a = this.props, group = _a.group, idProp = _a.idProp;\n var dragItem = this.state.dragItem;\n var el = document.querySelector(\".nestable-\".concat(group, \" .nestable-item-\").concat(dragItem[idProp]));\n var listStyles = {};\n if (el) {\n listStyles.width = el.clientWidth;\n }\n if (this.elCopyStyles) {\n listStyles = __assign(__assign({}, listStyles), this.elCopyStyles);\n }\n var options = this.getItemOptions();\n return (react_1.default.createElement(\"div\", { className: \"nestable-drag-layer\" },\n react_1.default.createElement(\"ol\", { className: \"nestable-list\", style: listStyles },\n react_1.default.createElement(NestableItem_1.default, { item: dragItem, options: options, isCopy: true }))));\n };\n Nestable.prototype.render = function () {\n var _a = this.props, group = _a.group, className = _a.className, idProp = _a.idProp;\n var _b = this.state, items = _b.items, dragItem = _b.dragItem;\n var options = this.getItemOptions();\n return (react_1.default.createElement(\"div\", { className: (0, classnames_1.default)(className, 'nestable', \"nestable-\".concat(group), { 'is-drag-active': dragItem }) },\n react_1.default.createElement(\"ol\", { className: \"nestable-list\" }, items.map(function (item, i) {\n return (react_1.default.createElement(NestableItem_1.default, { key: item[idProp], index: i, item: item, options: options }));\n })),\n dragItem && this.renderDragLayer()));\n };\n Nestable.defaultProps = {\n childrenProp: 'children',\n collapsed: false,\n confirmChange: function () { return true; },\n disableCollapse: false,\n disableDrag: false,\n group: Math.random().toString(36).slice(2),\n idProp: 'id',\n items: [],\n maxDepth: 10,\n onChange: function () { },\n onCollapseChange: function () { },\n onDragEnd: function () { },\n onDragStart: function () { },\n renderItem: function (_a) {\n var item = _a.item;\n return String(item);\n },\n threshold: 30,\n };\n return Nestable;\n}(react_1.Component));\nexports[\"default\"] = Nestable;\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./src/Nestable/Nestable.tsx","mappings":"AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","sources":["webpack://react-nestable/./src/Nestable/Nestable.tsx?1b20"],"sourcesContent":["\"use strict\";\nvar __extends = (this && this.__extends) || (function () {\n    var extendStatics = function (d, b) {\n        extendStatics = Object.setPrototypeOf ||\n            ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n            function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n        return extendStatics(d, b);\n    };\n    return function (d, b) {\n        if (typeof b !== \"function\" && b !== null)\n            throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n        extendStatics(d, b);\n        function __() { this.constructor = d; }\n        d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n    };\n})();\nvar __assign = (this && this.__assign) || function () {\n    __assign = Object.assign || function(t) {\n        for (var s, i = 1, n = arguments.length; i < n; i++) {\n            s = arguments[i];\n            for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))\n                t[p] = s[p];\n        }\n        return t;\n    };\n    return __assign.apply(this, arguments);\n};\nvar __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {\n    if (k2 === undefined) k2 = k;\n    var desc = Object.getOwnPropertyDescriptor(m, k);\n    if (!desc || (\"get\" in desc ? !m.__esModule : desc.writable || desc.configurable)) {\n      desc = { enumerable: true, get: function() { return m[k]; } };\n    }\n    Object.defineProperty(o, k2, desc);\n}) : (function(o, m, k, k2) {\n    if (k2 === undefined) k2 = k;\n    o[k2] = m[k];\n}));\nvar __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {\n    Object.defineProperty(o, \"default\", { enumerable: true, value: v });\n}) : function(o, v) {\n    o[\"default\"] = v;\n});\nvar __importStar = (this && this.__importStar) || function (mod) {\n    if (mod && mod.__esModule) return mod;\n    var result = {};\n    if (mod != null) for (var k in mod) if (k !== \"default\" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);\n    __setModuleDefault(result, mod);\n    return result;\n};\nvar __spreadArray = (this && this.__spreadArray) || function (to, from, pack) {\n    if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {\n        if (ar || !(i in from)) {\n            if (!ar) ar = Array.prototype.slice.call(from, 0, i);\n            ar[i] = from[i];\n        }\n    }\n    return to.concat(ar || Array.prototype.slice.call(from));\n};\nvar __importDefault = (this && this.__importDefault) || function (mod) {\n    return (mod && mod.__esModule) ? mod : { \"default\": mod };\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\nvar react_1 = __importStar(require(\"react\"));\nvar react_addons_shallow_compare_1 = __importDefault(require(\"react-addons-shallow-compare\"));\nvar react_addons_update_1 = __importDefault(require(\"react-addons-update\"));\nvar classnames_1 = __importDefault(require(\"classnames\"));\nvar utils_1 = require(\"../utils\");\nvar NestableItem_1 = __importDefault(require(\"./NestableItem\"));\nvar Nestable = /** @class */ (function (_super) {\n    __extends(Nestable, _super);\n    function Nestable(props) {\n        var _this = _super.call(this, props) || this;\n        _this.el = null;\n        _this.elCopyStyles = null;\n        _this.mouse = {\n            last: { x: 0 },\n            shift: { x: 0 },\n        };\n        // ––––––––––––––––––––––––––––––––––––\n        // Public Methods\n        // ––––––––––––––––––––––––––––––––––––\n        _this.collapse = function (itemIds) {\n            var _a = _this.props, idProp = _a.idProp, childrenProp = _a.childrenProp, collapsed = _a.collapsed;\n            var items = _this.state.items;\n            if (itemIds === 'NONE') {\n                _this.setState({\n                    collapsedItems: collapsed\n                        ? (0, utils_1.getAllNonEmptyNodesIds)(items, { idProp: idProp, childrenProp: childrenProp })\n                        : [],\n                });\n            }\n            else if (itemIds === 'ALL') {\n                _this.setState({\n                    collapsedItems: collapsed\n                        ? []\n                        : (0, utils_1.getAllNonEmptyNodesIds)(items, { idProp: idProp, childrenProp: childrenProp }),\n                });\n            }\n            else if ((0, utils_1.isArray)(itemIds)) {\n                _this.setState({\n                    collapsedItems: (0, utils_1.getAllNonEmptyNodesIds)(items, { idProp: idProp, childrenProp: childrenProp })\n                        .filter(function (id) { return (itemIds.indexOf(id) > -1) !== collapsed; }),\n                });\n            }\n        };\n        // ––––––––––––––––––––––––––––––––––––\n        // Methods\n        // ––––––––––––––––––––––––––––––––––––\n        _this.startTrackMouse = function () {\n            document.addEventListener('mousemove', _this.onMouseMove);\n            document.addEventListener('mouseup', _this.onDragEnd);\n            document.addEventListener('keydown', _this.onKeyDown);\n        };\n        _this.stopTrackMouse = function () {\n            document.removeEventListener('mousemove', _this.onMouseMove);\n            document.removeEventListener('mouseup', _this.onDragEnd);\n            document.removeEventListener('keydown', _this.onKeyDown);\n            _this.elCopyStyles = null;\n        };\n        _this.getItemDepth = function (item) {\n            var childrenProp = _this.props.childrenProp;\n            var level = 1;\n            if (item[childrenProp].length > 0) {\n                var childrenDepths = item[childrenProp].map(_this.getItemDepth);\n                level += Math.max.apply(Math, childrenDepths);\n            }\n            return level;\n        };\n        _this.checkIfCollapsed = function (item) {\n            var _a = _this.props, collapsed = _a.collapsed, idProp = _a.idProp;\n            var collapsedItems = _this.state.collapsedItems;\n            return !!((collapsedItems.indexOf(item[idProp]) > -1) !== collapsed);\n        };\n        // ––––––––––––––––––––––––––––––––––––\n        // Click handlers or event handlers\n        // ––––––––––––––––––––––––––––––––––––\n        _this.onDragStart = function (e, item) {\n            var onDragStart = _this.props.onDragStart;\n            e.preventDefault();\n            e.stopPropagation();\n            if (!(e.target instanceof Element))\n                return;\n            _this.el = (0, utils_1.closest)(e.target, '.nestable-item');\n            _this.startTrackMouse();\n            _this.onMouseMove(e);\n            onDragStart({ dragItem: item });\n            _this.setState({\n                dragItem: item,\n                itemsOld: _this.state.items,\n            });\n        };\n        _this.onDragEnd = function (e, isCancel) {\n            var onDragEnd = _this.props.onDragEnd;\n            e === null || e === void 0 ? void 0 : e.preventDefault();\n            _this.stopTrackMouse();\n            _this.el = null;\n            onDragEnd();\n            isCancel\n                ? _this.dragRevert()\n                : _this.dragApply();\n        };\n        _this.onMouseMove = function (e) {\n            var _a = _this.props, group = _a.group, threshold = _a.threshold;\n            var dragItem = _this.state.dragItem;\n            var clientX = e.clientX, clientY = e.clientY;\n            var transformProps = (0, utils_1.getTransformProps)(clientX, clientY);\n            var elCopy = document.querySelector(\".nestable-\".concat(group, \" .nestable-drag-layer > .nestable-list\"));\n            if (!_this.elCopyStyles) {\n                var offset = (0, utils_1.getOffsetRect)(_this.el);\n                var scroll_1 = (0, utils_1.getTotalScroll)(_this.el);\n                _this.elCopyStyles = __assign({ marginTop: offset.top - clientY - scroll_1.top, marginLeft: offset.left - clientX - scroll_1.left }, transformProps);\n            }\n            else {\n                _this.elCopyStyles = __assign(__assign({}, _this.elCopyStyles), transformProps);\n                Object.keys(transformProps).forEach(function (key) {\n                    elCopy.style[key] = transformProps[key];\n                });\n                var diffX = clientX - _this.mouse.last.x;\n                if ((diffX >= 0 && _this.mouse.shift.x >= 0) ||\n                    (diffX <= 0 && _this.mouse.shift.x <= 0)) {\n                    _this.mouse.shift.x += diffX;\n                }\n                else {\n                    _this.mouse.shift.x = 0;\n                }\n                _this.mouse.last.x = clientX;\n                if (Math.abs(_this.mouse.shift.x) > threshold) {\n                    if (_this.mouse.shift.x > 0) {\n                        _this.tryIncreaseDepth(dragItem);\n                    }\n                    else {\n                        _this.tryDecreaseDepth(dragItem);\n                    }\n                    _this.mouse.shift.x = 0;\n                }\n            }\n        };\n        _this.onMouseEnter = function (e, item) {\n            e.preventDefault();\n            e.stopPropagation();\n            var _a = _this.props, collapsed = _a.collapsed, idProp = _a.idProp, childrenProp = _a.childrenProp;\n            var dragItem = _this.state.dragItem;\n            if (dragItem[idProp] === item[idProp])\n                return;\n            var pathFrom = _this.getPathById(dragItem[idProp]);\n            var pathTo = _this.getPathById(item[idProp]);\n            // if collapsed by default\n            // and move out the only child\n            // remove parent node from list of open nodes\n            var collapseProps = {};\n            if (collapsed && pathFrom.length > 1) {\n                var parent_1 = _this.getItemByPath(pathFrom.slice(0, -1));\n                if (parent_1[childrenProp].length === 1) {\n                    collapseProps = _this.onToggleCollapse(parent_1, true);\n                }\n            }\n            _this.moveItem({ dragItem: dragItem, pathFrom: pathFrom, pathTo: pathTo }, collapseProps);\n        };\n        _this.onToggleCollapse = function (item, isGetter) {\n            var _a = _this.props, collapsed = _a.collapsed, idProp = _a.idProp;\n            var collapsedItems = _this.state.collapsedItems;\n            var isCollapsed = _this.checkIfCollapsed(item);\n            var newState = {\n                collapsedItems: (isCollapsed !== collapsed)\n                    ? collapsedItems.filter(function (id) { return id !== item[idProp]; })\n                    : collapsedItems.concat(item[idProp]),\n            };\n            if (isGetter) {\n                return newState;\n            }\n            else {\n                _this.setState(newState);\n                _this.onCollapseChange(newState.collapsedItems);\n            }\n        };\n        _this.onCollapseChange = function (ids) {\n            var _a = _this.props, collapsed = _a.collapsed, onCollapseChange = _a.onCollapseChange;\n            onCollapseChange(collapsed ? { openIds: ids } : { closedIds: ids });\n        };\n        _this.onKeyDown = function (e) {\n            if (e.which === 27) {\n                // ESC\n                _this.onDragEnd(null, true);\n            }\n        };\n        _this.state = {\n            items: [],\n            itemsOld: null,\n            dragItem: null,\n            isDirty: false,\n            collapsedItems: [],\n        };\n        return _this;\n    }\n    Nestable.prototype.componentDidMount = function () {\n        var _a = this.props, items = _a.items, childrenProp = _a.childrenProp;\n        // make sure every item has property 'children'\n        items = (0, utils_1.listWithChildren)(items, childrenProp);\n        this.setState({ items: items });\n    };\n    Nestable.prototype.componentDidUpdate = function (prevProps) {\n        var _this = this;\n        var _a = this, _b = _a.props, itemsNew = _b.items, childrenProp = _b.childrenProp, state = _a.state;\n        var isPropsChanged = (0, react_addons_shallow_compare_1.default)(__assign(__assign({}, this), { props: prevProps, state: state }), this.props, state);\n        if (isPropsChanged) {\n            this.stopTrackMouse();\n            this.setState(function (prevState) {\n                var newState = __assign(__assign({}, prevState), { items: (0, utils_1.listWithChildren)(itemsNew, childrenProp), dragItem: null, isDirty: false });\n                if (prevProps.collapsed !== _this.props.collapsed) {\n                    newState.collapsedItems = [];\n                    _this.onCollapseChange(newState.collapsedItems);\n                }\n                return newState;\n            });\n        }\n    };\n    Nestable.prototype.componentWillUnmount = function () {\n        this.stopTrackMouse();\n    };\n    Nestable.prototype.moveItem = function (_a, extraProps) {\n        var dragItem = _a.dragItem, pathFrom = _a.pathFrom, pathTo = _a.pathTo;\n        if (extraProps === void 0) { extraProps = {}; }\n        var _b = this.props, childrenProp = _b.childrenProp, confirmChange = _b.confirmChange;\n        var dragItemSize = this.getItemDepth(dragItem);\n        var items = this.state.items;\n        // the remove action might affect the next position,\n        // so update next coordinates accordingly\n        var realPathTo = this.getRealNextPath(pathFrom, pathTo, dragItemSize);\n        if (realPathTo.length === 0)\n            return;\n        // user can validate every movement\n        var destinationPath = realPathTo.length > pathTo.length\n            ? pathTo\n            : pathTo.slice(0, -1);\n        var destinationParent = this.getItemByPath(destinationPath);\n        if (!confirmChange({ dragItem: dragItem, destinationParent: destinationParent }))\n            return;\n        var removePath = this.getSplicePath(pathFrom, {\n            numToRemove: 1,\n            childrenProp: childrenProp,\n        });\n        var insertPath = this.getSplicePath(realPathTo, {\n            numToRemove: 0,\n            itemsToInsert: [dragItem],\n            childrenProp: childrenProp,\n        });\n        items = (0, react_addons_update_1.default)(items, removePath);\n        items = (0, react_addons_update_1.default)(items, insertPath);\n        this.setState(function (prevState) { return (__assign(__assign(__assign({}, prevState), { items: items, isDirty: true }), extraProps)); });\n        if (extraProps.collapsedItems !== this.state.collapsedItems) {\n            this.onCollapseChange(extraProps.collapsedItems);\n        }\n    };\n    Nestable.prototype.tryIncreaseDepth = function (dragItem) {\n        var _a = this.props, maxDepth = _a.maxDepth, idProp = _a.idProp, childrenProp = _a.childrenProp, collapsed = _a.collapsed;\n        var pathFrom = this.getPathById(dragItem[idProp]);\n        var itemIndex = pathFrom[pathFrom.length - 1];\n        var newDepth = pathFrom.length + this.getItemDepth(dragItem);\n        // has previous sibling and isn't at max depth\n        if (itemIndex > 0 && newDepth <= maxDepth) {\n            var prevSibling = this.getItemByPath(pathFrom.slice(0, -1).concat(itemIndex - 1));\n            // previous sibling is not collapsed\n            if (!prevSibling[childrenProp].length || !this.checkIfCollapsed(prevSibling)) {\n                var pathTo = pathFrom\n                    .slice(0, -1)\n                    .concat(itemIndex - 1)\n                    .concat(prevSibling[childrenProp].length);\n                // if collapsed by default\n                // and was no children here\n                // open this node\n                var collapseProps = {};\n                if (collapsed && !prevSibling[childrenProp].length) {\n                    collapseProps = this.onToggleCollapse(prevSibling, true);\n                }\n                this.moveItem({ dragItem: dragItem, pathFrom: pathFrom, pathTo: pathTo }, collapseProps);\n            }\n        }\n    };\n    Nestable.prototype.tryDecreaseDepth = function (dragItem) {\n        var _a = this.props, idProp = _a.idProp, childrenProp = _a.childrenProp, collapsed = _a.collapsed;\n        var pathFrom = this.getPathById(dragItem[idProp]);\n        var itemIndex = pathFrom[pathFrom.length - 1];\n        // has parent\n        if (pathFrom.length > 1) {\n            var parent_2 = this.getItemByPath(pathFrom.slice(0, -1));\n            // is last (by order) item in array\n            if (itemIndex + 1 === parent_2[childrenProp].length) {\n                var pathTo = pathFrom.slice(0, -1);\n                pathTo[pathTo.length - 1] += 1;\n                // if collapsed by default\n                // and is last (by count) item in array\n                // remove this node from list of open nodes\n                var collapseProps = {};\n                if (collapsed && parent_2[childrenProp].length === 1) {\n                    collapseProps = this.onToggleCollapse(parent_2, true);\n                }\n                this.moveItem({ dragItem: dragItem, pathFrom: pathFrom, pathTo: pathTo }, collapseProps);\n            }\n        }\n    };\n    Nestable.prototype.dragApply = function () {\n        var _a = this.props, onChange = _a.onChange, idProp = _a.idProp;\n        var _b = this.state, items = _b.items, isDirty = _b.isDirty, dragItem = _b.dragItem;\n        this.setState({\n            itemsOld: null,\n            dragItem: null,\n            isDirty: false,\n        });\n        if (onChange && isDirty) {\n            var targetPath = this.getPathById(dragItem[idProp], items);\n            onChange({ items: items, dragItem: dragItem, targetPath: targetPath });\n        }\n    };\n    Nestable.prototype.dragRevert = function () {\n        var itemsOld = this.state.itemsOld;\n        this.setState({\n            items: itemsOld,\n            itemsOld: null,\n            dragItem: null,\n            isDirty: false,\n        });\n    };\n    // ––––––––––––––––––––––––––––––––––––\n    // Getter methods\n    // ––––––––––––––––––––––––––––––––––––\n    Nestable.prototype.getPathById = function (id, items) {\n        var _this = this;\n        if (items === void 0) { items = this.state.items; }\n        var _a = this.props, idProp = _a.idProp, childrenProp = _a.childrenProp;\n        var path = [];\n        items.every(function (item, i) {\n            if (item[idProp] === id) {\n                path.push(i);\n            }\n            else if (item[childrenProp]) {\n                var childrenPath = _this.getPathById(id, item[childrenProp]);\n                if (childrenPath.length) {\n                    path = path.concat(i).concat(childrenPath);\n                }\n            }\n            return path.length === 0;\n        });\n        return path;\n    };\n    Nestable.prototype.getItemByPath = function (path, items) {\n        if (items === void 0) { items = this.state.items; }\n        var childrenProp = this.props.childrenProp;\n        var item = null;\n        path.forEach(function (index) {\n            var list = item ? item[childrenProp] : items;\n            item = list[index];\n        });\n        return item;\n    };\n    Nestable.prototype.getSplicePath = function (path, options) {\n        if (options === void 0) { options = {}; }\n        var splicePath = {};\n        var numToRemove = options.numToRemove || 0;\n        var itemsToInsert = options.itemsToInsert || [];\n        var lastIndex = path.length - 1;\n        var currentPath = splicePath;\n        path.forEach(function (index, i) {\n            var _a;\n            if (i === lastIndex) {\n                currentPath.$splice = [__spreadArray([index, numToRemove], itemsToInsert, true)];\n            }\n            else {\n                var nextPath = {};\n                currentPath[index] = (_a = {}, _a[options.childrenProp] = nextPath, _a);\n                currentPath = nextPath;\n            }\n        });\n        return splicePath;\n    };\n    Nestable.prototype.getRealNextPath = function (prevPath, nextPath, dragItemSize) {\n        var _a = this.props, childrenProp = _a.childrenProp, maxDepth = _a.maxDepth;\n        var ppLastIndex = prevPath.length - 1;\n        var npLastIndex = nextPath.length - 1;\n        var newDepth = nextPath.length + dragItemSize - 1;\n        if (prevPath.length < nextPath.length) {\n            // move into depth\n            var wasShifted_1 = false;\n            // if new depth exceeds max, try to put after item instead of into item\n            if (newDepth > maxDepth && nextPath.length) {\n                return this.getRealNextPath(prevPath, nextPath.slice(0, -1), dragItemSize);\n            }\n            return nextPath.map(function (nextIndex, i) {\n                if (wasShifted_1) {\n                    return i === npLastIndex\n                        ? nextIndex + 1\n                        : nextIndex;\n                }\n                if (typeof prevPath[i] !== 'number') {\n                    return nextIndex;\n                }\n                if (nextPath[i] > prevPath[i] && i === ppLastIndex) {\n                    wasShifted_1 = true;\n                    return nextIndex - 1;\n                }\n                return nextIndex;\n            });\n        }\n        else if (prevPath.length === nextPath.length) {\n            // if move bottom + move to item with children --> make it a first child instead of swap\n            if (nextPath[npLastIndex] > prevPath[npLastIndex]) {\n                var target = this.getItemByPath(nextPath);\n                if (newDepth < maxDepth &&\n                    target[childrenProp] &&\n                    target[childrenProp].length &&\n                    !this.checkIfCollapsed(target)) {\n                    return nextPath\n                        .slice(0, -1)\n                        .concat(nextPath[npLastIndex] - 1)\n                        .concat(0);\n                }\n            }\n        }\n        return nextPath;\n    };\n    Nestable.prototype.getItemOptions = function () {\n        var _a = this.props, renderItem = _a.renderItem, renderCollapseIcon = _a.renderCollapseIcon, handler = _a.handler, disableCollapse = _a.disableCollapse, disableDrag = _a.disableDrag, idProp = _a.idProp, childrenProp = _a.childrenProp;\n        var dragItem = this.state.dragItem;\n        return {\n            dragItem: dragItem,\n            idProp: idProp,\n            childrenProp: childrenProp,\n            disableCollapse: disableCollapse,\n            disableDrag: disableDrag,\n            renderItem: renderItem,\n            renderCollapseIcon: renderCollapseIcon,\n            handler: handler,\n            checkIfCollapsed: this.checkIfCollapsed,\n            onDragStart: this.onDragStart,\n            onMouseEnter: this.onMouseEnter,\n            onToggleCollapse: this.onToggleCollapse,\n        };\n    };\n    // ––––––––––––––––––––––––––––––––––––\n    // Render methods\n    // ––––––––––––––––––––––––––––––––––––\n    Nestable.prototype.renderDragLayer = function () {\n        var _a = this.props, group = _a.group, idProp = _a.idProp;\n        var dragItem = this.state.dragItem;\n        var el = document.querySelector(\".nestable-\".concat(group, \" .nestable-item-\").concat(dragItem[idProp]));\n        var listStyles = {};\n        if (el) {\n            listStyles.width = el.clientWidth;\n        }\n        if (this.elCopyStyles) {\n            listStyles = __assign(__assign({}, listStyles), this.elCopyStyles);\n        }\n        var options = this.getItemOptions();\n        return (react_1.default.createElement(\"div\", { className: \"nestable-drag-layer\" },\n            react_1.default.createElement(\"ol\", { className: \"nestable-list\", style: listStyles },\n                react_1.default.createElement(NestableItem_1.default, { item: dragItem, options: options, isCopy: true }))));\n    };\n    Nestable.prototype.render = function () {\n        var _a = this.props, group = _a.group, className = _a.className, idProp = _a.idProp;\n        var _b = this.state, items = _b.items, dragItem = _b.dragItem;\n        var options = this.getItemOptions();\n        return (react_1.default.createElement(\"div\", { className: (0, classnames_1.default)(className, 'nestable', \"nestable-\".concat(group), { 'is-drag-active': dragItem }) },\n            react_1.default.createElement(\"ol\", { className: \"nestable-list\" }, items.map(function (item, i) {\n                return (react_1.default.createElement(NestableItem_1.default, { key: item[idProp], index: i, item: item, options: options }));\n            })),\n            dragItem && this.renderDragLayer()));\n    };\n    Nestable.defaultProps = {\n        childrenProp: 'children',\n        collapsed: false,\n        confirmChange: function () { return true; },\n        disableCollapse: false,\n        disableDrag: false,\n        group: Math.random().toString(36).slice(2),\n        idProp: 'id',\n        items: [],\n        maxDepth: 10,\n        onChange: function () { },\n        onCollapseChange: function () { },\n        onDragEnd: function () { },\n        onDragStart: function () { },\n        renderItem: function (_a) {\n            var item = _a.item;\n            return String(item);\n        },\n        threshold: 30,\n    };\n    return Nestable;\n}(react_1.Component));\nexports.default = Nestable;\n"],"names":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///./src/Nestable/Nestable.tsx\n"); +eval("\nvar __extends = (this && this.__extends) || (function () {\n var extendStatics = function (d, b) {\n extendStatics = Object.setPrototypeOf ||\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n return extendStatics(d, b);\n };\n return function (d, b) {\n if (typeof b !== \"function\" && b !== null)\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n extendStatics(d, b);\n function __() { this.constructor = d; }\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n };\n})();\nvar __assign = (this && this.__assign) || function () {\n __assign = Object.assign || function(t) {\n for (var s, i = 1, n = arguments.length; i < n; i++) {\n s = arguments[i];\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))\n t[p] = s[p];\n }\n return t;\n };\n return __assign.apply(this, arguments);\n};\nvar __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n var desc = Object.getOwnPropertyDescriptor(m, k);\n if (!desc || (\"get\" in desc ? !m.__esModule : desc.writable || desc.configurable)) {\n desc = { enumerable: true, get: function() { return m[k]; } };\n }\n Object.defineProperty(o, k2, desc);\n}) : (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n o[k2] = m[k];\n}));\nvar __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {\n Object.defineProperty(o, \"default\", { enumerable: true, value: v });\n}) : function(o, v) {\n o[\"default\"] = v;\n});\nvar __importStar = (this && this.__importStar) || function (mod) {\n if (mod && mod.__esModule) return mod;\n var result = {};\n if (mod != null) for (var k in mod) if (k !== \"default\" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);\n __setModuleDefault(result, mod);\n return result;\n};\nvar __spreadArray = (this && this.__spreadArray) || function (to, from, pack) {\n if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {\n if (ar || !(i in from)) {\n if (!ar) ar = Array.prototype.slice.call(from, 0, i);\n ar[i] = from[i];\n }\n }\n return to.concat(ar || Array.prototype.slice.call(from));\n};\nvar __importDefault = (this && this.__importDefault) || function (mod) {\n return (mod && mod.__esModule) ? mod : { \"default\": mod };\n};\nObject.defineProperty(exports, \"__esModule\", ({ value: true }));\nvar react_1 = __importStar(__webpack_require__(/*! react */ \"./node_modules/react/index.js\"));\nvar react_addons_shallow_compare_1 = __importDefault(__webpack_require__(/*! react-addons-shallow-compare */ \"./node_modules/react-addons-shallow-compare/index.js\"));\nvar react_addons_update_1 = __importDefault(__webpack_require__(/*! react-addons-update */ \"./node_modules/react-addons-update/index.js\"));\nvar classnames_1 = __importDefault(__webpack_require__(/*! classnames */ \"./node_modules/classnames/index.js\"));\nvar utils_1 = __webpack_require__(/*! ../utils */ \"./src/utils.ts\");\nvar NestableItem_1 = __importDefault(__webpack_require__(/*! ./NestableItem */ \"./src/Nestable/NestableItem.tsx\"));\nvar Nestable = /** @class */ (function (_super) {\n __extends(Nestable, _super);\n function Nestable(props) {\n var _this = _super.call(this, props) || this;\n _this.el = null;\n _this.elCopyStyles = null;\n _this.mouse = {\n last: { x: 0 },\n shift: { x: 0 },\n };\n // ––––––––––––––––––––––––––––––––––––\n // Public Methods\n // ––––––––––––––––––––––––––––––––––––\n _this.collapse = function (itemIds) {\n var _a = _this.props, idProp = _a.idProp, childrenProp = _a.childrenProp, collapsed = _a.collapsed;\n var items = _this.state.items;\n if (itemIds === 'NONE') {\n _this.setState({\n collapsedItems: collapsed\n ? (0, utils_1.getAllNonEmptyNodesIds)(items, { idProp: idProp, childrenProp: childrenProp })\n : [],\n });\n }\n else if (itemIds === 'ALL') {\n _this.setState({\n collapsedItems: collapsed\n ? []\n : (0, utils_1.getAllNonEmptyNodesIds)(items, { idProp: idProp, childrenProp: childrenProp }),\n });\n }\n else if ((0, utils_1.isArray)(itemIds)) {\n _this.setState({\n collapsedItems: (0, utils_1.getAllNonEmptyNodesIds)(items, { idProp: idProp, childrenProp: childrenProp })\n .filter(function (id) { return (itemIds.indexOf(id) > -1) !== collapsed; }),\n });\n }\n };\n // ––––––––––––––––––––––––––––––––––––\n // Methods\n // ––––––––––––––––––––––––––––––––––––\n _this.startTrackMouse = function () {\n document.addEventListener('mousemove', _this.onMouseMove);\n document.addEventListener('mouseup', _this.onDragEnd);\n document.addEventListener('keydown', _this.onKeyDown);\n };\n _this.stopTrackMouse = function () {\n document.removeEventListener('mousemove', _this.onMouseMove);\n document.removeEventListener('mouseup', _this.onDragEnd);\n document.removeEventListener('keydown', _this.onKeyDown);\n _this.elCopyStyles = null;\n };\n _this.getItemDepth = function (item) {\n var childrenProp = _this.props.childrenProp;\n var level = 1;\n if (item[childrenProp].length > 0) {\n var childrenDepths = item[childrenProp].map(_this.getItemDepth);\n level += Math.max.apply(Math, childrenDepths);\n }\n return level;\n };\n _this.checkIfCollapsed = function (item) {\n var _a = _this.props, collapsed = _a.collapsed, idProp = _a.idProp;\n var collapsedItems = _this.state.collapsedItems;\n return !!((collapsedItems.indexOf(item[idProp]) > -1) !== collapsed);\n };\n // ––––––––––––––––––––––––––––––––––––\n // Click handlers or event handlers\n // ––––––––––––––––––––––––––––––––––––\n _this.onDragStart = function (e, item) {\n var onDragStart = _this.props.onDragStart;\n e.preventDefault();\n e.stopPropagation();\n if (!(e.target instanceof Element))\n return;\n _this.el = (0, utils_1.closest)(e.target, '.nestable-item');\n _this.startTrackMouse();\n _this.onMouseMove(e);\n onDragStart({ dragItem: item });\n _this.setState({\n dragItem: item,\n itemsOld: _this.state.items,\n });\n };\n _this.onDragEnd = function (e, isCancel) {\n var onDragEnd = _this.props.onDragEnd;\n e === null || e === void 0 ? void 0 : e.preventDefault();\n _this.stopTrackMouse();\n _this.el = null;\n onDragEnd();\n isCancel\n ? _this.dragRevert()\n : _this.dragApply();\n };\n _this.onMouseMove = function (e) {\n var _a = _this.props, group = _a.group, threshold = _a.threshold;\n var dragItem = _this.state.dragItem;\n var clientX = e.clientX, clientY = e.clientY;\n var transformProps = (0, utils_1.getTransformProps)(clientX, clientY);\n var elCopy = document.querySelector(\".nestable-\".concat(group, \" .nestable-drag-layer > .nestable-list\"));\n if (!_this.elCopyStyles) {\n var offset = (0, utils_1.getOffsetRect)(_this.el);\n var scroll_1 = (0, utils_1.getTotalScroll)(_this.el);\n _this.elCopyStyles = __assign({ marginTop: offset.top - clientY - scroll_1.top, marginLeft: offset.left - clientX - scroll_1.left }, transformProps);\n }\n else {\n _this.elCopyStyles = __assign(__assign({}, _this.elCopyStyles), transformProps);\n Object.keys(transformProps).forEach(function (key) {\n elCopy.style[key] = transformProps[key];\n });\n var diffX = clientX - _this.mouse.last.x;\n if ((diffX >= 0 && _this.mouse.shift.x >= 0) ||\n (diffX <= 0 && _this.mouse.shift.x <= 0)) {\n _this.mouse.shift.x += diffX;\n }\n else {\n _this.mouse.shift.x = 0;\n }\n _this.mouse.last.x = clientX;\n if (Math.abs(_this.mouse.shift.x) > threshold) {\n if (_this.mouse.shift.x > 0) {\n _this.tryIncreaseDepth(dragItem);\n }\n else {\n _this.tryDecreaseDepth(dragItem);\n }\n _this.mouse.shift.x = 0;\n }\n }\n };\n _this.onMouseEnter = function (e, item) {\n e.preventDefault();\n e.stopPropagation();\n var _a = _this.props, collapsed = _a.collapsed, idProp = _a.idProp, childrenProp = _a.childrenProp;\n var dragItem = _this.state.dragItem;\n if (dragItem[idProp] === item[idProp])\n return;\n var pathFrom = _this.getPathById(dragItem[idProp]);\n var pathTo = _this.getPathById(item[idProp]);\n // if collapsed by default\n // and move out the only child\n // remove parent node from list of open nodes\n var collapseProps = {};\n if (collapsed && pathFrom.length > 1) {\n var parent_1 = _this.getItemByPath(pathFrom.slice(0, -1));\n if (parent_1[childrenProp].length === 1) {\n collapseProps = _this.onToggleCollapse(parent_1, true);\n }\n }\n _this.moveItem({ dragItem: dragItem, pathFrom: pathFrom, pathTo: pathTo }, collapseProps);\n };\n _this.onToggleCollapse = function (item, isGetter) {\n var _a = _this.props, collapsed = _a.collapsed, idProp = _a.idProp;\n var collapsedItems = _this.state.collapsedItems;\n var isCollapsed = _this.checkIfCollapsed(item);\n var newState = {\n collapsedItems: (isCollapsed !== collapsed)\n ? collapsedItems.filter(function (id) { return id !== item[idProp]; })\n : collapsedItems.concat(item[idProp]),\n };\n if (isGetter) {\n return newState;\n }\n else {\n _this.setState(newState);\n _this.onCollapseChange(newState.collapsedItems);\n }\n };\n _this.onCollapseChange = function (ids) {\n var _a = _this.props, collapsed = _a.collapsed, onCollapseChange = _a.onCollapseChange;\n onCollapseChange(collapsed ? { openIds: ids } : { closedIds: ids });\n };\n _this.onKeyDown = function (e) {\n if (e.which === 27) {\n // ESC\n _this.onDragEnd(null, true);\n }\n };\n _this.state = {\n items: [],\n itemsOld: null,\n dragItem: null,\n isDirty: false,\n collapsedItems: [],\n };\n return _this;\n }\n Nestable.prototype.componentDidMount = function () {\n var _a = this.props, items = _a.items, childrenProp = _a.childrenProp;\n // make sure every item has property 'children'\n items = (0, utils_1.listWithChildren)(items, childrenProp);\n this.setState({ items: items });\n };\n Nestable.prototype.componentDidUpdate = function (prevProps) {\n var _this = this;\n var _a = this, _b = _a.props, itemsNew = _b.items, childrenProp = _b.childrenProp, state = _a.state;\n var isPropsChanged = (0, react_addons_shallow_compare_1.default)(__assign(__assign({}, this), { props: prevProps, state: state }), this.props, state);\n if (isPropsChanged) {\n this.stopTrackMouse();\n this.setState(function (prevState) {\n var newState = __assign(__assign({}, prevState), { items: (0, utils_1.listWithChildren)(itemsNew, childrenProp), dragItem: null, isDirty: false });\n if (prevProps.collapsed !== _this.props.collapsed) {\n newState.collapsedItems = [];\n _this.onCollapseChange(newState.collapsedItems);\n }\n return newState;\n });\n }\n };\n Nestable.prototype.componentWillUnmount = function () {\n this.stopTrackMouse();\n };\n Nestable.prototype.moveItem = function (_a, extraProps) {\n var dragItem = _a.dragItem, pathFrom = _a.pathFrom, pathTo = _a.pathTo;\n if (extraProps === void 0) { extraProps = {}; }\n var _b = this.props, childrenProp = _b.childrenProp, confirmChange = _b.confirmChange;\n var dragItemSize = this.getItemDepth(dragItem);\n var items = this.state.items;\n // the remove action might affect the next position,\n // so update next coordinates accordingly\n var realPathTo = this.getRealNextPath(pathFrom, pathTo, dragItemSize);\n if (realPathTo.length === 0)\n return;\n // user can validate every movement\n var destinationPath = realPathTo.length > pathTo.length\n ? pathTo\n : pathTo.slice(0, -1);\n var destinationParent = this.getItemByPath(destinationPath);\n var removePath = this.getSplicePath(pathFrom, {\n numToRemove: 1,\n childrenProp: childrenProp,\n });\n var insertPath = this.getSplicePath(realPathTo, {\n numToRemove: 0,\n itemsToInsert: [dragItem],\n childrenProp: childrenProp,\n });\n items = (0, react_addons_update_1.default)(items, removePath);\n items = (0, react_addons_update_1.default)(items, insertPath);\n if (!confirmChange({ dragItem: dragItem, destinationParent: destinationParent, items: items }))\n return;\n this.setState(function (prevState) { return (__assign(__assign(__assign({}, prevState), { items: items, isDirty: true }), extraProps)); });\n if (extraProps.collapsedItems !== this.state.collapsedItems) {\n this.onCollapseChange(extraProps.collapsedItems);\n }\n };\n Nestable.prototype.tryIncreaseDepth = function (dragItem) {\n var _a = this.props, maxDepth = _a.maxDepth, idProp = _a.idProp, childrenProp = _a.childrenProp, collapsed = _a.collapsed;\n var pathFrom = this.getPathById(dragItem[idProp]);\n var itemIndex = pathFrom[pathFrom.length - 1];\n var newDepth = pathFrom.length + this.getItemDepth(dragItem);\n // has previous sibling and isn't at max depth\n if (itemIndex > 0 && newDepth <= maxDepth) {\n var prevSibling = this.getItemByPath(pathFrom.slice(0, -1).concat(itemIndex - 1));\n // previous sibling is not collapsed\n if (!prevSibling[childrenProp].length || !this.checkIfCollapsed(prevSibling)) {\n var pathTo = pathFrom\n .slice(0, -1)\n .concat(itemIndex - 1)\n .concat(prevSibling[childrenProp].length);\n // if collapsed by default\n // and was no children here\n // open this node\n var collapseProps = {};\n if (collapsed && !prevSibling[childrenProp].length) {\n collapseProps = this.onToggleCollapse(prevSibling, true);\n }\n this.moveItem({ dragItem: dragItem, pathFrom: pathFrom, pathTo: pathTo }, collapseProps);\n }\n }\n };\n Nestable.prototype.tryDecreaseDepth = function (dragItem) {\n var _a = this.props, idProp = _a.idProp, childrenProp = _a.childrenProp, collapsed = _a.collapsed;\n var pathFrom = this.getPathById(dragItem[idProp]);\n var itemIndex = pathFrom[pathFrom.length - 1];\n // has parent\n if (pathFrom.length > 1) {\n var parent_2 = this.getItemByPath(pathFrom.slice(0, -1));\n // is last (by order) item in array\n if (itemIndex + 1 === parent_2[childrenProp].length) {\n var pathTo = pathFrom.slice(0, -1);\n pathTo[pathTo.length - 1] += 1;\n // if collapsed by default\n // and is last (by count) item in array\n // remove this node from list of open nodes\n var collapseProps = {};\n if (collapsed && parent_2[childrenProp].length === 1) {\n collapseProps = this.onToggleCollapse(parent_2, true);\n }\n this.moveItem({ dragItem: dragItem, pathFrom: pathFrom, pathTo: pathTo }, collapseProps);\n }\n }\n };\n Nestable.prototype.dragApply = function () {\n var _a = this.props, onChange = _a.onChange, idProp = _a.idProp;\n var _b = this.state, items = _b.items, isDirty = _b.isDirty, dragItem = _b.dragItem;\n this.setState({\n itemsOld: null,\n dragItem: null,\n isDirty: false,\n });\n if (onChange && isDirty) {\n var targetPath = this.getPathById(dragItem[idProp], items);\n onChange({ items: items, dragItem: dragItem, targetPath: targetPath });\n }\n };\n Nestable.prototype.dragRevert = function () {\n var itemsOld = this.state.itemsOld;\n this.setState({\n items: itemsOld,\n itemsOld: null,\n dragItem: null,\n isDirty: false,\n });\n };\n // ––––––––––––––––––––––––––––––––––––\n // Getter methods\n // ––––––––––––––––––––––––––––––––––––\n Nestable.prototype.getPathById = function (id, items) {\n var _this = this;\n if (items === void 0) { items = this.state.items; }\n var _a = this.props, idProp = _a.idProp, childrenProp = _a.childrenProp;\n var path = [];\n items.every(function (item, i) {\n if (item[idProp] === id) {\n path.push(i);\n }\n else if (item[childrenProp]) {\n var childrenPath = _this.getPathById(id, item[childrenProp]);\n if (childrenPath.length) {\n path = path.concat(i).concat(childrenPath);\n }\n }\n return path.length === 0;\n });\n return path;\n };\n Nestable.prototype.getItemByPath = function (path, items) {\n if (items === void 0) { items = this.state.items; }\n var childrenProp = this.props.childrenProp;\n var item = null;\n path.forEach(function (index) {\n var list = item ? item[childrenProp] : items;\n item = list[index];\n });\n return item;\n };\n Nestable.prototype.getSplicePath = function (path, options) {\n if (options === void 0) { options = {}; }\n var splicePath = {};\n var numToRemove = options.numToRemove || 0;\n var itemsToInsert = options.itemsToInsert || [];\n var lastIndex = path.length - 1;\n var currentPath = splicePath;\n path.forEach(function (index, i) {\n var _a;\n if (i === lastIndex) {\n currentPath.$splice = [__spreadArray([index, numToRemove], itemsToInsert, true)];\n }\n else {\n var nextPath = {};\n currentPath[index] = (_a = {}, _a[options.childrenProp] = nextPath, _a);\n currentPath = nextPath;\n }\n });\n return splicePath;\n };\n Nestable.prototype.getRealNextPath = function (prevPath, nextPath, dragItemSize) {\n var _a = this.props, childrenProp = _a.childrenProp, maxDepth = _a.maxDepth;\n var ppLastIndex = prevPath.length - 1;\n var npLastIndex = nextPath.length - 1;\n var newDepth = nextPath.length + dragItemSize - 1;\n if (prevPath.length < nextPath.length) {\n // move into depth\n var wasShifted_1 = false;\n // if new depth exceeds max, try to put after item instead of into item\n if (newDepth > maxDepth && nextPath.length) {\n return this.getRealNextPath(prevPath, nextPath.slice(0, -1), dragItemSize);\n }\n return nextPath.map(function (nextIndex, i) {\n if (wasShifted_1) {\n return i === npLastIndex\n ? nextIndex + 1\n : nextIndex;\n }\n if (typeof prevPath[i] !== 'number') {\n return nextIndex;\n }\n if (nextPath[i] > prevPath[i] && i === ppLastIndex) {\n wasShifted_1 = true;\n return nextIndex - 1;\n }\n return nextIndex;\n });\n }\n else if (prevPath.length === nextPath.length) {\n // if move bottom + move to item with children --> make it a first child instead of swap\n if (nextPath[npLastIndex] > prevPath[npLastIndex]) {\n var target = this.getItemByPath(nextPath);\n if (newDepth < maxDepth &&\n target[childrenProp] &&\n target[childrenProp].length &&\n !this.checkIfCollapsed(target)) {\n return nextPath\n .slice(0, -1)\n .concat(nextPath[npLastIndex] - 1)\n .concat(0);\n }\n }\n }\n return nextPath;\n };\n Nestable.prototype.getItemOptions = function () {\n var _a = this.props, renderItem = _a.renderItem, renderCollapseIcon = _a.renderCollapseIcon, handler = _a.handler, disableCollapse = _a.disableCollapse, disableDrag = _a.disableDrag, idProp = _a.idProp, childrenProp = _a.childrenProp;\n var dragItem = this.state.dragItem;\n return {\n dragItem: dragItem,\n idProp: idProp,\n childrenProp: childrenProp,\n disableCollapse: disableCollapse,\n disableDrag: disableDrag,\n renderItem: renderItem,\n renderCollapseIcon: renderCollapseIcon,\n handler: handler,\n checkIfCollapsed: this.checkIfCollapsed,\n onDragStart: this.onDragStart,\n onMouseEnter: this.onMouseEnter,\n onToggleCollapse: this.onToggleCollapse,\n };\n };\n // ––––––––––––––––––––––––––––––––––––\n // Render methods\n // ––––––––––––––––––––––––––––––––––––\n Nestable.prototype.renderDragLayer = function () {\n var _a = this.props, group = _a.group, idProp = _a.idProp;\n var dragItem = this.state.dragItem;\n var el = document.querySelector(\".nestable-\".concat(group, \" .nestable-item-\").concat(dragItem[idProp]));\n var listStyles = {};\n if (el) {\n listStyles.width = el.clientWidth;\n }\n if (this.elCopyStyles) {\n listStyles = __assign(__assign({}, listStyles), this.elCopyStyles);\n }\n var options = this.getItemOptions();\n return (react_1.default.createElement(\"div\", { className: \"nestable-drag-layer\" },\n react_1.default.createElement(\"ol\", { className: \"nestable-list\", style: listStyles },\n react_1.default.createElement(NestableItem_1.default, { item: dragItem, options: options, isCopy: true }))));\n };\n Nestable.prototype.render = function () {\n var _a = this.props, group = _a.group, className = _a.className, idProp = _a.idProp;\n var _b = this.state, items = _b.items, dragItem = _b.dragItem;\n var options = this.getItemOptions();\n return (react_1.default.createElement(\"div\", { className: (0, classnames_1.default)(className, 'nestable', \"nestable-\".concat(group), { 'is-drag-active': dragItem }) },\n react_1.default.createElement(\"ol\", { className: \"nestable-list\" }, items.map(function (item, i) {\n return (react_1.default.createElement(NestableItem_1.default, { key: item[idProp], index: i, item: item, options: options }));\n })),\n dragItem && this.renderDragLayer()));\n };\n Nestable.defaultProps = {\n childrenProp: 'children',\n collapsed: false,\n confirmChange: function () { return true; },\n disableCollapse: false,\n disableDrag: false,\n group: Math.random().toString(36).slice(2),\n idProp: 'id',\n items: [],\n maxDepth: 10,\n onChange: function () { },\n onCollapseChange: function () { },\n onDragEnd: function () { },\n onDragStart: function () { },\n renderItem: function (_a) {\n var item = _a.item;\n return String(item);\n },\n threshold: 30,\n };\n return Nestable;\n}(react_1.Component));\nexports[\"default\"] = Nestable;\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./src/Nestable/Nestable.tsx","mappings":"AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","sources":["webpack://react-nestable/./src/Nestable/Nestable.tsx?1b20"],"sourcesContent":["\"use strict\";\nvar __extends = (this && this.__extends) || (function () {\n    var extendStatics = function (d, b) {\n        extendStatics = Object.setPrototypeOf ||\n            ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\n            function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\n        return extendStatics(d, b);\n    };\n    return function (d, b) {\n        if (typeof b !== \"function\" && b !== null)\n            throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\n        extendStatics(d, b);\n        function __() { this.constructor = d; }\n        d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\n    };\n})();\nvar __assign = (this && this.__assign) || function () {\n    __assign = Object.assign || function(t) {\n        for (var s, i = 1, n = arguments.length; i < n; i++) {\n            s = arguments[i];\n            for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))\n                t[p] = s[p];\n        }\n        return t;\n    };\n    return __assign.apply(this, arguments);\n};\nvar __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {\n    if (k2 === undefined) k2 = k;\n    var desc = Object.getOwnPropertyDescriptor(m, k);\n    if (!desc || (\"get\" in desc ? !m.__esModule : desc.writable || desc.configurable)) {\n      desc = { enumerable: true, get: function() { return m[k]; } };\n    }\n    Object.defineProperty(o, k2, desc);\n}) : (function(o, m, k, k2) {\n    if (k2 === undefined) k2 = k;\n    o[k2] = m[k];\n}));\nvar __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {\n    Object.defineProperty(o, \"default\", { enumerable: true, value: v });\n}) : function(o, v) {\n    o[\"default\"] = v;\n});\nvar __importStar = (this && this.__importStar) || function (mod) {\n    if (mod && mod.__esModule) return mod;\n    var result = {};\n    if (mod != null) for (var k in mod) if (k !== \"default\" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);\n    __setModuleDefault(result, mod);\n    return result;\n};\nvar __spreadArray = (this && this.__spreadArray) || function (to, from, pack) {\n    if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {\n        if (ar || !(i in from)) {\n            if (!ar) ar = Array.prototype.slice.call(from, 0, i);\n            ar[i] = from[i];\n        }\n    }\n    return to.concat(ar || Array.prototype.slice.call(from));\n};\nvar __importDefault = (this && this.__importDefault) || function (mod) {\n    return (mod && mod.__esModule) ? mod : { \"default\": mod };\n};\nObject.defineProperty(exports, \"__esModule\", { value: true });\nvar react_1 = __importStar(require(\"react\"));\nvar react_addons_shallow_compare_1 = __importDefault(require(\"react-addons-shallow-compare\"));\nvar react_addons_update_1 = __importDefault(require(\"react-addons-update\"));\nvar classnames_1 = __importDefault(require(\"classnames\"));\nvar utils_1 = require(\"../utils\");\nvar NestableItem_1 = __importDefault(require(\"./NestableItem\"));\nvar Nestable = /** @class */ (function (_super) {\n    __extends(Nestable, _super);\n    function Nestable(props) {\n        var _this = _super.call(this, props) || this;\n        _this.el = null;\n        _this.elCopyStyles = null;\n        _this.mouse = {\n            last: { x: 0 },\n            shift: { x: 0 },\n        };\n        // ––––––––––––––––––––––––––––––––––––\n        // Public Methods\n        // ––––––––––––––––––––––––––––––––––––\n        _this.collapse = function (itemIds) {\n            var _a = _this.props, idProp = _a.idProp, childrenProp = _a.childrenProp, collapsed = _a.collapsed;\n            var items = _this.state.items;\n            if (itemIds === 'NONE') {\n                _this.setState({\n                    collapsedItems: collapsed\n                        ? (0, utils_1.getAllNonEmptyNodesIds)(items, { idProp: idProp, childrenProp: childrenProp })\n                        : [],\n                });\n            }\n            else if (itemIds === 'ALL') {\n                _this.setState({\n                    collapsedItems: collapsed\n                        ? []\n                        : (0, utils_1.getAllNonEmptyNodesIds)(items, { idProp: idProp, childrenProp: childrenProp }),\n                });\n            }\n            else if ((0, utils_1.isArray)(itemIds)) {\n                _this.setState({\n                    collapsedItems: (0, utils_1.getAllNonEmptyNodesIds)(items, { idProp: idProp, childrenProp: childrenProp })\n                        .filter(function (id) { return (itemIds.indexOf(id) > -1) !== collapsed; }),\n                });\n            }\n        };\n        // ––––––––––––––––––––––––––––––––––––\n        // Methods\n        // ––––––––––––––––––––––––––––––––––––\n        _this.startTrackMouse = function () {\n            document.addEventListener('mousemove', _this.onMouseMove);\n            document.addEventListener('mouseup', _this.onDragEnd);\n            document.addEventListener('keydown', _this.onKeyDown);\n        };\n        _this.stopTrackMouse = function () {\n            document.removeEventListener('mousemove', _this.onMouseMove);\n            document.removeEventListener('mouseup', _this.onDragEnd);\n            document.removeEventListener('keydown', _this.onKeyDown);\n            _this.elCopyStyles = null;\n        };\n        _this.getItemDepth = function (item) {\n            var childrenProp = _this.props.childrenProp;\n            var level = 1;\n            if (item[childrenProp].length > 0) {\n                var childrenDepths = item[childrenProp].map(_this.getItemDepth);\n                level += Math.max.apply(Math, childrenDepths);\n            }\n            return level;\n        };\n        _this.checkIfCollapsed = function (item) {\n            var _a = _this.props, collapsed = _a.collapsed, idProp = _a.idProp;\n            var collapsedItems = _this.state.collapsedItems;\n            return !!((collapsedItems.indexOf(item[idProp]) > -1) !== collapsed);\n        };\n        // ––––––––––––––––––––––––––––––––––––\n        // Click handlers or event handlers\n        // ––––––––––––––––––––––––––––––––––––\n        _this.onDragStart = function (e, item) {\n            var onDragStart = _this.props.onDragStart;\n            e.preventDefault();\n            e.stopPropagation();\n            if (!(e.target instanceof Element))\n                return;\n            _this.el = (0, utils_1.closest)(e.target, '.nestable-item');\n            _this.startTrackMouse();\n            _this.onMouseMove(e);\n            onDragStart({ dragItem: item });\n            _this.setState({\n                dragItem: item,\n                itemsOld: _this.state.items,\n            });\n        };\n        _this.onDragEnd = function (e, isCancel) {\n            var onDragEnd = _this.props.onDragEnd;\n            e === null || e === void 0 ? void 0 : e.preventDefault();\n            _this.stopTrackMouse();\n            _this.el = null;\n            onDragEnd();\n            isCancel\n                ? _this.dragRevert()\n                : _this.dragApply();\n        };\n        _this.onMouseMove = function (e) {\n            var _a = _this.props, group = _a.group, threshold = _a.threshold;\n            var dragItem = _this.state.dragItem;\n            var clientX = e.clientX, clientY = e.clientY;\n            var transformProps = (0, utils_1.getTransformProps)(clientX, clientY);\n            var elCopy = document.querySelector(\".nestable-\".concat(group, \" .nestable-drag-layer > .nestable-list\"));\n            if (!_this.elCopyStyles) {\n                var offset = (0, utils_1.getOffsetRect)(_this.el);\n                var scroll_1 = (0, utils_1.getTotalScroll)(_this.el);\n                _this.elCopyStyles = __assign({ marginTop: offset.top - clientY - scroll_1.top, marginLeft: offset.left - clientX - scroll_1.left }, transformProps);\n            }\n            else {\n                _this.elCopyStyles = __assign(__assign({}, _this.elCopyStyles), transformProps);\n                Object.keys(transformProps).forEach(function (key) {\n                    elCopy.style[key] = transformProps[key];\n                });\n                var diffX = clientX - _this.mouse.last.x;\n                if ((diffX >= 0 && _this.mouse.shift.x >= 0) ||\n                    (diffX <= 0 && _this.mouse.shift.x <= 0)) {\n                    _this.mouse.shift.x += diffX;\n                }\n                else {\n                    _this.mouse.shift.x = 0;\n                }\n                _this.mouse.last.x = clientX;\n                if (Math.abs(_this.mouse.shift.x) > threshold) {\n                    if (_this.mouse.shift.x > 0) {\n                        _this.tryIncreaseDepth(dragItem);\n                    }\n                    else {\n                        _this.tryDecreaseDepth(dragItem);\n                    }\n                    _this.mouse.shift.x = 0;\n                }\n            }\n        };\n        _this.onMouseEnter = function (e, item) {\n            e.preventDefault();\n            e.stopPropagation();\n            var _a = _this.props, collapsed = _a.collapsed, idProp = _a.idProp, childrenProp = _a.childrenProp;\n            var dragItem = _this.state.dragItem;\n            if (dragItem[idProp] === item[idProp])\n                return;\n            var pathFrom = _this.getPathById(dragItem[idProp]);\n            var pathTo = _this.getPathById(item[idProp]);\n            // if collapsed by default\n            // and move out the only child\n            // remove parent node from list of open nodes\n            var collapseProps = {};\n            if (collapsed && pathFrom.length > 1) {\n                var parent_1 = _this.getItemByPath(pathFrom.slice(0, -1));\n                if (parent_1[childrenProp].length === 1) {\n                    collapseProps = _this.onToggleCollapse(parent_1, true);\n                }\n            }\n            _this.moveItem({ dragItem: dragItem, pathFrom: pathFrom, pathTo: pathTo }, collapseProps);\n        };\n        _this.onToggleCollapse = function (item, isGetter) {\n            var _a = _this.props, collapsed = _a.collapsed, idProp = _a.idProp;\n            var collapsedItems = _this.state.collapsedItems;\n            var isCollapsed = _this.checkIfCollapsed(item);\n            var newState = {\n                collapsedItems: (isCollapsed !== collapsed)\n                    ? collapsedItems.filter(function (id) { return id !== item[idProp]; })\n                    : collapsedItems.concat(item[idProp]),\n            };\n            if (isGetter) {\n                return newState;\n            }\n            else {\n                _this.setState(newState);\n                _this.onCollapseChange(newState.collapsedItems);\n            }\n        };\n        _this.onCollapseChange = function (ids) {\n            var _a = _this.props, collapsed = _a.collapsed, onCollapseChange = _a.onCollapseChange;\n            onCollapseChange(collapsed ? { openIds: ids } : { closedIds: ids });\n        };\n        _this.onKeyDown = function (e) {\n            if (e.which === 27) {\n                // ESC\n                _this.onDragEnd(null, true);\n            }\n        };\n        _this.state = {\n            items: [],\n            itemsOld: null,\n            dragItem: null,\n            isDirty: false,\n            collapsedItems: [],\n        };\n        return _this;\n    }\n    Nestable.prototype.componentDidMount = function () {\n        var _a = this.props, items = _a.items, childrenProp = _a.childrenProp;\n        // make sure every item has property 'children'\n        items = (0, utils_1.listWithChildren)(items, childrenProp);\n        this.setState({ items: items });\n    };\n    Nestable.prototype.componentDidUpdate = function (prevProps) {\n        var _this = this;\n        var _a = this, _b = _a.props, itemsNew = _b.items, childrenProp = _b.childrenProp, state = _a.state;\n        var isPropsChanged = (0, react_addons_shallow_compare_1.default)(__assign(__assign({}, this), { props: prevProps, state: state }), this.props, state);\n        if (isPropsChanged) {\n            this.stopTrackMouse();\n            this.setState(function (prevState) {\n                var newState = __assign(__assign({}, prevState), { items: (0, utils_1.listWithChildren)(itemsNew, childrenProp), dragItem: null, isDirty: false });\n                if (prevProps.collapsed !== _this.props.collapsed) {\n                    newState.collapsedItems = [];\n                    _this.onCollapseChange(newState.collapsedItems);\n                }\n                return newState;\n            });\n        }\n    };\n    Nestable.prototype.componentWillUnmount = function () {\n        this.stopTrackMouse();\n    };\n    Nestable.prototype.moveItem = function (_a, extraProps) {\n        var dragItem = _a.dragItem, pathFrom = _a.pathFrom, pathTo = _a.pathTo;\n        if (extraProps === void 0) { extraProps = {}; }\n        var _b = this.props, childrenProp = _b.childrenProp, confirmChange = _b.confirmChange;\n        var dragItemSize = this.getItemDepth(dragItem);\n        var items = this.state.items;\n        // the remove action might affect the next position,\n        // so update next coordinates accordingly\n        var realPathTo = this.getRealNextPath(pathFrom, pathTo, dragItemSize);\n        if (realPathTo.length === 0)\n            return;\n        // user can validate every movement\n        var destinationPath = realPathTo.length > pathTo.length\n            ? pathTo\n            : pathTo.slice(0, -1);\n        var destinationParent = this.getItemByPath(destinationPath);\n        var removePath = this.getSplicePath(pathFrom, {\n            numToRemove: 1,\n            childrenProp: childrenProp,\n        });\n        var insertPath = this.getSplicePath(realPathTo, {\n            numToRemove: 0,\n            itemsToInsert: [dragItem],\n            childrenProp: childrenProp,\n        });\n        items = (0, react_addons_update_1.default)(items, removePath);\n        items = (0, react_addons_update_1.default)(items, insertPath);\n        if (!confirmChange({ dragItem: dragItem, destinationParent: destinationParent, items: items }))\n            return;\n        this.setState(function (prevState) { return (__assign(__assign(__assign({}, prevState), { items: items, isDirty: true }), extraProps)); });\n        if (extraProps.collapsedItems !== this.state.collapsedItems) {\n            this.onCollapseChange(extraProps.collapsedItems);\n        }\n    };\n    Nestable.prototype.tryIncreaseDepth = function (dragItem) {\n        var _a = this.props, maxDepth = _a.maxDepth, idProp = _a.idProp, childrenProp = _a.childrenProp, collapsed = _a.collapsed;\n        var pathFrom = this.getPathById(dragItem[idProp]);\n        var itemIndex = pathFrom[pathFrom.length - 1];\n        var newDepth = pathFrom.length + this.getItemDepth(dragItem);\n        // has previous sibling and isn't at max depth\n        if (itemIndex > 0 && newDepth <= maxDepth) {\n            var prevSibling = this.getItemByPath(pathFrom.slice(0, -1).concat(itemIndex - 1));\n            // previous sibling is not collapsed\n            if (!prevSibling[childrenProp].length || !this.checkIfCollapsed(prevSibling)) {\n                var pathTo = pathFrom\n                    .slice(0, -1)\n                    .concat(itemIndex - 1)\n                    .concat(prevSibling[childrenProp].length);\n                // if collapsed by default\n                // and was no children here\n                // open this node\n                var collapseProps = {};\n                if (collapsed && !prevSibling[childrenProp].length) {\n                    collapseProps = this.onToggleCollapse(prevSibling, true);\n                }\n                this.moveItem({ dragItem: dragItem, pathFrom: pathFrom, pathTo: pathTo }, collapseProps);\n            }\n        }\n    };\n    Nestable.prototype.tryDecreaseDepth = function (dragItem) {\n        var _a = this.props, idProp = _a.idProp, childrenProp = _a.childrenProp, collapsed = _a.collapsed;\n        var pathFrom = this.getPathById(dragItem[idProp]);\n        var itemIndex = pathFrom[pathFrom.length - 1];\n        // has parent\n        if (pathFrom.length > 1) {\n            var parent_2 = this.getItemByPath(pathFrom.slice(0, -1));\n            // is last (by order) item in array\n            if (itemIndex + 1 === parent_2[childrenProp].length) {\n                var pathTo = pathFrom.slice(0, -1);\n                pathTo[pathTo.length - 1] += 1;\n                // if collapsed by default\n                // and is last (by count) item in array\n                // remove this node from list of open nodes\n                var collapseProps = {};\n                if (collapsed && parent_2[childrenProp].length === 1) {\n                    collapseProps = this.onToggleCollapse(parent_2, true);\n                }\n                this.moveItem({ dragItem: dragItem, pathFrom: pathFrom, pathTo: pathTo }, collapseProps);\n            }\n        }\n    };\n    Nestable.prototype.dragApply = function () {\n        var _a = this.props, onChange = _a.onChange, idProp = _a.idProp;\n        var _b = this.state, items = _b.items, isDirty = _b.isDirty, dragItem = _b.dragItem;\n        this.setState({\n            itemsOld: null,\n            dragItem: null,\n            isDirty: false,\n        });\n        if (onChange && isDirty) {\n            var targetPath = this.getPathById(dragItem[idProp], items);\n            onChange({ items: items, dragItem: dragItem, targetPath: targetPath });\n        }\n    };\n    Nestable.prototype.dragRevert = function () {\n        var itemsOld = this.state.itemsOld;\n        this.setState({\n            items: itemsOld,\n            itemsOld: null,\n            dragItem: null,\n            isDirty: false,\n        });\n    };\n    // ––––––––––––––––––––––––––––––––––––\n    // Getter methods\n    // ––––––––––––––––––––––––––––––––––––\n    Nestable.prototype.getPathById = function (id, items) {\n        var _this = this;\n        if (items === void 0) { items = this.state.items; }\n        var _a = this.props, idProp = _a.idProp, childrenProp = _a.childrenProp;\n        var path = [];\n        items.every(function (item, i) {\n            if (item[idProp] === id) {\n                path.push(i);\n            }\n            else if (item[childrenProp]) {\n                var childrenPath = _this.getPathById(id, item[childrenProp]);\n                if (childrenPath.length) {\n                    path = path.concat(i).concat(childrenPath);\n                }\n            }\n            return path.length === 0;\n        });\n        return path;\n    };\n    Nestable.prototype.getItemByPath = function (path, items) {\n        if (items === void 0) { items = this.state.items; }\n        var childrenProp = this.props.childrenProp;\n        var item = null;\n        path.forEach(function (index) {\n            var list = item ? item[childrenProp] : items;\n            item = list[index];\n        });\n        return item;\n    };\n    Nestable.prototype.getSplicePath = function (path, options) {\n        if (options === void 0) { options = {}; }\n        var splicePath = {};\n        var numToRemove = options.numToRemove || 0;\n        var itemsToInsert = options.itemsToInsert || [];\n        var lastIndex = path.length - 1;\n        var currentPath = splicePath;\n        path.forEach(function (index, i) {\n            var _a;\n            if (i === lastIndex) {\n                currentPath.$splice = [__spreadArray([index, numToRemove], itemsToInsert, true)];\n            }\n            else {\n                var nextPath = {};\n                currentPath[index] = (_a = {}, _a[options.childrenProp] = nextPath, _a);\n                currentPath = nextPath;\n            }\n        });\n        return splicePath;\n    };\n    Nestable.prototype.getRealNextPath = function (prevPath, nextPath, dragItemSize) {\n        var _a = this.props, childrenProp = _a.childrenProp, maxDepth = _a.maxDepth;\n        var ppLastIndex = prevPath.length - 1;\n        var npLastIndex = nextPath.length - 1;\n        var newDepth = nextPath.length + dragItemSize - 1;\n        if (prevPath.length < nextPath.length) {\n            // move into depth\n            var wasShifted_1 = false;\n            // if new depth exceeds max, try to put after item instead of into item\n            if (newDepth > maxDepth && nextPath.length) {\n                return this.getRealNextPath(prevPath, nextPath.slice(0, -1), dragItemSize);\n            }\n            return nextPath.map(function (nextIndex, i) {\n                if (wasShifted_1) {\n                    return i === npLastIndex\n                        ? nextIndex + 1\n                        : nextIndex;\n                }\n                if (typeof prevPath[i] !== 'number') {\n                    return nextIndex;\n                }\n                if (nextPath[i] > prevPath[i] && i === ppLastIndex) {\n                    wasShifted_1 = true;\n                    return nextIndex - 1;\n                }\n                return nextIndex;\n            });\n        }\n        else if (prevPath.length === nextPath.length) {\n            // if move bottom + move to item with children --> make it a first child instead of swap\n            if (nextPath[npLastIndex] > prevPath[npLastIndex]) {\n                var target = this.getItemByPath(nextPath);\n                if (newDepth < maxDepth &&\n                    target[childrenProp] &&\n                    target[childrenProp].length &&\n                    !this.checkIfCollapsed(target)) {\n                    return nextPath\n                        .slice(0, -1)\n                        .concat(nextPath[npLastIndex] - 1)\n                        .concat(0);\n                }\n            }\n        }\n        return nextPath;\n    };\n    Nestable.prototype.getItemOptions = function () {\n        var _a = this.props, renderItem = _a.renderItem, renderCollapseIcon = _a.renderCollapseIcon, handler = _a.handler, disableCollapse = _a.disableCollapse, disableDrag = _a.disableDrag, idProp = _a.idProp, childrenProp = _a.childrenProp;\n        var dragItem = this.state.dragItem;\n        return {\n            dragItem: dragItem,\n            idProp: idProp,\n            childrenProp: childrenProp,\n            disableCollapse: disableCollapse,\n            disableDrag: disableDrag,\n            renderItem: renderItem,\n            renderCollapseIcon: renderCollapseIcon,\n            handler: handler,\n            checkIfCollapsed: this.checkIfCollapsed,\n            onDragStart: this.onDragStart,\n            onMouseEnter: this.onMouseEnter,\n            onToggleCollapse: this.onToggleCollapse,\n        };\n    };\n    // ––––––––––––––––––––––––––––––––––––\n    // Render methods\n    // ––––––––––––––––––––––––––––––––––––\n    Nestable.prototype.renderDragLayer = function () {\n        var _a = this.props, group = _a.group, idProp = _a.idProp;\n        var dragItem = this.state.dragItem;\n        var el = document.querySelector(\".nestable-\".concat(group, \" .nestable-item-\").concat(dragItem[idProp]));\n        var listStyles = {};\n        if (el) {\n            listStyles.width = el.clientWidth;\n        }\n        if (this.elCopyStyles) {\n            listStyles = __assign(__assign({}, listStyles), this.elCopyStyles);\n        }\n        var options = this.getItemOptions();\n        return (react_1.default.createElement(\"div\", { className: \"nestable-drag-layer\" },\n            react_1.default.createElement(\"ol\", { className: \"nestable-list\", style: listStyles },\n                react_1.default.createElement(NestableItem_1.default, { item: dragItem, options: options, isCopy: true }))));\n    };\n    Nestable.prototype.render = function () {\n        var _a = this.props, group = _a.group, className = _a.className, idProp = _a.idProp;\n        var _b = this.state, items = _b.items, dragItem = _b.dragItem;\n        var options = this.getItemOptions();\n        return (react_1.default.createElement(\"div\", { className: (0, classnames_1.default)(className, 'nestable', \"nestable-\".concat(group), { 'is-drag-active': dragItem }) },\n            react_1.default.createElement(\"ol\", { className: \"nestable-list\" }, items.map(function (item, i) {\n                return (react_1.default.createElement(NestableItem_1.default, { key: item[idProp], index: i, item: item, options: options }));\n            })),\n            dragItem && this.renderDragLayer()));\n    };\n    Nestable.defaultProps = {\n        childrenProp: 'children',\n        collapsed: false,\n        confirmChange: function () { return true; },\n        disableCollapse: false,\n        disableDrag: false,\n        group: Math.random().toString(36).slice(2),\n        idProp: 'id',\n        items: [],\n        maxDepth: 10,\n        onChange: function () { },\n        onCollapseChange: function () { },\n        onDragEnd: function () { },\n        onDragStart: function () { },\n        renderItem: function (_a) {\n            var item = _a.item;\n            return String(item);\n        },\n        threshold: 30,\n    };\n    return Nestable;\n}(react_1.Component));\nexports.default = Nestable;\n"],"names":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///./src/Nestable/Nestable.tsx\n"); /***/ }), @@ -459,7 +459,7 @@ module.exports = "data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGlu /******/ /******/ /* webpack/runtime/getFullHash */ /******/ (() => { -/******/ __webpack_require__.h = () => ("ad0b346140837f3ebe5e") +/******/ __webpack_require__.h = () => ("eed37ffcec21b8e07583") /******/ })(); /******/ /******/ /* webpack/runtime/hasOwnProperty shorthand */