easy-drag-and-drop 1.3.178 → 1.3.179
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/example.js +48 -32
- package/lib/example/view/div/drag.js +182 -0
- package/lib/example/view/div/drop.js +251 -0
- package/lib/mixins/drag.js +21 -11
- package/lib/mixins/drop.js +22 -12
- package/package.json +1 -1
- package/src/example/view/div/drag.js +54 -0
- package/src/example/view/div/drop.js +78 -0
- package/src/mixins/drag.js +25 -11
- package/src/mixins/drop.js +26 -12
package/lib/mixins/drop.js
CHANGED
|
@@ -10,10 +10,25 @@ Object.defineProperty(exports, "default", {
|
|
|
10
10
|
});
|
|
11
11
|
var _reference = require("../utilities/reference");
|
|
12
12
|
var _customEventTypes = require("../customEventTypes");
|
|
13
|
-
|
|
13
|
+
function getDropElement() {
|
|
14
|
+
var dropElement = globalThis.dropElement;
|
|
15
|
+
return dropElement;
|
|
16
|
+
}
|
|
17
|
+
function setDropElement(dropElement) {
|
|
18
|
+
Object.assign(globalThis, {
|
|
19
|
+
dropElement: dropElement
|
|
20
|
+
});
|
|
21
|
+
}
|
|
22
|
+
function resetDropElement() {
|
|
23
|
+
var dropElement = null;
|
|
24
|
+
setDropElement(dropElement);
|
|
25
|
+
}
|
|
14
26
|
Object.assign(globalThis, {
|
|
15
|
-
|
|
27
|
+
getDropElement: getDropElement,
|
|
28
|
+
setDropElement: setDropElement,
|
|
29
|
+
resetDropElement: resetDropElement
|
|
16
30
|
});
|
|
31
|
+
resetDropElement();
|
|
17
32
|
function drop(event, element, dragElement, aborted, done) {
|
|
18
33
|
var customEventType = _customEventTypes.DROP_CUSTOM_EVENT_TYPE;
|
|
19
34
|
this.callCustomHandlersAsync(customEventType, event, element, dragElement, aborted, done);
|
|
@@ -72,29 +87,24 @@ var _default = {
|
|
|
72
87
|
offCustomDragOver: offCustomDragOver
|
|
73
88
|
};
|
|
74
89
|
function mouseOutHandler(event, element) {
|
|
75
|
-
var dragElement =
|
|
90
|
+
var dragElement = getDragElement();
|
|
76
91
|
if (dragElement !== null) {
|
|
77
|
-
|
|
78
|
-
Object.assign(globalThis, {
|
|
79
|
-
dropElement: dropElement
|
|
80
|
-
});
|
|
92
|
+
resetDropElement();
|
|
81
93
|
this.dragOut(event, element, dragElement);
|
|
82
94
|
}
|
|
83
95
|
event.stopPropagation();
|
|
84
96
|
}
|
|
85
97
|
function mouseOverHandler(event, element) {
|
|
86
|
-
var dragElement =
|
|
98
|
+
var dragElement = getDragElement();
|
|
87
99
|
if (dragElement !== null) {
|
|
88
100
|
var dropElement = this, dragElementIgnoresDropElement = (0, _reference.checkDragElementIgnoresDropElement)(dragElement, dropElement);
|
|
89
101
|
if (dragElementIgnoresDropElement) {
|
|
90
102
|
return;
|
|
91
103
|
}
|
|
92
|
-
|
|
93
|
-
dropElement: dropElement
|
|
94
|
-
});
|
|
104
|
+
setDropElement(dropElement);
|
|
95
105
|
this.dragOver(event, element, dragElement);
|
|
96
106
|
}
|
|
97
107
|
event.stopPropagation();
|
|
98
108
|
}
|
|
99
109
|
|
|
100
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
110
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/mixins/drop.js"],"sourcesContent":["\"use strict\";\n\nimport { checkDragElementIgnoresDropElement } from \"../utilities/reference\";\nimport { DROP_CUSTOM_EVENT_TYPE, DRAG_OUT_CUSTOM_EVENT_TYPE, DRAG_OVER_CUSTOM_EVENT_TYPE } from \"../customEventTypes\";\n\nfunction getDropElement() {\n  const { dropElement } = globalThis;\n\n  return dropElement;\n}\n\nfunction setDropElement(dropElement) {\n  Object.assign(globalThis, {\n    dropElement\n  });\n}\n\nfunction resetDropElement() {\n  const dropElement = null;\n\n  setDropElement(dropElement);\n}\n\nObject.assign(globalThis, {\n  getDropElement,\n  setDropElement,\n  resetDropElement\n});\n\nresetDropElement();\n\nfunction drop(event, element, dragElement, aborted, done) {\n  const customEventType = DROP_CUSTOM_EVENT_TYPE;\n\n  this.callCustomHandlersAsync(customEventType, event, element, dragElement, aborted, done);\n}\n\nfunction dragOut(event, element, dragElement) {\n  const customEventType = DRAG_OUT_CUSTOM_EVENT_TYPE;\n\n  this.callCustomHandlers(customEventType, event, element, dragElement);\n}\n\nfunction dragOver(event, element, dragElement) {\n  const customEventType = DRAG_OVER_CUSTOM_EVENT_TYPE;\n\n  this.callCustomHandlers(customEventType, event, element, dragElement);\n}\n\nfunction enableDrop() {\n  this.onMouseOut(mouseOutHandler, this);\n  this.onMouseOver(mouseOverHandler, this);\n}\n\nfunction disableDrop() {\n  this.offMouseOut(mouseOutHandler, this);\n  this.offMouseOver(mouseOverHandler, this);\n}\n\nfunction onCustomDrop(dropCustomHandler, element) {\n  const customEventType = DROP_CUSTOM_EVENT_TYPE,\n        customHandler = dropCustomHandler;  ///\n\n  this.onCustomEvent(customEventType, customHandler, element);\n}\n\nfunction offCustomDrop(dropCustomHandler, element) {\n  const customEventType = DROP_CUSTOM_EVENT_TYPE,\n        customHandler = dropCustomHandler;  ///\n\n  this.offCustomEvent(customEventType, customHandler, element);\n}\n\nfunction onCustomDragOut(dragOutCustomHandler, element) {\n  const customEventType = DRAG_OUT_CUSTOM_EVENT_TYPE,\n        customHandler = dragOutCustomHandler;  ///\n\n  this.onCustomEvent(customEventType, customHandler, element);\n}\n\nfunction offCustomDragOut(dragOutCustomHandler, element) {\n  const customEventType = DRAG_OUT_CUSTOM_EVENT_TYPE,\n        customHandler = dragOutCustomHandler;  ///\n\n  this.offCustomEvent(customEventType, customHandler, element);\n}\n\nfunction onCustomDragOver(dragOverCustomHandler, element) {\n  const customEventType = DRAG_OVER_CUSTOM_EVENT_TYPE,\n        customHandler = dragOverCustomHandler;  ///\n\n  this.onCustomEvent(customEventType, customHandler, element);\n}\n\nfunction offCustomDragOver(dragOverCustomHandler, element) {\n  const customEventType = DRAG_OVER_CUSTOM_EVENT_TYPE,\n        customHandler = dragOverCustomHandler;  ///\n\n  this.offCustomEvent(customEventType, customHandler, element);\n}\n\nexport default {\n  drop,\n  dragOut,\n  dragOver,\n  enableDrop,\n  disableDrop,\n  onCustomDrop,\n  offCustomDrop,\n  onCustomDragOut,\n  offCustomDragOut,\n  onCustomDragOver,\n  offCustomDragOver\n}\n\nfunction mouseOutHandler(event, element) {\n  const dragElement = getDragElement();\n\n  if (dragElement !== null) {\n    resetDropElement();\n\n    this.dragOut(event, element, dragElement);\n  }\n\n  event.stopPropagation();\n}\n\nfunction mouseOverHandler(event, element) {\n  const dragElement = getDragElement();\n\n  if (dragElement !== null) {\n    const dropElement = this, ///\n          dragElementIgnoresDropElement = checkDragElementIgnoresDropElement(dragElement, dropElement);\n\n    if (dragElementIgnoresDropElement) {\n      return;\n    }\n\n    setDropElement(dropElement);\n\n    this.dragOver(event, element, dragElement);\n  }\n\n  event.stopPropagation();\n}\n"],"names":["getDropElement","dropElement","globalThis","setDropElement","Object","assign","resetDropElement","drop","event","element","dragElement","aborted","done","customEventType","DROP_CUSTOM_EVENT_TYPE","callCustomHandlersAsync","dragOut","DRAG_OUT_CUSTOM_EVENT_TYPE","callCustomHandlers","dragOver","DRAG_OVER_CUSTOM_EVENT_TYPE","enableDrop","onMouseOut","mouseOutHandler","onMouseOver","mouseOverHandler","disableDrop","offMouseOut","offMouseOver","onCustomDrop","dropCustomHandler","customHandler","onCustomEvent","offCustomDrop","offCustomEvent","onCustomDragOut","dragOutCustomHandler","offCustomDragOut","onCustomDragOver","dragOverCustomHandler","offCustomDragOver","getDragElement","stopPropagation","dragElementIgnoresDropElement","checkDragElementIgnoresDropElement"],"mappings":"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"}
|
package/package.json
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "easy-drag-and-drop",
|
|
3
3
|
"author": "James Smith",
|
|
4
|
-
"version": "1.3.
|
|
4
|
+
"version": "1.3.179",
|
|
5
5
|
"license": "MIT, Anti-996",
|
|
6
6
|
"homepage": "https://github.com/djalbat/easy-drag-and-drop",
|
|
7
7
|
"description": "Drag and drop functionality for Easy elements.",
|
|
@@ -0,0 +1,54 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
import withStyle from "easy-with-style";
|
|
4
|
+
|
|
5
|
+
import { eventTypes } from "easy";
|
|
6
|
+
import { dragMixins, DragElement } from "../../../index"; ///
|
|
7
|
+
|
|
8
|
+
import style from "../../style";
|
|
9
|
+
|
|
10
|
+
const { DBLCLICK_EVENT_TYPE } = eventTypes;
|
|
11
|
+
|
|
12
|
+
class DragDiv extends DragElement {
|
|
13
|
+
doubleClickHandler = (event, element) => {
|
|
14
|
+
console.log("double click!")
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
didMount() {
|
|
18
|
+
this.enableDrag();
|
|
19
|
+
|
|
20
|
+
this.onEvent(DBLCLICK_EVENT_TYPE, this.doubleClickHandler, this);
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
willUnmount() {
|
|
24
|
+
this.offEvent(DBLCLICK_EVENT_TYPE, this.doubleClickHandler, this);
|
|
25
|
+
|
|
26
|
+
this.disableDrag();
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
childElements() {
|
|
30
|
+
return ("DRAG ELEMENT");
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
static tagName = "div";
|
|
34
|
+
|
|
35
|
+
static defaultProperties = {
|
|
36
|
+
className: "drag"
|
|
37
|
+
};
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
Object.assign(DragDiv.prototype, dragMixins);
|
|
41
|
+
|
|
42
|
+
export default withStyle(DragDiv)`
|
|
43
|
+
|
|
44
|
+
${style}
|
|
45
|
+
|
|
46
|
+
background-color: red;
|
|
47
|
+
|
|
48
|
+
.dragging {
|
|
49
|
+
z-index: 1;
|
|
50
|
+
position: fixed;
|
|
51
|
+
pointer-events: none;
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
`;
|
|
@@ -0,0 +1,78 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
import withStyle from "easy-with-style";
|
|
4
|
+
|
|
5
|
+
import { Element } from "easy";
|
|
6
|
+
import { dropMixins } from "../../../index"; ///
|
|
7
|
+
|
|
8
|
+
import style from "../../style";
|
|
9
|
+
|
|
10
|
+
class DropDiv extends Element {
|
|
11
|
+
dropCustomHandler = (event, element, dragElement, aborted, done) => {
|
|
12
|
+
if (dragElement !== null) {
|
|
13
|
+
dragElement.remove();
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
done();
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
dragOutCustomHandler = (event, element) => {
|
|
20
|
+
this.removeClass("drag-over");
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
dragOverCustomHandler = (event, element) => {
|
|
24
|
+
this.addClass("drag-over");
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
getReference() {
|
|
28
|
+
const { reference = null } = this.properties;
|
|
29
|
+
|
|
30
|
+
return reference;
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
didMount() {
|
|
34
|
+
this.enableDrop();
|
|
35
|
+
|
|
36
|
+
this.onCustomDrop(this.dropCustomHandler);
|
|
37
|
+
this.onCustomDragOut(this.dragOutCustomHandler);
|
|
38
|
+
this.onCustomDragOver(this.dragOverCustomHandler);
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
willUnmount() {
|
|
42
|
+
this.disableDrop();
|
|
43
|
+
|
|
44
|
+
this.offCustomDrop(this.dropCustomHandler);
|
|
45
|
+
this.offCustomDragOut(this.dragOutCustomHandler);
|
|
46
|
+
this.offCustomDragOver(this.dragOverCustomHandler);
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
childElements() {
|
|
50
|
+
return "DROP ELEMENT";
|
|
51
|
+
}
|
|
52
|
+
|
|
53
|
+
static tagName = "div";
|
|
54
|
+
|
|
55
|
+
static ignoredProperties = [
|
|
56
|
+
"reference"
|
|
57
|
+
];
|
|
58
|
+
|
|
59
|
+
static defaultProperties = {
|
|
60
|
+
className: "drop",
|
|
61
|
+
reference: "drop-div"
|
|
62
|
+
};
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
Object.assign(DropDiv.prototype, dropMixins);
|
|
66
|
+
|
|
67
|
+
export default withStyle(DropDiv)`
|
|
68
|
+
|
|
69
|
+
${style}
|
|
70
|
+
|
|
71
|
+
margin-bottom: 10rem;
|
|
72
|
+
background-color: green;
|
|
73
|
+
|
|
74
|
+
.drag-over {
|
|
75
|
+
background-color: blue;
|
|
76
|
+
}
|
|
77
|
+
|
|
78
|
+
`;
|
package/src/mixins/drag.js
CHANGED
|
@@ -12,12 +12,32 @@ const { ESCAPE_KEY_CODE } = keyCodes,
|
|
|
12
12
|
{ BLUR_EVENT_TYPE } = eventTypes,
|
|
13
13
|
{ LEFT_MOUSE_BUTTON } = mouseButtons;
|
|
14
14
|
|
|
15
|
-
|
|
15
|
+
function getDragElement() {
|
|
16
|
+
const { dragElement } = globalThis;
|
|
17
|
+
|
|
18
|
+
return dragElement;
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
function setDragElement(dragElement) {
|
|
22
|
+
Object.assign(globalThis, {
|
|
23
|
+
dragElement
|
|
24
|
+
});
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
function resetDragElement() {
|
|
28
|
+
const dragElement = null;
|
|
29
|
+
|
|
30
|
+
setDragElement(dragElement);
|
|
31
|
+
}
|
|
16
32
|
|
|
17
33
|
Object.assign(globalThis, {
|
|
18
|
-
|
|
34
|
+
getDragElement,
|
|
35
|
+
setDragElement,
|
|
36
|
+
resetDragElement
|
|
19
37
|
});
|
|
20
38
|
|
|
39
|
+
resetDragElement();
|
|
40
|
+
|
|
21
41
|
function enableDrag() {
|
|
22
42
|
const timeout = null,
|
|
23
43
|
topOffset = null,
|
|
@@ -109,9 +129,7 @@ function startDrag(event, element, mouseTop, mouseLeft) {
|
|
|
109
129
|
|
|
110
130
|
this.addClass("dragging");
|
|
111
131
|
|
|
112
|
-
|
|
113
|
-
dragElement
|
|
114
|
-
});
|
|
132
|
+
setDragElement(dragElement);
|
|
115
133
|
|
|
116
134
|
this.setTopOffset(topOffset);
|
|
117
135
|
|
|
@@ -127,7 +145,7 @@ function startDrag(event, element, mouseTop, mouseLeft) {
|
|
|
127
145
|
}
|
|
128
146
|
|
|
129
147
|
function stopDrag(event, element, aborted) {
|
|
130
|
-
const
|
|
148
|
+
const dropElement = getDropElement(),
|
|
131
149
|
customEventType = STOP_DRAG_CUSTOM_EVENT_TYPE;
|
|
132
150
|
|
|
133
151
|
window.offKeyDown(keyDownHandler, this);
|
|
@@ -136,11 +154,7 @@ function stopDrag(event, element, aborted) {
|
|
|
136
154
|
|
|
137
155
|
const done = () => {
|
|
138
156
|
this.callCustomHandlersAsync(customEventType, event, element, dropElement, aborted, () => {
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
Object.assign(globalThis, {
|
|
142
|
-
dragElement
|
|
143
|
-
});
|
|
157
|
+
resetDragElement();
|
|
144
158
|
|
|
145
159
|
this.removeClass("dragging");
|
|
146
160
|
});
|
package/src/mixins/drop.js
CHANGED
|
@@ -3,12 +3,32 @@
|
|
|
3
3
|
import { checkDragElementIgnoresDropElement } from "../utilities/reference";
|
|
4
4
|
import { DROP_CUSTOM_EVENT_TYPE, DRAG_OUT_CUSTOM_EVENT_TYPE, DRAG_OVER_CUSTOM_EVENT_TYPE } from "../customEventTypes";
|
|
5
5
|
|
|
6
|
-
|
|
6
|
+
function getDropElement() {
|
|
7
|
+
const { dropElement } = globalThis;
|
|
8
|
+
|
|
9
|
+
return dropElement;
|
|
10
|
+
}
|
|
11
|
+
|
|
12
|
+
function setDropElement(dropElement) {
|
|
13
|
+
Object.assign(globalThis, {
|
|
14
|
+
dropElement
|
|
15
|
+
});
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
function resetDropElement() {
|
|
19
|
+
const dropElement = null;
|
|
20
|
+
|
|
21
|
+
setDropElement(dropElement);
|
|
22
|
+
}
|
|
7
23
|
|
|
8
24
|
Object.assign(globalThis, {
|
|
9
|
-
|
|
25
|
+
getDropElement,
|
|
26
|
+
setDropElement,
|
|
27
|
+
resetDropElement
|
|
10
28
|
});
|
|
11
29
|
|
|
30
|
+
resetDropElement();
|
|
31
|
+
|
|
12
32
|
function drop(event, element, dragElement, aborted, done) {
|
|
13
33
|
const customEventType = DROP_CUSTOM_EVENT_TYPE;
|
|
14
34
|
|
|
@@ -94,14 +114,10 @@ export default {
|
|
|
94
114
|
}
|
|
95
115
|
|
|
96
116
|
function mouseOutHandler(event, element) {
|
|
97
|
-
const
|
|
117
|
+
const dragElement = getDragElement();
|
|
98
118
|
|
|
99
119
|
if (dragElement !== null) {
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
Object.assign(globalThis, {
|
|
103
|
-
dropElement
|
|
104
|
-
});
|
|
120
|
+
resetDropElement();
|
|
105
121
|
|
|
106
122
|
this.dragOut(event, element, dragElement);
|
|
107
123
|
}
|
|
@@ -110,7 +126,7 @@ function mouseOutHandler(event, element) {
|
|
|
110
126
|
}
|
|
111
127
|
|
|
112
128
|
function mouseOverHandler(event, element) {
|
|
113
|
-
const
|
|
129
|
+
const dragElement = getDragElement();
|
|
114
130
|
|
|
115
131
|
if (dragElement !== null) {
|
|
116
132
|
const dropElement = this, ///
|
|
@@ -120,9 +136,7 @@ function mouseOverHandler(event, element) {
|
|
|
120
136
|
return;
|
|
121
137
|
}
|
|
122
138
|
|
|
123
|
-
|
|
124
|
-
dropElement
|
|
125
|
-
});
|
|
139
|
+
setDropElement(dropElement);
|
|
126
140
|
|
|
127
141
|
this.dragOver(event, element, dragElement);
|
|
128
142
|
}
|