jqtree 1.6.3 → 1.7.0
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/.github/workflows/ci.yml +21 -19
- package/.tool-versions +1 -0
- package/README.md +1 -1
- package/bower.json +10 -3
- package/config/production +2 -2
- package/config/{rollup.config.js → rollup.config.mjs} +3 -8
- package/docs/Gemfile.lock +3 -3
- package/docs/_config.yml +1 -1
- package/docs/_entries/10_changelog.md +9 -0
- package/docs/_entries/93_getnextnode.md +4 -1
- package/docs/_entries/{95_getpreviousnode.md → 95_getnextvisiblenode.md} +1 -1
- package/docs/_entries/96_getpreviousnode.md +0 -0
- package/docs/_entries/{96_getprevioussibling.md → 97_getprevioussibling.md} +0 -0
- package/docs/_entries/98_getpreviousvisiblenode.md +14 -0
- package/docs/_entries/{97_parent.md → 99_parent.md} +0 -0
- package/docs/package.json +7 -7
- package/docs/pnpm-lock.yaml +138 -108
- package/docs/static/bower.json +1 -1
- package/docs/static/bower_components/jquery/dist/jquery.js +209 -97
- package/docs/static/bower_components/jquery/dist/jquery.min.js +2 -2
- package/docs/static/documentation.css +224 -84
- package/docs/static/example.css +0 -1
- package/docs/tree.jquery.js +2 -2
- package/lib/dataLoader.js +5 -31
- package/lib/dragAndDropHandler.js +19 -132
- package/lib/elementsRenderer.js +29 -59
- package/lib/keyHandler.js +8 -32
- package/lib/mouse.widget.js +13 -74
- package/lib/node.js +60 -125
- package/lib/nodeElement.js +5 -72
- package/lib/playwright/coverage.js +58 -97
- package/lib/playwright/playwright.test.js +148 -210
- package/lib/playwright/testUtils.js +116 -182
- package/lib/saveStateHandler.js +12 -61
- package/lib/scrollHandler.js +17 -74
- package/lib/selectNodeHandler.js +5 -24
- package/lib/simple.widget.js +18 -53
- package/lib/test/jqTree/create.test.js +0 -4
- package/lib/test/jqTree/events.test.js +0 -7
- package/lib/test/jqTree/keyboard.test.js +0 -6
- package/lib/test/jqTree/loadOnDemand.test.js +84 -121
- package/lib/test/jqTree/methods.test.js +107 -150
- package/lib/test/jqTree/options.test.js +32 -54
- package/lib/test/node.test.js +127 -72
- package/lib/test/nodeUtil.test.js +0 -1
- package/lib/test/support/jqTreeMatchers.js +4 -9
- package/lib/test/support/setupTests.js +0 -4
- package/lib/test/support/testUtil.js +2 -11
- package/lib/test/support/treeStructure.js +0 -6
- package/lib/test/util.test.js +0 -1
- package/lib/tree.jquery.js +28 -239
- package/lib/util.js +0 -6
- package/lib/version.js +1 -1
- package/package.json +40 -39
- package/src/keyHandler.ts +3 -3
- package/src/node.ts +43 -12
- package/src/test/.eslintrc +3 -1
- package/src/test/node.test.ts +146 -54
- package/src/tree.jquery.ts +6 -5
- package/src/version.ts +1 -1
- package/tree.jquery.debug.js +202 -855
- package/tree.jquery.debug.js.map +1 -1
- package/tree.jquery.js +2 -2
- package/tree.jquery.js.map +1 -1
|
@@ -1,64 +1,39 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
|
-
function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); }
|
|
4
|
-
|
|
5
3
|
Object.defineProperty(exports, "__esModule", {
|
|
6
4
|
value: true
|
|
7
5
|
});
|
|
8
6
|
exports.HitAreasGenerator = exports.DragAndDropHandler = void 0;
|
|
9
|
-
|
|
10
7
|
var _node = require("./node");
|
|
11
|
-
|
|
8
|
+
function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); }
|
|
12
9
|
function _createForOfIteratorHelper(o, allowArrayLike) { var it = typeof Symbol !== "undefined" && o[Symbol.iterator] || o["@@iterator"]; if (!it) { if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === "number") { if (it) o = it; var i = 0; var F = function F() {}; return { s: F, n: function n() { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }, e: function e(_e) { throw _e; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var normalCompletion = true, didErr = false, err; return { s: function s() { it = it.call(o); }, n: function n() { var step = it.next(); normalCompletion = step.done; return step; }, e: function e(_e2) { didErr = true; err = _e2; }, f: function f() { try { if (!normalCompletion && it["return"] != null) it["return"](); } finally { if (didErr) throw err; } } }; }
|
|
13
|
-
|
|
14
10
|
function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
|
|
15
|
-
|
|
16
|
-
function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
|
|
17
|
-
|
|
11
|
+
function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }
|
|
18
12
|
function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); Object.defineProperty(subClass, "prototype", { writable: false }); if (superClass) _setPrototypeOf(subClass, superClass); }
|
|
19
|
-
|
|
20
13
|
function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }
|
|
21
|
-
|
|
22
14
|
function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }
|
|
23
|
-
|
|
24
15
|
function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } else if (call !== void 0) { throw new TypeError("Derived constructors may only return object or undefined"); } return _assertThisInitialized(self); }
|
|
25
|
-
|
|
26
16
|
function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; }
|
|
27
|
-
|
|
28
17
|
function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }
|
|
29
|
-
|
|
30
18
|
function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }
|
|
31
|
-
|
|
32
19
|
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
|
|
33
|
-
|
|
34
|
-
function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } }
|
|
35
|
-
|
|
20
|
+
function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, _toPropertyKey(descriptor.key), descriptor); } }
|
|
36
21
|
function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; }
|
|
37
|
-
|
|
38
|
-
function
|
|
39
|
-
|
|
22
|
+
function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
|
|
23
|
+
function _toPropertyKey(arg) { var key = _toPrimitive(arg, "string"); return _typeof(key) === "symbol" ? key : String(key); }
|
|
24
|
+
function _toPrimitive(input, hint) { if (_typeof(input) !== "object" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || "default"); if (_typeof(res) !== "object") return res; throw new TypeError("@@toPrimitive must return a primitive value."); } return (hint === "string" ? String : Number)(input); }
|
|
40
25
|
var DragAndDropHandler = /*#__PURE__*/function () {
|
|
41
26
|
function DragAndDropHandler(treeWidget) {
|
|
42
27
|
_classCallCheck(this, DragAndDropHandler);
|
|
43
|
-
|
|
44
28
|
_defineProperty(this, "hitAreas", void 0);
|
|
45
|
-
|
|
46
29
|
_defineProperty(this, "isDragging", void 0);
|
|
47
|
-
|
|
48
30
|
_defineProperty(this, "currentItem", void 0);
|
|
49
|
-
|
|
50
31
|
_defineProperty(this, "hoveredArea", void 0);
|
|
51
|
-
|
|
52
32
|
_defineProperty(this, "positionInfo", void 0);
|
|
53
|
-
|
|
54
33
|
_defineProperty(this, "treeWidget", void 0);
|
|
55
|
-
|
|
56
34
|
_defineProperty(this, "dragElement", void 0);
|
|
57
|
-
|
|
58
35
|
_defineProperty(this, "previousGhost", void 0);
|
|
59
|
-
|
|
60
36
|
_defineProperty(this, "openFolderTimer", void 0);
|
|
61
|
-
|
|
62
37
|
this.treeWidget = treeWidget;
|
|
63
38
|
this.hoveredArea = null;
|
|
64
39
|
this.hitAreas = [];
|
|
@@ -66,28 +41,22 @@ var DragAndDropHandler = /*#__PURE__*/function () {
|
|
|
66
41
|
this.currentItem = null;
|
|
67
42
|
this.positionInfo = null;
|
|
68
43
|
}
|
|
69
|
-
|
|
70
44
|
_createClass(DragAndDropHandler, [{
|
|
71
45
|
key: "mouseCapture",
|
|
72
46
|
value: function mouseCapture(positionInfo) {
|
|
73
47
|
var $element = jQuery(positionInfo.target);
|
|
74
|
-
|
|
75
48
|
if (!this.mustCaptureElement($element)) {
|
|
76
49
|
return null;
|
|
77
50
|
}
|
|
78
|
-
|
|
79
51
|
if (this.treeWidget.options.onIsMoveHandle && !this.treeWidget.options.onIsMoveHandle($element)) {
|
|
80
52
|
return null;
|
|
81
53
|
}
|
|
82
|
-
|
|
83
54
|
var nodeElement = this.treeWidget._getNodeElement($element);
|
|
84
|
-
|
|
85
55
|
if (nodeElement && this.treeWidget.options.onCanMove) {
|
|
86
56
|
if (!this.treeWidget.options.onCanMove(nodeElement.node)) {
|
|
87
57
|
nodeElement = null;
|
|
88
58
|
}
|
|
89
59
|
}
|
|
90
|
-
|
|
91
60
|
this.currentItem = nodeElement;
|
|
92
61
|
return this.currentItem != null;
|
|
93
62
|
}
|
|
@@ -95,11 +64,9 @@ var DragAndDropHandler = /*#__PURE__*/function () {
|
|
|
95
64
|
key: "mouseStart",
|
|
96
65
|
value: function mouseStart(positionInfo) {
|
|
97
66
|
var _this$treeWidget$opti;
|
|
98
|
-
|
|
99
67
|
if (!this.currentItem || positionInfo.pageX === undefined || positionInfo.pageY === undefined) {
|
|
100
68
|
return false;
|
|
101
69
|
}
|
|
102
|
-
|
|
103
70
|
this.refresh();
|
|
104
71
|
var offset = jQuery(positionInfo.target).offset();
|
|
105
72
|
var left = offset ? offset.left : 0;
|
|
@@ -117,25 +84,22 @@ var DragAndDropHandler = /*#__PURE__*/function () {
|
|
|
117
84
|
if (!this.currentItem || !this.dragElement || positionInfo.pageX === undefined || positionInfo.pageY === undefined) {
|
|
118
85
|
return false;
|
|
119
86
|
}
|
|
120
|
-
|
|
121
87
|
this.dragElement.move(positionInfo.pageX, positionInfo.pageY);
|
|
122
88
|
this.positionInfo = positionInfo;
|
|
123
89
|
var area = this.findHoveredArea(positionInfo.pageX, positionInfo.pageY);
|
|
124
|
-
|
|
125
90
|
if (area && this.canMoveToArea(area)) {
|
|
126
91
|
if (!area.node.isFolder()) {
|
|
127
92
|
this.stopOpenFolderTimer();
|
|
128
93
|
}
|
|
129
|
-
|
|
130
94
|
if (this.hoveredArea !== area) {
|
|
131
|
-
this.hoveredArea = area;
|
|
95
|
+
this.hoveredArea = area;
|
|
132
96
|
|
|
97
|
+
// If this is a closed folder, start timer to open it
|
|
133
98
|
if (this.mustOpenFolderTimer(area)) {
|
|
134
99
|
this.startOpenFolderTimer(area.node);
|
|
135
100
|
} else {
|
|
136
101
|
this.stopOpenFolderTimer();
|
|
137
102
|
}
|
|
138
|
-
|
|
139
103
|
this.updateDropHint();
|
|
140
104
|
}
|
|
141
105
|
} else {
|
|
@@ -143,13 +107,11 @@ var DragAndDropHandler = /*#__PURE__*/function () {
|
|
|
143
107
|
this.stopOpenFolderTimer();
|
|
144
108
|
this.hoveredArea = area;
|
|
145
109
|
}
|
|
146
|
-
|
|
147
110
|
if (!area) {
|
|
148
111
|
if (this.treeWidget.options.onDragMove) {
|
|
149
112
|
this.treeWidget.options.onDragMove(this.currentItem.node, positionInfo.originalEvent);
|
|
150
113
|
}
|
|
151
114
|
}
|
|
152
|
-
|
|
153
115
|
return true;
|
|
154
116
|
}
|
|
155
117
|
}, {
|
|
@@ -161,32 +123,26 @@ var DragAndDropHandler = /*#__PURE__*/function () {
|
|
|
161
123
|
this.removeDropHint();
|
|
162
124
|
this.removeHitAreas();
|
|
163
125
|
var currentItem = this.currentItem;
|
|
164
|
-
|
|
165
126
|
if (this.currentItem) {
|
|
166
127
|
this.currentItem.$element.removeClass("jqtree-moving");
|
|
167
128
|
this.currentItem = null;
|
|
168
129
|
}
|
|
169
|
-
|
|
170
130
|
this.isDragging = false;
|
|
171
131
|
this.positionInfo = null;
|
|
172
|
-
|
|
173
132
|
if (!this.hoveredArea && currentItem) {
|
|
174
133
|
if (this.treeWidget.options.onDragStop) {
|
|
175
134
|
this.treeWidget.options.onDragStop(currentItem.node, positionInfo.originalEvent);
|
|
176
135
|
}
|
|
177
136
|
}
|
|
178
|
-
|
|
179
137
|
return false;
|
|
180
138
|
}
|
|
181
139
|
}, {
|
|
182
140
|
key: "refresh",
|
|
183
141
|
value: function refresh() {
|
|
184
142
|
this.removeHitAreas();
|
|
185
|
-
|
|
186
143
|
if (this.currentItem) {
|
|
187
144
|
this.generateHitAreas();
|
|
188
145
|
this.currentItem = this.treeWidget._getNodeElementForNode(this.currentItem.node);
|
|
189
|
-
|
|
190
146
|
if (this.isDragging) {
|
|
191
147
|
this.currentItem.$element.addClass("jqtree-moving");
|
|
192
148
|
}
|
|
@@ -213,11 +169,9 @@ var DragAndDropHandler = /*#__PURE__*/function () {
|
|
|
213
169
|
if (!this.treeWidget.options.onCanMoveTo) {
|
|
214
170
|
return true;
|
|
215
171
|
}
|
|
216
|
-
|
|
217
172
|
if (!this.currentItem) {
|
|
218
173
|
return false;
|
|
219
174
|
}
|
|
220
|
-
|
|
221
175
|
var positionName = (0, _node.getPositionName)(area.position);
|
|
222
176
|
return this.treeWidget.options.onCanMoveTo(this.currentItem.node, area.node, positionName);
|
|
223
177
|
}
|
|
@@ -250,18 +204,14 @@ var DragAndDropHandler = /*#__PURE__*/function () {
|
|
|
250
204
|
key: "findHoveredArea",
|
|
251
205
|
value: function findHoveredArea(x, y) {
|
|
252
206
|
var dimensions = this.getTreeDimensions();
|
|
253
|
-
|
|
254
207
|
if (x < dimensions.left || y < dimensions.top || x > dimensions.right || y > dimensions.bottom) {
|
|
255
208
|
return null;
|
|
256
209
|
}
|
|
257
|
-
|
|
258
210
|
var low = 0;
|
|
259
211
|
var high = this.hitAreas.length;
|
|
260
|
-
|
|
261
212
|
while (low < high) {
|
|
262
213
|
var mid = low + high >> 1;
|
|
263
214
|
var area = this.hitAreas[mid];
|
|
264
|
-
|
|
265
215
|
if (y < area.top) {
|
|
266
216
|
high = mid;
|
|
267
217
|
} else if (y > area.bottom) {
|
|
@@ -270,7 +220,6 @@ var DragAndDropHandler = /*#__PURE__*/function () {
|
|
|
270
220
|
return area;
|
|
271
221
|
}
|
|
272
222
|
}
|
|
273
|
-
|
|
274
223
|
return null;
|
|
275
224
|
}
|
|
276
225
|
}, {
|
|
@@ -284,31 +233,27 @@ var DragAndDropHandler = /*#__PURE__*/function () {
|
|
|
284
233
|
value: function updateDropHint() {
|
|
285
234
|
if (!this.hoveredArea) {
|
|
286
235
|
return;
|
|
287
|
-
}
|
|
288
|
-
|
|
236
|
+
}
|
|
289
237
|
|
|
290
|
-
|
|
238
|
+
// remove previous drop hint
|
|
239
|
+
this.removeDropHint();
|
|
291
240
|
|
|
241
|
+
// add new drop hint
|
|
292
242
|
var nodeElement = this.treeWidget._getNodeElementForNode(this.hoveredArea.node);
|
|
293
|
-
|
|
294
243
|
this.previousGhost = nodeElement.addDropHint(this.hoveredArea.position);
|
|
295
244
|
}
|
|
296
245
|
}, {
|
|
297
246
|
key: "startOpenFolderTimer",
|
|
298
247
|
value: function startOpenFolderTimer(folder) {
|
|
299
248
|
var _this = this;
|
|
300
|
-
|
|
301
249
|
var openFolder = function openFolder() {
|
|
302
250
|
_this.treeWidget._openNode(folder, _this.treeWidget.options.slide, function () {
|
|
303
251
|
_this.refresh();
|
|
304
|
-
|
|
305
252
|
_this.updateDropHint();
|
|
306
253
|
});
|
|
307
254
|
};
|
|
308
|
-
|
|
309
255
|
this.stopOpenFolderTimer();
|
|
310
256
|
var openFolderDelay = this.treeWidget.options.openFolderDelay;
|
|
311
|
-
|
|
312
257
|
if (openFolderDelay !== false) {
|
|
313
258
|
this.openFolderTimer = window.setTimeout(openFolder, openFolderDelay);
|
|
314
259
|
}
|
|
@@ -325,25 +270,19 @@ var DragAndDropHandler = /*#__PURE__*/function () {
|
|
|
325
270
|
key: "moveItem",
|
|
326
271
|
value: function moveItem(positionInfo) {
|
|
327
272
|
var _this2 = this;
|
|
328
|
-
|
|
329
273
|
if (this.currentItem && this.hoveredArea && this.hoveredArea.position !== _node.Position.None && this.canMoveToArea(this.hoveredArea)) {
|
|
330
274
|
var movedNode = this.currentItem.node;
|
|
331
275
|
var targetNode = this.hoveredArea.node;
|
|
332
276
|
var position = this.hoveredArea.position;
|
|
333
277
|
var previousParent = movedNode.parent;
|
|
334
|
-
|
|
335
278
|
if (position === _node.Position.Inside) {
|
|
336
279
|
this.hoveredArea.node.is_open = true;
|
|
337
280
|
}
|
|
338
|
-
|
|
339
281
|
var doMove = function doMove() {
|
|
340
282
|
_this2.treeWidget.tree.moveNode(movedNode, targetNode, position);
|
|
341
|
-
|
|
342
283
|
_this2.treeWidget.element.empty();
|
|
343
|
-
|
|
344
284
|
_this2.treeWidget._refreshElements(null);
|
|
345
285
|
};
|
|
346
|
-
|
|
347
286
|
var event = this.treeWidget._triggerEvent("tree.move", {
|
|
348
287
|
move_info: {
|
|
349
288
|
moved_node: movedNode,
|
|
@@ -354,7 +293,6 @@ var DragAndDropHandler = /*#__PURE__*/function () {
|
|
|
354
293
|
original_event: positionInfo.originalEvent
|
|
355
294
|
}
|
|
356
295
|
});
|
|
357
|
-
|
|
358
296
|
if (!event.isDefaultPrevented()) {
|
|
359
297
|
doMove();
|
|
360
298
|
}
|
|
@@ -366,7 +304,6 @@ var DragAndDropHandler = /*#__PURE__*/function () {
|
|
|
366
304
|
// Return the dimensions of the tree. Add a margin to the bottom to allow
|
|
367
305
|
// to drag-and-drop after the last element.
|
|
368
306
|
var offset = this.treeWidget.element.offset();
|
|
369
|
-
|
|
370
307
|
if (!offset) {
|
|
371
308
|
return {
|
|
372
309
|
left: 0,
|
|
@@ -378,9 +315,7 @@ var DragAndDropHandler = /*#__PURE__*/function () {
|
|
|
378
315
|
var el = this.treeWidget.element;
|
|
379
316
|
var width = el.width() || 0;
|
|
380
317
|
var height = el.height() || 0;
|
|
381
|
-
|
|
382
318
|
var left = offset.left + this.treeWidget._getScrollLeft();
|
|
383
|
-
|
|
384
319
|
return {
|
|
385
320
|
left: left,
|
|
386
321
|
top: offset.top,
|
|
@@ -390,45 +325,32 @@ var DragAndDropHandler = /*#__PURE__*/function () {
|
|
|
390
325
|
}
|
|
391
326
|
}
|
|
392
327
|
}]);
|
|
393
|
-
|
|
394
328
|
return DragAndDropHandler;
|
|
395
329
|
}();
|
|
396
|
-
|
|
397
330
|
exports.DragAndDropHandler = DragAndDropHandler;
|
|
398
|
-
|
|
399
331
|
var VisibleNodeIterator = /*#__PURE__*/function () {
|
|
400
332
|
function VisibleNodeIterator(tree) {
|
|
401
333
|
_classCallCheck(this, VisibleNodeIterator);
|
|
402
|
-
|
|
403
334
|
_defineProperty(this, "tree", void 0);
|
|
404
|
-
|
|
405
335
|
this.tree = tree;
|
|
406
336
|
}
|
|
407
|
-
|
|
408
337
|
_createClass(VisibleNodeIterator, [{
|
|
409
338
|
key: "iterate",
|
|
410
339
|
value: function iterate() {
|
|
411
340
|
var _this3 = this;
|
|
412
|
-
|
|
413
341
|
var isFirstNode = true;
|
|
414
|
-
|
|
415
342
|
var _iterateNode = function _iterateNode(node, nextNode) {
|
|
416
343
|
var mustIterateInside = (node.is_open || !node.element) && node.hasChildren();
|
|
417
344
|
var $element = null;
|
|
418
|
-
|
|
419
345
|
if (node.element) {
|
|
420
346
|
$element = jQuery(node.element);
|
|
421
|
-
|
|
422
347
|
if (!$element.is(":visible")) {
|
|
423
348
|
return;
|
|
424
349
|
}
|
|
425
|
-
|
|
426
350
|
if (isFirstNode) {
|
|
427
351
|
_this3.handleFirstNode(node);
|
|
428
|
-
|
|
429
352
|
isFirstNode = false;
|
|
430
353
|
}
|
|
431
|
-
|
|
432
354
|
if (!node.hasChildren()) {
|
|
433
355
|
_this3.handleNode(node, nextNode, $element);
|
|
434
356
|
} else if (node.is_open) {
|
|
@@ -439,7 +361,6 @@ var VisibleNodeIterator = /*#__PURE__*/function () {
|
|
|
439
361
|
_this3.handleClosedFolder(node, nextNode, $element);
|
|
440
362
|
}
|
|
441
363
|
}
|
|
442
|
-
|
|
443
364
|
if (mustIterateInside) {
|
|
444
365
|
var childrenLength = node.children.length;
|
|
445
366
|
node.children.forEach(function (_, i) {
|
|
@@ -449,45 +370,31 @@ var VisibleNodeIterator = /*#__PURE__*/function () {
|
|
|
449
370
|
_iterateNode(node.children[i], node.children[i + 1]);
|
|
450
371
|
}
|
|
451
372
|
});
|
|
452
|
-
|
|
453
373
|
if (node.is_open && $element) {
|
|
454
374
|
_this3.handleAfterOpenFolder(node, nextNode);
|
|
455
375
|
}
|
|
456
376
|
}
|
|
457
377
|
};
|
|
458
|
-
|
|
459
378
|
_iterateNode(this.tree, null);
|
|
460
379
|
}
|
|
461
380
|
}]);
|
|
462
|
-
|
|
463
381
|
return VisibleNodeIterator;
|
|
464
382
|
}();
|
|
465
|
-
|
|
466
383
|
var HitAreasGenerator = /*#__PURE__*/function (_VisibleNodeIterator) {
|
|
467
384
|
_inherits(HitAreasGenerator, _VisibleNodeIterator);
|
|
468
|
-
|
|
469
385
|
var _super = _createSuper(HitAreasGenerator);
|
|
470
|
-
|
|
471
386
|
function HitAreasGenerator(tree, currentNode, treeBottom) {
|
|
472
387
|
var _this4;
|
|
473
|
-
|
|
474
388
|
_classCallCheck(this, HitAreasGenerator);
|
|
475
|
-
|
|
476
389
|
_this4 = _super.call(this, tree);
|
|
477
|
-
|
|
478
390
|
_defineProperty(_assertThisInitialized(_this4), "currentNode", void 0);
|
|
479
|
-
|
|
480
391
|
_defineProperty(_assertThisInitialized(_this4), "treeBottom", void 0);
|
|
481
|
-
|
|
482
392
|
_defineProperty(_assertThisInitialized(_this4), "positions", void 0);
|
|
483
|
-
|
|
484
393
|
_defineProperty(_assertThisInitialized(_this4), "lastTop", void 0);
|
|
485
|
-
|
|
486
394
|
_this4.currentNode = currentNode;
|
|
487
395
|
_this4.treeBottom = treeBottom;
|
|
488
396
|
return _this4;
|
|
489
397
|
}
|
|
490
|
-
|
|
491
398
|
_createClass(HitAreasGenerator, [{
|
|
492
399
|
key: "generate",
|
|
493
400
|
value: function generate() {
|
|
@@ -502,23 +409,18 @@ var HitAreasGenerator = /*#__PURE__*/function (_VisibleNodeIterator) {
|
|
|
502
409
|
var previousTop = -1;
|
|
503
410
|
var group = [];
|
|
504
411
|
var hitAreas = [];
|
|
505
|
-
|
|
506
412
|
var _iterator = _createForOfIteratorHelper(positions),
|
|
507
|
-
|
|
508
|
-
|
|
413
|
+
_step;
|
|
509
414
|
try {
|
|
510
415
|
for (_iterator.s(); !(_step = _iterator.n()).done;) {
|
|
511
416
|
var position = _step.value;
|
|
512
|
-
|
|
513
417
|
if (position.top !== previousTop && group.length) {
|
|
514
418
|
if (group.length) {
|
|
515
419
|
this.generateHitAreasForGroup(hitAreas, group, previousTop, position.top);
|
|
516
420
|
}
|
|
517
|
-
|
|
518
421
|
previousTop = position.top;
|
|
519
422
|
group = [];
|
|
520
423
|
}
|
|
521
|
-
|
|
522
424
|
group.push(position);
|
|
523
425
|
}
|
|
524
426
|
} catch (err) {
|
|
@@ -526,7 +428,6 @@ var HitAreasGenerator = /*#__PURE__*/function (_VisibleNodeIterator) {
|
|
|
526
428
|
} finally {
|
|
527
429
|
_iterator.f();
|
|
528
430
|
}
|
|
529
|
-
|
|
530
431
|
this.generateHitAreasForGroup(hitAreas, group, previousTop, this.treeBottom);
|
|
531
432
|
return hitAreas;
|
|
532
433
|
}
|
|
@@ -537,27 +438,27 @@ var HitAreasGenerator = /*#__PURE__*/function (_VisibleNodeIterator) {
|
|
|
537
438
|
// Cannot move inside current item
|
|
538
439
|
// Stop iterating
|
|
539
440
|
return false;
|
|
540
|
-
}
|
|
541
|
-
|
|
441
|
+
}
|
|
542
442
|
|
|
443
|
+
// Cannot move before current item
|
|
543
444
|
if (node.children[0] !== this.currentNode) {
|
|
544
445
|
this.addPosition(node, _node.Position.Inside, this.getTop($element));
|
|
545
|
-
}
|
|
546
|
-
|
|
446
|
+
}
|
|
547
447
|
|
|
448
|
+
// Continue iterating
|
|
548
449
|
return true;
|
|
549
450
|
}
|
|
550
451
|
}, {
|
|
551
452
|
key: "handleClosedFolder",
|
|
552
453
|
value: function handleClosedFolder(node, nextNode, $element) {
|
|
553
454
|
var top = this.getTop($element);
|
|
554
|
-
|
|
555
455
|
if (node === this.currentNode) {
|
|
556
456
|
// Cannot move after current item
|
|
557
457
|
this.addPosition(node, _node.Position.None, top);
|
|
558
458
|
} else {
|
|
559
|
-
this.addPosition(node, _node.Position.Inside, top);
|
|
459
|
+
this.addPosition(node, _node.Position.Inside, top);
|
|
560
460
|
|
|
461
|
+
// Cannot move before current item
|
|
561
462
|
if (nextNode !== this.currentNode) {
|
|
562
463
|
this.addPosition(node, _node.Position.After, top);
|
|
563
464
|
}
|
|
@@ -584,14 +485,12 @@ var HitAreasGenerator = /*#__PURE__*/function (_VisibleNodeIterator) {
|
|
|
584
485
|
key: "handleNode",
|
|
585
486
|
value: function handleNode(node, nextNode, $element) {
|
|
586
487
|
var top = this.getTop($element);
|
|
587
|
-
|
|
588
488
|
if (node === this.currentNode) {
|
|
589
489
|
// Cannot move inside current item
|
|
590
490
|
this.addPosition(node, _node.Position.None, top);
|
|
591
491
|
} else {
|
|
592
492
|
this.addPosition(node, _node.Position.Inside, top);
|
|
593
493
|
}
|
|
594
|
-
|
|
595
494
|
if (nextNode === this.currentNode || node === this.currentNode) {
|
|
596
495
|
// Cannot move before or after current item
|
|
597
496
|
this.addPosition(node, _node.Position.None, top);
|
|
@@ -625,7 +524,6 @@ var HitAreasGenerator = /*#__PURE__*/function (_VisibleNodeIterator) {
|
|
|
625
524
|
var areaHeight = Math.round((bottom - top) / positionCount);
|
|
626
525
|
var areaTop = top;
|
|
627
526
|
var i = 0;
|
|
628
|
-
|
|
629
527
|
while (i < positionCount) {
|
|
630
528
|
var position = positionsInGroup[i];
|
|
631
529
|
hitAreas.push({
|
|
@@ -639,36 +537,26 @@ var HitAreasGenerator = /*#__PURE__*/function (_VisibleNodeIterator) {
|
|
|
639
537
|
}
|
|
640
538
|
}
|
|
641
539
|
}]);
|
|
642
|
-
|
|
643
540
|
return HitAreasGenerator;
|
|
644
541
|
}(VisibleNodeIterator);
|
|
645
|
-
|
|
646
542
|
exports.HitAreasGenerator = HitAreasGenerator;
|
|
647
|
-
|
|
648
543
|
var DragElement = /*#__PURE__*/function () {
|
|
649
544
|
function DragElement(nodeName, offsetX, offsetY, $tree, autoEscape) {
|
|
650
545
|
_classCallCheck(this, DragElement);
|
|
651
|
-
|
|
652
546
|
_defineProperty(this, "offsetX", void 0);
|
|
653
|
-
|
|
654
547
|
_defineProperty(this, "offsetY", void 0);
|
|
655
|
-
|
|
656
548
|
_defineProperty(this, "$element", void 0);
|
|
657
|
-
|
|
658
549
|
this.offsetX = offsetX;
|
|
659
550
|
this.offsetY = offsetY;
|
|
660
551
|
this.$element = jQuery("<span>").addClass("jqtree-title jqtree-dragging");
|
|
661
|
-
|
|
662
552
|
if (autoEscape) {
|
|
663
553
|
this.$element.text(nodeName);
|
|
664
554
|
} else {
|
|
665
555
|
this.$element.html(nodeName);
|
|
666
556
|
}
|
|
667
|
-
|
|
668
557
|
this.$element.css("position", "absolute");
|
|
669
558
|
$tree.append(this.$element);
|
|
670
559
|
}
|
|
671
|
-
|
|
672
560
|
_createClass(DragElement, [{
|
|
673
561
|
key: "move",
|
|
674
562
|
value: function move(pageX, pageY) {
|
|
@@ -683,6 +571,5 @@ var DragElement = /*#__PURE__*/function () {
|
|
|
683
571
|
this.$element.remove();
|
|
684
572
|
}
|
|
685
573
|
}]);
|
|
686
|
-
|
|
687
574
|
return DragElement;
|
|
688
575
|
}();
|