@sunbird-cb/tree-hierarchy 0.0.1-cbrelease-4.8.26
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/components/action-bar/action-bar.component.mjs +41 -0
- package/esm2022/lib/components/approval/approval.component.mjs +19 -0
- package/esm2022/lib/components/approve-view/approve-view.component.mjs +64 -0
- package/esm2022/lib/components/categories-preview/categories-preview.component.mjs +44 -0
- package/esm2022/lib/components/conforamtion-popup/conforamtion-popup.component.mjs +74 -0
- package/esm2022/lib/components/connector/connector.component.mjs +59 -0
- package/esm2022/lib/components/create-categories/create-categories.component.mjs +83 -0
- package/esm2022/lib/components/create-term/create-term.component.mjs +847 -0
- package/esm2022/lib/components/create-term-from-framework/create-term-from-framework.component.mjs +823 -0
- package/esm2022/lib/components/org-hierarchy-add-modal/org-hierarchy-add-modal.component.mjs +149 -0
- package/esm2022/lib/components/pending-approval/pending-approval.component.mjs +64 -0
- package/esm2022/lib/components/term-card/term-card.component.mjs +311 -0
- package/esm2022/lib/components/tree-column-view/tree-column-view.component.mjs +322 -0
- package/esm2022/lib/components/tree-view/tree-view.component.mjs +497 -0
- package/esm2022/lib/constants/app-constant.mjs +40 -0
- package/esm2022/lib/constants/data.mjs +6972 -0
- package/esm2022/lib/containers/config-framework/config-framework.component.mjs +92 -0
- package/esm2022/lib/containers/dashboard/dashboard.component.mjs +14 -0
- package/esm2022/lib/labels/strings.mjs +40 -0
- package/esm2022/lib/models/approval.model.mjs +2 -0
- package/esm2022/lib/models/connection-type.model.mjs +2 -0
- package/esm2022/lib/models/connection.model.mjs +2 -0
- package/esm2022/lib/models/framework.model.mjs +2 -0
- package/esm2022/lib/models/variable-type.model.mjs +2 -0
- package/esm2022/lib/pipes/order-by.pipe.mjs +35 -0
- package/esm2022/lib/services/approval.service.mjs +47 -0
- package/esm2022/lib/services/connection.service.mjs +3 -0
- package/esm2022/lib/services/connector.service.mjs +240 -0
- package/esm2022/lib/services/framework.service.mjs +387 -0
- package/esm2022/lib/services/local-connection.service.mjs +75 -0
- package/esm2022/lib/services/odcs.service.mjs +23 -0
- package/esm2022/lib/tree-hierarchy-routing.module.mjs +43 -0
- package/esm2022/lib/tree-hierarchy.component.mjs +24 -0
- package/esm2022/lib/tree-hierarchy.module.mjs +138 -0
- package/esm2022/lib/tree-hierarchy.service.mjs +41 -0
- package/esm2022/material.module.mjs +199 -0
- package/esm2022/public-api.mjs +9 -0
- package/esm2022/sunbird-cb-tree-hierarchy.mjs +2 -0
- package/fesm2022/sunbird-cb-tree-hierarchy.mjs +11577 -0
- package/fesm2022/sunbird-cb-tree-hierarchy.mjs.map +1 -0
- package/index.d.ts +3 -0
- package/lib/components/action-bar/action-bar.component.d.ts +17 -0
- package/lib/components/action-bar/action-bar.component.d.ts.map +1 -0
- package/lib/components/approval/approval.component.d.ts +10 -0
- package/lib/components/approval/approval.component.d.ts.map +1 -0
- package/lib/components/approve-view/approve-view.component.d.ts +27 -0
- package/lib/components/approve-view/approve-view.component.d.ts.map +1 -0
- package/lib/components/categories-preview/categories-preview.component.d.ts +14 -0
- package/lib/components/categories-preview/categories-preview.component.d.ts.map +1 -0
- package/lib/components/conforamtion-popup/conforamtion-popup.component.d.ts +20 -0
- package/lib/components/conforamtion-popup/conforamtion-popup.component.d.ts.map +1 -0
- package/lib/components/connector/connector.component.d.ts +23 -0
- package/lib/components/connector/connector.component.d.ts.map +1 -0
- package/lib/components/create-categories/create-categories.component.d.ts +26 -0
- package/lib/components/create-categories/create-categories.component.d.ts.map +1 -0
- package/lib/components/create-term/create-term.component.d.ts +148 -0
- package/lib/components/create-term/create-term.component.d.ts.map +1 -0
- package/lib/components/create-term-from-framework/create-term-from-framework.component.d.ts +105 -0
- package/lib/components/create-term-from-framework/create-term-from-framework.component.d.ts.map +1 -0
- package/lib/components/org-hierarchy-add-modal/org-hierarchy-add-modal.component.d.ts +31 -0
- package/lib/components/org-hierarchy-add-modal/org-hierarchy-add-modal.component.d.ts.map +1 -0
- package/lib/components/pending-approval/pending-approval.component.d.ts +21 -0
- package/lib/components/pending-approval/pending-approval.component.d.ts.map +1 -0
- package/lib/components/term-card/term-card.component.d.ts +43 -0
- package/lib/components/term-card/term-card.component.d.ts.map +1 -0
- package/lib/components/tree-column-view/tree-column-view.component.d.ts +52 -0
- package/lib/components/tree-column-view/tree-column-view.component.d.ts.map +1 -0
- package/lib/components/tree-view/tree-view.component.d.ts +91 -0
- package/lib/components/tree-view/tree-view.component.d.ts.map +1 -0
- package/lib/constants/app-constant.d.ts +44 -0
- package/lib/constants/app-constant.d.ts.map +1 -0
- package/lib/constants/data.d.ts +117 -0
- package/lib/constants/data.d.ts.map +1 -0
- package/lib/containers/config-framework/config-framework.component.d.ts +32 -0
- package/lib/containers/config-framework/config-framework.component.d.ts.map +1 -0
- package/lib/containers/dashboard/dashboard.component.d.ts +9 -0
- package/lib/containers/dashboard/dashboard.component.d.ts.map +1 -0
- package/lib/labels/strings.d.ts +40 -0
- package/lib/labels/strings.d.ts.map +1 -0
- package/lib/models/approval.model.d.ts +11 -0
- package/lib/models/approval.model.d.ts.map +1 -0
- package/lib/models/connection-type.model.d.ts +6 -0
- package/lib/models/connection-type.model.d.ts.map +1 -0
- package/lib/models/connection.model.d.ts +7 -0
- package/lib/models/connection.model.d.ts.map +1 -0
- package/lib/models/framework.model.d.ts +88 -0
- package/lib/models/framework.model.d.ts.map +1 -0
- package/lib/models/variable-type.model.d.ts +46 -0
- package/lib/models/variable-type.model.d.ts.map +1 -0
- package/lib/pipes/order-by.pipe.d.ts +10 -0
- package/lib/pipes/order-by.pipe.d.ts.map +1 -0
- package/lib/services/approval.service.d.ts +21 -0
- package/lib/services/approval.service.d.ts.map +1 -0
- package/lib/services/connection.service.d.ts +4 -0
- package/lib/services/connection.service.d.ts.map +1 -0
- package/lib/services/connector.service.d.ts +17 -0
- package/lib/services/connector.service.d.ts.map +1 -0
- package/lib/services/framework.service.d.ts +82 -0
- package/lib/services/framework.service.d.ts.map +1 -0
- package/lib/services/local-connection.service.d.ts +18 -0
- package/lib/services/local-connection.service.d.ts.map +1 -0
- package/lib/services/odcs.service.d.ts +11 -0
- package/lib/services/odcs.service.d.ts.map +1 -0
- package/lib/tree-hierarchy-routing.module.d.ts +8 -0
- package/lib/tree-hierarchy-routing.module.d.ts.map +1 -0
- package/lib/tree-hierarchy.component.d.ts +13 -0
- package/lib/tree-hierarchy.component.d.ts.map +1 -0
- package/lib/tree-hierarchy.module.d.ts +31 -0
- package/lib/tree-hierarchy.module.d.ts.map +1 -0
- package/lib/tree-hierarchy.service.d.ts +17 -0
- package/lib/tree-hierarchy.service.d.ts.map +1 -0
- package/material.module.d.ts +52 -0
- package/material.module.d.ts.map +1 -0
- package/package.json +43 -0
- package/public-api.d.ts +9 -0
- package/public-api.d.ts.map +1 -0
- package/sunbird-cb-tree-hierarchy.d.ts.map +1 -0
|
@@ -0,0 +1,311 @@
|
|
|
1
|
+
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
2
|
+
import { labels } from '../../labels/strings';
|
|
3
|
+
import { CreateTermComponent } from '../create-term/create-term.component';
|
|
4
|
+
import { CreateTermFromFrameworkComponent } from './../create-term-from-framework/create-term-from-framework.component';
|
|
5
|
+
import { ConforamtionPopupComponent } from '../conforamtion-popup/conforamtion-popup.component';
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
import * as i1 from "../../services/framework.service";
|
|
8
|
+
import * as i2 from "../../services/local-connection.service";
|
|
9
|
+
import * as i3 from "../../services/approval.service";
|
|
10
|
+
import * as i4 from "@angular/material/legacy-dialog";
|
|
11
|
+
import * as i5 from "@angular/common";
|
|
12
|
+
import * as i6 from "@angular/material/button";
|
|
13
|
+
import * as i7 from "@angular/material/icon";
|
|
14
|
+
import * as i8 from "@angular/material/menu";
|
|
15
|
+
export class TermCardComponent {
|
|
16
|
+
set data(value) {
|
|
17
|
+
this._data = value;
|
|
18
|
+
this._data.children.highlight = false;
|
|
19
|
+
}
|
|
20
|
+
get data() {
|
|
21
|
+
return this._data;
|
|
22
|
+
}
|
|
23
|
+
constructor(frameworkService, localConnectionService, approvalService, dialog) {
|
|
24
|
+
this.frameworkService = frameworkService;
|
|
25
|
+
this.localConnectionService = localConnectionService;
|
|
26
|
+
this.approvalService = approvalService;
|
|
27
|
+
this.dialog = dialog;
|
|
28
|
+
this.isApprovalRequired = false;
|
|
29
|
+
this.approvalList = [];
|
|
30
|
+
this.heightLighted = [];
|
|
31
|
+
this.app_strings = labels;
|
|
32
|
+
this.loaded = {};
|
|
33
|
+
this.isSelected = new EventEmitter();
|
|
34
|
+
this.selectedCard = new EventEmitter();
|
|
35
|
+
}
|
|
36
|
+
ngOnInit() {
|
|
37
|
+
this.isApprovalRequired = this.localConnectionService.getConfigInfo().isApprovalRequired;
|
|
38
|
+
this.updateApprovalStatus();
|
|
39
|
+
this.subscription = this.frameworkService.insertUpdateDeleteNotifier.subscribe((e) => {
|
|
40
|
+
if (e) {
|
|
41
|
+
this.isCompetencyArea = e.action;
|
|
42
|
+
}
|
|
43
|
+
});
|
|
44
|
+
this.environment = this.frameworkService.getEnviroment();
|
|
45
|
+
}
|
|
46
|
+
cardClicked(data, cardRef) {
|
|
47
|
+
if (data.category != 'subtheme') {
|
|
48
|
+
this.frameworkService.cardClkData = data;
|
|
49
|
+
this.frameworkService.CurrentCardClk.next(data.category);
|
|
50
|
+
}
|
|
51
|
+
if (this.frameworkService.isLastColumn(this.data.category)) {
|
|
52
|
+
return;
|
|
53
|
+
}
|
|
54
|
+
this.isSelected.emit({ element: this.data.children, isSelected: !data.selected });
|
|
55
|
+
this.frameworkService.currentSelection.next({ type: this.data.category, data: data.children, cardRef });
|
|
56
|
+
}
|
|
57
|
+
handleProductClick(term, event) {
|
|
58
|
+
this.selectedCard.emit({ term: term, checked: event.checked });
|
|
59
|
+
}
|
|
60
|
+
updateApprovalStatus() {
|
|
61
|
+
const id = this._data.children.identifier;
|
|
62
|
+
this.approvalService.getUpdateList().subscribe((list) => {
|
|
63
|
+
this.approvalList = list.map((item) => item.identifier);
|
|
64
|
+
if (this.approvalList) {
|
|
65
|
+
if (this.approvalList.includes(id)) {
|
|
66
|
+
this._data.children.highlight = true;
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
});
|
|
70
|
+
}
|
|
71
|
+
getColor(indexClass, cardRef, property, data) {
|
|
72
|
+
let config = this.frameworkService.getConfig(data.category);
|
|
73
|
+
if (cardRef.classList.contains('selected') && property === 'bgColor') {
|
|
74
|
+
return config.color;
|
|
75
|
+
}
|
|
76
|
+
if (property === 'border') {
|
|
77
|
+
let borderColor;
|
|
78
|
+
if (cardRef.classList.contains((indexClass).toString())) {
|
|
79
|
+
borderColor = "8px solid" + config.color;
|
|
80
|
+
}
|
|
81
|
+
return borderColor;
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
view(data, childrenData, index) {
|
|
85
|
+
let dialog;
|
|
86
|
+
const selectedTerms = this.frameworkService.getPreviousSelectedTerms(data.columnInfo.code);
|
|
87
|
+
const nexColInfo = this.getNextCat(data);
|
|
88
|
+
const nextCat = nexColInfo || data.columnInfo;
|
|
89
|
+
if (nextCat && this.environment && this.environment.frameworkType === 'MDO_DESIGNATION') {
|
|
90
|
+
const nextNextCat = this.frameworkService.getNextCategory(nextCat.code);
|
|
91
|
+
const selectedTerms = this.frameworkService.getPreviousSelectedTerms(nextCat.code);
|
|
92
|
+
const colInfo = Array.from(this.frameworkService.list.values()).filter(l => l.code === nextCat.code);
|
|
93
|
+
let nextColInfo = [];
|
|
94
|
+
if (nextNextCat && nextNextCat.code) {
|
|
95
|
+
nextColInfo = Array.from(this.frameworkService.list.values()).filter(l => l.code === nextNextCat.code);
|
|
96
|
+
}
|
|
97
|
+
dialog = this.dialog.open(CreateTermFromFrameworkComponent, {
|
|
98
|
+
data: {
|
|
99
|
+
mode: 'multi-create',
|
|
100
|
+
openMode: 'view',
|
|
101
|
+
cardColInfo: this.data.columnInfo,
|
|
102
|
+
columnInfo: colInfo && colInfo.length ? colInfo[0] : [],
|
|
103
|
+
nextColInfo: nextColInfo && nextColInfo.length ? nextColInfo[0] : [],
|
|
104
|
+
frameworkId: this.frameworkService.getFrameworkId(),
|
|
105
|
+
selectedparents: this.heightLighted,
|
|
106
|
+
colIndex: nextCat.index,
|
|
107
|
+
childrenData: data.children,
|
|
108
|
+
selectedParentTerms: selectedTerms
|
|
109
|
+
},
|
|
110
|
+
width: '800px',
|
|
111
|
+
panelClass: 'custom-dialog-container'
|
|
112
|
+
});
|
|
113
|
+
}
|
|
114
|
+
else {
|
|
115
|
+
dialog = this.dialog.open(CreateTermComponent, {
|
|
116
|
+
data: {
|
|
117
|
+
mode: 'view',
|
|
118
|
+
columnInfo: this.data.columnInfo,
|
|
119
|
+
frameworkId: this.frameworkService.getFrameworkId(),
|
|
120
|
+
selectedparents: this.heightLighted,
|
|
121
|
+
colIndex: index,
|
|
122
|
+
childrenData: childrenData,
|
|
123
|
+
selectedParentTerms: selectedTerms
|
|
124
|
+
},
|
|
125
|
+
width: '800px',
|
|
126
|
+
panelClass: 'custom-dialog-container'
|
|
127
|
+
});
|
|
128
|
+
}
|
|
129
|
+
dialog.afterClosed().subscribe((res) => {
|
|
130
|
+
if (!res) {
|
|
131
|
+
return;
|
|
132
|
+
}
|
|
133
|
+
});
|
|
134
|
+
}
|
|
135
|
+
edit(data, childrenData, index, cardRef) {
|
|
136
|
+
let dialog;
|
|
137
|
+
const selectedTerms = this.frameworkService.getPreviousSelectedTerms(data.columnInfo.code);
|
|
138
|
+
const nexColInfo = this.getNextCat(data);
|
|
139
|
+
const nextCat = nexColInfo || data.columnInfo;
|
|
140
|
+
if (nextCat && this.environment && this.environment.frameworkType === 'MDO_DESIGNATION') {
|
|
141
|
+
this.create(data, 'edit');
|
|
142
|
+
}
|
|
143
|
+
else {
|
|
144
|
+
dialog = this.dialog.open(CreateTermComponent, {
|
|
145
|
+
data: {
|
|
146
|
+
mode: 'edit',
|
|
147
|
+
columnInfo: data.columnInfo,
|
|
148
|
+
frameworkId: this.frameworkService.getFrameworkId(),
|
|
149
|
+
selectedparents: this.heightLighted,
|
|
150
|
+
colIndex: index,
|
|
151
|
+
childrenData: childrenData,
|
|
152
|
+
selectedParentTerms: selectedTerms,
|
|
153
|
+
cardRef: cardRef
|
|
154
|
+
},
|
|
155
|
+
width: '800px',
|
|
156
|
+
panelClass: 'custom-dialog-container'
|
|
157
|
+
});
|
|
158
|
+
}
|
|
159
|
+
dialog.afterClosed().subscribe((res) => {
|
|
160
|
+
if (!res) {
|
|
161
|
+
return;
|
|
162
|
+
}
|
|
163
|
+
setTimeout(() => {
|
|
164
|
+
window.dispatchEvent(new Event('resize'));
|
|
165
|
+
}, 100);
|
|
166
|
+
});
|
|
167
|
+
}
|
|
168
|
+
create(data, mode) {
|
|
169
|
+
const nexColInfo = this.getNextCat(data);
|
|
170
|
+
const nextCat = nexColInfo || data.columnInfo;
|
|
171
|
+
const nextNextCat = this.frameworkService.getNextCategory(nextCat.code);
|
|
172
|
+
if (nextCat) {
|
|
173
|
+
const selectedTerms = this.frameworkService.getPreviousSelectedTerms(nextCat.code);
|
|
174
|
+
const colInfo = Array.from(this.frameworkService.list.values()).filter(l => l.code === nextCat.code);
|
|
175
|
+
let nextColInfo = [];
|
|
176
|
+
if (nextNextCat && nextNextCat.code) {
|
|
177
|
+
nextColInfo = Array.from(this.frameworkService.list.values()).filter(l => l.code === nextNextCat.code);
|
|
178
|
+
}
|
|
179
|
+
let dialog;
|
|
180
|
+
if (this.environment && this.environment.frameworkType === 'MDO_DESIGNATION') {
|
|
181
|
+
dialog = this.dialog.open(CreateTermFromFrameworkComponent, {
|
|
182
|
+
data: {
|
|
183
|
+
mode: 'multi-create',
|
|
184
|
+
openMode: mode || 'add',
|
|
185
|
+
cardColInfo: this.data.columnInfo,
|
|
186
|
+
columnInfo: colInfo && colInfo.length ? colInfo[0] : [],
|
|
187
|
+
nextColInfo: nextColInfo && nextColInfo.length ? nextColInfo[0] : [],
|
|
188
|
+
frameworkId: this.frameworkService.getFrameworkId(),
|
|
189
|
+
selectedparents: this.heightLighted,
|
|
190
|
+
colIndex: nextCat.index,
|
|
191
|
+
childrenData: data.children,
|
|
192
|
+
selectedParentTerms: selectedTerms
|
|
193
|
+
},
|
|
194
|
+
width: '800px',
|
|
195
|
+
panelClass: 'custom-dialog-container'
|
|
196
|
+
});
|
|
197
|
+
}
|
|
198
|
+
else {
|
|
199
|
+
dialog = this.dialog.open(CreateTermComponent, {
|
|
200
|
+
data: {
|
|
201
|
+
mode: 'multi-create',
|
|
202
|
+
columnInfo: colInfo && colInfo.length ? colInfo[0] : [],
|
|
203
|
+
frameworkId: this.frameworkService.getFrameworkId(),
|
|
204
|
+
selectedparents: this.heightLighted,
|
|
205
|
+
colIndex: nextCat.index,
|
|
206
|
+
childrenData: data.children,
|
|
207
|
+
selectedParentTerms: selectedTerms
|
|
208
|
+
},
|
|
209
|
+
width: '800px',
|
|
210
|
+
panelClass: 'custom-dialog-container'
|
|
211
|
+
});
|
|
212
|
+
}
|
|
213
|
+
dialog.afterClosed().subscribe((res) => {
|
|
214
|
+
if (!res) {
|
|
215
|
+
return;
|
|
216
|
+
}
|
|
217
|
+
const responseData = {
|
|
218
|
+
res,
|
|
219
|
+
index: nextCat.index,
|
|
220
|
+
data,
|
|
221
|
+
type: 'multi-create'
|
|
222
|
+
};
|
|
223
|
+
if (!(res && res.stopUpdate)) {
|
|
224
|
+
this.frameworkService.updateAfterAddOrEditSubject(responseData);
|
|
225
|
+
}
|
|
226
|
+
setTimeout(() => {
|
|
227
|
+
window.dispatchEvent(new Event('resize'));
|
|
228
|
+
}, 100);
|
|
229
|
+
});
|
|
230
|
+
}
|
|
231
|
+
}
|
|
232
|
+
getNextCatName(data) {
|
|
233
|
+
if (data && data.columnInfo && data.columnInfo.code) {
|
|
234
|
+
const nextCat = this.frameworkService.getNextCategory(data.columnInfo.code);
|
|
235
|
+
if (nextCat && nextCat.code) {
|
|
236
|
+
return nextCat.code;
|
|
237
|
+
}
|
|
238
|
+
}
|
|
239
|
+
return null;
|
|
240
|
+
}
|
|
241
|
+
getNextCat(data) {
|
|
242
|
+
if (data && data.columnInfo && data.columnInfo.code) {
|
|
243
|
+
const nextCat = this.frameworkService.getNextCategory(data.columnInfo.code);
|
|
244
|
+
return nextCat;
|
|
245
|
+
}
|
|
246
|
+
return null;
|
|
247
|
+
}
|
|
248
|
+
ngOnDestroy() {
|
|
249
|
+
if (this.subscription) {
|
|
250
|
+
this.subscription.unsubscribe();
|
|
251
|
+
}
|
|
252
|
+
}
|
|
253
|
+
delete(data) {
|
|
254
|
+
const dialogData = {
|
|
255
|
+
dialogType: 'warning',
|
|
256
|
+
dialogAction: 'retire',
|
|
257
|
+
descriptions: [
|
|
258
|
+
{
|
|
259
|
+
header: `Competency ${data.category === "subtheme" ? 'sub-theme' : 'theme'} will be deleted`,
|
|
260
|
+
headerClass: 'flex items-center justify-center text-blue textBold',
|
|
261
|
+
messages: [
|
|
262
|
+
{
|
|
263
|
+
msgClass: 'mb-2 mt-2',
|
|
264
|
+
msg: `Do you want to proceed?`,
|
|
265
|
+
},
|
|
266
|
+
],
|
|
267
|
+
},
|
|
268
|
+
],
|
|
269
|
+
footerClass: 'items-center justify-center',
|
|
270
|
+
buttons: [
|
|
271
|
+
{
|
|
272
|
+
btnText: 'No',
|
|
273
|
+
btnClass: 'btn-outline',
|
|
274
|
+
response: false,
|
|
275
|
+
},
|
|
276
|
+
{
|
|
277
|
+
btnText: 'Yes',
|
|
278
|
+
btnClass: 'btn-full-success',
|
|
279
|
+
response: true,
|
|
280
|
+
},
|
|
281
|
+
],
|
|
282
|
+
cardInfo: data
|
|
283
|
+
};
|
|
284
|
+
let dialog = this.dialog.open(ConforamtionPopupComponent, {
|
|
285
|
+
data: dialogData,
|
|
286
|
+
autoFocus: false,
|
|
287
|
+
width: '500px',
|
|
288
|
+
maxWidth: '80vw',
|
|
289
|
+
maxHeight: '90vh',
|
|
290
|
+
disableClose: true
|
|
291
|
+
});
|
|
292
|
+
dialog.afterClosed().subscribe(_res => {
|
|
293
|
+
setTimeout(() => {
|
|
294
|
+
window.dispatchEvent(new Event('resize'));
|
|
295
|
+
}, 100);
|
|
296
|
+
});
|
|
297
|
+
}
|
|
298
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TermCardComponent, deps: [{ token: i1.FrameworkService }, { token: i2.LocalConnectionService }, { token: i3.ApprovalService }, { token: i4.MatLegacyDialog }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
299
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TermCardComponent, selector: "lib-term-card", inputs: { data: "data" }, outputs: { isSelected: "isSelected", selectedCard: "selectedCard" }, ngImport: i0, template: "<ng-container [ngSwitch]=\"( (data && data?.cardSubType) || 'cardMinimal')\">\n <ng-container *ngSwitchCase=\"'standard'\" [ngTemplateOutlet]=\"cardStandard\"></ng-container>\n <ng-container *ngSwitchCase=\"'space-saving'\" [ngTemplateOutlet]=\"cardSpaceSaving\"></ng-container>\n <ng-container *ngSwitchDefault [ngTemplateOutlet]=\"cardMinimal\"></ng-container>\n</ng-container>\n\n<ng-template #cardMinimal>\n <div #cardRef class=\"term-card clickable {{data.index}}\" (click)=\"cardClicked(data, cardRef)\"\n [ngClass]=\"[data.children.selected?'selected':'', data.children.approvalStatus === 'Draft'? 'inDraft':'',\n data.children.associationProperties?.approvalStatus === 'Draft' && isApprovalRequired && !approvalList.length || data.children.highlight && isApprovalRequired ? 'inAssociationDraft':'']\"\n id=\"{{data.children.name}}\"\n [ngStyle]=\"{'background-color':getColor(data.index,cardRef,'bgColor',data)}\">\n <!-- (click)=\"data.selected=!data.selected\" --> \n <div class=\"term-card-parent\">\n <!-- <Below element is to show id on top left of the card> -->\n <!-- <div class=\"id\" [hidden]=\"true\">{{data.children.code}}</div> -->\n \n <div class=\"term-card-content\">\n <!-- <ng-container *ngIf=\"data?.children?.refId\">\n <div class=\"ribbon\">{{data?.children?.refId}}</div>\n </ng-container> -->\n\n <ng-container *ngIf=\"data?.children?.additionalProperties?.competencyArea?.name\">\n <div class=\"mb-2\">\n <span class=\"comp-area {{data?.children?.additionalProperties?.competencyArea?.name?.toLowerCase()}}\">{{data?.children?.additionalProperties?.competencyArea?.name}}</span>\n </div>\n </ng-container>\n <div class=\"card-title\">{{data.children.name}}\n <ng-container *ngIf=\"data?.children?.refId\">\n <div class=\"refIdCard mt-2\">\n <span>{{data?.children?.refId}} </span>\n </div>\n </ng-container> \n </div>\n <!-- <ng-container *ngIf=\"data?.children?.refId\">\n <div class=\"refIdCard px-4\">\n <span>{{data?.children?.refId}} </span>\n </div>\n </ng-container> -->\n <!-- <span>++{{data.children.selected}}+++</span>\n <span>=={{data.children.status}}==</span> -->\n <div class=\"card-description\">{{data.children.description}} </div>\n </div>\n </div>\n\n <!-- <p>{{data.children.approvalStatus}}, {{data.children.associationProperties?.approvalStatus}}</p> -->\n <!-- *ngIf=\"!data.isViewOnly && data.children.approvalStatus === 'Draft' && isApprovalRequired\" -->\n\n <!-- (click)=\"$event.stopPropagation();\" -->\n <ng-container *ngIf=\"data?.columnInfo?.config?.enableThreeDot\" >\n <button type=\"button\" mat-icon-button i18n-aria-label aria-label=\"action items\"\n [matMenuTriggerFor]=\"orgMenu\" [matMenuTriggerData]=\"{'data':data, 'cardRef': cardRef}\" class=\"action-btn\">\n <mat-icon>more_vert</mat-icon>\n </button>\n </ng-container>\n <!-- <div class=\"term-card-checkbox\">\n <mat-checkbox color=\"primary\" *ngIf=\"data.children.approvalStatus === 'Draft' && isApprovalRequired && !approvalList.length || \n data.children.associationProperties?.approvalStatus === 'Draft' && isApprovalRequired && !approvalList.length ||\n data.children.highlight && isApprovalRequired\" [checked]=\"data.children.highlight\" class=\"termSelection\"\n (change)=\"handleProductClick(data.children, $event)\" (click)=\"$event.stopPropagation()\"></mat-checkbox>\n <mat-icon color=\"primary\" class=\"approve-flag\"\n *ngIf=\"data.children.highlight && isApprovalRequired\">{{app_strings.flag}}</mat-icon>\n </div> -->\n </div>\n</ng-template>\n\n<ng-template #cardStandard>\n <div>\n {{data.children.name}}\n </div>\n <div>\n {{data.children.description}}\n </div>\n</ng-template>\n\n<ng-template #cardSpaceSaving>\n <div>\n {{data.children.name}}\n </div>\n</ng-template>\n\n<mat-menu #cardMenu=\"matMenu\" class=\"menu-sec\">\n <ng-template matMenuContent let-rowData=\"data\" let-cardRef=\"cardRef\">\n <!-- <div > -->\n <button *ngIf=\"data.columnInfo.config.enableView\" (click)=\"view(data, data.children, data.index)\" mat-menu-item name=\"channel-analytics-button\"\n class=\"ws-mat-primary-text\" i18n-aria-label aria-label=\"Analytics\">\n <mat-icon>visibility</mat-icon> <span>View</span>\n </button>\n <button *ngIf=\"data.columnInfo.config.enabaleEdit\" (click)=\"edit(data, data.children,data.index, cardRef)\"\n mat-menu-item name=\"channel-analytics-button\" class=\"ws-mat-primary-text\" i18n-aria-label\n aria-label=\"Analytics\">\n <mat-icon>edit</mat-icon>\n <span>Edit</span>\n </button>\n <button *ngIf=\"data.columnInfo.config.enableAdd\" (click)=\"create(data)\"\n mat-menu-item name=\"channel-analytics-button\" class=\"ws-mat-primary-text\" i18n-aria-label\n aria-label=\"Analytics\">\n <mat-icon>add</mat-icon>\n <span>Add</span>\n </button>\n <button *ngIf=\"data.columnInfo.config.enableDelete\" (click)=\"delete(data)\"\n mat-menu-item name=\"channel-analytics-button\" class=\"ws-mat-primary-text\" i18n-aria-label\n aria-label=\"Analytics\">\n <mat-icon>delete</mat-icon>\n <span>Delete</span>\n </button>\n </ng-template>\n</mat-menu>\n\n<mat-menu #orgMenu=\"matMenu\" class=\"menu-sec\">\n <ng-template matMenuContent let-rowData=\"data\" let-cardRef=\"cardRef\">\n <!-- <button *ngIf=\"data.columnInfo.config.enableUpdateHierarchy\" (click)=\"updateHierarchy(data, data.children, data.index)\" mat-menu-item name=\"channel-analytics-button\"\n class=\"ws-mat-primary-text\" i18n-aria-label aria-label=\"Analytics\">\n <mat-icon>visibility</mat-icon> <span>Update Hierarchy</span>\n </button>\n <button *ngIf=\"data.columnInfo.config.enabaleRemoveConnection\" (click)=\"removeConnection(data, data.children,data.index, cardRef)\"\n mat-menu-item name=\"channel-analytics-button\" class=\"ws-mat-primary-text\" i18n-aria-label\n aria-label=\"Analytics\">\n <mat-icon>edit</mat-icon>\n <span>Remove Connection</span>\n </button>\n <button *ngIf=\"data.columnInfo.config.enableManageOrganization\" (click)=\"manageOrganization(data)\"\n mat-menu-item name=\"channel-analytics-button\" class=\"ws-mat-primary-text\" i18n-aria-label\n aria-label=\"Analytics\">\n <mat-icon>add</mat-icon>\n <span>Manage Organisation</span>\n </button> -->\n </ng-template>\n</mat-menu>", styles: [".term-card{border:1px solid rgba(0,0,0,.08);padding:.9rem;margin:0 0 1em;background-color:#fff;border-radius:8px;overflow:hidden;position:relative;z-index:45;display:flex;align-items:center;box-shadow:#0000001a 0 1px 3px,#0000000f 0 1px 2px;word-break:break-word}.term-card .termSelection{position:absolute;right:10px;top:10px}.term-card .term-card-parent{display:flex;flex:1 1 0%}.term-card .term-card-parent .term-card-content{white-space:initial}.term-card .term-card-parent .term-card-content .card-title{margin-bottom:.5em;font-family:Lato;font-size:14px;font-weight:400}.term-card .term-card-parent .term-card-content .card-description{color:#0006;font-size:12px!important;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.term-card .term-card-checkbox{width:10%}.term-card.selected{color:#000;border-style:none}.term-card.selected .card-description{color:#000!important}.term-card.clickable{cursor:pointer}.approve-flag{position:absolute;right:5px;top:35px;font-size:24px}::ng-deep .menu-sec{min-height:0px!important;background:#fff!important}::ng-deep .mat-mdc-menu-panel{background-color:#fff!important}::ng-deep .mat-mdc-menu-content,::ng-deep .mat-mdc-menu-item{background-color:#fff!important}.menu-sec{background:#fff!important}.refIdCard{border-radius:12px;width:fit-content;border:1px solid #bbb;padding:0 8px;font-size:8px!important;display:flex;align-items:center}.comp-area{font-family:Inter;font-size:12px;font-weight:600;line-height:16px;text-align:left;padding:8px;border-radius:12px}.comp-area.functional{background:#e24577;color:#fff}.comp-area.domain{background:#7b47a4;color:#fff}.comp-area.behavioural{background:#f9bf71}.ribbon{font-size:8px;font-weight:700;color:#fff}.ribbon{--f: .5em;--r: .8em;position:absolute;top:8px;right:calc(-1 * var(--f));padding-inline:.25em;padding-right:8px;line-height:1.8;background:#fa6900;border-bottom:var(--f) solid rgba(0,0,0,.3333333333);border-left:var(--r) solid rgba(0,0,0,0);clip-path:polygon(var(--r) 0,100% 0,100% calc(100% - var(--f)),calc(100% - var(--f)) 100%,calc(100% - var(--f)) calc(100% - var(--f)),var(--r) calc(100% - var(--f)),0 calc(50% - var(--f) / 2))}.refId-card{font-size:10px}\n"], dependencies: [{ kind: "directive", type: i5.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i5.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i5.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "directive", type: i5.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i5.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "directive", type: i5.NgSwitchDefault, selector: "[ngSwitchDefault]" }, { kind: "component", type: i6.MatIconButton, selector: "button[mat-icon-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "component", type: i7.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i8.MatMenu, selector: "mat-menu", exportAs: ["matMenu"] }, { kind: "component", type: i8.MatMenuItem, selector: "[mat-menu-item]", inputs: ["disabled", "disableRipple", "role"], exportAs: ["matMenuItem"] }, { kind: "directive", type: i8.MatMenuContent, selector: "ng-template[matMenuContent]" }, { kind: "directive", type: i8.MatMenuTrigger, selector: "[mat-menu-trigger-for], [matMenuTriggerFor]", exportAs: ["matMenuTrigger"] }] }); }
|
|
300
|
+
}
|
|
301
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TermCardComponent, decorators: [{
|
|
302
|
+
type: Component,
|
|
303
|
+
args: [{ selector: 'lib-term-card', template: "<ng-container [ngSwitch]=\"( (data && data?.cardSubType) || 'cardMinimal')\">\n <ng-container *ngSwitchCase=\"'standard'\" [ngTemplateOutlet]=\"cardStandard\"></ng-container>\n <ng-container *ngSwitchCase=\"'space-saving'\" [ngTemplateOutlet]=\"cardSpaceSaving\"></ng-container>\n <ng-container *ngSwitchDefault [ngTemplateOutlet]=\"cardMinimal\"></ng-container>\n</ng-container>\n\n<ng-template #cardMinimal>\n <div #cardRef class=\"term-card clickable {{data.index}}\" (click)=\"cardClicked(data, cardRef)\"\n [ngClass]=\"[data.children.selected?'selected':'', data.children.approvalStatus === 'Draft'? 'inDraft':'',\n data.children.associationProperties?.approvalStatus === 'Draft' && isApprovalRequired && !approvalList.length || data.children.highlight && isApprovalRequired ? 'inAssociationDraft':'']\"\n id=\"{{data.children.name}}\"\n [ngStyle]=\"{'background-color':getColor(data.index,cardRef,'bgColor',data)}\">\n <!-- (click)=\"data.selected=!data.selected\" --> \n <div class=\"term-card-parent\">\n <!-- <Below element is to show id on top left of the card> -->\n <!-- <div class=\"id\" [hidden]=\"true\">{{data.children.code}}</div> -->\n \n <div class=\"term-card-content\">\n <!-- <ng-container *ngIf=\"data?.children?.refId\">\n <div class=\"ribbon\">{{data?.children?.refId}}</div>\n </ng-container> -->\n\n <ng-container *ngIf=\"data?.children?.additionalProperties?.competencyArea?.name\">\n <div class=\"mb-2\">\n <span class=\"comp-area {{data?.children?.additionalProperties?.competencyArea?.name?.toLowerCase()}}\">{{data?.children?.additionalProperties?.competencyArea?.name}}</span>\n </div>\n </ng-container>\n <div class=\"card-title\">{{data.children.name}}\n <ng-container *ngIf=\"data?.children?.refId\">\n <div class=\"refIdCard mt-2\">\n <span>{{data?.children?.refId}} </span>\n </div>\n </ng-container> \n </div>\n <!-- <ng-container *ngIf=\"data?.children?.refId\">\n <div class=\"refIdCard px-4\">\n <span>{{data?.children?.refId}} </span>\n </div>\n </ng-container> -->\n <!-- <span>++{{data.children.selected}}+++</span>\n <span>=={{data.children.status}}==</span> -->\n <div class=\"card-description\">{{data.children.description}} </div>\n </div>\n </div>\n\n <!-- <p>{{data.children.approvalStatus}}, {{data.children.associationProperties?.approvalStatus}}</p> -->\n <!-- *ngIf=\"!data.isViewOnly && data.children.approvalStatus === 'Draft' && isApprovalRequired\" -->\n\n <!-- (click)=\"$event.stopPropagation();\" -->\n <ng-container *ngIf=\"data?.columnInfo?.config?.enableThreeDot\" >\n <button type=\"button\" mat-icon-button i18n-aria-label aria-label=\"action items\"\n [matMenuTriggerFor]=\"orgMenu\" [matMenuTriggerData]=\"{'data':data, 'cardRef': cardRef}\" class=\"action-btn\">\n <mat-icon>more_vert</mat-icon>\n </button>\n </ng-container>\n <!-- <div class=\"term-card-checkbox\">\n <mat-checkbox color=\"primary\" *ngIf=\"data.children.approvalStatus === 'Draft' && isApprovalRequired && !approvalList.length || \n data.children.associationProperties?.approvalStatus === 'Draft' && isApprovalRequired && !approvalList.length ||\n data.children.highlight && isApprovalRequired\" [checked]=\"data.children.highlight\" class=\"termSelection\"\n (change)=\"handleProductClick(data.children, $event)\" (click)=\"$event.stopPropagation()\"></mat-checkbox>\n <mat-icon color=\"primary\" class=\"approve-flag\"\n *ngIf=\"data.children.highlight && isApprovalRequired\">{{app_strings.flag}}</mat-icon>\n </div> -->\n </div>\n</ng-template>\n\n<ng-template #cardStandard>\n <div>\n {{data.children.name}}\n </div>\n <div>\n {{data.children.description}}\n </div>\n</ng-template>\n\n<ng-template #cardSpaceSaving>\n <div>\n {{data.children.name}}\n </div>\n</ng-template>\n\n<mat-menu #cardMenu=\"matMenu\" class=\"menu-sec\">\n <ng-template matMenuContent let-rowData=\"data\" let-cardRef=\"cardRef\">\n <!-- <div > -->\n <button *ngIf=\"data.columnInfo.config.enableView\" (click)=\"view(data, data.children, data.index)\" mat-menu-item name=\"channel-analytics-button\"\n class=\"ws-mat-primary-text\" i18n-aria-label aria-label=\"Analytics\">\n <mat-icon>visibility</mat-icon> <span>View</span>\n </button>\n <button *ngIf=\"data.columnInfo.config.enabaleEdit\" (click)=\"edit(data, data.children,data.index, cardRef)\"\n mat-menu-item name=\"channel-analytics-button\" class=\"ws-mat-primary-text\" i18n-aria-label\n aria-label=\"Analytics\">\n <mat-icon>edit</mat-icon>\n <span>Edit</span>\n </button>\n <button *ngIf=\"data.columnInfo.config.enableAdd\" (click)=\"create(data)\"\n mat-menu-item name=\"channel-analytics-button\" class=\"ws-mat-primary-text\" i18n-aria-label\n aria-label=\"Analytics\">\n <mat-icon>add</mat-icon>\n <span>Add</span>\n </button>\n <button *ngIf=\"data.columnInfo.config.enableDelete\" (click)=\"delete(data)\"\n mat-menu-item name=\"channel-analytics-button\" class=\"ws-mat-primary-text\" i18n-aria-label\n aria-label=\"Analytics\">\n <mat-icon>delete</mat-icon>\n <span>Delete</span>\n </button>\n </ng-template>\n</mat-menu>\n\n<mat-menu #orgMenu=\"matMenu\" class=\"menu-sec\">\n <ng-template matMenuContent let-rowData=\"data\" let-cardRef=\"cardRef\">\n <!-- <button *ngIf=\"data.columnInfo.config.enableUpdateHierarchy\" (click)=\"updateHierarchy(data, data.children, data.index)\" mat-menu-item name=\"channel-analytics-button\"\n class=\"ws-mat-primary-text\" i18n-aria-label aria-label=\"Analytics\">\n <mat-icon>visibility</mat-icon> <span>Update Hierarchy</span>\n </button>\n <button *ngIf=\"data.columnInfo.config.enabaleRemoveConnection\" (click)=\"removeConnection(data, data.children,data.index, cardRef)\"\n mat-menu-item name=\"channel-analytics-button\" class=\"ws-mat-primary-text\" i18n-aria-label\n aria-label=\"Analytics\">\n <mat-icon>edit</mat-icon>\n <span>Remove Connection</span>\n </button>\n <button *ngIf=\"data.columnInfo.config.enableManageOrganization\" (click)=\"manageOrganization(data)\"\n mat-menu-item name=\"channel-analytics-button\" class=\"ws-mat-primary-text\" i18n-aria-label\n aria-label=\"Analytics\">\n <mat-icon>add</mat-icon>\n <span>Manage Organisation</span>\n </button> -->\n </ng-template>\n</mat-menu>", styles: [".term-card{border:1px solid rgba(0,0,0,.08);padding:.9rem;margin:0 0 1em;background-color:#fff;border-radius:8px;overflow:hidden;position:relative;z-index:45;display:flex;align-items:center;box-shadow:#0000001a 0 1px 3px,#0000000f 0 1px 2px;word-break:break-word}.term-card .termSelection{position:absolute;right:10px;top:10px}.term-card .term-card-parent{display:flex;flex:1 1 0%}.term-card .term-card-parent .term-card-content{white-space:initial}.term-card .term-card-parent .term-card-content .card-title{margin-bottom:.5em;font-family:Lato;font-size:14px;font-weight:400}.term-card .term-card-parent .term-card-content .card-description{color:#0006;font-size:12px!important;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.term-card .term-card-checkbox{width:10%}.term-card.selected{color:#000;border-style:none}.term-card.selected .card-description{color:#000!important}.term-card.clickable{cursor:pointer}.approve-flag{position:absolute;right:5px;top:35px;font-size:24px}::ng-deep .menu-sec{min-height:0px!important;background:#fff!important}::ng-deep .mat-mdc-menu-panel{background-color:#fff!important}::ng-deep .mat-mdc-menu-content,::ng-deep .mat-mdc-menu-item{background-color:#fff!important}.menu-sec{background:#fff!important}.refIdCard{border-radius:12px;width:fit-content;border:1px solid #bbb;padding:0 8px;font-size:8px!important;display:flex;align-items:center}.comp-area{font-family:Inter;font-size:12px;font-weight:600;line-height:16px;text-align:left;padding:8px;border-radius:12px}.comp-area.functional{background:#e24577;color:#fff}.comp-area.domain{background:#7b47a4;color:#fff}.comp-area.behavioural{background:#f9bf71}.ribbon{font-size:8px;font-weight:700;color:#fff}.ribbon{--f: .5em;--r: .8em;position:absolute;top:8px;right:calc(-1 * var(--f));padding-inline:.25em;padding-right:8px;line-height:1.8;background:#fa6900;border-bottom:var(--f) solid rgba(0,0,0,.3333333333);border-left:var(--r) solid rgba(0,0,0,0);clip-path:polygon(var(--r) 0,100% 0,100% calc(100% - var(--f)),calc(100% - var(--f)) 100%,calc(100% - var(--f)) calc(100% - var(--f)),var(--r) calc(100% - var(--f)),0 calc(50% - var(--f) / 2))}.refId-card{font-size:10px}\n"] }]
|
|
304
|
+
}], ctorParameters: function () { return [{ type: i1.FrameworkService }, { type: i2.LocalConnectionService }, { type: i3.ApprovalService }, { type: i4.MatLegacyDialog }]; }, propDecorators: { data: [{
|
|
305
|
+
type: Input
|
|
306
|
+
}], isSelected: [{
|
|
307
|
+
type: Output
|
|
308
|
+
}], selectedCard: [{
|
|
309
|
+
type: Output
|
|
310
|
+
}] } });
|
|
311
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"term-card.component.js","sourceRoot":"","sources":["../../../../../../../library/sunbird-cb/tree-hierarchy/src/lib/components/term-card/term-card.component.ts","../../../../../../../library/sunbird-cb/tree-hierarchy/src/lib/components/term-card/term-card.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnDestroy, OnInit, Output } from '@angular/core'\nimport { NSFramework } from '../../models/framework.model'\nimport { ApprovalService } from '../../services/approval.service';\nimport { FrameworkService } from '../../services/framework.service'\nimport { LocalConnectionService } from '../../services/local-connection.service';\nimport { labels } from '../../labels/strings';\nimport { CardSelection, CardChecked, Card } from '../../models/variable-type.model';\nimport { MatLegacyDialog as MatDialog } from '@angular/material/legacy-dialog';\nimport { CreateTermComponent } from '../create-term/create-term.component';\nimport { CreateTermFromFrameworkComponent } from './../create-term-from-framework/create-term-from-framework.component';\nimport { ConforamtionPopupComponent } from '../conforamtion-popup/conforamtion-popup.component';\n\n@Component({\n  selector: 'lib-term-card',\n  templateUrl: './term-card.component.html',\n  styleUrls: ['./term-card.component.scss']\n})\nexport class TermCardComponent implements OnInit, OnDestroy {\n  // @Input() data!: NSFramework.ITermCard\n\n  private _data!: NSFramework.ITermCard;\n  isApprovalRequired: boolean = false\n  approvalList: Array<Card> = []\n  heightLighted = []\n  app_strings: any = labels;\n  loaded: any = {}\n  isCompetencyArea:any;\n  environment: any\n  subscription :any\n  @Input()\n  set data(value: any) {\n    this._data = value;\n    //  if(this._data)\n    //    this.createTimeline(this._data[0].id)\n    this._data.children.highlight=false\n  }\n  get data(): any {\n    return this._data;\n  }\n\n  @Output() isSelected = new EventEmitter<CardSelection>()\n  @Output() selectedCard = new EventEmitter<CardChecked>()\n\n  constructor(\n    private frameworkService: FrameworkService,\n    private localConnectionService: LocalConnectionService,\n    private approvalService: ApprovalService,\n    public dialog: MatDialog, \n    \n  ) { }\n\n  ngOnInit() {\n    this.isApprovalRequired = this.localConnectionService.getConfigInfo().isApprovalRequired\n    \n    this.updateApprovalStatus()\n    this.subscription = this.frameworkService.insertUpdateDeleteNotifier.subscribe((e)=>{\n      if(e){\n       this.isCompetencyArea = e.action\n      }\n    })\n\n\n    this.environment = this.frameworkService.getEnviroment()\n    \n  }\n\n  cardClicked(data: any, cardRef: any) {\n    if(data.category!='subtheme'){\n      this.frameworkService.cardClkData = data;\n      this.frameworkService.CurrentCardClk.next(data.category)\n      \n    }\n    // this.data.selected = true\n    if(this.frameworkService.isLastColumn(this.data.category)){\n      return \n    }\n    this.isSelected.emit({ element: this.data.children, isSelected: !data.selected })\n    this.frameworkService.currentSelection.next({ type: this.data.category, data: data.children, cardRef })\n  }\n\n  handleProductClick(term: any, event: any){\n    this.selectedCard.emit({term:term, checked:event.checked})\n  }\n\n  updateApprovalStatus(){\n     const id = this._data.children.identifier;\n    this.approvalService.getUpdateList().subscribe((list:any) => {\n      this.approvalList = list.map((item: any) => item.identifier);\n      if(this.approvalList){\n           if(this.approvalList.includes(id)){\n              this._data.children.highlight = true\n            }\n      }     \n    })\n  }\n\n  getColor(indexClass:number, cardRef: any,property: string, data:any) {\n    let config = this.frameworkService.getConfig(data.category);\n    if(cardRef.classList.contains('selected') && property === 'bgColor'){\n       return config.color;\n    }\n    if(property === 'border'){\n      let borderColor;\n      if(cardRef.classList.contains((indexClass).toString())){\n        borderColor = \"8px solid\" + config.color;\n      }\n      return borderColor;\n    }\n  }\n\n\n  view(data: any, childrenData: any, index: any){\n    let dialog: any\n    const selectedTerms = this.frameworkService.getPreviousSelectedTerms(data.columnInfo.code)\n    const nexColInfo = this.getNextCat(data)\n    const nextCat = nexColInfo || data.columnInfo\n    if(nextCat && this.environment && this.environment.frameworkType === 'MDO_DESIGNATION') {\n      const nextNextCat = this.frameworkService.getNextCategory(nextCat.code)\n      const selectedTerms = this.frameworkService.getPreviousSelectedTerms(nextCat.code)\n      const colInfo = Array.from(this.frameworkService.list.values()).filter(l => l.code === nextCat.code )\n      let nextColInfo : any = []\n      if(nextNextCat && nextNextCat.code) {\n        nextColInfo = Array.from(this.frameworkService.list.values()).filter(l => l.code === nextNextCat.code )\n      }\n        dialog = this.dialog.open(CreateTermFromFrameworkComponent, {\n          data: { \n            mode:'multi-create',\n            openMode: 'view',\n            cardColInfo: this.data.columnInfo,\n            columnInfo: colInfo && colInfo.length ? colInfo[0] : [],\n            nextColInfo: nextColInfo && nextColInfo.length ? nextColInfo[0] : [],\n            frameworkId: this.frameworkService.getFrameworkId(),\n            selectedparents: this.heightLighted,\n            colIndex: nextCat.index,\n            childrenData: data.children,\n            selectedParentTerms: selectedTerms\n          },\n          width: '800px',\n          panelClass: 'custom-dialog-container'\n        })\n      \n     \n    }\n    else {\n      dialog = this.dialog.open(CreateTermComponent, {\n        data: { \n          mode:'view',\n          columnInfo: this.data.columnInfo,\n          frameworkId: this.frameworkService.getFrameworkId(),\n          selectedparents: this.heightLighted,\n          colIndex: index,\n          childrenData: childrenData,\n          selectedParentTerms: selectedTerms\n        },\n        width: '800px',\n        panelClass: 'custom-dialog-container'\n      })\n    }\n    dialog.afterClosed().subscribe((res: any) => {\n      if(!res) {\n        return;\n      }\n      // if (res && res.created) {\n      //   this.showPublish = true\n      // }\n      // this.loaded[res.term.category] = false\n      // // wait\n      // const parentColumn = this.frameworkService.getPreviousCategory(res.term.category)\n      // res.parent = null\n      // if (parentColumn) {\n      //   res.parent = this.frameworkService.selectionList.get(parentColumn.code)\n      //   res.parent.children? res.parent.children.push(res.term) :res.parent['children'] = [res.term]\n      // }\n      // this.updateFinalList({ selectedTerm: res.term, isSelected: false, parentData: res.parent, colIndex:colIndex })\n    })\n  }\n  edit(data: any, childrenData: any, index: any, cardRef: any){\n    let dialog: any\n    const selectedTerms = this.frameworkService.getPreviousSelectedTerms(data.columnInfo.code)\n    const nexColInfo = this.getNextCat(data)\n    const nextCat = nexColInfo || data.columnInfo\n   \n    if(nextCat && this.environment && this.environment.frameworkType === 'MDO_DESIGNATION') {\n      // const nextNextCat = this.frameworkService.getNextCategory(nextCat.code)\n      // const selectedTerms = this.frameworkService.getPreviousSelectedTerms(nextCat.code)\n      // const colInfo = Array.from(this.frameworkService.list.values()).filter(l => l.code === nextCat.code )\n      // let nextColInfo = []\n      // if(nextNextCat && nextNextCat.code) {\n      //   nextColInfo = Array.from(this.frameworkService.list.values()).filter(l => l.code === nextNextCat.code )\n      // }\n      //   dialog = this.dialog.open(CreateTermFromFrameworkComponent, {\n      //     data: { \n      //       mode:'multi-create',\n      //       openMode: 'edit',\n      //       cardColInfo: this.data.columnInfo,\n      //       columnInfo: colInfo && colInfo.length ? colInfo[0] : [],\n      //       nextColInfo: nextColInfo && nextColInfo.length ? nextColInfo[0] : [],\n      //       frameworkId: this.frameworkService.getFrameworkId(),\n      //       selectedparents: this.heightLighted,\n      //       colIndex: nextCat.index,\n      //       childrenData: data.children,\n      //       selectedParentTerms: selectedTerms\n      //     },\n      //     width: '800px',\n      //     panelClass: 'custom-dialog-container'\n      //   })\n      \n      this.create(data, 'edit')\n    }\n    else {\n      dialog = this.dialog.open(CreateTermComponent, {\n        data: { \n          mode:'edit',\n          columnInfo: data.columnInfo,\n          frameworkId: this.frameworkService.getFrameworkId(),\n          selectedparents: this.heightLighted,\n          colIndex: index,\n          childrenData: childrenData,\n          selectedParentTerms: selectedTerms,\n          cardRef: cardRef\n        },\n        width: '800px',\n        panelClass: 'custom-dialog-container'\n      })\n    }\n    dialog.afterClosed().subscribe((res: any) => {\n      if(!res) {\n        return;\n      }\n      // const responseData = {\n      //   res,\n      //   index: index.index,\n      //   data,\n      //   type: 'update',\n      //   cardRef: cardRef\n      // }\n      // this.frameworkService.updateAfterAddOrEditSubject(responseData)\n      setTimeout(() => {\n        window.dispatchEvent(new Event('resize'))\n      }, 100)\n    })\n  }\n  create(data: any, mode?:string){\n    const nexColInfo = this.getNextCat(data)\n    const nextCat = nexColInfo || data.columnInfo\n    const nextNextCat = this.frameworkService.getNextCategory(nextCat.code)\n    if(nextCat) {\n      const selectedTerms = this.frameworkService.getPreviousSelectedTerms(nextCat.code)\n      const colInfo = Array.from(this.frameworkService.list.values()).filter(l => l.code === nextCat.code )\n      let nextColInfo: any = []\n      if(nextNextCat && nextNextCat.code) {\n        nextColInfo = Array.from(this.frameworkService.list.values()).filter(l => l.code === nextNextCat.code )\n      }\n      let dialog: any\n      if(this.environment && this.environment.frameworkType === 'MDO_DESIGNATION'){\n        dialog = this.dialog.open(CreateTermFromFrameworkComponent, {\n          data: { \n            mode:'multi-create',\n            openMode: mode || 'add',\n            cardColInfo: this.data.columnInfo,\n            columnInfo: colInfo && colInfo.length ? colInfo[0] : [],\n            nextColInfo: nextColInfo && nextColInfo.length ? nextColInfo[0] : [],\n            frameworkId: this.frameworkService.getFrameworkId(),\n            selectedparents: this.heightLighted,\n            colIndex: nextCat.index,\n            childrenData: data.children,\n            selectedParentTerms: selectedTerms\n          },\n          width: '800px',\n          panelClass: 'custom-dialog-container'\n        })\n      } else {\n        dialog = this.dialog.open(CreateTermComponent, {\n          data: { \n            mode:'multi-create',\n            columnInfo: colInfo && colInfo.length ? colInfo[0] : [],\n            frameworkId: this.frameworkService.getFrameworkId(),\n            selectedparents: this.heightLighted,\n            colIndex: nextCat.index,\n            childrenData: data.children,\n            selectedParentTerms: selectedTerms\n          },\n          width: '800px',\n          panelClass: 'custom-dialog-container'\n        })\n      }\n      dialog.afterClosed().subscribe((res: any) => {\n        if(!res) {\n          return;\n        }\n        \n        const responseData = {\n          res,\n          index: nextCat.index,\n          data,\n          type: 'multi-create'\n        }\n        if(!(res && res.stopUpdate)){\n          this.frameworkService.updateAfterAddOrEditSubject(responseData)\n        }\n        setTimeout(() => {\n          window.dispatchEvent(new Event('resize'))\n        }, 100)\n      })\n    }\n  }\n\n  getNextCatName(data: any) {\n    if(data && data.columnInfo && data.columnInfo.code){\n      const nextCat = this.frameworkService.getNextCategory(data.columnInfo.code)\n      if(nextCat && nextCat.code){\n        \n        return nextCat.code\n      }\n    }\n    return null\n  }\n\n  getNextCat(data: any) {\n    if(data && data.columnInfo && data.columnInfo.code){\n      const nextCat = this.frameworkService.getNextCategory(data.columnInfo.code)\n      return nextCat\n    }\n    return null\n  }\n\n  ngOnDestroy(): void {\n    if(this.subscription){\n      this.subscription.unsubscribe()\n    }\n  }\n  delete(data: any) {\n    const dialogData = {\n      dialogType: 'warning',\n      dialogAction: 'retire',\n      descriptions: [\n        {\n          header: `Competency ${data.category ===\"subtheme\"? 'sub-theme': 'theme'} will be deleted`,\n          headerClass: 'flex items-center justify-center text-blue textBold',\n          messages: [\n            {\n              msgClass: 'mb-2 mt-2',\n              msg: `Do you want to proceed?`,\n            },\n          ],\n        },\n      ],\n      footerClass: 'items-center justify-center',\n      buttons: [\n        {\n          btnText: 'No',\n          btnClass: 'btn-outline',\n          response: false,\n        },\n        {\n          btnText: 'Yes',\n          btnClass: 'btn-full-success',\n          response: true,\n        },\n      ],\n      cardInfo: data\n    }\n    let dialog = this.dialog.open(ConforamtionPopupComponent, {\n          data: dialogData,\n          autoFocus: false,\n          width: '500px',\n          maxWidth: '80vw',\n          maxHeight: '90vh',\n          disableClose: true\n        })\n        dialog.afterClosed().subscribe(_res => {\n         \n        setTimeout(() => {\n          window.dispatchEvent(new Event('resize'))\n        }, 100)\n        })\n      \n    \n    }\n  \n}\n","<ng-container [ngSwitch]=\"( (data && data?.cardSubType) || 'cardMinimal')\">\n    <ng-container *ngSwitchCase=\"'standard'\" [ngTemplateOutlet]=\"cardStandard\"></ng-container>\n    <ng-container *ngSwitchCase=\"'space-saving'\" [ngTemplateOutlet]=\"cardSpaceSaving\"></ng-container>\n    <ng-container *ngSwitchDefault [ngTemplateOutlet]=\"cardMinimal\"></ng-container>\n</ng-container>\n\n<ng-template #cardMinimal>\n    <div #cardRef class=\"term-card clickable {{data.index}}\" (click)=\"cardClicked(data, cardRef)\"\n        [ngClass]=\"[data.children.selected?'selected':'', data.children.approvalStatus === 'Draft'? 'inDraft':'',\n    data.children.associationProperties?.approvalStatus === 'Draft' && isApprovalRequired && !approvalList.length || data.children.highlight && isApprovalRequired ? 'inAssociationDraft':'']\"\n        id=\"{{data.children.name}}\"\n        [ngStyle]=\"{'background-color':getColor(data.index,cardRef,'bgColor',data)}\">\n        <!-- (click)=\"data.selected=!data.selected\" -->   \n        <div class=\"term-card-parent\">\n            <!-- <Below element is to show id on top left of the card> -->\n            <!-- <div class=\"id\" [hidden]=\"true\">{{data.children.code}}</div> -->\n             \n            <div class=\"term-card-content\">\n                <!-- <ng-container  *ngIf=\"data?.children?.refId\">\n                    <div class=\"ribbon\">{{data?.children?.refId}}</div>\n                </ng-container> -->\n\n                <ng-container *ngIf=\"data?.children?.additionalProperties?.competencyArea?.name\">\n                    <div  class=\"mb-2\">\n                        <span class=\"comp-area {{data?.children?.additionalProperties?.competencyArea?.name?.toLowerCase()}}\">{{data?.children?.additionalProperties?.competencyArea?.name}}</span>\n                     </div>\n                 </ng-container>\n                <div class=\"card-title\">{{data.children.name}}\n                    <ng-container *ngIf=\"data?.children?.refId\">\n                        <div class=\"refIdCard mt-2\">\n                            <span>{{data?.children?.refId}} </span>\n                        </div>\n                    </ng-container> \n                </div>\n                <!-- <ng-container *ngIf=\"data?.children?.refId\">\n                    <div class=\"refIdCard px-4\">\n                        <span>{{data?.children?.refId}} </span>\n                    </div>\n                </ng-container> -->\n                <!-- <span>++{{data.children.selected}}+++</span>\n                <span>=={{data.children.status}}==</span>  -->\n                <div class=\"card-description\">{{data.children.description}} </div>\n            </div>\n        </div>\n\n        <!-- <p>{{data.children.approvalStatus}}, {{data.children.associationProperties?.approvalStatus}}</p> -->\n        <!-- *ngIf=\"!data.isViewOnly && data.children.approvalStatus === 'Draft' && isApprovalRequired\" -->\n\n        <!-- (click)=\"$event.stopPropagation();\" -->\n         <ng-container *ngIf=\"data?.columnInfo?.config?.enableThreeDot\" >\n            <button type=\"button\" mat-icon-button i18n-aria-label aria-label=\"action items\"\n            [matMenuTriggerFor]=\"orgMenu\" [matMenuTriggerData]=\"{'data':data, 'cardRef': cardRef}\" class=\"action-btn\">\n            <mat-icon>more_vert</mat-icon>\n            </button>\n         </ng-container>\n        <!-- <div class=\"term-card-checkbox\">\n            <mat-checkbox color=\"primary\" *ngIf=\"data.children.approvalStatus === 'Draft' && isApprovalRequired && !approvalList.length || \n            data.children.associationProperties?.approvalStatus === 'Draft' && isApprovalRequired && !approvalList.length ||\n            data.children.highlight && isApprovalRequired\" [checked]=\"data.children.highlight\" class=\"termSelection\"\n                (change)=\"handleProductClick(data.children, $event)\" (click)=\"$event.stopPropagation()\"></mat-checkbox>\n            <mat-icon color=\"primary\" class=\"approve-flag\"\n                *ngIf=\"data.children.highlight && isApprovalRequired\">{{app_strings.flag}}</mat-icon>\n        </div> -->\n    </div>\n</ng-template>\n\n<ng-template #cardStandard>\n    <div>\n        {{data.children.name}}\n    </div>\n    <div>\n        {{data.children.description}}\n    </div>\n</ng-template>\n\n<ng-template #cardSpaceSaving>\n    <div>\n        {{data.children.name}}\n    </div>\n</ng-template>\n\n<mat-menu #cardMenu=\"matMenu\" class=\"menu-sec\">\n    <ng-template matMenuContent let-rowData=\"data\" let-cardRef=\"cardRef\">\n        <!-- <div > -->\n        <button *ngIf=\"data.columnInfo.config.enableView\"  (click)=\"view(data, data.children, data.index)\" mat-menu-item name=\"channel-analytics-button\"\n            class=\"ws-mat-primary-text\" i18n-aria-label aria-label=\"Analytics\">\n            <mat-icon>visibility</mat-icon> <span>View</span>\n        </button>\n        <button *ngIf=\"data.columnInfo.config.enabaleEdit\" (click)=\"edit(data,  data.children,data.index, cardRef)\"\n            mat-menu-item name=\"channel-analytics-button\" class=\"ws-mat-primary-text\" i18n-aria-label\n            aria-label=\"Analytics\">\n            <mat-icon>edit</mat-icon>\n            <span>Edit</span>\n        </button>\n        <button *ngIf=\"data.columnInfo.config.enableAdd\" (click)=\"create(data)\"\n            mat-menu-item name=\"channel-analytics-button\" class=\"ws-mat-primary-text\" i18n-aria-label\n            aria-label=\"Analytics\">\n            <mat-icon>add</mat-icon>\n            <span>Add</span>\n        </button>\n        <button *ngIf=\"data.columnInfo.config.enableDelete\" (click)=\"delete(data)\"\n            mat-menu-item name=\"channel-analytics-button\" class=\"ws-mat-primary-text\" i18n-aria-label\n            aria-label=\"Analytics\">\n            <mat-icon>delete</mat-icon>\n            <span>Delete</span>\n        </button>\n    </ng-template>\n</mat-menu>\n\n<mat-menu #orgMenu=\"matMenu\" class=\"menu-sec\">\n    <ng-template matMenuContent let-rowData=\"data\" let-cardRef=\"cardRef\">\n        <!-- <button *ngIf=\"data.columnInfo.config.enableUpdateHierarchy\"  (click)=\"updateHierarchy(data, data.children, data.index)\" mat-menu-item name=\"channel-analytics-button\"\n            class=\"ws-mat-primary-text\" i18n-aria-label aria-label=\"Analytics\">\n            <mat-icon>visibility</mat-icon> <span>Update Hierarchy</span>\n        </button>\n        <button *ngIf=\"data.columnInfo.config.enabaleRemoveConnection\" (click)=\"removeConnection(data,  data.children,data.index, cardRef)\"\n            mat-menu-item name=\"channel-analytics-button\" class=\"ws-mat-primary-text\" i18n-aria-label\n            aria-label=\"Analytics\">\n            <mat-icon>edit</mat-icon>\n            <span>Remove Connection</span>\n        </button>\n        <button *ngIf=\"data.columnInfo.config.enableManageOrganization\" (click)=\"manageOrganization(data)\"\n            mat-menu-item name=\"channel-analytics-button\" class=\"ws-mat-primary-text\" i18n-aria-label\n            aria-label=\"Analytics\">\n            <mat-icon>add</mat-icon>\n            <span>Manage Organisation</span>\n        </button> -->\n    </ng-template>\n</mat-menu>"]}
|