|
- !(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);
- },
- ]);
- });
|