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.
@@ -10,10 +10,25 @@ Object.defineProperty(exports, "default", {
10
10
  });
11
11
  var _reference = require("../utilities/reference");
12
12
  var _customEventTypes = require("../customEventTypes");
13
- var dropElement = null;
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
- dropElement: dropElement
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 = globalThis.dragElement;
90
+ var dragElement = getDragElement();
76
91
  if (dragElement !== null) {
77
- var dropElement = null; ///
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 = globalThis.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
- Object.assign(globalThis, {
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,{"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\nconst dropElement = null;\n\nObject.assign(globalThis, {\n  dropElement\n});\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 } = globalThis;\n\n  if (dragElement !== null) {\n    const dropElement = null; ///\n\n    Object.assign(globalThis, {\n      dropElement\n    });\n\n    this.dragOut(event, element, dragElement);\n  }\n\n  event.stopPropagation();\n}\n\nfunction mouseOverHandler(event, element) {\n  const { dragElement } = globalThis;\n\n  if (dragElement !== null) {\n    const dropElement = this, ///\n          dragElementIgnoresDropElement = checkDragElementIgnoresDropElement(dragElement, dropElement);\n\n    if (dragElementIgnoresDropElement) {\n      return;\n    }\n\n    Object.assign(globalThis, {\n      dropElement\n    });\n\n    this.dragOver(event, element, dragElement);\n  }\n\n  event.stopPropagation();\n}\n"],"names":["dropElement","Object","assign","globalThis","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","stopPropagation","dragElementIgnoresDropElement","checkDragElementIgnoresDropElement"],"mappings":"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"}
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.178",
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
+ `;
@@ -12,12 +12,32 @@ const { ESCAPE_KEY_CODE } = keyCodes,
12
12
  { BLUR_EVENT_TYPE } = eventTypes,
13
13
  { LEFT_MOUSE_BUTTON } = mouseButtons;
14
14
 
15
- const dragElement = null;
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
- dragElement
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
- Object.assign(globalThis, {
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 { dropElement } = globalThis,
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
- const dragElement = null;
140
-
141
- Object.assign(globalThis, {
142
- dragElement
143
- });
157
+ resetDragElement();
144
158
 
145
159
  this.removeClass("dragging");
146
160
  });
@@ -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
- const dropElement = null;
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
- dropElement
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 { dragElement } = globalThis;
117
+ const dragElement = getDragElement();
98
118
 
99
119
  if (dragElement !== null) {
100
- const dropElement = null; ///
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 { dragElement } = globalThis;
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
- Object.assign(globalThis, {
124
- dropElement
125
- });
139
+ setDropElement(dropElement);
126
140
 
127
141
  this.dragOver(event, element, dragElement);
128
142
  }