easy-file-system 1.5.1 → 1.5.3

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.
@@ -75,6 +75,45 @@ function _interopRequireDefault(obj) {
75
75
  default: obj
76
76
  };
77
77
  }
78
+ function _objectSpread(target) {
79
+ for(var i = 1; i < arguments.length; i++){
80
+ var source = arguments[i] != null ? arguments[i] : {};
81
+ var ownKeys = Object.keys(source);
82
+ if (typeof Object.getOwnPropertySymbols === "function") {
83
+ ownKeys = ownKeys.concat(Object.getOwnPropertySymbols(source).filter(function(sym) {
84
+ return Object.getOwnPropertyDescriptor(source, sym).enumerable;
85
+ }));
86
+ }
87
+ ownKeys.forEach(function(key) {
88
+ _defineProperty(target, key, source[key]);
89
+ });
90
+ }
91
+ return target;
92
+ }
93
+ function ownKeys(object, enumerableOnly) {
94
+ var keys = Object.keys(object);
95
+ if (Object.getOwnPropertySymbols) {
96
+ var symbols = Object.getOwnPropertySymbols(object);
97
+ if (enumerableOnly) {
98
+ symbols = symbols.filter(function(sym) {
99
+ return Object.getOwnPropertyDescriptor(object, sym).enumerable;
100
+ });
101
+ }
102
+ keys.push.apply(keys, symbols);
103
+ }
104
+ return keys;
105
+ }
106
+ function _objectSpreadProps(target, source) {
107
+ source = source != null ? source : {};
108
+ if (Object.getOwnPropertyDescriptors) {
109
+ Object.defineProperties(target, Object.getOwnPropertyDescriptors(source));
110
+ } else {
111
+ ownKeys(Object(source)).forEach(function(key) {
112
+ Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key));
113
+ });
114
+ }
115
+ return target;
116
+ }
78
117
  function _possibleConstructorReturn(self, call) {
79
118
  if (call && (_typeof(call) === "object" || typeof call === "function")) {
80
119
  return call;
@@ -129,7 +168,7 @@ function _createSuper(Derived) {
129
168
  function _templateObject() {
130
169
  var data = _taggedTemplateLiteral([
131
170
  "\n\n font-size: ",
132
- ";\n user-select: none;\n\n .dragging {\n z-index: 1;\n position: fixed;\n pointer-events: none;\n }\n \n"
171
+ ";\n user-select: none;\n \n font-weight: normal;\n \n .selected {\n font-weight: bold;\n }\n\n .dragging {\n z-index: 1;\n position: fixed;\n pointer-events: none;\n }\n \n"
133
172
  ]);
134
173
  _templateObject = function _templateObject() {
135
174
  return data;
@@ -164,6 +203,20 @@ var DragEntryItem = /*#__PURE__*/ function(EntryItem) {
164
203
  return _this;
165
204
  }
166
205
  _createClass(DragEntryItem, [
206
+ {
207
+ key: "retrieveMarkerEntryItem",
208
+ value: function retrieveMarkerEntryItem() {
209
+ var markerEntryItem = globalThis.markerEntryItem;
210
+ return markerEntryItem;
211
+ }
212
+ },
213
+ {
214
+ key: "isSelected",
215
+ value: function isSelected() {
216
+ var selected = this.hasClass("selected"); ///
217
+ return selected;
218
+ }
219
+ },
167
220
  {
168
221
  key: "getPathMap",
169
222
  value: function getPathMap(sourceEntryPath, targetEntryPath) {
@@ -187,10 +240,15 @@ var DragEntryItem = /*#__PURE__*/ function(EntryItem) {
187
240
  }
188
241
  },
189
242
  {
190
- key: "retrieveMarkerEntryItem",
191
- value: function retrieveMarkerEntryItem() {
192
- var markerEntryItem = globalThis.markerEntryItem;
193
- return markerEntryItem;
243
+ key: "deselect",
244
+ value: function deselect() {
245
+ this.removeClass("selected");
246
+ }
247
+ },
248
+ {
249
+ key: "select",
250
+ value: function select() {
251
+ this.addClass("selected");
194
252
  }
195
253
  },
196
254
  {
@@ -209,6 +267,16 @@ var DragEntryItem = /*#__PURE__*/ function(EntryItem) {
209
267
  this.disableDrag();
210
268
  }
211
269
  },
270
+ {
271
+ key: "parentContext",
272
+ value: function parentContext() {
273
+ var context = this.getContext(), select = this.select.bind(this), deselect = this.deselect.bind(this);
274
+ return _objectSpreadProps(_objectSpread({}, context), {
275
+ select: select,
276
+ deselect: deselect
277
+ });
278
+ }
279
+ },
212
280
  {
213
281
  key: "initialise",
214
282
  value: function initialise() {
@@ -224,4 +292,4 @@ _defineProperty(DragEntryItem, "defaultProperties", {
224
292
  Object.assign(_entry.default.prototype, _easyDragAndDrop.dragMixins);
225
293
  var _default = (0, _easyWithStyle.default)(DragEntryItem)(_templateObject(), _styles.dragEntryItemFontSize);
226
294
 
227
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9pdGVtL2VudHJ5L2RyYWcuanMiXSwic291cmNlc0NvbnRlbnQiOlsiXCJ1c2Ugc3RyaWN0XCI7XG5cbmltcG9ydCB3aXRoU3R5bGUgZnJvbSBcImVhc3ktd2l0aC1zdHlsZVwiOyAgLy8vXG5cbmltcG9ydCB7IGRyYWdNaXhpbnMgfSBmcm9tIFwiZWFzeS1kcmFnLWFuZC1kcm9wXCI7XG5cbmltcG9ydCBFbnRyeUl0ZW0gZnJvbSBcIi4uLy4uL2l0ZW0vZW50cnlcIjtcblxuaW1wb3J0IHsgZHJhZ0VudHJ5SXRlbUZvbnRTaXplIH0gZnJvbSBcIi4uLy4uL3N0eWxlc1wiO1xuaW1wb3J0IHsgYWRqdXN0U291cmNlRW50cnlQYXRoLCBhZGp1c3RUYXJnZXRFbnRyeVBhdGggfSBmcm9tIFwiLi4vLi4vdXRpbGl0aWVzL3BhdGhNYXBcIjtcblxuY2xhc3MgRHJhZ0VudHJ5SXRlbSBleHRlbmRzIEVudHJ5SXRlbSB7XG4gIHN0YXJ0RHJhZ0hhbmRsZXIgPSAoZWxlbWVudCkgPT4ge1xuICAgIGNvbnN0IHBhdGggPSB0aGlzLmdldFBhdGgoKSxcbiAgICAgICAgICB0eXBlID0gdGhpcy5nZXRUeXBlKCksXG4gICAgICAgICAgZXhwbG9yZXIgPSB0aGlzLmdldEV4cGxvcmVyKCksXG4gICAgICAgICAgZHJhZ0VudHJ5SXRlbVR5cGUgPSB0eXBlLCAgLy8vXG4gICAgICAgICAgbWFya2VyRW50cnlJdGVtUGF0aCA9IHBhdGg7ICAvLy9cblxuICAgIGV4cGxvcmVyLmFkZE1hcmtlcihtYXJrZXJFbnRyeUl0ZW1QYXRoLCBkcmFnRW50cnlJdGVtVHlwZSk7XG4gIH1cblxuICBzdG9wRHJhZ0hhbmRsZXIgPSAoZHJvcEVsZW1lbnQsIGFib3J0ZWQsIGVsZW1lbnQsIGRvbmUpID0+IHtcbiAgICBpZiAoZHJvcEVsZW1lbnQgIT09IG51bGwpIHtcbiAgICAgIGRvbmUoKTtcblxuICAgICAgcmV0dXJuO1xuICAgIH1cblxuICAgIGNvbnN0IG1hcmtlckVudHJ5SXRlbSA9IHRoaXMucmV0cmlldmVNYXJrZXJFbnRyeUl0ZW0oKSxcbiAgICAgICAgICBtYXJrZXJFbnRyeUl0ZW1FeHBsb3JlciA9IG1hcmtlckVudHJ5SXRlbS5nZXRFeHBsb3JlcigpO1xuXG4gICAgaWYgKGFib3J0ZWQpIHtcbiAgICAgIG1hcmtlckVudHJ5SXRlbUV4cGxvcmVyLnJlbW92ZU1hcmtlcigpO1xuXG4gICAgICBkb25lKCk7XG5cbiAgICAgIHJldHVybjtcbiAgICB9XG5cbiAgICBjb25zdCBkcmFnRW50cnlJdGVtID0gZWxlbWVudDsgIC8vL1xuXG4gICAgbWFya2VyRW50cnlJdGVtRXhwbG9yZXIuZHJvcERyYWdFbnRyeUl0ZW0oZHJhZ0VudHJ5SXRlbSwgZG9uZSk7XG4gIH1cblxuICBnZXRQYXRoTWFwKHNvdXJjZUVudHJ5UGF0aCwgdGFyZ2V0RW50cnlQYXRoKSB7XG5cdFx0Y29uc3QgbmFtZSA9IHRoaXMuZ2V0TmFtZSgpO1xuXG5cdFx0c291cmNlRW50cnlQYXRoID0gYWRqdXN0U291cmNlRW50cnlQYXRoKHNvdXJjZUVudHJ5UGF0aCwgbmFtZSk7XHQvLy9cblx0XHR0YXJnZXRFbnRyeVBhdGggPSBhZGp1c3RUYXJnZXRFbnRyeVBhdGgodGFyZ2V0RW50cnlQYXRoLCBuYW1lKTtcdC8vL1xuXG5cdFx0Y29uc3QgcGF0aE1hcCA9IHtcblx0XHRcdHNvdXJjZUVudHJ5UGF0aCxcblx0XHRcdHRhcmdldEVudHJ5UGF0aFxuXHRcdH07XG5cblx0XHRyZXR1cm4gcGF0aE1hcDtcblx0fVxuXG5cdGdldFBhdGhNYXBzKHNvdXJjZUVudHJ5UGF0aCwgdGFyZ2V0RW50cnlQYXRoKSB7XG5cdFx0bGV0IHBhdGhNYXBzID0gW107XG5cblx0XHR0aGlzLnJldHJpZXZlUGF0aE1hcHMoc291cmNlRW50cnlQYXRoLCB0YXJnZXRFbnRyeVBhdGgsIHBhdGhNYXBzKTtcblxuXHRcdHBhdGhNYXBzLnJldmVyc2UoKTtcblxuXHRcdHJldHVybiBwYXRoTWFwcztcblx0fVxuXG5cdHJldHJpZXZlTWFya2VyRW50cnlJdGVtKCkge1xuXHRcdGNvbnN0IHsgbWFya2VyRW50cnlJdGVtIH0gPSBnbG9iYWxUaGlzO1xuXG5cdFx0cmV0dXJuIG1hcmtlckVudHJ5SXRlbTtcblx0fVxuXG5cdGRpZE1vdW50KCkge1xuXHQgIHRoaXMub25TdGFydERyYWcodGhpcy5zdGFydERyYWdIYW5kbGVyKTtcblxuICAgIHRoaXMub25TdG9wRHJhZyh0aGlzLnN0b3BEcmFnSGFuZGxlcik7XG5cbiAgICB0aGlzLmVuYWJsZURyYWcoKTtcblx0fVxuXG5cdHdpbGxVbm1vdW50KCkge1xuICAgIHRoaXMub2ZmU3RhcnREcmFnKHRoaXMuc3RhcnREcmFnSGFuZGxlcik7XG5cbiAgICB0aGlzLm9mZlN0b3BEcmFnKHRoaXMuc3RvcERyYWdIYW5kbGVyKTtcblxuICAgIHRoaXMuZGlzYWJsZURyYWcoKTtcblx0fVxuXG5cdGluaXRpYWxpc2UoKSB7XG5cdFx0dGhpcy5hc3NpZ25Db250ZXh0KCk7XG5cdH1cblxuXHRzdGF0aWMgZGVmYXVsdFByb3BlcnRpZXMgPSB7XG5cdFx0Y2xhc3NOYW1lOiBcImRyYWdcIlxuXHR9O1xufVxuXG5PYmplY3QuYXNzaWduKEVudHJ5SXRlbS5wcm90b3R5cGUsIGRyYWdNaXhpbnMpO1xuXG5leHBvcnQgZGVmYXVsdCB3aXRoU3R5bGUoRHJhZ0VudHJ5SXRlbSlgXG5cblx0Zm9udC1zaXplOiAke2RyYWdFbnRyeUl0ZW1Gb250U2l6ZX07XG4gIHVzZXItc2VsZWN0OiBub25lO1xuXG4gIC5kcmFnZ2luZyB7XG4gICAgei1pbmRleDogMTtcbiAgICBwb3NpdGlvbjogZml4ZWQ7XG4gICAgcG9pbnRlci1ldmVudHM6IG5vbmU7XG4gIH1cbiAgXG5gO1xuIl0sIm5hbWVzIjpbIkRyYWdFbnRyeUl0ZW0iLCJzdGFydERyYWdIYW5kbGVyIiwiZWxlbWVudCIsInBhdGgiLCJnZXRQYXRoIiwidHlwZSIsImdldFR5cGUiLCJleHBsb3JlciIsImdldEV4cGxvcmVyIiwiZHJhZ0VudHJ5SXRlbVR5cGUiLCJtYXJrZXJFbnRyeUl0ZW1QYXRoIiwiYWRkTWFya2VyIiwic3RvcERyYWdIYW5kbGVyIiwiZHJvcEVsZW1lbnQiLCJhYm9ydGVkIiwiZG9uZSIsIm1hcmtlckVudHJ5SXRlbSIsInJldHJpZXZlTWFya2VyRW50cnlJdGVtIiwibWFya2VyRW50cnlJdGVtRXhwbG9yZXIiLCJyZW1vdmVNYXJrZXIiLCJkcmFnRW50cnlJdGVtIiwiZHJvcERyYWdFbnRyeUl0ZW0iLCJnZXRQYXRoTWFwIiwic291cmNlRW50cnlQYXRoIiwidGFyZ2V0RW50cnlQYXRoIiwibmFtZSIsImdldE5hbWUiLCJhZGp1c3RTb3VyY2VFbnRyeVBhdGgiLCJhZGp1c3RUYXJnZXRFbnRyeVBhdGgiLCJwYXRoTWFwIiwiZ2V0UGF0aE1hcHMiLCJwYXRoTWFwcyIsInJldHJpZXZlUGF0aE1hcHMiLCJyZXZlcnNlIiwiZ2xvYmFsVGhpcyIsImRpZE1vdW50Iiwib25TdGFydERyYWciLCJvblN0b3BEcmFnIiwiZW5hYmxlRHJhZyIsIndpbGxVbm1vdW50Iiwib2ZmU3RhcnREcmFnIiwib2ZmU3RvcERyYWciLCJkaXNhYmxlRHJhZyIsImluaXRpYWxpc2UiLCJhc3NpZ25Db250ZXh0IiwiRW50cnlJdGVtIiwiZGVmYXVsdFByb3BlcnRpZXMiLCJjbGFzc05hbWUiLCJPYmplY3QiLCJhc3NpZ24iLCJwcm90b3R5cGUiLCJkcmFnTWl4aW5zIiwid2l0aFN0eWxlIiwiZHJhZ0VudHJ5SXRlbUZvbnRTaXplIl0sIm1hcHBpbmdzIjoiQUFBQTs7OzsrQkFzR0E7OztlQUFBOzs7a0VBcEdzQjsrQkFFSzswREFFTDtzQkFFZ0I7dUJBQ3VCOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBRTdELElBQUEsQUFBTUEsOEJBeUZILEFBekZIO2NBQU1BOzhCQUFBQTth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
295
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../src/item/entry/drag.js"],"sourcesContent":["\"use strict\";\n\nimport withStyle from \"easy-with-style\";  ///\n\nimport { dragMixins } from \"easy-drag-and-drop\";\n\nimport EntryItem from \"../../item/entry\";\n\nimport { dragEntryItemFontSize } from \"../../styles\";\nimport { adjustSourceEntryPath, adjustTargetEntryPath } from \"../../utilities/pathMap\";\n\nclass DragEntryItem extends EntryItem {\n  startDragHandler = (element) => {\n    const path = this.getPath(),\n          type = this.getType(),\n          explorer = this.getExplorer(),\n          dragEntryItemType = type,  ///\n          markerEntryItemPath = path;  ///\n\n    explorer.addMarker(markerEntryItemPath, dragEntryItemType);\n  }\n\n  stopDragHandler = (dropElement, aborted, element, done) => {\n    if (dropElement !== null) {\n      done();\n\n      return;\n    }\n\n    const markerEntryItem = this.retrieveMarkerEntryItem(),\n          markerEntryItemExplorer = markerEntryItem.getExplorer();\n\n    if (aborted) {\n      markerEntryItemExplorer.removeMarker();\n\n      done();\n\n      return;\n    }\n\n    const dragEntryItem = element;  ///\n\n    markerEntryItemExplorer.dropDragEntryItem(dragEntryItem, done);\n  }\n\n  retrieveMarkerEntryItem() {\n    const { markerEntryItem } = globalThis;\n\n    return markerEntryItem;\n  }\n\n  isSelected() {\n    const selected = this.hasClass(\"selected\"); ///\n\n    return selected;\n  }\n\n  getPathMap(sourceEntryPath, targetEntryPath) {\n\t\tconst name = this.getName();\n\n\t\tsourceEntryPath = adjustSourceEntryPath(sourceEntryPath, name);\t///\n\t\ttargetEntryPath = adjustTargetEntryPath(targetEntryPath, name);\t///\n\n\t\tconst pathMap = {\n\t\t\tsourceEntryPath,\n\t\t\ttargetEntryPath\n\t\t};\n\n\t\treturn pathMap;\n\t}\n\n\tgetPathMaps(sourceEntryPath, targetEntryPath) {\n\t\tlet pathMaps = [];\n\n\t\tthis.retrievePathMaps(sourceEntryPath, targetEntryPath, pathMaps);\n\n\t\tpathMaps.reverse();\n\n\t\treturn pathMaps;\n\t}\n\n  deselect() {\n    this.removeClass(\"selected\");\n  }\n\n  select() {\n    this.addClass(\"selected\");\n  }\n\n  didMount() {\n\t  this.onStartDrag(this.startDragHandler);\n\n    this.onStopDrag(this.stopDragHandler);\n\n    this.enableDrag();\n\t}\n\n\twillUnmount() {\n    this.offStartDrag(this.startDragHandler);\n\n    this.offStopDrag(this.stopDragHandler);\n\n    this.disableDrag();\n\t}\n\n  parentContext() {\n    const context = this.getContext(),\n          select = this.select.bind(this),\n          deselect = this.deselect.bind(this);\n\n    return ({\n      ...context,\n      select,\n      deselect\n    });\n  }\n\n  initialise() {\n\t\tthis.assignContext();\n\t}\n\n\tstatic defaultProperties = {\n\t\tclassName: \"drag\"\n\t};\n}\n\nObject.assign(EntryItem.prototype, dragMixins);\n\nexport default withStyle(DragEntryItem)`\n\n\tfont-size: ${dragEntryItemFontSize};\n  user-select: none;\n  \n  font-weight: normal;\n  \n  .selected {\n    font-weight: bold;\n  }\n\n  .dragging {\n    z-index: 1;\n    position: fixed;\n    pointer-events: none;\n  }\n  \n`;\n"],"names":["DragEntryItem","startDragHandler","element","path","getPath","type","getType","explorer","getExplorer","dragEntryItemType","markerEntryItemPath","addMarker","stopDragHandler","dropElement","aborted","done","markerEntryItem","retrieveMarkerEntryItem","markerEntryItemExplorer","removeMarker","dragEntryItem","dropDragEntryItem","globalThis","isSelected","selected","hasClass","getPathMap","sourceEntryPath","targetEntryPath","name","getName","adjustSourceEntryPath","adjustTargetEntryPath","pathMap","getPathMaps","pathMaps","retrievePathMaps","reverse","deselect","removeClass","select","addClass","didMount","onStartDrag","onStopDrag","enableDrag","willUnmount","offStartDrag","offStopDrag","disableDrag","parentContext","context","getContext","bind","initialise","assignContext","EntryItem","defaultProperties","className","Object","assign","prototype","dragMixins","withStyle","dragEntryItemFontSize"],"mappings":"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"}
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "easy-file-system",
3
3
  "author": "James Smith",
4
- "version": "1.5.1",
4
+ "version": "1.5.3",
5
5
  "license": "MIT, Anti-996",
6
6
  "homepage": "https://github.com/djalbat/easy-file-system",
7
7
  "description": "A file system explorer and a rubbish bin.",
@@ -35,6 +35,7 @@ export default withStyle(NameButton)`
35
35
  display: inline-block;
36
36
  font-size: inherit;
37
37
  text-align: left;
38
+ font-weight: inherit;
38
39
  font-family: inherit;
39
40
  background: transparent;
40
41
  vertical-align: bottom;
@@ -26,19 +26,13 @@ export default class DirectoryNameEntryItemDiv extends EntryItemDiv {
26
26
  svgButtonClickHandler = (event, element) => {
27
27
  const explorer = this.getExplorer(),
28
28
  parentElement = this.getParentElement(),
29
- dragEntryItem = parentElement; ///
29
+ dragEntryItem = parentElement; ///
30
30
 
31
31
  explorer.selectDragEntryItem(dragEntryItem);
32
32
 
33
33
  event.stopPropagation();
34
34
  }
35
35
 
36
- getExplorer() {
37
- const { explorer } = this.properties;
38
-
39
- return explorer;
40
- }
41
-
42
36
  childElements() {
43
37
  const { name, NameButton, ToggleButton, DirectoryNameSVG } = this.properties;
44
38
 
@@ -18,19 +18,13 @@ export default class FileNameEntryItemDiv extends EntryItemDiv {
18
18
  svgButtonClickHandler = (event, element) => {
19
19
  const explorer = this.getExplorer(),
20
20
  parentElement = this.getParentElement(),
21
- dragEntryItem = parentElement; ///
21
+ dragEntryItem = parentElement; ///
22
22
 
23
23
  explorer.selectDragEntryItem(dragEntryItem);
24
24
 
25
25
  event.stopPropagation();
26
26
  }
27
27
 
28
- getExplorer() {
29
- const { explorer } = this.properties;
30
-
31
- return explorer;
32
- }
33
-
34
28
  childElements() {
35
29
  const { name, NameButton, FileNameSVG } = this.properties;
36
30
 
@@ -7,24 +7,10 @@ import { Element } from "easy";
7
7
  import { entryItemDivMinHeight, entryItemDivPaddingTop } from "../../styles";
8
8
 
9
9
  class EntryItemDiv extends Element {
10
- deselect() {
11
- this.removeClass("selected");
12
- }
13
-
14
- select() {
15
- this.addClass("selected");
16
- }
10
+ getExplorer() {
11
+ const { explorer } = this.properties;
17
12
 
18
- parentContext() {
19
- const context = this.getContext(),
20
- select = this.select.bind(this),
21
- deselect = this.deselect.bind(this);
22
-
23
- return ({
24
- ...context,
25
- select,
26
- deselect
27
- });
13
+ return explorer;
28
14
  }
29
15
 
30
16
  static tagName = "div";
@@ -44,8 +30,4 @@ export default withStyle(EntryItemDiv)`
44
30
  min-height: ${entryItemDivMinHeight};
45
31
  padding-top: ${entryItemDivPaddingTop};
46
32
 
47
- .selected {
48
- background-color: #c0c0c0;
49
- }
50
-
51
33
  `;
@@ -26,11 +26,11 @@ export default class View extends Element {
26
26
 
27
27
  explorer2.removeFilePath("directory2/directory3/file4.txt", true);
28
28
 
29
- explorer1.onSelect((path) => {
29
+ explorer1.onSelect((path, selected) => {
30
30
  explorer2.deselectAllPaths();
31
31
  });
32
32
 
33
- explorer2.onSelect((path) => {
33
+ explorer2.onSelect((path, selected) => {
34
34
  explorer1.deselectAllPaths();
35
35
  });
36
36
 
package/src/explorer.js CHANGED
@@ -241,9 +241,16 @@ class Explorer extends Element {
241
241
  }
242
242
 
243
243
  selectDragEntryItem(dragEntryItem) {
244
- const path = dragEntryItem.getPath();
244
+ const path = dragEntryItem.getPath(),
245
+ selected = dragEntryItem.isSelected();
245
246
 
246
- this.callSelectHandlers(path);
247
+ this.callSelectHandlers(path, selected);
248
+
249
+ if (selected) {
250
+ dragEntryItem.deselect();
251
+
252
+ return;
253
+ }
247
254
 
248
255
  this.deselectAllPaths();
249
256
 
@@ -118,12 +118,6 @@ export default class DirectoryNameDragEntryItem extends DragEntryItem {
118
118
  return pathMap;
119
119
  }
120
120
 
121
- getExplorer() {
122
- const { explorer } = this.properties;
123
-
124
- return explorer;
125
- }
126
-
127
121
  isCollapsed() {
128
122
  const entriesListCollapsed = this.isEntriesListCollapsed(),
129
123
  collapsed = entriesListCollapsed; ///
@@ -43,6 +43,18 @@ class DragEntryItem extends EntryItem {
43
43
  markerEntryItemExplorer.dropDragEntryItem(dragEntryItem, done);
44
44
  }
45
45
 
46
+ retrieveMarkerEntryItem() {
47
+ const { markerEntryItem } = globalThis;
48
+
49
+ return markerEntryItem;
50
+ }
51
+
52
+ isSelected() {
53
+ const selected = this.hasClass("selected"); ///
54
+
55
+ return selected;
56
+ }
57
+
46
58
  getPathMap(sourceEntryPath, targetEntryPath) {
47
59
  const name = this.getName();
48
60
 
@@ -67,13 +79,15 @@ class DragEntryItem extends EntryItem {
67
79
  return pathMaps;
68
80
  }
69
81
 
70
- retrieveMarkerEntryItem() {
71
- const { markerEntryItem } = globalThis;
82
+ deselect() {
83
+ this.removeClass("selected");
84
+ }
72
85
 
73
- return markerEntryItem;
74
- }
86
+ select() {
87
+ this.addClass("selected");
88
+ }
75
89
 
76
- didMount() {
90
+ didMount() {
77
91
  this.onStartDrag(this.startDragHandler);
78
92
 
79
93
  this.onStopDrag(this.stopDragHandler);
@@ -89,7 +103,19 @@ class DragEntryItem extends EntryItem {
89
103
  this.disableDrag();
90
104
  }
91
105
 
92
- initialise() {
106
+ parentContext() {
107
+ const context = this.getContext(),
108
+ select = this.select.bind(this),
109
+ deselect = this.deselect.bind(this);
110
+
111
+ return ({
112
+ ...context,
113
+ select,
114
+ deselect
115
+ });
116
+ }
117
+
118
+ initialise() {
93
119
  this.assignContext();
94
120
  }
95
121
 
@@ -104,6 +130,12 @@ export default withStyle(DragEntryItem)`
104
130
 
105
131
  font-size: ${dragEntryItemFontSize};
106
132
  user-select: none;
133
+
134
+ font-weight: normal;
135
+
136
+ .selected {
137
+ font-weight: bold;
138
+ }
107
139
 
108
140
  .dragging {
109
141
  z-index: 1;