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/example.js +91 -46
- package/lib/div/item/entry/drag.js +2 -2
- package/lib/explorer.js +75 -33
- package/lib/item/entry/drag.js +4 -7
- package/lib/rubbishBin.js +12 -6
- package/lib/span/name.js +2 -2
- package/package.json +1 -1
- package/src/div/item/entry/drag.js +1 -1
- package/src/explorer.js +69 -34
- package/src/item/entry/drag.js +3 -9
- package/src/rubbishBin.js +11 -7
- package/src/span/name.js +0 -2
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
|
|
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,
|
|
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
|
@@ -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.
|
|
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
|
-
|
|
274
|
-
const
|
|
265
|
+
selectOrDeselectDragEntryItem(dragEntryItem, callHandlers = true) {
|
|
266
|
+
const disabled = this.isDisabled();
|
|
275
267
|
|
|
276
|
-
|
|
268
|
+
if (disabled) {
|
|
269
|
+
return;
|
|
270
|
+
}
|
|
277
271
|
|
|
278
|
-
|
|
272
|
+
let selected = dragEntryItem.isSelected();
|
|
279
273
|
|
|
280
|
-
|
|
281
|
-
const selected = true,
|
|
282
|
-
readOnly = dragEntryItem.isReadOnly(),
|
|
283
|
-
explorer = dragEntryItem.getExplorer();
|
|
274
|
+
const path = dragEntryItem.getPath();
|
|
284
275
|
|
|
285
|
-
|
|
276
|
+
if (selected) {
|
|
277
|
+
dragEntryItem.deselect();
|
|
278
|
+
} else {
|
|
279
|
+
this.deselectAllPaths();
|
|
280
|
+
|
|
281
|
+
this.selectPath(path);
|
|
286
282
|
}
|
|
287
|
-
}
|
|
288
283
|
|
|
289
|
-
|
|
290
|
-
const path = null;
|
|
284
|
+
selected = !selected; ///
|
|
291
285
|
|
|
292
286
|
if (callHandlers) {
|
|
293
|
-
const
|
|
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
|
`;
|
package/src/item/entry/drag.js
CHANGED
|
@@ -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
|
-
|
|
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
|
-
|
|
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
|
-
|
|
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.
|
|
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
|
`;
|