easy-file-system 2.1.147 → 2.1.148

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/lib/rubbishBin.js CHANGED
@@ -17,6 +17,7 @@ var _closed = /*#__PURE__*/ _interop_require_default(require("./svg/rubbishBin/c
17
17
  var _dragEntryItem = /*#__PURE__*/ _interop_require_default(require("./mixins/dragEntryItem"));
18
18
  var _fileName = /*#__PURE__*/ _interop_require_default(require("./item/entry/marker/fileName"));
19
19
  var _directoryName = /*#__PURE__*/ _interop_require_default(require("./item/entry/marker/directoryName"));
20
+ var _customEventTypes = require("./customEventTypes");
20
21
  var _pathMap = require("./utilities/pathMap");
21
22
  var _entryTypes = require("./entryTypes");
22
23
  function _assert_this_initialized(self) {
@@ -194,7 +195,7 @@ var RubbishBin = /*#__PURE__*/ function(Element) {
194
195
  _class_call_check(this, RubbishBin);
195
196
  var _this;
196
197
  _this = _super.apply(this, arguments);
197
- _define_property(_assert_this_initialized(_this), "dropHandler", function(dragElement, aborted, element, done) {
198
+ _define_property(_assert_this_initialized(_this), "dropCustomHandler", function(dragElement, aborted, element, done) {
198
199
  var dragEntryItem = dragElement, markerEntryItem = _this.retrieveMarkerEntryItem(), markerEntryItemExplorer = markerEntryItem.getExplorer();
199
200
  if (aborted) {
200
201
  markerEntryItemExplorer.removeMarker();
@@ -203,7 +204,7 @@ var RubbishBin = /*#__PURE__*/ function(Element) {
203
204
  }
204
205
  markerEntryItemExplorer.dropDragEntryItem(dragEntryItem, done);
205
206
  });
206
- _define_property(_assert_this_initialized(_this), "dragOverHandler", function(dragElement, element) {
207
+ _define_property(_assert_this_initialized(_this), "dragOverCustomHandler", function(dragElement, element) {
207
208
  var dragEntryItem = dragElement, markerEntryItem = _this.retrieveMarkerEntryItem();
208
209
  var markerEntryItemPath = markerEntryItem.getPath(), markerEntryItemExplorer = markerEntryItem.getExplorer(), previousMarkerEntryItemPath = markerEntryItemPath, previousMarkerEntryItemExplorer = markerEntryItemExplorer; ///
209
210
  markerEntryItemPath = null; ///
@@ -307,7 +308,8 @@ var RubbishBin = /*#__PURE__*/ function(Element) {
307
308
  key: "removeDragEntryItems",
308
309
  value: function removeDragEntryItems(pathMaps, explorer, done) {
309
310
  var _this = this;
310
- this.callRemoveHandlersAsync(pathMaps, explorer, function() {
311
+ var customEventType = _customEventTypes.REMOVE_CUSTOM_EVENT_TYPE;
312
+ this.callCustomHandlersAsync(customEventType, pathMaps, explorer, function() {
311
313
  pathMaps.forEach(function(pathMap) {
312
314
  _this.removeDragEntryItem(pathMap, explorer);
313
315
  });
@@ -335,22 +337,18 @@ var RubbishBin = /*#__PURE__*/ function(Element) {
335
337
  {
336
338
  key: "didMount",
337
339
  value: function didMount() {
338
- var onRemove = this.properties.onRemove, removeHandler = onRemove; ///
339
340
  this.enableDrop();
340
- this.onDrop(this.dropHandler);
341
- this.onDragOver(this.dragOverHandler);
342
- removeHandler && this.onRemove(removeHandler);
341
+ this.onCustomDrop(this.dropCustomHandler);
342
+ this.onCustomDragOver(this.dragOverCustomHandler);
343
343
  this.close();
344
344
  }
345
345
  },
346
346
  {
347
347
  key: "willUnmount",
348
348
  value: function willUnmount() {
349
- var onRemove = this.properties.onRemove, removeHandler = onRemove; ///
350
349
  this.disableDrop();
351
- this.offDrop(this.dropHandler);
352
- this.offDragOver(this.dragOverHandler);
353
- removeHandler && this.offRemove(removeHandler);
350
+ this.offCustomDrop(this.dropCustomHandler);
351
+ this.offCustomDragOver(this.dragOverCustomHandler);
354
352
  }
355
353
  },
356
354
  {
@@ -451,7 +449,6 @@ _define_property(RubbishBin, "OpenRubbishBinSVG", _open.default);
451
449
  _define_property(RubbishBin, "ClosedRubbishBinSVG", _closed.default);
452
450
  _define_property(RubbishBin, "tagName", "div");
453
451
  _define_property(RubbishBin, "ignoredProperties", [
454
- "onRemove",
455
452
  "reference",
456
453
  "references"
457
454
  ]);
@@ -463,4 +460,4 @@ Object.assign(RubbishBin.prototype, _rubbishBin.default);
463
460
  Object.assign(RubbishBin.prototype, _dragEntryItem.default);
464
461
  var _default = (0, _easywithstyle.default)(RubbishBin)(_templateObject());
465
462
 
466
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/rubbishBin.js"],"sourcesContent":["\"use strict\";\n\nimport withStyle from \"easy-with-style\";  ///\n\nimport { Element } from \"easy\";\nimport { dropMixins } from \"easy-drag-and-drop\";\n\nimport rubbishBinMixins from \"./mixins/rubbishBin\";\nimport OpenRubbishBinSVG from \"./svg/rubbishBin/open\";\nimport ClosedRubbishBinSVG from \"./svg/rubbishBin/closed\";\nimport dragEntryItemMixins from \"./mixins/dragEntryItem\";\nimport FileNameMarkerEntryItem from \"./item/entry/marker/fileName\";\nimport DirectoryNameMarkerEntryItem from \"./item/entry/marker/directoryName\";\n\nimport { sourceEntryPathFromEntryItem } from \"./utilities/pathMap\";\nimport { DIRECTORY_NAME_DRAG_ENTRY_TYPE, FILE_NAME_DRAG_ENTRY_TYPE } from \"./entryTypes\";\n\nclass RubbishBin extends Element {\n  dropHandler = (dragElement, aborted, element, done) => {\n    const dragEntryItem = dragElement,  ///\n          markerEntryItem = this.retrieveMarkerEntryItem(),\n          markerEntryItemExplorer = markerEntryItem.getExplorer();\n\n    if (aborted) {\n      markerEntryItemExplorer.removeMarker();\n\n      done();\n\n      return;\n    }\n\n    markerEntryItemExplorer.dropDragEntryItem(dragEntryItem, done);\n  }\n\n  dragOverHandler = (dragElement, element) => {\n    const dragEntryItem = dragElement,  ///\n          markerEntryItem = this.retrieveMarkerEntryItem();\n\n    let markerEntryItemPath = markerEntryItem.getPath(),\n        markerEntryItemExplorer = markerEntryItem.getExplorer(),\n        previousMarkerEntryItemPath = markerEntryItemPath, ///\n        previousMarkerEntryItemExplorer = markerEntryItemExplorer; ///\n\n    markerEntryItemPath = null; ///\n\n    markerEntryItemExplorer = this;  ///\n\n    if ((markerEntryItemExplorer !== previousMarkerEntryItemExplorer) || (markerEntryItemPath !== previousMarkerEntryItemPath)) {\n      const dragEntryItemType = dragEntryItem.getType();\n\n      previousMarkerEntryItemExplorer.removeMarker();\n\n      markerEntryItemExplorer.addMarker(markerEntryItemPath, dragEntryItemType);\n    }\n  }\n\n  getReference() {\n    const { reference = null } = this.properties;\n\n    return reference;\n  }\n\n  getReferences() {\n    const { references = [] } = this.properties;\n\n    return references;\n  }\n\n  retrieveMarkerEntryItem() {\n    const { markerEntryItem } = globalThis;\n\n    return markerEntryItem;\n  }\n\n  addMarker(markerEntryItemPath, dragEntryItemType) {\n    const markerEntryItemName = markerEntryItemPath;  ///\n\n    this.addMarkerEntryItem(markerEntryItemName, dragEntryItemType);\n\n    this.open();\n  }\n\n  removeMarker() {\n    this.removeMarkerEntryItem();\n\n    this.close();\n  }\n\n  addMarkerEntryItem(markerEntryItemName, dragEntryItemType) {\n    let markerEntryItem;\n\n    const name = markerEntryItemName, ///\n          type = dragEntryItemType;  ///\n\n    switch (type) {\n      case FILE_NAME_DRAG_ENTRY_TYPE : {\n        const explorer = this,  ///\n              fileNameMarkerEntryItem =\n\n                <FileNameMarkerEntryItem name={name} explorer={explorer} />\n\n              ;\n\n        markerEntryItem = fileNameMarkerEntryItem;  ///\n\n        break;\n      }\n\n      case DIRECTORY_NAME_DRAG_ENTRY_TYPE : {\n        const explorer = this,  ///\n              directoryNameMarkerEntryItem =\n\n                <DirectoryNameMarkerEntryItem name={name} explorer={explorer} />\n\n              ;\n\n        markerEntryItem = directoryNameMarkerEntryItem; ///\n\n        break;\n      }\n    }\n\n    Object.assign(globalThis, {\n      markerEntryItem\n    });\n  }\n\n  removeMarkerEntryItem() {\n    const markerEntryItem = null;\n\n    Object.assign(globalThis, {\n      markerEntryItem\n    });\n  }\n\n  dropDragEntryItem(dragEntryItem, done) {\n    const dragEntryItemExplorer = dragEntryItem.getExplorer(),\n          sourceEntryPath = sourceEntryPathFromEntryItem(dragEntryItem),\n          targetEntryPath = null,\n          pathMaps = dragEntryItem.getPathMaps(sourceEntryPath, targetEntryPath),\n          explorer = dragEntryItemExplorer;  ///\n\n    this.removeDragEntryItems(pathMaps, explorer, () => {\n      this.removeMarker();\n\n      done();\n    });\n  }\n\n  removeDragEntryItems(pathMaps, explorer, done) {\n    this.callRemoveHandlersAsync(pathMaps, explorer, () => {\n      pathMaps.forEach((pathMap) => {\n        this.removeDragEntryItem(pathMap, explorer)\n      });\n\n      pathMaps.forEach((pathMap) => {\n        this.addDragEntryItem(pathMap, explorer);\n      });\n\n      done();\n    });\n  }\n\n  open() {\n    this.showOpenRubbishBinSVG();\n    this.hideClosedRubbishBinSVG();\n  }\n\n  close() {\n    this.hideOpenRubbishBinSVG();\n    this.showClosedRubbishBinSVG();\n  }\n\n  didMount() {\n    const { onRemove } = this.properties,\n          removeHandler = onRemove; ///\n\n    this.enableDrop();\n\n    this.onDrop(this.dropHandler);\n\n    this.onDragOver(this.dragOverHandler);\n\n    removeHandler && this.onRemove(removeHandler);\n\n    this.close();\n  }\n\n  willUnmount() {\n    const { onRemove } = this.properties,\n          removeHandler = onRemove; ///\n\n    this.disableDrop();\n\n    this.offDrop(this.dropHandler);\n\n    this.offDragOver(this.dragOverHandler);\n\n    removeHandler && this.offRemove(removeHandler);\n  }\n\n  addFilePath(filePath, readOnly = false) {\n    ///\n  }\n\n  removeFilePath(filePath, removeEmptyParentDirectories = false) {\n    ///\n  }\n\n  removeAllPaths() {\n    ///\n  }\n\n  addDirectoryPath(directoryPath, readOnly = false, collapsed = true) {\n    ///\n  }\n\n  removeDirectoryPath(directoryPath, removeEmptyParentDirectories = false) {\n    ///\n  }\n\n  getMarkerEntryItemPath() {\n    const { markerEntryItemPath } = this.getState();\n\n    return markerEntryItemPath;\n  }\n\n  getMarkerEntryItemExplorer() {\n    const { markerEntryItemExplorer } = this.getState();\n\n    return markerEntryItemExplorer;\n  }\n\n  setMarkerEntryItemPath(markerEntryItemPath) {\n    this.updateState({\n      markerEntryItemPath\n    });\n  }\n\n  setMarkerEntryItemExplorer(markerEntryItemExplorer) {\n    this.updateState({\n      markerEntryItemExplorer\n    });\n  }\n\n  setInitialState() {\n    const markerEntryItemPath = null,\n          markerEntryItemExplorer = null;\n\n    this.setState({\n      markerEntryItemPath,\n      markerEntryItemExplorer\n    });\n  }\n\n  childElements() {\n    const { OpenRubbishBinSVG, ClosedRubbishBinSVG } = this.constructor;\n\n    return ([\n\n      <OpenRubbishBinSVG/>,\n      <ClosedRubbishBinSVG/>\n\n    ]);\n  }\n\n  initialise() {\n    this.assignContext();\n\n    this.setInitialState();\n  }\n\n  static OpenRubbishBinSVG = OpenRubbishBinSVG;\n\n  static ClosedRubbishBinSVG = ClosedRubbishBinSVG;\n\n  static tagName = \"div\";\n\n  static ignoredProperties = [\n    \"onRemove\",\n    \"reference\",\n    \"references\"\n  ];\n\n  static defaultProperties = {\n    className: \"rubbish-bin\"\n  };\n}\n\nObject.assign(RubbishBin.prototype, dropMixins);\nObject.assign(RubbishBin.prototype, rubbishBinMixins);\nObject.assign(RubbishBin.prototype, dragEntryItemMixins);\n\nexport default withStyle(RubbishBin)`\n  \n  display: inline-block;\n      \n`;\n"],"names":["RubbishBin","dropHandler","dragElement","aborted","element","done","dragEntryItem","markerEntryItem","retrieveMarkerEntryItem","markerEntryItemExplorer","getExplorer","removeMarker","dropDragEntryItem","dragOverHandler","markerEntryItemPath","getPath","previousMarkerEntryItemPath","previousMarkerEntryItemExplorer","dragEntryItemType","getType","addMarker","getReference","properties","reference","getReferences","references","globalThis","markerEntryItemName","addMarkerEntryItem","open","removeMarkerEntryItem","close","name","type","FILE_NAME_DRAG_ENTRY_TYPE","explorer","fileNameMarkerEntryItem","FileNameMarkerEntryItem","DIRECTORY_NAME_DRAG_ENTRY_TYPE","directoryNameMarkerEntryItem","DirectoryNameMarkerEntryItem","Object","assign","dragEntryItemExplorer","sourceEntryPath","sourceEntryPathFromEntryItem","targetEntryPath","pathMaps","getPathMaps","removeDragEntryItems","callRemoveHandlersAsync","forEach","pathMap","removeDragEntryItem","addDragEntryItem","showOpenRubbishBinSVG","hideClosedRubbishBinSVG","hideOpenRubbishBinSVG","showClosedRubbishBinSVG","didMount","onRemove","removeHandler","enableDrop","onDrop","onDragOver","willUnmount","disableDrop","offDrop","offDragOver","offRemove","addFilePath","filePath","readOnly","removeFilePath","removeEmptyParentDirectories","removeAllPaths","addDirectoryPath","directoryPath","collapsed","removeDirectoryPath","getMarkerEntryItemPath","getState","getMarkerEntryItemExplorer","setMarkerEntryItemPath","updateState","setMarkerEntryItemExplorer","setInitialState","setState","childElements","constructor","OpenRubbishBinSVG","ClosedRubbishBinSVG","initialise","assignContext","Element","tagName","ignoredProperties","defaultProperties","className","prototype","dropMixins","rubbishBinMixins","dragEntryItemMixins","withStyle"],"mappings":"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"}
463
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/rubbishBin.js"],"sourcesContent":["\"use strict\";\n\nimport withStyle from \"easy-with-style\";  ///\n\nimport { Element } from \"easy\";\nimport { dropMixins } from \"easy-drag-and-drop\";\n\nimport rubbishBinMixins from \"./mixins/rubbishBin\";\nimport OpenRubbishBinSVG from \"./svg/rubbishBin/open\";\nimport ClosedRubbishBinSVG from \"./svg/rubbishBin/closed\";\nimport dragEntryItemMixins from \"./mixins/dragEntryItem\";\nimport FileNameMarkerEntryItem from \"./item/entry/marker/fileName\";\nimport DirectoryNameMarkerEntryItem from \"./item/entry/marker/directoryName\";\n\nimport { REMOVE_CUSTOM_EVENT_TYPE } from \"./customEventTypes\";\nimport { sourceEntryPathFromEntryItem } from \"./utilities/pathMap\";\nimport { DIRECTORY_NAME_DRAG_ENTRY_TYPE, FILE_NAME_DRAG_ENTRY_TYPE } from \"./entryTypes\";\n\nclass RubbishBin extends Element {\n  dropCustomHandler = (dragElement, aborted, element, done) => {\n    const dragEntryItem = dragElement,  ///\n          markerEntryItem = this.retrieveMarkerEntryItem(),\n          markerEntryItemExplorer = markerEntryItem.getExplorer();\n\n    if (aborted) {\n      markerEntryItemExplorer.removeMarker();\n\n      done();\n\n      return;\n    }\n\n    markerEntryItemExplorer.dropDragEntryItem(dragEntryItem, done);\n  }\n\n  dragOverCustomHandler = (dragElement, element) => {\n    const dragEntryItem = dragElement,  ///\n          markerEntryItem = this.retrieveMarkerEntryItem();\n\n    let markerEntryItemPath = markerEntryItem.getPath(),\n        markerEntryItemExplorer = markerEntryItem.getExplorer(),\n        previousMarkerEntryItemPath = markerEntryItemPath, ///\n        previousMarkerEntryItemExplorer = markerEntryItemExplorer; ///\n\n    markerEntryItemPath = null; ///\n\n    markerEntryItemExplorer = this;  ///\n\n    if ((markerEntryItemExplorer !== previousMarkerEntryItemExplorer) || (markerEntryItemPath !== previousMarkerEntryItemPath)) {\n      const dragEntryItemType = dragEntryItem.getType();\n\n      previousMarkerEntryItemExplorer.removeMarker();\n\n      markerEntryItemExplorer.addMarker(markerEntryItemPath, dragEntryItemType);\n    }\n  }\n\n  getReference() {\n    const { reference = null } = this.properties;\n\n    return reference;\n  }\n\n  getReferences() {\n    const { references = [] } = this.properties;\n\n    return references;\n  }\n\n  retrieveMarkerEntryItem() {\n    const { markerEntryItem } = globalThis;\n\n    return markerEntryItem;\n  }\n\n  addMarker(markerEntryItemPath, dragEntryItemType) {\n    const markerEntryItemName = markerEntryItemPath;  ///\n\n    this.addMarkerEntryItem(markerEntryItemName, dragEntryItemType);\n\n    this.open();\n  }\n\n  removeMarker() {\n    this.removeMarkerEntryItem();\n\n    this.close();\n  }\n\n  addMarkerEntryItem(markerEntryItemName, dragEntryItemType) {\n    let markerEntryItem;\n\n    const name = markerEntryItemName, ///\n          type = dragEntryItemType;  ///\n\n    switch (type) {\n      case FILE_NAME_DRAG_ENTRY_TYPE : {\n        const explorer = this,  ///\n              fileNameMarkerEntryItem =\n\n                <FileNameMarkerEntryItem name={name} explorer={explorer} />\n\n              ;\n\n        markerEntryItem = fileNameMarkerEntryItem;  ///\n\n        break;\n      }\n\n      case DIRECTORY_NAME_DRAG_ENTRY_TYPE : {\n        const explorer = this,  ///\n              directoryNameMarkerEntryItem =\n\n                <DirectoryNameMarkerEntryItem name={name} explorer={explorer} />\n\n              ;\n\n        markerEntryItem = directoryNameMarkerEntryItem; ///\n\n        break;\n      }\n    }\n\n    Object.assign(globalThis, {\n      markerEntryItem\n    });\n  }\n\n  removeMarkerEntryItem() {\n    const markerEntryItem = null;\n\n    Object.assign(globalThis, {\n      markerEntryItem\n    });\n  }\n\n  dropDragEntryItem(dragEntryItem, done) {\n    const dragEntryItemExplorer = dragEntryItem.getExplorer(),\n          sourceEntryPath = sourceEntryPathFromEntryItem(dragEntryItem),\n          targetEntryPath = null,\n          pathMaps = dragEntryItem.getPathMaps(sourceEntryPath, targetEntryPath),\n          explorer = dragEntryItemExplorer;  ///\n\n    this.removeDragEntryItems(pathMaps, explorer, () => {\n      this.removeMarker();\n\n      done();\n    });\n  }\n\n  removeDragEntryItems(pathMaps, explorer, done) {\n    const customEventType = REMOVE_CUSTOM_EVENT_TYPE;\n\n    this.callCustomHandlersAsync(customEventType, pathMaps, explorer, () => {\n      pathMaps.forEach((pathMap) => {\n        this.removeDragEntryItem(pathMap, explorer)\n      });\n\n      pathMaps.forEach((pathMap) => {\n        this.addDragEntryItem(pathMap, explorer);\n      });\n\n      done();\n    });\n  }\n\n  open() {\n    this.showOpenRubbishBinSVG();\n    this.hideClosedRubbishBinSVG();\n  }\n\n  close() {\n    this.hideOpenRubbishBinSVG();\n    this.showClosedRubbishBinSVG();\n  }\n\n  didMount() {\n    this.enableDrop();\n\n    this.onCustomDrop(this.dropCustomHandler);\n\n    this.onCustomDragOver(this.dragOverCustomHandler);\n\n    this.close();\n  }\n\n  willUnmount() {\n    this.disableDrop();\n\n    this.offCustomDrop(this.dropCustomHandler);\n\n    this.offCustomDragOver(this.dragOverCustomHandler);\n  }\n\n  addFilePath(filePath, readOnly = false) {\n    ///\n  }\n\n  removeFilePath(filePath, removeEmptyParentDirectories = false) {\n    ///\n  }\n\n  removeAllPaths() {\n    ///\n  }\n\n  addDirectoryPath(directoryPath, readOnly = false, collapsed = true) {\n    ///\n  }\n\n  removeDirectoryPath(directoryPath, removeEmptyParentDirectories = false) {\n    ///\n  }\n\n  getMarkerEntryItemPath() {\n    const { markerEntryItemPath } = this.getState();\n\n    return markerEntryItemPath;\n  }\n\n  getMarkerEntryItemExplorer() {\n    const { markerEntryItemExplorer } = this.getState();\n\n    return markerEntryItemExplorer;\n  }\n\n  setMarkerEntryItemPath(markerEntryItemPath) {\n    this.updateState({\n      markerEntryItemPath\n    });\n  }\n\n  setMarkerEntryItemExplorer(markerEntryItemExplorer) {\n    this.updateState({\n      markerEntryItemExplorer\n    });\n  }\n\n  setInitialState() {\n    const markerEntryItemPath = null,\n          markerEntryItemExplorer = null;\n\n    this.setState({\n      markerEntryItemPath,\n      markerEntryItemExplorer\n    });\n  }\n\n  childElements() {\n    const { OpenRubbishBinSVG, ClosedRubbishBinSVG } = this.constructor;\n\n    return ([\n\n      <OpenRubbishBinSVG/>,\n      <ClosedRubbishBinSVG/>\n\n    ]);\n  }\n\n  initialise() {\n    this.assignContext();\n\n    this.setInitialState();\n  }\n\n  static OpenRubbishBinSVG = OpenRubbishBinSVG;\n\n  static ClosedRubbishBinSVG = ClosedRubbishBinSVG;\n\n  static tagName = \"div\";\n\n  static ignoredProperties = [\n    \"reference\",\n    \"references\"\n  ];\n\n  static defaultProperties = {\n    className: \"rubbish-bin\"\n  };\n}\n\nObject.assign(RubbishBin.prototype, dropMixins);\nObject.assign(RubbishBin.prototype, rubbishBinMixins);\nObject.assign(RubbishBin.prototype, dragEntryItemMixins);\n\nexport default withStyle(RubbishBin)`\n  \n  display: inline-block;\n      \n`;\n"],"names":["RubbishBin","dropCustomHandler","dragElement","aborted","element","done","dragEntryItem","markerEntryItem","retrieveMarkerEntryItem","markerEntryItemExplorer","getExplorer","removeMarker","dropDragEntryItem","dragOverCustomHandler","markerEntryItemPath","getPath","previousMarkerEntryItemPath","previousMarkerEntryItemExplorer","dragEntryItemType","getType","addMarker","getReference","properties","reference","getReferences","references","globalThis","markerEntryItemName","addMarkerEntryItem","open","removeMarkerEntryItem","close","name","type","FILE_NAME_DRAG_ENTRY_TYPE","explorer","fileNameMarkerEntryItem","FileNameMarkerEntryItem","DIRECTORY_NAME_DRAG_ENTRY_TYPE","directoryNameMarkerEntryItem","DirectoryNameMarkerEntryItem","Object","assign","dragEntryItemExplorer","sourceEntryPath","sourceEntryPathFromEntryItem","targetEntryPath","pathMaps","getPathMaps","removeDragEntryItems","customEventType","REMOVE_CUSTOM_EVENT_TYPE","callCustomHandlersAsync","forEach","pathMap","removeDragEntryItem","addDragEntryItem","showOpenRubbishBinSVG","hideClosedRubbishBinSVG","hideOpenRubbishBinSVG","showClosedRubbishBinSVG","didMount","enableDrop","onCustomDrop","onCustomDragOver","willUnmount","disableDrop","offCustomDrop","offCustomDragOver","addFilePath","filePath","readOnly","removeFilePath","removeEmptyParentDirectories","removeAllPaths","addDirectoryPath","directoryPath","collapsed","removeDirectoryPath","getMarkerEntryItemPath","getState","getMarkerEntryItemExplorer","setMarkerEntryItemPath","updateState","setMarkerEntryItemExplorer","setInitialState","setState","childElements","constructor","OpenRubbishBinSVG","ClosedRubbishBinSVG","initialise","assignContext","Element","tagName","ignoredProperties","defaultProperties","className","prototype","dropMixins","rubbishBinMixins","dragEntryItemMixins","withStyle"],"mappings":"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"}
package/lib/span/name.js CHANGED
@@ -13,6 +13,7 @@ var _necessary = require("necessary");
13
13
  var _easy = require("easy");
14
14
  var _nameSpan = /*#__PURE__*/ _interop_require_default(require("../mixins/nameSpan"));
15
15
  var _constants = require("../constants");
16
+ var _customEventTypes = require("../customEventTypes");
16
17
  function _assert_this_initialized(self) {
17
18
  if (self === void 0) {
18
19
  throw new ReferenceError("this hasn't been initialised - super() hasn't been called");
@@ -192,11 +193,13 @@ var NameSpan = /*#__PURE__*/ function(Element) {
192
193
  _define_property(_assert_this_initialized(_this), "keyDownHandler", function(event, element) {
193
194
  var keyCode = event.keyCode;
194
195
  if (keyCode === ENTER_KEY_CODE) {
195
- _this.callChangeHandlers();
196
+ var customEventType = _customEventTypes.CHANGE_CUSTOM_EVENT_TYPE;
197
+ _this.callCustomHandlers(customEventType);
196
198
  event.preventDefault();
197
199
  }
198
200
  if (keyCode === ESCAPE_KEY_CODE) {
199
- _this.callCancelHandlers();
201
+ var customEventType1 = _customEventTypes.CANCEL_CUSTOM_EVENT_TYPE;
202
+ _this.callCustomHandlers(customEventType1);
200
203
  event.preventDefault();
201
204
  }
202
205
  });
@@ -247,16 +250,16 @@ var NameSpan = /*#__PURE__*/ function(Element) {
247
250
  {
248
251
  key: "parentContext",
249
252
  value: function parentContext() {
250
- var editNameSpan = this.edit.bind(this), resetNameSpan = this.reset.bind(this), getNameSpanName = this.getName.bind(this), setNameSpanName = this.setName.bind(this), onNameSpanChange = this.onChange.bind(this), onNameSpanCancel = this.onCancel.bind(this), offNameSpanChange = this.offChange.bind(this), offNameSpanCancel = this.offCancel.bind(this); ///
253
+ var editNameSpan = this.edit.bind(this), resetNameSpan = this.reset.bind(this), getNameSpanName = this.getName.bind(this), setNameSpanName = this.setName.bind(this), onCustomNameSpanCancel = this.onCustomCancel.bind(this), offCustomNameSpanCancel = this.offCustomCancel.bind(this), onCustomNameSpanChange = this.onCustomChange.bind(this), offCustomNameSpanChange = this.offCustomChange.bind(this); ///
251
254
  return {
252
255
  editNameSpan: editNameSpan,
253
256
  resetNameSpan: resetNameSpan,
254
257
  getNameSpanName: getNameSpanName,
255
258
  setNameSpanName: setNameSpanName,
256
- onNameSpanChange: onNameSpanChange,
257
- onNameSpanCancel: onNameSpanCancel,
258
- offNameSpanChange: offNameSpanChange,
259
- offNameSpanCancel: offNameSpanCancel
259
+ onCustomNameSpanCancel: onCustomNameSpanCancel,
260
+ offCustomNameSpanCancel: offCustomNameSpanCancel,
261
+ onCustomNameSpanChange: onCustomNameSpanChange,
262
+ offCustomNameSpanChange: offCustomNameSpanChange
260
263
  };
261
264
  }
262
265
  }
@@ -271,4 +274,4 @@ _define_property(NameSpan, "defaultProperties", {
271
274
  Object.assign(NameSpan.prototype, _nameSpan.default);
272
275
  var _default = (0, _easywithstyle.default)(NameSpan)(_templateObject());
273
276
 
274
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/span/name.js"],"sourcesContent":["\"use strict\";\n\nimport withStyle from \"easy-with-style\";  ///\n\nimport { keyCodes, arrayUtilities } from \"necessary\";\nimport { Element, window, document } from \"easy\";\n\nimport nameSpanMixins from \"../mixins/nameSpan\";\n\nimport { TRUE, CONTENT_EDITABLE } from \"../constants\";\n\nconst { first } = arrayUtilities,\n      { ENTER_KEY_CODE, ESCAPE_KEY_CODE } = keyCodes;\n\nclass NameSpan extends Element {\n  keyDownHandler = (event, element) => {\n    const { keyCode } = event;\n\n    if (keyCode === ENTER_KEY_CODE) {\n      this.callChangeHandlers();\n\n      event.preventDefault();\n    }\n\n    if (keyCode === ESCAPE_KEY_CODE) {\n      this.callCancelHandlers();\n\n      event.preventDefault();\n    }\n  }\n\n  getName() {\n    const html = this.html(),\n          name = html;  ///\n\n    return name;\n  }\n\n  setName(name) {\n    const domElement = this.getDOMElement(),\n          { firstChild } = domElement;\n\n    let textNode;\n\n    if (firstChild !== null) {\n      textNode = firstChild;  ///\n    } else {\n      textNode = document.createTextNode();\n\n      domElement.appendChild(textNode);\n    }\n\n    textNode.nodeValue = name;  ///\n  }\n\n  edit() {\n    this.focus();\n\n    this.addAttribute(CONTENT_EDITABLE, TRUE);\n\n    const html = this.html(),\n          range = document.createRange(),\n          selection = window.getSelection(),\n          domElement = this.getDOMElement(),\n          htmlLength = html.length,\n          { childNodes } = domElement,\n          firstChildNode = first(childNodes),\n          textNode = firstChildNode;  ///\n\n    range.setStart(textNode, 0);\n\n    range.setEnd(textNode, htmlLength);\n\n    selection.removeAllRanges();\n\n    selection.addRange(range);\n\n    this.onKeyDown(this.keyDownHandler);\n  }\n\n  reset() {\n    this.offKeyDown(this.keyDownHandler);\n\n    this.removeAttribute(CONTENT_EDITABLE, TRUE);\n  }\n\n  parentContext() {\n    const editNameSpan = this.edit.bind(this), ///\n          resetNameSpan = this.reset.bind(this), ///\n          getNameSpanName = this.getName.bind(this), ///\n          setNameSpanName = this.setName.bind(this), ///\n          onNameSpanChange = this.onChange.bind(this), ///\n          onNameSpanCancel = this.onCancel.bind(this), ///\n          offNameSpanChange = this.offChange.bind(this), ///\n          offNameSpanCancel = this.offCancel.bind(this); ///\n\n    return ({\n      editNameSpan,\n      resetNameSpan,\n      getNameSpanName,\n      setNameSpanName,\n      onNameSpanChange,\n      onNameSpanCancel,\n      offNameSpanChange,\n      offNameSpanCancel\n    });\n  }\n\n  static tagName = \"span\";  ///\n\n  static defaultProperties = {\n    className: \"name\"\n  };\n}\n\nObject.assign(NameSpan.prototype, nameSpanMixins);\n\nexport default withStyle(NameSpan)`\n\n  border: none;\n  display: inline-block;\n  font-size: inherit;\n  text-align: left;\n  background: transparent;\n  font-weight: inherit;\n  font-family: inherit;\n\n  [contentEditable] {\n    border: 1px solid black;\n    padding: 4px;\n  }\n  \n`;\n"],"names":["first","arrayUtilities","ENTER_KEY_CODE","keyCodes","ESCAPE_KEY_CODE","NameSpan","keyDownHandler","event","element","keyCode","callChangeHandlers","preventDefault","callCancelHandlers","getName","html","name","setName","domElement","getDOMElement","firstChild","textNode","document","createTextNode","appendChild","nodeValue","edit","focus","addAttribute","CONTENT_EDITABLE","TRUE","range","createRange","selection","window","getSelection","htmlLength","length","childNodes","firstChildNode","setStart","setEnd","removeAllRanges","addRange","onKeyDown","reset","offKeyDown","removeAttribute","parentContext","editNameSpan","bind","resetNameSpan","getNameSpanName","setNameSpanName","onNameSpanChange","onChange","onNameSpanCancel","onCancel","offNameSpanChange","offChange","offNameSpanCancel","offCancel","Element","tagName","defaultProperties","className","Object","assign","prototype","nameSpanMixins","withStyle"],"mappings":"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"}
277
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/span/name.js"],"sourcesContent":["\"use strict\";\n\nimport withStyle from \"easy-with-style\";  ///\n\nimport { keyCodes, arrayUtilities } from \"necessary\";\nimport { Element, window, document } from \"easy\";\n\nimport nameSpanMixins from \"../mixins/nameSpan\";\n\nimport { TRUE, CONTENT_EDITABLE } from \"../constants\";\nimport {CANCEL_CUSTOM_EVENT_TYPE, CHANGE_CUSTOM_EVENT_TYPE} from \"../customEventTypes\";\n\nconst { first } = arrayUtilities,\n      { ENTER_KEY_CODE, ESCAPE_KEY_CODE } = keyCodes;\n\nclass NameSpan extends Element {\n  keyDownHandler = (event, element) => {\n    const { keyCode } = event;\n\n    if (keyCode === ENTER_KEY_CODE) {\n      const customEventType = CHANGE_CUSTOM_EVENT_TYPE;\n\n      this.callCustomHandlers(customEventType);\n\n      event.preventDefault();\n    }\n\n    if (keyCode === ESCAPE_KEY_CODE) {\n      const customEventType = CANCEL_CUSTOM_EVENT_TYPE;\n\n      this.callCustomHandlers(customEventType);\n\n      event.preventDefault();\n    }\n  }\n\n  getName() {\n    const html = this.html(),\n          name = html;  ///\n\n    return name;\n  }\n\n  setName(name) {\n    const domElement = this.getDOMElement(),\n          { firstChild } = domElement;\n\n    let textNode;\n\n    if (firstChild !== null) {\n      textNode = firstChild;  ///\n    } else {\n      textNode = document.createTextNode();\n\n      domElement.appendChild(textNode);\n    }\n\n    textNode.nodeValue = name;  ///\n  }\n\n  edit() {\n    this.focus();\n\n    this.addAttribute(CONTENT_EDITABLE, TRUE);\n\n    const html = this.html(),\n          range = document.createRange(),\n          selection = window.getSelection(),\n          domElement = this.getDOMElement(),\n          htmlLength = html.length,\n          { childNodes } = domElement,\n          firstChildNode = first(childNodes),\n          textNode = firstChildNode;  ///\n\n    range.setStart(textNode, 0);\n\n    range.setEnd(textNode, htmlLength);\n\n    selection.removeAllRanges();\n\n    selection.addRange(range);\n\n    this.onKeyDown(this.keyDownHandler);\n  }\n\n  reset() {\n    this.offKeyDown(this.keyDownHandler);\n\n    this.removeAttribute(CONTENT_EDITABLE, TRUE);\n  }\n\n  parentContext() {\n    const editNameSpan = this.edit.bind(this), ///\n          resetNameSpan = this.reset.bind(this), ///\n          getNameSpanName = this.getName.bind(this), ///\n          setNameSpanName = this.setName.bind(this), ///\n          onCustomNameSpanCancel = this.onCustomCancel.bind(this), ///\n          offCustomNameSpanCancel = this.offCustomCancel.bind(this), ///\n          onCustomNameSpanChange = this.onCustomChange.bind(this), ///\n          offCustomNameSpanChange = this.offCustomChange.bind(this); ///\n\n    return ({\n      editNameSpan,\n      resetNameSpan,\n      getNameSpanName,\n      setNameSpanName,\n      onCustomNameSpanCancel,\n      offCustomNameSpanCancel,\n      onCustomNameSpanChange,\n      offCustomNameSpanChange\n    });\n  }\n\n  static tagName = \"span\";  ///\n\n  static defaultProperties = {\n    className: \"name\"\n  };\n}\n\nObject.assign(NameSpan.prototype, nameSpanMixins);\n\nexport default withStyle(NameSpan)`\n\n  border: none;\n  display: inline-block;\n  font-size: inherit;\n  text-align: left;\n  background: transparent;\n  font-weight: inherit;\n  font-family: inherit;\n\n  [contentEditable] {\n    border: 1px solid black;\n    padding: 4px;\n  }\n  \n`;\n"],"names":["first","arrayUtilities","ENTER_KEY_CODE","keyCodes","ESCAPE_KEY_CODE","NameSpan","keyDownHandler","event","element","keyCode","customEventType","CHANGE_CUSTOM_EVENT_TYPE","callCustomHandlers","preventDefault","CANCEL_CUSTOM_EVENT_TYPE","getName","html","name","setName","domElement","getDOMElement","firstChild","textNode","document","createTextNode","appendChild","nodeValue","edit","focus","addAttribute","CONTENT_EDITABLE","TRUE","range","createRange","selection","window","getSelection","htmlLength","length","childNodes","firstChildNode","setStart","setEnd","removeAllRanges","addRange","onKeyDown","reset","offKeyDown","removeAttribute","parentContext","editNameSpan","bind","resetNameSpan","getNameSpanName","setNameSpanName","onCustomNameSpanCancel","onCustomCancel","offCustomNameSpanCancel","offCustomCancel","onCustomNameSpanChange","onCustomChange","offCustomNameSpanChange","offCustomChange","Element","tagName","defaultProperties","className","Object","assign","prototype","nameSpanMixins","withStyle"],"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": "2.1.147",
4
+ "version": "2.1.148",
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.",
@@ -10,8 +10,9 @@
10
10
  "url": "https://github.com/djalbat/easy-file-system"
11
11
  },
12
12
  "dependencies": {
13
- "easy": "^15.1.1",
14
- "easy-drag-and-drop": "^1.3.79",
13
+ "easy": "^15.1.10",
14
+ "easy-drag-and-drop": "^1.3.84",
15
+ "easy-layout": "^6.0.85",
15
16
  "easy-with-style": "^3.0.273",
16
17
  "necessary": "^13.1.4"
17
18
  },
@@ -0,0 +1,10 @@
1
+ "use strict";
2
+
3
+ export const OPEN_CUSTOM_EVENT_TYPE = "open-custom";
4
+ export const MOVE_CUSTOM_EVENT_TYPE = "move-custom";
5
+ export const CHANGE_CUSTOM_EVENT_TYPE = "change-custom";
6
+ export const CANCEL_CUSTOM_EVENT_TYPE = "cancel-custom";
7
+ export const SELECT_CUSTOM_EVENT_TYPE = "select-custom";
8
+ export const RENAME_CUSTOM_EVENT_TYPE = "rename-custom";
9
+ export const REMOVE_CUSTOM_EVENT_TYPE = "remove-custom";
10
+ export const CREATE_CUSTOM_EVENT_TYPE = "create-custom";
@@ -35,35 +35,35 @@ export default class View extends Element {
35
35
  firstExplorer.renameSelectedPath();
36
36
  }
37
37
 
38
- openHandler = (filePath, explorer) => {
38
+ openCustomHandler = (filePath, explorer) => {
39
39
  console.log("open", filePath)
40
40
  }
41
41
 
42
- moveHandler = (pathMaps, explorer, done) => {
42
+ moveCustomHandler = (pathMaps, explorer, element, done) => {
43
43
  console.log("move", JSON.stringify(pathMaps, null, " "))
44
44
 
45
45
  done();
46
46
  }
47
47
 
48
- removeHandler = (pathMaps, explorer, done) => {
48
+ removeCustomHandler = (pathMaps, explorer, element, done) => {
49
49
  console.log("remove", JSON.stringify(pathMaps, null, " "))
50
50
 
51
51
  done();
52
52
  }
53
53
 
54
- renameHandler = (pathMaps, explorer, done) => {
54
+ renameCustomHandler = (pathMaps, explorer, element, done) => {
55
55
  console.log("rename", JSON.stringify(pathMaps, null, " "))
56
56
 
57
57
  done();
58
58
  }
59
59
 
60
- createHandler = (pathMaps, explorer, done) => {
60
+ createCustomHandler = (pathMaps, explorer, element, done) => {
61
61
  console.log("create", JSON.stringify(pathMaps, null, " "))
62
62
 
63
63
  done();
64
64
  }
65
65
 
66
- selectHandler = (path, selected, readOnly, explorer) => {
66
+ selectCustomHandler = (path, selected, readOnly, explorer) => {
67
67
  console.log("select", path, selected, readOnly)
68
68
  }
69
69
 
@@ -91,19 +91,19 @@ export default class View extends Element {
91
91
  childElements() {
92
92
  return ([
93
93
 
94
- <RubbishBin onRemove={this.removeHandler} />,
95
- <FirstExplorer onOpen={this.openHandler}
96
- onMove={this.moveHandler}
97
- onRemove={this.removeHandler}
98
- onRename={this.renameHandler}
99
- onCreate={this.createHandler}
100
- onSelect={this.selectHandler}
94
+ <RubbishBin onCustomRemove={this.removeCustomHandler} />,
95
+ <FirstExplorer onCustomOpen={this.openCustomHandler}
96
+ onCustomMove={this.moveCustomHandler}
97
+ onCustomRemove={this.removeCustomHandler}
98
+ onCustomRename={this.renameCustomHandler}
99
+ onCustomCreate={this.createCustomHandler}
100
+ onCustomSelect={this.selectCustomHandler}
101
101
  />,
102
- <SecondExplorer onOpen={this.openHandler}
103
- onMove={this.moveHandler}
104
- onRename={this.renameHandler}
105
- onRemove={this.removeHandler}
106
- onCreate={this.createHandler}
102
+ <SecondExplorer onCustomOpen={this.openCustomHandler}
103
+ onCustomMove={this.moveCustomHandler}
104
+ onCustomRename={this.renameCustomHandler}
105
+ onCustomRemove={this.removeCustomHandler}
106
+ onCustomCreate={this.createCustomHandler}
107
107
  />,
108
108
  <Button onClick={this.renameSelectedButtonClickHandler}>
109
109
  Rename selected path
package/src/explorer.js CHANGED
@@ -18,11 +18,17 @@ import { explorerPadding } from "./styles";
18
18
  import { PERIOD, DOUBLE_CLICK_DELAY } from "./constants";
19
19
  import { FILE_NAME_DRAG_ENTRY_TYPE, DIRECTORY_NAME_DRAG_ENTRY_TYPE } from "./entryTypes";
20
20
  import { sourceEntryPathFromEntryItem, targetEntryPathFromEntryItem } from "./utilities/pathMap";
21
+ import { MOVE_CUSTOM_EVENT_TYPE,
22
+ OPEN_CUSTOM_EVENT_TYPE,
23
+ REMOVE_CUSTOM_EVENT_TYPE,
24
+ RENAME_CUSTOM_EVENT_TYPE,
25
+ SELECT_CUSTOM_EVENT_TYPE,
26
+ CREATE_CUSTOM_EVENT_TYPE } from "./customEventTypes";
21
27
 
22
28
  const { concatenatePaths, pathWithoutBottommostNameFromPath } = pathUtilities;
23
29
 
24
30
  class Explorer extends Element {
25
- dragOverHandler = (dragElement, element) => {
31
+ dragOverCustomHandler = (dragElement, element) => {
26
32
  const dragEntryItem = dragElement, ///
27
33
  markerEntryItem = this.retrieveMarkerEntryItem(),
28
34
  dragEntryItemName = dragEntryItem.getName();
@@ -45,7 +51,7 @@ class Explorer extends Element {
45
51
  }
46
52
  }
47
53
 
48
- dropHandler = (dragElement, aborted, element, done) => {
54
+ dropCustomHandler = (dragElement, aborted, element, done) => {
49
55
  const markerEntryItem = this.retrieveMarkerEntryItem(),
50
56
  markerEntryItemExplorer = markerEntryItem.getExplorer();
51
57
 
@@ -285,9 +291,10 @@ class Explorer extends Element {
285
291
 
286
292
  const fileNameDragEntryItemPath = fileNameDragEntryItem.getPath(),
287
293
  filePath = fileNameDragEntryItemPath, ///
288
- explorer = fileNameDragEntryItem.getExplorer();
294
+ explorer = fileNameDragEntryItem.getExplorer(),
295
+ customEventType = OPEN_CUSTOM_EVENT_TYPE;
289
296
 
290
- this.callOpenHandlers(filePath, explorer);
297
+ this.callCustomHandlers(customEventType, filePath, explorer);
291
298
  }
292
299
 
293
300
  selectOrDeselectDragEntryItem(dragEntryItem) {
@@ -312,9 +319,10 @@ class Explorer extends Element {
312
319
  selected = !selected; ///
313
320
 
314
321
  const readOnly = dragEntryItem.isReadOnly(),
315
- explorer = dragEntryItem.getExplorer();
322
+ explorer = dragEntryItem.getExplorer(),
323
+ customEventType = SELECT_CUSTOM_EVENT_TYPE;
316
324
 
317
- this.callSelectHandlers(path, selected, readOnly, explorer);
325
+ this.callCustomHandlers(customEventType, path, selected, readOnly, explorer);
318
326
 
319
327
  return selected;
320
328
  }
@@ -382,7 +390,9 @@ class Explorer extends Element {
382
390
  }
383
391
 
384
392
  renameDragEntryItems(pathMaps, explorer, done) {
385
- this.callRenameHandlersAsync(pathMaps, explorer, () => {
393
+ const customEventType = RENAME_CUSTOM_EVENT_TYPE;
394
+
395
+ this.callCustomHandlersAsync(customEventType, pathMaps, explorer, () => {
386
396
  pathMaps.forEach((pathMap) => {
387
397
  this.removeDragEntryItem(pathMap, explorer);
388
398
  });
@@ -396,7 +406,9 @@ class Explorer extends Element {
396
406
  }
397
407
 
398
408
  moveDragEntryItems(pathMaps, explorer, done) {
399
- this.callMoveHandlersAsync(pathMaps, explorer, () => {
409
+ const customEventType = MOVE_CUSTOM_EVENT_TYPE;
410
+
411
+ this.callCustomHandlersAsync(customEventType, pathMaps, explorer, () => {
400
412
  pathMaps.forEach((pathMap) => {
401
413
  this.removeDragEntryItem(pathMap, explorer);
402
414
  });
@@ -410,7 +422,9 @@ class Explorer extends Element {
410
422
  }
411
423
 
412
424
  removeDragEntryItems(pathMaps, explorer, done) {
413
- this.callRemoveHandlersAsync(pathMaps, explorer, () => {
425
+ const customEventType = REMOVE_CUSTOM_EVENT_TYPE;
426
+
427
+ this.callCustomHandlersAsync(customEventType, pathMaps, explorer, () => {
414
428
  pathMaps.forEach((pathMap) => {
415
429
  this.removeDragEntryItem(pathMap, explorer);
416
430
  });
@@ -424,7 +438,9 @@ class Explorer extends Element {
424
438
  }
425
439
 
426
440
  createDragEntryItems(pathMaps, explorer, done) {
427
- this.callCreateHandlersAsync(pathMaps, explorer, () => {
441
+ const customEventType = CREATE_CUSTOM_EVENT_TYPE;
442
+
443
+ this.callCustomHandlersAsync(customEventType, pathMaps, explorer, () => {
428
444
  pathMaps.forEach((pathMap) => {
429
445
  this.removeDragEntryItem(pathMap, explorer);
430
446
  });
@@ -558,30 +574,15 @@ class Explorer extends Element {
558
574
  }
559
575
 
560
576
  didMount() {
561
- const { onMove, onOpen, onSelect, onCreate, onRename, singleClick = false } = this.properties,
562
- moveHandler = onMove, ///
563
- openHandler = onOpen, ///
564
- createHandler = onCreate, ///
565
- renameHandler = onRename, ///
566
- selectHandler = onSelect; ///
577
+ const { singleClick = false } = this.properties;
567
578
 
568
579
  this.setSingleClick(singleClick);
569
580
 
570
581
  this.enableDrop();
571
582
 
572
- this.onDragOver(this.dragOverHandler);
573
-
574
- this.onDrop(this.dropHandler);
575
-
576
- moveHandler && this.onMove(moveHandler);
577
-
578
- openHandler && this.onOpen(openHandler);
579
-
580
- createHandler && this.onCreate(createHandler);
583
+ this.onCustomDragOver(this.dragOverCustomHandler);
581
584
 
582
- renameHandler && this.onRename(renameHandler);
583
-
584
- selectHandler && this.onSelect(selectHandler);
585
+ this.onCustomDrop(this.dropCustomHandler);
585
586
 
586
587
  const mounted = true;
587
588
 
@@ -589,28 +590,11 @@ class Explorer extends Element {
589
590
  }
590
591
 
591
592
  willUnmount() {
592
- const { onMove, onOpen, onSelect, onCreate, onRename } = this.properties,
593
- moveHandler = onMove, ///
594
- openHandler = onOpen, ///
595
- createHandler = onCreate, ///
596
- renameHandler = onRename, ///
597
- selectHandler = onSelect; ///
598
-
599
593
  this.disableDrop();
600
594
 
601
- this.offDragOver(this.dragOverHandler);
602
-
603
- this.offDrop(this.dropHandler);
604
-
605
- moveHandler && this.offMove(moveHandler);
606
-
607
- openHandler && this.offOpen(openHandler);
608
-
609
- createHandler && this.offCreate(createHandler);
610
-
611
- renameHandler && this.offRename(renameHandler);
595
+ this.offCustomDragOver(this.dragOverCustomHandler);
612
596
 
613
- selectHandler && this.offSelect(selectHandler);
597
+ this.offCustomDrop(this.dropCustomHandler);
614
598
 
615
599
  const mounted = false;
616
600
 
@@ -662,11 +646,6 @@ class Explorer extends Element {
662
646
  static tagName = "div";
663
647
 
664
648
  static ignoredProperties = [
665
- "onMove",
666
- "onOpen",
667
- "onRename",
668
- "onSelect",
669
- "onCreate",
670
649
  "reference",
671
650
  "references",
672
651
  "singleClick"
package/src/index.js CHANGED
@@ -3,8 +3,6 @@
3
3
  export { default as Explorer } from "./explorer";
4
4
  export { default as RubbishBin } from "./rubbishBin";
5
5
 
6
- export { default as eventTypes } from "./eventTypes";
7
-
8
6
  export { default as NameSpan } from "./span/name";
9
7
  export { default as EntriesList } from "./list/entries";
10
8
  export { default as ToggleButton } from "./button/toggle";
@@ -14,7 +14,7 @@ import { FILE_NAME_DRAG_ENTRY_TYPE, FILE_NAME_MARKER_ENTRY_TYPE, DIRECTORY_NAME_
14
14
  const { concatenatePaths } = pathUtilities;
15
15
 
16
16
  export default class DirectoryNameDragEntryItem extends DragEntryItem {
17
- dragOverHandler = (dragElement, element) => {
17
+ dragOverCustomHandler = (dragElement, element) => {
18
18
  const collapsed = this.isCollapsed();
19
19
 
20
20
  if (collapsed) {
@@ -45,7 +45,7 @@ export default class DirectoryNameDragEntryItem extends DragEntryItem {
45
45
  }
46
46
  }
47
47
 
48
- dropHandler = (dragElement, aborted, element, done) => {
48
+ dropCustomHandler = (dragElement, aborted, element, done) => {
49
49
  const dragEntryItem = dragElement, ///
50
50
  markerEntryItem = this.retrieveMarkerEntryItem(),
51
51
  markerEntryItemExplorer = markerEntryItem.getExplorer();
@@ -172,9 +172,9 @@ export default class DirectoryNameDragEntryItem extends DragEntryItem {
172
172
 
173
173
  this.enableDrop();
174
174
 
175
- this.onDrop(this.dropHandler);
175
+ this.onCustomDrop(this.dropCustomHandler);
176
176
 
177
- this.onDragOver(this.dragOverHandler);
177
+ this.onCustomDragOver(this.dragOverCustomHandler);
178
178
 
179
179
  super.didMount();
180
180
  }
@@ -182,9 +182,9 @@ export default class DirectoryNameDragEntryItem extends DragEntryItem {
182
182
  willUnmount() {
183
183
  this.disableDrop();
184
184
 
185
- this.offDrop(this.dropHandler);
185
+ this.offCustomDrop(this.dropCustomHandler);
186
186
 
187
- this.offDragOver(this.dragOverHandler);
187
+ this.offCustomDragOver(this.dragOverCustomHandler);
188
188
 
189
189
  super.willUnmount();
190
190
  }