@deeksha2309/sunbird-collection-editor 8.0.7
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/README.md +24 -0
- package/esm2022/lib/collection-editor-cursor.service.mjs +3 -0
- package/esm2022/lib/collection-editor-library.component.mjs +16 -0
- package/esm2022/lib/collection-editor-library.module.mjs +137 -0
- package/esm2022/lib/components/answer/answer.component.mjs +43 -0
- package/esm2022/lib/components/asset-browser/asset-browser.component.mjs +325 -0
- package/esm2022/lib/components/asset-browser/asset-browser.data.mjs +53 -0
- package/esm2022/lib/components/assign-page-number/assign-page-number.component.mjs +191 -0
- package/esm2022/lib/components/ckeditor-tool/ckeditor-tool.component.mjs +895 -0
- package/esm2022/lib/components/collection-icon/collection-icon.component.mjs +43 -0
- package/esm2022/lib/components/contentplayer-page/contentplayer-page.component.mjs +351 -0
- package/esm2022/lib/components/csv-upload/csv-upload.component.mjs +178 -0
- package/esm2022/lib/components/dialcode/dialcode.component.mjs +182 -0
- package/esm2022/lib/components/editor/editor.component.mjs +1125 -0
- package/esm2022/lib/components/fancy-tree/fancy-tree.component.mjs +529 -0
- package/esm2022/lib/components/header/header.component.mjs +123 -0
- package/esm2022/lib/components/library/library.component.mjs +242 -0
- package/esm2022/lib/components/library-filter/library-filter.component.mjs +149 -0
- package/esm2022/lib/components/library-list/library-list.component.mjs +92 -0
- package/esm2022/lib/components/library-player/library-player.component.mjs +62 -0
- package/esm2022/lib/components/manage-collaborator/manage-collaborator.component.mjs +256 -0
- package/esm2022/lib/components/meta-form/meta-form.component.mjs +377 -0
- package/esm2022/lib/components/options/options.component.mjs +144 -0
- package/esm2022/lib/components/plain-tree/plain-tree.component.mjs +125 -0
- package/esm2022/lib/components/progress-status/progress-status.component.mjs +46 -0
- package/esm2022/lib/components/publish-checklist/publish-checklist.component.mjs +67 -0
- package/esm2022/lib/components/quality-params-modal/quality-params-modal.component.mjs +52 -0
- package/esm2022/lib/components/question/question.component.mjs +1360 -0
- package/esm2022/lib/components/quml-player/quml-player.component.mjs +73 -0
- package/esm2022/lib/components/qumlplayer-page/qumlplayer-page.component.mjs +84 -0
- package/esm2022/lib/components/resource-reorder/resource-reorder.component.mjs +143 -0
- package/esm2022/lib/components/skeleton-loader/skeleton-loader.component.mjs +26 -0
- package/esm2022/lib/components/template/template.component.mjs +42 -0
- package/esm2022/lib/components/term-and-condition/term-and-condition.component.mjs +68 -0
- package/esm2022/lib/directives/telemetry-interact/telemetry-interact.directive.mjs +33 -0
- package/esm2022/lib/interfaces/McqForm.mjs +29 -0
- package/esm2022/lib/interfaces/editor.mjs +2 -0
- package/esm2022/lib/interfaces/framework.mjs +2 -0
- package/esm2022/lib/interfaces/httpOptions.mjs +2 -0
- package/esm2022/lib/interfaces/requestParam.mjs +2 -0
- package/esm2022/lib/interfaces/serverResponse.mjs +2 -0
- package/esm2022/lib/pipes/sanitize-html.pipe.mjs +20 -0
- package/esm2022/lib/services/config/category.config.json +8 -0
- package/esm2022/lib/services/config/config.service.mjs +27 -0
- package/esm2022/lib/services/config/editor.config.json +31 -0
- package/esm2022/lib/services/config/label.config.json +314 -0
- package/esm2022/lib/services/config/player.config.json +96 -0
- package/esm2022/lib/services/config/url.config.json +69 -0
- package/esm2022/lib/services/data/data.service.mjs +192 -0
- package/esm2022/lib/services/dialcode/dialcode.service.mjs +309 -0
- package/esm2022/lib/services/editor/editor.service.mjs +682 -0
- package/esm2022/lib/services/framework/framework.service.mjs +106 -0
- package/esm2022/lib/services/helper/helper.service.mjs +160 -0
- package/esm2022/lib/services/player/player.service.mjs +99 -0
- package/esm2022/lib/services/public-data/public-data.service.mjs +21 -0
- package/esm2022/lib/services/question/question.service.mjs +167 -0
- package/esm2022/lib/services/telemetry/telemetry.service.mjs +120 -0
- package/esm2022/lib/services/toaster/toaster.service.mjs +105 -0
- package/esm2022/lib/services/tree/tree.service.mjs +284 -0
- package/esm2022/project-sunbird-sunbird-collection-editor.mjs +5 -0
- package/esm2022/public-api.mjs +4 -0
- package/fesm2022/project-sunbird-sunbird-collection-editor.mjs +10138 -0
- package/fesm2022/project-sunbird-sunbird-collection-editor.mjs.map +1 -0
- package/index.d.ts +6 -0
- package/lib/assets/.gitkeep +0 -0
- package/lib/assets/images/MCQ.png +0 -0
- package/lib/assets/images/Spin.gif +0 -0
- package/lib/assets/images/bulkuploadfile.png +0 -0
- package/lib/assets/images/cancel-sign copy.png +0 -0
- package/lib/assets/images/cancel-sign.png +0 -0
- package/lib/assets/images/emptyResult.svg +1 -0
- package/lib/assets/images/icons-rtl.gif +0 -0
- package/lib/assets/images/icons.gif +0 -0
- package/lib/assets/images/imageicon.svg +16 -0
- package/lib/assets/images/imageicon_blue.svg +16 -0
- package/lib/assets/images/layoutoneicon.svg +16 -0
- package/lib/assets/images/layoutoneicon_blue.svg +16 -0
- package/lib/assets/images/layoutthreeicon.svg +18 -0
- package/lib/assets/images/layoutthreeicon_blue.svg +18 -0
- package/lib/assets/images/layouttwoicon.svg +18 -0
- package/lib/assets/images/layouttwoicon_blue.svg +18 -0
- package/lib/assets/images/leftalignicon.svg +17 -0
- package/lib/assets/images/leftalignicon_blue.svg +17 -0
- package/lib/assets/images/loader.gif +0 -0
- package/lib/assets/images/loader.svg +1 -0
- package/lib/assets/images/loading.gif +0 -0
- package/lib/assets/images/middlealignicon.svg +17 -0
- package/lib/assets/images/middlealignicon_blue.svg +17 -0
- package/lib/assets/images/question_collection.svg +18 -0
- package/lib/assets/images/rightalignicon.svg +17 -0
- package/lib/assets/images/rightalignicon_blue.svg +17 -0
- package/lib/assets/images/vline-rtl.gif +0 -0
- package/lib/assets/images/vline.gif +0 -0
- package/lib/assets/images/writing.png +0 -0
- package/lib/collection-editor-cursor.service.d.ts +5 -0
- package/lib/collection-editor-cursor.service.d.ts.map +1 -0
- package/lib/collection-editor-library.component.d.ts +9 -0
- package/lib/collection-editor-library.component.d.ts.map +1 -0
- package/lib/collection-editor-library.module.d.ts +50 -0
- package/lib/collection-editor-library.module.d.ts.map +1 -0
- package/lib/components/answer/answer.component.d.ts +24 -0
- package/lib/components/answer/answer.component.d.ts.map +1 -0
- package/lib/components/asset-browser/asset-browser.component.d.ts +81 -0
- package/lib/components/asset-browser/asset-browser.component.d.ts.map +1 -0
- package/lib/components/asset-browser/asset-browser.data.d.ts +52 -0
- package/lib/components/asset-browser/asset-browser.data.d.ts.map +1 -0
- package/lib/components/assign-page-number/assign-page-number.component.d.ts +38 -0
- package/lib/components/assign-page-number/assign-page-number.component.d.ts.map +1 -0
- package/lib/components/ckeditor-tool/ckeditor-tool.component.d.ts +161 -0
- package/lib/components/ckeditor-tool/ckeditor-tool.component.d.ts.map +1 -0
- package/lib/components/collection-icon/collection-icon.component.d.ts +18 -0
- package/lib/components/collection-icon/collection-icon.component.d.ts.map +1 -0
- package/lib/components/contentplayer-page/contentplayer-page.component.d.ts +54 -0
- package/lib/components/contentplayer-page/contentplayer-page.component.d.ts.map +1 -0
- package/lib/components/csv-upload/csv-upload.component.d.ts +42 -0
- package/lib/components/csv-upload/csv-upload.component.d.ts.map +1 -0
- package/lib/components/dialcode/dialcode.component.d.ts +48 -0
- package/lib/components/dialcode/dialcode.component.d.ts.map +1 -0
- package/lib/components/editor/editor.component.d.ts +146 -0
- package/lib/components/editor/editor.component.d.ts.map +1 -0
- package/lib/components/fancy-tree/fancy-tree.component.d.ts +77 -0
- package/lib/components/fancy-tree/fancy-tree.component.d.ts.map +1 -0
- package/lib/components/header/header.component.d.ts +46 -0
- package/lib/components/header/header.component.d.ts.map +1 -0
- package/lib/components/library/library.component.d.ts +69 -0
- package/lib/components/library/library.component.d.ts.map +1 -0
- package/lib/components/library-filter/library-filter.component.d.ts +47 -0
- package/lib/components/library-filter/library-filter.component.d.ts.map +1 -0
- package/lib/components/library-list/library-list.component.d.ts +32 -0
- package/lib/components/library-list/library-list.component.d.ts.map +1 -0
- package/lib/components/library-player/library-player.component.d.ts +24 -0
- package/lib/components/library-player/library-player.component.d.ts.map +1 -0
- package/lib/components/manage-collaborator/manage-collaborator.component.d.ts +75 -0
- package/lib/components/manage-collaborator/manage-collaborator.component.d.ts.map +1 -0
- package/lib/components/meta-form/meta-form.component.d.ts +51 -0
- package/lib/components/meta-form/meta-form.component.d.ts.map +1 -0
- package/lib/components/options/options.component.d.ts +53 -0
- package/lib/components/options/options.component.d.ts.map +1 -0
- package/lib/components/plain-tree/plain-tree.component.d.ts +20 -0
- package/lib/components/plain-tree/plain-tree.component.d.ts.map +1 -0
- package/lib/components/progress-status/progress-status.component.d.ts +25 -0
- package/lib/components/progress-status/progress-status.component.d.ts.map +1 -0
- package/lib/components/publish-checklist/publish-checklist.component.d.ts +23 -0
- package/lib/components/publish-checklist/publish-checklist.component.d.ts.map +1 -0
- package/lib/components/quality-params-modal/quality-params-modal.component.d.ts +24 -0
- package/lib/components/quality-params-modal/quality-params-modal.component.d.ts.map +1 -0
- package/lib/components/question/question.component.d.ts +215 -0
- package/lib/components/question/question.component.d.ts.map +1 -0
- package/lib/components/quml-player/quml-player.component.d.ts +26 -0
- package/lib/components/quml-player/quml-player.component.d.ts.map +1 -0
- package/lib/components/qumlplayer-page/qumlplayer-page.component.d.ts +31 -0
- package/lib/components/qumlplayer-page/qumlplayer-page.component.d.ts.map +1 -0
- package/lib/components/resource-reorder/resource-reorder.component.d.ts +45 -0
- package/lib/components/resource-reorder/resource-reorder.component.d.ts.map +1 -0
- package/lib/components/skeleton-loader/skeleton-loader.component.d.ts +13 -0
- package/lib/components/skeleton-loader/skeleton-loader.component.d.ts.map +1 -0
- package/lib/components/template/template.component.d.ts +21 -0
- package/lib/components/template/template.component.d.ts.map +1 -0
- package/lib/components/term-and-condition/term-and-condition.component.d.ts +26 -0
- package/lib/components/term-and-condition/term-and-condition.component.d.ts.map +1 -0
- package/lib/directives/telemetry-interact/telemetry-interact.directive.d.ts +27 -0
- package/lib/directives/telemetry-interact/telemetry-interact.directive.d.ts.map +1 -0
- package/lib/interfaces/McqForm.d.ts +32 -0
- package/lib/interfaces/McqForm.d.ts.map +1 -0
- package/lib/interfaces/editor.d.ts +78 -0
- package/lib/interfaces/editor.d.ts.map +1 -0
- package/lib/interfaces/framework.d.ts +46 -0
- package/lib/interfaces/framework.d.ts.map +1 -0
- package/lib/interfaces/httpOptions.d.ts +35 -0
- package/lib/interfaces/httpOptions.d.ts.map +1 -0
- package/lib/interfaces/requestParam.d.ts +24 -0
- package/lib/interfaces/requestParam.d.ts.map +1 -0
- package/lib/interfaces/serverResponse.d.ts +38 -0
- package/lib/interfaces/serverResponse.d.ts.map +1 -0
- package/lib/pipes/sanitize-html.pipe.d.ts +11 -0
- package/lib/pipes/sanitize-html.pipe.d.ts.map +1 -0
- package/lib/services/config/config.service.d.ts +13 -0
- package/lib/services/config/config.service.d.ts.map +1 -0
- package/lib/services/data/data.service.d.ts +85 -0
- package/lib/services/data/data.service.d.ts.map +1 -0
- package/lib/services/dialcode/dialcode.service.d.ts +36 -0
- package/lib/services/dialcode/dialcode.service.d.ts.map +1 -0
- package/lib/services/editor/editor.service.d.ts +150 -0
- package/lib/services/editor/editor.service.d.ts.map +1 -0
- package/lib/services/framework/framework.service.d.ts +35 -0
- package/lib/services/framework/framework.service.d.ts.map +1 -0
- package/lib/services/helper/helper.service.d.ts +41 -0
- package/lib/services/helper/helper.service.d.ts.map +1 -0
- package/lib/services/player/player.service.d.ts +33 -0
- package/lib/services/player/player.service.d.ts.map +1 -0
- package/lib/services/public-data/public-data.service.d.ts +15 -0
- package/lib/services/public-data/public-data.service.d.ts.map +1 -0
- package/lib/services/question/question.service.d.ts +30 -0
- package/lib/services/question/question.service.d.ts.map +1 -0
- package/lib/services/telemetry/telemetry.service.d.ts +45 -0
- package/lib/services/telemetry/telemetry.service.d.ts.map +1 -0
- package/lib/services/toaster/toaster.service.d.ts +50 -0
- package/lib/services/toaster/toaster.service.d.ts.map +1 -0
- package/lib/services/tree/tree.service.d.ts +51 -0
- package/lib/services/tree/tree.service.d.ts.map +1 -0
- package/package.json +32 -0
- package/project-sunbird-sunbird-collection-editor.d.ts.map +1 -0
- package/public-api.d.ts +4 -0
- package/public-api.d.ts.map +1 -0
|
@@ -0,0 +1,529 @@
|
|
|
1
|
+
import { Component, Input, ViewChild, Output, EventEmitter, ViewEncapsulation } from '@angular/core';
|
|
2
|
+
import 'jquery.fancytree';
|
|
3
|
+
import * as _ from 'lodash-es';
|
|
4
|
+
import { Subject } from 'rxjs';
|
|
5
|
+
import { v4 as uuidv4 } from 'uuid';
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
import * as i1 from "../../services/tree/tree.service";
|
|
8
|
+
import * as i2 from "../../services/editor/editor.service";
|
|
9
|
+
import * as i3 from "../../services/telemetry/telemetry.service";
|
|
10
|
+
import * as i4 from "../../services/helper/helper.service";
|
|
11
|
+
import * as i5 from "../../services/toaster/toaster.service";
|
|
12
|
+
import * as i6 from "../../services/config/config.service";
|
|
13
|
+
import * as i7 from "../../services/dialcode/dialcode.service";
|
|
14
|
+
import * as i8 from "@angular/common";
|
|
15
|
+
import * as i9 from "../../directives/telemetry-interact/telemetry-interact.directive";
|
|
16
|
+
export class FancyTreeComponent {
|
|
17
|
+
constructor(treeService, editorService, telemetryService, helperService, toasterService, cdr, configService, dialcodeService) {
|
|
18
|
+
this.treeService = treeService;
|
|
19
|
+
this.editorService = editorService;
|
|
20
|
+
this.telemetryService = telemetryService;
|
|
21
|
+
this.helperService = helperService;
|
|
22
|
+
this.toasterService = toasterService;
|
|
23
|
+
this.cdr = cdr;
|
|
24
|
+
this.configService = configService;
|
|
25
|
+
this.dialcodeService = dialcodeService;
|
|
26
|
+
this.treeEventEmitter = new EventEmitter();
|
|
27
|
+
this.showLibraryButton = false;
|
|
28
|
+
this.rootMenuTemplate = `<span class="ui dropdown sb-dotted-dropdown" autoclose="itemClick" suidropdown="" tabindex="0">
|
|
29
|
+
<span id="contextMenu" class="p-0 w-auto"><i class="icon ellipsis vertical sb-color-black"></i></span>
|
|
30
|
+
<span id= "contextMenuDropDown" class="menu transition hidden" suidropdownmenu="" style="">
|
|
31
|
+
<div id="addchild" class="item">Add Child</div>
|
|
32
|
+
</span>
|
|
33
|
+
</span>`;
|
|
34
|
+
this.folderMenuTemplate = `<span id= "removeNodeIcon"> <i class="fa fa-trash-o" type="button"></i> </span><span class="ui dropdown sb-dotted-dropdown" autoclose="itemClick" suidropdown="" tabindex="0">
|
|
35
|
+
<span id="contextMenu" class="p-0 w-auto"><i class="icon ellipsis vertical sb-color-black"></i></span>
|
|
36
|
+
<span id= "contextMenuDropDown" class="menu transition hidden" suidropdownmenu="" style="">
|
|
37
|
+
<div id="addsibling" class="item">Add Sibling</div>
|
|
38
|
+
<div id="addchild" class="item">Add Child</div>
|
|
39
|
+
<div id="delete" class="item">Delete</div>
|
|
40
|
+
</span>
|
|
41
|
+
</span>`;
|
|
42
|
+
// tslint:disable-next-line:max-line-length
|
|
43
|
+
this.contentMenuTemplate = `<span id="contextMenu"><span id= "removeNodeIcon" type="content" > <i class="fa fa-trash-o" type="button"></i> </span></span>`;
|
|
44
|
+
this.onComponentDestroy$ = new Subject();
|
|
45
|
+
}
|
|
46
|
+
ngOnInit() {
|
|
47
|
+
this.config = _.cloneDeep(this.editorService.editorConfig.config);
|
|
48
|
+
this.config.mode = _.get(this.config, 'mode').toLowerCase();
|
|
49
|
+
if (!_.has(this.config, 'maxDepth')) { // TODO:: rethink this
|
|
50
|
+
this.config.maxDepth = 4;
|
|
51
|
+
}
|
|
52
|
+
this.initialize();
|
|
53
|
+
this.editorService.bulkUploadStatus$.subscribe(status => {
|
|
54
|
+
this.bulkUploadProcessingStatus = status;
|
|
55
|
+
});
|
|
56
|
+
}
|
|
57
|
+
ngAfterViewInit() {
|
|
58
|
+
this.renderTree(this.getTreeConfig());
|
|
59
|
+
}
|
|
60
|
+
initialize() {
|
|
61
|
+
const data = this.nodes.data;
|
|
62
|
+
this.nodeParentDependentMap = this.editorService.getParentDependentMap(this.nodes.data);
|
|
63
|
+
let treeData;
|
|
64
|
+
if (_.get(this.editorService, 'editorConfig.config.renderTaxonomy') === true && _.isEmpty(_.get(this.nodes, 'data.children'))) {
|
|
65
|
+
this.helperService.addDepthToHierarchy(this.nodes.data.children);
|
|
66
|
+
this.nodes.data.children = this.removeIntermediateLevelsFromFramework(this.nodes.data.children);
|
|
67
|
+
treeData = this.buildTreeFromFramework(this.nodes.data);
|
|
68
|
+
}
|
|
69
|
+
else {
|
|
70
|
+
treeData = this.buildTree(this.nodes.data);
|
|
71
|
+
}
|
|
72
|
+
this.editorService.treeData = treeData;
|
|
73
|
+
this.rootNode = [{
|
|
74
|
+
id: data.identifier || uuidv4(),
|
|
75
|
+
title: data.name,
|
|
76
|
+
tooltip: data.name,
|
|
77
|
+
...(data.contentType && { contentType: data.contentType }),
|
|
78
|
+
primaryCategory: data.primaryCategory,
|
|
79
|
+
objectType: data.objectType,
|
|
80
|
+
metadata: _.omit(data, ['children', 'collections']),
|
|
81
|
+
folder: true,
|
|
82
|
+
children: treeData,
|
|
83
|
+
root: true,
|
|
84
|
+
icon: _.get(this.config, 'iconClass')
|
|
85
|
+
}];
|
|
86
|
+
}
|
|
87
|
+
buildTreeFromFramework(data, tree, level) {
|
|
88
|
+
tree = tree || [];
|
|
89
|
+
if (data.children) {
|
|
90
|
+
data.children = _.sortBy(data.children, ['index']);
|
|
91
|
+
}
|
|
92
|
+
_.forEach(data.children, (child) => {
|
|
93
|
+
const childTree = [];
|
|
94
|
+
tree.push({
|
|
95
|
+
id: uuidv4(),
|
|
96
|
+
title: child.name,
|
|
97
|
+
tooltip: child.name,
|
|
98
|
+
primaryCategory: child.primaryCategory,
|
|
99
|
+
metadata: _.omit(child, ['children', 'collections']),
|
|
100
|
+
folder: true,
|
|
101
|
+
children: childTree,
|
|
102
|
+
root: false,
|
|
103
|
+
icon: 'fa fa-folder-o'
|
|
104
|
+
});
|
|
105
|
+
if (child.children) {
|
|
106
|
+
this.buildTreeFromFramework(child, childTree);
|
|
107
|
+
}
|
|
108
|
+
});
|
|
109
|
+
return tree;
|
|
110
|
+
}
|
|
111
|
+
removeIntermediateLevelsFromFramework(data, parentData) {
|
|
112
|
+
const tree = [];
|
|
113
|
+
_.forEach(data, child => {
|
|
114
|
+
if (child.depth === 0 || child.depth === this.helperService.treeDepth) {
|
|
115
|
+
const node = {
|
|
116
|
+
..._.omit(child, ['children']),
|
|
117
|
+
...(child.children && { children: this.removeIntermediateLevelsFromFramework(child.children, child) })
|
|
118
|
+
};
|
|
119
|
+
tree.push(node);
|
|
120
|
+
}
|
|
121
|
+
else if ((child.depth !== 0 || child.depth !== this.helperService.treeDepth)) {
|
|
122
|
+
parentData.children = _.filter(parentData.children, item => (item.depth === 0 || item.depth === this.helperService.treeDepth));
|
|
123
|
+
if (child.children && child.children.length > 0) {
|
|
124
|
+
const children = this.removeIntermediateLevelsFromFramework(child.children, child);
|
|
125
|
+
parentData.children = _.concat(parentData.children, children);
|
|
126
|
+
}
|
|
127
|
+
else {
|
|
128
|
+
parentData.children = _.concat(parentData.children, child.children);
|
|
129
|
+
}
|
|
130
|
+
}
|
|
131
|
+
});
|
|
132
|
+
return !_.isEmpty(tree) ? tree : _.flatten(parentData.children);
|
|
133
|
+
}
|
|
134
|
+
buildTree(data, tree, level) {
|
|
135
|
+
tree = tree || [];
|
|
136
|
+
if (data.children) {
|
|
137
|
+
data.children = _.sortBy(data.children, ['index']);
|
|
138
|
+
}
|
|
139
|
+
data.level = level ? (level + 1) : 1;
|
|
140
|
+
_.forEach(data.children, (child) => {
|
|
141
|
+
const childTree = [];
|
|
142
|
+
tree.push({
|
|
143
|
+
id: child.identifier || uuidv4(),
|
|
144
|
+
title: child.name,
|
|
145
|
+
tooltip: child.name,
|
|
146
|
+
...(child.contentType && { contentType: child.contentType }),
|
|
147
|
+
primaryCategory: child.primaryCategory,
|
|
148
|
+
objectType: child.objectType,
|
|
149
|
+
metadata: _.omit(child, ['children', 'collections']),
|
|
150
|
+
folder: this.isFolder(child),
|
|
151
|
+
children: childTree,
|
|
152
|
+
root: false,
|
|
153
|
+
icon: this.getIconClass(child, data.level)
|
|
154
|
+
});
|
|
155
|
+
if (child.visibility === 'Parent') {
|
|
156
|
+
this.buildTree(child, childTree, data.level);
|
|
157
|
+
}
|
|
158
|
+
});
|
|
159
|
+
return tree;
|
|
160
|
+
}
|
|
161
|
+
isFolder(child) {
|
|
162
|
+
if (this.isContent(child)) {
|
|
163
|
+
return false;
|
|
164
|
+
}
|
|
165
|
+
else {
|
|
166
|
+
return child.visibility === 'Parent' ? true : false;
|
|
167
|
+
}
|
|
168
|
+
}
|
|
169
|
+
getIconClass(child, level) {
|
|
170
|
+
if (this.isContent(child)) {
|
|
171
|
+
return 'fa fa-file-o';
|
|
172
|
+
}
|
|
173
|
+
else if (child.visibility === 'Parent') {
|
|
174
|
+
return _.get(this.config, `hierarchy.level.${level}.iconClass`) || 'fa fa-folder-o';
|
|
175
|
+
}
|
|
176
|
+
else {
|
|
177
|
+
return 'fa fa-file-o';
|
|
178
|
+
}
|
|
179
|
+
}
|
|
180
|
+
isContent(child) {
|
|
181
|
+
// tslint:disable-next-line:max-line-length
|
|
182
|
+
return (_.get(this.config, 'objectType') === 'QuestionSet' && child.objectType === 'Question');
|
|
183
|
+
}
|
|
184
|
+
renderTree(options) {
|
|
185
|
+
options = { ...options, ...this.options };
|
|
186
|
+
$(this.tree.nativeElement).fancytree(options);
|
|
187
|
+
this.treeService.setTreeElement(this.tree.nativeElement);
|
|
188
|
+
if (this.options.showConnectors) {
|
|
189
|
+
$('.fancytree-container').addClass('fancytree-connectors');
|
|
190
|
+
}
|
|
191
|
+
setTimeout(() => {
|
|
192
|
+
this.treeService.reloadTree(this.rootNode);
|
|
193
|
+
this.treeService.setActiveNode();
|
|
194
|
+
const rootNode = this.treeService.getFirstChild();
|
|
195
|
+
rootNode.setExpanded(true);
|
|
196
|
+
this.eachNodeActionButton(rootNode);
|
|
197
|
+
this.dialcodeService.readExistingQrCode();
|
|
198
|
+
});
|
|
199
|
+
if (_.get(this.editorService, 'editorConfig.config.renderTaxonomy') === true && _.isEmpty(_.get(this.nodes, 'data.children'))) {
|
|
200
|
+
_.forEach(this.rootNode[0]?.children, (child) => {
|
|
201
|
+
this.treeService.updateTreeNodeMetadata(child.metadata, child.id, child.primaryCategory, child.objectType);
|
|
202
|
+
_.forEach(child.children, (el) => {
|
|
203
|
+
this.treeService.updateTreeNodeMetadata(el.metadata, el.id, el.primaryCategory, el.objectType);
|
|
204
|
+
});
|
|
205
|
+
});
|
|
206
|
+
}
|
|
207
|
+
}
|
|
208
|
+
getTreeConfig() {
|
|
209
|
+
const options = {
|
|
210
|
+
extensions: ['glyph', 'dnd5'],
|
|
211
|
+
clickFolderMode: 3,
|
|
212
|
+
source: this.rootNode,
|
|
213
|
+
escapeTitles: true,
|
|
214
|
+
glyph: {
|
|
215
|
+
preset: 'awesome4',
|
|
216
|
+
map: {
|
|
217
|
+
folder: 'icon folder sb-fancyTree-icon',
|
|
218
|
+
folderOpen: 'icon folder outline sb-fancyTree-icon'
|
|
219
|
+
}
|
|
220
|
+
},
|
|
221
|
+
dnd5: {
|
|
222
|
+
autoExpandMS: 400,
|
|
223
|
+
// focusOnClick: true,
|
|
224
|
+
preventVoidMoves: true,
|
|
225
|
+
preventRecursion: true,
|
|
226
|
+
dragStart: (node, data) => {
|
|
227
|
+
/** This function MUST be defined to enable dragging for the tree.
|
|
228
|
+
* Return false to cancel dragging of node.
|
|
229
|
+
*/
|
|
230
|
+
const draggable = _.get(this.config, 'mode') === 'edit' ? true : false;
|
|
231
|
+
return draggable;
|
|
232
|
+
},
|
|
233
|
+
dragEnter: (node, data) => {
|
|
234
|
+
/** data.otherNode may be null for non-fancytree droppables.
|
|
235
|
+
* Return false to disallow dropping on node. In this case
|
|
236
|
+
* dragOver and dragLeave are not called.
|
|
237
|
+
* Return 'over', 'before, or 'after' to force a hitMode.
|
|
238
|
+
* Return ['before', 'after'] to restrict available hitModes.
|
|
239
|
+
* Any other return value will calc the hitMode from the cursor position.
|
|
240
|
+
*/
|
|
241
|
+
// Prevent dropping a parent below another parent (only sort
|
|
242
|
+
// nodes under the same parent)
|
|
243
|
+
/* if(node.parent !== data.otherNode.parent){
|
|
244
|
+
return false;
|
|
245
|
+
}
|
|
246
|
+
// Don't allow dropping *over* a node (would create a child)
|
|
247
|
+
return ["before", "after"];
|
|
248
|
+
*/
|
|
249
|
+
return true;
|
|
250
|
+
},
|
|
251
|
+
dragDrop: (node, data) => {
|
|
252
|
+
/** This function MUST be defined to enable dropping of items on
|
|
253
|
+
* the tree.
|
|
254
|
+
*/
|
|
255
|
+
// data.otherNode.moveTo(node, data.hitMode);
|
|
256
|
+
return this.dragDrop(node, data);
|
|
257
|
+
},
|
|
258
|
+
filter: {
|
|
259
|
+
autoApply: true,
|
|
260
|
+
autoExpand: false,
|
|
261
|
+
counter: true,
|
|
262
|
+
fuzzy: false,
|
|
263
|
+
hideExpandedCounter: true,
|
|
264
|
+
hideExpanders: false,
|
|
265
|
+
highlight: true,
|
|
266
|
+
leavesOnly: false,
|
|
267
|
+
nodata: true,
|
|
268
|
+
mode: 'dimm'
|
|
269
|
+
}
|
|
270
|
+
},
|
|
271
|
+
init: (event, data) => { },
|
|
272
|
+
click: (event, data) => {
|
|
273
|
+
this.tree.nativeElement.click();
|
|
274
|
+
this.telemetryService.interact({ edata: this.getTelemetryInteractEdata() });
|
|
275
|
+
return true;
|
|
276
|
+
},
|
|
277
|
+
activate: (event, data) => {
|
|
278
|
+
this.treeEventEmitter.emit({ type: 'nodeSelect', data: data.node });
|
|
279
|
+
setTimeout(() => {
|
|
280
|
+
this.attachContextMenu(data.node, true);
|
|
281
|
+
this.eachNodeActionButton(data.node);
|
|
282
|
+
}, 10);
|
|
283
|
+
},
|
|
284
|
+
renderNode: (event, data) => {
|
|
285
|
+
const node = data.node;
|
|
286
|
+
const $nodeSpan = $(node.span);
|
|
287
|
+
// check if span of node already rendered
|
|
288
|
+
if (!$nodeSpan.data('rendered')) {
|
|
289
|
+
this.attachContextMenu(node);
|
|
290
|
+
// span rendered
|
|
291
|
+
$nodeSpan.data('rendered', true);
|
|
292
|
+
}
|
|
293
|
+
}
|
|
294
|
+
};
|
|
295
|
+
return options;
|
|
296
|
+
}
|
|
297
|
+
eachNodeActionButton(node) {
|
|
298
|
+
this.visibility = {};
|
|
299
|
+
if (this.bulkUploadProcessingStatus) {
|
|
300
|
+
this.visibility.addChild = false;
|
|
301
|
+
this.visibility.addSibling = false;
|
|
302
|
+
this.visibility.addFromLibrary = false;
|
|
303
|
+
this.visibility.addQuestionFromLibrary = false;
|
|
304
|
+
this.visibility.createNew = false;
|
|
305
|
+
}
|
|
306
|
+
else {
|
|
307
|
+
const nodeLevel = node.getLevel() - 1;
|
|
308
|
+
this.visibility.addChild = ((node.folder === false) || (nodeLevel >= this.config.maxDepth)) ? false : true;
|
|
309
|
+
// tslint:disable-next-line:max-line-length
|
|
310
|
+
this.visibility.addSibling = ((node.folder === true) && (!node.data.root) && !((node.getLevel() - 1) > this.config.maxDepth)) ? true : false;
|
|
311
|
+
if (nodeLevel === 0) {
|
|
312
|
+
this.visibility.addFromLibrary = _.isEmpty(_.get(this.config, 'children')) || _.get(this.config, 'enableQuestionCreation') === false ? false : true;
|
|
313
|
+
this.visibility.createNew = _.isEmpty(_.get(this.config, 'children')) || _.get(this.config, 'enableQuestionCreation') === false ? false : true;
|
|
314
|
+
this.visibility.addQuestionFromLibrary = !_.isEmpty(_.get(this.config, 'children')) && _.get(this.config, 'enableAddFromLibrary') === true ? true : false;
|
|
315
|
+
}
|
|
316
|
+
else {
|
|
317
|
+
const hierarchylevelData = this.config.hierarchy[`level${nodeLevel}`];
|
|
318
|
+
// tslint:disable-next-line:max-line-length
|
|
319
|
+
this.visibility.addFromLibrary = ((node.folder === false) || _.isEmpty(_.get(hierarchylevelData, 'children')) || _.get(this.config, 'enableQuestionCreation') === false) ? false : true;
|
|
320
|
+
// tslint:disable-next-line:max-line-length
|
|
321
|
+
this.visibility.createNew = ((node.folder === false) || _.isEmpty(_.get(hierarchylevelData, 'children')) || _.get(this.config, 'enableQuestionCreation') === false) ? false : true;
|
|
322
|
+
this.visibility.addQuestionFromLibrary = ((node.folder === true) && !_.isEmpty(_.get(hierarchylevelData, 'children')) && _.get(this.config, 'enableAddFromLibrary') === true) ? true : false;
|
|
323
|
+
}
|
|
324
|
+
}
|
|
325
|
+
if (_.get(this.editorService, 'editorConfig.config.renderTaxonomy') === true) {
|
|
326
|
+
this.visibility.addChild = false;
|
|
327
|
+
this.visibility.addSibling = false;
|
|
328
|
+
}
|
|
329
|
+
this.cdr.detectChanges();
|
|
330
|
+
}
|
|
331
|
+
addChild() {
|
|
332
|
+
this.telemetryService.interact({ edata: this.getTelemetryInteractEdata('add_child') });
|
|
333
|
+
const tree = $(this.tree.nativeElement).fancytree('getTree');
|
|
334
|
+
const nodeConfig = this.config.hierarchy[tree.getActiveNode().getLevel()];
|
|
335
|
+
const childrenTypes = _.get(nodeConfig, 'children.Content');
|
|
336
|
+
if ((((tree.getActiveNode().getLevel() - 1) >= this.config.maxDepth))) {
|
|
337
|
+
return this.toasterService.error(_.get(this.configService, 'labelConfig.messages.error.007'));
|
|
338
|
+
}
|
|
339
|
+
this.treeService.addNode('child');
|
|
340
|
+
}
|
|
341
|
+
addSibling() {
|
|
342
|
+
this.telemetryService.interact({ edata: this.getTelemetryInteractEdata('add_sibling') });
|
|
343
|
+
const tree = $(this.tree.nativeElement).fancytree('getTree');
|
|
344
|
+
const node = tree.getActiveNode();
|
|
345
|
+
if (!node.data.root) {
|
|
346
|
+
this.treeService.addNode('sibling');
|
|
347
|
+
}
|
|
348
|
+
else {
|
|
349
|
+
this.toasterService.error(_.get(this.configService, 'labelConfig.messages.error.007'));
|
|
350
|
+
}
|
|
351
|
+
}
|
|
352
|
+
getActiveNode() {
|
|
353
|
+
return $(this.tree.nativeElement).fancytree('getTree').getActiveNode();
|
|
354
|
+
}
|
|
355
|
+
attachContextMenu(node, activeNode) {
|
|
356
|
+
if (_.get(this.config, 'mode') !== 'edit' || (node.data.root === true && _.isEmpty(this.config.hierarchy))) {
|
|
357
|
+
return;
|
|
358
|
+
}
|
|
359
|
+
const $nodeSpan = $(node.span);
|
|
360
|
+
// tslint:disable-next-line:max-line-length // TODO:: (node.data.contentType === 'CourseUnit') check this condition
|
|
361
|
+
const menuTemplate = node.data.root === true ? this.rootMenuTemplate : (node.data.root === false && node.folder === true ? this.folderMenuTemplate : this.contentMenuTemplate);
|
|
362
|
+
const iconsButton = $(menuTemplate);
|
|
363
|
+
if ((node.getLevel() - 1) >= this.config.maxDepth) {
|
|
364
|
+
iconsButton.find('#addchild').remove();
|
|
365
|
+
}
|
|
366
|
+
let contextMenu = $($nodeSpan[0]).find(`#contextMenu`);
|
|
367
|
+
if (!contextMenu.length) {
|
|
368
|
+
$nodeSpan.append(iconsButton);
|
|
369
|
+
if (!activeNode) {
|
|
370
|
+
iconsButton.hide();
|
|
371
|
+
}
|
|
372
|
+
$nodeSpan[0].onmouseover = () => {
|
|
373
|
+
iconsButton.show();
|
|
374
|
+
};
|
|
375
|
+
$nodeSpan[0].onmouseout = () => {
|
|
376
|
+
iconsButton.hide();
|
|
377
|
+
};
|
|
378
|
+
contextMenu = $($nodeSpan[0]).find(`#contextMenu`);
|
|
379
|
+
contextMenu.on('click', (event) => {
|
|
380
|
+
this.treeService.closePrevOpenedDropDown();
|
|
381
|
+
setTimeout(() => {
|
|
382
|
+
const nSpan = $(this.getActiveNode().span);
|
|
383
|
+
const dropDownElement = $(nSpan[0]).find(`#contextMenuDropDown`);
|
|
384
|
+
dropDownElement.removeClass('hidden');
|
|
385
|
+
dropDownElement.addClass('visible');
|
|
386
|
+
_.forEach(_.get(_.first(dropDownElement), 'children'), item => {
|
|
387
|
+
item.addEventListener('click', (ev) => {
|
|
388
|
+
this.treeService.closePrevOpenedDropDown();
|
|
389
|
+
this.handleActionButtons(ev.currentTarget);
|
|
390
|
+
ev.stopPropagation();
|
|
391
|
+
});
|
|
392
|
+
});
|
|
393
|
+
}, 100);
|
|
394
|
+
// event.stopPropagation();
|
|
395
|
+
});
|
|
396
|
+
$($nodeSpan[0]).find(`#removeNodeIcon`).on('click', (event) => {
|
|
397
|
+
const isContent = event.currentTarget.getAttribute('type') && event.currentTarget.getAttribute('type') === 'content';
|
|
398
|
+
this.removeNode(isContent);
|
|
399
|
+
});
|
|
400
|
+
}
|
|
401
|
+
}
|
|
402
|
+
dropNode(targetNode, currentNode) {
|
|
403
|
+
let dropAllowed;
|
|
404
|
+
dropAllowed = true;
|
|
405
|
+
// tslint:disable-next-line:max-line-length
|
|
406
|
+
if (currentNode.otherNode.getLevel() === targetNode.getLevel() && currentNode.otherNode.folder === true && currentNode.hitMode !== 'over') {
|
|
407
|
+
dropAllowed = true;
|
|
408
|
+
// tslint:disable-next-line:max-line-length
|
|
409
|
+
}
|
|
410
|
+
else if (currentNode.otherNode.folder === true && (this.maxTreeDepth(currentNode.otherNode) + (targetNode.getLevel() - 1)) > _.get(this.config, 'maxDepth')) {
|
|
411
|
+
return this.dropNotAllowed();
|
|
412
|
+
}
|
|
413
|
+
else if (currentNode.otherNode.folder === false && !this.checkContentAddition(targetNode, currentNode)) {
|
|
414
|
+
dropAllowed = false;
|
|
415
|
+
}
|
|
416
|
+
if (dropAllowed) {
|
|
417
|
+
currentNode.otherNode.moveTo(targetNode, currentNode.hitMode);
|
|
418
|
+
this.treeService.nextTreeStatus('reorder');
|
|
419
|
+
return true;
|
|
420
|
+
}
|
|
421
|
+
else {
|
|
422
|
+
this.toasterService.warning(`${currentNode.otherNode.title} cannot be added to ${currentNode.node.title}`);
|
|
423
|
+
return false;
|
|
424
|
+
}
|
|
425
|
+
}
|
|
426
|
+
dragDrop(node, data) {
|
|
427
|
+
if ((data.hitMode === 'before' || data.hitMode === 'after' || data.hitMode === 'over') && data.node.data.root) {
|
|
428
|
+
return this.dropNotAllowed();
|
|
429
|
+
}
|
|
430
|
+
if (_.has(this.config, 'maxDepth')) {
|
|
431
|
+
return this.dropNode(node, data);
|
|
432
|
+
}
|
|
433
|
+
}
|
|
434
|
+
dropNotAllowed() {
|
|
435
|
+
this.toasterService.warning(_.get(this.configService, 'labelConfig.messages.error.007'));
|
|
436
|
+
return false;
|
|
437
|
+
}
|
|
438
|
+
maxTreeDepth(root) {
|
|
439
|
+
const buffer = [{ node: root, depth: 1 }];
|
|
440
|
+
let current = buffer.pop();
|
|
441
|
+
let max = 0;
|
|
442
|
+
while (current && current.node) {
|
|
443
|
+
// Find all children of this node.
|
|
444
|
+
_.forEach(current.node.children, (child) => {
|
|
445
|
+
buffer.push({ node: child, depth: current.depth + 1 });
|
|
446
|
+
});
|
|
447
|
+
if (current.depth > max) {
|
|
448
|
+
max = current.depth;
|
|
449
|
+
}
|
|
450
|
+
current = buffer.pop();
|
|
451
|
+
}
|
|
452
|
+
return max;
|
|
453
|
+
}
|
|
454
|
+
checkContentAddition(targetNode, contentNode) {
|
|
455
|
+
if (targetNode.folder === false && (contentNode.hitMode === 'before' || contentNode.hitMode === 'after')) {
|
|
456
|
+
return true;
|
|
457
|
+
}
|
|
458
|
+
if (targetNode.folder === false && contentNode.hitMode === 'over') {
|
|
459
|
+
return false;
|
|
460
|
+
}
|
|
461
|
+
const nodeConfig = this.config.hierarchy[`level${targetNode.getLevel() - 1}`];
|
|
462
|
+
const contentPrimaryCategories = _.flatMap(_.get(nodeConfig, 'children'));
|
|
463
|
+
if (!_.isEmpty(contentPrimaryCategories)) {
|
|
464
|
+
return _.includes(contentPrimaryCategories, _.get(contentNode, 'otherNode.data.metadata.primaryCategory')) ? true : false;
|
|
465
|
+
}
|
|
466
|
+
return false;
|
|
467
|
+
}
|
|
468
|
+
removeNode(isContent) {
|
|
469
|
+
this.treeEventEmitter.emit({ type: 'deleteNode', isContent });
|
|
470
|
+
this.telemetryService.interact({ edata: this.getTelemetryInteractEdata('delete') });
|
|
471
|
+
}
|
|
472
|
+
handleActionButtons(el) {
|
|
473
|
+
console.log('action buttons -------->', el.id);
|
|
474
|
+
switch (el.id) {
|
|
475
|
+
case 'edit':
|
|
476
|
+
break;
|
|
477
|
+
case 'delete':
|
|
478
|
+
this.removeNode();
|
|
479
|
+
break;
|
|
480
|
+
case 'addsibling':
|
|
481
|
+
this.addSibling();
|
|
482
|
+
break;
|
|
483
|
+
case 'addchild':
|
|
484
|
+
this.addChild();
|
|
485
|
+
break;
|
|
486
|
+
case 'addresource':
|
|
487
|
+
break;
|
|
488
|
+
}
|
|
489
|
+
}
|
|
490
|
+
addFromLibrary() {
|
|
491
|
+
this.editorService.emitshowLibraryPageEvent('showLibraryPage');
|
|
492
|
+
}
|
|
493
|
+
getTelemetryInteractEdata(id) {
|
|
494
|
+
return {
|
|
495
|
+
id: id || 'collection-toc',
|
|
496
|
+
type: 'click',
|
|
497
|
+
subtype: 'launch',
|
|
498
|
+
pageid: this.telemetryService.telemetryPageId,
|
|
499
|
+
extra: {
|
|
500
|
+
values: [_.get(this.getActiveNode(), 'data')]
|
|
501
|
+
}
|
|
502
|
+
};
|
|
503
|
+
}
|
|
504
|
+
createNewContent() {
|
|
505
|
+
this.treeEventEmitter.emit({ type: 'createNewContent' });
|
|
506
|
+
}
|
|
507
|
+
ngOnDestroy() {
|
|
508
|
+
this.onComponentDestroy$.next();
|
|
509
|
+
this.onComponentDestroy$.complete();
|
|
510
|
+
}
|
|
511
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: FancyTreeComponent, deps: [{ token: i1.TreeService }, { token: i2.EditorService }, { token: i3.EditorTelemetryService }, { token: i4.HelperService }, { token: i5.ToasterService }, { token: i0.ChangeDetectorRef }, { token: i6.ConfigService }, { token: i7.DialcodeService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
512
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: FancyTreeComponent, selector: "lib-fancy-tree", inputs: { nodes: "nodes", options: "options", buttonLoaders: "buttonLoaders" }, outputs: { treeEventEmitter: "treeEventEmitter" }, viewQueries: [{ propertyName: "tree", first: true, predicate: ["fancyTree"], descendants: true }], ngImport: i0, template: "<div #fancyTree></div>\n<div class=\"sb-fixed-with-whitebg pr-20 d-flex flex-jc-space-between\" *ngIf=\"config && config.mode === 'edit'\">\n <div class=\"d-flex w-25\">\n <div class=\"sb-btn-cover\">\n <button [ngClass]=\"visibility?.addSibling ? '' : 'sb-disabled'\" (click)=\"addSibling();\"\n class=\"sb-btn sb-btn-outline-primary sb-btn-normal sb-btn-radius p-0 b-none\"><i aria-hidden=\"true\" class=\"icon plus\"></i>\n {{configService.labelConfig?.button_labels?.add_sibling_btn_label}} </button>\n </div>\n <div class=\"sb-btn-cover\">\n <button [ngClass]=\"visibility?.addChild ? '' : 'sb-disabled'\" (click)=\"addChild();\"\n class=\"sb-btn sb-btn-outline-primary sb-btn-normal sb-btn-radius b-none p-0\"><i class=\"icon plus\"></i>\n {{configService.labelConfig?.button_labels?.add_child_btn_label}} </button>\n </div>\n </div>\n <button *ngIf=\"config.objectType !== 'QuestionSet'\" (click)=\"addFromLibrary();\"\n [disabled]=\"!visibility?.addFromLibrary\"\n [ngClass]=\"[!visibility?.addFromLibrary ? 'sb-btn-outline-disabled' : '', (visibility?.addFromLibrary && buttonLoaders?.addFromLibraryButtonLoader) ? 'sb-btn-loading-spinner sb-btn-outline-disabled': '']\"\n class=\"sb-btn sb-btn-outline-primary sb-btn-normal mt-10 mr-30\" libTelemetryInteract\n [telemetryInteractEdata]=\"telemetryService.getTelemetryInteractEdata('add_from_library','click','launch', telemetryService.telemetryPageId)\">\n <i class=\"icon plus\" aria-hidden=\"true\" *ngIf=\"!buttonLoaders?.addFromLibraryButtonLoader\"></i>\n <div class=\"sb-loading-spinner\" *ngIf=\"buttonLoaders?.addFromLibraryButtonLoader\" role=\"status\" aria-hidden=\"true\">\n </div>\n {{configService.labelConfig?.button_labels?.add_from_library_btn_label}}\n </button>\n <button *ngIf=\"config.objectType === 'QuestionSet'\" [disabled]=\"!visibility?.createNew\"\n [ngClass]=\"[!visibility?.createNew ? 'sb-btn-outline-disabled' : '', (visibility?.createNew && buttonLoaders?.addFromLibraryButtonLoader) ? 'sb-btn-loading-spinner sb-btn-outline-disabled': '']\"\n type=\"button\" class=\"sb-btn sb-btn-normal sb-btn-primary mt-10 mr-30\" (click)=\"createNewContent()\"\n libTelemetryInteract\n [telemetryInteractEdata]=\"telemetryService.getTelemetryInteractEdata('create_new','click','launch', telemetryService.telemetryPageId)\">\n <i class=\"icon plus\" *ngIf=\"!buttonLoaders?.addFromLibraryButtonLoader\"></i>\n <div class=\"sb-loading-spinner\" *ngIf=\"buttonLoaders?.addFromLibraryButtonLoader\" role=\"status\" aria-hidden=\"true\">\n </div>\n {{configService.labelConfig?.button_labels?.create_new_btn_label}}\n </button>\n</div>", styles: [".sb-collectionTree-fancyTreelist ul{padding:0!important}.sb-collectionTree-fancyTreelist .ui-fancytree{margin-bottom:1rem!important}.sb-collectionTree-fancyTreelist .ui-fancytree:before{background:none!important}.sb-collectionTree-fancyTreelist .ui-fancytree ul:before{background:none!important}.sb-collectionTree-fancyTreelist .ui-fancytree .fancytree-folder .fancytree-title{color:var(--primary-color)!important;font-size:.9286rem!important;font-weight:700!important;padding-left:5px;width:inherit!important}.sb-collectionTree-fancyTreelist .ui-fancytree .fancytree-folder .highlightNode{color:red!important}.sb-collectionTree-fancyTreelist .ui-fancytree .fancytree-folder .highlightNode:before{color:red!important}.sb-collectionTree-fancyTreelist .ui-fancytree li{padding:0;margin:0 0 1px}.sb-collectionTree-fancyTreelist .ui-fancytree li .fancytree-ico-c{padding-left:5px!important}.sb-collectionTree-fancyTreelist .ui-fancytree li .fancytree-expanded{padding:15px 33px;border:1px solid transparent;background-color:#fff}.sb-collectionTree-fancyTreelist .ui-fancytree li .fancytree-active{border:1px solid #d0e0f3;background-color:var(--primary-0);padding:15px 33px;border-top:none}.sb-collectionTree-fancyTreelist .ui-fancytree li:last-child:after{display:none}.sb-collectionTree-fancyTreelist .ui-fancytree li ul{padding-top:1px}.sb-collectionTree-fancyTreelist .ui-fancytree li ul li{list-style-type:none}.sb-collectionTree-fancyTreelist .ui-fancytree li ul li .fancytree-custom-icon:before{color:var(--primary-color)!important;margin-top:2px;float:left;margin-left:6px;font-size:16px}.sb-collectionTree-fancyTreelist .ui-fancytree li ul li .fancytree-custom-icon:last-child:after{display:none}.sb-collectionTree-fancyTreelist .ui-fancytree li ul li .fancytree-node{padding:6px 6px 8px 5px;margin-left:45px;border:1px solid transparent}.sb-collectionTree-fancyTreelist .ui-fancytree li ul li .fancytree-node.fancytree-active,.sb-collectionTree-fancyTreelist .ui-fancytree li ul li .fancytree-node.fancytree-focused,.sb-collectionTree-fancyTreelist .ui-fancytree li ul li .fancytree-node:hover{border:1px solid #d0e0f3;background-color:var(--primary-0);border-right:0}.sb-collectionTree-fancyTreelist .ui-fancytree li:before{background:none!important}.sb-collectionTree-fancyTreelist .ui-fancytree li .sb-fancyTree-icon{color:var(--gray-300)!important}.sb-collectionTree-fancyTreelist .ui-fancytree li .fancytree-custom-icon:before{color:var(--primary-color)!important;margin-left:5px}.sb-collectionTree-fancyTreelist .ui-fancytree .fa-caret-down{margin-top:6px;display:block;width:10px;padding-left:2px}.sb-collectionTree-fancyTreelist .ui-fancytree .fa-caret-right{margin-top:6px;display:block;width:10px;padding-left:6px}.sb-collectionTree-fancyTreelist .ui-fancytree{padding-right:.785rem;margin:0;padding:0;list-style-type:none}.sb-fixed-with-whitebg{position:fixed;width:100%;border-top:1px solid #ddd;left:0;right:0;bottom:0;background-color:#fff;z-index:99999;padding:0!important}.sb-fixed-with-whitebg .sb-btn-cover{padding:.5rem;border-right:solid 1px #ccc;width:50%;text-align:center}.sb-fixed-with-whitebg .sb-btn-cover .sb-btn:hover{background:none!important;color:var(--primary-400)}.sb-dotted-dropdown{position:absolute!important;right:6px;padding-left:33px}.sb-dotted-dropdown .menu{right:0!important;left:inherit!important}.sb-dotted-dropdown .menu .item{font-size:.785rem!important}.eight.bg-white{border-left:solid 1px var(--gray-100);padding-bottom:4.5rem!important}.b-none{border:none!important}.w-25{width:25.1%;max-width:25.1%}#removeNodeIcon{padding-right:24px}\n"], dependencies: [{ kind: "directive", type: i8.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i8.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i9.TelemetryInteractDirective, selector: "[libTelemetryInteract]", inputs: ["telemetryInteractEdata"] }], encapsulation: i0.ViewEncapsulation.None }); }
|
|
513
|
+
}
|
|
514
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: FancyTreeComponent, decorators: [{
|
|
515
|
+
type: Component,
|
|
516
|
+
args: [{ selector: 'lib-fancy-tree', encapsulation: ViewEncapsulation.None, template: "<div #fancyTree></div>\n<div class=\"sb-fixed-with-whitebg pr-20 d-flex flex-jc-space-between\" *ngIf=\"config && config.mode === 'edit'\">\n <div class=\"d-flex w-25\">\n <div class=\"sb-btn-cover\">\n <button [ngClass]=\"visibility?.addSibling ? '' : 'sb-disabled'\" (click)=\"addSibling();\"\n class=\"sb-btn sb-btn-outline-primary sb-btn-normal sb-btn-radius p-0 b-none\"><i aria-hidden=\"true\" class=\"icon plus\"></i>\n {{configService.labelConfig?.button_labels?.add_sibling_btn_label}} </button>\n </div>\n <div class=\"sb-btn-cover\">\n <button [ngClass]=\"visibility?.addChild ? '' : 'sb-disabled'\" (click)=\"addChild();\"\n class=\"sb-btn sb-btn-outline-primary sb-btn-normal sb-btn-radius b-none p-0\"><i class=\"icon plus\"></i>\n {{configService.labelConfig?.button_labels?.add_child_btn_label}} </button>\n </div>\n </div>\n <button *ngIf=\"config.objectType !== 'QuestionSet'\" (click)=\"addFromLibrary();\"\n [disabled]=\"!visibility?.addFromLibrary\"\n [ngClass]=\"[!visibility?.addFromLibrary ? 'sb-btn-outline-disabled' : '', (visibility?.addFromLibrary && buttonLoaders?.addFromLibraryButtonLoader) ? 'sb-btn-loading-spinner sb-btn-outline-disabled': '']\"\n class=\"sb-btn sb-btn-outline-primary sb-btn-normal mt-10 mr-30\" libTelemetryInteract\n [telemetryInteractEdata]=\"telemetryService.getTelemetryInteractEdata('add_from_library','click','launch', telemetryService.telemetryPageId)\">\n <i class=\"icon plus\" aria-hidden=\"true\" *ngIf=\"!buttonLoaders?.addFromLibraryButtonLoader\"></i>\n <div class=\"sb-loading-spinner\" *ngIf=\"buttonLoaders?.addFromLibraryButtonLoader\" role=\"status\" aria-hidden=\"true\">\n </div>\n {{configService.labelConfig?.button_labels?.add_from_library_btn_label}}\n </button>\n <button *ngIf=\"config.objectType === 'QuestionSet'\" [disabled]=\"!visibility?.createNew\"\n [ngClass]=\"[!visibility?.createNew ? 'sb-btn-outline-disabled' : '', (visibility?.createNew && buttonLoaders?.addFromLibraryButtonLoader) ? 'sb-btn-loading-spinner sb-btn-outline-disabled': '']\"\n type=\"button\" class=\"sb-btn sb-btn-normal sb-btn-primary mt-10 mr-30\" (click)=\"createNewContent()\"\n libTelemetryInteract\n [telemetryInteractEdata]=\"telemetryService.getTelemetryInteractEdata('create_new','click','launch', telemetryService.telemetryPageId)\">\n <i class=\"icon plus\" *ngIf=\"!buttonLoaders?.addFromLibraryButtonLoader\"></i>\n <div class=\"sb-loading-spinner\" *ngIf=\"buttonLoaders?.addFromLibraryButtonLoader\" role=\"status\" aria-hidden=\"true\">\n </div>\n {{configService.labelConfig?.button_labels?.create_new_btn_label}}\n </button>\n</div>", styles: [".sb-collectionTree-fancyTreelist ul{padding:0!important}.sb-collectionTree-fancyTreelist .ui-fancytree{margin-bottom:1rem!important}.sb-collectionTree-fancyTreelist .ui-fancytree:before{background:none!important}.sb-collectionTree-fancyTreelist .ui-fancytree ul:before{background:none!important}.sb-collectionTree-fancyTreelist .ui-fancytree .fancytree-folder .fancytree-title{color:var(--primary-color)!important;font-size:.9286rem!important;font-weight:700!important;padding-left:5px;width:inherit!important}.sb-collectionTree-fancyTreelist .ui-fancytree .fancytree-folder .highlightNode{color:red!important}.sb-collectionTree-fancyTreelist .ui-fancytree .fancytree-folder .highlightNode:before{color:red!important}.sb-collectionTree-fancyTreelist .ui-fancytree li{padding:0;margin:0 0 1px}.sb-collectionTree-fancyTreelist .ui-fancytree li .fancytree-ico-c{padding-left:5px!important}.sb-collectionTree-fancyTreelist .ui-fancytree li .fancytree-expanded{padding:15px 33px;border:1px solid transparent;background-color:#fff}.sb-collectionTree-fancyTreelist .ui-fancytree li .fancytree-active{border:1px solid #d0e0f3;background-color:var(--primary-0);padding:15px 33px;border-top:none}.sb-collectionTree-fancyTreelist .ui-fancytree li:last-child:after{display:none}.sb-collectionTree-fancyTreelist .ui-fancytree li ul{padding-top:1px}.sb-collectionTree-fancyTreelist .ui-fancytree li ul li{list-style-type:none}.sb-collectionTree-fancyTreelist .ui-fancytree li ul li .fancytree-custom-icon:before{color:var(--primary-color)!important;margin-top:2px;float:left;margin-left:6px;font-size:16px}.sb-collectionTree-fancyTreelist .ui-fancytree li ul li .fancytree-custom-icon:last-child:after{display:none}.sb-collectionTree-fancyTreelist .ui-fancytree li ul li .fancytree-node{padding:6px 6px 8px 5px;margin-left:45px;border:1px solid transparent}.sb-collectionTree-fancyTreelist .ui-fancytree li ul li .fancytree-node.fancytree-active,.sb-collectionTree-fancyTreelist .ui-fancytree li ul li .fancytree-node.fancytree-focused,.sb-collectionTree-fancyTreelist .ui-fancytree li ul li .fancytree-node:hover{border:1px solid #d0e0f3;background-color:var(--primary-0);border-right:0}.sb-collectionTree-fancyTreelist .ui-fancytree li:before{background:none!important}.sb-collectionTree-fancyTreelist .ui-fancytree li .sb-fancyTree-icon{color:var(--gray-300)!important}.sb-collectionTree-fancyTreelist .ui-fancytree li .fancytree-custom-icon:before{color:var(--primary-color)!important;margin-left:5px}.sb-collectionTree-fancyTreelist .ui-fancytree .fa-caret-down{margin-top:6px;display:block;width:10px;padding-left:2px}.sb-collectionTree-fancyTreelist .ui-fancytree .fa-caret-right{margin-top:6px;display:block;width:10px;padding-left:6px}.sb-collectionTree-fancyTreelist .ui-fancytree{padding-right:.785rem;margin:0;padding:0;list-style-type:none}.sb-fixed-with-whitebg{position:fixed;width:100%;border-top:1px solid #ddd;left:0;right:0;bottom:0;background-color:#fff;z-index:99999;padding:0!important}.sb-fixed-with-whitebg .sb-btn-cover{padding:.5rem;border-right:solid 1px #ccc;width:50%;text-align:center}.sb-fixed-with-whitebg .sb-btn-cover .sb-btn:hover{background:none!important;color:var(--primary-400)}.sb-dotted-dropdown{position:absolute!important;right:6px;padding-left:33px}.sb-dotted-dropdown .menu{right:0!important;left:inherit!important}.sb-dotted-dropdown .menu .item{font-size:.785rem!important}.eight.bg-white{border-left:solid 1px var(--gray-100);padding-bottom:4.5rem!important}.b-none{border:none!important}.w-25{width:25.1%;max-width:25.1%}#removeNodeIcon{padding-right:24px}\n"] }]
|
|
517
|
+
}], ctorParameters: function () { return [{ type: i1.TreeService }, { type: i2.EditorService }, { type: i3.EditorTelemetryService }, { type: i4.HelperService }, { type: i5.ToasterService }, { type: i0.ChangeDetectorRef }, { type: i6.ConfigService }, { type: i7.DialcodeService }]; }, propDecorators: { tree: [{
|
|
518
|
+
type: ViewChild,
|
|
519
|
+
args: ['fancyTree']
|
|
520
|
+
}], nodes: [{
|
|
521
|
+
type: Input
|
|
522
|
+
}], options: [{
|
|
523
|
+
type: Input
|
|
524
|
+
}], buttonLoaders: [{
|
|
525
|
+
type: Input
|
|
526
|
+
}], treeEventEmitter: [{
|
|
527
|
+
type: Output
|
|
528
|
+
}] } });
|
|
529
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"fancy-tree.component.js","sourceRoot":"","sources":["../../../../../../projects/collection-editor-library/src/lib/components/fancy-tree/fancy-tree.component.ts","../../../../../../projects/collection-editor-library/src/lib/components/fancy-tree/fancy-tree.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component, AfterViewInit, Input, ViewChild, ElementRef, Output, EventEmitter,\n  OnDestroy, OnInit, ViewEncapsulation, ChangeDetectorRef\n} from '@angular/core';\nimport 'jquery.fancytree';\nimport * as _ from 'lodash-es';\nimport { TreeService } from '../../services/tree/tree.service';\nimport { EditorService } from '../../services/editor/editor.service';\nimport { HelperService } from '../../services/helper/helper.service';\nimport { EditorTelemetryService } from '../../services/telemetry/telemetry.service';\nimport { ToasterService } from '../../services/toaster/toaster.service';\nimport { ConfigService } from '../../services/config/config.service';\nimport {  DialcodeService } from '../../services/dialcode/dialcode.service';\n\n\nimport { Subject } from 'rxjs';\nimport { v4 as uuidv4 } from 'uuid';\n\ndeclare var $: any;\n\n@Component({\n  selector: 'lib-fancy-tree',\n  templateUrl: './fancy-tree.component.html',\n  styleUrls: ['./fancy-tree.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n})\nexport class FancyTreeComponent implements OnInit, AfterViewInit, OnDestroy {\n  @ViewChild('fancyTree') public tree: ElementRef;\n  @Input() public nodes: any;\n  @Input() public options: any;\n  @Input( ) buttonLoaders: any;\n  @Output() public treeEventEmitter: EventEmitter<any> = new EventEmitter();\n  public config: any;\n  public showTree: boolean;\n  public visibility: any;\n  public showAddChildButton: boolean;\n  public showAddSiblingButton: boolean;\n  public rootNode: any;\n  public showLibraryButton = false;\n  public rootMenuTemplate = `<span class=\"ui dropdown sb-dotted-dropdown\" autoclose=\"itemClick\" suidropdown=\"\" tabindex=\"0\">\n  <span id=\"contextMenu\" class=\"p-0 w-auto\"><i class=\"icon ellipsis vertical sb-color-black\"></i></span>\n  <span id= \"contextMenuDropDown\" class=\"menu transition hidden\" suidropdownmenu=\"\" style=\"\">\n    <div id=\"addchild\" class=\"item\">Add Child</div>\n  </span>\n  </span>`;\n  public folderMenuTemplate = `<span id= \"removeNodeIcon\"> <i class=\"fa fa-trash-o\" type=\"button\"></i> </span><span class=\"ui dropdown sb-dotted-dropdown\" autoclose=\"itemClick\" suidropdown=\"\" tabindex=\"0\">\n  <span id=\"contextMenu\" class=\"p-0 w-auto\"><i class=\"icon ellipsis vertical sb-color-black\"></i></span>\n  <span id= \"contextMenuDropDown\" class=\"menu transition hidden\" suidropdownmenu=\"\" style=\"\">\n    <div id=\"addsibling\" class=\"item\">Add Sibling</div>\n    <div id=\"addchild\" class=\"item\">Add Child</div>\n    <div id=\"delete\" class=\"item\">Delete</div>\n  </span>\n  </span>`;\n  // tslint:disable-next-line:max-line-length\n  public contentMenuTemplate = `<span id=\"contextMenu\"><span id= \"removeNodeIcon\" type=\"content\" > <i class=\"fa fa-trash-o\" type=\"button\"></i> </span></span>`;\n  public nodeParentDependentMap: any;\n  public bulkUploadProcessingStatus: any;\n  constructor(public treeService: TreeService, private editorService: EditorService,\n              public telemetryService: EditorTelemetryService, private helperService: HelperService,\n              private toasterService: ToasterService, private cdr: ChangeDetectorRef,\n              public configService: ConfigService, private dialcodeService: DialcodeService) { }\n  private onComponentDestroy$ = new Subject<any>();\n\n  ngOnInit() {\n    this.config = _.cloneDeep(this.editorService.editorConfig.config);\n    this.config.mode =  _.get(this.config, 'mode').toLowerCase();\n    if (!_.has(this.config, 'maxDepth')) { // TODO:: rethink this\n      this.config.maxDepth = 4;\n    }\n    this.initialize();\n    this.editorService.bulkUploadStatus$.subscribe(status => {\n      this.bulkUploadProcessingStatus = status;\n    });\n  }\n\n  ngAfterViewInit() {\n    this.renderTree(this.getTreeConfig());\n  }\n\n  private initialize() {\n    const data = this.nodes.data;\n    this.nodeParentDependentMap = this.editorService.getParentDependentMap(this.nodes.data);\n    let treeData;\n    if (_.get(this.editorService, 'editorConfig.config.renderTaxonomy') === true && _.isEmpty(_.get(this.nodes, 'data.children'))) {\n      this.helperService.addDepthToHierarchy(this.nodes.data.children);\n      this.nodes.data.children =   this.removeIntermediateLevelsFromFramework(this.nodes.data.children);\n      treeData = this.buildTreeFromFramework(this.nodes.data);\n    } else {\n      treeData = this.buildTree(this.nodes.data);\n    }\n    this.editorService.treeData = treeData;\n    this.rootNode = [{\n      id: data.identifier || uuidv4(),\n      title: data.name,\n      tooltip: data.name,\n      ...(data.contentType && {contentType: data.contentType}),\n      primaryCategory: data.primaryCategory,\n      objectType: data.objectType,\n      metadata: _.omit(data, ['children', 'collections']),\n      folder: true,\n      children: treeData,\n      root: true,\n      icon: _.get(this.config, 'iconClass')\n    }];\n  }\n\n  buildTreeFromFramework(data, tree?, level?) {\n    tree = tree || [];\n    if (data.children) { data.children = _.sortBy(data.children, ['index']); }\n    _.forEach(data.children, (child) => {\n      const childTree = [];\n      tree.push({\n        id: uuidv4(),\n        title: child.name,\n        tooltip: child.name,\n        primaryCategory: child.primaryCategory,\n        metadata: _.omit(child, ['children', 'collections']),\n        folder: true,\n        children: childTree,\n        root: false,\n        icon: 'fa fa-folder-o'\n      });\n      if (child.children) {\n        this.buildTreeFromFramework(child, childTree);\n      }\n    });\n    return tree;\n  }\n\n  removeIntermediateLevelsFromFramework(data, parentData?) {\n    const tree = [];\n    _.forEach(data, child => {\n      if (child.depth === 0 || child.depth === this.helperService.treeDepth) {\n        const node = {\n          ..._.omit(child, ['children']),\n          ...(child.children && {children: this.removeIntermediateLevelsFromFramework(child.children, child)})\n        };\n        tree.push(\n          node\n        );\n      } else if ((child.depth !== 0 || child.depth !== this.helperService.treeDepth)) {\n        parentData.children  = _.filter(parentData.children, item => (item.depth === 0 || item.depth === this.helperService.treeDepth));\n        if (child.children && child.children.length > 0) {\n          const children = this.removeIntermediateLevelsFromFramework(child.children, child);\n          parentData.children = _.concat(parentData.children, children);\n        } else {\n          parentData.children = _.concat(parentData.children, child.children);\n        }\n      }\n    });\n    return !_.isEmpty(tree) ? tree : _.flatten(parentData.children);\n  }\n\n  buildTree(data, tree?, level?) {\n    tree = tree || [];\n    if (data.children) { data.children = _.sortBy(data.children, ['index']); }\n    data.level = level ? (level + 1) : 1;\n    _.forEach(data.children, (child) => {\n      const childTree = [];\n      tree.push({\n        id: child.identifier || uuidv4(),\n        title: child.name,\n        tooltip: child.name,\n        ...(child.contentType && {contentType: child.contentType}),\n        primaryCategory: child.primaryCategory,\n        objectType: child.objectType,\n        metadata: _.omit(child, ['children', 'collections']),\n        folder: this.isFolder(child),\n        children: childTree,\n        root: false,\n        icon: this.getIconClass(child, data.level)\n      });\n      if (child.visibility === 'Parent') {\n        this.buildTree(child, childTree, data.level);\n      }\n    });\n    return tree;\n  }\n\n  isFolder(child: any) {\n    if (this.isContent(child)) {\n      return false;\n    } else {\n      return child.visibility === 'Parent' ? true : false;\n    }\n  }\n\n  getIconClass(child: any, level: number) {\n    if (this.isContent(child)) {\n      return 'fa fa-file-o';\n    } else if (child.visibility === 'Parent') {\n        return _.get(this.config, `hierarchy.level.${level}.iconClass`) || 'fa fa-folder-o';\n    } else {\n      return 'fa fa-file-o';\n    }\n  }\n\n  isContent(child: any) {\n    // tslint:disable-next-line:max-line-length\n    return (_.get(this.config, 'objectType') === 'QuestionSet' && child.objectType === 'Question');\n  }\n\n  renderTree(options) {\n    options = { ...options, ...this.options };\n    $(this.tree.nativeElement).fancytree(options);\n    this.treeService.setTreeElement(this.tree.nativeElement);\n    if (this.options.showConnectors) {\n      $('.fancytree-container').addClass('fancytree-connectors');\n    }\n    setTimeout(() => {\n      this.treeService.reloadTree(this.rootNode);\n      this.treeService.setActiveNode();\n      const rootNode = this.treeService.getFirstChild();\n      rootNode.setExpanded(true);\n      this.eachNodeActionButton(rootNode);\n      this.dialcodeService.readExistingQrCode();\n    });\n    if (_.get(this.editorService, 'editorConfig.config.renderTaxonomy') === true && _.isEmpty(_.get(this.nodes, 'data.children'))) {\n      _.forEach(this.rootNode[0]?.children, (child) => {\n          this.treeService.updateTreeNodeMetadata(child.metadata, child.id, child.primaryCategory, child.objectType);\n          _.forEach(child.children, (el) => {\n            this.treeService.updateTreeNodeMetadata(el.metadata, el.id, el.primaryCategory, el.objectType);\n          });\n      });\n    }\n  }\n\n  getTreeConfig() {\n    const options: any = {\n      extensions: ['glyph', 'dnd5'],\n      clickFolderMode: 3,\n      source: this.rootNode,\n      escapeTitles: true,\n      glyph: {\n        preset: 'awesome4',\n        map: {\n          folder: 'icon folder sb-fancyTree-icon',\n          folderOpen: 'icon folder outline sb-fancyTree-icon'\n        }\n      },\n      dnd5: {\n        autoExpandMS: 400,\n        // focusOnClick: true,\n        preventVoidMoves: true, // Prevent dropping nodes 'before self', etc.\n        preventRecursion: true, // Prevent dropping nodes on own descendants\n        dragStart: (node, data) => {\n          /** This function MUST be defined to enable dragging for the tree.\n           *  Return false to cancel dragging of node.\n           */\n          const draggable = _.get(this.config, 'mode') === 'edit' ? true : false;\n          return draggable;\n        },\n        dragEnter: (node, data) => {\n          /** data.otherNode may be null for non-fancytree droppables.\n           *  Return false to disallow dropping on node. In this case\n           *  dragOver and dragLeave are not called.\n           *  Return 'over', 'before, or 'after' to force a hitMode.\n           *  Return ['before', 'after'] to restrict available hitModes.\n           *  Any other return value will calc the hitMode from the cursor position.\n           */\n          // Prevent dropping a parent below another parent (only sort\n          // nodes under the same parent)\n          /*           if(node.parent !== data.otherNode.parent){\n                      return false;\n                    }\n                    // Don't allow dropping *over* a node (would create a child)\n                    return [\"before\", \"after\"];\n          */\n          return true;\n        },\n        dragDrop: (node, data) => {\n          /** This function MUST be defined to enable dropping of items on\n           *  the tree.\n           */\n          // data.otherNode.moveTo(node, data.hitMode);\n          return this.dragDrop(node, data);\n        },\n        filter: {\n          autoApply: true,\n          autoExpand: false,\n          counter: true,\n          fuzzy: false,\n          hideExpandedCounter: true,\n          hideExpanders: false,\n          highlight: true,\n          leavesOnly: false,\n          nodata: true,\n          mode: 'dimm'\n        }\n      },\n      init: (event, data) => { },\n      click: (event, data): boolean => {\n        this.tree.nativeElement.click();\n        this.telemetryService.interact({ edata: this.getTelemetryInteractEdata() });\n        return true;\n      },\n      activate: (event, data) => {\n        this.treeEventEmitter.emit({ type: 'nodeSelect', data: data.node });\n        setTimeout(() => {\n          this.attachContextMenu(data.node, true);\n          this.eachNodeActionButton(data.node);\n        }, 10);\n      },\n      renderNode: (event, data) => {\n        const node = data.node;\n        const $nodeSpan = $(node.span);\n\n        // check if span of node already rendered\n        if (!$nodeSpan.data('rendered')) {\n          this.attachContextMenu(node);\n          // span rendered\n          $nodeSpan.data('rendered', true);\n        }\n      }\n    };\n    return options;\n  }\n\n  eachNodeActionButton(node) {\n    this.visibility = {};\n    if (this.bulkUploadProcessingStatus) {\n    this.visibility.addChild = false;\n    this.visibility.addSibling =  false;\n    this.visibility.addFromLibrary =  false;\n    this.visibility.addQuestionFromLibrary = false;\n    this.visibility.createNew =  false;\n    } else {\n      const nodeLevel = node.getLevel() - 1;\n      this.visibility.addChild = ((node.folder === false) || (nodeLevel >= this.config.maxDepth)) ? false : true;\n      // tslint:disable-next-line:max-line-length\n      this.visibility.addSibling = ((node.folder === true) && (!node.data.root) && !((node.getLevel() - 1) > this.config.maxDepth)) ? true : false;\n      if (nodeLevel === 0) {\n        this.visibility.addFromLibrary = _.isEmpty(_.get(this.config, 'children')) || _.get(this.config, 'enableQuestionCreation') === false ? false : true;\n        this.visibility.createNew = _.isEmpty(_.get(this.config, 'children')) || _.get(this.config, 'enableQuestionCreation') === false ? false : true;\n        this.visibility.addQuestionFromLibrary = !_.isEmpty(_.get(this.config, 'children')) && _.get(this.config, 'enableAddFromLibrary') === true ? true : false;\n      } else {\n        const hierarchylevelData = this.config.hierarchy[`level${nodeLevel}`];\n        // tslint:disable-next-line:max-line-length\n        this.visibility.addFromLibrary = ((node.folder === false) || _.isEmpty(_.get(hierarchylevelData, 'children')) || _.get(this.config, 'enableQuestionCreation') === false) ? false : true;\n        // tslint:disable-next-line:max-line-length\n        this.visibility.createNew = ((node.folder === false) || _.isEmpty(_.get(hierarchylevelData, 'children')) || _.get(this.config, 'enableQuestionCreation') === false) ? false : true;\n        this.visibility.addQuestionFromLibrary = ((node.folder === true) && !_.isEmpty(_.get(hierarchylevelData, 'children')) && _.get(this.config, 'enableAddFromLibrary') === true) ? true : false;\n      }\n    }\n    if (_.get(this.editorService, 'editorConfig.config.renderTaxonomy') === true) {\n      this.visibility.addChild = false;\n      this.visibility.addSibling = false;\n    }\n    this.cdr.detectChanges();\n  }\n\n  addChild() {\n    this.telemetryService.interact({ edata: this.getTelemetryInteractEdata('add_child') });\n    const tree = $(this.tree.nativeElement).fancytree('getTree');\n    const nodeConfig = this.config.hierarchy[tree.getActiveNode().getLevel()];\n    const childrenTypes = _.get(nodeConfig, 'children.Content');\n    if ((((tree.getActiveNode().getLevel() - 1) >= this.config.maxDepth))) {\n      return this.toasterService.error(_.get(this.configService, 'labelConfig.messages.error.007'));\n    }\n    this.treeService.addNode('child');\n  }\n\n  addSibling() {\n    this.telemetryService.interact({ edata: this.getTelemetryInteractEdata('add_sibling') });\n    const tree = $(this.tree.nativeElement).fancytree('getTree');\n\n    const node = tree.getActiveNode();\n    if (!node.data.root) {\n      this.treeService.addNode('sibling');\n    } else {\n      this.toasterService.error(_.get(this.configService, 'labelConfig.messages.error.007'));\n    }\n  }\n\n  getActiveNode() {\n    return $(this.tree.nativeElement).fancytree('getTree').getActiveNode();\n  }\n\n  attachContextMenu(node, activeNode?) {\n    if (_.get(this.config, 'mode') !== 'edit' || (node.data.root === true && _.isEmpty(this.config.hierarchy) )) {\n      return;\n    }\n    const $nodeSpan = $(node.span);\n    // tslint:disable-next-line:max-line-length   // TODO:: (node.data.contentType === 'CourseUnit') check this condition\n    const menuTemplate = node.data.root === true ? this.rootMenuTemplate : (node.data.root === false && node.folder === true  ? this.folderMenuTemplate : this.contentMenuTemplate);\n    const iconsButton = $(menuTemplate);\n    if ((node.getLevel() - 1) >= this.config.maxDepth) {\n      iconsButton.find('#addchild').remove();\n    }\n\n    let contextMenu = $($nodeSpan[0]).find(`#contextMenu`);\n\n    if (!contextMenu.length) {\n      $nodeSpan.append(iconsButton);\n\n      if (!activeNode) {\n        iconsButton.hide();\n      }\n\n      $nodeSpan[0].onmouseover = () => {\n        iconsButton.show();\n      };\n\n      $nodeSpan[0].onmouseout = () => {\n        iconsButton.hide();\n      };\n\n      contextMenu = $($nodeSpan[0]).find(`#contextMenu`);\n\n      contextMenu.on('click', (event) => {\n        this.treeService.closePrevOpenedDropDown();\n        setTimeout(() => {\n          const nSpan = $(this.getActiveNode().span);\n\n          const dropDownElement = $(nSpan[0]).find(`#contextMenuDropDown`);\n          dropDownElement.removeClass('hidden');\n          dropDownElement.addClass('visible');\n          _.forEach(_.get(_.first(dropDownElement), 'children'), item => {\n            item.addEventListener('click', (ev) => {\n              this.treeService.closePrevOpenedDropDown();\n              this.handleActionButtons(ev.currentTarget);\n              ev.stopPropagation();\n            });\n          });\n        }, 100);\n        // event.stopPropagation();\n      });\n\n      $($nodeSpan[0]).find(`#removeNodeIcon`).on('click', (event: any) => {\n        const isContent =  event.currentTarget.getAttribute('type') && event.currentTarget.getAttribute('type') === 'content';\n        this.removeNode(isContent);\n      });\n    }\n\n  }\n\n  dropNode(targetNode, currentNode) {\n\n    let dropAllowed;\n    dropAllowed = true;\n    // tslint:disable-next-line:max-line-length\n    if (currentNode.otherNode.getLevel() === targetNode.getLevel() && currentNode.otherNode.folder === true &&  currentNode.hitMode !== 'over') {\n      dropAllowed = true;\n    // tslint:disable-next-line:max-line-length\n    } else if (currentNode.otherNode.folder === true && (this.maxTreeDepth(currentNode.otherNode) + (targetNode.getLevel() - 1)) > _.get(this.config, 'maxDepth')) {\n      return this.dropNotAllowed();\n    } else if (currentNode.otherNode.folder === false && !this.checkContentAddition(targetNode, currentNode)) {\n      dropAllowed = false;\n    }\n\n    if (dropAllowed) {\n        currentNode.otherNode.moveTo(targetNode, currentNode.hitMode);\n        this.treeService.nextTreeStatus('reorder');\n        return true;\n    } else {\n        this.toasterService.warning(`${currentNode.otherNode.title} cannot be added to ${currentNode.node.title}`);\n        return false;\n    }\n\n  }\n\n  dragDrop(node, data) {\n    if ((data.hitMode === 'before' || data.hitMode === 'after' || data.hitMode === 'over') && data.node.data.root) {\n      return this.dropNotAllowed();\n    }\n    if (_.has(this.config, 'maxDepth')) {\n      return this.dropNode(node, data);\n    }\n  }\n\n  dropNotAllowed() {\n    this.toasterService.warning(_.get(this.configService, 'labelConfig.messages.error.007'));\n    return false;\n  }\n\n  maxTreeDepth(root) {\n    const buffer = [{ node: root, depth: 1 }];\n    let current = buffer.pop();\n    let max = 0;\n\n    while (current && current.node) {\n      // Find all children of this node.\n      _.forEach(current.node.children, (child) => {\n        buffer.push({ node: child, depth: current.depth + 1 });\n      });\n      if (current.depth > max) {\n        max = current.depth;\n      }\n      current = buffer.pop();\n    }\n    return max;\n  }\n\n  checkContentAddition(targetNode, contentNode): boolean {\n    if (targetNode.folder === false && (contentNode.hitMode === 'before' || contentNode.hitMode === 'after')) {\n      return true;\n    }\n    if (targetNode.folder === false && contentNode.hitMode === 'over') {\n      return false;\n    }\n    const nodeConfig = this.config.hierarchy[`level${targetNode.getLevel() - 1}`];\n    const contentPrimaryCategories = _.flatMap(_.get(nodeConfig, 'children'));\n    if (!_.isEmpty(contentPrimaryCategories)) {\n      return _.includes(contentPrimaryCategories, _.get(contentNode, 'otherNode.data.metadata.primaryCategory')) ? true : false;\n    }\n    return false;\n  }\n\n  removeNode(isContent?: boolean) {\n    this.treeEventEmitter.emit({ type: 'deleteNode', isContent });\n    this.telemetryService.interact({ edata: this.getTelemetryInteractEdata('delete') });\n  }\n\n  handleActionButtons(el) {\n    console.log('action buttons -------->', el.id);\n    switch (el.id) {\n      case 'edit':\n        break;\n      case 'delete':\n        this.removeNode();\n        break;\n      case 'addsibling':\n        this.addSibling();\n        break;\n      case 'addchild':\n        this.addChild();\n        break;\n      case 'addresource':\n        break;\n    }\n  }\n\n  addFromLibrary() {\n    this.editorService.emitshowLibraryPageEvent('showLibraryPage');\n  }\n  getTelemetryInteractEdata(id?) {\n    return {\n      id: id || 'collection-toc',\n      type: 'click',\n      subtype: 'launch',\n      pageid: this.telemetryService.telemetryPageId,\n      extra: {\n        values: [_.get(this.getActiveNode(), 'data')]\n      }\n    };\n  }\n\n  createNewContent() {\n    this.treeEventEmitter.emit({ type: 'createNewContent' });\n  }\n\n  ngOnDestroy() {\n    this.onComponentDestroy$.next();\n    this.onComponentDestroy$.complete();\n  }\n}","<div #fancyTree></div>\n<div class=\"sb-fixed-with-whitebg pr-20 d-flex flex-jc-space-between\" *ngIf=\"config && config.mode === 'edit'\">\n  <div class=\"d-flex w-25\">\n    <div class=\"sb-btn-cover\">\n      <button [ngClass]=\"visibility?.addSibling ? '' : 'sb-disabled'\" (click)=\"addSibling();\"\n        class=\"sb-btn sb-btn-outline-primary sb-btn-normal sb-btn-radius p-0 b-none\"><i aria-hidden=\"true\" class=\"icon plus\"></i>\n        {{configService.labelConfig?.button_labels?.add_sibling_btn_label}} </button>\n    </div>\n    <div class=\"sb-btn-cover\">\n      <button [ngClass]=\"visibility?.addChild ? '' : 'sb-disabled'\" (click)=\"addChild();\"\n        class=\"sb-btn sb-btn-outline-primary sb-btn-normal sb-btn-radius b-none p-0\"><i class=\"icon plus\"></i>\n        {{configService.labelConfig?.button_labels?.add_child_btn_label}} </button>\n    </div>\n  </div>\n  <button *ngIf=\"config.objectType !== 'QuestionSet'\" (click)=\"addFromLibrary();\"\n    [disabled]=\"!visibility?.addFromLibrary\"\n    [ngClass]=\"[!visibility?.addFromLibrary ? 'sb-btn-outline-disabled' : '', (visibility?.addFromLibrary && buttonLoaders?.addFromLibraryButtonLoader) ? 'sb-btn-loading-spinner sb-btn-outline-disabled': '']\"\n    class=\"sb-btn sb-btn-outline-primary sb-btn-normal mt-10 mr-30\" libTelemetryInteract\n    [telemetryInteractEdata]=\"telemetryService.getTelemetryInteractEdata('add_from_library','click','launch', telemetryService.telemetryPageId)\">\n    <i class=\"icon plus\" aria-hidden=\"true\" *ngIf=\"!buttonLoaders?.addFromLibraryButtonLoader\"></i>\n    <div class=\"sb-loading-spinner\" *ngIf=\"buttonLoaders?.addFromLibraryButtonLoader\" role=\"status\" aria-hidden=\"true\">\n    </div>\n    {{configService.labelConfig?.button_labels?.add_from_library_btn_label}}\n  </button>\n  <button *ngIf=\"config.objectType === 'QuestionSet'\" [disabled]=\"!visibility?.createNew\"\n    [ngClass]=\"[!visibility?.createNew ? 'sb-btn-outline-disabled' : '', (visibility?.createNew && buttonLoaders?.addFromLibraryButtonLoader) ? 'sb-btn-loading-spinner sb-btn-outline-disabled': '']\"\n    type=\"button\" class=\"sb-btn sb-btn-normal sb-btn-primary mt-10 mr-30\" (click)=\"createNewContent()\"\n    libTelemetryInteract\n    [telemetryInteractEdata]=\"telemetryService.getTelemetryInteractEdata('create_new','click','launch', telemetryService.telemetryPageId)\">\n    <i class=\"icon plus\" *ngIf=\"!buttonLoaders?.addFromLibraryButtonLoader\"></i>\n    <div class=\"sb-loading-spinner\" *ngIf=\"buttonLoaders?.addFromLibraryButtonLoader\" role=\"status\" aria-hidden=\"true\">\n    </div>\n    {{configService.labelConfig?.button_labels?.create_new_btn_label}}\n  </button>\n</div>"]}
|