!(function(e, t) { 'object' == typeof exports && 'object' == typeof module ? (module.exports = t()) : 'function' == typeof define && define.amd ? define('dnd', [], t) : 'object' == typeof exports ? (exports.dnd = t()) : (e.dnd = t()); })(this, function() { return (function(e) { function t(n) { if (i[n]) return i[n].exports; var o = (i[n] = { i: n, l: !1, exports: {} }); return e[n].call(o.exports, o, o.exports, t), (o.l = !0), o.exports; } var i = {}; return ( (t.m = e), (t.c = i), (t.i = function(e) { return e; }), (t.d = function(e, i, n) { t.o(e, i) || Object.defineProperty(e, i, { configurable: !1, enumerable: !0, get: n, }); }), (t.n = function(e) { var i = e && e.__esModule ? function() { return e.default; } : function() { return e; }; return t.d(i, 'a', i), i; }), (t.o = function(e, t) { return Object.prototype.hasOwnProperty.call(e, t); }), (t.p = ''), t((t.s = 6)) ); })([ function(e, t, i) { 'use strict'; Object.defineProperty(t, '__esModule', { value: !0 }); (t.DOCUMENT_ADDR = 'https://github.com/qgh810/dnd'), (t.REMOVE_ANIMATION_TYPES = { fade: 'animation_fade', blost: 'animation_blost', back: 'animation_back', }); }, function(e, t, i) { 'use strict'; function n(e) { return e && e.__esModule ? e : { default: e }; } function o(e, t, i) { return ( t in e ? Object.defineProperty(e, t, { value: i, enumerable: !0, configurable: !0, writable: !0, }) : (e[t] = i), e ); } Object.defineProperty(t, '__esModule', { value: !0 }), (t.methods = void 0); var s, a = i(5), r = n(a), d = i(0), h = ((s = { isMobile: !1, data: null, draggedNode: null, sourceNode: null, markNode: null, stateIcon: null, mousePosition: null, targets: [], targetOnDragStarts: [], targetOnDragEnds: [], onDragEnters: [], onDragLeaves: [], onDragOvers: [], onDrops: [], targetPositions: [], targetIndex: -1, _prevValidIndex: -1, _inTarget: !1, onDragStart: function(e, t) { var i = this; this._initStore(), (this.sourceNode = t), (this.data = e), this.targetOnDragStarts.forEach(function(t, n) { return ( t && t({ data: e, enter: n === i.targetIndex, el: i.targets[n].el, sourceNode: i.sourceNode, name: i.targets[n].name, methods: u, }) ); }); }, _initStore: function() { (this._inTarget = !1), (this._prevValidIndex = -1), (this.targetIndex = -1), this.hideStateIcon(); }, onDragOver: function(e, t) { if ( ((this.mousePosition = [e, t]), (this.targetIndex = this.collision(e, t)), this.setIconPosition(e, t), this.targetIndex >= 0) ) { if (!this._inTarget) { (this._prevValidIndex = this.targetIndex), (this._inTarget = !0); var i = { enter: !0, data: this.data, el: this.targets[this.targetIndex].el, sourceNode: this.sourceNode, name: this.targets[this.targetIndex].name, methods: u, }; this.onDragEnters[this.targetIndex](i); } var n = { enter: !0, data: this.data, el: this.targets[this.targetIndex].el, sourceNode: this.sourceNode, name: this.targets[this.targetIndex].name, pageX: e, pageY: t, methods: u, }; this.onDragOvers[this.targetIndex](n); } else if (this._inTarget) { this._inTarget = !1; var o = { enter: !1, data: this.data, el: this.targets[this._prevValidIndex].el, sourceNode: this.sourceNode, name: this.targets[this._prevValidIndex].name, methods: u, }; this.onDragLeaves[this._prevValidIndex](o); } }, onDragEnd: function() { var e = this; if (this.targetIndex >= 0) { var t = { enter: !0, data: this.data, el: this.targets[this.targetIndex].el, sourceNode: this.sourceNode, name: this.targets[this.targetIndex].name, methods: u, }; this.targetIndex >= 0 && this.onDrops[this.targetIndex](t); } this.targetOnDragEnds.forEach(function(t, i) { if (t) { t({ enter: i === e.targetIndex, data: e.data, el: e.targets[i].el, sourceNode: e.sourceNode, name: e.targets[i].name, methods: u, }); } }); }, collision: function(e, t) { for (var i = -1, n = 0; n < this.targetPositions.length; n++) { var o = this.targetPositions[n]; if (o) { var s = n; if ( e >= o.left && t >= o.top && e <= o.right && t <= o.bottom ) { i = s; break; } } } return i; }, setIconPosition: function(e, t) { var i = this.stateIcon.style; (i.left = e + 8 + 'px'), (i.top = t + 'px'); }, showStateIcon: function(e) { var t = this; setTimeout(function() { if (t.isMobile) return console.warn( 'showStateIcon仅在pc端口可用 请参考相关说明' + d.DOCUMENT_ADDR ); e = r.default[e] || e || 'add'; var i = t.stateIcon.style; (i.display = 'block'), (i.background = 'no-repeat url(' + e + ') center center / 100% auto'); }, 0); }, hideStateIcon: function() { try { this.stateIcon.style.display = 'none'; } catch (e) {} }, removeDragedNode: function(e, t) { var i = this; return e && d.REMOVE_ANIMATION_TYPES[e] ? (setTimeout(function() { clearTimeout(i.removeMarkTid); }, 0), void this[d.REMOVE_ANIMATION_TYPES[e]](t)) : this.removeMark(); }, }), o(s, d.REMOVE_ANIMATION_TYPES.fade, function() { var e = arguments.length > 0 && void 0 !== arguments[0] ? arguments[0] : 150, t = this.draggedNode && this.draggedNode.style; t && ((t.transition = 'all ' + e / 1e3 + 's ease'), (t.opacity = '0'), setTimeout(this.removeMark.bind(this), e)); }), o(s, d.REMOVE_ANIMATION_TYPES.blost, function() { var e = arguments.length > 0 && void 0 !== arguments[0] ? arguments[0] : 150, t = this.draggedNode && this.draggedNode.style; t && ((t.transition = 'all ' + e / 1e3 + 's ease'), (t.boxShadow = '0 0 50px 30px rgba(0,0,0,0.3)'), (t.opacity = '0'), setTimeout(this.removeMark.bind(this), e)); }), o(s, d.REMOVE_ANIMATION_TYPES.back, function() { var e = arguments.length > 0 && void 0 !== arguments[0] ? arguments[0] : 400, t = this.draggedNode && this.draggedNode.style; t && ((t.transition = 'all ' + e / 1e3 + 's cubic-bezier(0.2,0.4,0.25,1.1)'), (t.transform = 'translate(0,0)'), setTimeout(this.removeMark.bind(this), e)); }), o(s, 'removeMark', function() { var e = this; clearTimeout(this.removeMarkTid), (this.removeMarkTid = setTimeout(function() { try { document.body.removeChild(e.markNode), (e.draggedNode = null); } catch (e) {} }, 10)); }), o(s, 'destroyDrop', function(e) { var t = this; this.targets.forEach(function(i, n) { i.name === e && t.removeDrop(n); }); }), o(s, 'removeDrop', function(e) { delete this.targets[e], delete this.targetOnDragStarts[e], delete this.targetOnDragEnds[e], delete this.onDragEnters[e], delete this.onDragLeaves[e], delete this.onDragOvers[e], delete this.onDrops[e], delete this.targetPositions[e]; }), o(s, 'getStateIconNode', function() { return this.stateIcon; }), s); t.default = h; var u = (t.methods = { showStateIcon: h.showStateIcon.bind(h), hideStateIcon: h.hideStateIcon.bind(h), getStateIconNode: h.getStateIconNode.bind(h), removeDragedNode: h.removeDragedNode.bind(h), destroyDrop: h.destroyDrop.bind(h), }); }, function(e, t, i) { 'use strict'; function n(e) { var t = e; if (!t) return console.error('找不到当前节点', e); if ('string' == typeof e) { var i = e; if (!(t = document.querySelector(i))) return console.error('找不到当前节点', e); } else if ( 'object' === (void 0 === e ? 'undefined' : o(e)) && !e.nodeName ) return console.error('找不到当前节点', e); return t; } Object.defineProperty(t, '__esModule', { value: !0 }); var o = 'function' == typeof Symbol && 'symbol' == typeof Symbol.iterator ? function(e) { return typeof e; } : function(e) { return e && 'function' == typeof Symbol && e.constructor === Symbol && e !== Symbol.prototype ? 'symbol' : typeof e; }; t.checkNode = n; }, function(e, t, i) { 'use strict'; function n(e) { return e && e.__esModule ? e : { default: e }; } function o(e) { if (Array.isArray(e)) { for (var t = 0, i = Array(e.length); t < e.length; t++) i[t] = e[t]; return i; } return Array.from(e); } function s(e, t) { if (!(e instanceof t)) throw new TypeError('Cannot call a class as a function'); } var a = (function() { function e(e, t) { for (var i = 0; i < t.length; i++) { var n = t[i]; (n.enumerable = n.enumerable || !1), (n.configurable = !0), 'value' in n && (n.writable = !0), Object.defineProperty(e, n.key, n); } } return function(t, i, n) { return i && e(t.prototype, i), n && e(t, n), t; }; })(), r = i(2), d = i(1), h = n(d), u = (function() { function e(t, i) { s(this, e), this.initData(t, i) && this.init(); } return ( a(e, [ { key: 'initData', value: function(e, t) { if (((this.el = (0, r.checkNode)(e)), this.el)) return ( (this.el.style.MozUserSelect = 'none'), (this.el.style.userSelect = 'none'), (this.el.style.cursor = 'default'), (t = this.checkOptions(t)), (this.options = t), (this.data = t.data), (this.mouseDownPosition = { left: -1, top: -1 }), (this.mouseDragging = !1), (this.mark = null), (this.position = { left: 0, top: 0 }), !0 ); }, }, { key: 'init', value: function() { this.addEventListenerPC(), this.addEventListenerMobile(); }, }, { key: 'addEventListenerPC', value: function() { function e(e) { var i = e.pageX, n = e.pageY; (this.mouseDownPosition = { left: i, top: n }), (t.onmousemove = this.onElMousemove.bind(this)), (t.onmouseup = this.onElMouseUp.bind(this)), document.addEventListener( 'mouseup', this.onElMouseUp.bind(this) ); } var t = this.el; t.addEventListener('mousedown', e.bind(this)); }, }, { key: 'addEventListenerMobile', value: function() { this.el.addEventListener( 'touchmove', this.onElTouchMove.bind(this) ), this.el.addEventListener( 'touchend', this.onElTouchEnd.bind(this) ); }, }, { key: 'onElMousemove', value: function() { this.mouseDragging || ((this.mouseDragging = !0), h.default.onDragStart(this.data, this.el), (this.position = this.el.getBoundingClientRect()), (this.mark = document.createElement('div')), (this.mark.className = 'x-drag-mark'), this.setMarkStyle(), (this.mark.onmousemove = this.onMarkMouseMove.bind(this)), (this.mark.onmouseup = this.onMarkMouseUp.bind(this)), (this.mark.onmouseleave = this.onMarkMouseUp.bind(this)), (h.default.markNode = this.mark), document.body.appendChild(this.mark), (h.default.draggedNode = this.el.cloneNode(!0)), this.setCloneNodeStyle(), this.mark.appendChild(h.default.draggedNode), (h.default.stateIcon = document.createElement('i')), (h.default.stateIcon.className = 'x-state-icon'), this.setIconStyle(), this.mark.appendChild(h.default.stateIcon), this.emit('onDragStart', { el: this.el, data: this.data, methods: d.methods, })); }, }, { key: 'onElMouseUp', value: function() { (this.mouseDragging = !1), (this.el.onmousemove = null), (this.el.onmouseup = null), this.mark && (this.mark.onmousemove = null), this.mark && (this.mark.onmouseup = null), d.methods.hideStateIcon(), d.methods.removeDragedNode(), document.removeEventListener( 'mouseup', this.onElMouseUp.bind(this) ); }, }, { key: 'onMarkMouseMove', value: function(e) { if (h.default.draggedNode) { var t = (e.touches && e.touches[0]) || e, i = t.pageX, n = t.pageY, o = i - this.mouseDownPosition.left, s = n - this.mouseDownPosition.top; (h.default.draggedNode.style.transform = 'translate(' + o + 'px,' + s + 'px)'), h.default.onDragOver(i, n); } }, }, { key: 'onMarkMouseUp', value: function() { document.removeEventListener( 'mouseup', this.onElMouseUp.bind(this) ), (this.mouseDragging = !1), (this.mark.onmousemove = null), (this.el.onmousemove = null), (this.mouseDownPosition = { left: -1, top: -1 }), this.emit('onDragEnd', { el: this.el, data: this.data, target: h.default.targets[h.default.targetIndex], methods: d.methods, }), h.default.onDragEnd(); }, }, { key: 'onElTouchMove', value: function(e) { if ( (e.preventDefault(), (h.default.isMobile = !0), this.mouseDownPosition.left === -1) ) { var t = e.touches[0], i = t.pageX, n = t.pageY; (this.mouseDownPosition.left = i), (this.mouseDownPosition.top = n); } this.onElMousemove(), this.onMarkMouseMove(e); }, }, { key: 'onElTouchEnd', value: function(e) { this.onMarkMouseUp(); }, }, { key: 'checkOptions', value: function(e) { e = e || {}; var t = { data: '这里可以放需要丢给目标的内容', el: this.el, removeanimationtype: 1, }; for (var i in t) !e[i] && (e[i] = t[i]); return e; }, }, { key: 'setMarkStyle', value: function() { var e = { position: 'absolute', top: '0', left: '0', width: '100%', height: '100%', zIndex: '10', }; for (var t in e) this.mark.style[t] = e[t]; }, }, { key: 'setCloneNodeStyle', value: function() { var e = h.default.draggedNode, t = e.style, i = this.position, n = i.left, o = i.top; (t.position = 'absolute'), (t.left = n + 'px'), (t.top = o + 'px'), (t.transform = 'translate(0,0)'), (t.zIndex = 1e3), (t.margin = 0); }, }, { key: 'setIconStyle', value: function() { var e = h.default.stateIcon.style; (e.display = 'none'), (e.position = 'absolute'), (e.width = '20px'), (e.height = '20px'), (e.zIndex = '10001'); }, }, { key: 'emit', value: function() { var e, t = Array.from(arguments), i = t.shift(); 'function' == typeof this.options[i] && (e = this.options)[i].apply(e, o(t)); }, }, ]), e ); })(); e.exports = u; }, function(e, t, i) { 'use strict'; function n(e) { return e && e.__esModule ? e : { default: e }; } function o(e) { if (Array.isArray(e)) { for (var t = 0, i = Array(e.length); t < e.length; t++) i[t] = e[t]; return i; } return Array.from(e); } function s(e, t) { if (!(e instanceof t)) throw new TypeError('Cannot call a class as a function'); } var a = (function() { function e(e, t) { for (var i = 0; i < t.length; i++) { var n = t[i]; (n.enumerable = n.enumerable || !1), (n.configurable = !0), 'value' in n && (n.writable = !0), Object.defineProperty(e, n.key, n); } } return function(t, i, n) { return i && e(t.prototype, i), n && e(t, n), t; }; })(), r = i(2), d = i(0), h = i(1), u = n(h), l = (function() { function e(t, i) { s(this, e), this.initData(t, i) && this.init(); } return ( a(e, [ { key: 'initData', value: function(e, t) { if ( ((this.el = (0, r.checkNode)(e)), this.el && ((this.options = this.checkOptions(t)), this.options)) ) return (this.index = -1), !0; }, }, { key: 'checkOptions', value: function(e) { if (!e) return console.error( this.el, '未检测到options 请参考相关说明' + d.DOCUMENT_ADDR ); if ('function' != typeof e.onDrop) return console.error( this.el, 'onDrop 必须是一个函数 请参考相关说明' + d.DOCUMENT_ADDR ); var t = { name: null }; for (var i in t) !e[e] && (e[e] = t[i]); return e; }, }, { key: 'init', value: function() { this.setStore(); }, }, { key: 'setStore', value: function() { var e = u.default.targets.push({ el: this.el, name: this.options.name, }) - 1; (this.index = e), (u.default.targetOnDragStarts[e] = this.onDragStart.bind( this )), (u.default.targetOnDragEnds[e] = this.onDragEnd.bind(this)), (u.default.onDragEnters[e] = this.onDragEnter.bind(this)), (u.default.onDragOvers[e] = this.onDragOver.bind(this)), (u.default.onDragLeaves[e] = this.onDragLeave.bind(this)), (u.default.onDrops[e] = this.onDrop.bind(this)); }, }, { key: 'onDragStart', value: function(e) { this.setStorePositions(), this.emit('onDragStart', e); }, }, { key: 'onDragEnd', value: function(e) { this.emit('onDragEnd', e); }, }, { key: 'onDragEnter', value: function(e) { this.emit('onDragEnter', e); }, }, { key: 'onDragOver', value: function(e) { this.emit('onDragOver', e); }, }, { key: 'onDragLeave', value: function(e) { this.emit('onDragLeave', e); }, }, { key: 'onDrop', value: function(e) { this.emit('onDrop', e); }, }, { key: 'setStorePositions', value: function() { var e = this.el.getBoundingClientRect(), t = e.left, i = e.top, n = e.width, o = e.height; u.default.targetPositions[this.index] = { top: i, bottom: i + o, left: t, right: t + n, }; }, }, { key: 'emit', value: function() { var e, t = Array.from(arguments), i = t.shift(); 'function' == typeof this.options[i] && (e = this.options)[i].apply(e, o(t)); }, }, ]), e ); })(); e.exports = l; }, function(e, t, i) { 'use strict'; Object.defineProperty(t, '__esModule', { value: !0 }); var n = { add: '', error: '', delete: '', reject: '', }; t.default = n; }, function(e, t, i) { 'use strict'; function n(e) { return e && e.__esModule ? e : { default: e }; } Object.defineProperty(t, '__esModule', { value: !0 }), (t.Drop = t.Drag = void 0); var o = i(3), s = n(o), a = i(4), r = n(a); (t.Drag = s.default), (t.Drop = r.default); }, ]); });