1 line
No EOL
85 KiB
Text
1 line
No EOL
85 KiB
Text
{"version":3,"file":"vue-easy-dnd.esm.min.js","sources":["../../src/vue-easy-dnd/vue-easy-dnd.esm.js"],"sourcesContent":["import { reactive, openBlock, createBlock, resolveDynamicComponent, normalizeClass, createSlots, withCtx, renderSlot, normalizeProps, guardReactiveProps, createElementBlock, createCommentVNode, renderList, TransitionGroup, h, nextTick } from 'vue';\n\nfunction mitt(n){return {all:n=n||new Map,on:function(t,e){var i=n.get(t);i?i.push(e):n.set(t,[e]);},off:function(t,e){var i=n.get(t);i&&(e?i.splice(i.indexOf(e)>>>0,1):n.set(t,[]));},emit:function(t,e){var i=n.get(t);i&&i.slice().map(function(n){n(e);}),(i=n.get(\"*\"))&&i.slice().map(function(n){n(t,e);});}}}\n\n/**\r\n * This is the class of the global object that holds the state of the drag and drop during its progress. It emits events\r\n * reporting its state evolution during the progress of the drag and drop. Its data is reactive and listeners can be\r\n * attached to it using the method on.\r\n */\r\nclass DnD {\r\n\r\n inProgress = false;\r\n type = null;\r\n data = null;\r\n source = null;\r\n top = null;\r\n position = null;\r\n eventBus = mitt();\r\n success = null;\r\n\r\n startDrag (source, event, x, y, type, data) {\r\n this.type = type;\r\n this.data = data;\r\n this.source = source;\r\n this.position = { x, y };\r\n this.top = null;\r\n this.inProgress = true;\r\n this.emit(event, 'dragstart');\r\n this.emit(event, 'dragtopchanged', { previousTop: null });\r\n }\r\n\r\n resetVariables () {\r\n this.inProgress = false;\r\n this.data = null;\r\n this.source = null;\r\n this.position = null;\r\n this.success = null;\r\n }\r\n\r\n stopDrag (event) {\r\n this.success = this.top !== null && this.top['compatibleMode'] && this.top['dropAllowed'];\r\n if (this.top !== null) {\r\n this.emit(event, 'drop');\r\n }\r\n this.emit(event, 'dragend');\r\n this.resetVariables();\r\n }\r\n\r\n cancelDrag (event) {\r\n this.success = false;\r\n this.emit(event, 'dragend');\r\n this.resetVariables();\r\n }\r\n\r\n mouseMove (event, comp) {\r\n if (this.inProgress) {\r\n let prevent = false;\r\n const previousTop = this.top;\r\n if (comp === null) {\r\n // The mouse move event reached the top of the document without hitting a drop component.\r\n this.top = null;\r\n prevent = true;\r\n }\r\n else if (comp['isDropMask']) {\r\n // The mouse move event bubbled until it reached a drop mask.\r\n this.top = null;\r\n prevent = true;\r\n }\r\n else if (comp['candidate'](this.type, this.data, this.source)) {\r\n // The mouse move event bubbled until it reached a drop component that participates in the current drag operation.\r\n this.top = comp;\r\n prevent = true;\r\n }\r\n\r\n if (prevent) {\r\n // We prevent the mouse move event from bubbling further up the tree because it reached the foremost drop component and that component is all that matters.\r\n event.stopPropagation();\r\n }\r\n if (this.top !== previousTop) {\r\n this.emit(event.detail.native, 'dragtopchanged', { previousTop: previousTop });\r\n }\r\n this.position = {\r\n x: event.detail.x,\r\n y: event.detail.y\r\n };\r\n this.emit(event.detail.native, 'dragpositionchanged');\r\n }\r\n }\r\n\r\n emit (native, event, data = {}) {\r\n this.eventBus.emit(event, {\r\n type: this.type,\r\n data: this.data,\r\n top: this.top,\r\n source: this.source,\r\n position: this.position,\r\n success: this.success,\r\n native,\r\n ...data\r\n });\r\n }\r\n\r\n on (event, callback) {\r\n this.eventBus.on(event, callback);\r\n }\r\n\r\n off (event, callback) {\r\n this.eventBus.off(event, callback);\r\n }\r\n}\r\n\r\nconst dnd = reactive(new DnD());\n\nvar DragAwareMixin = {\r\n data () {\r\n return {\r\n isDropMask: false\r\n };\r\n },\r\n computed: {\r\n dragInProgress () {\r\n return dnd.inProgress;\r\n },\r\n dragData () {\r\n return dnd.data;\r\n },\r\n dragType () {\r\n return dnd.type;\r\n },\r\n dragPosition () {\r\n return dnd.position;\r\n },\r\n dragSource () {\r\n return dnd.source;\r\n },\r\n dragTop () {\r\n return dnd.top;\r\n }\r\n }\r\n};\n\n/**\r\n * This files contains the primitives required to create drag images from HTML elements that serve as models. A snapshot\r\n * of the computed styles of the model elements is taken when creating the drag image, so that it will look the same as\r\n * the model, no matter where the drag images is grafted into the DOM.\r\n */\r\n\r\n/**\r\n * Creates a drag image using the given element as model.\r\n */\r\nfunction createDragImage (el) {\r\n const clone = deepClone(el);\r\n clone.style.position = 'fixed';\r\n clone.style.margin = '0';\r\n clone.style['z-index'] = '1000';\r\n clone.style.transition = 'opacity 0.2s';\r\n return clone;\r\n}\r\n\r\n/**\r\n * Clones the given element and all its descendants.\r\n */\r\nfunction deepClone (el) {\r\n const clone = el.cloneNode(true);\r\n copyStyle(el, clone);\r\n const vSrcElements = el.getElementsByTagName('*');\r\n const vDstElements = clone.getElementsByTagName('*');\r\n for (let i = vSrcElements.length; i--;) {\r\n const vSrcElement = vSrcElements[i];\r\n const vDstElement = vDstElements[i];\r\n copyStyle(vSrcElement, vDstElement);\r\n }\r\n return clone;\r\n}\r\n\r\n/**\r\n * Copy the computed styles from src to destination.\r\n */\r\nfunction copyStyle (src, destination) {\r\n const computedStyle = window.getComputedStyle(src);\r\n for (const key of computedStyle) {\r\n if (key === 'width') {\r\n // IE11\r\n const width = computedStyle.getPropertyValue('box-sizing') === 'border-box' ?\r\n src.clientWidth :\r\n src.clientWidth - parseFloat(computedStyle.paddingLeft) - parseFloat(computedStyle.paddingRight);\r\n destination.style.setProperty('width', width + 'px');\r\n }\r\n else if (key === 'height') {\r\n // IE11\r\n const height = computedStyle.getPropertyValue('box-sizing') === 'border-box' ?\r\n src.clientHeight :\r\n src.clientHeight - parseFloat(computedStyle.paddingTop) - parseFloat(computedStyle.paddingBottom);\r\n destination.style.setProperty('height', height + 'px');\r\n }\r\n else {\r\n destination.style.setProperty(key, computedStyle.getPropertyValue(key), computedStyle.getPropertyPriority(key));\r\n }\r\n }\r\n destination.style.pointerEvents = 'none';\r\n}\n\n// Forked from https://gist.github.com/gre/296291b8ce0d8fe6e1c3ea4f1d1c5c3b\r\nconst regex = /(auto|scroll)/;\r\n\r\nconst style = (node, prop) =>\r\n getComputedStyle(node, null).getPropertyValue(prop);\r\n\r\nconst scroll = (node) =>\r\n regex.test(\r\n style(node, 'overflow') +\r\n style(node, 'overflow-y') +\r\n style(node, 'overflow-x'));\r\n\r\nconst scrollparent = (node) =>\r\n !node || node===document.body\r\n ? document.body\r\n : scroll(node)\r\n ? node\r\n : scrollparent(node.parentNode);\n\n// Forked from https://github.com/bennadel/JavaScript-Demos/blob/master/demos/window-edge-scrolling/index.htm\r\n// Code was altered to work with scrollable containers\r\n\r\nvar timer = null;\r\n\r\nfunction cancelScrollAction () {\r\n clearTimeout(timer);\r\n}\r\n\r\nfunction performEdgeScroll (event, container, clientX, clientY, edgeSize) {\r\n if (!container || !edgeSize) {\r\n cancelScrollAction();\r\n return false;\r\n }\r\n \r\n // NOTE: Much of the information here, with regard to document dimensions,\r\n // viewport dimensions, and window scrolling is derived from JavaScript.info.\r\n // I am consuming it here primarily as NOTE TO SELF.\r\n // --\r\n // Read More: https://javascript.info/size-and-scroll-window\r\n // --\r\n // CAUTION: The viewport and document dimensions can all be CACHED and then\r\n // recalculated on window-resize events (for the most part). I am keeping it\r\n // all here in the mousemove event handler to remove as many of the moving\r\n // parts as possible and keep the demo as simple as possible.\r\n \r\n // Get the viewport-relative coordinates of the mousemove event.\r\n var rect = container.getBoundingClientRect();\r\n var isBody = container === document.body;\r\n \r\n var viewportX = clientX - rect.left;\r\n var viewportY = clientY - rect.top;\r\n if (isBody) {\r\n viewportX = clientX;\r\n viewportY = clientY;\r\n }\r\n \r\n // Get the viewport dimensions.\r\n var viewportWidth = rect.width;\r\n var viewportHeight = rect.height;\r\n if (isBody) {\r\n viewportWidth = document.documentElement.clientWidth;\r\n viewportHeight = document.documentElement.clientHeight;\r\n }\r\n \r\n // Next, we need to determine if the mouse is within the \"edge\" of the\r\n // viewport, which may require scrolling the window. To do this, we need to\r\n // calculate the boundaries of the edge in the viewport (these coordinates\r\n // are relative to the viewport grid system).\r\n var edgeTop = edgeSize;\r\n var edgeLeft = edgeSize;\r\n var edgeBottom = ( viewportHeight - edgeSize );\r\n var edgeRight = ( viewportWidth - edgeSize );\r\n \r\n var isInLeftEdge = ( viewportX < edgeLeft );\r\n var isInRightEdge = ( viewportX > edgeRight );\r\n var isInTopEdge = ( viewportY < edgeTop );\r\n var isInBottomEdge = ( viewportY > edgeBottom );\r\n \r\n // If the mouse is not in the viewport edge, there's no need to calculate\r\n // anything else.\r\n if (!(isInLeftEdge || isInRightEdge || isInTopEdge || isInBottomEdge)) {\r\n cancelScrollAction();\r\n return false;\r\n }\r\n \r\n // If we made it this far, the user's mouse is located within the edge of the\r\n // viewport. As such, we need to check to see if scrolling needs to be done.\r\n \r\n // Get the document dimensions.\r\n var documentWidth = Math.max(\r\n container.scrollWidth,\r\n container.offsetWidth,\r\n container.clientWidth\r\n );\r\n var documentHeight = Math.max(\r\n container.scrollHeight,\r\n container.offsetHeight,\r\n container.clientHeight\r\n );\r\n \r\n // Calculate the maximum scroll offset in each direction. Since you can only\r\n // scroll the overflow portion of the document, the maximum represents the\r\n // length of the document that is NOT in the viewport.\r\n var maxScrollX = (documentWidth - viewportWidth);\r\n var maxScrollY = (documentHeight - viewportHeight);\r\n \r\n // As we examine the mousemove event, we want to adjust the window scroll in\r\n // immediate response to the event; but, we also want to continue adjusting\r\n // the window scroll if the user rests their mouse in the edge boundary. To\r\n // do this, we'll invoke the adjustment logic immediately. Then, we'll setup\r\n // a timer that continues to invoke the adjustment logic while the window can\r\n // still be scrolled in a particular direction.\r\n (function checkForWindowScroll () {\r\n cancelScrollAction();\r\n \r\n if (adjustWindowScroll()) {\r\n timer = setTimeout( checkForWindowScroll, 30 );\r\n }\r\n })();\r\n \r\n // Adjust the window scroll based on the user's mouse position. Returns True\r\n // or False depending on whether or not the window scroll was changed.\r\n function adjustWindowScroll () {\r\n // Get the current scroll position of the document.\r\n var currentScrollX = container.scrollLeft;\r\n var currentScrollY = container.scrollTop;\r\n if (isBody) {\r\n currentScrollX = window.pageXOffset;\r\n currentScrollY = window.pageYOffset;\r\n }\r\n \r\n // Determine if the window can be scrolled in any particular direction.\r\n var canScrollUp = (currentScrollY > 0);\r\n var canScrollDown = (currentScrollY < maxScrollY);\r\n var canScrollLeft = (currentScrollX > 0);\r\n var canScrollRight = (currentScrollX < maxScrollX);\r\n \r\n // Since we can potentially scroll in two directions at the same time,\r\n // let's keep track of the next scroll, starting with the current scroll.\r\n // Each of these values can then be adjusted independently in the logic\r\n // below.\r\n var nextScrollX = currentScrollX;\r\n var nextScrollY = currentScrollY;\r\n \r\n // As we examine the mouse position within the edge, we want to make the\r\n // incremental scroll changes more \"intense\" the closer that the user\r\n // gets the viewport edge. As such, we'll calculate the percentage that\r\n // the user has made it \"through the edge\" when calculating the delta.\r\n // Then, that use that percentage to back-off from the \"max\" step value.\r\n var maxStep = 50;\r\n \r\n // Should we scroll left?\r\n if (isInLeftEdge && canScrollLeft) {\r\n const intensity = ((edgeLeft - viewportX) / edgeSize);\r\n nextScrollX = (nextScrollX - (maxStep * intensity));\r\n }\r\n // Should we scroll right?\r\n else if (isInRightEdge && canScrollRight) {\r\n const intensity = ((viewportX - edgeRight) / edgeSize);\r\n nextScrollX = (nextScrollX + (maxStep * intensity));\r\n }\r\n \r\n // Should we scroll up?\r\n if (isInTopEdge && canScrollUp) {\r\n const intensity = ((edgeTop - viewportY) / edgeSize);\r\n nextScrollY = (nextScrollY - (maxStep * intensity));\r\n }\r\n // Should we scroll down?\r\n else if (isInBottomEdge && canScrollDown) {\r\n const intensity = ((viewportY - edgeBottom) / edgeSize);\r\n nextScrollY = (nextScrollY + (maxStep * intensity));\r\n }\r\n \r\n // Sanitize invalid maximums. An invalid scroll offset won't break the\r\n // subsequent .scrollTo() call; however, it will make it harder to\r\n // determine if the .scrollTo() method should have been called in the\r\n // first place.\r\n nextScrollX = Math.max(0, Math.min(maxScrollX, nextScrollX));\r\n nextScrollY = Math.max(0, Math.min(maxScrollY, nextScrollY));\r\n \r\n if (\r\n (nextScrollX !== currentScrollX) ||\r\n (nextScrollY !== currentScrollY)\r\n ) {\r\n (isBody ? window : container).scrollTo(nextScrollX, nextScrollY);\r\n return true;\r\n }\r\n else {\r\n return false;\r\n }\r\n }\r\n \r\n return true;\r\n}\n\nvar DragMixin = {\r\n mixins: [DragAwareMixin],\r\n props: {\r\n type: {\r\n type: String,\r\n default: null\r\n },\r\n data: {\r\n default: null\r\n },\r\n dragImageOpacity: {\r\n type: Number,\r\n default: 0.7\r\n },\r\n disabled: {\r\n type: Boolean,\r\n default: false\r\n },\r\n goBack: {\r\n type: Boolean,\r\n default: false\r\n },\r\n handle: {\r\n type: String,\r\n default: null\r\n },\r\n delta: {\r\n type: Number,\r\n default: 0\r\n },\r\n delay: {\r\n type: Number,\r\n default: 0\r\n },\r\n dragClass: {\r\n type: String,\r\n default: null\r\n },\r\n vibration: {\r\n type: Number,\r\n default: 0\r\n },\r\n scrollingEdgeSize: {\r\n type: Number,\r\n default: 100\r\n }\r\n },\r\n emits: ['dragstart', 'dragend', 'cut', 'copy'],\r\n data () {\r\n return {\r\n dragInitialised: false,\r\n dragStarted: false,\r\n ignoreNextClick: false,\r\n initialUserSelect: null,\r\n downEvent: null,\r\n startPosition: null,\r\n delayTimer: null,\r\n scrollContainer: null\r\n };\r\n },\r\n computed: {\r\n cssClasses () {\r\n const clazz = {\r\n 'dnd-drag': true\r\n };\r\n if (!this.disabled) {\r\n return {\r\n ...clazz,\r\n 'drag-source': this.dragInProgress && this.dragSource === this,\r\n 'drag-mode-copy': this.currentDropMode === 'copy',\r\n 'drag-mode-cut': this.currentDropMode === 'cut',\r\n 'drag-mode-reordering': this.currentDropMode === 'reordering',\r\n 'drag-no-handle': !this.handle\r\n };\r\n }\r\n else {\r\n return clazz;\r\n }\r\n },\r\n currentDropMode () {\r\n if (this.dragInProgress && this.dragSource === this) {\r\n if (this.dragTop && this.dragTop['dropAllowed']) {\r\n if (this.dragTop['reordering']) {\r\n return 'reordering';\r\n }\r\n else {\r\n return this.dragTop['mode'];\r\n }\r\n }\r\n else {\r\n return null;\r\n }\r\n }\r\n else {\r\n return null;\r\n }\r\n }\r\n },\r\n methods: {\r\n onSelectStart (e) {\r\n e.stopPropagation();\r\n e.preventDefault();\r\n },\r\n performVibration () {\r\n // If browser can perform vibration and user has defined a vibration, perform it\r\n if (this.vibration > 0 && window.navigator && window.navigator.vibrate) {\r\n window.navigator.vibrate(this.vibration);\r\n }\r\n },\r\n onMouseDown (e) {\r\n let target = null;\r\n let goodButton = false;\r\n if (e.type === 'mousedown') {\r\n const mouse = e;\r\n target = e.target;\r\n goodButton = mouse.buttons === 1;\r\n }\r\n else {\r\n const touch = e;\r\n target = touch.touches[0].target;\r\n goodButton = true;\r\n }\r\n\r\n if (this.disabled || this.downEvent !== null || !goodButton) {\r\n return;\r\n }\r\n\r\n // Check that the target element is eligible for starting a drag\r\n // Includes checking against the handle selector\r\n // or whether the element contains 'dnd-no-drag' class (which should disable dragging from that\r\n // sub-element of a draggable parent)\r\n const goodTarget = !target.matches('.dnd-no-drag, .dnd-no-drag *') &&\r\n (\r\n !this.handle ||\r\n target.matches(this.handle + ', ' + this.handle + ' *')\r\n );\r\n\r\n if (!goodTarget) {\r\n return;\r\n }\r\n\r\n this.scrollContainer = scrollparent(target);\r\n this.initialUserSelect = document.body.style.userSelect;\r\n document.documentElement.style.userSelect = 'none'; // Permet au drag de se poursuivre normalement même\r\n // quand on quitte un élémént avec overflow: hidden.\r\n this.dragStarted = false;\r\n this.downEvent = e;\r\n if (this.downEvent.type === 'mousedown') {\r\n const mouse = e;\r\n this.startPosition = {\r\n x: mouse.clientX,\r\n y: mouse.clientY\r\n };\r\n }\r\n else {\r\n const touch = e;\r\n this.startPosition = {\r\n x: touch.touches[0].clientX,\r\n y: touch.touches[0].clientY\r\n };\r\n }\r\n\r\n if (this.delay) {\r\n this.dragInitialised = false;\r\n clearTimeout(this.delayTimer);\r\n this.delayTimer = setTimeout(() => {\r\n this.dragInitialised = true;\r\n this.performVibration();\r\n }, this.delay);\r\n }\r\n else {\r\n this.dragInitialised = true;\r\n this.performVibration();\r\n }\r\n\r\n document.addEventListener('click', this.onMouseClick, true);\r\n document.addEventListener('mouseup', this.onMouseUp);\r\n document.addEventListener('touchend', this.onMouseUp);\r\n document.addEventListener('selectstart', this.onSelectStart);\r\n document.addEventListener('keyup', this.onKeyUp);\r\n\r\n setTimeout(() => {\r\n document.addEventListener('mousemove', this.onMouseMove);\r\n document.addEventListener('touchmove', this.onMouseMove, { passive: false });\r\n document.addEventListener('easy-dnd-move', this.onEasyDnDMove);\r\n }, 0);\r\n\r\n // Prevents event from bubbling to ancestor drag components and initiate several drags at the same time\r\n e.stopPropagation();\r\n },\r\n // Prevent the user from accidentally causing a click event\r\n // if they have just attempted a drag event\r\n onMouseClick (e) {\r\n if (this.ignoreNextClick) {\r\n e.preventDefault();\r\n e.stopPropagation && e.stopPropagation();\r\n e.stopImmediatePropagation && e.stopImmediatePropagation();\r\n this.ignoreNextClick = false;\r\n return false;\r\n }\r\n },\r\n onMouseMove (e) {\r\n // We ignore the mousemove event that follows touchend :\r\n if (this.downEvent === null) return;\r\n\r\n // On touch devices, we ignore fake mouse events and deal with touch events only.\r\n if (this.downEvent.type === 'touchstart' && e.type === 'mousemove') return;\r\n\r\n // Find out event target and pointer position :\r\n let target = null;\r\n let x = null;\r\n let y = null;\r\n if (e.type === 'touchmove') {\r\n const touch = e;\r\n x = touch.touches[0].clientX;\r\n y = touch.touches[0].clientY;\r\n target = document.elementFromPoint(x, y);\r\n if (!target) {\r\n // Mouse going off screen. Ignore event.\r\n return;\r\n }\r\n }\r\n else {\r\n const mouse = e;\r\n x = mouse.clientX;\r\n y = mouse.clientY;\r\n target = mouse.target;\r\n }\r\n\r\n // Distance between current event and start position :\r\n const dist = Math.sqrt(Math.pow(this.startPosition.x - x, 2) + Math.pow(this.startPosition.y - y, 2));\r\n\r\n // If the drag has not begun yet and distance from initial point is greater than delta, we start the drag :\r\n if (!this.dragStarted && dist > this.delta) {\r\n // If they have dragged greater than the delta before the delay period has ended,\r\n // It means that they attempted to perform another action (such as scrolling) on the page\r\n if (!this.dragInitialised) {\r\n clearTimeout(this.delayTimer);\r\n }\r\n else {\r\n this.ignoreNextClick = true;\r\n this.dragStarted = true;\r\n dnd.startDrag(this, this.downEvent, this.startPosition.x, this.startPosition.y, this.type, this.data);\r\n document.documentElement.classList.add('drag-in-progress');\r\n }\r\n }\r\n\r\n // Dispatch custom easy-dnd-move event :\r\n if (this.dragStarted) {\r\n // If cursor/touch is at edge of container, perform scroll if available\r\n // If this.dragTop is defined, it means they are dragging on top of another DropList/EasyDnd component\r\n // if dropTop is a DropList, use the scrollingEdgeSize of that container if it exists, otherwise use the scrollingEdgeSize of the Drag component\r\n const currEdgeSize = this.dragTop && this.dragTop.$props.scrollingEdgeSize !== undefined ?\r\n this.dragTop.$props.scrollingEdgeSize :\r\n this.scrollingEdgeSize;\r\n\r\n if (currEdgeSize) {\r\n const currScrollContainer = this.dragTop ? scrollparent(this.dragTop.$el) : this.scrollContainer;\r\n performEdgeScroll(e, currScrollContainer, x, y, currEdgeSize);\r\n }\r\n else {\r\n cancelScrollAction();\r\n }\r\n\r\n const custom = new CustomEvent('easy-dnd-move', {\r\n bubbles: true,\r\n cancelable: true,\r\n detail: {\r\n x,\r\n y,\r\n native: e\r\n }\r\n });\r\n target.dispatchEvent(custom);\r\n }\r\n\r\n // Prevent scroll on touch devices if they were performing a drag\r\n if (this.dragInitialised && e.cancelable) {\r\n e.preventDefault();\r\n }\r\n },\r\n onEasyDnDMove (e) {\r\n dnd.mouseMove(e, null);\r\n },\r\n onMouseUp (e) {\r\n // On touch devices, we ignore fake mouse events and deal with touch events only.\r\n if (this.downEvent.type === 'touchstart' && e.type === 'mouseup') return;\r\n\r\n // This delay makes sure that when the click event that results from the mouseup is produced, the drag is\r\n // still in progress. So by checking the flag dnd.inProgress, one can tell apart true clicks from drag and\r\n // drop artefacts.\r\n setTimeout(() => {\r\n this.cancelDragActions();\r\n\r\n if (this.dragStarted) {\r\n dnd.stopDrag(e);\r\n }\r\n this.finishDrag();\r\n }, 0);\r\n },\r\n onKeyUp (e) {\r\n // If ESC is pressed, cancel the drag\r\n if (e.key === 'Escape') {\r\n this.cancelDragActions();\r\n\r\n setTimeout(() => {\r\n dnd.cancelDrag(e);\r\n this.finishDrag();\r\n }, 0);\r\n }\r\n },\r\n cancelDragActions () {\r\n this.dragInitialised = false;\r\n clearTimeout(this.delayTimer);\r\n cancelScrollAction();\r\n },\r\n finishDrag () {\r\n this.downEvent = null;\r\n this.scrollContainer = null;\r\n\r\n if (this.dragStarted) {\r\n document.documentElement.classList.remove('drag-in-progress');\r\n }\r\n document.removeEventListener('click', this.onMouseClick, true);\r\n document.removeEventListener('mousemove', this.onMouseMove);\r\n document.removeEventListener('touchmove', this.onMouseMove);\r\n document.removeEventListener('easy-dnd-move', this.onEasyDnDMove);\r\n document.removeEventListener('mouseup', this.onMouseUp);\r\n document.removeEventListener('touchend', this.onMouseUp);\r\n document.removeEventListener('selectstart', this.onSelectStart);\r\n document.removeEventListener('keyup', this.onKeyUp);\r\n document.documentElement.style.userSelect = this.initialUserSelect;\r\n },\r\n dndDragStart (ev) {\r\n if (ev.source === this) {\r\n this.$emit('dragstart', ev);\r\n }\r\n },\r\n dndDragEnd (ev) {\r\n if (ev.source === this) {\r\n this.$emit('dragend', ev);\r\n }\r\n },\r\n createDragImage (selfTransform) {\r\n let image;\r\n if (this.$slots['drag-image']) {\r\n const el = this.$refs['drag-image'] || document.createElement('div');\r\n if (el.childElementCount !== 1) {\r\n image = createDragImage(el);\r\n }\r\n else {\r\n image = createDragImage(el.children.item(0));\r\n }\r\n }\r\n else {\r\n image = createDragImage(this.$el);\r\n image.style.transform = selfTransform;\r\n }\r\n\r\n if (this.dragClass) {\r\n image.classList.add(this.dragClass);\r\n }\r\n image.classList.add('dnd-ghost');\r\n image['__opacity'] = this.dragImageOpacity;\r\n return image;\r\n }\r\n },\r\n created () {\r\n dnd.on('dragstart', this.dndDragStart);\r\n dnd.on('dragend', this.dndDragEnd);\r\n },\r\n mounted () {\r\n this.$el.addEventListener('mousedown', this.onMouseDown);\r\n this.$el.addEventListener('touchstart', this.onMouseDown);\r\n },\r\n beforeUnmount () {\r\n dnd.off('dragstart', this.dndDragStart);\r\n dnd.off('dragend', this.dndDragEnd);\r\n\r\n this.$el.removeEventListener('mousedown', this.onMouseDown);\r\n this.$el.removeEventListener('touchstart', this.onMouseDown);\r\n }\r\n};\n\nvar script$4 = {\r\n name: 'Drag',\r\n mixins: [DragMixin],\r\n props: {\r\n /**\r\n * Tag to be used as root of this component. Defaults to div.\r\n */\r\n tag: {\r\n type: [String, Object, Function],\r\n default: 'div'\r\n }\r\n },\r\n computed: {\r\n dynamicSlots () {\r\n return Object.entries(this.$slots).filter(([key]) => key !== 'drag-image' && key !== 'default');\r\n }\r\n }\r\n};\n\nconst _hoisted_1$2 = {\n key: 0,\n ref: \"drag-image\",\n class: \"__drag-image\"\n};\n\nfunction render$3(_ctx, _cache, $props, $setup, $data, $options) {\n return (openBlock(), createBlock(resolveDynamicComponent($props.tag), {\n class: normalizeClass(_ctx.cssClasses)\n }, createSlots({\n default: withCtx(() => [\n renderSlot(_ctx.$slots, \"default\", normalizeProps(guardReactiveProps(_ctx.$slots['default'] || {}))),\n (_ctx.dragInitialised)\n ? (openBlock(), createElementBlock(\"div\", _hoisted_1$2, [\n renderSlot(_ctx.$slots, \"drag-image\")\n ], 512 /* NEED_PATCH */))\n : createCommentVNode(\"v-if\", true)\n ]),\n _: 2 /* DYNAMIC */\n }, [\n renderList($options.dynamicSlots, ([slot, args]) => {\n return {\n name: slot,\n fn: withCtx(() => [\n renderSlot(_ctx.$slots, slot, normalizeProps(guardReactiveProps(args)))\n ])\n }\n })\n ]), 1032 /* PROPS, DYNAMIC_SLOTS */, [\"class\"]))\n}\n\nscript$4.render = render$3;\nscript$4.__scopeId = \"data-v-f87407ce\";\n\nfunction dropAllowed (inst) {\r\n if (inst.dragInProgress && inst.typeAllowed) {\r\n return inst.compatibleMode && inst.effectiveAcceptsData(inst.dragData, inst.dragType);\r\n }\r\n return null;\r\n}\r\n\r\nfunction doDrop (inst, event) {\r\n inst.$emit('drop', event);\r\n event.source.$emit(inst.mode, event);\r\n}\r\n\r\nfunction candidate (inst, type) {\r\n return inst.effectiveAcceptsType(type);\r\n}\r\n\r\nvar DropMixin = {\r\n mixins: [DragAwareMixin],\r\n props: {\r\n acceptsType: {\r\n type: [String, Array, Function],\r\n default: null\r\n },\r\n acceptsData: {\r\n type: Function,\r\n default: () => {\r\n return true;\r\n }\r\n },\r\n mode: {\r\n type: String,\r\n default: 'copy'\r\n },\r\n dragImageOpacity: {\r\n type: Number,\r\n default: 0.7\r\n }\r\n },\r\n emits: ['dragover', 'dragenter', 'dragleave', 'dragend', 'drop'],\r\n data () {\r\n return {\r\n isDrop: true\r\n };\r\n },\r\n computed: {\r\n compatibleMode () {\r\n return this.dragInProgress ? true : null;\r\n },\r\n dropIn () {\r\n if (this.dragInProgress) {\r\n return this.dragTop === this;\r\n }\r\n return null;\r\n },\r\n typeAllowed () {\r\n if (this.dragInProgress) {\r\n return this.effectiveAcceptsType(this.dragType);\r\n }\r\n return null;\r\n },\r\n dropAllowed () {\r\n return dropAllowed(this);\r\n },\r\n cssClasses () {\r\n const clazz = {\r\n 'dnd-drop': true\r\n };\r\n if (this.dropIn !== null) {\r\n clazz['drop-in'] = this.dropIn;\r\n clazz['drop-out'] = !this.dropIn;\r\n }\r\n if (this.typeAllowed !== null) {\r\n clazz['type-allowed'] = this.typeAllowed;\r\n clazz['type-forbidden'] = !this.typeAllowed;\r\n }\r\n if (this.dropAllowed !== null) {\r\n clazz['drop-allowed'] = this.dropAllowed;\r\n clazz['drop-forbidden'] = !this.dropAllowed;\r\n }\r\n return clazz;\r\n }\r\n },\r\n methods: {\r\n effectiveAcceptsType (type) {\r\n if (this.acceptsType === null) {\r\n return true;\r\n }\r\n else if (typeof (this.acceptsType) === 'string' || typeof(this.acceptsType) === 'number') {\r\n return this.acceptsType === type;\r\n }\r\n else if (typeof (this.acceptsType) === 'object' && Array.isArray(this.acceptsType)) {\r\n return this.acceptsType.includes(type);\r\n }\r\n else {\r\n return this.acceptsType(type);\r\n }\r\n },\r\n effectiveAcceptsData (data, type) {\r\n return this.acceptsData(data, type);\r\n },\r\n onDragPositionChanged (event) {\r\n if (this === event.top) {\r\n this.$emit('dragover', event);\r\n }\r\n },\r\n onDragTopChanged (event) {\r\n if (this === event.top) {\r\n this.$emit('dragenter', event);\r\n }\r\n if (this === event.previousTop) {\r\n this.$emit('dragleave', event);\r\n }\r\n },\r\n onDragEnd (event) {\r\n if (this === event.top) {\r\n this.$emit('dragend', event);\r\n }\r\n },\r\n onDrop (event) {\r\n if (this.dropIn && this.compatibleMode && this.dropAllowed) {\r\n this.doDrop(event);\r\n }\r\n },\r\n doDrop (event) {\r\n doDrop(this, event);\r\n },\r\n /**\r\n * Returns true if the current drop area participates in the current drag operation.\r\n */\r\n candidate (type) {\r\n return candidate(this, type);\r\n },\r\n createDragImage () {\r\n let image = 'source';\r\n if (this.$refs['drag-image']) {\r\n const el = this.$refs['drag-image'];\r\n if (el.childElementCount !== 1) {\r\n image = createDragImage(el);\r\n }\r\n else {\r\n image = createDragImage(el.children.item(0));\r\n }\r\n image['__opacity'] = this.dragImageOpacity;\r\n image.classList.add('dnd-ghost');\r\n }\r\n return image;\r\n },\r\n onDnDMove (e) {\r\n dnd.mouseMove(e, this);\r\n }\r\n },\r\n created () {\r\n dnd.on('dragpositionchanged', this.onDragPositionChanged);\r\n dnd.on('dragtopchanged', this.onDragTopChanged);\r\n dnd.on('drop', this.onDrop);\r\n dnd.on('dragend', this.onDragEnd);\r\n },\r\n mounted () {\r\n this.$el.addEventListener('easy-dnd-move', this.onDnDMove);\r\n },\r\n beforeUnmount () {\r\n this.$el.removeEventListener('easy-dnd-move', this.onDnDMove);\r\n\r\n dnd.off('dragpositionchanged', this.onDragPositionChanged);\r\n dnd.off('dragtopchanged', this.onDragTopChanged);\r\n dnd.off('drop', this.onDrop);\r\n dnd.off('dragend', this.onDragEnd);\r\n }\r\n};\n\nvar script$3 = {\r\n name: 'Drop',\r\n mixins: [DropMixin],\r\n props: {\r\n tag: {\r\n type: [String, Object, Function],\r\n default: 'div'\r\n }\r\n },\r\n computed: {\r\n dynamicSlots () {\r\n return Object.entries(this.$slots).filter(([key]) => key !== 'drag-image' && key !== 'default');\r\n },\r\n showDragImage () {\r\n return this.dragInProgress && this.typeAllowed && !!this.$slots['drag-image'];\r\n }\r\n }\r\n};\n\nconst _hoisted_1$1 = {\n key: 0,\n ref: \"drag-image\",\n class: \"__drag-image\"\n};\n\nfunction render$2(_ctx, _cache, $props, $setup, $data, $options) {\n return (openBlock(), createBlock(resolveDynamicComponent($props.tag), {\n class: normalizeClass(_ctx.cssClasses)\n }, createSlots({\n default: withCtx(() => [\n renderSlot(_ctx.$slots, \"default\", normalizeProps(guardReactiveProps(_ctx.$slots['default'] || {}))),\n ($options.showDragImage)\n ? (openBlock(), createElementBlock(\"div\", _hoisted_1$1, [\n renderSlot(_ctx.$slots, \"drag-image\", {\n type: _ctx.dragType,\n data: _ctx.dragData\n })\n ], 512 /* NEED_PATCH */))\n : createCommentVNode(\"v-if\", true)\n ]),\n _: 2 /* DYNAMIC */\n }, [\n renderList($options.dynamicSlots, ([slot, args]) => {\n return {\n name: slot,\n fn: withCtx(() => [\n renderSlot(_ctx.$slots, slot, normalizeProps(guardReactiveProps(args)))\n ])\n }\n })\n ]), 1032 /* PROPS, DYNAMIC_SLOTS */, [\"class\"]))\n}\n\nscript$3.render = render$2;\nscript$3.__scopeId = \"data-v-12a39e52\";\n\nvar script$2 = {\r\n name: 'DropMask',\r\n mixins: [DragAwareMixin],\r\n props: {\r\n tag: {\r\n type: [String, Object, Function],\r\n default: 'div'\r\n }\r\n },\r\n data () {\r\n return {\r\n isDropMask: true\r\n };\r\n },\r\n mounted () {\r\n this.$el.addEventListener('easy-dnd-move', this.onDndMove);\r\n },\r\n beforeUnmount () {\r\n this.$el.removeEventListener('easy-dnd-move', this.onDndMove);\r\n },\r\n methods: {\r\n createDragImage () {\r\n return 'source';\r\n },\r\n onDndMove (e) {\r\n dnd.mouseMove(e, this);\r\n }\r\n }\r\n};\n\nfunction render$1(_ctx, _cache, $props, $setup, $data, $options) {\n return (openBlock(), createBlock(resolveDynamicComponent($props.tag), null, createSlots({ _: 2 /* DYNAMIC */ }, [\n renderList(_ctx.$slots, (args, slot) => {\n return {\n name: slot,\n fn: withCtx(() => [\n renderSlot(_ctx.$slots, slot, normalizeProps(guardReactiveProps(args)))\n ])\n }\n })\n ]), 1024 /* DYNAMIC_SLOTS */))\n}\n\nscript$2.render = render$1;\n\nvar script$1 = {\r\n name: 'DragFeedback'\r\n};\n\nconst _hoisted_1 = { class: \"DragFeedback\" };\n\nfunction render(_ctx, _cache, $props, $setup, $data, $options) {\n return (openBlock(), createElementBlock(\"div\", _hoisted_1, [\n renderSlot(_ctx.$slots, \"default\")\n ]))\n}\n\nscript$1.render = render;\n\nclass Grid {\r\n reference;\r\n referenceOriginalPosition;\r\n magnets = [];\r\n\r\n constructor (collection, upToIndex, direction, fromIndex) {\r\n this.reference = collection.item(0).parentNode;\r\n this.referenceOriginalPosition = {\r\n x: this.reference.getBoundingClientRect().left - this.reference.scrollLeft,\r\n y: this.reference.getBoundingClientRect().top - this.reference.scrollTop,\r\n };\r\n let index = 0;\r\n for (const child of collection) {\r\n if (index > upToIndex) break;\r\n const rect = child.getBoundingClientRect();\r\n const hasNestedDrop = child.classList.contains('dnd-drop') || child.getElementsByClassName('dnd-drop').length > 0;\r\n let horizontal = false;\r\n if (hasNestedDrop) {\r\n if (direction === 'auto') {\r\n // Auto mode not supported for now. Row or column must be defined explicitly if there are nested drop lists.\r\n throw 'Easy-DnD error : a drop list is missing one of these attributes : \\'row\\' or \\'column\\'.';\r\n }\r\n else {\r\n horizontal = direction === 'row';\r\n }\r\n }\r\n if (fromIndex === null) {\r\n // Inserting mode.\r\n this.magnets.push(hasNestedDrop ? this.before(rect, horizontal) : this.center(rect));\r\n }\r\n else {\r\n // Reordering mode.\r\n this.magnets.push(hasNestedDrop ? (\r\n fromIndex < index ? this.after : this.before\r\n )(rect, horizontal) : this.center(rect));\r\n }\r\n // Debug : show magnets :\r\n //document.body.insertAdjacentHTML(\"beforeend\", \"<div style='background-color: red; position: fixed; width: 1px; height: 1px; top:\" + this.magnets[index].y + \"px; left:\" + this.magnets[index].x + \"px;' ></div>\")\r\n index++;\r\n }\r\n }\r\n\r\n /**\r\n * Returns the center of the rectangle.\r\n */\r\n center (rect) {\r\n return {\r\n x: rect.left + rect.width / 2,\r\n y: rect.top + rect.height / 2\r\n };\r\n }\r\n\r\n /**\r\n * When horizontal is true / false, returns middle of the left / top side of the rectangle.\r\n */\r\n before (rect, horizontal) {\r\n return horizontal ? {\r\n x: rect.left,\r\n y: rect.top + rect.height / 2\r\n } : {\r\n x: rect.left + rect.width / 2,\r\n y: rect.top\r\n };\r\n }\r\n\r\n /**\r\n * When horizontal is true / false, returns middle of the right / bottom side of the rectangle.\r\n */\r\n after (rect, horizontal) {\r\n return horizontal ? {\r\n x: rect.left + rect.width,\r\n y: rect.top + rect.height / 2\r\n } : {\r\n x: rect.left + rect.width / 2,\r\n y: rect.top + rect.height\r\n };\r\n }\r\n\r\n /**\r\n * In case the user scrolls during the drag, the position of the magnets are not what they used to be when the drag\r\n * started. A correction must be applied that takes into account the amount of scroll. This correction is the\r\n * difference between the current position of the parent element and its position when the drag started.\r\n */\r\n correction () {\r\n return {\r\n x: this.reference.getBoundingClientRect().left - this.reference.scrollLeft - this.referenceOriginalPosition.x,\r\n y: this.reference.getBoundingClientRect().top - this.reference.scrollTop - this.referenceOriginalPosition.y,\r\n };\r\n }\r\n\r\n closestIndex (position) {\r\n const x = position.x - this.correction().x;\r\n const y = position.y - this.correction().y;\r\n let minDist = 999999;\r\n let index = -1;\r\n for (let i = 0; i < this.magnets.length; i++) {\r\n const magnet = this.magnets[i];\r\n const dist = Math.sqrt(Math.pow(magnet.x - x, 2) + Math.pow(magnet.y - y, 2));\r\n if (dist < minDist) {\r\n minDist = dist;\r\n index = i;\r\n }\r\n }\r\n return index;\r\n }\r\n}\n\nclass DnDEvent {\r\n type;\r\n data;\r\n top;\r\n previousTop;\r\n source;\r\n position;\r\n success;\r\n native;\r\n}\r\n\r\nclass ReorderEvent {\r\n from;\r\n to;\r\n \r\n constructor (from, to) {\r\n this.from = from;\r\n this.to = to;\r\n }\r\n\r\n apply (array) {\r\n const temp = array[this.from];\r\n array.splice(this.from, 1);\r\n array.splice(this.to, 0, temp);\r\n }\r\n\r\n}\r\n\r\nclass InsertEvent {\r\n type;\r\n data;\r\n index;\r\n \r\n constructor (type, data, index) {\r\n this.type = type;\r\n this.data = data;\r\n this.index = index;\r\n }\r\n}\n\nvar script = {\r\n name: 'DropList',\r\n mixins: [DropMixin],\r\n props: {\r\n tag: {\r\n type: [String, Object, Function],\r\n default: 'div'\r\n },\r\n items: {\r\n type: Array,\r\n required: true\r\n },\r\n row: {\r\n type: Boolean,\r\n default: false\r\n },\r\n column: {\r\n type: Boolean,\r\n default: false\r\n },\r\n noAnimations: {\r\n type: Boolean,\r\n default: false\r\n },\r\n scrollingEdgeSize: {\r\n type: Number,\r\n default: undefined\r\n }\r\n },\r\n emits: ['reorder', 'insert'],\r\n data () {\r\n return {\r\n grid: null,\r\n forbiddenKeys: [],\r\n feedbackKey: null,\r\n fromIndex: null\r\n };\r\n },\r\n computed: {\r\n rootTag () {\r\n if (this.noAnimations) {\r\n return this.tag;\r\n }\r\n return TransitionGroup;\r\n },\r\n rootProps () {\r\n if (this.noAnimations) {\r\n return {};\r\n }\r\n\r\n return {\r\n tag: this.tag,\r\n css: false\r\n };\r\n },\r\n direction () {\r\n // todo - rewrite this logic\r\n if (this.row) return 'row';\r\n if (this.column) return 'column';\r\n return 'auto';\r\n },\r\n reordering () {\r\n if (dnd.inProgress) {\r\n return dnd.source.$el.parentElement === this.$el;\r\n }\r\n return null;\r\n },\r\n closestIndex () {\r\n if (this.grid) {\r\n return this.grid.closestIndex(dnd.position);\r\n }\r\n return null;\r\n },\r\n dropAllowed () {\r\n if (this.dragInProgress) {\r\n if (this.reordering) {\r\n return this.items.length > 1;\r\n }\r\n else {\r\n // todo - eventually refactor so that this isn't necessary\r\n if (!dropAllowed(this)) {\r\n return false;\r\n }\r\n\r\n if (this.forbiddenKeys !== null && this.feedbackKey !== null) {\r\n return !this.forbiddenKeys.includes(this.feedbackKey);\r\n }\r\n\r\n return true;\r\n }\r\n }\r\n\r\n return null;\r\n },\r\n itemsBeforeFeedback () {\r\n if (this.closestIndex === 0) {\r\n return [];\r\n }\r\n return this.items.slice(0, this.closestIndex);\r\n },\r\n itemsAfterFeedback () {\r\n if (this.closestIndex === this.items.length) {\r\n return [];\r\n }\r\n return this.items.slice(this.closestIndex);\r\n },\r\n itemsBeforeReorderingFeedback () {\r\n if (this.closestIndex <= this.fromIndex) {\r\n return this.items.slice(0, this.closestIndex);\r\n }\r\n return this.items.slice(0, this.closestIndex + 1);\r\n },\r\n itemsAfterReorderingFeedback () {\r\n if (this.closestIndex <= this.fromIndex) {\r\n return this.items.slice(this.closestIndex);\r\n }\r\n return this.items.slice(this.closestIndex + 1);\r\n },\r\n reorderedItems () {\r\n const toIndex = this.closestIndex;\r\n const reordered = [...this.items];\r\n const temp = reordered[this.fromIndex];\r\n\r\n reordered.splice(this.fromIndex, 1);\r\n reordered.splice(toIndex, 0, temp);\r\n return reordered;\r\n },\r\n clazz () {\r\n return {\r\n 'drop-list': true,\r\n 'reordering': this.reordering === true,\r\n 'inserting': this.reordering === false,\r\n ...(this.reordering === false ? this.cssClasses : { 'dnd-drop': true })\r\n };\r\n },\r\n showDragFeedback () {\r\n return this.dragInProgress && this.typeAllowed && !this.reordering;\r\n },\r\n showInsertingDragImage () {\r\n return this.dragInProgress && this.typeAllowed && !this.reordering && !!this.$slots['drag-image'];\r\n },\r\n showReorderingDragImage () {\r\n return this.dragInProgress && this.reordering && !!this.$slots['reordering-drag-image'];\r\n },\r\n hasReorderingFeedback () {\r\n return !!this.$slots['reordering-feedback'];\r\n },\r\n hasEmptySlot () {\r\n return !!this.$slots['empty'];\r\n }\r\n },\r\n created () {\r\n dnd.on('dragstart', this.onDragStart);\r\n dnd.on('dragend', this.onDragEnd);\r\n },\r\n beforeUnmount () {\r\n dnd.off('dragstart', this.onDragStart);\r\n dnd.off('dragend', this.onDragEnd);\r\n },\r\n methods: {\r\n // Presence of feedback node in the DOM and of keys in the virtual DOM required => delayed until what\r\n // depends on drag data has been processed.\r\n refresh () {\r\n this.$nextTick(() => {\r\n this.grid = this.computeInsertingGrid();\r\n this.feedbackKey = this.computeFeedbackKey();\r\n this.forbiddenKeys = this.computeForbiddenKeys();\r\n });\r\n },\r\n onDragStart (event) {\r\n if (this.candidate(dnd.type)) {\r\n if (this.reordering) {\r\n this.fromIndex = Array.prototype.indexOf.call(event.source.$el.parentElement.children, event.source.$el);\r\n this.grid = this.computeReorderingGrid();\r\n }\r\n else {\r\n this.refresh();\r\n }\r\n }\r\n },\r\n onDragEnd () {\r\n this.fromIndex = null;\r\n this.feedbackKey = null;\r\n this.forbiddenKeys = null;\r\n this.grid = null;\r\n },\r\n doDrop (event) {\r\n if (this.reordering) {\r\n if (this.fromIndex !== this.closestIndex) {\r\n this.$emit('reorder', new ReorderEvent(\r\n this.fromIndex,\r\n this.closestIndex\r\n ));\r\n }\r\n }\r\n else {\r\n // todo - eventually remove the need for this\r\n doDrop(this, event);\r\n this.$emit('insert', new InsertEvent(\r\n event.type,\r\n event.data,\r\n this.closestIndex\r\n ));\r\n }\r\n },\r\n candidate (type) {\r\n return candidate(this, type) || this.reordering;\r\n },\r\n computeForbiddenKeys () {\r\n return (this.noAnimations ? [] : this.$refs.component.$slots['default']())\r\n .map(vn => vn.key)\r\n .filter(k => !!k && k !== 'drag-image' && k !== 'drag-feedback');\r\n },\r\n computeFeedbackKey () {\r\n return this.$refs['feedback']['$slots']['default']()[0]['key'];\r\n },\r\n computeInsertingGrid () {\r\n if (this.$refs.feedback.$el.children.length < 1) {\r\n return null;\r\n }\r\n\r\n const feedback = this.$refs.feedback.$el.children[0];\r\n const clone = feedback.cloneNode(true);\r\n const tg = this.$el;\r\n if (tg.children.length > this.items.length) {\r\n tg.insertBefore(clone, tg.children[this.items.length]);\r\n }\r\n else {\r\n tg.appendChild(clone);\r\n }\r\n const grid = new Grid(tg.children, this.items.length, this.direction, null);\r\n tg.removeChild(clone);\r\n return grid;\r\n },\r\n computeReorderingGrid () {\r\n return new Grid(this.$el.children, this.items.length - 1, this.direction, this.fromIndex);\r\n },\r\n createDragImage () {\r\n let image;\r\n if (this.$refs['drag-image']) {\r\n const el = this.$refs['drag-image'];\r\n let model;\r\n if (el.childElementCount !== 1) {\r\n model = el;\r\n }\r\n else {\r\n model = el.children.item(0);\r\n }\r\n const clone = model.cloneNode(true);\r\n const tg = this.$el;\r\n tg.appendChild(clone);\r\n image = createDragImage(clone);\r\n tg.removeChild(clone);\r\n image['__opacity'] = this.dragImageOpacity;\r\n image.classList.add('dnd-ghost');\r\n }\r\n else {\r\n image = 'source';\r\n }\r\n return image;\r\n }\r\n },\r\n render () {\r\n if (!this.$slots['item']) {\r\n throw 'The \"Item\" slot must be defined to use DropList';\r\n }\r\n\r\n if (!this.$slots['feedback']) {\r\n throw 'The \"Feedback\" slot must be defined to use DropList';\r\n }\r\n\r\n let defaultArr = [];\r\n if (this.dropIn && this.dropAllowed) {\r\n if (this.reordering) {\r\n if (this.hasReorderingFeedback) {\r\n const itemsReorderingBefore = this.itemsBeforeReorderingFeedback.map((item, index) => {\r\n return this.$slots['item']({\r\n item: item,\r\n index: index,\r\n reorder: false\r\n })[0];\r\n });\r\n if (itemsReorderingBefore.length > 0) {\r\n defaultArr = defaultArr.concat(itemsReorderingBefore);\r\n }\r\n\r\n defaultArr.push(this.$slots['reordering-feedback']({\r\n key: 'reordering-feedback',\r\n item: this.items[this.fromIndex]\r\n })[0]);\r\n\r\n const itemsReorderingAfter = this.itemsAfterReorderingFeedback.map((item, index) => {\r\n return this.$slots['item']({\r\n item: item,\r\n index: this.itemsBeforeReorderingFeedback.length + index,\r\n reorder: false\r\n })[0];\r\n });\r\n if (itemsReorderingAfter.length > 0) {\r\n defaultArr = defaultArr.concat(itemsReorderingAfter);\r\n }\r\n }\r\n else {\r\n const reorderedItems = this.reorderedItems.map((item, index) => {\r\n return this.$slots['item']({\r\n item: item,\r\n index: index,\r\n reorder: index === this.closestIndex\r\n })[0];\r\n });\r\n if (reorderedItems.length > 0) {\r\n defaultArr = defaultArr.concat(reorderedItems);\r\n }\r\n }\r\n }\r\n else {\r\n const itemsBefore = this.itemsBeforeFeedback.map((item, index) => {\r\n return this.$slots['item']({\r\n item: item,\r\n index: index,\r\n reorder: false\r\n })[0];\r\n });\r\n if (itemsBefore.length > 0) {\r\n defaultArr = defaultArr.concat(itemsBefore);\r\n }\r\n\r\n defaultArr.push(this.$slots['feedback']({\r\n key: 'drag-feedback',\r\n data: this.dragData,\r\n type: this.dragType\r\n })[0]);\r\n\r\n const itemsAfter = this.itemsAfterFeedback.map((item, index) => {\r\n return this.$slots['item']({\r\n item: item,\r\n index: this.itemsBeforeFeedback.length + index,\r\n reorder: false\r\n })[0];\r\n });\r\n if (itemsAfter.length > 0) {\r\n defaultArr = defaultArr.concat(itemsAfter);\r\n }\r\n }\r\n }\r\n else {\r\n const defaultItems = this.items.map((item, index) => {\r\n return this.$slots['item']({\r\n item: item,\r\n index: index,\r\n reorder: false\r\n })[0];\r\n });\r\n\r\n if (defaultItems.length > 0) {\r\n defaultArr = defaultArr.concat(defaultItems);\r\n }\r\n else if (this.hasEmptySlot) {\r\n defaultArr.push(this.$slots['empty']()[0]);\r\n }\r\n }\r\n\r\n if (this.showDragFeedback) {\r\n defaultArr.push(h(\r\n script$1,\r\n {\r\n class: '__feedback',\r\n ref: 'feedback',\r\n key: 'drag-feedback'\r\n },\r\n {\r\n default: () => this.$slots['feedback']({\r\n type: this.dragType,\r\n data: this.dragData\r\n })[0]\r\n }\r\n ));\r\n }\r\n\r\n if (this.showReorderingDragImage) {\r\n defaultArr.push(h(\r\n 'div',\r\n {\r\n class: '__drag-image',\r\n ref: 'drag-image',\r\n key: 'reordering-drag-image'\r\n },\r\n {\r\n default: () => this.$slots['reordering-drag-image']({\r\n item: this.items[this.fromIndex]\r\n })[0]\r\n }\r\n ));\r\n }\r\n\r\n if (this.showInsertingDragImage) {\r\n defaultArr.push(h(\r\n 'div',\r\n {\r\n class: '__drag-image',\r\n ref: 'drag-image',\r\n key: 'inserting-drag-image'\r\n },\r\n {\r\n default: () => this.$slots['drag-image']({\r\n type: this.dragType,\r\n data: this.dragData\r\n })[0]\r\n }\r\n ));\r\n }\r\n\r\n return h(\r\n this.rootTag,\r\n {\r\n ref: 'component',\r\n class: this.clazz,\r\n ...this.rootProps\r\n },\r\n {\r\n default: () => defaultArr\r\n }\r\n );\r\n }\r\n};\n\nscript.__scopeId = \"data-v-230f65e3\";\n\n/**\r\n * This class reacts to drag events emitted by the dnd object to manage a sequence of drag images and fade from one to the\r\n * other as the drag progresses.\r\n */\r\nclass DragImagesManager {\r\n\r\n selfTransform = null;\r\n clones = null;\r\n source = null;\r\n sourcePos = null;\r\n sourceClone = null;\r\n\r\n constructor () {\r\n dnd.on('dragstart', this.onDragStart.bind(this));\r\n dnd.on('dragtopchanged', this.onDragTopChanged.bind(this));\r\n dnd.on('dragpositionchanged', this.onDragPositionChanged.bind(this));\r\n dnd.on('dragend', this.onDragEnd.bind(this));\r\n }\r\n\r\n onDragStart (event) {\r\n // If go-back=true and it is still animating while they attempt another drag,\r\n // it will bug out. Best to clean up any existing elements on the page before\r\n // attempting to start the next animation\r\n this.cleanUp();\r\n\r\n this.sourcePos = {\r\n x: event.source.$el.getBoundingClientRect().left,\r\n y: event.source.$el.getBoundingClientRect().top\r\n };\r\n this.selfTransform = 'translate(-' + (event.position.x - this.sourcePos.x) + 'px, -' + (event.position.y - this.sourcePos.y) + 'px)';\r\n this.clones = new Map();\r\n this.source = event.source;\r\n }\r\n\r\n onDragEnd (event) {\r\n nextTick()\r\n .then(() => {\r\n if (!event.success && this.source && this.source['goBack']) {\r\n // Restore the drag image that is active when hovering outside any drop zone :\r\n const img = this.switch(null);\r\n \r\n // Move it back to its original place :\r\n window.requestAnimationFrame(() => {\r\n img.style.transition = 'all 0.5s';\r\n window.requestAnimationFrame(() => {\r\n img.style.left = this.sourcePos.x + 'px';\r\n img.style.top = this.sourcePos.y + 'px';\r\n img.style.transform = 'translate(0,0)';\r\n const handler = () => {\r\n this.cleanUp();\r\n img.removeEventListener('transitionend', handler);\r\n };\r\n img.addEventListener('transitionend', handler);\r\n });\r\n });\r\n }\r\n else {\r\n this.cleanUp();\r\n }\r\n });\r\n }\r\n\r\n cleanUp () {\r\n if (this.clones) {\r\n this.clones.forEach((clone) => {\r\n if (clone.parentNode === document.body) {\r\n document.body.removeChild(clone);\r\n }\r\n });\r\n }\r\n if (this.sourceClone !== null) {\r\n if (this.sourceClone.parentNode === document.body) {\r\n document.body.removeChild(this.sourceClone);\r\n }\r\n }\r\n this.selfTransform = null;\r\n this.clones = null;\r\n this.source = null;\r\n this.sourceClone = null;\r\n this.sourcePos = null;\r\n }\r\n\r\n onDragTopChanged (event) {\r\n this.switch(event.top);\r\n }\r\n\r\n switch (top) {\r\n this.clones.forEach(clone => {\r\n clone.style.opacity = '0';\r\n });\r\n if (this.sourceClone) {\r\n this.sourceClone.style.opacity = '0';\r\n }\r\n\r\n let activeClone;\r\n if (top === null) {\r\n activeClone = this.getSourceClone();\r\n }\r\n else {\r\n if (!this.clones.has(top)) {\r\n let clone = top['createDragImage'](this.selfTransform);\r\n if (clone === 'source') {\r\n clone = this.getSourceClone();\r\n }\r\n else if (clone !== null) {\r\n clone.style.opacity = '0';\r\n document.body.appendChild(clone);\r\n }\r\n this.clones.set(top, clone);\r\n }\r\n activeClone = this.clones.get(top);\r\n }\r\n\r\n if (activeClone !== null) {\r\n activeClone.offsetWidth; // Forces browser reflow\r\n activeClone.style.opacity = activeClone['__opacity'];\r\n activeClone.style.visibility = 'visible';\r\n }\r\n\r\n return activeClone;\r\n }\r\n\r\n getSourceClone () {\r\n if (this.sourceClone === null) {\r\n this.sourceClone = this.source['createDragImage'](this.selfTransform);\r\n this.sourceClone.style.opacity = '0';\r\n document.body.appendChild(this.sourceClone);\r\n }\r\n return this.sourceClone;\r\n }\r\n\r\n onDragPositionChanged () {\r\n this.clones.forEach((clone) => {\r\n clone.style.left = dnd.position.x + 'px';\r\n clone.style.top = dnd.position.y + 'px';\r\n });\r\n if (this.sourceClone) {\r\n this.sourceClone.style.left = dnd.position.x + 'px';\r\n this.sourceClone.style.top = dnd.position.y + 'px';\r\n }\r\n }\r\n\r\n}\r\n\r\nnew DragImagesManager();\n\nexport { DnDEvent, script$4 as Drag, DragAwareMixin, script$1 as DragFeedback, DragImagesManager, DragMixin, script$3 as Drop, script as DropList, script$2 as DropMask, DropMixin, InsertEvent, ReorderEvent, createDragImage, dnd };\n"],"names":["DnD","n","all","Map","on","t","e","i","get","push","set","off","splice","indexOf","emit","slice","map","source","event","x","y","type","data","position","top","inProgress","previousTop","success","this","resetVariables","comp","prevent","stopPropagation","detail","native","eventBus","callback","dnd","DragAwareMixin","isDropMask","computed","dragInProgress","dragData","dragType","dragPosition","dragSource","dragTop","createDragImage","el","clone","cloneNode","copyStyle","vSrcElements","getElementsByTagName","vDstElements","length","deepClone","style","margin","transition","src","destination","computedStyle","window","getComputedStyle","key","width","getPropertyValue","clientWidth","parseFloat","paddingLeft","paddingRight","setProperty","height","clientHeight","paddingTop","paddingBottom","getPropertyPriority","pointerEvents","regex","node","prop","scrollparent","document","body","test","scroll","parentNode","timer","cancelScrollAction","clearTimeout","performEdgeScroll","container","clientX","clientY","edgeSize","rect","getBoundingClientRect","isBody","viewportX","left","viewportY","viewportWidth","viewportHeight","documentElement","edgeTop","edgeLeft","edgeBottom","edgeRight","isInLeftEdge","isInRightEdge","isInTopEdge","isInBottomEdge","documentWidth","Math","max","scrollWidth","offsetWidth","documentHeight","scrollHeight","offsetHeight","maxScrollX","maxScrollY","checkForWindowScroll","currentScrollX","scrollLeft","currentScrollY","scrollTop","pageXOffset","pageYOffset","canScrollUp","canScrollDown","canScrollLeft","canScrollRight","nextScrollX","nextScrollY","maxStep","min","scrollTo","adjustWindowScroll","setTimeout","DragMixin","mixins","props","String","default","dragImageOpacity","Number","disabled","Boolean","goBack","handle","delta","delay","dragClass","vibration","scrollingEdgeSize","emits","dragInitialised","dragStarted","ignoreNextClick","initialUserSelect","downEvent","startPosition","delayTimer","scrollContainer","cssClasses","clazz","currentDropMode","methods","onSelectStart","preventDefault","performVibration","navigator","vibrate","onMouseDown","target","goodButton","mouse","buttons","touches","matches","userSelect","touch","_this","addEventListener","onMouseClick","onMouseUp","onKeyUp","onMouseMove","passive","onEasyDnDMove","stopImmediatePropagation","elementFromPoint","dist","sqrt","pow","startDrag","classList","add","currEdgeSize","undefined","$props","$el","custom","CustomEvent","bubbles","cancelable","dispatchEvent","mouseMove","_this2","cancelDragActions","stopDrag","finishDrag","cancelDrag","_this3","remove","removeEventListener","dndDragStart","ev","$emit","dndDragEnd","selfTransform","image","$slots","$refs","createElement","childElementCount","children","item","transform","created","mounted","beforeUnmount","script$4","name","tag","Object","Function","dynamicSlots","entries","filter","_hoisted_1$2","ref","class","dropAllowed","inst","typeAllowed","compatibleMode","effectiveAcceptsData","doDrop","mode","candidate","effectiveAcceptsType","render","_ctx","_cache","$setup","$data","$options","_","slot","args","fn","__scopeId","DropMixin","acceptsType","Array","acceptsData","isDrop","dropIn","_typeof","isArray","includes","onDragPositionChanged","onDragTopChanged","onDragEnd","onDrop","onDnDMove","script$3","showDragImage","_hoisted_1$1","script$2","onDndMove","script$1","_hoisted_1","Grid","collection","upToIndex","direction","fromIndex","reference","referenceOriginalPosition","index","child","hasNestedDrop","contains","getElementsByClassName","horizontal","magnets","before","center","after","correction","minDist","magnet","DnDEvent","ReorderEvent","from","to","array","temp","InsertEvent","script","items","required","row","column","noAnimations","grid","forbiddenKeys","feedbackKey","rootTag","TransitionGroup","rootProps","css","reordering","parentElement","closestIndex","itemsBeforeFeedback","itemsAfterFeedback","itemsBeforeReorderingFeedback","itemsAfterReorderingFeedback","reorderedItems","toIndex","reordered","showDragFeedback","showInsertingDragImage","showReorderingDragImage","hasReorderingFeedback","hasEmptySlot","onDragStart","refresh","$nextTick","_this4","computeInsertingGrid","computeFeedbackKey","computeForbiddenKeys","prototype","call","computeReorderingGrid","component","vn","k","feedback","tg","insertBefore","appendChild","removeChild","defaultArr","itemsReorderingBefore","_this5","reorder","concat","itemsReorderingAfter","itemsBefore","itemsAfter","defaultItems","DragImagesManager","bind","cleanUp","sourcePos","clones","then","_this6","img","switch","requestAnimationFrame","handler","forEach","sourceClone","activeClone","opacity","getSourceClone","has","visibility"],"mappings":"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"} |