@hmcts/media-viewer 3.1.0 → 3.1.2
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/assets/sass/toolbar/side-bar.scss +2 -1
- package/esm2020/lib/viewers/pdf-viewer/side-bar/bookmarks/bookmarks.component.mjs +40 -20
- package/fesm2015/hmcts-media-viewer.mjs +39 -19
- package/fesm2015/hmcts-media-viewer.mjs.map +1 -1
- package/fesm2020/hmcts-media-viewer.mjs +39 -19
- package/fesm2020/hmcts-media-viewer.mjs.map +1 -1
- package/lib/viewers/pdf-viewer/side-bar/bookmarks/bookmarks.component.d.ts +3 -1
- package/lib/viewers/pdf-viewer/side-bar/bookmarks/bookmarks.component.d.ts.map +1 -1
- package/package.json +1 -1
|
@@ -31,7 +31,8 @@ export class BookmarksComponent {
|
|
|
31
31
|
this._bookmarkNodes = [];
|
|
32
32
|
// expansion model tracks expansion state
|
|
33
33
|
this.expansionModel = new SelectionModel(true);
|
|
34
|
-
this.
|
|
34
|
+
this.isDraggingOn = false;
|
|
35
|
+
this.isUserdragging = false;
|
|
35
36
|
this.expandDelay = 1000;
|
|
36
37
|
this.pageLookup = {};
|
|
37
38
|
this.BOOKMARK_CHAR_LIMIT = 30;
|
|
@@ -148,12 +149,14 @@ export class BookmarksComponent {
|
|
|
148
149
|
}
|
|
149
150
|
positionSortBookmarks() {
|
|
150
151
|
this.bookmarkNodes.sort((a, b) => a.pageNumber === b.pageNumber ? a.yCoordinate - b.yCoordinate : a.pageNumber - b.pageNumber);
|
|
152
|
+
this.isDraggingOn = false;
|
|
151
153
|
this.rebuildTreeForData(this.bookmarkNodes);
|
|
152
154
|
}
|
|
153
155
|
customSortBookmarks() {
|
|
154
156
|
if (this.bookmarkNodes.length > 1) {
|
|
155
157
|
this.bookmarkNodes.sort((a, b) => a.index - b.index);
|
|
156
158
|
}
|
|
159
|
+
this.isDraggingOn = true;
|
|
157
160
|
this.rebuildTreeForData(this.bookmarkNodes);
|
|
158
161
|
}
|
|
159
162
|
scaledY(yCoordinate, height, page) {
|
|
@@ -178,7 +181,8 @@ export class BookmarksComponent {
|
|
|
178
181
|
if (!event.isPointerOverContainer || (event.previousIndex === event.currentIndex))
|
|
179
182
|
return;
|
|
180
183
|
const hasMovedUpTheTree = event.previousIndex > event.currentIndex;
|
|
181
|
-
const
|
|
184
|
+
const bookmarkNodesString = JSON.stringify(this._bookmarkNodes);
|
|
185
|
+
const changedData = JSON.parse(bookmarkNodesString);
|
|
182
186
|
const visibleNodes = this.visibleNodes(this._bookmarkNodes);
|
|
183
187
|
const toNode = visibleNodes[event.currentIndex];
|
|
184
188
|
const toNodeSiblings = this.findNodeSiblings(changedData, toNode.id);
|
|
@@ -187,6 +191,8 @@ export class BookmarksComponent {
|
|
|
187
191
|
const fromNode = event.item.data;
|
|
188
192
|
const fromNodeSiblings = this.findNodeSiblings(changedData, fromNode.id);
|
|
189
193
|
const fromIndex = fromNodeSiblings.findIndex(n => n.id === fromNode.id);
|
|
194
|
+
if (this.isToNodeChildOfFromNode(fromNode?.children, toNode))
|
|
195
|
+
return;
|
|
190
196
|
if (this.dragNodeInsertToParent) {
|
|
191
197
|
const indexOfParent = toNodeSiblings.findIndex(element => element.id === toNode.id);
|
|
192
198
|
const parentNode = toNodeSiblings[indexOfParent];
|
|
@@ -195,18 +201,29 @@ export class BookmarksComponent {
|
|
|
195
201
|
if (firstChild) {
|
|
196
202
|
movedBookmarksWithParent = [...movedBookmarksWithParent, { ...firstChild, previous: fromNode.id }];
|
|
197
203
|
}
|
|
204
|
+
let fromNodeSibling = this.getSiblingFromAllSibliings(fromNodeSiblings, fromIndex + 1);
|
|
205
|
+
const nextFromindexforParent = fromIndex + 1;
|
|
206
|
+
fromNodeSibling = fromNodeSibling && fromNodeSibling.id === fromNode.previous ? this.getSiblingFromAllSibliings(fromNodeSiblings, nextFromindexforParent + 1) : fromNodeSibling;
|
|
207
|
+
if (fromNodeSibling && fromNodeSibling.id !== parentNode.id) {
|
|
208
|
+
movedBookmarksWithParent = [...movedBookmarksWithParent, { ...fromNodeSibling, previous: fromNode.previous }];
|
|
209
|
+
}
|
|
198
210
|
let previousSiblingForParentIndex = toIndex - 1;
|
|
199
|
-
let parentNodeSibling = this.getSiblingFromAllSibliings(
|
|
200
|
-
if (parentNodeSibling.id == fromNode.id) {
|
|
211
|
+
let parentNodeSibling = this.getSiblingFromAllSibliings(toNodeSiblings, previousSiblingForParentIndex);
|
|
212
|
+
if (parentNodeSibling && parentNodeSibling.id == fromNode.id) {
|
|
201
213
|
previousSiblingForParentIndex = previousSiblingForParentIndex - 1;
|
|
202
|
-
if (previousSiblingForParentIndex
|
|
203
|
-
parentNodeSibling = this.getSiblingFromAllSibliings(
|
|
214
|
+
if (previousSiblingForParentIndex >= 0) {
|
|
215
|
+
parentNodeSibling = this.getSiblingFromAllSibliings(toNodeSiblings, previousSiblingForParentIndex);
|
|
204
216
|
}
|
|
205
217
|
else {
|
|
206
218
|
parentNodeSibling = null;
|
|
207
219
|
}
|
|
208
220
|
}
|
|
209
221
|
movedBookmarksWithParent = [...movedBookmarksWithParent, { ...parentNode, previous: parentNodeSibling?.id }];
|
|
222
|
+
const hasParentDups = movedBookmarksWithParent.map(x => x.id).some(function (value, index, array) {
|
|
223
|
+
return array.indexOf(value) !== array.lastIndexOf(value); // comparing first and last indexes of the same value
|
|
224
|
+
});
|
|
225
|
+
if (hasParentDups || movedBookmarksWithParent && movedBookmarksWithParent.length <= 1)
|
|
226
|
+
return;
|
|
210
227
|
this.store.dispatch(new MoveBookmark(movedBookmarksWithParent));
|
|
211
228
|
return;
|
|
212
229
|
}
|
|
@@ -219,7 +236,8 @@ export class BookmarksComponent {
|
|
|
219
236
|
parent: toNodeParent
|
|
220
237
|
}];
|
|
221
238
|
let fromNodeSibling = this.getSiblingFromAllSibliings(fromNodeSiblings, fromIndex + 1);
|
|
222
|
-
|
|
239
|
+
const nextFromindex = fromIndex + 1;
|
|
240
|
+
fromNodeSibling = fromNodeSibling && fromNodeSibling.id === fromNode.previous ? this.getSiblingFromAllSibliings(fromNodeSiblings, nextFromindex + 1) : fromNodeSibling;
|
|
223
241
|
if (fromNodeSibling) {
|
|
224
242
|
movedBookmarks = [...movedBookmarks, { ...fromNodeSibling, previous: fromNode.previous }];
|
|
225
243
|
}
|
|
@@ -241,13 +259,13 @@ export class BookmarksComponent {
|
|
|
241
259
|
dragStart() {
|
|
242
260
|
this.dragNodeInsertToParent = false;
|
|
243
261
|
this.hoveredNode = null;
|
|
244
|
-
this.
|
|
262
|
+
this.isUserdragging = true;
|
|
245
263
|
}
|
|
246
264
|
dragEnd() {
|
|
247
|
-
this.
|
|
265
|
+
this.isUserdragging = false;
|
|
248
266
|
}
|
|
249
267
|
dragHover(event, node) {
|
|
250
|
-
if (this.
|
|
268
|
+
if (this.isUserdragging) {
|
|
251
269
|
const newEvent = event;
|
|
252
270
|
const percentageX = newEvent.offsetX / newEvent.target.clientWidth;
|
|
253
271
|
if (percentageX > .55) {
|
|
@@ -258,19 +276,14 @@ export class BookmarksComponent {
|
|
|
258
276
|
this.hoveredNode = null;
|
|
259
277
|
this.dragNodeInsertToParent = false;
|
|
260
278
|
}
|
|
261
|
-
clearTimeout(this.expandTimeout);
|
|
262
|
-
this.expandTimeout = setTimeout(() => {
|
|
263
|
-
this.treeControl.expand(node);
|
|
264
|
-
}, this.expandDelay);
|
|
265
279
|
}
|
|
266
280
|
}
|
|
267
281
|
dragHoverEnd(event, node) {
|
|
268
|
-
if (this.
|
|
282
|
+
if (this.isUserdragging) {
|
|
269
283
|
if (!node || this.hoveredNode?.id !== node.id) {
|
|
270
284
|
this.dragNodeInsertToParent = false;
|
|
271
285
|
this.hoveredNode = null;
|
|
272
286
|
}
|
|
273
|
-
clearTimeout(this.expandTimeout);
|
|
274
287
|
}
|
|
275
288
|
}
|
|
276
289
|
onNodeExpand(node) {
|
|
@@ -296,7 +309,7 @@ export class BookmarksComponent {
|
|
|
296
309
|
if (item.id === id) {
|
|
297
310
|
result = arr;
|
|
298
311
|
}
|
|
299
|
-
else if (item
|
|
312
|
+
else if (item?.children) {
|
|
300
313
|
subResult = this.findNodeSiblings(item.children, id);
|
|
301
314
|
if (subResult)
|
|
302
315
|
result = subResult;
|
|
@@ -314,12 +327,19 @@ export class BookmarksComponent {
|
|
|
314
327
|
this.treeControl.expand(node);
|
|
315
328
|
});
|
|
316
329
|
}
|
|
330
|
+
isToNodeChildOfFromNode(fromNodeChildren, toNode) {
|
|
331
|
+
if (!fromNodeChildren) {
|
|
332
|
+
return false;
|
|
333
|
+
}
|
|
334
|
+
const result = this.getNode(fromNodeChildren, toNode.id);
|
|
335
|
+
return result ? true : false;
|
|
336
|
+
}
|
|
317
337
|
}
|
|
318
338
|
/** @nocollapse */ BookmarksComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: BookmarksComponent, deps: [{ token: i1.Store }], target: i0.ɵɵFactoryTarget.Component });
|
|
319
|
-
/** @nocollapse */ BookmarksComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: BookmarksComponent, selector: "mv-bookmarks", inputs: { bookmarkNodes: "bookmarkNodes", zoom: "zoom", rotate: "rotate" }, outputs: { goToDestination: "goToDestination" }, ngImport: i0, template: "<a *ngIf=\"bookmarkNodes?.length === 0\" class=\"highlightedOutlineItem\"\n >No bookmarks created yet</a\n>\n<cdk-tree\n cdkDropList\n class=\"bookmarks-tree\"\n *ngIf=\"datasource\"\n [dataSource]=\"datasource\"\n [treeControl]=\"treeControl\"\n (cdkDropListDropped)=\"drop($event)\"\n>\n <!-- This is the tree node template for leaf nodes -->\n <cdk-nested-tree-node class=\"node-wrapper\" *cdkTreeNodeDef=\"let node\">\n <div *ngIf=\"node.id !== editableBookmark; else inputBookmark\">\n <div\n class=\"node-content-wrapper nested-tree-node\"\n cdkDrag\n [cdkDragData]=\"node\"\n (mouseenter)=\"dragHover($event, node)\"\n (mouseleave)=\"dragHoverEnd($event, node)\"\n (cdkDragStarted)=\"dragStart()\"\n (cdkDragReleased)=\"dragEnd()\"\n >\n <div class=\"outlineItem\">\n <a (click)=\"goToBookmark(node)\">\n {{ node.name }}\n </a>\n </div>\n <button\n class=\"bookmark__rename\"\n (click)=\"editBookmark(node.id)\"\n ></button>\n <button\n class=\"bookmark__delete\"\n (click)=\"deleteBookmark2(node)\"\n ></button>\n </div>\n <div class=\"node-drop-slot\"></div>\n </div>\n <ng-template #inputBookmark>\n <input\n #bookmarkName\n class=\"bookmark__input\"\n [value]=\"node.name\"\n [maxLength]=\"BOOKMARK_CHAR_LIMIT\"\n />\n <button\n class=\"bookmark__save\"\n (click)=\"updateBookmark(node, bookmarkName.value)\"\n ></button>\n </ng-template>\n </cdk-nested-tree-node>\n <!-- This is the tree node template for expandable nodes -->\n <cdk-nested-tree-node\n class=\"node-wrapper\"\n *cdkTreeNodeDef=\"let node; when: hasChild\"\n >\n <div *ngIf=\"node.id !== editableBookmark; else inputBookmark2\">\n <div\n class=\"node-content-wrapper nested-tree-node\"\n cdkDrag\n [cdkDragData]=\"node\"\n (mouseenter)=\"dragHover($event, node)\"\n (mouseleave)=\"dragHoverEnd($event, node)\"\n (cdkDragStarted)=\"dragStart()\"\n (cdkDragReleased)=\"dragEnd()\"\n >\n <div class=\"outlineItem\">\n <span\n cdkTreeNodeToggle\n class=\"toggle-children-wrapper\"\n [ngClass]=\"onNodeExpand(node)\"\n ><span class=\"toggle-children\"></span\n ></span>\n <a (click)=\"goToBookmark(node)\">\n {{ node.name }}\n </a>\n </div>\n <button\n class=\"bookmark__rename\"\n (click)=\"editBookmark(node.id)\"\n ></button>\n <button\n class=\"bookmark__delete\"\n (click)=\"deleteBookmark2(node)\"\n ></button>\n </div>\n <div class=\"node-drop-slot\"></div>\n </div>\n <ng-template #inputBookmark2>\n <input\n #bookmarkName\n class=\"bookmark__input\"\n [value]=\"node.name\"\n [maxLength]=\"BOOKMARK_CHAR_LIMIT\"\n />\n <button\n class=\"bookmark__save\"\n (click)=\"updateBookmark(node, bookmarkName.value)\"\n ></button>\n </ng-template>\n <div class=\"nested-tree-node-children\" *ngIf=\"treeControl.isExpanded(node)\">\n <ng-container cdkTreeNodeOutlet></ng-container>\n </div>\n </cdk-nested-tree-node>\n</cdk-tree>\n", dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.CdkNestedTreeNode, selector: "cdk-nested-tree-node", inputs: ["role", "disabled", "tabIndex"], exportAs: ["cdkNestedTreeNode"] }, { kind: "directive", type: i3.CdkTreeNodeDef, selector: "[cdkTreeNodeDef]", inputs: ["cdkTreeNodeDefWhen"] }, { kind: "directive", type: i3.CdkTreeNodeToggle, selector: "[cdkTreeNodeToggle]", inputs: ["cdkTreeNodeToggleRecursive"] }, { kind: "component", type: i3.CdkTree, selector: "cdk-tree", inputs: ["dataSource", "treeControl", "trackBy"], exportAs: ["cdkTree"] }, { kind: "directive", type: i3.CdkTreeNodeOutlet, selector: "[cdkTreeNodeOutlet]" }, { kind: "directive", type: i4.CdkDropList, selector: "[cdkDropList], cdk-drop-list", inputs: ["cdkDropListConnectedTo", "cdkDropListData", "cdkDropListOrientation", "id", "cdkDropListLockAxis", "cdkDropListDisabled", "cdkDropListSortingDisabled", "cdkDropListEnterPredicate", "cdkDropListSortPredicate", "cdkDropListAutoScrollDisabled", "cdkDropListAutoScrollStep"], outputs: ["cdkDropListDropped", "cdkDropListEntered", "cdkDropListExited", "cdkDropListSorted"], exportAs: ["cdkDropList"] }, { kind: "directive", type: i4.CdkDrag, selector: "[cdkDrag]", inputs: ["cdkDragData", "cdkDragLockAxis", "cdkDragRootElement", "cdkDragBoundary", "cdkDragStartDelay", "cdkDragFreeDragPosition", "cdkDragDisabled", "cdkDragConstrainPosition", "cdkDragPreviewClass", "cdkDragPreviewContainer"], outputs: ["cdkDragStarted", "cdkDragReleased", "cdkDragEnded", "cdkDragEntered", "cdkDragExited", "cdkDragDropped", "cdkDragMoved"], exportAs: ["cdkDrag"] }] });
|
|
339
|
+
/** @nocollapse */ BookmarksComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: BookmarksComponent, selector: "mv-bookmarks", inputs: { bookmarkNodes: "bookmarkNodes", zoom: "zoom", rotate: "rotate" }, outputs: { goToDestination: "goToDestination" }, ngImport: i0, template: "<a *ngIf=\"bookmarkNodes?.length === 0\" class=\"highlightedOutlineItem\"\n >No bookmarks created yet</a\n>\n<cdk-tree\n cdkDropList\n [cdkDropListDisabled]=\"!isDraggingOn\"\n class=\"bookmarks-tree\"\n *ngIf=\"datasource\"\n [dataSource]=\"datasource\"\n [treeControl]=\"treeControl\"\n (cdkDropListDropped)=\"drop($event)\"\n>\n <!-- This is the tree node template for leaf nodes -->\n <cdk-nested-tree-node class=\"node-wrapper\" *cdkTreeNodeDef=\"let node\">\n <div *ngIf=\"node.id !== editableBookmark; else inputBookmark\">\n <div\n class=\"node-content-wrapper nested-tree-node\"\n cdkDrag\n [cdkDragData]=\"node\"\n (mouseenter)=\"dragHover($event, node)\"\n (mouseleave)=\"dragHoverEnd($event, node)\"\n (cdkDragStarted)=\"dragStart()\"\n (cdkDragReleased)=\"dragEnd()\"\n >\n <div class=\"outlineItem\">\n <a (click)=\"goToBookmark(node)\">\n {{ node.name }}\n </a>\n </div>\n <button\n class=\"bookmark__rename\"\n (click)=\"editBookmark(node.id)\"\n ></button>\n <button\n class=\"bookmark__delete\"\n (click)=\"deleteBookmark2(node)\"\n ></button>\n </div>\n <div class=\"node-drop-slot\"></div>\n </div>\n <ng-template #inputBookmark>\n <input\n #bookmarkName\n class=\"bookmark__input\"\n [value]=\"node.name\"\n [maxLength]=\"BOOKMARK_CHAR_LIMIT\"\n />\n <button\n class=\"bookmark__save\"\n (click)=\"updateBookmark(node, bookmarkName.value)\"\n ></button>\n </ng-template>\n </cdk-nested-tree-node>\n <!-- This is the tree node template for expandable nodes -->\n <cdk-nested-tree-node\n class=\"node-wrapper\"\n *cdkTreeNodeDef=\"let node; when: hasChild\"\n >\n <div *ngIf=\"node.id !== editableBookmark; else inputBookmark2\">\n <div\n class=\"node-content-wrapper nested-tree-node\"\n cdkDrag\n [cdkDragData]=\"node\"\n (mouseenter)=\"dragHover($event, node)\"\n (mouseleave)=\"dragHoverEnd($event, node)\"\n (cdkDragStarted)=\"dragStart()\"\n (cdkDragReleased)=\"dragEnd()\"\n >\n <div class=\"outlineItem\">\n <span\n cdkTreeNodeToggle\n class=\"toggle-children-wrapper\"\n [ngClass]=\"onNodeExpand(node)\"\n ><span class=\"toggle-children\"></span\n ></span>\n <a (click)=\"goToBookmark(node)\">\n {{ node.name }}\n </a>\n </div>\n <button\n class=\"bookmark__rename\"\n (click)=\"editBookmark(node.id)\"\n ></button>\n <button\n class=\"bookmark__delete\"\n (click)=\"deleteBookmark2(node)\"\n ></button>\n </div>\n <div class=\"node-drop-slot\"></div>\n </div>\n <ng-template #inputBookmark2>\n <input\n #bookmarkName\n class=\"bookmark__input\"\n [value]=\"node.name\"\n [maxLength]=\"BOOKMARK_CHAR_LIMIT\"\n />\n <button\n class=\"bookmark__save\"\n (click)=\"updateBookmark(node, bookmarkName.value)\"\n ></button>\n </ng-template>\n <div class=\"nested-tree-node-children\" *ngIf=\"treeControl.isExpanded(node)\">\n <ng-container cdkTreeNodeOutlet></ng-container>\n </div>\n </cdk-nested-tree-node>\n</cdk-tree>\n", dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.CdkNestedTreeNode, selector: "cdk-nested-tree-node", inputs: ["role", "disabled", "tabIndex"], exportAs: ["cdkNestedTreeNode"] }, { kind: "directive", type: i3.CdkTreeNodeDef, selector: "[cdkTreeNodeDef]", inputs: ["cdkTreeNodeDefWhen"] }, { kind: "directive", type: i3.CdkTreeNodeToggle, selector: "[cdkTreeNodeToggle]", inputs: ["cdkTreeNodeToggleRecursive"] }, { kind: "component", type: i3.CdkTree, selector: "cdk-tree", inputs: ["dataSource", "treeControl", "trackBy"], exportAs: ["cdkTree"] }, { kind: "directive", type: i3.CdkTreeNodeOutlet, selector: "[cdkTreeNodeOutlet]" }, { kind: "directive", type: i4.CdkDropList, selector: "[cdkDropList], cdk-drop-list", inputs: ["cdkDropListConnectedTo", "cdkDropListData", "cdkDropListOrientation", "id", "cdkDropListLockAxis", "cdkDropListDisabled", "cdkDropListSortingDisabled", "cdkDropListEnterPredicate", "cdkDropListSortPredicate", "cdkDropListAutoScrollDisabled", "cdkDropListAutoScrollStep"], outputs: ["cdkDropListDropped", "cdkDropListEntered", "cdkDropListExited", "cdkDropListSorted"], exportAs: ["cdkDropList"] }, { kind: "directive", type: i4.CdkDrag, selector: "[cdkDrag]", inputs: ["cdkDragData", "cdkDragLockAxis", "cdkDragRootElement", "cdkDragBoundary", "cdkDragStartDelay", "cdkDragFreeDragPosition", "cdkDragDisabled", "cdkDragConstrainPosition", "cdkDragPreviewClass", "cdkDragPreviewContainer"], outputs: ["cdkDragStarted", "cdkDragReleased", "cdkDragEnded", "cdkDragEntered", "cdkDragExited", "cdkDragDropped", "cdkDragMoved"], exportAs: ["cdkDrag"] }] });
|
|
320
340
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: BookmarksComponent, decorators: [{
|
|
321
341
|
type: Component,
|
|
322
|
-
args: [{ selector: 'mv-bookmarks', template: "<a *ngIf=\"bookmarkNodes?.length === 0\" class=\"highlightedOutlineItem\"\n >No bookmarks created yet</a\n>\n<cdk-tree\n cdkDropList\n class=\"bookmarks-tree\"\n *ngIf=\"datasource\"\n [dataSource]=\"datasource\"\n [treeControl]=\"treeControl\"\n (cdkDropListDropped)=\"drop($event)\"\n>\n <!-- This is the tree node template for leaf nodes -->\n <cdk-nested-tree-node class=\"node-wrapper\" *cdkTreeNodeDef=\"let node\">\n <div *ngIf=\"node.id !== editableBookmark; else inputBookmark\">\n <div\n class=\"node-content-wrapper nested-tree-node\"\n cdkDrag\n [cdkDragData]=\"node\"\n (mouseenter)=\"dragHover($event, node)\"\n (mouseleave)=\"dragHoverEnd($event, node)\"\n (cdkDragStarted)=\"dragStart()\"\n (cdkDragReleased)=\"dragEnd()\"\n >\n <div class=\"outlineItem\">\n <a (click)=\"goToBookmark(node)\">\n {{ node.name }}\n </a>\n </div>\n <button\n class=\"bookmark__rename\"\n (click)=\"editBookmark(node.id)\"\n ></button>\n <button\n class=\"bookmark__delete\"\n (click)=\"deleteBookmark2(node)\"\n ></button>\n </div>\n <div class=\"node-drop-slot\"></div>\n </div>\n <ng-template #inputBookmark>\n <input\n #bookmarkName\n class=\"bookmark__input\"\n [value]=\"node.name\"\n [maxLength]=\"BOOKMARK_CHAR_LIMIT\"\n />\n <button\n class=\"bookmark__save\"\n (click)=\"updateBookmark(node, bookmarkName.value)\"\n ></button>\n </ng-template>\n </cdk-nested-tree-node>\n <!-- This is the tree node template for expandable nodes -->\n <cdk-nested-tree-node\n class=\"node-wrapper\"\n *cdkTreeNodeDef=\"let node; when: hasChild\"\n >\n <div *ngIf=\"node.id !== editableBookmark; else inputBookmark2\">\n <div\n class=\"node-content-wrapper nested-tree-node\"\n cdkDrag\n [cdkDragData]=\"node\"\n (mouseenter)=\"dragHover($event, node)\"\n (mouseleave)=\"dragHoverEnd($event, node)\"\n (cdkDragStarted)=\"dragStart()\"\n (cdkDragReleased)=\"dragEnd()\"\n >\n <div class=\"outlineItem\">\n <span\n cdkTreeNodeToggle\n class=\"toggle-children-wrapper\"\n [ngClass]=\"onNodeExpand(node)\"\n ><span class=\"toggle-children\"></span\n ></span>\n <a (click)=\"goToBookmark(node)\">\n {{ node.name }}\n </a>\n </div>\n <button\n class=\"bookmark__rename\"\n (click)=\"editBookmark(node.id)\"\n ></button>\n <button\n class=\"bookmark__delete\"\n (click)=\"deleteBookmark2(node)\"\n ></button>\n </div>\n <div class=\"node-drop-slot\"></div>\n </div>\n <ng-template #inputBookmark2>\n <input\n #bookmarkName\n class=\"bookmark__input\"\n [value]=\"node.name\"\n [maxLength]=\"BOOKMARK_CHAR_LIMIT\"\n />\n <button\n class=\"bookmark__save\"\n (click)=\"updateBookmark(node, bookmarkName.value)\"\n ></button>\n </ng-template>\n <div class=\"nested-tree-node-children\" *ngIf=\"treeControl.isExpanded(node)\">\n <ng-container cdkTreeNodeOutlet></ng-container>\n </div>\n </cdk-nested-tree-node>\n</cdk-tree>\n" }]
|
|
342
|
+
args: [{ selector: 'mv-bookmarks', template: "<a *ngIf=\"bookmarkNodes?.length === 0\" class=\"highlightedOutlineItem\"\n >No bookmarks created yet</a\n>\n<cdk-tree\n cdkDropList\n [cdkDropListDisabled]=\"!isDraggingOn\"\n class=\"bookmarks-tree\"\n *ngIf=\"datasource\"\n [dataSource]=\"datasource\"\n [treeControl]=\"treeControl\"\n (cdkDropListDropped)=\"drop($event)\"\n>\n <!-- This is the tree node template for leaf nodes -->\n <cdk-nested-tree-node class=\"node-wrapper\" *cdkTreeNodeDef=\"let node\">\n <div *ngIf=\"node.id !== editableBookmark; else inputBookmark\">\n <div\n class=\"node-content-wrapper nested-tree-node\"\n cdkDrag\n [cdkDragData]=\"node\"\n (mouseenter)=\"dragHover($event, node)\"\n (mouseleave)=\"dragHoverEnd($event, node)\"\n (cdkDragStarted)=\"dragStart()\"\n (cdkDragReleased)=\"dragEnd()\"\n >\n <div class=\"outlineItem\">\n <a (click)=\"goToBookmark(node)\">\n {{ node.name }}\n </a>\n </div>\n <button\n class=\"bookmark__rename\"\n (click)=\"editBookmark(node.id)\"\n ></button>\n <button\n class=\"bookmark__delete\"\n (click)=\"deleteBookmark2(node)\"\n ></button>\n </div>\n <div class=\"node-drop-slot\"></div>\n </div>\n <ng-template #inputBookmark>\n <input\n #bookmarkName\n class=\"bookmark__input\"\n [value]=\"node.name\"\n [maxLength]=\"BOOKMARK_CHAR_LIMIT\"\n />\n <button\n class=\"bookmark__save\"\n (click)=\"updateBookmark(node, bookmarkName.value)\"\n ></button>\n </ng-template>\n </cdk-nested-tree-node>\n <!-- This is the tree node template for expandable nodes -->\n <cdk-nested-tree-node\n class=\"node-wrapper\"\n *cdkTreeNodeDef=\"let node; when: hasChild\"\n >\n <div *ngIf=\"node.id !== editableBookmark; else inputBookmark2\">\n <div\n class=\"node-content-wrapper nested-tree-node\"\n cdkDrag\n [cdkDragData]=\"node\"\n (mouseenter)=\"dragHover($event, node)\"\n (mouseleave)=\"dragHoverEnd($event, node)\"\n (cdkDragStarted)=\"dragStart()\"\n (cdkDragReleased)=\"dragEnd()\"\n >\n <div class=\"outlineItem\">\n <span\n cdkTreeNodeToggle\n class=\"toggle-children-wrapper\"\n [ngClass]=\"onNodeExpand(node)\"\n ><span class=\"toggle-children\"></span\n ></span>\n <a (click)=\"goToBookmark(node)\">\n {{ node.name }}\n </a>\n </div>\n <button\n class=\"bookmark__rename\"\n (click)=\"editBookmark(node.id)\"\n ></button>\n <button\n class=\"bookmark__delete\"\n (click)=\"deleteBookmark2(node)\"\n ></button>\n </div>\n <div class=\"node-drop-slot\"></div>\n </div>\n <ng-template #inputBookmark2>\n <input\n #bookmarkName\n class=\"bookmark__input\"\n [value]=\"node.name\"\n [maxLength]=\"BOOKMARK_CHAR_LIMIT\"\n />\n <button\n class=\"bookmark__save\"\n (click)=\"updateBookmark(node, bookmarkName.value)\"\n ></button>\n </ng-template>\n <div class=\"nested-tree-node-children\" *ngIf=\"treeControl.isExpanded(node)\">\n <ng-container cdkTreeNodeOutlet></ng-container>\n </div>\n </cdk-nested-tree-node>\n</cdk-tree>\n" }]
|
|
323
343
|
}], ctorParameters: function () { return [{ type: i1.Store }]; }, propDecorators: { bookmarkNodes: [{
|
|
324
344
|
type: Input
|
|
325
345
|
}], zoom: [{
|
|
@@ -329,4 +349,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
|
|
|
329
349
|
}], goToDestination: [{
|
|
330
350
|
type: Output
|
|
331
351
|
}] } });
|
|
332
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bookmarks.component.js","sourceRoot":"","sources":["../../../../../../../../projects/media-viewer/src/lib/viewers/pdf-viewer/side-bar/bookmarks/bookmarks.component.ts","../../../../../../../../projects/media-viewer/src/lib/viewers/pdf-viewer/side-bar/bookmarks/bookmarks.component.html"],"names":[],"mappings":"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","sourcesContent":["import { provideMockActions } from '@ngrx/effects/testing';\nimport { Bookmark } from './../../../../store/models/bookmarks.interface';\nimport { Component, EventEmitter, Input, OnDestroy, OnInit, Output, ViewChild } from '@angular/core';\nimport { select, Store } from '@ngrx/store';\nimport { Subscription, from } from 'rxjs';\n\nimport { CreateBookmark, DeleteBookmark, MoveBookmark, UpdateBookmark } from '../../../../store/actions/bookmark.actions';\nimport * as bookmarksSelectors from '../../../../store/selectors/bookmark.selectors';\nimport { AnnotationSetState } from '../../../../store/reducers/annotations.reducer';\nimport { DocumentPages } from '../../../../store/reducers/document.reducer';\nimport * as fromDocument from '../../../../store/selectors/document.selectors';\nimport * as fromBookmarks from '../../../../store/reducers/bookmarks.reducer';\nimport { getBookmarkChildren } from '../../../../store/bookmarks-store-utils';\nimport { take } from 'rxjs/operators';\nimport uuid from 'uuid';\nimport { ArrayDataSource, SelectionModel } from '@angular/cdk/collections';\nimport { FlatTreeControl, NestedTreeControl } from '@angular/cdk/tree';\nimport { CdkDragDrop } from '@angular/cdk/drag-drop';\n\n@Component({\n  selector: 'mv-bookmarks',\n  templateUrl: './bookmarks.component.html'\n})\n\nexport class BookmarksComponent implements OnInit, OnDestroy {\n\n  @Input()\n  set bookmarkNodes(value: Bookmark[]) {\n    this.rebuildTreeForData(value);\n    if (this._bookmarkNodes && this.sortMode !== this.customSort) {\n      this.sortBookmarks();\n    }\n  };\n\n  get bookmarkNodes() {\n    return this._bookmarkNodes;\n  };\n\n  @Input() zoom: number;\n  @Input() rotate: number;\n  @Output() goToDestination = new EventEmitter<any[]>();\n\n  private _bookmarkNodes: Bookmark[] = [];\n  datasource: ArrayDataSource<Bookmark>;\n  treeControl: FlatTreeControl<Bookmark>;\n  hoveredNode: Bookmark;\n  // expansion model tracks expansion state\n  expansionModel = new SelectionModel<Bookmark>(true);\n  dragging = false;\n  expandTimeout: any;\n  expandDelay = 1000;\n  dragNodeInsertToParent: boolean;\n\n  pageLookup: { [pageId: number]: DocumentPages } = {};\n  editableBookmark: string;\n  BOOKMARK_CHAR_LIMIT = 30;\n\n  dragNode: any;\n  dragNodeExpandOverWaitTimeMs = 300;\n  dragNodeExpandOverNode: any;\n  dragNodeExpandOverTime: number;\n  dragNodeExpandOverArea: number;\n\n  options = {\n    allowDrag: true,\n    allowDrop: true\n  };\n\n  $subscription: Subscription;\n\n  private sortMode: string;\n\n  private readonly _customSort = 'CUSTOM';\n  private readonly _positionSort = 'POSITION';\n\n  constructor(private store: Store<fromBookmarks.BookmarksState | AnnotationSetState>) { }\n\n  ngOnInit(): void {\n    this.sortMode = this.customSort;\n    this.$subscription = this.store.pipe(select(bookmarksSelectors.getEditableBookmark))\n      .subscribe(editableId => this.editableBookmark = editableId);\n    this.$subscription.add(this.store.select(fromDocument.getPages)\n      .subscribe(pages => {\n\n        Object.keys(pages).map(key => {\n          this.pageLookup[key] = pages[key];\n        });\n\n      }));\n  }\n\n  ngOnDestroy(): void {\n    this.$subscription.unsubscribe();\n  }\n\n  editBookmark(id) {\n    this.editableBookmark = id;\n  }\n\n  onAddBookmarkClick() {\n    this.store.pipe(select(bookmarksSelectors.getBookmarkInfo), take(1))\n      .subscribe((bookmarkInfo) => {\n        this.store.dispatch(new CreateBookmark({\n          ...bookmarkInfo, name: '', id: uuid()\n        } as any));\n      });\n  }\n\n  deleteBookmark2(node: Bookmark) {\n    this.customSortBookmarks();\n    let next: Bookmark;\n\n    const changedData = JSON.parse(JSON.stringify(this.bookmarkNodes));\n    const siblings = this.findNodeSiblings(changedData, node.id);\n    if (siblings && siblings.length > node.index + 1) {\n      next = siblings[node.index + 1];\n      next.previous = node.previous;\n    }\n    const toDelete = [node.id, ...getBookmarkChildren(node.children)];\n    this.store.dispatch(new DeleteBookmark({\n      deleted: toDelete, updated: next\n    }));\n  }\n\n  updateBookmark(bookmark: Bookmark, name) {\n    const editedBookmark = {\n      ...bookmark,\n      name\n    };\n    if (name) {\n      this.store.dispatch(new UpdateBookmark(editedBookmark));\n      this.editableBookmark = undefined;\n    }\n  }\n\n  goToBookmark(bookmark: Bookmark) {\n    const thisPage = this.pageLookup[bookmark.pageNumber + 1];\n    const defaultHeight = thisPage.styles.height;\n    const defaultScaleY = this.scaledY(bookmark.yCoordinate, defaultHeight, thisPage);\n\n    let top = 0, left = 0;\n    switch (this.rotate) {\n      case 90:\n        left = - defaultScaleY;\n        break;\n      case 180:\n        top = this.scaledY(bookmark.yCoordinate, (defaultHeight - (24 * this.zoom)), thisPage);\n        break;\n      case 270:\n        left = defaultScaleY;\n        break;\n      default:\n        top = defaultScaleY;\n    }\n\n    this.goToDestination.emit([\n      bookmark.pageNumber,\n      { 'name': 'XYZ' },\n      left,\n      top\n    ]);\n  }\n\n  get customSort() {\n    return this._customSort;\n  }\n\n  get positionSort() {\n    return this._positionSort;\n  }\n\n  sort(mode: string) {\n    this.sortMode = mode;\n    this.sortBookmarks();\n  }\n\n  private sortBookmarks() {\n    switch (this.sortMode) {\n      case this.customSort: {\n        this.customSortBookmarks();\n        break;\n      }\n      case this.positionSort: {\n        this.positionSortBookmarks();\n        break;\n      }\n      default: {\n        this.customSortBookmarks();\n        break;\n      }\n    }\n  }\n\n  private positionSortBookmarks() {\n    this.bookmarkNodes.sort((a, b) => a.pageNumber === b.pageNumber ? a.yCoordinate - b.yCoordinate : a.pageNumber - b.pageNumber);\n    this.rebuildTreeForData(this.bookmarkNodes);\n  }\n\n  private customSortBookmarks() {\n    if (this.bookmarkNodes.length > 1) {\n      this.bookmarkNodes.sort((a, b) => a.index - b.index);\n    }\n    this.rebuildTreeForData(this.bookmarkNodes);\n  }\n\n  private scaledY(yCoordinate: number, height: number, page: DocumentPages): number {\n    const viewportScale = page.viewportScale / this.zoom;\n    return ((height / this.zoom) - yCoordinate) / viewportScale;\n  }\n\n  hasChild = (_: number, node: Bookmark) => {\n    return node.children && node.children.length > 0;\n  }\n\n  getNode(bookmarks, parentId) {\n    if (typeof bookmarks !== 'undefined') {\n      for (let i = 0; i < bookmarks.length; i++) {\n        if (bookmarks[i].id === parentId) {\n          return [bookmarks[i]];\n        }\n        const a = this.getNode(bookmarks[i].children, parentId);\n        if (a !== null) {\n          return a;\n        }\n      }\n    }\n    return null;\n  }\n\n  drop(event: CdkDragDrop<Bookmark>) {\n\n    if (!event.isPointerOverContainer || (event.previousIndex === event.currentIndex)) return;\n\n    const hasMovedUpTheTree = event.previousIndex > event.currentIndex;\n    const changedData = JSON.parse(JSON.stringify(this.bookmarkNodes));\n    const visibleNodes = this.visibleNodes(this._bookmarkNodes);\n    const toNode = visibleNodes[event.currentIndex];\n    const toNodeSiblings = this.findNodeSiblings(changedData, toNode.id);\n\n    const toNodeParent = toNodeSiblings[0].parent;\n    const toIndex = toNodeSiblings.findIndex(s => s.id === toNode.id);\n\n    const fromNode = event.item.data;\n    const fromNodeSiblings = this.findNodeSiblings(changedData, fromNode.id);\n    const fromIndex = fromNodeSiblings.findIndex(n => n.id === fromNode.id);\n\n    if (this.dragNodeInsertToParent) {\n\n      const indexOfParent = toNodeSiblings.findIndex(element => element.id === toNode.id);\n      const parentNode = toNodeSiblings[indexOfParent]\n      const firstChild = parentNode?.children && parentNode?.children.length > 0 ? parentNode.children[0] : null;\n      let movedBookmarksWithParent = [{ ...fromNode, parent: parentNode.id, previous: null }];\n\n      if (firstChild) {\n        movedBookmarksWithParent = [...movedBookmarksWithParent, { ...firstChild, previous: fromNode.id }];\n      }\n\n      let previousSiblingForParentIndex = toIndex - 1;\n      let parentNodeSibling = this.getSiblingFromAllSibliings(fromNodeSiblings, previousSiblingForParentIndex);\n\n      if (parentNodeSibling.id == fromNode.id) {\n        previousSiblingForParentIndex = previousSiblingForParentIndex - 1;\n        if (previousSiblingForParentIndex > 0) {\n          parentNodeSibling = this.getSiblingFromAllSibliings(fromNodeSiblings, previousSiblingForParentIndex);\n        }\n        else {\n          parentNodeSibling = null;\n        }\n      }\n\n      movedBookmarksWithParent = [...movedBookmarksWithParent, { ...parentNode, previous: parentNodeSibling?.id }];\n\n      this.store.dispatch(new MoveBookmark(movedBookmarksWithParent));\n      return;\n    }\n\n    if (!toNodeSiblings) return;\n\n    const fromNodePrevious = hasMovedUpTheTree ? toNode.previous : toNode.id;\n    let movedBookmarks = [{\n      ...fromNode,\n      previous: toNode.index > 0 ? fromNodePrevious : undefined,\n      parent: toNodeParent\n    }];\n\n    let fromNodeSibling = this.getSiblingFromAllSibliings(fromNodeSiblings, fromIndex + 1);\n    fromNodeSibling = fromNodeSibling && fromNodeSibling.id === fromNode.previous ? this.getSiblingFromAllSibliings(fromNodeSiblings, fromIndex + 1) : fromNodeSibling;\n\n    if (fromNodeSibling) {\n      movedBookmarks = [...movedBookmarks, { ...fromNodeSibling, previous: fromNode.previous }];\n    }\n\n\n    let toNodeSiblingIndex = hasMovedUpTheTree ? toIndex : toIndex + 1;\n    let toNodeSibling = this.getSiblingFromAllSibliings(toNodeSiblings, toNodeSiblingIndex);\n\n    if (toNodeSibling) {\n      movedBookmarks = [...movedBookmarks, { ...toNodeSibling, previous: fromNode.id }];\n    }\n\n    const hasDups = (movedBookmarks as Bookmark[]).map(x => x.id).some(function (value, index, array) {                            // .some will break as soon as duplicate found (no need to itterate over all array)\n      return array.indexOf(value) !== array.lastIndexOf(value);   // comparing first and last indexes of the same value\n    })\n    if (hasDups || movedBookmarks && movedBookmarks.length <= 1) return;\n\n    this.store.dispatch(new MoveBookmark(movedBookmarks));\n  }\n\n  private getSiblingFromAllSibliings(sibling: Bookmark[], index) {\n    return sibling.length > index ? sibling[index] : undefined;\n  }\n\n  dragStart() {\n    this.dragNodeInsertToParent = false;\n    this.hoveredNode = null;\n    this.dragging = true;\n  }\n\n  dragEnd() {\n    this.dragging = false;\n  }\n\n  dragHover(event: any, node: Bookmark) {\n    if (this.dragging) {\n      const newEvent: any = event;\n      const percentageX = newEvent.offsetX / newEvent.target.clientWidth;\n      if (percentageX > .55) {\n        this.hoveredNode = node;\n        this.dragNodeInsertToParent = true;\n      } else {\n        this.hoveredNode = null;\n        this.dragNodeInsertToParent = false;\n      }\n      clearTimeout(this.expandTimeout);\n      this.expandTimeout = setTimeout(() => {\n        this.treeControl.expand(node);\n      }, this.expandDelay);\n    }\n  }\n\n  dragHoverEnd(event: any, node: Bookmark) {\n    if (this.dragging) {\n      if (!node || this.hoveredNode?.id !== node.id) {\n        this.dragNodeInsertToParent = false;\n        this.hoveredNode = null;\n      }\n      clearTimeout(this.expandTimeout);\n    }\n  }\n\n  onNodeExpand(node: Bookmark) {\n    const isExpanded = this.treeControl.isExpanded(node);\n    return isExpanded ? \"toggle-children-wrapper-expanded\" : \"toggle-children-wrapper-collapsed\";\n  }\n\n  visibleNodes(bookmarks: Bookmark[]): Bookmark[] {\n    const result = [];\n\n    function addExpandedChildren(node: Bookmark, expanded: Bookmark[]) {\n      result.push(node);\n      if (expanded.some(bookmark => bookmark && bookmark.id === node.id) && node.children) {\n        node.children.map((child) => addExpandedChildren(child, expanded));\n      }\n    }\n    bookmarks.forEach((node) => {\n      addExpandedChildren(node, this.treeControl.expansionModel.selected);\n    });\n    return result;\n  }\n\n  findNodeSiblings(arr: Array<any>, id: string): Array<any> {\n    let result, subResult;\n    arr.forEach((item, i) => {\n      if (item.id === id) {\n        result = arr;\n      } else if (item.children) {\n        subResult = this.findNodeSiblings(item.children, id);\n        if (subResult) result = subResult;\n      }\n    });\n    return result;\n  }\n\n  rebuildTreeForData(data: any) {\n    this._bookmarkNodes = data ?? [];\n    this.datasource = new ArrayDataSource(this._bookmarkNodes);\n    this.treeControl = new NestedTreeControl<Bookmark>(node => node.children);\n    this.treeControl.dataNodes = this._bookmarkNodes;\n    this.expansionModel.selected.forEach((bookmark) => {\n      const node = this.treeControl.dataNodes.find((n) => n.id === bookmark.id);\n      this.treeControl.expand(node);\n    });\n  }\n}\n","<a *ngIf=\"bookmarkNodes?.length === 0\" class=\"highlightedOutlineItem\"\n  >No bookmarks created yet</a\n>\n<cdk-tree\n  cdkDropList\n  class=\"bookmarks-tree\"\n  *ngIf=\"datasource\"\n  [dataSource]=\"datasource\"\n  [treeControl]=\"treeControl\"\n  (cdkDropListDropped)=\"drop($event)\"\n>\n  <!-- This is the tree node template for leaf nodes -->\n  <cdk-nested-tree-node class=\"node-wrapper\" *cdkTreeNodeDef=\"let node\">\n    <div *ngIf=\"node.id !== editableBookmark; else inputBookmark\">\n      <div\n        class=\"node-content-wrapper nested-tree-node\"\n        cdkDrag\n        [cdkDragData]=\"node\"\n        (mouseenter)=\"dragHover($event, node)\"\n        (mouseleave)=\"dragHoverEnd($event, node)\"\n        (cdkDragStarted)=\"dragStart()\"\n        (cdkDragReleased)=\"dragEnd()\"\n      >\n        <div class=\"outlineItem\">\n          <a (click)=\"goToBookmark(node)\">\n            {{ node.name }}\n          </a>\n        </div>\n        <button\n          class=\"bookmark__rename\"\n          (click)=\"editBookmark(node.id)\"\n        ></button>\n        <button\n          class=\"bookmark__delete\"\n          (click)=\"deleteBookmark2(node)\"\n        ></button>\n      </div>\n      <div class=\"node-drop-slot\"></div>\n    </div>\n    <ng-template #inputBookmark>\n      <input\n        #bookmarkName\n        class=\"bookmark__input\"\n        [value]=\"node.name\"\n        [maxLength]=\"BOOKMARK_CHAR_LIMIT\"\n      />\n      <button\n        class=\"bookmark__save\"\n        (click)=\"updateBookmark(node, bookmarkName.value)\"\n      ></button>\n    </ng-template>\n  </cdk-nested-tree-node>\n  <!-- This is the tree node template for expandable nodes -->\n  <cdk-nested-tree-node\n    class=\"node-wrapper\"\n    *cdkTreeNodeDef=\"let node; when: hasChild\"\n  >\n    <div *ngIf=\"node.id !== editableBookmark; else inputBookmark2\">\n      <div\n        class=\"node-content-wrapper nested-tree-node\"\n        cdkDrag\n        [cdkDragData]=\"node\"\n        (mouseenter)=\"dragHover($event, node)\"\n        (mouseleave)=\"dragHoverEnd($event, node)\"\n        (cdkDragStarted)=\"dragStart()\"\n        (cdkDragReleased)=\"dragEnd()\"\n      >\n        <div class=\"outlineItem\">\n          <span\n            cdkTreeNodeToggle\n            class=\"toggle-children-wrapper\"\n            [ngClass]=\"onNodeExpand(node)\"\n            ><span class=\"toggle-children\"></span\n          ></span>\n          <a (click)=\"goToBookmark(node)\">\n            {{ node.name }}\n          </a>\n        </div>\n        <button\n          class=\"bookmark__rename\"\n          (click)=\"editBookmark(node.id)\"\n        ></button>\n        <button\n          class=\"bookmark__delete\"\n          (click)=\"deleteBookmark2(node)\"\n        ></button>\n      </div>\n      <div class=\"node-drop-slot\"></div>\n    </div>\n    <ng-template #inputBookmark2>\n      <input\n        #bookmarkName\n        class=\"bookmark__input\"\n        [value]=\"node.name\"\n        [maxLength]=\"BOOKMARK_CHAR_LIMIT\"\n      />\n      <button\n        class=\"bookmark__save\"\n        (click)=\"updateBookmark(node, bookmarkName.value)\"\n      ></button>\n    </ng-template>\n    <div class=\"nested-tree-node-children\" *ngIf=\"treeControl.isExpanded(node)\">\n      <ng-container cdkTreeNodeOutlet></ng-container>\n    </div>\n  </cdk-nested-tree-node>\n</cdk-tree>\n"]}
|
|
352
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bookmarks.component.js","sourceRoot":"","sources":["../../../../../../../../projects/media-viewer/src/lib/viewers/pdf-viewer/side-bar/bookmarks/bookmarks.component.ts","../../../../../../../../projects/media-viewer/src/lib/viewers/pdf-viewer/side-bar/bookmarks/bookmarks.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Bookmark } from './../../../../store/models/bookmarks.interface';\nimport { Component, EventEmitter, Input, OnDestroy, OnInit, Output, ViewChild } from '@angular/core';\nimport { select, Store } from '@ngrx/store';\nimport { Subscription, from } from 'rxjs';\n\nimport { CreateBookmark, DeleteBookmark, MoveBookmark, UpdateBookmark } from '../../../../store/actions/bookmark.actions';\nimport * as bookmarksSelectors from '../../../../store/selectors/bookmark.selectors';\nimport { AnnotationSetState } from '../../../../store/reducers/annotations.reducer';\nimport { DocumentPages } from '../../../../store/reducers/document.reducer';\nimport * as fromDocument from '../../../../store/selectors/document.selectors';\nimport * as fromBookmarks from '../../../../store/reducers/bookmarks.reducer';\nimport { getBookmarkChildren } from '../../../../store/bookmarks-store-utils';\nimport { take } from 'rxjs/operators';\nimport uuid from 'uuid';\nimport { ArrayDataSource, SelectionModel } from '@angular/cdk/collections';\nimport { FlatTreeControl, NestedTreeControl } from '@angular/cdk/tree';\nimport { CdkDragDrop } from '@angular/cdk/drag-drop';\n\n@Component({\n  selector: 'mv-bookmarks',\n  templateUrl: './bookmarks.component.html'\n})\n\nexport class BookmarksComponent implements OnInit, OnDestroy {\n\n  @Input()\n  set bookmarkNodes(value: Bookmark[]) {\n    this.rebuildTreeForData(value);\n    if (this._bookmarkNodes && this.sortMode !== this.customSort) {\n      this.sortBookmarks();\n    }\n  };\n\n  get bookmarkNodes() {\n    return this._bookmarkNodes;\n  };\n\n  @Input() zoom: number;\n  @Input() rotate: number;\n  @Output() goToDestination = new EventEmitter<any[]>();\n\n  private _bookmarkNodes: Bookmark[] = [];\n  datasource: ArrayDataSource<Bookmark>;\n  treeControl: FlatTreeControl<Bookmark>;\n  hoveredNode: Bookmark;\n  // expansion model tracks expansion state\n  expansionModel = new SelectionModel<Bookmark>(true);\n  isDraggingOn = false;\n  isUserdragging = false;\n  expandTimeout: any;\n  expandDelay = 1000;\n  dragNodeInsertToParent: boolean;\n\n  pageLookup: { [pageId: number]: DocumentPages } = {};\n  editableBookmark: string;\n  BOOKMARK_CHAR_LIMIT = 30;\n\n  dragNode: any;\n  dragNodeExpandOverWaitTimeMs = 300;\n  dragNodeExpandOverNode: any;\n  dragNodeExpandOverTime: number;\n  dragNodeExpandOverArea: number;\n\n  options = {\n    allowDrag: true,\n    allowDrop: true\n  };\n\n  $subscription: Subscription;\n\n  private sortMode: string;\n\n  private readonly _customSort = 'CUSTOM';\n  private readonly _positionSort = 'POSITION';\n\n  constructor(private store: Store<fromBookmarks.BookmarksState | AnnotationSetState>) { }\n\n  ngOnInit(): void {\n    this.sortMode = this.customSort;\n    this.$subscription = this.store.pipe(select(bookmarksSelectors.getEditableBookmark))\n      .subscribe(editableId => this.editableBookmark = editableId);\n    this.$subscription.add(this.store.select(fromDocument.getPages)\n      .subscribe(pages => {\n\n        Object.keys(pages).map(key => {\n          this.pageLookup[key] = pages[key];\n        });\n\n      }));\n  }\n\n  ngOnDestroy(): void {\n    this.$subscription.unsubscribe();\n  }\n\n  editBookmark(id) {\n    this.editableBookmark = id;\n  }\n\n  onAddBookmarkClick() {\n    this.store.pipe(select(bookmarksSelectors.getBookmarkInfo), take(1))\n      .subscribe((bookmarkInfo) => {\n        this.store.dispatch(new CreateBookmark({\n          ...bookmarkInfo, name: '', id: uuid()\n        } as any));\n      });\n  }\n\n  deleteBookmark2(node: Bookmark) {\n    this.customSortBookmarks();\n    let next: Bookmark;\n\n    const changedData = JSON.parse(JSON.stringify(this.bookmarkNodes));\n    const siblings = this.findNodeSiblings(changedData, node.id);\n    if (siblings && siblings.length > node.index + 1) {\n      next = siblings[node.index + 1];\n      next.previous = node.previous;\n    }\n    const toDelete = [node.id, ...getBookmarkChildren(node.children)];\n    this.store.dispatch(new DeleteBookmark({\n      deleted: toDelete, updated: next\n    }));\n  }\n\n  updateBookmark(bookmark: Bookmark, name) {\n    const editedBookmark = {\n      ...bookmark,\n      name\n    };\n    if (name) {\n      this.store.dispatch(new UpdateBookmark(editedBookmark));\n      this.editableBookmark = undefined;\n    }\n  }\n\n  goToBookmark(bookmark: Bookmark) {\n    const thisPage = this.pageLookup[bookmark.pageNumber + 1];\n    const defaultHeight = thisPage.styles.height;\n    const defaultScaleY = this.scaledY(bookmark.yCoordinate, defaultHeight, thisPage);\n\n    let top = 0, left = 0;\n    switch (this.rotate) {\n      case 90:\n        left = - defaultScaleY;\n        break;\n      case 180:\n        top = this.scaledY(bookmark.yCoordinate, (defaultHeight - (24 * this.zoom)), thisPage);\n        break;\n      case 270:\n        left = defaultScaleY;\n        break;\n      default:\n        top = defaultScaleY;\n    }\n\n    this.goToDestination.emit([\n      bookmark.pageNumber,\n      { 'name': 'XYZ' },\n      left,\n      top\n    ]);\n  }\n\n  get customSort() {\n    return this._customSort;\n  }\n\n  get positionSort() {\n    return this._positionSort;\n  }\n\n  sort(mode: string) {\n    this.sortMode = mode;\n    this.sortBookmarks();\n  }\n\n  private sortBookmarks() {\n    switch (this.sortMode) {\n      case this.customSort: {\n        this.customSortBookmarks();\n        break;\n      }\n      case this.positionSort: {\n        this.positionSortBookmarks();\n        break;\n      }\n      default: {\n        this.customSortBookmarks();\n        break;\n      }\n    }\n  }\n\n  private positionSortBookmarks() {\n    this.bookmarkNodes.sort((a, b) => a.pageNumber === b.pageNumber ? a.yCoordinate - b.yCoordinate : a.pageNumber - b.pageNumber);\n    this.isDraggingOn = false;\n    this.rebuildTreeForData(this.bookmarkNodes);\n  }\n\n  private customSortBookmarks() {\n    if (this.bookmarkNodes.length > 1) {\n      this.bookmarkNodes.sort((a, b) => a.index - b.index);\n    }\n    this.isDraggingOn = true;\n    this.rebuildTreeForData(this.bookmarkNodes);\n  }\n\n  private scaledY(yCoordinate: number, height: number, page: DocumentPages): number {\n    const viewportScale = page.viewportScale / this.zoom;\n    return ((height / this.zoom) - yCoordinate) / viewportScale;\n  }\n\n  hasChild = (_: number, node: Bookmark) => {\n    return node.children && node.children.length > 0;\n  }\n\n  getNode(bookmarks, parentId) {\n    if (typeof bookmarks !== 'undefined') {\n      for (let i = 0; i < bookmarks.length; i++) {\n        if (bookmarks[i].id === parentId) {\n          return [bookmarks[i]];\n        }\n        const a = this.getNode(bookmarks[i].children, parentId);\n        if (a !== null) {\n          return a;\n        }\n      }\n    }\n    return null;\n  }\n\n  drop(event: CdkDragDrop<Bookmark>) {\n\n    if (!event.isPointerOverContainer || (event.previousIndex === event.currentIndex)) return;\n\n    const hasMovedUpTheTree = event.previousIndex > event.currentIndex;\n    const bookmarkNodesString = JSON.stringify(this._bookmarkNodes);\n    const changedData = JSON.parse(bookmarkNodesString);\n    const visibleNodes = this.visibleNodes(this._bookmarkNodes);\n    const toNode = visibleNodes[event.currentIndex] as Bookmark;\n    const toNodeSiblings = this.findNodeSiblings(changedData, toNode.id);\n\n    const toNodeParent = toNodeSiblings[0].parent;\n    const toIndex = toNodeSiblings.findIndex(s => s.id === toNode.id);\n\n    const fromNode = event.item.data as Bookmark;\n    const fromNodeSiblings = this.findNodeSiblings(changedData, fromNode.id);\n    const fromIndex = fromNodeSiblings.findIndex(n => n.id === fromNode.id);\n\n    if (this.isToNodeChildOfFromNode(fromNode?.children, toNode)) return;\n\n    if (this.dragNodeInsertToParent) {\n\n      const indexOfParent = toNodeSiblings.findIndex(element => element.id === toNode.id);\n      const parentNode = toNodeSiblings[indexOfParent];\n      const firstChild = parentNode?.children && parentNode?.children.length > 0 ? parentNode.children[0] : null;\n      let movedBookmarksWithParent = [{ ...fromNode, parent: parentNode.id, previous: null }];\n\n      if (firstChild) {\n        movedBookmarksWithParent = [...movedBookmarksWithParent, { ...firstChild, previous: fromNode.id }];\n      }\n\n      let fromNodeSibling = this.getSiblingFromAllSibliings(fromNodeSiblings, fromIndex + 1);\n      const nextFromindexforParent = fromIndex + 1;\n      fromNodeSibling = fromNodeSibling && fromNodeSibling.id === fromNode.previous ? this.getSiblingFromAllSibliings(fromNodeSiblings, nextFromindexforParent + 1) : fromNodeSibling;\n\n      if (fromNodeSibling && fromNodeSibling.id !== parentNode.id) {\n        movedBookmarksWithParent = [...movedBookmarksWithParent, { ...fromNodeSibling, previous: fromNode.previous }];\n      }\n\n      let previousSiblingForParentIndex = toIndex - 1;\n      let parentNodeSibling = this.getSiblingFromAllSibliings(toNodeSiblings, previousSiblingForParentIndex);\n\n      if (parentNodeSibling && parentNodeSibling.id == fromNode.id) {\n        previousSiblingForParentIndex = previousSiblingForParentIndex - 1;\n        if (previousSiblingForParentIndex >= 0) {\n          parentNodeSibling = this.getSiblingFromAllSibliings(toNodeSiblings, previousSiblingForParentIndex);\n        }\n        else {\n          parentNodeSibling = null;\n        }\n      }\n\n      movedBookmarksWithParent = [...movedBookmarksWithParent, { ...parentNode, previous: parentNodeSibling?.id }];\n\n      const hasParentDups = (movedBookmarksWithParent as Bookmark[]).map(x => x.id).some(function (value, index, array) {                            // .some will break as soon as duplicate found (no need to itterate over all array)\n        return array.indexOf(value) !== array.lastIndexOf(value);   // comparing first and last indexes of the same value\n      })\n      if (hasParentDups || movedBookmarksWithParent && movedBookmarksWithParent.length <= 1) return;\n\n      this.store.dispatch(new MoveBookmark(movedBookmarksWithParent));\n      return;\n    }\n\n    if (!toNodeSiblings) return;\n\n    const fromNodePrevious = hasMovedUpTheTree ? toNode.previous : toNode.id;\n    let movedBookmarks = [{\n      ...fromNode,\n      previous: toNode.index > 0 ? fromNodePrevious : undefined,\n      parent: toNodeParent\n    }];\n\n    let fromNodeSibling = this.getSiblingFromAllSibliings(fromNodeSiblings, fromIndex + 1);\n    const nextFromindex = fromIndex + 1;\n    fromNodeSibling = fromNodeSibling && fromNodeSibling.id === fromNode.previous ? this.getSiblingFromAllSibliings(fromNodeSiblings, nextFromindex + 1) : fromNodeSibling;\n\n    if (fromNodeSibling) {\n      movedBookmarks = [...movedBookmarks, { ...fromNodeSibling, previous: fromNode.previous }];\n    }\n\n\n    let toNodeSiblingIndex = hasMovedUpTheTree ? toIndex : toIndex + 1;\n    let toNodeSibling = this.getSiblingFromAllSibliings(toNodeSiblings, toNodeSiblingIndex);\n\n    if (toNodeSibling) {\n      movedBookmarks = [...movedBookmarks, { ...toNodeSibling, previous: fromNode.id }];\n    }\n\n    const hasDups = (movedBookmarks as Bookmark[]).map(x => x.id).some(function (value, index, array) {\n      return array.indexOf(value) !== array.lastIndexOf(value);   // comparing first and last indexes of the same value\n    })\n    if (hasDups || movedBookmarks && movedBookmarks.length <= 1) return;\n\n    this.store.dispatch(new MoveBookmark(movedBookmarks));\n  }\n\n  private getSiblingFromAllSibliings(sibling: Bookmark[], index) {\n    return sibling.length > index ? sibling[index] : undefined;\n  }\n\n  dragStart() {\n    this.dragNodeInsertToParent = false;\n    this.hoveredNode = null;\n    this.isUserdragging = true;\n  }\n\n  dragEnd() {\n    this.isUserdragging = false;\n  }\n\n  dragHover(event: any, node: Bookmark) {\n    if (this.isUserdragging) {\n      const newEvent: any = event;\n      const percentageX = newEvent.offsetX / newEvent.target.clientWidth;\n      if (percentageX > .55) {\n        this.hoveredNode = node;\n        this.dragNodeInsertToParent = true;\n      } else {\n        this.hoveredNode = null;\n        this.dragNodeInsertToParent = false;\n      }\n    }\n  }\n\n  dragHoverEnd(event: any, node: Bookmark) {\n    if (this.isUserdragging) {\n      if (!node || this.hoveredNode?.id !== node.id) {\n        this.dragNodeInsertToParent = false;\n        this.hoveredNode = null;\n      }\n    }\n  }\n\n  onNodeExpand(node: Bookmark) {\n    const isExpanded = this.treeControl.isExpanded(node);\n    return isExpanded ? \"toggle-children-wrapper-expanded\" : \"toggle-children-wrapper-collapsed\";\n  }\n\n  visibleNodes(bookmarks: Bookmark[]): Bookmark[] {\n    const result = [];\n\n    function addExpandedChildren(node: Bookmark, expanded: Bookmark[]) {\n      result.push(node);\n      if (expanded.some(bookmark => bookmark && bookmark.id === node.id) && node.children) {\n        node.children.map((child) => addExpandedChildren(child, expanded));\n      }\n    }\n    bookmarks.forEach((node) => {\n      addExpandedChildren(node, this.treeControl.expansionModel.selected);\n    });\n    return result;\n  }\n\n  findNodeSiblings(arr: Array<any>, id: string): Array<any> {\n    let result, subResult;\n    arr.forEach((item, i) => {\n      if (item.id === id) {\n        result = arr;\n      } else if (item?.children) {\n        subResult = this.findNodeSiblings(item.children, id);\n        if (subResult) result = subResult;\n      }\n    });\n    return result;\n  }\n\n  rebuildTreeForData(data: any) {\n    this._bookmarkNodes = data ?? [];\n    this.datasource = new ArrayDataSource(this._bookmarkNodes);\n    this.treeControl = new NestedTreeControl<Bookmark>(node => node.children);\n    this.treeControl.dataNodes = this._bookmarkNodes;\n    this.expansionModel.selected.forEach((bookmark) => {\n      const node = this.treeControl.dataNodes.find((n) => n.id === bookmark.id);\n      this.treeControl.expand(node);\n    });\n  }\n\n  isToNodeChildOfFromNode(fromNodeChildren: Bookmark[], toNode: Bookmark) {\n\n    if (!fromNodeChildren) {\n      return false;\n    }\n\n    const result = this.getNode(fromNodeChildren, toNode.id);\n    return result ? true : false;\n  }\n}\n","<a *ngIf=\"bookmarkNodes?.length === 0\" class=\"highlightedOutlineItem\"\n  >No bookmarks created yet</a\n>\n<cdk-tree\n  cdkDropList\n  [cdkDropListDisabled]=\"!isDraggingOn\"\n  class=\"bookmarks-tree\"\n  *ngIf=\"datasource\"\n  [dataSource]=\"datasource\"\n  [treeControl]=\"treeControl\"\n  (cdkDropListDropped)=\"drop($event)\"\n>\n  <!-- This is the tree node template for leaf nodes -->\n  <cdk-nested-tree-node class=\"node-wrapper\" *cdkTreeNodeDef=\"let node\">\n    <div *ngIf=\"node.id !== editableBookmark; else inputBookmark\">\n      <div\n        class=\"node-content-wrapper nested-tree-node\"\n        cdkDrag\n        [cdkDragData]=\"node\"\n        (mouseenter)=\"dragHover($event, node)\"\n        (mouseleave)=\"dragHoverEnd($event, node)\"\n        (cdkDragStarted)=\"dragStart()\"\n        (cdkDragReleased)=\"dragEnd()\"\n      >\n        <div class=\"outlineItem\">\n          <a (click)=\"goToBookmark(node)\">\n            {{ node.name }}\n          </a>\n        </div>\n        <button\n          class=\"bookmark__rename\"\n          (click)=\"editBookmark(node.id)\"\n        ></button>\n        <button\n          class=\"bookmark__delete\"\n          (click)=\"deleteBookmark2(node)\"\n        ></button>\n      </div>\n      <div class=\"node-drop-slot\"></div>\n    </div>\n    <ng-template #inputBookmark>\n      <input\n        #bookmarkName\n        class=\"bookmark__input\"\n        [value]=\"node.name\"\n        [maxLength]=\"BOOKMARK_CHAR_LIMIT\"\n      />\n      <button\n        class=\"bookmark__save\"\n        (click)=\"updateBookmark(node, bookmarkName.value)\"\n      ></button>\n    </ng-template>\n  </cdk-nested-tree-node>\n  <!-- This is the tree node template for expandable nodes -->\n  <cdk-nested-tree-node\n    class=\"node-wrapper\"\n    *cdkTreeNodeDef=\"let node; when: hasChild\"\n  >\n    <div *ngIf=\"node.id !== editableBookmark; else inputBookmark2\">\n      <div\n        class=\"node-content-wrapper nested-tree-node\"\n        cdkDrag\n        [cdkDragData]=\"node\"\n        (mouseenter)=\"dragHover($event, node)\"\n        (mouseleave)=\"dragHoverEnd($event, node)\"\n        (cdkDragStarted)=\"dragStart()\"\n        (cdkDragReleased)=\"dragEnd()\"\n      >\n        <div class=\"outlineItem\">\n          <span\n            cdkTreeNodeToggle\n            class=\"toggle-children-wrapper\"\n            [ngClass]=\"onNodeExpand(node)\"\n            ><span class=\"toggle-children\"></span\n          ></span>\n          <a (click)=\"goToBookmark(node)\">\n            {{ node.name }}\n          </a>\n        </div>\n        <button\n          class=\"bookmark__rename\"\n          (click)=\"editBookmark(node.id)\"\n        ></button>\n        <button\n          class=\"bookmark__delete\"\n          (click)=\"deleteBookmark2(node)\"\n        ></button>\n      </div>\n      <div class=\"node-drop-slot\"></div>\n    </div>\n    <ng-template #inputBookmark2>\n      <input\n        #bookmarkName\n        class=\"bookmark__input\"\n        [value]=\"node.name\"\n        [maxLength]=\"BOOKMARK_CHAR_LIMIT\"\n      />\n      <button\n        class=\"bookmark__save\"\n        (click)=\"updateBookmark(node, bookmarkName.value)\"\n      ></button>\n    </ng-template>\n    <div class=\"nested-tree-node-children\" *ngIf=\"treeControl.isExpanded(node)\">\n      <ng-container cdkTreeNodeOutlet></ng-container>\n    </div>\n  </cdk-nested-tree-node>\n</cdk-tree>\n"]}
|
|
@@ -4478,7 +4478,8 @@ class BookmarksComponent {
|
|
|
4478
4478
|
this._bookmarkNodes = [];
|
|
4479
4479
|
// expansion model tracks expansion state
|
|
4480
4480
|
this.expansionModel = new SelectionModel(true);
|
|
4481
|
-
this.
|
|
4481
|
+
this.isDraggingOn = false;
|
|
4482
|
+
this.isUserdragging = false;
|
|
4482
4483
|
this.expandDelay = 1000;
|
|
4483
4484
|
this.pageLookup = {};
|
|
4484
4485
|
this.BOOKMARK_CHAR_LIMIT = 30;
|
|
@@ -4590,12 +4591,14 @@ class BookmarksComponent {
|
|
|
4590
4591
|
}
|
|
4591
4592
|
positionSortBookmarks() {
|
|
4592
4593
|
this.bookmarkNodes.sort((a, b) => a.pageNumber === b.pageNumber ? a.yCoordinate - b.yCoordinate : a.pageNumber - b.pageNumber);
|
|
4594
|
+
this.isDraggingOn = false;
|
|
4593
4595
|
this.rebuildTreeForData(this.bookmarkNodes);
|
|
4594
4596
|
}
|
|
4595
4597
|
customSortBookmarks() {
|
|
4596
4598
|
if (this.bookmarkNodes.length > 1) {
|
|
4597
4599
|
this.bookmarkNodes.sort((a, b) => a.index - b.index);
|
|
4598
4600
|
}
|
|
4601
|
+
this.isDraggingOn = true;
|
|
4599
4602
|
this.rebuildTreeForData(this.bookmarkNodes);
|
|
4600
4603
|
}
|
|
4601
4604
|
scaledY(yCoordinate, height, page) {
|
|
@@ -4620,7 +4623,8 @@ class BookmarksComponent {
|
|
|
4620
4623
|
if (!event.isPointerOverContainer || (event.previousIndex === event.currentIndex))
|
|
4621
4624
|
return;
|
|
4622
4625
|
const hasMovedUpTheTree = event.previousIndex > event.currentIndex;
|
|
4623
|
-
const
|
|
4626
|
+
const bookmarkNodesString = JSON.stringify(this._bookmarkNodes);
|
|
4627
|
+
const changedData = JSON.parse(bookmarkNodesString);
|
|
4624
4628
|
const visibleNodes = this.visibleNodes(this._bookmarkNodes);
|
|
4625
4629
|
const toNode = visibleNodes[event.currentIndex];
|
|
4626
4630
|
const toNodeSiblings = this.findNodeSiblings(changedData, toNode.id);
|
|
@@ -4629,6 +4633,8 @@ class BookmarksComponent {
|
|
|
4629
4633
|
const fromNode = event.item.data;
|
|
4630
4634
|
const fromNodeSiblings = this.findNodeSiblings(changedData, fromNode.id);
|
|
4631
4635
|
const fromIndex = fromNodeSiblings.findIndex(n => n.id === fromNode.id);
|
|
4636
|
+
if (this.isToNodeChildOfFromNode(fromNode === null || fromNode === void 0 ? void 0 : fromNode.children, toNode))
|
|
4637
|
+
return;
|
|
4632
4638
|
if (this.dragNodeInsertToParent) {
|
|
4633
4639
|
const indexOfParent = toNodeSiblings.findIndex(element => element.id === toNode.id);
|
|
4634
4640
|
const parentNode = toNodeSiblings[indexOfParent];
|
|
@@ -4637,18 +4643,29 @@ class BookmarksComponent {
|
|
|
4637
4643
|
if (firstChild) {
|
|
4638
4644
|
movedBookmarksWithParent = [...movedBookmarksWithParent, Object.assign(Object.assign({}, firstChild), { previous: fromNode.id })];
|
|
4639
4645
|
}
|
|
4646
|
+
let fromNodeSibling = this.getSiblingFromAllSibliings(fromNodeSiblings, fromIndex + 1);
|
|
4647
|
+
const nextFromindexforParent = fromIndex + 1;
|
|
4648
|
+
fromNodeSibling = fromNodeSibling && fromNodeSibling.id === fromNode.previous ? this.getSiblingFromAllSibliings(fromNodeSiblings, nextFromindexforParent + 1) : fromNodeSibling;
|
|
4649
|
+
if (fromNodeSibling && fromNodeSibling.id !== parentNode.id) {
|
|
4650
|
+
movedBookmarksWithParent = [...movedBookmarksWithParent, Object.assign(Object.assign({}, fromNodeSibling), { previous: fromNode.previous })];
|
|
4651
|
+
}
|
|
4640
4652
|
let previousSiblingForParentIndex = toIndex - 1;
|
|
4641
|
-
let parentNodeSibling = this.getSiblingFromAllSibliings(
|
|
4642
|
-
if (parentNodeSibling.id == fromNode.id) {
|
|
4653
|
+
let parentNodeSibling = this.getSiblingFromAllSibliings(toNodeSiblings, previousSiblingForParentIndex);
|
|
4654
|
+
if (parentNodeSibling && parentNodeSibling.id == fromNode.id) {
|
|
4643
4655
|
previousSiblingForParentIndex = previousSiblingForParentIndex - 1;
|
|
4644
|
-
if (previousSiblingForParentIndex
|
|
4645
|
-
parentNodeSibling = this.getSiblingFromAllSibliings(
|
|
4656
|
+
if (previousSiblingForParentIndex >= 0) {
|
|
4657
|
+
parentNodeSibling = this.getSiblingFromAllSibliings(toNodeSiblings, previousSiblingForParentIndex);
|
|
4646
4658
|
}
|
|
4647
4659
|
else {
|
|
4648
4660
|
parentNodeSibling = null;
|
|
4649
4661
|
}
|
|
4650
4662
|
}
|
|
4651
4663
|
movedBookmarksWithParent = [...movedBookmarksWithParent, Object.assign(Object.assign({}, parentNode), { previous: parentNodeSibling === null || parentNodeSibling === void 0 ? void 0 : parentNodeSibling.id })];
|
|
4664
|
+
const hasParentDups = movedBookmarksWithParent.map(x => x.id).some(function (value, index, array) {
|
|
4665
|
+
return array.indexOf(value) !== array.lastIndexOf(value); // comparing first and last indexes of the same value
|
|
4666
|
+
});
|
|
4667
|
+
if (hasParentDups || movedBookmarksWithParent && movedBookmarksWithParent.length <= 1)
|
|
4668
|
+
return;
|
|
4652
4669
|
this.store.dispatch(new MoveBookmark(movedBookmarksWithParent));
|
|
4653
4670
|
return;
|
|
4654
4671
|
}
|
|
@@ -4657,7 +4674,8 @@ class BookmarksComponent {
|
|
|
4657
4674
|
const fromNodePrevious = hasMovedUpTheTree ? toNode.previous : toNode.id;
|
|
4658
4675
|
let movedBookmarks = [Object.assign(Object.assign({}, fromNode), { previous: toNode.index > 0 ? fromNodePrevious : undefined, parent: toNodeParent })];
|
|
4659
4676
|
let fromNodeSibling = this.getSiblingFromAllSibliings(fromNodeSiblings, fromIndex + 1);
|
|
4660
|
-
|
|
4677
|
+
const nextFromindex = fromIndex + 1;
|
|
4678
|
+
fromNodeSibling = fromNodeSibling && fromNodeSibling.id === fromNode.previous ? this.getSiblingFromAllSibliings(fromNodeSiblings, nextFromindex + 1) : fromNodeSibling;
|
|
4661
4679
|
if (fromNodeSibling) {
|
|
4662
4680
|
movedBookmarks = [...movedBookmarks, Object.assign(Object.assign({}, fromNodeSibling), { previous: fromNode.previous })];
|
|
4663
4681
|
}
|
|
@@ -4679,13 +4697,13 @@ class BookmarksComponent {
|
|
|
4679
4697
|
dragStart() {
|
|
4680
4698
|
this.dragNodeInsertToParent = false;
|
|
4681
4699
|
this.hoveredNode = null;
|
|
4682
|
-
this.
|
|
4700
|
+
this.isUserdragging = true;
|
|
4683
4701
|
}
|
|
4684
4702
|
dragEnd() {
|
|
4685
|
-
this.
|
|
4703
|
+
this.isUserdragging = false;
|
|
4686
4704
|
}
|
|
4687
4705
|
dragHover(event, node) {
|
|
4688
|
-
if (this.
|
|
4706
|
+
if (this.isUserdragging) {
|
|
4689
4707
|
const newEvent = event;
|
|
4690
4708
|
const percentageX = newEvent.offsetX / newEvent.target.clientWidth;
|
|
4691
4709
|
if (percentageX > .55) {
|
|
@@ -4696,20 +4714,15 @@ class BookmarksComponent {
|
|
|
4696
4714
|
this.hoveredNode = null;
|
|
4697
4715
|
this.dragNodeInsertToParent = false;
|
|
4698
4716
|
}
|
|
4699
|
-
clearTimeout(this.expandTimeout);
|
|
4700
|
-
this.expandTimeout = setTimeout(() => {
|
|
4701
|
-
this.treeControl.expand(node);
|
|
4702
|
-
}, this.expandDelay);
|
|
4703
4717
|
}
|
|
4704
4718
|
}
|
|
4705
4719
|
dragHoverEnd(event, node) {
|
|
4706
4720
|
var _a;
|
|
4707
|
-
if (this.
|
|
4721
|
+
if (this.isUserdragging) {
|
|
4708
4722
|
if (!node || ((_a = this.hoveredNode) === null || _a === void 0 ? void 0 : _a.id) !== node.id) {
|
|
4709
4723
|
this.dragNodeInsertToParent = false;
|
|
4710
4724
|
this.hoveredNode = null;
|
|
4711
4725
|
}
|
|
4712
|
-
clearTimeout(this.expandTimeout);
|
|
4713
4726
|
}
|
|
4714
4727
|
}
|
|
4715
4728
|
onNodeExpand(node) {
|
|
@@ -4735,7 +4748,7 @@ class BookmarksComponent {
|
|
|
4735
4748
|
if (item.id === id) {
|
|
4736
4749
|
result = arr;
|
|
4737
4750
|
}
|
|
4738
|
-
else if (item.children) {
|
|
4751
|
+
else if (item === null || item === void 0 ? void 0 : item.children) {
|
|
4739
4752
|
subResult = this.findNodeSiblings(item.children, id);
|
|
4740
4753
|
if (subResult)
|
|
4741
4754
|
result = subResult;
|
|
@@ -4753,12 +4766,19 @@ class BookmarksComponent {
|
|
|
4753
4766
|
this.treeControl.expand(node);
|
|
4754
4767
|
});
|
|
4755
4768
|
}
|
|
4769
|
+
isToNodeChildOfFromNode(fromNodeChildren, toNode) {
|
|
4770
|
+
if (!fromNodeChildren) {
|
|
4771
|
+
return false;
|
|
4772
|
+
}
|
|
4773
|
+
const result = this.getNode(fromNodeChildren, toNode.id);
|
|
4774
|
+
return result ? true : false;
|
|
4775
|
+
}
|
|
4756
4776
|
}
|
|
4757
4777
|
/** @nocollapse */ BookmarksComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: BookmarksComponent, deps: [{ token: i1.Store }], target: i0.ɵɵFactoryTarget.Component });
|
|
4758
|
-
/** @nocollapse */ BookmarksComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: BookmarksComponent, selector: "mv-bookmarks", inputs: { bookmarkNodes: "bookmarkNodes", zoom: "zoom", rotate: "rotate" }, outputs: { goToDestination: "goToDestination" }, ngImport: i0, template: "<a *ngIf=\"bookmarkNodes?.length === 0\" class=\"highlightedOutlineItem\"\n >No bookmarks created yet</a\n>\n<cdk-tree\n cdkDropList\n class=\"bookmarks-tree\"\n *ngIf=\"datasource\"\n [dataSource]=\"datasource\"\n [treeControl]=\"treeControl\"\n (cdkDropListDropped)=\"drop($event)\"\n>\n <!-- This is the tree node template for leaf nodes -->\n <cdk-nested-tree-node class=\"node-wrapper\" *cdkTreeNodeDef=\"let node\">\n <div *ngIf=\"node.id !== editableBookmark; else inputBookmark\">\n <div\n class=\"node-content-wrapper nested-tree-node\"\n cdkDrag\n [cdkDragData]=\"node\"\n (mouseenter)=\"dragHover($event, node)\"\n (mouseleave)=\"dragHoverEnd($event, node)\"\n (cdkDragStarted)=\"dragStart()\"\n (cdkDragReleased)=\"dragEnd()\"\n >\n <div class=\"outlineItem\">\n <a (click)=\"goToBookmark(node)\">\n {{ node.name }}\n </a>\n </div>\n <button\n class=\"bookmark__rename\"\n (click)=\"editBookmark(node.id)\"\n ></button>\n <button\n class=\"bookmark__delete\"\n (click)=\"deleteBookmark2(node)\"\n ></button>\n </div>\n <div class=\"node-drop-slot\"></div>\n </div>\n <ng-template #inputBookmark>\n <input\n #bookmarkName\n class=\"bookmark__input\"\n [value]=\"node.name\"\n [maxLength]=\"BOOKMARK_CHAR_LIMIT\"\n />\n <button\n class=\"bookmark__save\"\n (click)=\"updateBookmark(node, bookmarkName.value)\"\n ></button>\n </ng-template>\n </cdk-nested-tree-node>\n <!-- This is the tree node template for expandable nodes -->\n <cdk-nested-tree-node\n class=\"node-wrapper\"\n *cdkTreeNodeDef=\"let node; when: hasChild\"\n >\n <div *ngIf=\"node.id !== editableBookmark; else inputBookmark2\">\n <div\n class=\"node-content-wrapper nested-tree-node\"\n cdkDrag\n [cdkDragData]=\"node\"\n (mouseenter)=\"dragHover($event, node)\"\n (mouseleave)=\"dragHoverEnd($event, node)\"\n (cdkDragStarted)=\"dragStart()\"\n (cdkDragReleased)=\"dragEnd()\"\n >\n <div class=\"outlineItem\">\n <span\n cdkTreeNodeToggle\n class=\"toggle-children-wrapper\"\n [ngClass]=\"onNodeExpand(node)\"\n ><span class=\"toggle-children\"></span\n ></span>\n <a (click)=\"goToBookmark(node)\">\n {{ node.name }}\n </a>\n </div>\n <button\n class=\"bookmark__rename\"\n (click)=\"editBookmark(node.id)\"\n ></button>\n <button\n class=\"bookmark__delete\"\n (click)=\"deleteBookmark2(node)\"\n ></button>\n </div>\n <div class=\"node-drop-slot\"></div>\n </div>\n <ng-template #inputBookmark2>\n <input\n #bookmarkName\n class=\"bookmark__input\"\n [value]=\"node.name\"\n [maxLength]=\"BOOKMARK_CHAR_LIMIT\"\n />\n <button\n class=\"bookmark__save\"\n (click)=\"updateBookmark(node, bookmarkName.value)\"\n ></button>\n </ng-template>\n <div class=\"nested-tree-node-children\" *ngIf=\"treeControl.isExpanded(node)\">\n <ng-container cdkTreeNodeOutlet></ng-container>\n </div>\n </cdk-nested-tree-node>\n</cdk-tree>\n", dependencies: [{ kind: "directive", type: i4.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.CdkNestedTreeNode, selector: "cdk-nested-tree-node", inputs: ["role", "disabled", "tabIndex"], exportAs: ["cdkNestedTreeNode"] }, { kind: "directive", type: i3.CdkTreeNodeDef, selector: "[cdkTreeNodeDef]", inputs: ["cdkTreeNodeDefWhen"] }, { kind: "directive", type: i3.CdkTreeNodeToggle, selector: "[cdkTreeNodeToggle]", inputs: ["cdkTreeNodeToggleRecursive"] }, { kind: "component", type: i3.CdkTree, selector: "cdk-tree", inputs: ["dataSource", "treeControl", "trackBy"], exportAs: ["cdkTree"] }, { kind: "directive", type: i3.CdkTreeNodeOutlet, selector: "[cdkTreeNodeOutlet]" }, { kind: "directive", type: i4$3.CdkDropList, selector: "[cdkDropList], cdk-drop-list", inputs: ["cdkDropListConnectedTo", "cdkDropListData", "cdkDropListOrientation", "id", "cdkDropListLockAxis", "cdkDropListDisabled", "cdkDropListSortingDisabled", "cdkDropListEnterPredicate", "cdkDropListSortPredicate", "cdkDropListAutoScrollDisabled", "cdkDropListAutoScrollStep"], outputs: ["cdkDropListDropped", "cdkDropListEntered", "cdkDropListExited", "cdkDropListSorted"], exportAs: ["cdkDropList"] }, { kind: "directive", type: i4$3.CdkDrag, selector: "[cdkDrag]", inputs: ["cdkDragData", "cdkDragLockAxis", "cdkDragRootElement", "cdkDragBoundary", "cdkDragStartDelay", "cdkDragFreeDragPosition", "cdkDragDisabled", "cdkDragConstrainPosition", "cdkDragPreviewClass", "cdkDragPreviewContainer"], outputs: ["cdkDragStarted", "cdkDragReleased", "cdkDragEnded", "cdkDragEntered", "cdkDragExited", "cdkDragDropped", "cdkDragMoved"], exportAs: ["cdkDrag"] }] });
|
|
4778
|
+
/** @nocollapse */ BookmarksComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: BookmarksComponent, selector: "mv-bookmarks", inputs: { bookmarkNodes: "bookmarkNodes", zoom: "zoom", rotate: "rotate" }, outputs: { goToDestination: "goToDestination" }, ngImport: i0, template: "<a *ngIf=\"bookmarkNodes?.length === 0\" class=\"highlightedOutlineItem\"\n >No bookmarks created yet</a\n>\n<cdk-tree\n cdkDropList\n [cdkDropListDisabled]=\"!isDraggingOn\"\n class=\"bookmarks-tree\"\n *ngIf=\"datasource\"\n [dataSource]=\"datasource\"\n [treeControl]=\"treeControl\"\n (cdkDropListDropped)=\"drop($event)\"\n>\n <!-- This is the tree node template for leaf nodes -->\n <cdk-nested-tree-node class=\"node-wrapper\" *cdkTreeNodeDef=\"let node\">\n <div *ngIf=\"node.id !== editableBookmark; else inputBookmark\">\n <div\n class=\"node-content-wrapper nested-tree-node\"\n cdkDrag\n [cdkDragData]=\"node\"\n (mouseenter)=\"dragHover($event, node)\"\n (mouseleave)=\"dragHoverEnd($event, node)\"\n (cdkDragStarted)=\"dragStart()\"\n (cdkDragReleased)=\"dragEnd()\"\n >\n <div class=\"outlineItem\">\n <a (click)=\"goToBookmark(node)\">\n {{ node.name }}\n </a>\n </div>\n <button\n class=\"bookmark__rename\"\n (click)=\"editBookmark(node.id)\"\n ></button>\n <button\n class=\"bookmark__delete\"\n (click)=\"deleteBookmark2(node)\"\n ></button>\n </div>\n <div class=\"node-drop-slot\"></div>\n </div>\n <ng-template #inputBookmark>\n <input\n #bookmarkName\n class=\"bookmark__input\"\n [value]=\"node.name\"\n [maxLength]=\"BOOKMARK_CHAR_LIMIT\"\n />\n <button\n class=\"bookmark__save\"\n (click)=\"updateBookmark(node, bookmarkName.value)\"\n ></button>\n </ng-template>\n </cdk-nested-tree-node>\n <!-- This is the tree node template for expandable nodes -->\n <cdk-nested-tree-node\n class=\"node-wrapper\"\n *cdkTreeNodeDef=\"let node; when: hasChild\"\n >\n <div *ngIf=\"node.id !== editableBookmark; else inputBookmark2\">\n <div\n class=\"node-content-wrapper nested-tree-node\"\n cdkDrag\n [cdkDragData]=\"node\"\n (mouseenter)=\"dragHover($event, node)\"\n (mouseleave)=\"dragHoverEnd($event, node)\"\n (cdkDragStarted)=\"dragStart()\"\n (cdkDragReleased)=\"dragEnd()\"\n >\n <div class=\"outlineItem\">\n <span\n cdkTreeNodeToggle\n class=\"toggle-children-wrapper\"\n [ngClass]=\"onNodeExpand(node)\"\n ><span class=\"toggle-children\"></span\n ></span>\n <a (click)=\"goToBookmark(node)\">\n {{ node.name }}\n </a>\n </div>\n <button\n class=\"bookmark__rename\"\n (click)=\"editBookmark(node.id)\"\n ></button>\n <button\n class=\"bookmark__delete\"\n (click)=\"deleteBookmark2(node)\"\n ></button>\n </div>\n <div class=\"node-drop-slot\"></div>\n </div>\n <ng-template #inputBookmark2>\n <input\n #bookmarkName\n class=\"bookmark__input\"\n [value]=\"node.name\"\n [maxLength]=\"BOOKMARK_CHAR_LIMIT\"\n />\n <button\n class=\"bookmark__save\"\n (click)=\"updateBookmark(node, bookmarkName.value)\"\n ></button>\n </ng-template>\n <div class=\"nested-tree-node-children\" *ngIf=\"treeControl.isExpanded(node)\">\n <ng-container cdkTreeNodeOutlet></ng-container>\n </div>\n </cdk-nested-tree-node>\n</cdk-tree>\n", dependencies: [{ kind: "directive", type: i4.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.CdkNestedTreeNode, selector: "cdk-nested-tree-node", inputs: ["role", "disabled", "tabIndex"], exportAs: ["cdkNestedTreeNode"] }, { kind: "directive", type: i3.CdkTreeNodeDef, selector: "[cdkTreeNodeDef]", inputs: ["cdkTreeNodeDefWhen"] }, { kind: "directive", type: i3.CdkTreeNodeToggle, selector: "[cdkTreeNodeToggle]", inputs: ["cdkTreeNodeToggleRecursive"] }, { kind: "component", type: i3.CdkTree, selector: "cdk-tree", inputs: ["dataSource", "treeControl", "trackBy"], exportAs: ["cdkTree"] }, { kind: "directive", type: i3.CdkTreeNodeOutlet, selector: "[cdkTreeNodeOutlet]" }, { kind: "directive", type: i4$3.CdkDropList, selector: "[cdkDropList], cdk-drop-list", inputs: ["cdkDropListConnectedTo", "cdkDropListData", "cdkDropListOrientation", "id", "cdkDropListLockAxis", "cdkDropListDisabled", "cdkDropListSortingDisabled", "cdkDropListEnterPredicate", "cdkDropListSortPredicate", "cdkDropListAutoScrollDisabled", "cdkDropListAutoScrollStep"], outputs: ["cdkDropListDropped", "cdkDropListEntered", "cdkDropListExited", "cdkDropListSorted"], exportAs: ["cdkDropList"] }, { kind: "directive", type: i4$3.CdkDrag, selector: "[cdkDrag]", inputs: ["cdkDragData", "cdkDragLockAxis", "cdkDragRootElement", "cdkDragBoundary", "cdkDragStartDelay", "cdkDragFreeDragPosition", "cdkDragDisabled", "cdkDragConstrainPosition", "cdkDragPreviewClass", "cdkDragPreviewContainer"], outputs: ["cdkDragStarted", "cdkDragReleased", "cdkDragEnded", "cdkDragEntered", "cdkDragExited", "cdkDragDropped", "cdkDragMoved"], exportAs: ["cdkDrag"] }] });
|
|
4759
4779
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: BookmarksComponent, decorators: [{
|
|
4760
4780
|
type: Component,
|
|
4761
|
-
args: [{ selector: 'mv-bookmarks', template: "<a *ngIf=\"bookmarkNodes?.length === 0\" class=\"highlightedOutlineItem\"\n >No bookmarks created yet</a\n>\n<cdk-tree\n cdkDropList\n class=\"bookmarks-tree\"\n *ngIf=\"datasource\"\n [dataSource]=\"datasource\"\n [treeControl]=\"treeControl\"\n (cdkDropListDropped)=\"drop($event)\"\n>\n <!-- This is the tree node template for leaf nodes -->\n <cdk-nested-tree-node class=\"node-wrapper\" *cdkTreeNodeDef=\"let node\">\n <div *ngIf=\"node.id !== editableBookmark; else inputBookmark\">\n <div\n class=\"node-content-wrapper nested-tree-node\"\n cdkDrag\n [cdkDragData]=\"node\"\n (mouseenter)=\"dragHover($event, node)\"\n (mouseleave)=\"dragHoverEnd($event, node)\"\n (cdkDragStarted)=\"dragStart()\"\n (cdkDragReleased)=\"dragEnd()\"\n >\n <div class=\"outlineItem\">\n <a (click)=\"goToBookmark(node)\">\n {{ node.name }}\n </a>\n </div>\n <button\n class=\"bookmark__rename\"\n (click)=\"editBookmark(node.id)\"\n ></button>\n <button\n class=\"bookmark__delete\"\n (click)=\"deleteBookmark2(node)\"\n ></button>\n </div>\n <div class=\"node-drop-slot\"></div>\n </div>\n <ng-template #inputBookmark>\n <input\n #bookmarkName\n class=\"bookmark__input\"\n [value]=\"node.name\"\n [maxLength]=\"BOOKMARK_CHAR_LIMIT\"\n />\n <button\n class=\"bookmark__save\"\n (click)=\"updateBookmark(node, bookmarkName.value)\"\n ></button>\n </ng-template>\n </cdk-nested-tree-node>\n <!-- This is the tree node template for expandable nodes -->\n <cdk-nested-tree-node\n class=\"node-wrapper\"\n *cdkTreeNodeDef=\"let node; when: hasChild\"\n >\n <div *ngIf=\"node.id !== editableBookmark; else inputBookmark2\">\n <div\n class=\"node-content-wrapper nested-tree-node\"\n cdkDrag\n [cdkDragData]=\"node\"\n (mouseenter)=\"dragHover($event, node)\"\n (mouseleave)=\"dragHoverEnd($event, node)\"\n (cdkDragStarted)=\"dragStart()\"\n (cdkDragReleased)=\"dragEnd()\"\n >\n <div class=\"outlineItem\">\n <span\n cdkTreeNodeToggle\n class=\"toggle-children-wrapper\"\n [ngClass]=\"onNodeExpand(node)\"\n ><span class=\"toggle-children\"></span\n ></span>\n <a (click)=\"goToBookmark(node)\">\n {{ node.name }}\n </a>\n </div>\n <button\n class=\"bookmark__rename\"\n (click)=\"editBookmark(node.id)\"\n ></button>\n <button\n class=\"bookmark__delete\"\n (click)=\"deleteBookmark2(node)\"\n ></button>\n </div>\n <div class=\"node-drop-slot\"></div>\n </div>\n <ng-template #inputBookmark2>\n <input\n #bookmarkName\n class=\"bookmark__input\"\n [value]=\"node.name\"\n [maxLength]=\"BOOKMARK_CHAR_LIMIT\"\n />\n <button\n class=\"bookmark__save\"\n (click)=\"updateBookmark(node, bookmarkName.value)\"\n ></button>\n </ng-template>\n <div class=\"nested-tree-node-children\" *ngIf=\"treeControl.isExpanded(node)\">\n <ng-container cdkTreeNodeOutlet></ng-container>\n </div>\n </cdk-nested-tree-node>\n</cdk-tree>\n" }]
|
|
4781
|
+
args: [{ selector: 'mv-bookmarks', template: "<a *ngIf=\"bookmarkNodes?.length === 0\" class=\"highlightedOutlineItem\"\n >No bookmarks created yet</a\n>\n<cdk-tree\n cdkDropList\n [cdkDropListDisabled]=\"!isDraggingOn\"\n class=\"bookmarks-tree\"\n *ngIf=\"datasource\"\n [dataSource]=\"datasource\"\n [treeControl]=\"treeControl\"\n (cdkDropListDropped)=\"drop($event)\"\n>\n <!-- This is the tree node template for leaf nodes -->\n <cdk-nested-tree-node class=\"node-wrapper\" *cdkTreeNodeDef=\"let node\">\n <div *ngIf=\"node.id !== editableBookmark; else inputBookmark\">\n <div\n class=\"node-content-wrapper nested-tree-node\"\n cdkDrag\n [cdkDragData]=\"node\"\n (mouseenter)=\"dragHover($event, node)\"\n (mouseleave)=\"dragHoverEnd($event, node)\"\n (cdkDragStarted)=\"dragStart()\"\n (cdkDragReleased)=\"dragEnd()\"\n >\n <div class=\"outlineItem\">\n <a (click)=\"goToBookmark(node)\">\n {{ node.name }}\n </a>\n </div>\n <button\n class=\"bookmark__rename\"\n (click)=\"editBookmark(node.id)\"\n ></button>\n <button\n class=\"bookmark__delete\"\n (click)=\"deleteBookmark2(node)\"\n ></button>\n </div>\n <div class=\"node-drop-slot\"></div>\n </div>\n <ng-template #inputBookmark>\n <input\n #bookmarkName\n class=\"bookmark__input\"\n [value]=\"node.name\"\n [maxLength]=\"BOOKMARK_CHAR_LIMIT\"\n />\n <button\n class=\"bookmark__save\"\n (click)=\"updateBookmark(node, bookmarkName.value)\"\n ></button>\n </ng-template>\n </cdk-nested-tree-node>\n <!-- This is the tree node template for expandable nodes -->\n <cdk-nested-tree-node\n class=\"node-wrapper\"\n *cdkTreeNodeDef=\"let node; when: hasChild\"\n >\n <div *ngIf=\"node.id !== editableBookmark; else inputBookmark2\">\n <div\n class=\"node-content-wrapper nested-tree-node\"\n cdkDrag\n [cdkDragData]=\"node\"\n (mouseenter)=\"dragHover($event, node)\"\n (mouseleave)=\"dragHoverEnd($event, node)\"\n (cdkDragStarted)=\"dragStart()\"\n (cdkDragReleased)=\"dragEnd()\"\n >\n <div class=\"outlineItem\">\n <span\n cdkTreeNodeToggle\n class=\"toggle-children-wrapper\"\n [ngClass]=\"onNodeExpand(node)\"\n ><span class=\"toggle-children\"></span\n ></span>\n <a (click)=\"goToBookmark(node)\">\n {{ node.name }}\n </a>\n </div>\n <button\n class=\"bookmark__rename\"\n (click)=\"editBookmark(node.id)\"\n ></button>\n <button\n class=\"bookmark__delete\"\n (click)=\"deleteBookmark2(node)\"\n ></button>\n </div>\n <div class=\"node-drop-slot\"></div>\n </div>\n <ng-template #inputBookmark2>\n <input\n #bookmarkName\n class=\"bookmark__input\"\n [value]=\"node.name\"\n [maxLength]=\"BOOKMARK_CHAR_LIMIT\"\n />\n <button\n class=\"bookmark__save\"\n (click)=\"updateBookmark(node, bookmarkName.value)\"\n ></button>\n </ng-template>\n <div class=\"nested-tree-node-children\" *ngIf=\"treeControl.isExpanded(node)\">\n <ng-container cdkTreeNodeOutlet></ng-container>\n </div>\n </cdk-nested-tree-node>\n</cdk-tree>\n" }]
|
|
4762
4782
|
}], ctorParameters: function () { return [{ type: i1.Store }]; }, propDecorators: { bookmarkNodes: [{
|
|
4763
4783
|
type: Input
|
|
4764
4784
|
}], zoom: [{
|