easy-file-system 2.1.97 → 2.1.99

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/span/name.js CHANGED
@@ -174,7 +174,7 @@ function _create_super(Derived) {
174
174
  }
175
175
  function _templateObject() {
176
176
  var data = _tagged_template_literal([
177
- "\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 pointer-events: all;\n\n [contentEditable] {\n border: 1px solid black;\n padding: 4px;\n }\n \n \n"
177
+ "\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"
178
178
  ]);
179
179
  _templateObject = function _templateObject() {
180
180
  return data;
@@ -264,4 +264,4 @@ _define_property(NameSpan, "defaultProperties", {
264
264
  Object.assign(NameSpan.prototype, _nameSpan.default);
265
265
  var _default = (0, _easywithstyle.default)(NameSpan)(_templateObject());
266
266
 
267
- //# 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\";\n\nimport nameSpanMixins from \"../mixins/nameSpan\";\n\nimport { TRUE, CONTENT_EDITABLE } from \"../constants\";\nimport { Element, window, document } from \"easy\";\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          { childNodes } = domElement,\n          firstChildNode = first(childNodes),\n          textNode = firstChildNode;  ///\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, htmlLength);\n\n    range.setEnd(textNode, htmlLength);\n\n    selection.removeAllRanges();\n\n    selection.addRange(range);\n\n    this.onKeyDown(this.keyDownHandler);\n  }\n\n  cancel() {\n    this.offKeyDown(this.keyDownHandler);\n\n    this.removeAttribute(CONTENT_EDITABLE, TRUE);\n  }\n\n  parentContext() {\n    const editNameSpan = this.edit.bind(this), ///\n          cancelNameSpan = this.cancel.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      cancelNameSpan,\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  pointer-events: all;\n\n  [contentEditable] {\n    border: 1px solid black;\n    padding: 4px;\n  }\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","childNodes","firstChildNode","textNode","nodeValue","edit","focus","addAttribute","CONTENT_EDITABLE","TRUE","range","document","createRange","selection","window","getSelection","htmlLength","length","setStart","setEnd","removeAllRanges","addRange","onKeyDown","cancel","offKeyDown","removeAttribute","parentContext","editNameSpan","bind","cancelNameSpan","getNameSpanName","setNameSpanName","onNameSpanChange","onChange","onNameSpanCancel","onCancel","offNameSpanChange","offChange","offNameSpanCancel","offCancel","Element","tagName","defaultProperties","className","Object","assign","prototype","nameSpanMixins","withStyle"],"mappings":"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"}
267
+ //# 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\";\n\nimport nameSpanMixins from \"../mixins/nameSpan\";\n\nimport { TRUE, CONTENT_EDITABLE } from \"../constants\";\nimport { Element, window, document } from \"easy\";\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          { childNodes } = domElement,\n          firstChildNode = first(childNodes),\n          textNode = firstChildNode;  ///\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, htmlLength);\n\n    range.setEnd(textNode, htmlLength);\n\n    selection.removeAllRanges();\n\n    selection.addRange(range);\n\n    this.onKeyDown(this.keyDownHandler);\n  }\n\n  cancel() {\n    this.offKeyDown(this.keyDownHandler);\n\n    this.removeAttribute(CONTENT_EDITABLE, TRUE);\n  }\n\n  parentContext() {\n    const editNameSpan = this.edit.bind(this), ///\n          cancelNameSpan = this.cancel.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      cancelNameSpan,\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","childNodes","firstChildNode","textNode","nodeValue","edit","focus","addAttribute","CONTENT_EDITABLE","TRUE","range","document","createRange","selection","window","getSelection","htmlLength","length","setStart","setEnd","removeAllRanges","addRange","onKeyDown","cancel","offKeyDown","removeAttribute","parentContext","editNameSpan","bind","cancelNameSpan","getNameSpanName","setNameSpanName","onNameSpanChange","onChange","onNameSpanCancel","onCancel","offNameSpanChange","offChange","offNameSpanCancel","offCancel","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.97",
4
+ "version": "2.1.99",
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.",
@@ -7,7 +7,7 @@ export default class DragEntryItemDiv extends EntryItemDiv {
7
7
  const explorer = this.getExplorer(),
8
8
  dragEntryItem = this.getDragEntryItem();
9
9
 
10
- explorer.selectDragEntryItem(dragEntryItem);
10
+ explorer.selectOrDeselectDragEntryItem(dragEntryItem);
11
11
  }
12
12
 
13
13
  didMount() {
package/src/explorer.js CHANGED
@@ -184,14 +184,6 @@ class Explorer extends Element {
184
184
  this.callOpenHandlers(filePath, explorer);
185
185
  }
186
186
 
187
- enable() {
188
- this.removeClass("disabled");
189
- }
190
-
191
- disable() {
192
- this.addClass("disabled");
193
- }
194
-
195
187
  collapse() {
196
188
  const directoryNameDragEntryItems = this.retrieveDirectoryNameDragEntryItems();
197
189
 
@@ -270,28 +262,29 @@ class Explorer extends Element {
270
262
  return selectedPath;
271
263
  }
272
264
 
273
- selectDragEntryItem(dragEntryItem, callHandlers = true) {
274
- const path = dragEntryItem.getPath();
265
+ selectOrDeselectDragEntryItem(dragEntryItem, callHandlers = true) {
266
+ const disabled = this.isDisabled();
275
267
 
276
- this.deselectAllPaths();
268
+ if (disabled) {
269
+ return;
270
+ }
277
271
 
278
- this.selectPath(path);
272
+ let selected = dragEntryItem.isSelected();
279
273
 
280
- if (callHandlers) {
281
- const selected = true,
282
- readOnly = dragEntryItem.isReadOnly(),
283
- explorer = dragEntryItem.getExplorer();
274
+ const path = dragEntryItem.getPath();
284
275
 
285
- this.callSelectHandlers(path, selected, readOnly, explorer);
276
+ if (selected) {
277
+ dragEntryItem.deselect();
278
+ } else {
279
+ this.deselectAllPaths();
280
+
281
+ this.selectPath(path);
286
282
  }
287
- }
288
283
 
289
- deselectDragEntryItem(dragEntryItem, callHandlers = true) {
290
- const path = null;
284
+ selected = !selected; ///
291
285
 
292
286
  if (callHandlers) {
293
- const selected = false,
294
- readOnly = dragEntryItem.isReadOnly(),
287
+ const readOnly = dragEntryItem.isReadOnly(),
295
288
  explorer = dragEntryItem.getExplorer();
296
289
 
297
290
  this.callSelectHandlers(path, selected, readOnly, explorer);
@@ -329,16 +322,8 @@ class Explorer extends Element {
329
322
  explorer = dragEntryItemExplorer; ///
330
323
 
331
324
  this.moveDragEntryItems(pathMaps, explorer, () => {
332
- const lastPathMap = last(pathMaps),
333
- { targetEntryPath } = lastPathMap,
334
- path = targetEntryPath;
335
-
336
325
  this.removeMarker();
337
326
 
338
- if (path !== null) {
339
- this.selectPath(path);
340
- }
341
-
342
327
  done();
343
328
  });
344
329
  }
@@ -399,6 +384,58 @@ class Explorer extends Element {
399
384
  });
400
385
  }
401
386
 
387
+ enable() {
388
+ const disabled = false;
389
+
390
+ this.setDisabled(disabled);
391
+
392
+ this.enableDrag();
393
+ }
394
+
395
+ disable() {
396
+ const disabled = true;
397
+
398
+ this.setDisabled(disabled);
399
+
400
+ this.disableDrag();
401
+ }
402
+
403
+ enableDrag() {
404
+ const dragEntryItems = this.retrieveDragEntryItems();
405
+
406
+ dragEntryItems.forEach((dragEntryItem) => {
407
+ dragEntryItem.enableDrag();
408
+ });
409
+ }
410
+
411
+ disableDrag() {
412
+ const dragEntryItems = this.retrieveDragEntryItems();
413
+
414
+ dragEntryItems.forEach((dragEntryItem) => {
415
+ dragEntryItem.disableDrag();
416
+ });
417
+ }
418
+
419
+ isDisabled() {
420
+ const { disabled } = this.getState();
421
+
422
+ return disabled;
423
+ }
424
+
425
+ setDisabled(disabled) {
426
+ this.updateState({
427
+ disabled
428
+ });
429
+ }
430
+
431
+ setInitialState() {
432
+ const disabled = false;
433
+
434
+ this.setState({
435
+ disabled
436
+ });
437
+ }
438
+
402
439
  didMount() {
403
440
  const { onMove, onOpen, onSelect } = this.properties,
404
441
  moveHandler = onMove, ///
@@ -469,6 +506,8 @@ class Explorer extends Element {
469
506
 
470
507
  initialise() {
471
508
  this.assignContext();
509
+
510
+ this.setInitialState();
472
511
  }
473
512
 
474
513
  static EntriesList = EntriesList;
@@ -504,8 +543,4 @@ export default withStyle(Explorer)`
504
543
 
505
544
  padding: ${explorerPadding};
506
545
 
507
- .disabled {
508
- pointer-events: none;
509
- }
510
-
511
546
  `;
@@ -177,15 +177,13 @@ class DragEntryItem extends EntryItem {
177
177
  explorer = this.getExplorer(),
178
178
  nameSpanName = EMPTY_STRING; ///
179
179
 
180
- explorer.disable();
181
-
182
180
  this.setCreated(created);
183
181
 
184
182
  this.setNameSpanName(nameSpanName);
185
183
 
186
184
  this.editNameSpan();
187
185
 
188
- this.disableDrag();
186
+ explorer.disable();
189
187
  }
190
188
 
191
189
  edit() {
@@ -194,28 +192,24 @@ class DragEntryItem extends EntryItem {
194
192
  explorer = this.getExplorer(),
195
193
  nameSpanName = name; ///
196
194
 
197
- explorer.disable();
198
-
199
195
  this.setCreated(created);
200
196
 
201
197
  this.setNameSpanName(nameSpanName);
202
198
 
203
199
  this.editNameSpan();
204
200
 
205
- this.disableDrag();
201
+ explorer.disable();
206
202
  }
207
203
 
208
204
  reset() {
209
205
  const created = this.isCreated(),
210
206
  explorer = this.getExplorer();
211
207
 
212
- explorer.enable();
213
-
214
208
  this.cancelNameSpan();
215
209
 
216
210
  this.setCreated(created);
217
211
 
218
- this.enableDrag();
212
+ explorer.enable();
219
213
  }
220
214
 
221
215
  cancel() {
package/src/rubbishBin.js CHANGED
@@ -268,6 +268,16 @@ class RubbishBin extends Element {
268
268
  });
269
269
  }
270
270
 
271
+ setInitialState() {
272
+ const markerEntryItemPath = null,
273
+ markerEntryItemExplorer = null;
274
+
275
+ this.setState({
276
+ markerEntryItemPath,
277
+ markerEntryItemExplorer
278
+ });
279
+ }
280
+
271
281
  childElements() {
272
282
  const { OpenRubbishBinSVG, ClosedRubbishBinSVG } = this.constructor;
273
283
 
@@ -280,15 +290,9 @@ class RubbishBin extends Element {
280
290
  }
281
291
 
282
292
  initialise() {
283
- const markerEntryItemPath = null,
284
- markerEntryItemExplorer = null;
285
-
286
293
  this.assignContext();
287
294
 
288
- this.setState({
289
- markerEntryItemPath,
290
- markerEntryItemExplorer
291
- });
295
+ this.setInitialState();
292
296
  }
293
297
 
294
298
  static OpenRubbishBinSVG = OpenRubbishBinSVG;
package/src/span/name.js CHANGED
@@ -116,12 +116,10 @@ export default withStyle(NameSpan)`
116
116
  background: transparent;
117
117
  font-weight: inherit;
118
118
  font-family: inherit;
119
- pointer-events: all;
120
119
 
121
120
  [contentEditable] {
122
121
  border: 1px solid black;
123
122
  padding: 4px;
124
123
  }
125
124
 
126
-
127
125
  `;