qms-angular 1.0.53 → 1.0.57

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.
Files changed (60) hide show
  1. package/README.md +46 -1
  2. package/bundles/qms-angular.umd.js +1133 -453
  3. package/bundles/qms-angular.umd.js.map +1 -1
  4. package/esm2015/lib/components/qms-app-bar/qms-app-bar.component.js +1 -1
  5. package/esm2015/lib/components/related/model/popup-data.model.js +1 -1
  6. package/esm2015/lib/components/related/popup/related-popup.component.js +52 -31
  7. package/esm2015/lib/components/related/risk/analysis/analysis.component.js +1 -1
  8. package/esm2015/lib/components/select-include-children/enum/select-option-type.enum.js +7 -0
  9. package/esm2015/lib/components/select-include-children/model/select-option.model.js +1 -1
  10. package/esm2015/lib/components/select-include-children/model/select-popup-data.model.js +1 -1
  11. package/esm2015/lib/components/select-include-children/model/select-search-option.model.js +4 -0
  12. package/esm2015/lib/components/select-include-children/model/seleted-option.model.js +3 -0
  13. package/esm2015/lib/components/select-include-children/select-include-children.component.js +419 -331
  14. package/esm2015/lib/components/select-include-children/services/select-global.service.js +3 -7
  15. package/esm2015/lib/components/select-one/common/data-type.enum.js +14 -0
  16. package/esm2015/lib/components/select-one/common/document-folder-type.enum.js +12 -0
  17. package/esm2015/lib/components/select-one/common/module-type.enum.js +8 -0
  18. package/esm2015/lib/components/select-one/common/select-data.model.js +3 -0
  19. package/esm2015/lib/components/select-one/common/selected-node.model.js +3 -0
  20. package/esm2015/lib/components/select-one/common/selectone-popup-data.model.js +11 -0
  21. package/esm2015/lib/components/select-one/common/show-hide-search-result.const.js +6 -0
  22. package/esm2015/lib/components/select-one/index.js +2 -0
  23. package/esm2015/lib/components/select-one/public_api.js +7 -0
  24. package/esm2015/lib/components/select-one/select-one.component.js +359 -0
  25. package/esm2015/lib/components/select-one/select-one.module.js +94 -0
  26. package/esm2015/lib/components/select-one/service/select-one-global.service.js +18 -0
  27. package/esm2015/lib/components/tree/tree.component.js +69 -5
  28. package/esm2015/public-api.js +5 -1
  29. package/fesm2015/qms-angular.js +1088 -444
  30. package/fesm2015/qms-angular.js.map +1 -1
  31. package/lib/components/related/model/popup-data.model.d.ts +0 -1
  32. package/lib/components/related/popup/related-popup.component.d.ts +4 -5
  33. package/lib/components/select-include-children/enum/select-option-type.enum.d.ts +5 -0
  34. package/lib/components/select-include-children/model/select-option.model.d.ts +2 -0
  35. package/lib/components/select-include-children/model/select-popup-data.model.d.ts +4 -0
  36. package/lib/components/select-include-children/model/select-search-option.model.d.ts +7 -0
  37. package/lib/components/select-include-children/model/seleted-option.model.d.ts +15 -0
  38. package/lib/components/select-include-children/select-include-children.component.d.ts +32 -18
  39. package/lib/components/select-include-children/services/select-global.service.d.ts +3 -5
  40. package/lib/components/select-one/common/data-type.enum.d.ts +12 -0
  41. package/lib/components/select-one/common/document-folder-type.enum.d.ts +10 -0
  42. package/lib/components/select-one/common/module-type.enum.d.ts +6 -0
  43. package/lib/components/select-one/common/select-data.model.d.ts +12 -0
  44. package/lib/components/select-one/common/selected-node.model.d.ts +12 -0
  45. package/lib/components/select-one/common/selectone-popup-data.model.d.ts +12 -0
  46. package/lib/components/select-one/common/show-hide-search-result.const.d.ts +5 -0
  47. package/lib/components/select-one/index.d.ts +1 -0
  48. package/lib/components/select-one/public_api.d.ts +6 -0
  49. package/lib/components/select-one/select-one.component.d.ts +80 -0
  50. package/lib/components/select-one/select-one.module.d.ts +25 -0
  51. package/lib/components/select-one/service/select-one-global.service.d.ts +10 -0
  52. package/lib/components/tree/tree.component.d.ts +6 -1
  53. package/package.json +1 -1
  54. package/public-api.d.ts +4 -0
  55. package/src/assets/qms-ckeditor-plugin/build/ckeditor.js +1 -2
  56. package/src/assets/qms-ckeditor-plugin/build/ckeditor.js.map +1 -1
  57. package/src/assets/qms-ckeditor-plugin/src/ckeditor.js +0 -2
  58. package/src/lib/components/qms-app-bar/qms-app-bar.component.scss +7 -0
  59. package/src/lib/components/select-include-children/select-include-children.component.scss +11 -4
  60. package/src/lib/components/select-one/select-one.component.scss +240 -0
@@ -8,6 +8,8 @@ import { debounceTime, takeUntil } from 'rxjs/operators';
8
8
  import { SelectOption } from './model/select-option.model';
9
9
  import { TreeComponent } from '../tree/tree.component';
10
10
  import { SelectConst } from './model/select.const';
11
+ import { SelectOptionTypes } from 'projects/qms-angular/src/public-api';
12
+ import { ItemIconType } from '../related/common/item-icon-type.enum';
11
13
  import * as i0 from "@angular/core";
12
14
  import * as i1 from "../../services/translation-registry.service";
13
15
  import * as i2 from "@angular/material/dialog";
@@ -15,28 +17,29 @@ import * as i3 from "./services/select-global.service";
15
17
  import * as i4 from "@angular/material/icon";
16
18
  import * as i5 from "@angular/platform-browser";
17
19
  import * as i6 from "../app-icon/icon-registry.service";
18
- import * as i7 from "@angular/material/autocomplete";
19
- import * as i8 from "@angular/cdk/scrolling";
20
- import * as i9 from "@angular/material/core";
21
- import * as i10 from "../tree/tree.component";
22
- import * as i11 from "@angular/material/button";
23
- import * as i12 from "@angular/material/slide-toggle";
24
- import * as i13 from "../button/button";
25
- import * as i14 from "@angular/material/input";
26
- import * as i15 from "@angular/forms";
27
- import * as i16 from "../../directives/scrollbar/scrollbar.directive";
28
- import * as i17 from "@angular/common";
29
- import * as i18 from "../../directives/tooltip/tooltip-renderer.directive";
30
- import * as i19 from "../../directives/form.directive";
31
- import * as i20 from "./model/select-popup-data.model";
20
+ import * as i7 from "@angular/material/slide-toggle";
21
+ import * as i8 from "@angular/material/autocomplete";
22
+ import * as i9 from "@angular/cdk/scrolling";
23
+ import * as i10 from "@angular/material/core";
24
+ import * as i11 from "../list/list";
25
+ import * as i12 from "../tree/tree.component";
26
+ import * as i13 from "@angular/material/button";
27
+ import * as i14 from "../button/button";
28
+ import * as i15 from "@angular/material/input";
29
+ import * as i16 from "@angular/forms";
30
+ import * as i17 from "../../directives/form.directive";
31
+ import * as i18 from "../../directives/scrollbar/scrollbar.directive";
32
+ import * as i19 from "@angular/common";
33
+ import * as i20 from "../../directives/tooltip/tooltip-renderer.directive";
34
+ import * as i21 from "./model/select-popup-data.model";
32
35
  export class SelectIncludeChildrenPopUpComponent {
33
- constructor(cdRef, translate, dialogRef, globalService, iconRegistry, sanitizer, appIconService, elem, data) {
36
+ constructor(cdRef, translate, dialogRef, globalService, iconRegistry, domSanitizer, appIconService, elem, data) {
34
37
  this.cdRef = cdRef;
35
38
  this.translate = translate;
36
39
  this.dialogRef = dialogRef;
37
40
  this.globalService = globalService;
38
41
  this.iconRegistry = iconRegistry;
39
- this.sanitizer = sanitizer;
42
+ this.domSanitizer = domSanitizer;
40
43
  this.appIconService = appIconService;
41
44
  this.elem = elem;
42
45
  this.data = data;
@@ -44,15 +47,13 @@ export class SelectIncludeChildrenPopUpComponent {
44
47
  this.headerName = '';
45
48
  this.treeData = [];
46
49
  this.checkedNodeList = [];
47
- this.SelectOption = [];
50
+ this.selectedOptions = [];
48
51
  this.selectedData = [];
49
52
  this.commonCheckedList = [];
50
- this.documentCheckedList = [];
51
- this.singleProcessList = [];
52
53
  this.itemType = 0;
53
54
  this.selectedRiskData = [];
54
55
  this.disabledList = [];
55
- this.disabledList2 = [];
56
+ this.orginalDisableList = [];
56
57
  this.isDocumentExpanded = true;
57
58
  this.isCommonExpanded = true;
58
59
  this.singleSelectOption = false;
@@ -63,22 +64,33 @@ export class SelectIncludeChildrenPopUpComponent {
63
64
  this.selectedFolder = null;
64
65
  this.listChildrenSelectOne = [];
65
66
  this.includeChildren = false;
67
+ this.itemIconType = ItemIconType;
66
68
  this.onSearch = new EventEmitter();
67
69
  this.onExpandFolder = new EventEmitter();
68
70
  this.headerName = data.headerName;
69
71
  this.treeData = data.treeData;
70
72
  this.treeConfig = data.treeConfig;
71
73
  this.selectedRiskData = (data === null || data === void 0 ? void 0 : data.selectedNode) || [];
72
- this.disabledList = data.disabledList || [];
74
+ this.disabledList = $.extend(true, [], data.disabledList || []);
75
+ this.orginalDisableList = $.extend(true, [], data.disabledList || []);
73
76
  this.singleSelectOption = data.treeConfig.singleSelectedNode;
74
77
  this.maxSelectItemCount = data.maxSelectItemCount;
75
- appIconService.registerProcessIcon(iconRegistry, sanitizer);
76
- appIconService.registerProcessAreaIcon(iconRegistry, sanitizer);
77
- appIconService.registerDocumentIcon(iconRegistry, sanitizer);
78
- appIconService.registerFolderIcon(iconRegistry, sanitizer);
79
- appIconService.registerDeviationIcon(iconRegistry, sanitizer);
80
- appIconService.registerChecklistIcon(iconRegistry, sanitizer);
81
- appIconService.registerRiskIcon(iconRegistry, sanitizer);
78
+ this.checkedNodeList = (data === null || data === void 0 ? void 0 : data.selectedList) || [];
79
+ this.includeChildren = data === null || data === void 0 ? void 0 : data.includeChildren;
80
+ this.editItem = data.editItem;
81
+ appIconService.registerProcessIcon(iconRegistry, domSanitizer);
82
+ appIconService.registerProcessAreaIcon(iconRegistry, domSanitizer);
83
+ appIconService.registerDocumentIcon(iconRegistry, domSanitizer);
84
+ appIconService.registerFolderIcon(iconRegistry, domSanitizer);
85
+ appIconService.registerDeviationIcon(iconRegistry, domSanitizer);
86
+ appIconService.registerChecklistIcon(iconRegistry, domSanitizer);
87
+ appIconService.registerRiskIcon(iconRegistry, domSanitizer);
88
+ }
89
+ ngAfterViewInit() {
90
+ if (this.editItem) {
91
+ this.focusEditItem(this.editItem);
92
+ }
93
+ this.initTree(this.checkedNodeList);
82
94
  }
83
95
  ngOnDestroy() {
84
96
  this.ngUnsubscribe.next();
@@ -97,7 +109,7 @@ export class SelectIncludeChildrenPopUpComponent {
97
109
  this.LANG = this.translate.getObjectLang(res);
98
110
  }
99
111
  });
100
- this.globalService.searchRelated.pipe(takeUntil(this.ngUnsubscribe)).subscribe((res) => {
112
+ this.globalService.searchSelect.pipe(takeUntil(this.ngUnsubscribe)).subscribe((res) => {
101
113
  if (res && res.length) {
102
114
  this.filteredOptions = res;
103
115
  }
@@ -118,36 +130,98 @@ export class SelectIncludeChildrenPopUpComponent {
118
130
  this.autoComplete.closePanel();
119
131
  }
120
132
  }
121
- removeCheckedNodeList(item) {
122
- this.selectedData = [];
123
- this.checkedNodeList = this.checkedNodeList.filter(x => (x.id.toLowerCase() !== item.id.toLowerCase() || x.parentId.toLowerCase() !== item.parentId.toLowerCase()));
124
- const tempArr = [];
125
- const tempArrDocument = [];
126
- const newSelectProcessList = [];
127
- const newSelectDocumentList = [];
128
- this.commonCheckedList.forEach(element => {
129
- this.checkedNodeList.forEach(x => {
130
- if (element.id.toLowerCase() === x.id.toLowerCase() && element.parentId.toLowerCase() === x.parentId.toLowerCase()) {
131
- tempArr.push(element);
132
- }
133
- });
134
- });
135
- this.singleProcessList.forEach(element => {
136
- this.checkedNodeList.forEach(x => {
137
- if (element.id.toLowerCase() === x.id.toLowerCase() && element.parentId.toLowerCase() === x.parentId.toLowerCase()) {
138
- newSelectProcessList.push(element);
139
- }
140
- });
141
- });
142
- this.singleProcessList = newSelectProcessList;
143
- this.selectedData = [...tempArr];
144
- this.documentCheckedList.forEach(element => {
145
- this.checkedNodeList.forEach(x => {
146
- if (element.id.toLowerCase() === x.id.toLowerCase() && element.parentId.toLowerCase() === x.parentId.toLowerCase()) {
147
- tempArrDocument.push(element);
133
+ initTree(selectedOptions) {
134
+ if (selectedOptions.length > 0) {
135
+ selectedOptions.forEach(element => {
136
+ this.selectedOptions.push(element);
137
+ if (element.type === SelectOptionTypes.IncludeChildren) {
138
+ this.selectedOptions = this.selectedOptions.concat(element.children);
148
139
  }
140
+ this.selectedData = this.mapSelectOptionToTreeNode(this.selectedOptions);
149
141
  });
150
- });
142
+ }
143
+ }
144
+ focusEditItem(selectedOption) {
145
+ const node = this.dataTrees.toArray()[0].getNodeByIdAndParentId(selectedOption.id, selectedOption.parentId);
146
+ if (node) {
147
+ this.dataTrees.toArray()[0].expandNode(node);
148
+ const element = document.getElementById(`_${node.parentId ? node.parentId : ''}_${node.id}_${node.level}`);
149
+ if (element) {
150
+ element.scrollIntoView(false);
151
+ }
152
+ }
153
+ }
154
+ removeCheckedNodeList(item) {
155
+ const index = this.checkedNodeList.findIndex(x => (x.id.toLowerCase() === item.id.toLowerCase() && x.parentId.toLowerCase() === item.parentId.toLowerCase()));
156
+ if (index >= 0) {
157
+ let position = this.selectedOptions.findIndex(x => x.id === item.id && x.parentId === item.parentId);
158
+ if (position >= 0) {
159
+ this.selectedOptions.splice(position, 1);
160
+ }
161
+ if (this.checkedNodeList[index].type === SelectOptionTypes.IncludeChildren) {
162
+ this.removeIncludeChildren(item);
163
+ }
164
+ if (this.includeChildren) {
165
+ this.refactorSelectList(item);
166
+ }
167
+ else {
168
+ this.checkedNodeList.splice(index, 1);
169
+ }
170
+ this.enableSelectedNode({ id: item.id, parentId: item.parentId, itemName: item.name, type: SelectOptionTypes.IncludeChildren });
171
+ this.selectedData = this.mapSelectOptionToTreeNode(this.selectedOptions);
172
+ }
173
+ }
174
+ selectSearchOption(item) {
175
+ let position = this.selectedOptions.findIndex(x => x.id === item.id && x.parentId === item.parentId);
176
+ if (position < 0) {
177
+ if (this.includeChildren) {
178
+ this.selectIncludeChildren({
179
+ id: item.id,
180
+ name: item.itemName,
181
+ parentId: item.parentId,
182
+ level: 0,
183
+ expandable: true,
184
+ disabled: false,
185
+ hasChild: false
186
+ });
187
+ this.refactorSelectList({
188
+ id: item.id,
189
+ name: item.itemName,
190
+ parentId: item.parentId,
191
+ level: 0,
192
+ expandable: true,
193
+ disabled: false,
194
+ hasChild: false
195
+ });
196
+ }
197
+ else {
198
+ this.selectedOptions.push(item);
199
+ this.checkedNodeList.push({
200
+ id: item.id,
201
+ itemName: item.itemName,
202
+ type: SelectOptionTypes.SelectOne,
203
+ parentId: item.parentId,
204
+ children: [],
205
+ noChildren: 0,
206
+ noSelectedChildren: 0
207
+ });
208
+ }
209
+ }
210
+ this.selectedData = this.mapSelectOptionToTreeNode(this.selectedOptions);
211
+ }
212
+ getItemIconType(item) {
213
+ if (item.itemIcon && item.itemIcon.length)
214
+ return this.itemIconType.name;
215
+ if (item.itemIconPath && item.itemIconPath.length)
216
+ return this.itemIconType.path;
217
+ if (item.itemIconBase64 && item.itemIconBase64.length)
218
+ return this.itemIconType.base64;
219
+ if (item.itemIconSvg && item.itemIconSvg.length)
220
+ return this.itemIconType.svg;
221
+ return this.itemIconType.none;
222
+ }
223
+ getImagePath(item) {
224
+ return this.domSanitizer.bypassSecurityTrustResourceUrl(item.itemIconBase64);
151
225
  }
152
226
  isMatchTrue(arr, arr2) {
153
227
  return arr.every((i) => {
@@ -183,163 +257,87 @@ export class SelectIncludeChildrenPopUpComponent {
183
257
  }
184
258
  }
185
259
  }
186
- getModuleFilteredOptions() {
187
- if (this.listChildrenSelectOne.length) {
188
- for (let index = 0; index < this.listChildrenSelectOne.length; index++) {
189
- const firstEl = this.listChildrenSelectOne[index];
190
- for (let j = 0; j < this.filteredOptions.length; j++) {
191
- const secondEl = this.filteredOptions[j];
192
- if (firstEl.id === secondEl.id) {
193
- this.filteredOptions.splice(j, 1);
194
- }
195
- }
196
- }
197
- }
198
- return this.filteredOptions;
199
- }
200
260
  showSearchResult() {
201
261
  this.autoComplete.openPanel();
202
262
  }
203
263
  displayRelated(related) {
204
264
  return related ? related.itemName : undefined;
205
265
  }
206
- selectSearch(item) {
207
- if (this.treeConfig.selectOne) {
208
- this.disabledList = [];
209
- }
210
- let index = -1;
211
- this.SelectOption = [];
212
- if (this.treeConfig.showCheckBox) {
213
- index = this.checkedNodeList.findIndex(x => {
214
- return x.id === item.id && x.parentId === item.parentId;
215
- });
216
- }
217
- if (index < 0) {
218
- let position = -1;
219
- let node;
220
- let typeId;
221
- }
266
+ getCommonCheckedNode(list) {
222
267
  }
223
- selectNodeRecursive(item) {
224
- let position = this.treeData.findIndex(x => {
225
- return x.rootId === item.rootId;
268
+ selectIncludeChildren(item) {
269
+ let listChildren = [];
270
+ listChildren = this.getAllChildrenNodeRecursive(listChildren, item);
271
+ this.selectedOptions.push({
272
+ id: item.id,
273
+ itemName: item.name,
274
+ itemNumberId: item.id,
275
+ parentId: item.parentId,
276
+ type: SelectOptionTypes.IncludeChildren
226
277
  });
227
- if (position >= 0) {
228
- const node = {
229
- id: item.rootId,
230
- name: item.rootName,
231
- children: [],
232
- parentId: item.parentId
233
- };
234
- let nodeChildren = this.treeData.
235
- filter(x => x.rootId === item.rootId).
236
- map(x => {
278
+ listChildren.forEach(x => {
279
+ const index = this.selectedOptions.findIndex(node => node.id === x.id && node.parentId === x.parentId);
280
+ if (index < 0) {
281
+ this.selectedOptions.push(x);
282
+ }
283
+ });
284
+ }
285
+ removeIncludeChildren(item) {
286
+ let listChildren = [];
287
+ listChildren = this.getAllChildrenNodeRecursive(listChildren, item);
288
+ const itemIndex = this.selectedOptions.findIndex(node => node.id === item.id && node.parentId === item.parentId);
289
+ if (itemIndex >= 0) {
290
+ this.selectedOptions.splice(itemIndex, 1);
291
+ }
292
+ listChildren.forEach(x => {
293
+ const index = this.selectedOptions.findIndex(node => node.id === x.id && node.parentId === x.parentId);
294
+ if (index >= 0) {
295
+ this.selectedOptions.splice(index, 1);
296
+ }
297
+ });
298
+ }
299
+ getAllChildrenNodeRecursive(listResult, item) {
300
+ let children = this.treeData.filter(x => x.parentId === item.id);
301
+ let childrenItem = [...new Set(this.treeData.filter(x => x.rootId === item.id && !!x.childId))];
302
+ if (childrenItem.length > 0) {
303
+ childrenItem = childrenItem.filter(x => listResult.findIndex(node => node.id === x.childId && node.parentId === x.rootId) < 0);
304
+ listResult = listResult.concat([...new Set(childrenItem.map(x => {
305
+ return {
306
+ id: x.childId,
307
+ itemName: x.childName,
308
+ parentId: x.rootId,
309
+ parentName: x.rootName,
310
+ type: SelectOptionTypes.Children
311
+ };
312
+ }))]);
313
+ }
314
+ if (children.length > 0) {
315
+ children = children.filter(x => listResult.findIndex(node => node.id === x.rootId && node.parentId === x.parentId) < 0);
316
+ const uniqueChildren = children.map(x => {
317
+ var _a;
237
318
  return {
238
- id: x.childId,
239
- name: item.childName,
240
- children: [],
241
- parentId: item.rootId
319
+ id: x.rootId,
320
+ itemName: ((_a = x.parentId) === null || _a === void 0 ? void 0 : _a.length) > 0 ? x.subName : x.rootName,
321
+ parentId: x.parentId,
322
+ type: SelectOptionTypes.IncludeChildren
242
323
  };
243
324
  });
244
- let nodeSubfolders = this.treeData.
245
- filter(x => x.parentId === item.rootId);
246
- if (this.treeConfig.showCheckBox) {
247
- nodeChildren.forEach(x => {
248
- this.checkedNodeList.push({
249
- id: x.id,
250
- itemName: x.name,
251
- itemNumberId: item.displayId.toString(),
252
- parentId: item.rootId,
253
- parentName: item.rootName
254
- });
325
+ listResult = listResult.concat(uniqueChildren.filter((x, index) => {
326
+ return index === uniqueChildren.findIndex(node => node.id === x.id && node.parentId === x.parentId);
327
+ }));
328
+ children.forEach(node => {
329
+ listResult = this.getAllChildrenNodeRecursive(listResult, {
330
+ id: node.rootId,
331
+ name: node.rootName,
332
+ parentId: node.parentId,
333
+ level: 0,
334
+ expandable: true,
335
+ hasChild: true,
336
+ disabled: false
255
337
  });
256
- }
257
- else {
258
- nodeChildren.forEach(x => {
259
- this.SelectOption.push({
260
- id: x.id,
261
- itemName: x.name,
262
- itemNumberId: item.displayId.toString(),
263
- parentId: item.rootId,
264
- parentName: item.rootName
265
- });
266
- });
267
- }
268
- this.dataTrees.toArray()[0].todoItemSelection([node].concat(nodeChildren));
269
- if (nodeSubfolders) {
270
- nodeSubfolders.forEach(folder => {
271
- this.selectNodeRecursive(folder);
272
- });
273
- }
274
- }
275
- return;
276
- }
277
- // setTypeProcess(expand) {
278
- // return expand ? this.dataType.area : this.dataType.process;
279
- // }
280
- getCommonCheckedNode(list) {
281
- this.checkedNodeList = [];
282
- this.commonCheckedList = [];
283
- this.singleProcessList = [];
284
- if (list.length) {
285
- list.forEach(item => {
286
- const index = this.checkedNodeList.findIndex(x => x.id === item.id && x.parentId === item.parentId);
287
- if (item.id && index < 0) {
288
- this.commonCheckedList.push(item);
289
- }
290
- if (this.singleSelectOption) {
291
- let position;
292
- if (item.expandable) {
293
- position = this.treeData.findIndex(p => p.rootId === item.id);
294
- }
295
- else {
296
- position = this.treeData.findIndex(p => p.childId === item.id);
297
- }
298
- if (position > -1) {
299
- this.singleProcessList.push({
300
- id: item.id,
301
- itemName: item.name,
302
- itemNumberId: this.treeData[position].displayId.toString(),
303
- parentId: item.parentId,
304
- levelType: item.levelType
305
- });
306
- }
307
- }
308
- if (item.id && index < 0 && !item.expandable && !this.singleSelectOption) {
309
- const position = this.treeData.findIndex(p => p.childId === item.id && p.rootId === item.parentId);
310
- if (position > -1) {
311
- this.checkedNodeList.push({
312
- id: item.id,
313
- itemName: item.name,
314
- parentId: item.parentId,
315
- parentName: this.treeData[position].parentId ? this.treeData[position].subName : this.treeData[position].rootName,
316
- itemNumberId: this.treeData[position].displayId.toString(),
317
- levelType: item.levelType
318
- });
319
- }
320
- }
321
338
  });
322
- if (this.singleSelectOption) {
323
- this.checkedNodeList = [...this.checkedNodeList, ...this.singleProcessList];
324
- }
325
- if (this.maxSelectItemCount && this.maxSelectItemCount > 0) {
326
- const removeList = this.checkedNodeList.slice(0, this.maxSelectItemCount * -1);
327
- if (removeList.length) {
328
- removeList.forEach(item => {
329
- this.removeCheckedNodeList({
330
- id: item.id,
331
- name: item.itemName,
332
- parentId: item.parentId,
333
- level: 0,
334
- expandable: true,
335
- hasChild: true,
336
- disabled: false
337
- });
338
- });
339
- }
340
- this.checkedNodeList = this.checkedNodeList.slice(this.maxSelectItemCount * -1);
341
- }
342
339
  }
340
+ return listResult;
343
341
  }
344
342
  onCloseClick() {
345
343
  this.selectedFolder = null;
@@ -347,13 +345,8 @@ export class SelectIncludeChildrenPopUpComponent {
347
345
  }
348
346
  ;
349
347
  onAddClick() {
350
- // if (this.treeConfig.showCheckBox) {
351
348
  this.selectedFolder = null;
352
349
  this.dialogRef.close(this.checkedNodeList);
353
- // }
354
- // else {
355
- // this.dialogRef.close(this.SelectOption);
356
- // }
357
350
  }
358
351
  getOffsetHeight(element, includeMargin) {
359
352
  let elmHeight = 0, elmMargin = 0;
@@ -365,100 +358,14 @@ export class SelectIncludeChildrenPopUpComponent {
365
358
  return (elmHeight + elmMargin);
366
359
  }
367
360
  getItemChipName(item) {
368
- return (item.parentName) ? `${item.parentName}/${item.itemName}` : item.itemName;
361
+ return `${item.itemName}`;
362
+ }
363
+ getItemSelectedChildrenRatio(item) {
364
+ return `${item.noSelectedChildren}/${item.noChildren}`;
369
365
  }
370
366
  isEllipsisActive(e) {
371
367
  return e ? (e.clientWidth < e.scrollWidth) : false;
372
368
  }
373
- // getNodeIcon(item: SelectOption) {
374
- // switch (item.itemType) {
375
- // case DataType.folder: {
376
- // switch (item.levelType) {
377
- // case DocumentNodeType.DepartmentFolder:
378
- // return 'department_folder_outlined';
379
- // case DocumentNodeType.RegionalFolder:
380
- // return 'regional_folder_outlined';
381
- // case DocumentNodeType.TopFolder:
382
- // return 'enterprise_folder_outlined';
383
- // case DocumentNodeType.Folder:
384
- // return 'local_folder_outlined';
385
- // default:
386
- // return 'folder_outlined';
387
- // }
388
- // }
389
- // case DataType.document: {
390
- // switch (item.levelType) {
391
- // case DocumentNodeType.DepartmentFolder:
392
- // return 'document_department';
393
- // case DocumentNodeType.RegionalFolder:
394
- // return 'document_regional';
395
- // case DocumentNodeType.TopFolder:
396
- // return 'document_enterprise';
397
- // case DocumentNodeType.Folder:
398
- // return 'document_local';
399
- // default:
400
- // return 'document';
401
- // }
402
- // }
403
- // case DataType.area:
404
- // return 'process_area_outlined';
405
- // case DataType.process:
406
- // return 'process';
407
- // case DataType.deviation:
408
- // return 'deviation';
409
- // case DataType.checklist:
410
- // return 'checklist';
411
- // case DataType.risk:
412
- // return 'risk';
413
- // default:
414
- // return 'folder_outlined';
415
- // }
416
- // }
417
- // getSearchOrder() {
418
- // let searchTypes = Object.keys(this.dataType)
419
- // .map(key => ({ value: this.dataType[key], key: key }));
420
- // searchTypes = searchTypes.slice(searchTypes.length / 2);
421
- // return searchTypes;
422
- // }
423
- // getTitle(type: number) {
424
- // switch (type) {
425
- // case DataType.process:
426
- // return this.LANG.PROCESSES;
427
- // case DataType.area:
428
- // return this.LANG.PROCESS_AREA;
429
- // case DataType.document:
430
- // return this.LANG.DOCUMENTS;
431
- // case DataType.folder:
432
- // return this.LANG.FOLDER;
433
- // case DataType.deviation:
434
- // return this.LANG.DEVIATION;
435
- // case DataType.deviationType:
436
- // return this.LANG.DEVIATION_TYPE;
437
- // case DataType.checklist:
438
- // return this.LANG.CHECKLIST;
439
- // case DataType.checklistCategory:
440
- // return this.LANG.CHECKLIST_CATEGORY;
441
- // case DataType.risk:
442
- // return this.LANG.ASSESSMENT;
443
- // case DataType.riskFolder:
444
- // return this.LANG.FOLDER;
445
- // }
446
- // }
447
- // getParentName(item: SelectOption) {
448
- // if (item.itemType === this.dataType.checklist || item.itemType === this.dataType.deviation) {
449
- // return item.parentName;
450
- // }
451
- // return null;
452
- // }
453
- // getItemId(item: SelectOption) {
454
- // if (item.itemType === this.dataType.process) {
455
- // return `${this.LANG.PROCESS_ID}: ${item.itemNumberId}; ${item.statusName}`;
456
- // }
457
- // else if (item.itemType === this.dataType.document) {
458
- // return `${this.LANG.DOCUMENT_ID}: ${item.itemNumberId}; ${item.statusName}`;
459
- // }
460
- // return null;
461
- // }
462
369
  toggleSelectItem(node) {
463
370
  const SelectOption = this.checkedNodeList.find(x => (x.id.toLowerCase() === node.id.toLowerCase() && x.parentId.toLowerCase() === node.parentId.toLowerCase()));
464
371
  if (SelectOption) {
@@ -497,47 +404,228 @@ export class SelectIncludeChildrenPopUpComponent {
497
404
  this.onExpandFolder.emit(item);
498
405
  // }
499
406
  }
500
- // canShowSearchOption(moduleId: number) {
501
- // if (this.canOnlySelectItem &&
502
- // (moduleId === DataType.checklistCategory
503
- // || moduleId === DataType.riskFolder
504
- // || moduleId === DataType.deviationType
505
- // || (moduleId === DataType.area && this.treeConfig && !this.treeConfig.singleSelectOption)
506
- // || (moduleId === DataType.folder && this.treeConfig2 && !this.treeConfig2.singleSelectOption)
507
- // )) {
508
- // return false;
509
- // }
510
- // return this.getModuleFilteredOptions(moduleId).length > 0;
511
- // }
512
407
  selectNodeTreeEvent(node) {
513
- var _a, _b;
514
- let position = -1;
515
- let parentName = '';
516
- let itemNumberId = '';
517
- position = !node.expandable ? this.treeData.findIndex(p => p.childId === node.id && p.rootId === node.parentId) :
518
- this.treeData.findIndex(p => p.rootId === node.id);
519
- parentName = this.treeData[position].parentId ? this.treeData[position].subName : this.treeData[position].rootName;
520
- itemNumberId = (_b = (_a = this.treeData[position]) === null || _a === void 0 ? void 0 : _a.displayId) === null || _b === void 0 ? void 0 : _b.toString();
521
- this.checkedNodeList = [];
522
- this.checkedNodeList.push({
523
- id: node.id,
524
- itemName: node.name,
525
- parentId: node.parentId,
526
- parentName: parentName,
527
- itemNumberId: itemNumberId,
528
- levelType: node.levelType
529
- });
530
- }
531
- getChildNodeSelectOne(listChildren) {
532
- this.listChildrenSelectOne = [];
533
- this.listChildrenSelectOne = listChildren;
408
+ let position = this.selectedOptions.findIndex(x => x.id === node.id && x.parentId === node.parentId);
409
+ if (position > -1) {
410
+ if (this.includeChildren) {
411
+ if (node.expandable) {
412
+ this.removeIncludeChildren(node);
413
+ }
414
+ else {
415
+ const itemIndex = this.selectedOptions.findIndex(item => node.id === item.id && node.parentId === item.parentId);
416
+ if (itemIndex >= 0) {
417
+ this.selectedOptions.splice(itemIndex, 1);
418
+ }
419
+ }
420
+ this.checkedNodeList = this.checkedNodeList.filter(x => x.id !== node.id || x.parentId !== node.parentId);
421
+ this.refactorSelectList(node);
422
+ }
423
+ else {
424
+ const itemIndex = this.selectedOptions.findIndex(item => node.id === item.id && node.parentId === item.parentId);
425
+ if (itemIndex >= 0) {
426
+ this.selectedOptions.splice(itemIndex, 1);
427
+ }
428
+ this.checkedNodeList = this.checkedNodeList.filter(x => x.id !== node.id || x.parentId !== node.parentId);
429
+ }
430
+ }
431
+ else {
432
+ if (this.includeChildren) {
433
+ if (node.expandable) {
434
+ this.selectIncludeChildren(node);
435
+ }
436
+ else {
437
+ this.selectedOptions.push({
438
+ id: node.id,
439
+ itemName: node.name,
440
+ itemNumberId: node.id,
441
+ parentId: node.parentId,
442
+ type: SelectOptionTypes.Children
443
+ });
444
+ }
445
+ this.refactorSelectList(node);
446
+ }
447
+ else {
448
+ this.selectedOptions.push({
449
+ id: node.id,
450
+ itemName: node.name,
451
+ itemNumberId: node.id,
452
+ parentId: node.parentId,
453
+ type: SelectOptionTypes.SelectOne
454
+ });
455
+ this.checkedNodeList.push({
456
+ id: node.id,
457
+ itemName: node.name,
458
+ type: SelectOptionTypes.SelectOne,
459
+ parentId: node.parentId,
460
+ children: [],
461
+ noSelectedChildren: 0,
462
+ noChildren: 0,
463
+ });
464
+ }
465
+ }
466
+ this.selectedData = this.mapSelectOptionToTreeNode(this.selectedOptions);
534
467
  }
535
468
  setValue(e) {
536
469
  this.includeChildren = !!e.checked;
470
+ if (!this.includeChildren) {
471
+ this.checkedNodeList.forEach(node => {
472
+ this.disableSelectedNode(node);
473
+ });
474
+ }
475
+ else {
476
+ this.disabledList = this.orginalDisableList;
477
+ }
478
+ }
479
+ mapSelectOptionToTreeNode(list) {
480
+ return list.map(x => {
481
+ return {
482
+ id: x.id,
483
+ name: x.itemName,
484
+ level: 0,
485
+ expandable: true,
486
+ hasChild: true,
487
+ parentId: x.parentId,
488
+ disabled: false,
489
+ };
490
+ });
491
+ }
492
+ refactorSelectList(node) {
493
+ let parent;
494
+ let parentList = [];
495
+ parent = this.treeData.find(x => x.rootId === node.parentId);
496
+ if (parent) {
497
+ parentList.push({
498
+ id: parent.rootId,
499
+ itemName: parent.rootName,
500
+ parentId: parent.parentId,
501
+ type: SelectOptionTypes.IncludeChildren
502
+ });
503
+ parentList = this.getParentLineOfNode(parentList, parent);
504
+ }
505
+ if (parentList.length > 0) {
506
+ const selectedParentList = parentList.filter(x => this.selectedOptions
507
+ .findIndex(selectedNode => x.id === selectedNode.id && x.parentId === selectedNode.parentId) >= 0);
508
+ if (selectedParentList.length > 0) {
509
+ const highestSelectedNode = selectedParentList[selectedParentList.length - 1];
510
+ this.combineNodes(highestSelectedNode);
511
+ }
512
+ else {
513
+ this.combineNodes({
514
+ id: node.id,
515
+ itemName: node.name,
516
+ type: SelectOptionTypes.IncludeChildren,
517
+ parentId: node.parentId
518
+ });
519
+ }
520
+ }
521
+ else {
522
+ this.combineNodes({
523
+ id: node.id,
524
+ itemName: node.name,
525
+ type: SelectOptionTypes.IncludeChildren,
526
+ parentId: node.parentId
527
+ });
528
+ }
529
+ }
530
+ combineNodes(root) {
531
+ let children = [];
532
+ children = this.getAllChildrenNodeRecursive(children, {
533
+ id: root.id,
534
+ name: root.itemName,
535
+ parentId: root.parentId,
536
+ level: 0,
537
+ expandable: true,
538
+ hasChild: true,
539
+ disabled: false
540
+ });
541
+ let selectedNodeIndex = this.checkedNodeList.findIndex(x => x.id === root.id && x.parentId === root.parentId);
542
+ let nodeList = [];
543
+ children.forEach(child => {
544
+ const index = this.checkedNodeList.findIndex(node => node.id === child.id && node.parentId === child.parentId);
545
+ if (index >= 0) {
546
+ this.checkedNodeList.splice(index, 1);
547
+ }
548
+ const selectIndex = this.selectedOptions.findIndex(node => node.id === child.id && node.parentId === child.parentId);
549
+ if (selectIndex >= 0) {
550
+ nodeList.push(child);
551
+ }
552
+ });
553
+ if (nodeList.length > 0 || children.length === 0) {
554
+ if (selectedNodeIndex < 0) {
555
+ this.checkedNodeList.push({
556
+ id: root.id,
557
+ itemName: root.itemName,
558
+ type: SelectOptionTypes.IncludeChildren,
559
+ parentId: root.parentId,
560
+ children: [],
561
+ noSelectedChildren: 0,
562
+ noChildren: 0
563
+ });
564
+ selectedNodeIndex = this.checkedNodeList.length - 1;
565
+ }
566
+ this.checkedNodeList[selectedNodeIndex].children = nodeList;
567
+ this.checkedNodeList[selectedNodeIndex].noChildren = children.length;
568
+ this.checkedNodeList[selectedNodeIndex].noSelectedChildren = nodeList.length;
569
+ this.checkedNodeList[selectedNodeIndex].type = children.length === 0 ? SelectOptionTypes.SelectOne : SelectOptionTypes.IncludeChildren;
570
+ }
571
+ }
572
+ getParentLineOfNode(listParent, node) {
573
+ let parent;
574
+ parent = this.treeData.find(x => x.rootId === node.parentId);
575
+ if (parent) {
576
+ listParent = [...listParent, {
577
+ id: parent.rootId,
578
+ itemName: parent.rootName,
579
+ parentId: parent.parentId,
580
+ type: SelectOptionTypes.IncludeChildren
581
+ }];
582
+ this.getParentLineOfNode(listParent, parent);
583
+ }
584
+ return listParent;
585
+ }
586
+ disableSelectedNode(node) {
587
+ if (node.type === SelectOptionTypes.IncludeChildren) {
588
+ let children = [];
589
+ children = this.getAllChildrenNodeRecursive(children, {
590
+ id: node.id,
591
+ name: node.itemName,
592
+ parentId: node.parentId,
593
+ level: 0,
594
+ expandable: true,
595
+ hasChild: true,
596
+ disabled: false
597
+ });
598
+ let disableNodes = [];
599
+ const index = this.disabledList.findIndex(x => x.id === node.id && x.parentId === node.parentId);
600
+ if (index < 0) {
601
+ disableNodes.push(node);
602
+ }
603
+ children.forEach(child => {
604
+ const index = this.disabledList.findIndex(x => x.id === child.id && x.parentId === child.parentId);
605
+ if (index < 0) {
606
+ disableNodes.push(child);
607
+ }
608
+ });
609
+ this.disabledList = [...this.disabledList, ...disableNodes];
610
+ }
611
+ }
612
+ enableSelectedNode(node) {
613
+ let children = [];
614
+ children = this.getAllChildrenNodeRecursive(children, {
615
+ id: node.id,
616
+ name: node.itemName,
617
+ parentId: node.parentId,
618
+ level: 0,
619
+ expandable: true,
620
+ hasChild: true,
621
+ disabled: false
622
+ });
623
+ this.disabledList = this.disabledList.filter(x => children.filter(child => (x.id === child.id && x.parentId === child.parentId)).length === 0);
624
+ this.disabledList = this.disabledList.filter(x => !(x.id === node.id && x.parentId === node.parentId));
537
625
  }
538
626
  }
539
627
  SelectIncludeChildrenPopUpComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.0.5", ngImport: i0, type: SelectIncludeChildrenPopUpComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.TranslateLibraryService }, { token: i2.MatDialogRef }, { token: i3.QMSSelectGlobalService }, { token: i4.MatIconRegistry }, { token: i5.DomSanitizer }, { token: i6.QMSIconRegistryService }, { token: i0.ElementRef }, { token: MAT_DIALOG_DATA }], target: i0.ɵɵFactoryTarget.Component });
540
- SelectIncludeChildrenPopUpComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.0.5", type: SelectIncludeChildrenPopUpComponent, selector: "qms-select-include-children-popup", host: { listeners: { "window:message": "onMessage($event)" } }, viewQueries: [{ propertyName: "autoComplete", first: true, predicate: ["autoCompleteInputSearch"], descendants: true, read: MatAutocompleteTrigger, static: true }, { propertyName: "dataTrees", predicate: TreeComponent, descendants: true }], ngImport: i0, template: "<div id=\"qmslib_related_popup\" class=\"qmslib__related__popup__container\">\r\n <div id=\"qmslib_related_popup_header\">\r\n <span mat-icon-button class=\"button__close\" (click)=\"onCloseClick()\">\r\n <mat-icon mat-icon>close</mat-icon>\r\n </span>\r\n <div id=\"qmslib_related_popup_header_001\" mat-dialog-content>\r\n <span>{{ headerName | uppercase }}</span>\r\n </div>\r\n </div>\r\n \r\n <div\r\n id=\"qmslib_related_popup_search\"\r\n class=\"input__field\"\r\n (click)=\"showSearchResult()\"\r\n >\r\n <input\r\n #name\r\n type=\"text\"\r\n placeholder=\"{{ LANG.SEARCH }}\"\r\n matInput\r\n [formControl]=\"myControl\"\r\n [matAutocomplete]=\"auto\"\r\n #autoCompleteInputSearch\r\n />\r\n <mat-icon>search</mat-icon>\r\n </div>\r\n \r\n <div class=\"line__divider\"></div>\r\n \r\n <mat-autocomplete\r\n #auto=\"matAutocomplete\"\r\n [displayWith]=\"displayRelated\"\r\n class=\"mat-autocomplete_related-viewport\"\r\n >\r\n <cdk-virtual-scroll-viewport\r\n qms-scrollbar\r\n itemSize=\"10\"\r\n class=\"related-viewport\"\r\n >\r\n <ng-container *ngFor=\"let type of searchOrder\">\r\n <div\r\n class=\"search__module-result\"\r\n *ngIf=\"filteredOptions\"\r\n >\r\n <span class=\"search__module-title\">Hello</span>\r\n <mat-option\r\n class=\"search__option\"\r\n *ngFor=\"let option of getModuleFilteredOptions()\"\r\n [value]=\"option\"\r\n >\r\n <!-- <qms-list-item type=\"image-square\">\r\n <mat-icon\r\n leading-icon\r\n type=\"image-square\"\r\n [svgIcon]=\"getNodeIcon(option)\"\r\n ></mat-icon>\r\n <div qms-list-header>\r\n <div\r\n qms-line\r\n type=\"caption\"\r\n qms-tool-tip=\"{{\r\n isEllipsisActive(searchItemResult) ? option.parentName : ''\r\n }}\"\r\n mode=\"dark\"\r\n *ngIf=\"getParentName(option)\"\r\n >\r\n <span #searchItemResult class=\"search__result__parent-name\">\r\n {{ option.parentName }}\r\n </span>\r\n </div>\r\n <div qms-line type=\"subtitle\" class=\"search__option-name\">\r\n {{ option.itemName }}\r\n </div>\r\n <div\r\n class=\"caption\"\r\n *ngIf=\"option.breadcumbs && option.breadcumbs.length\"\r\n >\r\n <qms-breadcrumb\r\n class=\"breadcrumb-containe\"\r\n type=\"table\"\r\n numDisplayItem=\"1\"\r\n [nodes]=\"option.breadcumbs\"\r\n >\r\n </qms-breadcrumb>\r\n </div>\r\n </div>\r\n <div qms-line color=\"default-subtitle\" *ngIf=\"getItemId(option)\">\r\n <span class=\"material-icons-outlined search__description-icon\">\r\n local_offer\r\n </span>\r\n {{ getItemId(option) }}\r\n </div>\r\n </qms-list-item> -->\r\n </mat-option>\r\n </div>\r\n </ng-container>\r\n </cdk-virtual-scroll-viewport>\r\n </mat-autocomplete>\r\n \r\n <div class=\"row\">\r\n <div\r\n class=\"qms-scrollbar qmslib_related_popup_content col-12\"\r\n [ngClass]=\"{\r\n panel__content_item: checkedNodeList.length,\r\n panel__content: !checkedNodeList.length\r\n }\">\r\n <div id=\"qmslib_related_popup_common_002\">\r\n <qms-tree\r\n [treeData]=\"treeData\"\r\n [treeConfig]=\"treeConfig\"\r\n [selectedData]=\"selectedData\"\r\n [selectedRiskData]=\"selectedRiskData\"\r\n [disabledList]=\"disabledList\"\r\n (checkBoxEvent)=\"getCommonCheckedNode($event)\"\r\n (nodeExpandEvent)=\"getChildrenOfFolder($event)\"\r\n (selectNodeEvent)=\"selectNodeTreeEvent($event)\"\r\n (getChildNodeSelectOne)=\"getChildNodeSelectOne($event)\"\r\n ></qms-tree>\r\n </div>\r\n </div>\r\n \r\n <div *ngIf=\"checkedNodeList.length\" class=\"line__divider\"></div>\r\n \r\n <div *ngIf=\"checkedNodeList.length\" class=\"panel__item qms-scrollbar\">\r\n <div class=\"related__item__inline\" *ngFor=\"let item of checkedNodeList\">\r\n <button\r\n *ngIf=\"item.itemName\"\r\n mat-button\r\n class=\"related__item__content\"\r\n qms-tool-tip=\"{{\r\n isEllipsisActive(itemName) ? getItemChipName(item) : ''\r\n }}\"\r\n mode=\"dark\"\r\n >\r\n <span class=\"related__item__content_name\" #itemName>\r\n {{getItemChipName(item)}}</span>\r\n <mat-icon\r\n *ngIf=\"!treeConfig?.selectOne\"\r\n (click)=\"removeCheckedNodeList(item)\"\r\n >cancel</mat-icon\r\n >\r\n </button>\r\n </div>\r\n <div class=\"select__toggle-include\">\r\n <mat-slide-toggle\r\n [checked]=\"includeChildren\"\r\n (change)=\"setValue($event)\"\r\n color=\"default\"\r\n qms-group-options>\r\n <span class=\"text-label\">Select label</span>\r\n </mat-slide-toggle>\r\n </div>\r\n </div>\r\n \r\n <div class=\"line__divider\"></div>\r\n \r\n <div class=\"confirm__button__groups\">\r\n <button\r\n *ngIf=\"!checkedNodeList.length\"\r\n qms-btn\r\n style=\"margin-top: 7px\"\r\n (click)=\"onAddClick()\"\r\n >\r\n {{ LANG.ADD }}\r\n </button>\r\n <button\r\n *ngIf=\"checkedNodeList.length\"\r\n qms-btn\r\n style=\"margin-top: 0px\"\r\n (click)=\"onAddClick()\"\r\n >\r\n {{ LANG.ADD }} ({{ checkedNodeList.length }})\r\n </button>\r\n <button\r\n qms-btn-text\r\n [ngStyle]=\"{ 'margin-top': checkedNodeList.length ? '0px' : '7px' }\"\r\n (click)=\"onCloseClick()\"\r\n >\r\n {{ LANG.CANCEL }}\r\n </button>\r\n </div>\r\n</div>\r\n ", styles: [".qms-scrollbar::-webkit-scrollbar{width:12px}.qms-scrollbar::-webkit-scrollbar-track{background:rgba(0,0,0,.12);background-clip:content-box}.qms-scrollbar::-webkit-scrollbar-thumb{background:rgba(0,0,0,.38);border-radius:20px;width:4px;border:4px solid transparent;background-clip:content-box}.qms-scrollbar::-webkit-scrollbar-thumb:hover{background:rgba(0,0,0,.5);background-clip:content-box;border:4px solid transparent}.qms-scrollbar.none-scroll-bg::-webkit-scrollbar-track{background:transparent;background-clip:content-box}.qms__popup .button__close{float:right;top:-24px;right:-24px;cursor:pointer}.qms__danger button{border:none;color:#fff;padding:0;text-align:center;text-decoration:none;display:inline-block;cursor:pointer;height:20px;width:20px;font-family:Open Sans;font-size:12px;font-weight:600;font-style:normal;line-height:16px}.qms__danger .red{background-color:#9e360f;margin-left:10px}.qms__danger .yellow{background-color:#e4cf53;margin-left:10px;color:#323232}.qms__danger .green{background-color:#00804c;margin-left:10px}.confirm__button__groups{margin-top:11px}.confirm__button__groups button{min-height:36px;width:auto;font-family:Open Sans;font-weight:500;font-size:14px;letter-spacing:1px;line-height:16px;padding-left:15px;padding-right:15px;margin-right:5px;float:right}.confirm__button__groups .confirm{background:#f8f9f9}.confirm__button__groups .confirm:hover{background:#001983;color:#fff}.confirm__button__groups .confirm:disabled{cursor:not-allowed}.confirm__button__groups .cancel{background:#f8f9f9}.confirm__button__groups .cancel:hover{background:#001983;color:#fff}.qmslib__related__popup__container .input__field{display:flex;align-items:center}.qmslib__related__popup__container .input__field input{width:100%;padding:10px;outline:none;border:none;background:#eee}.qmslib__related__popup__container .input__field .mat-icon{margin-left:-30px;cursor:pointer;vertical-align:middle}.qmslib__related__popup__container .line__divider{border-bottom:1px solid #ccc;height:1px;margin-top:10px;min-width:300px;max-width:100%}.qmslib__related__popup__container .button__close{float:right;top:-24px;right:-24px;cursor:pointer}.qmslib__related__popup__container .panel__content{height:450px;overflow:auto;margin-top:12px}.qmslib__related__popup__container .panel__content_item{height:350px;overflow:auto;margin-top:12px}.qmslib__related__popup__container .panel-tree .mat-expansion-panel-body{padding:0 12px 12px}.qmslib__related__popup__container .mat-expansion-panel-header{height:30px;font-size:12px;letter-spacing:1px;font-family:Raleway;font-weight:600;padding:0}.qmslib__related__popup__container .mat-expansion-panel-header .mat-expansion-panel-header-title{align-items:center;margin-left:12px}.qmslib__related__popup__container .mat-expansion-panel-header .related_popup_toggle-btn{width:1.5rem;height:1.5rem;line-height:1.5rem}.qmslib__related__popup__container .mat-expansion-panel:not([class*=mat-elevation-z]){box-shadow:none}.qmslib__related__popup__container .panel__item{height:100px;margin-top:12px;overflow-x:hidden;overflow-y:auto;padding-right:5px;width:100%;max-width:100%;display:flex;flex-wrap:wrap;align-content:flex-start}.qmslib__related__popup__container .panel__item .related__item__inline{max-width:100%}.qmslib__related__popup__container .panel__item .select__toggle-include{width:100%}.qmslib__related__popup__container .panel__item .related__item__content{height:32px;line-height:32px;background-color:#e5e5e5;max-width:100%;margin-bottom:5px;margin-left:2.5px;margin-right:2.5px}.qmslib__related__popup__container .panel__item .related__item__content .mat-icon{color:#8e8e8e;font-size:24px}.qmslib__related__popup__container .panel__item .related__item__content span.related__item__content_name{display:inline-block;min-width:calc(100% - 13px);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:320px}.qmslib__related__popup__container .qmslib-related-popup-splitview{background-color:#fff;border-left:1px solid #ccc;height:450px;overflow-y:auto;margin-top:12px}.qmslib__related__popup__container .qmslib-related-popup-splitview.panel__content{height:450px;overflow:auto;margin-top:12px}.qmslib__related__popup__container .qmslib-related-popup-splitview.panel__content_item{height:350px;overflow:auto;margin-top:12px}.qmslib__related__popup__container .qmslib-related-popup-splitview .splitview-header{height:30px;font-size:12px;letter-spacing:1px;font-family:RALEWAY;font-weight:600;display:flex;align-items:center}.qmslib__related__popup__container .qmslib-related-popup-splitview .mat-checkbox.qms-group-options{padding:0}.qmslib__related__popup__container .qmslib-related-popup-splitview .mat-checkbox.qms-group-options .mat-checkbox-inner-container{margin-right:11px}.qmslib__related__popup__container .qmslib-related-popup-splitview .mat-checkbox.qms-group-options.mat-checkbox-checked{background:transparent!important}.qmslib__related__popup__container .qmslib-related-popup-splitview .expand-node{margin-left:8px;display:flex;align-items:center;min-height:40px}.qmslib__related__popup__container .qmslib-related-popup-splitview .expand-node .mat-icon{color:rgba(0,0,0,.6);margin-right:17px;min-width:-webkit-fit-content;min-width:-moz-fit-content;min-width:fit-content}.qmslib__related__popup__container .qmslib-related-popup-splitview .expand-node .mat-icon svg{display:block;min-width:-webkit-fit-content;min-width:-moz-fit-content;min-width:fit-content}cdk-virtual-scroll-viewport{overflow-x:hidden}cdk-virtual-scroll-viewport .search__module-result{margin:1.5rem;padding:0 0 .5rem}cdk-virtual-scroll-viewport .search__module-result .search__module-title{font-size:14px;font-weight:600}cdk-virtual-scroll-viewport .search__module-result .search__option{height:auto;line-height:normal;padding:8px 0;border-bottom:1px solid #e0e0e0}cdk-virtual-scroll-viewport .search__module-result .search__option .qms-list-item.mat-2-line.image-item{height:auto}cdk-virtual-scroll-viewport .search__module-result .search__option .qms-list-item-content{margin:0;border-bottom:none}cdk-virtual-scroll-viewport .search__module-result .search__option .qms-list-item-content .wrap-image.image-square{width:2.5rem;height:100%;background:transparent;align-self:center;margin-right:0}cdk-virtual-scroll-viewport .search__module-result .search__option .qms-list-item-content .wrap-image.image-square img{width:24px;height:24px}cdk-virtual-scroll-viewport .search__module-result .search__option .qms-list-item-content .material-icons-outlined.leading-icon,cdk-virtual-scroll-viewport .search__module-result .search__option .qms-list-item-content mat-icon.leading-icon{padding:4px 0 4px 4px}cdk-virtual-scroll-viewport .search__module-result .search__option .qms-list-item-content .subtitle{font-weight:400}cdk-virtual-scroll-viewport .search__module-result .search__option .qms-list-item-content .caption{overflow:hidden;line-height:normal;white-space:normal;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;padding:0;margin:0}cdk-virtual-scroll-viewport .search__module-result .search__option .qms-list-item-content .caption span.search__result__parent-name{display:inline-block;width:auto;width:calc(100% - 13px);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}cdk-virtual-scroll-viewport .search__module-result .search__option .qms-list-item-content .default-subtitle{color:rgba(0,0,0,.38)}cdk-virtual-scroll-viewport .search__module-result .search__option .qms-list-item-content .search__description-icon{margin-right:0;width:12px;height:12px;font-size:12px}cdk-virtual-scroll-viewport .search__module-result .search__option .qms-list-item-content .qms-list-text{border-bottom:none}cdk-virtual-scroll-viewport .search__module-result .search__option .qms-list-item-content .breadcrumb-containe .qms-breadcrumb-item .mat-icon{font-size:16px!important;padding-bottom:1px}cdk-virtual-scroll-viewport .search__module-result svg{display:block}#qmslib_related_popup_header_001{margin-bottom:20px;padding:0;font-weight:600;font-family:Raleway}.padding-5{padding:5px}.mat-autocomplete_related-viewport{height:100%;max-height:100%!important}.mat-autocomplete_related-viewport .cdk-virtual-scroll-content-wrapper{width:100%}.mat-autocomplete_related-viewport .related-viewport{min-height:10.25rem}"], components: [{ type: i4.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { type: i7.MatAutocomplete, selector: "mat-autocomplete", inputs: ["disableRipple"], exportAs: ["matAutocomplete"] }, { type: i8.CdkVirtualScrollViewport, selector: "cdk-virtual-scroll-viewport", inputs: ["orientation"], outputs: ["scrolledIndexChange"] }, { type: i9.MatOption, selector: "mat-option", exportAs: ["matOption"] }, { type: i10.TreeComponent, selector: "qms-tree", inputs: ["treeData", "treeConfig", "selectedData", "selectedRiskData", "disabledList", "expandOnTitleClick"], outputs: ["selectNodeEvent", "selectFolderEvent", "checkBoxEvent", "childCheckedEvent", "nodeExpandEvent", "getChildNodeSelectOne"] }, { type: i11.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { type: i12.MatSlideToggle, selector: "mat-slide-toggle", inputs: ["disabled", "disableRipple", "color", "tabIndex", "name", "id", "labelPosition", "aria-label", "aria-labelledby", "required", "checked"], outputs: ["change", "toggleChange"], exportAs: ["matSlideToggle"] }, { type: i13.QMSButton, selector: "button[qms-btn], button[qms-btn-lg], button[qms-btn-outlined],\n button[qms-btn-outlined-lg], button[qms-btn-text], button[qms-btn-text-lg],\n button[qms-btn-fab],button[qms-btn-fab-sm],button[qms-btn-fab-ext],\n button[qms-btn-fab-outlined],button[qms-btn-fab-outlined-sm],button[qms-btn-fab-outlined-ext]", inputs: ["disabled", "color"], exportAs: ["qmsButton"] }], directives: [{ type: i2.MatDialogContent, selector: "[mat-dialog-content], mat-dialog-content, [matDialogContent]" }, { type: i14.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["id", "disabled", "required", "type", "value", "readonly", "placeholder", "errorStateMatcher", "aria-describedby"], exportAs: ["matInput"] }, { type: i15.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i7.MatAutocompleteTrigger, selector: "input[matAutocomplete], textarea[matAutocomplete]", exportAs: ["matAutocompleteTrigger"] }, { type: i15.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i15.FormControlDirective, selector: "[formControl]", inputs: ["disabled", "formControl", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { type: i8.CdkFixedSizeVirtualScroll, selector: "cdk-virtual-scroll-viewport[itemSize]", inputs: ["itemSize", "minBufferPx", "maxBufferPx"] }, { type: i16.QMSScrollbarDirective, selector: "[qms-scrollbar]", inputs: ["isNoneBackground"] }, { type: i17.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i17.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i17.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i18.QMSToolTipRendererDirective, selector: "[qms-tool-tip]", inputs: ["showToolTip", "mode", "qms-tool-tip", "contentTemplate", "position"] }, { type: i19.QMSGroupOptionDirective, selector: "[qms-group-options]" }, { type: i19.AutocompleteOffDirective, selector: "[qms-group-options]" }, { type: i17.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }], pipes: { "uppercase": i17.UpperCasePipe }, encapsulation: i0.ViewEncapsulation.None });
628
+ SelectIncludeChildrenPopUpComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.0.5", type: SelectIncludeChildrenPopUpComponent, selector: "qms-select-include-children-popup", host: { listeners: { "window:message": "onMessage($event)" } }, viewQueries: [{ propertyName: "autoComplete", first: true, predicate: ["autoCompleteInputSearch"], descendants: true, read: MatAutocompleteTrigger, static: true }, { propertyName: "dataTrees", predicate: TreeComponent, descendants: true }], ngImport: i0, template: "<div id=\"qmslib_related_popup\" class=\"qmslib__related__popup__container\">\r\n <div id=\"qmslib_related_popup_header\">\r\n <span mat-icon-button class=\"button__close\" (click)=\"onCloseClick()\">\r\n <mat-icon mat-icon>close</mat-icon>\r\n </span>\r\n <div id=\"qmslib_related_popup_header_001\" mat-dialog-content>\r\n <span>{{ headerName | uppercase }}</span>\r\n </div>\r\n </div>\r\n \r\n <div\r\n id=\"qmslib_related_popup_search\"\r\n class=\"input__field\"\r\n (click)=\"showSearchResult()\"\r\n >\r\n <input\r\n #name\r\n type=\"text\"\r\n placeholder=\"{{ LANG.SEARCH }}\"\r\n matInput\r\n [formControl]=\"myControl\"\r\n [matAutocomplete]=\"auto\"\r\n #autoCompleteInputSearch\r\n />\r\n <mat-icon>search</mat-icon>\r\n </div>\r\n <div class=\"select__toggle-include\">\r\n <mat-slide-toggle\r\n [checked]=\"includeChildren\"\r\n (change)=\"setValue($event)\"\r\n color=\"default\"\r\n qms-group-options>\r\n <span class=\"text-label\">Select label</span>\r\n </mat-slide-toggle>\r\n </div>\r\n <div class=\"line__divider\"></div>\r\n \r\n <mat-autocomplete\r\n #auto=\"matAutocomplete\"\r\n [displayWith]=\"displayRelated\"\r\n class=\"mat-autocomplete_related-viewport\"\r\n >\r\n <cdk-virtual-scroll-viewport\r\n qms-scrollbar\r\n itemSize=\"10\"\r\n class=\"related-viewport\"\r\n >\r\n <div\r\n class=\"search__module-result\"\r\n *ngIf=\"filteredOptions\">\r\n <mat-option\r\n class=\"search__option\"\r\n *ngFor=\"let option of filteredOptions\"\r\n [value]=\"option\"\r\n (click)=\"selectSearchOption(option)\"\r\n >\r\n <qms-list-item type=\"image-square\">\r\n <mat-icon\r\n leading-icon\r\n *ngIf=\"getItemIconType(option) === itemIconType.name\"\r\n class=\"mat-icon-rtl-mirror material-icons-outlined\"\r\n type=\"image-square\"\r\n >\r\n {{ option.itemIcon }}\r\n </mat-icon>\r\n\r\n <mat-icon \r\n leading-icon\r\n *ngIf=\"getItemIconType(option) === itemIconType.svg\"\r\n class=\"mat-icon-rtl-mirror material-icons-outlined\"\r\n type=\"image-square\"\r\n [svgIcon]=\"option.itemIconSvg\"\r\n >\r\n </mat-icon>\r\n\r\n <img \r\n leading-icon\r\n *ngIf=\"getItemIconType(option) === itemIconType.path\"\r\n class=\"mat-icon\"\r\n [src]=\"option.itemIconPath\"\r\n type=\"image-square\"\r\n />\r\n\r\n <img \r\n leading-icon\r\n *ngIf=\"getItemIconType(option) === itemIconType.base64\"\r\n class=\"mat-icon image-base64\"\r\n [src]=\"getImagePath(option)\"\r\n type=\"image-square\"\r\n />\r\n <div qms-list-header>\r\n <div qms-line type=\"subtitle\" class=\"search__option-name\">\r\n {{ option.itemName }}\r\n </div>\r\n </div>\r\n </qms-list-item>\r\n </mat-option>\r\n </div>\r\n </cdk-virtual-scroll-viewport>\r\n </mat-autocomplete>\r\n \r\n <div class=\"row\">\r\n <div\r\n class=\"qms-scrollbar qmslib_related_popup_content col-12\"\r\n [ngClass]=\"{\r\n panel__content_item: checkedNodeList.length,\r\n panel__content: !checkedNodeList.length\r\n }\">\r\n <div id=\"qmslib_related_popup_common_002\">\r\n <qms-tree\r\n [treeData]=\"treeData\"\r\n [treeConfig]=\"treeConfig\"\r\n [selectedData]=\"selectedData\"\r\n [selectedRiskData]=\"selectedRiskData\"\r\n [disabledList]=\"disabledList\"\r\n (checkBoxEvent)=\"getCommonCheckedNode($event)\"\r\n (nodeExpandEvent)=\"getChildrenOfFolder($event)\"\r\n (selectNodeEvent)=\"selectNodeTreeEvent($event)\"\r\n ></qms-tree>\r\n </div>\r\n </div>\r\n \r\n <div *ngIf=\"checkedNodeList.length\" class=\"line__divider\"></div>\r\n \r\n <div *ngIf=\"checkedNodeList.length\" class=\"panel__item qms-scrollbar\">\r\n <div class=\"related__item__inline\" *ngFor=\"let item of checkedNodeList\">\r\n <button\r\n *ngIf=\"item.itemName\"\r\n mat-button\r\n class=\"related__item__content\"\r\n qms-tool-tip=\"{{\r\n isEllipsisActive(itemName) ? getItemChipName(item) : ''\r\n }}\"\r\n mode=\"dark\"\r\n >\r\n <span class=\"related__item__content_name\" #itemName>\r\n {{getItemChipName(item)}}\r\n <span class=\"select__include-children__count\" *ngIf=\"item.noSelectedChildren > 0\">\r\n {{getItemSelectedChildrenRatio(item)}}\r\n </span>\r\n </span>\r\n \r\n <mat-icon\r\n (click)=\"removeCheckedNodeList(item)\"\r\n >cancel</mat-icon\r\n >\r\n </button>\r\n </div>\r\n </div>\r\n \r\n <div class=\"line__divider\"></div>\r\n \r\n <div class=\"confirm__button__groups\">\r\n <button\r\n *ngIf=\"!checkedNodeList.length\"\r\n qms-btn\r\n style=\"margin-top: 7px\"\r\n (click)=\"onAddClick()\"\r\n >\r\n {{ LANG.ADD }}\r\n </button>\r\n <button\r\n *ngIf=\"checkedNodeList.length\"\r\n qms-btn\r\n style=\"margin-top: 0px\"\r\n (click)=\"onAddClick()\"\r\n >\r\n {{ LANG.ADD }} ({{ checkedNodeList.length }})\r\n </button>\r\n <button\r\n qms-btn-text\r\n [ngStyle]=\"{ 'margin-top': checkedNodeList.length ? '0px' : '7px' }\"\r\n (click)=\"onCloseClick()\"\r\n >\r\n {{ LANG.CANCEL }}\r\n </button>\r\n </div>\r\n</div>\r\n ", styles: [".qms-scrollbar::-webkit-scrollbar{width:12px}.qms-scrollbar::-webkit-scrollbar-track{background:rgba(0,0,0,.12);background-clip:content-box}.qms-scrollbar::-webkit-scrollbar-thumb{background:rgba(0,0,0,.38);border-radius:20px;width:4px;border:4px solid transparent;background-clip:content-box}.qms-scrollbar::-webkit-scrollbar-thumb:hover{background:rgba(0,0,0,.5);background-clip:content-box;border:4px solid transparent}.qms-scrollbar.none-scroll-bg::-webkit-scrollbar-track{background:transparent;background-clip:content-box}.qms__popup .button__close{float:right;top:-24px;right:-24px;cursor:pointer}.qms__danger button{border:none;color:#fff;padding:0;text-align:center;text-decoration:none;display:inline-block;cursor:pointer;height:20px;width:20px;font-family:Open Sans;font-size:12px;font-weight:600;font-style:normal;line-height:16px}.qms__danger .red{background-color:#9e360f;margin-left:10px}.qms__danger .yellow{background-color:#e4cf53;margin-left:10px;color:#323232}.qms__danger .green{background-color:#00804c;margin-left:10px}.confirm__button__groups{margin-top:11px}.confirm__button__groups button{min-height:36px;width:auto;font-family:Open Sans;font-weight:500;font-size:14px;letter-spacing:1px;line-height:16px;padding-left:15px;padding-right:15px;margin-right:5px;float:right}.confirm__button__groups .confirm{background:#f8f9f9}.confirm__button__groups .confirm:hover{background:#001983;color:#fff}.confirm__button__groups .confirm:disabled{cursor:not-allowed}.confirm__button__groups .cancel{background:#f8f9f9}.confirm__button__groups .cancel:hover{background:#001983;color:#fff}.qmslib__related__popup__container .input__field{display:flex;align-items:center}.qmslib__related__popup__container .input__field input{width:100%;padding:10px;outline:none;border:none;background:#eee}.qmslib__related__popup__container .input__field .mat-icon{margin-left:-30px;cursor:pointer;vertical-align:middle}.qmslib__related__popup__container .select__toggle-include{width:100%;padding:0;margin:1rem 0}.qmslib__related__popup__container .line__divider{border-bottom:1px solid #ccc;height:1px;margin-top:10px;min-width:300px;max-width:100%}.qmslib__related__popup__container .button__close{float:right;top:-24px;right:-24px;cursor:pointer}.qmslib__related__popup__container .panel__content{height:450px;overflow:auto;margin-top:12px}.qmslib__related__popup__container .panel__content_item{height:350px;overflow:auto;margin-top:12px}.qmslib__related__popup__container .panel-tree .mat-expansion-panel-body{padding:0 12px 12px}.qmslib__related__popup__container .mat-expansion-panel-header{height:30px;font-size:12px;letter-spacing:1px;font-family:Raleway;font-weight:600;padding:0}.qmslib__related__popup__container .mat-expansion-panel-header .mat-expansion-panel-header-title{align-items:center;margin-left:12px}.qmslib__related__popup__container .mat-expansion-panel-header .related_popup_toggle-btn{width:1.5rem;height:1.5rem;line-height:1.5rem}.qmslib__related__popup__container .mat-expansion-panel:not([class*=mat-elevation-z]){box-shadow:none}.qmslib__related__popup__container .panel__item{height:100px;margin-top:12px;overflow-x:hidden;overflow-y:auto;padding-right:5px;width:100%;max-width:100%;display:flex;flex-wrap:wrap;align-content:flex-start}.qmslib__related__popup__container .panel__item .related__item__inline{max-width:100%}.qmslib__related__popup__container .panel__item .related__item__content{height:32px;line-height:32px;background-color:#e5e5e5;max-width:100%;margin-bottom:5px;margin-left:2.5px;margin-right:2.5px}.qmslib__related__popup__container .panel__item .related__item__content .mat-icon{color:#8e8e8e;font-size:24px}.qmslib__related__popup__container .panel__item .related__item__content span.related__item__content_name{display:inline-block;min-width:calc(100% - 13px);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:320px}.qmslib__related__popup__container .panel__item .related__item__content span.related__item__content_name .select__include-children__count{font-size:.75rem;color:rgba(0,0,0,.38)}.qmslib__related__popup__container .qmslib-related-popup-splitview{background-color:#fff;border-left:1px solid #ccc;height:450px;overflow-y:auto;margin-top:12px}.qmslib__related__popup__container .qmslib-related-popup-splitview.panel__content{height:450px;overflow:auto;margin-top:12px}.qmslib__related__popup__container .qmslib-related-popup-splitview.panel__content_item{height:350px;overflow:auto;margin-top:12px}.qmslib__related__popup__container .qmslib-related-popup-splitview .splitview-header{height:30px;font-size:12px;letter-spacing:1px;font-family:RALEWAY;font-weight:600;display:flex;align-items:center}.qmslib__related__popup__container .qmslib-related-popup-splitview .mat-checkbox.qms-group-options{padding:0}.qmslib__related__popup__container .qmslib-related-popup-splitview .mat-checkbox.qms-group-options .mat-checkbox-inner-container{margin-right:11px}.qmslib__related__popup__container .qmslib-related-popup-splitview .mat-checkbox.qms-group-options.mat-checkbox-checked{background:transparent!important}.qmslib__related__popup__container .qmslib-related-popup-splitview .expand-node{margin-left:8px;display:flex;align-items:center;min-height:40px}.qmslib__related__popup__container .qmslib-related-popup-splitview .expand-node .mat-icon{color:rgba(0,0,0,.6);margin-right:17px;min-width:-webkit-fit-content;min-width:-moz-fit-content;min-width:fit-content}.qmslib__related__popup__container .qmslib-related-popup-splitview .expand-node .mat-icon svg{display:block;min-width:-webkit-fit-content;min-width:-moz-fit-content;min-width:fit-content}cdk-virtual-scroll-viewport{overflow-x:hidden}cdk-virtual-scroll-viewport .search__module-result{margin:1.5rem;padding:0 0 .5rem}cdk-virtual-scroll-viewport .search__module-result .search__module-title{font-size:14px;font-weight:600}cdk-virtual-scroll-viewport .search__module-result .search__option{height:auto;line-height:normal;padding:8px 0;border-bottom:1px solid #e0e0e0}cdk-virtual-scroll-viewport .search__module-result .search__option .qms-list-item.mat-2-line.image-item{height:auto}cdk-virtual-scroll-viewport .search__module-result .search__option .qms-list-item-content{margin:0;border-bottom:none}cdk-virtual-scroll-viewport .search__module-result .search__option .qms-list-item-content .wrap-image.image-square{width:2.5rem;height:100%;background:transparent;align-self:center;margin-right:0}cdk-virtual-scroll-viewport .search__module-result .search__option .qms-list-item-content .wrap-image.image-square img{width:24px;height:24px}cdk-virtual-scroll-viewport .search__module-result .search__option .qms-list-item-content .material-icons-outlined.leading-icon,cdk-virtual-scroll-viewport .search__module-result .search__option .qms-list-item-content mat-icon.leading-icon{padding:4px 0 4px 4px}cdk-virtual-scroll-viewport .search__module-result .search__option .qms-list-item-content .subtitle{font-weight:400}cdk-virtual-scroll-viewport .search__module-result .search__option .qms-list-item-content .caption{overflow:hidden;line-height:normal;white-space:normal;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;padding:0;margin:0}cdk-virtual-scroll-viewport .search__module-result .search__option .qms-list-item-content .caption span.search__result__parent-name{display:inline-block;width:auto;width:calc(100% - 13px);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}cdk-virtual-scroll-viewport .search__module-result .search__option .qms-list-item-content .default-subtitle{color:rgba(0,0,0,.38)}cdk-virtual-scroll-viewport .search__module-result .search__option .qms-list-item-content .search__description-icon{margin-right:0;width:12px;height:12px;font-size:12px}cdk-virtual-scroll-viewport .search__module-result .search__option .qms-list-item-content .qms-list-text{border-bottom:none}cdk-virtual-scroll-viewport .search__module-result .search__option .qms-list-item-content .breadcrumb-containe .qms-breadcrumb-item .mat-icon{font-size:16px!important;padding-bottom:1px}cdk-virtual-scroll-viewport .search__module-result svg{display:block}#qmslib_related_popup_header_001{margin-bottom:20px;padding:0;font-weight:600;font-family:Raleway}.padding-5{padding:5px}.mat-autocomplete_related-viewport{height:100%;max-height:100%!important}.mat-autocomplete_related-viewport .cdk-virtual-scroll-content-wrapper{width:100%}.mat-autocomplete_related-viewport .related-viewport{min-height:10.25rem}"], components: [{ type: i4.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { type: i7.MatSlideToggle, selector: "mat-slide-toggle", inputs: ["disabled", "disableRipple", "color", "tabIndex", "name", "id", "labelPosition", "aria-label", "aria-labelledby", "required", "checked"], outputs: ["change", "toggleChange"], exportAs: ["matSlideToggle"] }, { type: i8.MatAutocomplete, selector: "mat-autocomplete", inputs: ["disableRipple"], exportAs: ["matAutocomplete"] }, { type: i9.CdkVirtualScrollViewport, selector: "cdk-virtual-scroll-viewport", inputs: ["orientation"], outputs: ["scrolledIndexChange"] }, { type: i10.MatOption, selector: "mat-option", exportAs: ["matOption"] }, { type: i11.QMSListItem, selector: "qms-list-item", inputs: ["type"] }, { type: i12.TreeComponent, selector: "qms-tree", inputs: ["treeData", "treeConfig", "selectedData", "selectedRiskData", "disabledList", "expandOnTitleClick", "expandToChildNode"], outputs: ["selectNodeEvent", "selectFolderEvent", "checkBoxEvent", "childCheckedEvent", "nodeExpandEvent", "getChildNodeSelectOne"] }, { type: i13.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { type: i14.QMSButton, selector: "button[qms-btn], button[qms-btn-lg], button[qms-btn-outlined],\n button[qms-btn-outlined-lg], button[qms-btn-text], button[qms-btn-text-lg],\n button[qms-btn-fab],button[qms-btn-fab-sm],button[qms-btn-fab-ext],\n button[qms-btn-fab-outlined],button[qms-btn-fab-outlined-sm],button[qms-btn-fab-outlined-ext]", inputs: ["disabled", "color"], exportAs: ["qmsButton"] }], directives: [{ type: i2.MatDialogContent, selector: "[mat-dialog-content], mat-dialog-content, [matDialogContent]" }, { type: i15.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["id", "disabled", "required", "type", "value", "readonly", "placeholder", "errorStateMatcher", "aria-describedby"], exportAs: ["matInput"] }, { type: i16.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i8.MatAutocompleteTrigger, selector: "input[matAutocomplete], textarea[matAutocomplete]", exportAs: ["matAutocompleteTrigger"] }, { type: i16.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i16.FormControlDirective, selector: "[formControl]", inputs: ["disabled", "formControl", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { type: i17.QMSGroupOptionDirective, selector: "[qms-group-options]" }, { type: i17.AutocompleteOffDirective, selector: "[qms-group-options]" }, { type: i9.CdkFixedSizeVirtualScroll, selector: "cdk-virtual-scroll-viewport[itemSize]", inputs: ["itemSize", "minBufferPx", "maxBufferPx"] }, { type: i18.QMSScrollbarDirective, selector: "[qms-scrollbar]", inputs: ["isNoneBackground"] }, { type: i19.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i19.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i11.QMSListLeadingIcon, selector: "[leading-icon]" }, { type: i11.QMSListHeader, selector: "[qms-list-header]" }, { type: i11.QMSListLine, selector: "[qms-line]", inputs: ["size", "type", "color"] }, { type: i19.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i20.QMSToolTipRendererDirective, selector: "[qms-tool-tip]", inputs: ["showToolTip", "mode", "qms-tool-tip", "contentTemplate", "position"] }, { type: i19.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }], pipes: { "uppercase": i19.UpperCasePipe }, encapsulation: i0.ViewEncapsulation.None });
541
629
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.5", ngImport: i0, type: SelectIncludeChildrenPopUpComponent, decorators: [{
542
630
  type: Component,
543
631
  args: [{
@@ -546,7 +634,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.5", ngImpor
546
634
  styleUrls: ['./select-include-children.component.scss'],
547
635
  encapsulation: ViewEncapsulation.None
548
636
  }]
549
- }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: i1.TranslateLibraryService }, { type: i2.MatDialogRef }, { type: i3.QMSSelectGlobalService }, { type: i4.MatIconRegistry }, { type: i5.DomSanitizer }, { type: i6.QMSIconRegistryService }, { type: i0.ElementRef }, { type: i20.SelectPopupData, decorators: [{
637
+ }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: i1.TranslateLibraryService }, { type: i2.MatDialogRef }, { type: i3.QMSSelectGlobalService }, { type: i4.MatIconRegistry }, { type: i5.DomSanitizer }, { type: i6.QMSIconRegistryService }, { type: i0.ElementRef }, { type: i21.SelectPopupData, decorators: [{
550
638
  type: Inject,
551
639
  args: [MAT_DIALOG_DATA]
552
640
  }] }]; }, propDecorators: { dataTrees: [{
@@ -559,4 +647,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.0.5", ngImpor
559
647
  type: HostListener,
560
648
  args: ['window:message', ['$event']]
561
649
  }] } });
562
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select-include-children.component.js","sourceRoot":"","sources":["../../../../../../projects/qms-angular/src/lib/components/select-include-children/select-include-children.component.ts","../../../../../../projects/qms-angular/src/lib/components/select-include-children/select-include-children.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, EventEmitter, OnDestroy, ViewChild, ViewEncapsulation, AfterViewChecked, QueryList, ViewChildren, ElementRef } from '@angular/core';\r\nimport { Component, HostListener, Inject, OnInit } from '@angular/core';\r\nimport { FormControl } from '@angular/forms';\r\nimport { MatAutocompleteTrigger } from '@angular/material/autocomplete';\r\nimport { MatDialogRef, MAT_DIALOG_DATA } from '@angular/material/dialog';\r\nimport { MatIconRegistry } from '@angular/material/icon';\r\nimport { DomSanitizer } from '@angular/platform-browser';\r\nimport { Subject } from 'rxjs';\r\nimport { debounceTime, takeUntil } from 'rxjs/operators';\r\nimport { TreeNode } from '../../qms-ckeditor-components/common/models/qms-ckeditor-tree-node.model';\r\nimport { TranslateLibraryService } from '../../services/translation-registry.service';\r\nimport { QMSIconRegistryService } from '../app-icon/icon-registry.service';\r\nimport { SelectPopupData } from './model/select-popup-data.model';\r\nimport { SelectOption } from './model/select-option.model';\r\nimport { TreeModel } from '../tree/model/tree.model';\r\nimport { QMSSelectGlobalService } from './services/select-global.service';\r\nimport { TreeComponent } from '../tree/tree.component';\r\nimport { TreeFlatNode } from '../tree/model/tree-flat-node.model';\r\nimport { TreeConfig } from '../tree/model/tree-config.model';\r\nimport { SelectConst } from './model/select.const';\r\n\r\n\r\n\r\n@Component({\r\n  selector: 'qms-select-include-children-popup',\r\n  templateUrl: './select-include-children.component.html',\r\n  styleUrls: ['./select-include-children.component.scss'],\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class SelectIncludeChildrenPopUpComponent implements OnInit, OnDestroy, AfterViewChecked {\r\n    ngUnsubscribe = new Subject<void>();\r\n\r\n    LANG: any;\r\n    headerName = '';\r\n    treeData: Array<TreeModel> = [];\r\n    treeConfig: TreeConfig;\r\n\r\n    checkedNodeList: Array<SelectOption> = [];\r\n    SelectOption: Array<SelectOption> = [];\r\n    selectedData: Array<TreeFlatNode> = [];\r\n\r\n    commonCheckedList: Array<TreeFlatNode> = [];\r\n    documentCheckedList: Array<TreeFlatNode> = [];\r\n    singleProcessList: Array<SelectOption> = [];\r\n\r\n    itemType = 0;\r\n    selectedRiskData: any = [];\r\n    disabledList: any = [];\r\n    disabledList2: any = [];\r\n    maxSelectItemCount: number;\r\n    canOnlySelectItem: boolean;\r\n\r\n    isDocumentExpanded = true;\r\n    isCommonExpanded = true;\r\n    singleSelectOption = false;\r\n    searchOrder = [];\r\n\r\n    myControl = new FormControl();\r\n    filteredOptions: SelectOption[] = [];\r\n    isInputValue = false;\r\n    selectedFolder: TreeFlatNode = null;\r\n    listChildrenSelectOne: any = [];\r\n    includeChildren = false;\r\n    onSearch = new EventEmitter();\r\n    onExpandFolder = new EventEmitter<SelectOption>();\r\n\r\n    @ViewChildren(TreeComponent, {}) dataTrees: QueryList<TreeComponent>;\r\n\r\n    @ViewChild('autoCompleteInputSearch', { read: MatAutocompleteTrigger, static: true })\r\n    autoComplete: MatAutocompleteTrigger;\r\n    constructor(\r\n        private cdRef: ChangeDetectorRef,\r\n        public translate: TranslateLibraryService,\r\n        public dialogRef: MatDialogRef<SelectIncludeChildrenPopUpComponent>,\r\n        public globalService: QMSSelectGlobalService,\r\n        private iconRegistry: MatIconRegistry,\r\n        private sanitizer: DomSanitizer,\r\n        private appIconService: QMSIconRegistryService,\r\n        private elem: ElementRef,\r\n        @Inject(MAT_DIALOG_DATA) public data: SelectPopupData\r\n    ) {\r\n        this.headerName = data.headerName;\r\n        this.treeData = data.treeData;\r\n        this.treeConfig = data.treeConfig;\r\n        this.selectedRiskData = data?.selectedNode || [];\r\n        this.disabledList = data.disabledList || [];\r\n        this.singleSelectOption = data.treeConfig.singleSelectedNode;\r\n        this.maxSelectItemCount = data.maxSelectItemCount;\r\n        appIconService.registerProcessIcon(iconRegistry, sanitizer);\r\n        appIconService.registerProcessAreaIcon(iconRegistry, sanitizer);\r\n        appIconService.registerDocumentIcon(iconRegistry, sanitizer);\r\n        appIconService.registerFolderIcon(iconRegistry, sanitizer);\r\n        appIconService.registerDeviationIcon(iconRegistry, sanitizer);\r\n        appIconService.registerChecklistIcon(iconRegistry, sanitizer);\r\n        appIconService.registerRiskIcon(iconRegistry, sanitizer);\r\n    }\r\n\r\n    ngOnDestroy(): void {\r\n        this.ngUnsubscribe.next();\r\n        this.ngUnsubscribe.complete();\r\n        this.globalService.setSearchResult([]);\r\n        this.selectedFolder = null;\r\n    }\r\n\r\n    @HostListener('window:message', ['$event'])\r\n    onMessage(event) {\r\n        if (event.data === SelectConst.HIDE_SEARCH_RESULT) {\r\n        this.autoComplete.closePanel();\r\n        }\r\n    }\r\n\r\n    ngOnInit(): void {\r\n        this.translate.getLanguageSubject$.pipe().subscribe((res) => {\r\n        if (res) {\r\n            this.LANG = this.translate.getObjectLang(res);\r\n        }\r\n        });\r\n\r\n        this.globalService.searchRelated.pipe(takeUntil(this.ngUnsubscribe)).subscribe((res) => {\r\n        if (res && res.length) {\r\n            this.filteredOptions = res;\r\n        }\r\n        });\r\n\r\n        this.myControl.valueChanges.pipe(debounceTime(1000)).subscribe((val) => {\r\n        this.isInputValue = true;\r\n        this.onSearchRelated(val);\r\n        });\r\n\r\n        // this.searchOrder = this.getSearchOrder();\r\n    }\r\n\r\n    ngAfterViewChecked() {\r\n        this.cdRef.detectChanges();\r\n        if (this.filteredOptions && this.filteredOptions.length) {\r\n        this.autoComplete.openPanel();\r\n        this.setResultHeight();\r\n        } else if (this.autoComplete) {\r\n        this.autoComplete.closePanel();\r\n        }\r\n    }\r\n\r\n\r\n    removeCheckedNodeList(item: TreeFlatNode) {\r\n        this.selectedData = [];\r\n\r\n        this.checkedNodeList = this.checkedNodeList.filter(x => (x.id.toLowerCase() !== item.id.toLowerCase() || x.parentId.toLowerCase() !== item.parentId.toLowerCase()));\r\n        const tempArr = [];\r\n        const tempArrDocument = [];\r\n        const newSelectProcessList = [];\r\n        const newSelectDocumentList = [];\r\n\r\n\r\n        this.commonCheckedList.forEach(element => {\r\n        this.checkedNodeList.forEach(x => {\r\n            if (element.id.toLowerCase() === x.id.toLowerCase() && element.parentId.toLowerCase() === x.parentId.toLowerCase()) {\r\n            tempArr.push(element);\r\n            }\r\n        });\r\n        });\r\n\r\n        this.singleProcessList.forEach(element => {\r\n        this.checkedNodeList.forEach(x => {\r\n            if (element.id.toLowerCase() === x.id.toLowerCase() && element.parentId.toLowerCase() === x.parentId.toLowerCase()) {\r\n            newSelectProcessList.push(element);\r\n            }\r\n        });\r\n        });\r\n\r\n        this.singleProcessList = newSelectProcessList;\r\n        this.selectedData = [...tempArr];\r\n\r\n        this.documentCheckedList.forEach(element => {\r\n        this.checkedNodeList.forEach(x => {\r\n            if (element.id.toLowerCase() === x.id.toLowerCase() && element.parentId.toLowerCase() === x.parentId.toLowerCase()) {\r\n            tempArrDocument.push(element);\r\n            }\r\n        });\r\n        });\r\n    }\r\n\r\n    isMatchTrue(arr: any[], arr2: any[]) {\r\n        return arr.every((i) => {\r\n        return arr2.includes(i);\r\n        });\r\n    }\r\n\r\n    setResultHeight(arr?: SelectOption[]) {\r\n        let maxHeight = 484;\r\n        const popup_content = document.getElementsByClassName('qmslib_related_popup_content')[0] as HTMLElement;\r\n        const line__divider = document.getElementsByClassName('line__divider')[0] as HTMLElement;\r\n        if (popup_content && line__divider) {\r\n        maxHeight = this.getOffsetHeight(popup_content, true) + this.getOffsetHeight(line__divider, true) * 2;\r\n        }\r\n\r\n        const contentResult = document.getElementsByClassName('cdk-virtual-scroll-content-wrapper')[0] as HTMLElement;\r\n        const viewreports = document.getElementsByClassName('related-viewport')[0] as HTMLElement;\r\n\r\n        if (viewreports) {\r\n        if (contentResult.offsetHeight <= maxHeight) {\r\n            viewreports.style.height = `${contentResult.offsetHeight}px`;\r\n        }\r\n        else {\r\n            viewreports.style.height = `${maxHeight}px`;\r\n        }\r\n        }\r\n    }\r\n\r\n    onSearchRelated(_val: any) {\r\n        this.filteredOptions = [];\r\n        if (typeof (_val) === 'object') {\r\n            this.myControl.setValue('');\r\n        }\r\n        else if (typeof (_val) === 'string') {\r\n            if (!!_val) {\r\n                this.onSearch.emit(_val);\r\n            }\r\n        }\r\n    }\r\n\r\n    getModuleFilteredOptions() {\r\n        if (this.listChildrenSelectOne.length) {\r\n        for (let index = 0; index < this.listChildrenSelectOne.length; index++) {\r\n            const firstEl = this.listChildrenSelectOne[index];\r\n            for (let j = 0; j < this.filteredOptions.length; j++) {\r\n            const secondEl = this.filteredOptions[j];\r\n            if (firstEl.id === secondEl.id) {\r\n                this.filteredOptions.splice(j, 1);\r\n            }\r\n            }\r\n        }\r\n\r\n        }\r\n        return this.filteredOptions;\r\n    }\r\n\r\n    showSearchResult() {\r\n        this.autoComplete.openPanel();\r\n    }\r\n\r\n    displayRelated(related?: SelectOption): string | undefined {\r\n        return related ? related.itemName : undefined;\r\n    }\r\n\r\n    selectSearch(item: SelectOption) {\r\n        if (this.treeConfig.selectOne) {\r\n        this.disabledList = [];\r\n        }\r\n\r\n        let index = -1;\r\n        this.SelectOption = [];\r\n        if (this.treeConfig.showCheckBox) {\r\n        index = this.checkedNodeList.findIndex(x => {\r\n            return x.id === item.id && x.parentId === item.parentId;\r\n        });\r\n        }\r\n\r\n        if (index < 0) {\r\n        let position = -1;\r\n        let node: any;\r\n        let typeId: number;\r\n        }\r\n    }\r\n\r\n    selectNodeRecursive(item: TreeModel) {\r\n        let position = this.treeData.findIndex(x => {\r\n        return x.rootId === item.rootId;\r\n        });\r\n\r\n        if (position >= 0) {\r\n\r\n        const node: TreeNode = {\r\n            id: item.rootId,\r\n            name: item.rootName,\r\n            children: [],\r\n            parentId: item.parentId\r\n        };\r\n\r\n        let nodeChildren: TreeNode[] = this.treeData.\r\n            filter(x => x.rootId === item.rootId).\r\n            map(x => {\r\n            return {\r\n                id: x.childId,\r\n                name: item.childName,\r\n                children: [],\r\n                parentId: item.rootId\r\n            };\r\n            });\r\n        let nodeSubfolders: TreeModel[] = this.treeData.\r\n            filter(x => x.parentId === item.rootId);\r\n\r\n        if (this.treeConfig.showCheckBox) {\r\n            nodeChildren.forEach(x => {\r\n            this.checkedNodeList.push({\r\n                id: x.id,\r\n                itemName: x.name,\r\n                itemNumberId: item.displayId.toString(),\r\n                parentId: item.rootId,\r\n                parentName: item.rootName\r\n            });\r\n            });\r\n        }\r\n        else {\r\n            nodeChildren.forEach(x => {\r\n            this.SelectOption.push({\r\n                id: x.id,\r\n                itemName: x.name,\r\n                itemNumberId: item.displayId.toString(),\r\n                parentId: item.rootId,\r\n                parentName: item.rootName\r\n            });\r\n            });\r\n        }\r\n\r\n        this.dataTrees.toArray()[0].todoItemSelection([node].concat(nodeChildren));\r\n        if (nodeSubfolders) {\r\n            nodeSubfolders.forEach(folder => {\r\n            this.selectNodeRecursive(folder);\r\n            });\r\n        }\r\n        }\r\n        return;\r\n    }\r\n\r\n    // setTypeProcess(expand) {\r\n    //     return expand ? this.dataType.area : this.dataType.process;\r\n    // }\r\n\r\n    getCommonCheckedNode(list: Array<TreeFlatNode>) {\r\n        this.checkedNodeList = [];\r\n        this.commonCheckedList = [];\r\n        this.singleProcessList = [];\r\n\r\n        if (list.length) {\r\n            list.forEach(item => {\r\n                const index = this.checkedNodeList.findIndex(x => x.id === item.id && x.parentId === item.parentId);\r\n\r\n                if (item.id && index < 0) {\r\n                    this.commonCheckedList.push(item);\r\n                }\r\n\r\n                if (this.singleSelectOption) {\r\n                    let position: number;\r\n                    if (item.expandable) {\r\n                        position = this.treeData.findIndex(p => p.rootId === item.id);\r\n                    }\r\n                    else {\r\n                        position = this.treeData.findIndex(p => p.childId === item.id);\r\n                    }\r\n                    if (position > -1) {\r\n                        this.singleProcessList.push({\r\n                        id: item.id,\r\n                        itemName: item.name,\r\n                        itemNumberId: this.treeData[position].displayId.toString(),\r\n                        parentId: item.parentId,\r\n                        levelType: item.levelType\r\n                        });\r\n                    }\r\n                }\r\n\r\n                if (item.id && index < 0 && !item.expandable && !this.singleSelectOption) {\r\n                    const position = this.treeData.findIndex(p => p.childId === item.id && p.rootId === item.parentId);\r\n                    if (position > -1) {\r\n                        this.checkedNodeList.push({\r\n                        id: item.id,\r\n                        itemName: item.name,\r\n                        parentId: item.parentId,\r\n                        parentName: this.treeData[position].parentId ? this.treeData[position].subName : this.treeData[position].rootName,\r\n                        itemNumberId: this.treeData[position].displayId.toString(),\r\n                        levelType: item.levelType\r\n                        });\r\n                    }\r\n                }\r\n            });\r\n\r\n            if (this.singleSelectOption) {\r\n                this.checkedNodeList = [...this.checkedNodeList, ...this.singleProcessList];\r\n            }\r\n\r\n            if (this.maxSelectItemCount && this.maxSelectItemCount > 0) {\r\n                const removeList = this.checkedNodeList.slice(0, this.maxSelectItemCount * -1);\r\n                if (removeList.length) {\r\n                    removeList.forEach(item => {\r\n                        this.removeCheckedNodeList({\r\n                        id: item.id,\r\n                        name: item.itemName,\r\n                        parentId: item.parentId,\r\n                        level: 0,\r\n                        expandable: true,\r\n                        hasChild: true,\r\n                        disabled: false\r\n                        });\r\n                    });\r\n                }\r\n                this.checkedNodeList = this.checkedNodeList.slice(this.maxSelectItemCount * -1);\r\n            }\r\n        }\r\n    }\r\n\r\n    onCloseClick(): void {\r\n        this.selectedFolder = null;\r\n        this.dialogRef.close();\r\n    };\r\n\r\n    onAddClick() {\r\n        // if (this.treeConfig.showCheckBox) {\r\n        this.selectedFolder = null;\r\n        this.dialogRef.close(this.checkedNodeList);\r\n        // }\r\n        // else {\r\n        //   this.dialogRef.close(this.SelectOption);\r\n        // }\r\n    }\r\n\r\n    getOffsetHeight(element: HTMLElement, includeMargin: boolean): number {\r\n        let elmHeight = 0, elmMargin = 0;\r\n\r\n        elmHeight = element.offsetHeight;\r\n        if (includeMargin) {\r\n        const style = window.getComputedStyle(element);\r\n        elmMargin = parseFloat(style.marginTop.replace('px', '')) + parseFloat(style.marginBottom.replace('px', ''));\r\n        }\r\n\r\n        return (elmHeight + elmMargin);\r\n    }\r\n\r\n    getItemChipName(item: SelectOption) {\r\n        return (item.parentName) ? `${item.parentName}/${item.itemName}` : item.itemName;\r\n    }\r\n\r\n    isEllipsisActive(e: HTMLElement): boolean {\r\n        return e ? (e.clientWidth < e.scrollWidth) : false;\r\n    }\r\n\r\n    // getNodeIcon(item: SelectOption) {\r\n    //     switch (item.itemType) {\r\n    //     case DataType.folder: {\r\n    //         switch (item.levelType) {\r\n    //         case DocumentNodeType.DepartmentFolder:\r\n    //             return 'department_folder_outlined';\r\n    //         case DocumentNodeType.RegionalFolder:\r\n    //             return 'regional_folder_outlined';\r\n    //         case DocumentNodeType.TopFolder:\r\n    //             return 'enterprise_folder_outlined';\r\n    //         case DocumentNodeType.Folder:\r\n    //             return 'local_folder_outlined';\r\n    //         default:\r\n    //             return 'folder_outlined';\r\n    //         }\r\n    //     }\r\n    //     case DataType.document: {\r\n    //         switch (item.levelType) {\r\n    //         case DocumentNodeType.DepartmentFolder:\r\n    //             return 'document_department';\r\n    //         case DocumentNodeType.RegionalFolder:\r\n    //             return 'document_regional';\r\n    //         case DocumentNodeType.TopFolder:\r\n    //             return 'document_enterprise';\r\n    //         case DocumentNodeType.Folder:\r\n    //             return 'document_local';\r\n    //         default:\r\n    //             return 'document';\r\n    //         }\r\n    //     }\r\n    //     case DataType.area:\r\n    //         return 'process_area_outlined';\r\n    //     case DataType.process:\r\n    //         return 'process';\r\n    //     case DataType.deviation:\r\n    //         return 'deviation';\r\n    //     case DataType.checklist:\r\n    //         return 'checklist';\r\n    //     case DataType.risk:\r\n    //         return 'risk';\r\n    //     default:\r\n    //         return 'folder_outlined';\r\n    //     }\r\n    // }\r\n\r\n    // getSearchOrder() {\r\n    //     let searchTypes = Object.keys(this.dataType)\r\n    //     .map(key => ({ value: this.dataType[key], key: key }));\r\n    //     searchTypes = searchTypes.slice(searchTypes.length / 2);\r\n    //     return searchTypes;\r\n    // }\r\n\r\n//   getTitle(type: number) {\r\n//     switch (type) {\r\n//       case DataType.process:\r\n//         return this.LANG.PROCESSES;\r\n//       case DataType.area:\r\n//         return this.LANG.PROCESS_AREA;\r\n//       case DataType.document:\r\n//         return this.LANG.DOCUMENTS;\r\n//       case DataType.folder:\r\n//         return this.LANG.FOLDER;\r\n//       case DataType.deviation:\r\n//         return this.LANG.DEVIATION;\r\n//       case DataType.deviationType:\r\n//         return this.LANG.DEVIATION_TYPE;\r\n//       case DataType.checklist:\r\n//         return this.LANG.CHECKLIST;\r\n//       case DataType.checklistCategory:\r\n//         return this.LANG.CHECKLIST_CATEGORY;\r\n//       case DataType.risk:\r\n//         return this.LANG.ASSESSMENT;\r\n//       case DataType.riskFolder:\r\n//         return this.LANG.FOLDER;\r\n//     }\r\n//   }\r\n\r\n//   getParentName(item: SelectOption) {\r\n//     if (item.itemType === this.dataType.checklist || item.itemType === this.dataType.deviation) {\r\n//       return item.parentName;\r\n//     }\r\n//     return null;\r\n//   }\r\n\r\n//   getItemId(item: SelectOption) {\r\n//     if (item.itemType === this.dataType.process) {\r\n//       return `${this.LANG.PROCESS_ID}: ${item.itemNumberId}; ${item.statusName}`;\r\n//     }\r\n//     else if (item.itemType === this.dataType.document) {\r\n//       return `${this.LANG.DOCUMENT_ID}: ${item.itemNumberId}; ${item.statusName}`;\r\n//     }\r\n//     return null;\r\n//   }\r\n\r\n    toggleSelectItem(node: SelectOption) {\r\n        const SelectOption = this.checkedNodeList.find(x => (x.id.toLowerCase() === node.id.toLowerCase() && x.parentId.toLowerCase() === node.parentId.toLowerCase()));\r\n        if (SelectOption) {\r\n        this.removeCheckedNodeList({\r\n            id: SelectOption.id,\r\n            name: node.itemName,\r\n            parentId: SelectOption.parentId,\r\n            hasChild: false,\r\n            expandable: false,\r\n            level: 0,\r\n            disabled: false,\r\n        });\r\n        }\r\n        else {\r\n            // this.selectRelated(node);\r\n        }\r\n    }\r\n\r\n    isNodeSelected(node) {\r\n        return this.checkedNodeList.filter(x => (x.id.toLowerCase() === node.id.toLowerCase() && x.parentId.toLowerCase() === node.parentId.toLowerCase())).length > 0;\r\n    }\r\n\r\n\r\n    getChildrenOfFolder(node: TreeFlatNode) {\r\n        // if (this.splitView) {\r\n        // const parentTexts = this.elem.nativeElement.querySelectorAll('.text-node-parent');\r\n        // [].forEach.call(parentTexts, (el) => {\r\n        //     el.classList.remove('active-item');\r\n        // });\r\n        // const itemElement = document.querySelectorAll(`#_${node.parentId ? node.parentId : ''}_${node.id}_${node.level}`);\r\n        // [].forEach.call(itemElement, (el) => {\r\n        //     el.classList.add('active-item');\r\n        // });\r\n        let item = new SelectOption();\r\n        item.id = node.id;\r\n        item.itemName = node.name;\r\n        item.levelType = node.levelType;\r\n        this.selectedFolder = node;\r\n        this.onExpandFolder.emit(item);\r\n        // }\r\n    }\r\n\r\n//   canShowSearchOption(moduleId: number) {\r\n//     if (this.canOnlySelectItem &&\r\n//       (moduleId === DataType.checklistCategory\r\n//         || moduleId === DataType.riskFolder\r\n//         || moduleId === DataType.deviationType\r\n//         || (moduleId === DataType.area && this.treeConfig && !this.treeConfig.singleSelectOption)\r\n//         || (moduleId === DataType.folder && this.treeConfig2 && !this.treeConfig2.singleSelectOption)\r\n//       )) {\r\n//       return false;\r\n//     }\r\n//     return this.getModuleFilteredOptions(moduleId).length > 0;\r\n//   }\r\n\r\n    selectNodeTreeEvent(node) {\r\n        let position = -1;\r\n        let parentName = '';\r\n        let itemNumberId = '';\r\n\r\n        position = !node.expandable ? this.treeData.findIndex(p => p.childId === node.id && p.rootId === node.parentId) :\r\n        this.treeData.findIndex(p => p.rootId === node.id);\r\n        parentName = this.treeData[position].parentId ? this.treeData[position].subName : this.treeData[position].rootName;\r\n        itemNumberId = this.treeData[position]?.displayId?.toString();\r\n\r\n        this.checkedNodeList = [];\r\n        this.checkedNodeList.push({\r\n        id: node.id,\r\n        itemName: node.name,\r\n        parentId: node.parentId,\r\n        parentName: parentName,\r\n        itemNumberId: itemNumberId,\r\n        levelType: node.levelType\r\n        });\r\n    }\r\n\r\n    getChildNodeSelectOne(listChildren) {\r\n        this.listChildrenSelectOne = [];\r\n        this.listChildrenSelectOne = listChildren;\r\n    }\r\n\r\n    setValue(e){\r\n        this.includeChildren = !!e.checked;\r\n    }\r\n}\r\n","<div id=\"qmslib_related_popup\" class=\"qmslib__related__popup__container\">\r\n    <div id=\"qmslib_related_popup_header\">\r\n      <span mat-icon-button class=\"button__close\" (click)=\"onCloseClick()\">\r\n        <mat-icon mat-icon>close</mat-icon>\r\n      </span>\r\n      <div id=\"qmslib_related_popup_header_001\" mat-dialog-content>\r\n        <span>{{ headerName | uppercase }}</span>\r\n      </div>\r\n    </div>\r\n  \r\n    <div\r\n      id=\"qmslib_related_popup_search\"\r\n      class=\"input__field\"\r\n      (click)=\"showSearchResult()\"\r\n    >\r\n      <input\r\n        #name\r\n        type=\"text\"\r\n        placeholder=\"{{ LANG.SEARCH }}\"\r\n        matInput\r\n        [formControl]=\"myControl\"\r\n        [matAutocomplete]=\"auto\"\r\n        #autoCompleteInputSearch\r\n      />\r\n      <mat-icon>search</mat-icon>\r\n    </div>\r\n  \r\n    <div class=\"line__divider\"></div>\r\n  \r\n    <mat-autocomplete\r\n      #auto=\"matAutocomplete\"\r\n      [displayWith]=\"displayRelated\"\r\n      class=\"mat-autocomplete_related-viewport\"\r\n    >\r\n      <cdk-virtual-scroll-viewport\r\n        qms-scrollbar\r\n        itemSize=\"10\"\r\n        class=\"related-viewport\"\r\n      >\r\n        <ng-container *ngFor=\"let type of searchOrder\">\r\n          <div\r\n            class=\"search__module-result\"\r\n            *ngIf=\"filteredOptions\"\r\n          >\r\n            <span class=\"search__module-title\">Hello</span>\r\n            <mat-option\r\n              class=\"search__option\"\r\n              *ngFor=\"let option of getModuleFilteredOptions()\"\r\n              [value]=\"option\"\r\n            >\r\n              <!-- <qms-list-item type=\"image-square\">\r\n                <mat-icon\r\n                  leading-icon\r\n                  type=\"image-square\"\r\n                  [svgIcon]=\"getNodeIcon(option)\"\r\n                ></mat-icon>\r\n                <div qms-list-header>\r\n                  <div\r\n                    qms-line\r\n                    type=\"caption\"\r\n                    qms-tool-tip=\"{{\r\n                      isEllipsisActive(searchItemResult) ? option.parentName : ''\r\n                    }}\"\r\n                    mode=\"dark\"\r\n                    *ngIf=\"getParentName(option)\"\r\n                  >\r\n                    <span #searchItemResult class=\"search__result__parent-name\">\r\n                      {{ option.parentName }}\r\n                    </span>\r\n                  </div>\r\n                  <div qms-line type=\"subtitle\" class=\"search__option-name\">\r\n                    {{ option.itemName }}\r\n                  </div>\r\n                  <div\r\n                    class=\"caption\"\r\n                    *ngIf=\"option.breadcumbs && option.breadcumbs.length\"\r\n                  >\r\n                    <qms-breadcrumb\r\n                      class=\"breadcrumb-containe\"\r\n                      type=\"table\"\r\n                      numDisplayItem=\"1\"\r\n                      [nodes]=\"option.breadcumbs\"\r\n                    >\r\n                    </qms-breadcrumb>\r\n                  </div>\r\n                </div>\r\n                <div qms-line color=\"default-subtitle\" *ngIf=\"getItemId(option)\">\r\n                  <span class=\"material-icons-outlined search__description-icon\">\r\n                    local_offer\r\n                  </span>\r\n                  {{ getItemId(option) }}\r\n                </div>\r\n              </qms-list-item> -->\r\n            </mat-option>\r\n          </div>\r\n        </ng-container>\r\n      </cdk-virtual-scroll-viewport>\r\n    </mat-autocomplete>\r\n  \r\n    <div class=\"row\">\r\n        <div\r\n            class=\"qms-scrollbar qmslib_related_popup_content col-12\"\r\n            [ngClass]=\"{\r\n            panel__content_item: checkedNodeList.length,\r\n            panel__content: !checkedNodeList.length\r\n            }\">\r\n            <div id=\"qmslib_related_popup_common_002\">\r\n                <qms-tree\r\n                    [treeData]=\"treeData\"\r\n                    [treeConfig]=\"treeConfig\"\r\n                    [selectedData]=\"selectedData\"\r\n                    [selectedRiskData]=\"selectedRiskData\"\r\n                    [disabledList]=\"disabledList\"\r\n                    (checkBoxEvent)=\"getCommonCheckedNode($event)\"\r\n                    (nodeExpandEvent)=\"getChildrenOfFolder($event)\"\r\n                    (selectNodeEvent)=\"selectNodeTreeEvent($event)\"\r\n                    (getChildNodeSelectOne)=\"getChildNodeSelectOne($event)\"\r\n                ></qms-tree>\r\n            </div>\r\n    </div>\r\n  \r\n    <div *ngIf=\"checkedNodeList.length\" class=\"line__divider\"></div>\r\n  \r\n    <div *ngIf=\"checkedNodeList.length\" class=\"panel__item qms-scrollbar\">\r\n      <div class=\"related__item__inline\" *ngFor=\"let item of checkedNodeList\">\r\n        <button\r\n          *ngIf=\"item.itemName\"\r\n          mat-button\r\n          class=\"related__item__content\"\r\n          qms-tool-tip=\"{{\r\n            isEllipsisActive(itemName) ? getItemChipName(item) : ''\r\n          }}\"\r\n          mode=\"dark\"\r\n        >\r\n          <span class=\"related__item__content_name\" #itemName>\r\n              {{getItemChipName(item)}}</span>\r\n          <mat-icon\r\n            *ngIf=\"!treeConfig?.selectOne\"\r\n            (click)=\"removeCheckedNodeList(item)\"\r\n            >cancel</mat-icon\r\n          >\r\n        </button>\r\n      </div>\r\n      <div class=\"select__toggle-include\">\r\n        <mat-slide-toggle\r\n          [checked]=\"includeChildren\"\r\n          (change)=\"setValue($event)\"\r\n          color=\"default\"\r\n          qms-group-options>\r\n          <span class=\"text-label\">Select label</span>\r\n        </mat-slide-toggle>\r\n      </div>\r\n    </div>\r\n  \r\n    <div class=\"line__divider\"></div>\r\n  \r\n    <div class=\"confirm__button__groups\">\r\n      <button\r\n        *ngIf=\"!checkedNodeList.length\"\r\n        qms-btn\r\n        style=\"margin-top: 7px\"\r\n        (click)=\"onAddClick()\"\r\n      >\r\n        {{ LANG.ADD }}\r\n      </button>\r\n      <button\r\n        *ngIf=\"checkedNodeList.length\"\r\n        qms-btn\r\n        style=\"margin-top: 0px\"\r\n        (click)=\"onAddClick()\"\r\n      >\r\n        {{ LANG.ADD }} ({{ checkedNodeList.length }})\r\n      </button>\r\n      <button\r\n        qms-btn-text\r\n        [ngStyle]=\"{ 'margin-top': checkedNodeList.length ? '0px' : '7px' }\"\r\n        (click)=\"onCloseClick()\"\r\n      >\r\n        {{ LANG.CANCEL }}\r\n      </button>\r\n    </div>\r\n</div>\r\n  "]}
650
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select-include-children.component.js","sourceRoot":"","sources":["../../../../../../projects/qms-angular/src/lib/components/select-include-children/select-include-children.component.ts","../../../../../../projects/qms-angular/src/lib/components/select-include-children/select-include-children.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAqB,YAAY,EAAa,SAAS,EAAE,iBAAiB,EAA+B,YAAY,EAA6B,MAAM,eAAe,CAAC;AAC/K,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,MAAM,EAAU,MAAM,eAAe,CAAC;AACxE,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAC7C,OAAO,EAAE,sBAAsB,EAAE,MAAM,gCAAgC,CAAC;AACxE,OAAO,EAAgB,eAAe,EAAE,MAAM,0BAA0B,CAAC;AAGzE,OAAO,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AAC/B,OAAO,EAAE,YAAY,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAKzD,OAAO,EAAE,YAAY,EAAE,MAAM,6BAA6B,CAAC;AAG3D,OAAO,EAAE,aAAa,EAAE,MAAM,wBAAwB,CAAC;AAGvD,OAAO,EAAE,WAAW,EAAE,MAAM,sBAAsB,CAAC;AAGnD,OAAO,EAAE,iBAAiB,EAAE,MAAM,qCAAqC,CAAC;AACxE,OAAO,EAAE,YAAY,EAAE,MAAM,uCAAuC,CAAC;;;;;;;;;;;;;;;;;;;;;;;AAWrE,MAAM,OAAO,mCAAmC;IAwC5C,YACY,KAAwB,EACzB,SAAkC,EAClC,SAA4D,EAC5D,aAAqC,EACpC,YAA6B,EAC7B,YAA0B,EAC1B,cAAsC,EACtC,IAAgB,EACQ,IAAqB;QAR7C,UAAK,GAAL,KAAK,CAAmB;QACzB,cAAS,GAAT,SAAS,CAAyB;QAClC,cAAS,GAAT,SAAS,CAAmD;QAC5D,kBAAa,GAAb,aAAa,CAAwB;QACpC,iBAAY,GAAZ,YAAY,CAAiB;QAC7B,iBAAY,GAAZ,YAAY,CAAc;QAC1B,mBAAc,GAAd,cAAc,CAAwB;QACtC,SAAI,GAAJ,IAAI,CAAY;QACQ,SAAI,GAAJ,IAAI,CAAiB;QAhDzD,kBAAa,GAAG,IAAI,OAAO,EAAQ,CAAC;QAGpC,eAAU,GAAG,EAAE,CAAC;QAChB,aAAQ,GAAqB,EAAE,CAAC;QAGhC,oBAAe,GAA0B,EAAE,CAAC;QAC5C,oBAAe,GAAwB,EAAE,CAAC;QAC1C,iBAAY,GAAwB,EAAE,CAAC;QAEvC,sBAAiB,GAAwB,EAAE,CAAC;QAE5C,aAAQ,GAAG,CAAC,CAAC;QACb,qBAAgB,GAAQ,EAAE,CAAC;QAC3B,iBAAY,GAAqB,EAAE,CAAC;QACpC,uBAAkB,GAAQ,EAAE,CAAC;QAG7B,uBAAkB,GAAG,IAAI,CAAC;QAC1B,qBAAgB,GAAG,IAAI,CAAC;QACxB,uBAAkB,GAAG,KAAK,CAAC;QAC3B,gBAAW,GAAG,EAAE,CAAC;QAEjB,cAAS,GAAG,IAAI,WAAW,EAAE,CAAC;QAC9B,oBAAe,GAAyB,EAAE,CAAC;QAC3C,iBAAY,GAAG,KAAK,CAAC;QACrB,mBAAc,GAAiB,IAAI,CAAC;QACpC,0BAAqB,GAAQ,EAAE,CAAC;QAChC,oBAAe,GAAG,KAAK,CAAC;QAExB,iBAAY,GAAG,YAAY,CAAC;QAC5B,aAAQ,GAAG,IAAI,YAAY,EAAE,CAAC;QAC9B,mBAAc,GAAG,IAAI,YAAY,EAAgB,CAAC;QAiB9C,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,UAAU,CAAC;QAClC,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC;QAC9B,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,UAAU,CAAC;QAClC,IAAI,CAAC,gBAAgB,GAAG,CAAA,IAAI,aAAJ,IAAI,uBAAJ,IAAI,CAAE,YAAY,KAAI,EAAE,CAAC;QACjD,IAAI,CAAC,YAAY,GAAG,CAAC,CAAC,MAAM,CAAC,IAAI,EAAE,EAAE,EAAE,IAAI,CAAC,YAAY,IAAI,EAAE,CAAC,CAAC;QAChE,IAAI,CAAC,kBAAkB,GAAG,CAAC,CAAC,MAAM,CAAC,IAAI,EAAE,EAAE,EAAE,IAAI,CAAC,YAAY,IAAI,EAAE,CAAC,CAAC;QACtE,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC,UAAU,CAAC,kBAAkB,CAAC;QAC7D,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC,kBAAkB,CAAC;QAClD,IAAI,CAAC,eAAe,GAAG,CAAA,IAAI,aAAJ,IAAI,uBAAJ,IAAI,CAAE,YAAY,KAAI,EAAE,CAAC;QAChD,IAAI,CAAC,eAAe,GAAG,IAAI,aAAJ,IAAI,uBAAJ,IAAI,CAAE,eAAe,CAAC;QAC7C,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC;QAC9B,cAAc,CAAC,mBAAmB,CAAC,YAAY,EAAE,YAAY,CAAC,CAAC;QAC/D,cAAc,CAAC,uBAAuB,CAAC,YAAY,EAAE,YAAY,CAAC,CAAC;QACnE,cAAc,CAAC,oBAAoB,CAAC,YAAY,EAAE,YAAY,CAAC,CAAC;QAChE,cAAc,CAAC,kBAAkB,CAAC,YAAY,EAAE,YAAY,CAAC,CAAC;QAC9D,cAAc,CAAC,qBAAqB,CAAC,YAAY,EAAE,YAAY,CAAC,CAAC;QACjE,cAAc,CAAC,qBAAqB,CAAC,YAAY,EAAE,YAAY,CAAC,CAAC;QACjE,cAAc,CAAC,gBAAgB,CAAC,YAAY,EAAE,YAAY,CAAC,CAAC;IAChE,CAAC;IACD,eAAe;QACX,IAAI,IAAI,CAAC,QAAQ,EAAE;YACf,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;SACrC;QACD,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;IACxC,CAAC;IAED,WAAW;QACP,IAAI,CAAC,aAAa,CAAC,IAAI,EAAE,CAAC;QAC1B,IAAI,CAAC,aAAa,CAAC,QAAQ,EAAE,CAAC;QAC9B,IAAI,CAAC,aAAa,CAAC,eAAe,CAAC,EAAE,CAAC,CAAC;QACvC,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC;IAC/B,CAAC;IAGD,SAAS,CAAC,KAAK;QACX,IAAI,KAAK,CAAC,IAAI,KAAK,WAAW,CAAC,kBAAkB,EAAE;YAC/C,IAAI,CAAC,YAAY,CAAC,UAAU,EAAE,CAAC;SAClC;IACL,CAAC;IAED,QAAQ;QACJ,IAAI,CAAC,SAAS,CAAC,mBAAmB,CAAC,IAAI,EAAE,CAAC,SAAS,CAAC,CAAC,GAAG,EAAE,EAAE;YACxD,IAAI,GAAG,EAAE;gBACL,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC;aACjD;QACL,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,aAAa,CAAC,YAAY,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,GAAG,EAAE,EAAE;YAClF,IAAI,GAAG,IAAI,GAAG,CAAC,MAAM,EAAE;gBACnB,IAAI,CAAC,eAAe,GAAG,GAAG,CAAC;aAC9B;QACL,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,GAAG,EAAE,EAAE;YACnE,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;YACzB,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,CAAC;QAC9B,CAAC,CAAC,CAAC;QACH,4CAA4C;IAChD,CAAC;IAED,kBAAkB;QACd,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE,CAAC;QAC3B,IAAI,IAAI,CAAC,eAAe,IAAI,IAAI,CAAC,eAAe,CAAC,MAAM,EAAE;YACrD,IAAI,CAAC,YAAY,CAAC,SAAS,EAAE,CAAC;YAC9B,IAAI,CAAC,eAAe,EAAE,CAAC;SAC1B;aAAM,IAAI,IAAI,CAAC,YAAY,EAAE;YAC1B,IAAI,CAAC,YAAY,CAAC,UAAU,EAAE,CAAC;SAClC;IACL,CAAC;IAED,QAAQ,CAAC,eAAiC;QACtC,IAAI,eAAe,CAAC,MAAM,GAAG,CAAC,EAAE;YAC5B,eAAe,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE;gBAC9B,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;gBACnC,IAAI,OAAO,CAAC,IAAI,KAAK,iBAAiB,CAAC,eAAe,EAAE;oBACpD,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC;iBACxE;gBACD,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,yBAAyB,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;YAC7E,CAAC,CAAC,CAAA;SACL;IACL,CAAC;IAED,aAAa,CAAC,cAA8B;QACxC,MAAM,IAAI,GAAG,IAAI,CAAC,SAAS,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC,CAAC,sBAAsB,CAAC,cAAc,CAAC,EAAE,EAAE,cAAc,CAAC,QAAQ,CAAC,CAAC;QAC5G,IAAI,IAAI,EAAE;YACN,IAAI,CAAC,SAAS,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;YAC7C,MAAM,OAAO,GAAG,QAAQ,CAAC,cAAc,CAAC,IAAI,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,IAAI,IAAI,CAAC,EAAE,IAAI,IAAI,CAAC,KAAK,EAAE,CAAC,CAAC;YAC3G,IAAI,OAAO,EAAE;gBACT,OAAO,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;aACjC;SACJ;IACL,CAAC;IAED,qBAAqB,CAAC,IAAkB;QACpC,MAAM,KAAK,GAAG,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,WAAW,EAAE,KAAK,IAAI,CAAC,EAAE,CAAC,WAAW,EAAE,IAAI,CAAC,CAAC,QAAQ,CAAC,WAAW,EAAE,KAAK,IAAI,CAAC,QAAQ,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC;QAC9J,IAAI,KAAK,IAAI,CAAC,EAAE;YACZ,IAAI,QAAQ,GAAG,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,IAAI,CAAC,EAAE,IAAI,CAAC,CAAC,QAAQ,KAAK,IAAI,CAAC,QAAQ,CAAC,CAAC;YACrG,IAAI,QAAQ,IAAI,CAAC,EAAE;gBACf,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC;aAC5C;YAED,IAAI,IAAI,CAAC,eAAe,CAAC,KAAK,CAAC,CAAC,IAAI,KAAK,iBAAiB,CAAC,eAAe,EAAE;gBACxE,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,CAAC;aACpC;YAED,IAAI,IAAI,CAAC,eAAe,EAAE;gBACtB,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,CAAC;aACjC;iBACI;gBACD,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC;aACzC;YAED,IAAI,CAAC,kBAAkB,CAAC,EAAE,EAAE,EAAE,IAAI,CAAC,EAAE,EAAE,QAAQ,EAAE,IAAI,CAAC,QAAQ,EAAE,QAAQ,EAAE,IAAI,CAAC,IAAI,EAAE,IAAI,EAAE,iBAAiB,CAAC,eAAe,EAAE,CAAC,CAAC;YAChI,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,yBAAyB,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;SAC5E;IACL,CAAC;IAED,kBAAkB,CAAC,IAAkB;QACjC,IAAI,QAAQ,GAAG,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,IAAI,CAAC,EAAE,IAAI,CAAC,CAAC,QAAQ,KAAK,IAAI,CAAC,QAAQ,CAAC,CAAC;QACrG,IAAI,QAAQ,GAAG,CAAC,EAAE;YACd,IAAI,IAAI,CAAC,eAAe,EAAE;gBACtB,IAAI,CAAC,qBAAqB,CAAC;oBACvB,EAAE,EAAE,IAAI,CAAC,EAAE;oBACX,IAAI,EAAE,IAAI,CAAC,QAAQ;oBACnB,QAAQ,EAAE,IAAI,CAAC,QAAQ;oBACvB,KAAK,EAAE,CAAC;oBACR,UAAU,EAAE,IAAI;oBAChB,QAAQ,EAAE,KAAK;oBACf,QAAQ,EAAE,KAAK;iBAClB,CAAC,CAAC;gBACH,IAAI,CAAC,kBAAkB,CAAC;oBACpB,EAAE,EAAE,IAAI,CAAC,EAAE;oBACX,IAAI,EAAE,IAAI,CAAC,QAAQ;oBACnB,QAAQ,EAAE,IAAI,CAAC,QAAQ;oBACvB,KAAK,EAAE,CAAC;oBACR,UAAU,EAAE,IAAI;oBAChB,QAAQ,EAAE,KAAK;oBACf,QAAQ,EAAE,KAAK;iBAClB,CAAC,CAAC;aACN;iBACI;gBACD,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;gBAE/B,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC;oBACtB,EAAE,EAAE,IAAI,CAAC,EAAE;oBACX,QAAQ,EAAE,IAAI,CAAC,QAAQ;oBACvB,IAAI,EAAE,iBAAiB,CAAC,SAAS;oBACjC,QAAQ,EAAE,IAAI,CAAC,QAAQ;oBACvB,QAAQ,EAAE,EAAE;oBACZ,UAAU,EAAE,CAAC;oBACb,kBAAkB,EAAE,CAAC;iBACxB,CACA,CAAA;aACJ;SACJ;QACD,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,yBAAyB,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;IAC7E,CAAC;IAGD,eAAe,CAAC,IAAwB;QACpC,IAAI,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,QAAQ,CAAC,MAAM;YAAE,OAAO,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC;QACzE,IAAI,IAAI,CAAC,YAAY,IAAI,IAAI,CAAC,YAAY,CAAC,MAAM;YAAE,OAAO,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC;QACjF,IAAI,IAAI,CAAC,cAAc,IAAI,IAAI,CAAC,cAAc,CAAC,MAAM;YAAE,OAAO,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC;QACvF,IAAI,IAAI,CAAC,WAAW,IAAI,IAAI,CAAC,WAAW,CAAC,MAAM;YAAE,OAAO,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC;QAC9E,OAAO,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC;IAClC,CAAC;IAED,YAAY,CAAC,IAAwB;QACjC,OAAO,IAAI,CAAC,YAAY,CAAC,8BAA8B,CAAC,IAAI,CAAC,cAAc,CAAW,CAAC;IAC3F,CAAC;IAED,WAAW,CAAC,GAAU,EAAE,IAAW;QAC/B,OAAO,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,EAAE;YACnB,OAAO,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC;QAC5B,CAAC,CAAC,CAAC;IACP,CAAC;IAED,eAAe,CAAC,GAAoB;QAChC,IAAI,SAAS,GAAG,GAAG,CAAC;QACpB,MAAM,aAAa,GAAG,QAAQ,CAAC,sBAAsB,CAAC,8BAA8B,CAAC,CAAC,CAAC,CAAgB,CAAC;QACxG,MAAM,aAAa,GAAG,QAAQ,CAAC,sBAAsB,CAAC,eAAe,CAAC,CAAC,CAAC,CAAgB,CAAC;QACzF,IAAI,aAAa,IAAI,aAAa,EAAE;YAChC,SAAS,GAAG,IAAI,CAAC,eAAe,CAAC,aAAa,EAAE,IAAI,CAAC,GAAG,IAAI,CAAC,eAAe,CAAC,aAAa,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC;SACzG;QAED,MAAM,aAAa,GAAG,QAAQ,CAAC,sBAAsB,CAAC,oCAAoC,CAAC,CAAC,CAAC,CAAgB,CAAC;QAC9G,MAAM,WAAW,GAAG,QAAQ,CAAC,sBAAsB,CAAC,kBAAkB,CAAC,CAAC,CAAC,CAAgB,CAAC;QAE1F,IAAI,WAAW,EAAE;YACb,IAAI,aAAa,CAAC,YAAY,IAAI,SAAS,EAAE;gBACzC,WAAW,CAAC,KAAK,CAAC,MAAM,GAAG,GAAG,aAAa,CAAC,YAAY,IAAI,CAAC;aAChE;iBACI;gBACD,WAAW,CAAC,KAAK,CAAC,MAAM,GAAG,GAAG,SAAS,IAAI,CAAC;aAC/C;SACJ;IACL,CAAC;IAED,eAAe,CAAC,IAAS;QACrB,IAAI,CAAC,eAAe,GAAG,EAAE,CAAC;QAC1B,IAAI,OAAO,CAAC,IAAI,CAAC,KAAK,QAAQ,EAAE;YAC5B,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC;SAC/B;aACI,IAAI,OAAO,CAAC,IAAI,CAAC,KAAK,QAAQ,EAAE;YACjC,IAAI,CAAC,CAAC,IAAI,EAAE;gBACR,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;aAC5B;SACJ;IACL,CAAC;IAED,gBAAgB;QACZ,IAAI,CAAC,YAAY,CAAC,SAAS,EAAE,CAAC;IAClC,CAAC;IAED,cAAc,CAAC,OAAsB;QACjC,OAAO,OAAO,CAAC,CAAC,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAC;IAClD,CAAC;IAED,oBAAoB,CAAC,IAAyB;IAC9C,CAAC;IAED,qBAAqB,CAAC,IAAkB;QACpC,IAAI,YAAY,GAAmB,EAAE,CAAC;QACtC,YAAY,GAAG,IAAI,CAAC,2BAA2B,CAAC,YAAY,EAAE,IAAI,CAAC,CAAC;QACpE,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC;YACtB,EAAE,EAAE,IAAI,CAAC,EAAE;YACX,QAAQ,EAAE,IAAI,CAAC,IAAI;YACnB,YAAY,EAAE,IAAI,CAAC,EAAE;YACrB,QAAQ,EAAE,IAAI,CAAC,QAAQ;YACvB,IAAI,EAAE,iBAAiB,CAAC,eAAe;SAC1C,CAAC,CAAC;QACH,YAAY,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE;YACrB,MAAM,KAAK,GAAG,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,KAAK,CAAC,CAAC,EAAE,IAAI,IAAI,CAAC,QAAQ,KAAK,CAAC,CAAC,QAAQ,CAAC,CAAC;YACvG,IAAI,KAAK,GAAG,CAAC,EAAE;gBACX,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;aAChC;QACL,CAAC,CAAC,CAAC;IAEP,CAAC;IAED,qBAAqB,CAAC,IAAkB;QACpC,IAAI,YAAY,GAAG,EAAE,CAAC;QACtB,YAAY,GAAG,IAAI,CAAC,2BAA2B,CAAC,YAAY,EAAE,IAAI,CAAC,CAAC;QACpE,MAAM,SAAS,GAAG,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,KAAK,IAAI,CAAC,EAAE,IAAI,IAAI,CAAC,QAAQ,KAAK,IAAI,CAAC,QAAQ,CAAC,CAAC;QACjH,IAAI,SAAS,IAAI,CAAC,EAAE;YAChB,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC,SAAS,EAAE,CAAC,CAAC,CAAC;SAC7C;QACD,YAAY,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE;YACrB,MAAM,KAAK,GAAG,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,KAAK,CAAC,CAAC,EAAE,IAAI,IAAI,CAAC,QAAQ,KAAK,CAAC,CAAC,QAAQ,CAAC,CAAC;YACvG,IAAI,KAAK,IAAI,CAAC,EAAE;gBACZ,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC;aACzC;QACL,CAAC,CAAC,CAAC;IACP,CAAC;IAED,2BAA2B,CAAC,UAAU,EAAE,IAAkB;QACtD,IAAI,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,KAAK,IAAI,CAAC,EAAE,CAAC,CAAC;QACjE,IAAI,YAAY,GAAG,CAAC,GAAG,IAAI,GAAG,CAAC,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,KAAK,IAAI,CAAC,EAAE,IAAI,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;QAChG,IAAI,YAAY,CAAC,MAAM,GAAG,CAAC,EAAE;YACzB,YAAY,GAAG,YAAY,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,UAAU,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,KAAK,CAAC,CAAC,OAAO,IAAI,IAAI,CAAC,QAAQ,KAAK,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAA;YAC9H,UAAU,GAAG,UAAU,CAAC,MAAM,CAAC,CAAC,GAAG,IAAI,GAAG,CAAC,YAAY,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE;oBAC5D,OAAO;wBACH,EAAE,EAAE,CAAC,CAAC,OAAO;wBACb,QAAQ,EAAE,CAAC,CAAC,SAAS;wBACrB,QAAQ,EAAE,CAAC,CAAC,MAAM;wBAClB,UAAU,EAAE,CAAC,CAAC,QAAQ;wBACtB,IAAI,EAAE,iBAAiB,CAAC,QAAQ;qBACnC,CAAA;gBACL,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;SACT;QACD,IAAI,QAAQ,CAAC,MAAM,GAAG,CAAC,EAAE;YACrB,QAAQ,GAAG,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,UAAU,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,KAAK,CAAC,CAAC,MAAM,IAAI,IAAI,CAAC,QAAQ,KAAK,CAAC,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAA;YACvH,MAAM,cAAc,GAAmB,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE;;gBACpD,OAAO;oBACH,EAAE,EAAE,CAAC,CAAC,MAAM;oBACZ,QAAQ,EAAE,CAAA,MAAA,CAAC,CAAC,QAAQ,0CAAE,MAAM,IAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,QAAQ;oBACzD,QAAQ,EAAE,CAAC,CAAC,QAAQ;oBACpB,IAAI,EAAE,iBAAiB,CAAC,eAAe;iBAC1C,CAAA;YACL,CAAC,CAAC,CAAC;YACH,UAAU,GAAG,UAAU,CAAC,MAAM,CAC1B,cAAc,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,EAAE;gBAC/B,OAAO,KAAK,KAAK,cAAc,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,KAAK,CAAC,CAAC,EAAE,IAAI,IAAI,CAAC,QAAQ,KAAK,CAAC,CAAC,QAAQ,CAAC,CAAA;YACvG,CAAC,CAAC,CACL,CAAC;YACF,QAAQ,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;gBACpB,UAAU,GAAG,IAAI,CAAC,2BAA2B,CAAC,UAAU,EAAE;oBACtD,EAAE,EAAE,IAAI,CAAC,MAAM;oBACf,IAAI,EAAE,IAAI,CAAC,QAAQ;oBACnB,QAAQ,EAAE,IAAI,CAAC,QAAQ;oBACvB,KAAK,EAAE,CAAC;oBACR,UAAU,EAAE,IAAI;oBAChB,QAAQ,EAAE,IAAI;oBACd,QAAQ,EAAE,KAAK;iBAClB,CAAC,CAAA;YACN,CAAC,CAAC,CAAA;SACL;QACD,OAAO,UAAU,CAAC;IACtB,CAAC;IAED,YAAY;QACR,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC;QAC3B,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE,CAAC;IAC3B,CAAC;IAAA,CAAC;IAEF,UAAU;QACN,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC;QAC3B,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;IAC/C,CAAC;IAED,eAAe,CAAC,OAAoB,EAAE,aAAsB;QACxD,IAAI,SAAS,GAAG,CAAC,EAAE,SAAS,GAAG,CAAC,CAAC;QAEjC,SAAS,GAAG,OAAO,CAAC,YAAY,CAAC;QACjC,IAAI,aAAa,EAAE;YACf,MAAM,KAAK,GAAG,MAAM,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAC;YAC/C,SAAS,GAAG,UAAU,CAAC,KAAK,CAAC,SAAS,CAAC,OAAO,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC,GAAG,UAAU,CAAC,KAAK,CAAC,YAAY,CAAC,OAAO,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC,CAAC;SAChH;QAED,OAAO,CAAC,SAAS,GAAG,SAAS,CAAC,CAAC;IACnC,CAAC;IAED,eAAe,CAAC,IAAoB;QAChC,OAAO,GAAG,IAAI,CAAC,QAAQ,EAAE,CAAC;IAC9B,CAAC;IAED,4BAA4B,CAAC,IAAoB;QAC7C,OAAO,GAAG,IAAI,CAAC,kBAAkB,IAAI,IAAI,CAAC,UAAU,EAAE,CAAC;IAC3D,CAAC;IAED,gBAAgB,CAAC,CAAc;QAC3B,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,WAAW,GAAG,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC;IACvD,CAAC;IAED,gBAAgB,CAAC,IAAkB;QAC/B,MAAM,YAAY,GAAG,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,WAAW,EAAE,KAAK,IAAI,CAAC,EAAE,CAAC,WAAW,EAAE,IAAI,CAAC,CAAC,QAAQ,CAAC,WAAW,EAAE,KAAK,IAAI,CAAC,QAAQ,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC;QAChK,IAAI,YAAY,EAAE;YACd,IAAI,CAAC,qBAAqB,CAAC;gBACvB,EAAE,EAAE,YAAY,CAAC,EAAE;gBACnB,IAAI,EAAE,IAAI,CAAC,QAAQ;gBACnB,QAAQ,EAAE,YAAY,CAAC,QAAQ;gBAC/B,QAAQ,EAAE,KAAK;gBACf,UAAU,EAAE,KAAK;gBACjB,KAAK,EAAE,CAAC;gBACR,QAAQ,EAAE,KAAK;aAClB,CAAC,CAAC;SACN;aACI;YACD,4BAA4B;SAC/B;IACL,CAAC;IAED,cAAc,CAAC,IAAI;QACf,OAAO,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,WAAW,EAAE,KAAK,IAAI,CAAC,EAAE,CAAC,WAAW,EAAE,IAAI,CAAC,CAAC,QAAQ,CAAC,WAAW,EAAE,KAAK,IAAI,CAAC,QAAQ,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC,MAAM,GAAG,CAAC,CAAC;IACnK,CAAC;IAED,mBAAmB,CAAC,IAAkB;QAClC,wBAAwB;QACxB,qFAAqF;QACrF,yCAAyC;QACzC,0CAA0C;QAC1C,MAAM;QACN,qHAAqH;QACrH,yCAAyC;QACzC,uCAAuC;QACvC,MAAM;QACN,IAAI,IAAI,GAAG,IAAI,YAAY,EAAE,CAAC;QAC9B,IAAI,CAAC,EAAE,GAAG,IAAI,CAAC,EAAE,CAAC;QAClB,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,IAAI,CAAC;QAC1B,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,SAAS,CAAC;QAChC,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC;QAC3B,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC/B,IAAI;IACR,CAAC;IAED,mBAAmB,CAAC,IAAkB;QAClC,IAAI,QAAQ,GAAG,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,IAAI,CAAC,EAAE,IAAI,CAAC,CAAC,QAAQ,KAAK,IAAI,CAAC,QAAQ,CAAC,CAAC;QACrG,IAAI,QAAQ,GAAG,CAAC,CAAC,EAAE;YACf,IAAI,IAAI,CAAC,eAAe,EAAE;gBACtB,IAAI,IAAI,CAAC,UAAU,EAAE;oBACjB,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,CAAC;iBACpC;qBACI;oBACD,MAAM,SAAS,GAAG,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,KAAK,IAAI,CAAC,EAAE,IAAI,IAAI,CAAC,QAAQ,KAAK,IAAI,CAAC,QAAQ,CAAC,CAAC;oBACjH,IAAI,SAAS,IAAI,CAAC,EAAE;wBAChB,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC,SAAS,EAAE,CAAC,CAAC,CAAC;qBAC7C;iBACJ;gBACD,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,IAAI,CAAC,EAAE,IAAI,CAAC,CAAC,QAAQ,KAAK,IAAI,CAAC,QAAQ,CAAC,CAAC;gBAC1G,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,CAAC;aACjC;iBACI;gBACD,MAAM,SAAS,GAAG,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,KAAK,IAAI,CAAC,EAAE,IAAI,IAAI,CAAC,QAAQ,KAAK,IAAI,CAAC,QAAQ,CAAC,CAAC;gBACjH,IAAI,SAAS,IAAI,CAAC,EAAE;oBAChB,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC,SAAS,EAAE,CAAC,CAAC,CAAC;iBAC7C;gBACD,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,IAAI,CAAC,EAAE,IAAI,CAAC,CAAC,QAAQ,KAAK,IAAI,CAAC,QAAQ,CAAC,CAAA;aAC5G;SACJ;aACI;YACD,IAAI,IAAI,CAAC,eAAe,EAAE;gBACtB,IAAI,IAAI,CAAC,UAAU,EAAE;oBACjB,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,CAAC;iBACpC;qBACI;oBACD,IAAI,CAAC,eAAe,CAAC,IAAI,CACrB;wBACI,EAAE,EAAE,IAAI,CAAC,EAAE;wBACX,QAAQ,EAAE,IAAI,CAAC,IAAI;wBACnB,YAAY,EAAE,IAAI,CAAC,EAAE;wBACrB,QAAQ,EAAE,IAAI,CAAC,QAAQ;wBACvB,IAAI,EAAE,iBAAiB,CAAC,QAAQ;qBACnC,CACJ,CAAA;iBACJ;gBACD,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,CAAC;aACjC;iBACI;gBACD,IAAI,CAAC,eAAe,CAAC,IAAI,CACrB;oBACI,EAAE,EAAE,IAAI,CAAC,EAAE;oBACX,QAAQ,EAAE,IAAI,CAAC,IAAI;oBACnB,YAAY,EAAE,IAAI,CAAC,EAAE;oBACrB,QAAQ,EAAE,IAAI,CAAC,QAAQ;oBACvB,IAAI,EAAE,iBAAiB,CAAC,SAAS;iBACpC,CACJ,CAAA;gBAED,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC;oBACtB,EAAE,EAAE,IAAI,CAAC,EAAE;oBACX,QAAQ,EAAE,IAAI,CAAC,IAAI;oBACnB,IAAI,EAAE,iBAAiB,CAAC,SAAS;oBACjC,QAAQ,EAAE,IAAI,CAAC,QAAQ;oBACvB,QAAQ,EAAE,EAAE;oBACZ,kBAAkB,EAAE,CAAC;oBACrB,UAAU,EAAE,CAAC;iBAChB,CACA,CAAA;aACJ;SACJ;QACD,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,yBAAyB,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;IAC7E,CAAC;IAGD,QAAQ,CAAC,CAAC;QACN,IAAI,CAAC,eAAe,GAAG,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC;QACnC,IAAI,CAAC,IAAI,CAAC,eAAe,EAAE;YACvB,IAAI,CAAC,eAAe,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;gBAChC,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,CAAC;YACnC,CAAC,CAAC,CAAC;SACN;aACI;YACD,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,kBAAkB,CAAC;SAC/C;IACL,CAAC;IAED,yBAAyB,CAAC,IAAoB;QAC1C,OAAO,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE;YAChB,OAAO;gBACH,EAAE,EAAE,CAAC,CAAC,EAAE;gBACR,IAAI,EAAE,CAAC,CAAC,QAAQ;gBAChB,KAAK,EAAE,CAAC;gBACR,UAAU,EAAE,IAAI;gBAChB,QAAQ,EAAE,IAAI;gBACd,QAAQ,EAAE,CAAC,CAAC,QAAQ;gBACpB,QAAQ,EAAE,KAAK;aAClB,CAAC;QACN,CAAC,CAAC,CAAC;IACP,CAAC;IAED,kBAAkB,CAAC,IAAkB;QACjC,IAAI,MAAM,CAAC;QACX,IAAI,UAAU,GAAmB,EAAE,CAAC;QACpC,MAAM,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,KAAK,IAAI,CAAC,QAAQ,CAAC,CAAC;QAC7D,IAAI,MAAM,EAAE;YACR,UAAU,CAAC,IAAI,CAAC;gBACZ,EAAE,EAAE,MAAM,CAAC,MAAM;gBACjB,QAAQ,EAAE,MAAM,CAAC,QAAQ;gBACzB,QAAQ,EAAE,MAAM,CAAC,QAAQ;gBACzB,IAAI,EAAE,iBAAiB,CAAC,eAAe;aAC1C,CAAC,CAAC;YACH,UAAU,GAAG,IAAI,CAAC,mBAAmB,CAAC,UAAU,EAAE,MAAM,CAAC,CAAC;SAC7D;QACD,IAAI,UAAU,CAAC,MAAM,GAAG,CAAC,EAAE;YACvB,MAAM,kBAAkB,GAAG,UAAU,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,eAAe;iBACjE,SAAS,CAAC,YAAY,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,YAAY,CAAC,EAAE,IAAI,CAAC,CAAC,QAAQ,KAAK,YAAY,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC;YACvG,IAAI,kBAAkB,CAAC,MAAM,GAAG,CAAC,EAAE;gBAC/B,MAAM,mBAAmB,GAAG,kBAAkB,CAAC,kBAAkB,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;gBAC9E,IAAI,CAAC,YAAY,CAAC,mBAAmB,CAAC,CAAC;aAC1C;iBACI;gBACD,IAAI,CAAC,YAAY,CAAC;oBACd,EAAE,EAAE,IAAI,CAAC,EAAE;oBACX,QAAQ,EAAE,IAAI,CAAC,IAAI;oBACnB,IAAI,EAAE,iBAAiB,CAAC,eAAe;oBACvC,QAAQ,EAAE,IAAI,CAAC,QAAQ;iBAC1B,CAAC,CAAA;aACL;SACJ;aACI;YACD,IAAI,CAAC,YAAY,CAAC;gBACd,EAAE,EAAE,IAAI,CAAC,EAAE;gBACX,QAAQ,EAAE,IAAI,CAAC,IAAI;gBACnB,IAAI,EAAE,iBAAiB,CAAC,eAAe;gBACvC,QAAQ,EAAE,IAAI,CAAC,QAAQ;aAC1B,CAAC,CAAA;SACL;IACL,CAAC;IAED,YAAY,CAAC,IAAkB;QAC3B,IAAI,QAAQ,GAAG,EAAE,CAAC;QAClB,QAAQ,GAAG,IAAI,CAAC,2BAA2B,CAAC,QAAQ,EAAE;YAClD,EAAE,EAAE,IAAI,CAAC,EAAE;YACX,IAAI,EAAE,IAAI,CAAC,QAAQ;YACnB,QAAQ,EAAE,IAAI,CAAC,QAAQ;YACvB,KAAK,EAAE,CAAC;YACR,UAAU,EAAE,IAAI;YAChB,QAAQ,EAAE,IAAI;YACd,QAAQ,EAAE,KAAK;SAClB,CAAC,CAAC;QACH,IAAI,iBAAiB,GAAG,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,IAAI,CAAC,EAAE,IAAI,CAAC,CAAC,QAAQ,KAAK,IAAI,CAAC,QAAQ,CAAC,CAAC;QAE9G,IAAI,QAAQ,GAAG,EAAE,CAAC;QAClB,QAAQ,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE;YACrB,MAAM,KAAK,GAAG,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,KAAK,KAAK,CAAC,EAAE,IAAI,IAAI,CAAC,QAAQ,KAAK,KAAK,CAAC,QAAQ,CAAC,CAAC;YAC/G,IAAI,KAAK,IAAI,CAAC,EAAE;gBACZ,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC;aACzC;YACD,MAAM,WAAW,GAAG,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,EAAE,KAAK,KAAK,CAAC,EAAE,IAAI,IAAI,CAAC,QAAQ,KAAK,KAAK,CAAC,QAAQ,CAAC,CAAC;YACrH,IAAI,WAAW,IAAI,CAAC,EAAE;gBAClB,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;aACxB;QACL,CAAC,CAAC,CAAC;QACH,IAAI,QAAQ,CAAC,MAAM,GAAG,CAAC,IAAI,QAAQ,CAAC,MAAM,KAAK,CAAC,EAAE;YAC9C,IAAI,iBAAiB,GAAG,CAAC,EAAE;gBACvB,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC;oBACtB,EAAE,EAAE,IAAI,CAAC,EAAE;oBACX,QAAQ,EAAE,IAAI,CAAC,QAAQ;oBACvB,IAAI,EAAE,iBAAiB,CAAC,eAAe;oBACvC,QAAQ,EAAE,IAAI,CAAC,QAAQ;oBACvB,QAAQ,EAAE,EAAE;oBACZ,kBAAkB,EAAE,CAAC;oBACrB,UAAU,EAAE,CAAC;iBAChB,CACA,CAAC;gBACF,iBAAiB,GAAG,IAAI,CAAC,eAAe,CAAC,MAAM,GAAG,CAAC,CAAC;aACvD;YAED,IAAI,CAAC,eAAe,CAAC,iBAAiB,CAAC,CAAC,QAAQ,GAAG,QAAQ,CAAC;YAC5D,IAAI,CAAC,eAAe,CAAC,iBAAiB,CAAC,CAAC,UAAU,GAAG,QAAQ,CAAC,MAAM,CAAC;YACrE,IAAI,CAAC,eAAe,CAAC,iBAAiB,CAAC,CAAC,kBAAkB,GAAG,QAAQ,CAAC,MAAM,CAAC;YAC7E,IAAI,CAAC,eAAe,CAAC,iBAAiB,CAAC,CAAC,IAAI,GAAG,QAAQ,CAAC,MAAM,KAAK,CAAC,CAAC,CAAC,CAAC,iBAAiB,CAAC,SAAS,CAAC,CAAC,CAAC,iBAAiB,CAAC,eAAe,CAAC;SAC1I;IAEL,CAAC;IAED,mBAAmB,CAAC,UAA0B,EAAE,IAAe;QAC3D,IAAI,MAAM,CAAC;QACX,MAAM,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,KAAK,IAAI,CAAC,QAAQ,CAAC,CAAC;QAC7D,IAAI,MAAM,EAAE;YACR,UAAU,GAAG,CAAC,GAAG,UAAU,EAAE;oBACzB,EAAE,EAAE,MAAM,CAAC,MAAM;oBACjB,QAAQ,EAAE,MAAM,CAAC,QAAQ;oBACzB,QAAQ,EAAE,MAAM,CAAC,QAAQ;oBACzB,IAAI,EAAE,iBAAiB,CAAC,eAAe;iBAC1C,CAAC,CAAC;YACH,IAAI,CAAC,mBAAmB,CAAC,UAAU,EAAE,MAAM,CAAC,CAAC;SAChD;QACD,OAAO,UAAU,CAAC;IACtB,CAAC;IAED,mBAAmB,CAAC,IAAoB;QACpC,IAAI,IAAI,CAAC,IAAI,KAAK,iBAAiB,CAAC,eAAe,EAAE;YACjD,IAAI,QAAQ,GAAG,EAAE,CAAA;YACjB,QAAQ,GAAG,IAAI,CAAC,2BAA2B,CAAC,QAAQ,EAAE;gBAClD,EAAE,EAAE,IAAI,CAAC,EAAE;gBACX,IAAI,EAAE,IAAI,CAAC,QAAQ;gBACnB,QAAQ,EAAE,IAAI,CAAC,QAAQ;gBACvB,KAAK,EAAE,CAAC;gBACR,UAAU,EAAE,IAAI;gBAChB,QAAQ,EAAE,IAAI;gBACd,QAAQ,EAAE,KAAK;aAClB,CAAC,CAAA;YACF,IAAI,YAAY,GAAG,EAAE,CAAA;YACrB,MAAM,KAAK,GAAG,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,IAAI,CAAC,EAAE,IAAI,CAAC,CAAC,QAAQ,KAAK,IAAI,CAAC,QAAQ,CAAC,CAAC;YACjG,IAAI,KAAK,GAAG,CAAC,EAAE;gBACX,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;aAC3B;YACD,QAAQ,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE;gBACrB,MAAM,KAAK,GAAG,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,KAAK,CAAC,EAAE,IAAI,CAAC,CAAC,QAAQ,KAAK,KAAK,CAAC,QAAQ,CAAC,CAAC;gBACnG,IAAI,KAAK,GAAG,CAAC,EAAE;oBACX,YAAY,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;iBAC5B;YACL,CAAC,CAAC,CAAA;YACF,IAAI,CAAC,YAAY,GAAG,CAAC,GAAG,IAAI,CAAC,YAAY,EAAE,GAAG,YAAY,CAAC,CAAC;SAC/D;IACL,CAAC;IAED,kBAAkB,CAAC,IAAkB;QACjC,IAAI,QAAQ,GAAG,EAAE,CAAA;QACjB,QAAQ,GAAG,IAAI,CAAC,2BAA2B,CAAC,QAAQ,EAAE;YAClD,EAAE,EAAE,IAAI,CAAC,EAAE;YACX,IAAI,EAAE,IAAI,CAAC,QAAQ;YACnB,QAAQ,EAAE,IAAI,CAAC,QAAQ;YACvB,KAAK,EAAE,CAAC;YACR,UAAU,EAAE,IAAI;YAChB,QAAQ,EAAE,IAAI;YACd,QAAQ,EAAE,KAAK;SAClB,CAAC,CAAA;QAEF,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAC7C,QAAQ,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE,CACpB,CAAC,CAAC,CAAC,EAAE,KAAK,KAAK,CAAC,EAAE,IAAI,CAAC,CAAC,QAAQ,KAAK,KAAK,CAAC,QAAQ,CAAC,CACvD,CAAC,MAAM,KAAK,CAAC,CACjB,CAAC;QACF,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,KAAK,IAAI,CAAC,EAAE,IAAI,CAAC,CAAC,QAAQ,KAAK,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC;IAC3G,CAAC;;gIA3pBQ,mCAAmC,uRAiDhC,eAAe;oHAjDlB,mCAAmC,6OAsCE,sBAAsB,0DAFtD,aAAa,gDCtE/B,wsMAkLE;2FDhJW,mCAAmC;kBAN/C,SAAS;mBAAC;oBACP,QAAQ,EAAE,mCAAmC;oBAC7C,WAAW,EAAE,0CAA0C;oBACvD,SAAS,EAAE,CAAC,0CAA0C,CAAC;oBACvD,aAAa,EAAE,iBAAiB,CAAC,IAAI;iBACxC;;0BAkDQ,MAAM;2BAAC,eAAe;4CAbM,SAAS;sBAAzC,YAAY;uBAAC,aAAa,EAAE,EAAE;gBAG/B,YAAY;sBADX,SAAS;uBAAC,yBAAyB,EAAE,EAAE,IAAI,EAAE,sBAAsB,EAAE,MAAM,EAAE,IAAI,EAAE;gBA+CpF,SAAS;sBADR,YAAY;uBAAC,gBAAgB,EAAE,CAAC,QAAQ,CAAC","sourcesContent":["import { ChangeDetectorRef, EventEmitter, OnDestroy, ViewChild, ViewEncapsulation, AfterViewChecked, QueryList, ViewChildren, ElementRef, AfterViewInit } from '@angular/core';\r\nimport { Component, HostListener, Inject, OnInit } from '@angular/core';\r\nimport { FormControl } from '@angular/forms';\r\nimport { MatAutocompleteTrigger } from '@angular/material/autocomplete';\r\nimport { MatDialogRef, MAT_DIALOG_DATA } from '@angular/material/dialog';\r\nimport { MatIconRegistry } from '@angular/material/icon';\r\nimport { DomSanitizer } from '@angular/platform-browser';\r\nimport { Subject } from 'rxjs';\r\nimport { debounceTime, takeUntil } from 'rxjs/operators';\r\nimport { TreeNode } from '../../qms-ckeditor-components/common/models/qms-ckeditor-tree-node.model';\r\nimport { TranslateLibraryService } from '../../services/translation-registry.service';\r\nimport { QMSIconRegistryService } from '../app-icon/icon-registry.service';\r\nimport { SelectPopupData } from './model/select-popup-data.model';\r\nimport { SelectOption } from './model/select-option.model';\r\nimport { TreeModel } from '../tree/model/tree.model';\r\nimport { QMSSelectGlobalService } from './services/select-global.service';\r\nimport { TreeComponent } from '../tree/tree.component';\r\nimport { TreeFlatNode } from '../tree/model/tree-flat-node.model';\r\nimport { TreeConfig } from '../tree/model/tree-config.model';\r\nimport { SelectConst } from './model/select.const';\r\nimport { X } from '@angular/cdk/keycodes';\r\nimport { SelectedOption } from './model/seleted-option.model';\r\nimport { SelectOptionTypes } from 'projects/qms-angular/src/public-api';\r\nimport { ItemIconType } from '../related/common/item-icon-type.enum';\r\nimport { SelectSearchOption } from './model/select-search-option.model';\r\n\r\n\r\n\r\n@Component({\r\n    selector: 'qms-select-include-children-popup',\r\n    templateUrl: './select-include-children.component.html',\r\n    styleUrls: ['./select-include-children.component.scss'],\r\n    encapsulation: ViewEncapsulation.None\r\n})\r\nexport class SelectIncludeChildrenPopUpComponent implements OnInit, OnDestroy, AfterViewChecked, AfterViewInit {\r\n    ngUnsubscribe = new Subject<void>();\r\n\r\n    LANG: any;\r\n    headerName = '';\r\n    treeData: Array<TreeModel> = [];\r\n    treeConfig: TreeConfig;\r\n\r\n    checkedNodeList: Array<SelectedOption> = [];\r\n    selectedOptions: Array<SelectOption> = [];\r\n    selectedData: Array<TreeFlatNode> = [];\r\n\r\n    commonCheckedList: Array<TreeFlatNode> = [];\r\n\r\n    itemType = 0;\r\n    selectedRiskData: any = [];\r\n    disabledList: SelectedOption[] = [];\r\n    orginalDisableList: any = [];\r\n    maxSelectItemCount: number;\r\n\r\n    isDocumentExpanded = true;\r\n    isCommonExpanded = true;\r\n    singleSelectOption = false;\r\n    searchOrder = [];\r\n\r\n    myControl = new FormControl();\r\n    filteredOptions: SelectSearchOption[] = [];\r\n    isInputValue = false;\r\n    selectedFolder: TreeFlatNode = null;\r\n    listChildrenSelectOne: any = [];\r\n    includeChildren = false;\r\n    editItem: SelectedOption;\r\n    itemIconType = ItemIconType;\r\n    onSearch = new EventEmitter();\r\n    onExpandFolder = new EventEmitter<SelectOption>();\r\n\r\n    @ViewChildren(TreeComponent, {}) dataTrees: QueryList<TreeComponent>;\r\n\r\n    @ViewChild('autoCompleteInputSearch', { read: MatAutocompleteTrigger, static: true })\r\n    autoComplete: MatAutocompleteTrigger;\r\n    constructor(\r\n        private cdRef: ChangeDetectorRef,\r\n        public translate: TranslateLibraryService,\r\n        public dialogRef: MatDialogRef<SelectIncludeChildrenPopUpComponent>,\r\n        public globalService: QMSSelectGlobalService,\r\n        private iconRegistry: MatIconRegistry,\r\n        private domSanitizer: DomSanitizer,\r\n        private appIconService: QMSIconRegistryService,\r\n        private elem: ElementRef,\r\n        @Inject(MAT_DIALOG_DATA) public data: SelectPopupData\r\n    ) {\r\n        this.headerName = data.headerName;\r\n        this.treeData = data.treeData;\r\n        this.treeConfig = data.treeConfig;\r\n        this.selectedRiskData = data?.selectedNode || [];\r\n        this.disabledList = $.extend(true, [], data.disabledList || []);\r\n        this.orginalDisableList = $.extend(true, [], data.disabledList || []);\r\n        this.singleSelectOption = data.treeConfig.singleSelectedNode;\r\n        this.maxSelectItemCount = data.maxSelectItemCount;\r\n        this.checkedNodeList = data?.selectedList || [];\r\n        this.includeChildren = data?.includeChildren;\r\n        this.editItem = data.editItem;\r\n        appIconService.registerProcessIcon(iconRegistry, domSanitizer);\r\n        appIconService.registerProcessAreaIcon(iconRegistry, domSanitizer);\r\n        appIconService.registerDocumentIcon(iconRegistry, domSanitizer);\r\n        appIconService.registerFolderIcon(iconRegistry, domSanitizer);\r\n        appIconService.registerDeviationIcon(iconRegistry, domSanitizer);\r\n        appIconService.registerChecklistIcon(iconRegistry, domSanitizer);\r\n        appIconService.registerRiskIcon(iconRegistry, domSanitizer);\r\n    }\r\n    ngAfterViewInit(): void {\r\n        if (this.editItem) {\r\n            this.focusEditItem(this.editItem);\r\n        }\r\n        this.initTree(this.checkedNodeList);\r\n    }\r\n\r\n    ngOnDestroy(): void {\r\n        this.ngUnsubscribe.next();\r\n        this.ngUnsubscribe.complete();\r\n        this.globalService.setSearchResult([]);\r\n        this.selectedFolder = null;\r\n    }\r\n\r\n    @HostListener('window:message', ['$event'])\r\n    onMessage(event) {\r\n        if (event.data === SelectConst.HIDE_SEARCH_RESULT) {\r\n            this.autoComplete.closePanel();\r\n        }\r\n    }\r\n\r\n    ngOnInit(): void {\r\n        this.translate.getLanguageSubject$.pipe().subscribe((res) => {\r\n            if (res) {\r\n                this.LANG = this.translate.getObjectLang(res);\r\n            }\r\n        });\r\n\r\n        this.globalService.searchSelect.pipe(takeUntil(this.ngUnsubscribe)).subscribe((res) => {\r\n            if (res && res.length) {\r\n                this.filteredOptions = res;\r\n            }\r\n        });\r\n\r\n        this.myControl.valueChanges.pipe(debounceTime(1000)).subscribe((val) => {\r\n            this.isInputValue = true;\r\n            this.onSearchRelated(val);\r\n        });\r\n        // this.searchOrder = this.getSearchOrder();\r\n    }\r\n\r\n    ngAfterViewChecked() {\r\n        this.cdRef.detectChanges();\r\n        if (this.filteredOptions && this.filteredOptions.length) {\r\n            this.autoComplete.openPanel();\r\n            this.setResultHeight();\r\n        } else if (this.autoComplete) {\r\n            this.autoComplete.closePanel();\r\n        }\r\n    }\r\n\r\n    initTree(selectedOptions: SelectedOption[]) {\r\n        if (selectedOptions.length > 0) {\r\n            selectedOptions.forEach(element => {\r\n                this.selectedOptions.push(element);\r\n                if (element.type === SelectOptionTypes.IncludeChildren) {\r\n                    this.selectedOptions = this.selectedOptions.concat(element.children);\r\n                }\r\n                this.selectedData = this.mapSelectOptionToTreeNode(this.selectedOptions);\r\n            })\r\n        }\r\n    }\r\n\r\n    focusEditItem(selectedOption: SelectedOption) {\r\n        const node = this.dataTrees.toArray()[0].getNodeByIdAndParentId(selectedOption.id, selectedOption.parentId);\r\n        if (node) {\r\n            this.dataTrees.toArray()[0].expandNode(node);\r\n            const element = document.getElementById(`_${node.parentId ? node.parentId : ''}_${node.id}_${node.level}`);\r\n            if (element) {\r\n                element.scrollIntoView(false);\r\n            }\r\n        }\r\n    }\r\n\r\n    removeCheckedNodeList(item: TreeFlatNode) {\r\n        const index = this.checkedNodeList.findIndex(x => (x.id.toLowerCase() === item.id.toLowerCase() && x.parentId.toLowerCase() === item.parentId.toLowerCase()));\r\n        if (index >= 0) {\r\n            let position = this.selectedOptions.findIndex(x => x.id === item.id && x.parentId === item.parentId);\r\n            if (position >= 0) {\r\n                this.selectedOptions.splice(position, 1);\r\n            }\r\n\r\n            if (this.checkedNodeList[index].type === SelectOptionTypes.IncludeChildren) {\r\n                this.removeIncludeChildren(item);\r\n            }\r\n\r\n            if (this.includeChildren) {\r\n                this.refactorSelectList(item);\r\n            }\r\n            else {\r\n                this.checkedNodeList.splice(index, 1);\r\n            }\r\n\r\n            this.enableSelectedNode({ id: item.id, parentId: item.parentId, itemName: item.name, type: SelectOptionTypes.IncludeChildren });\r\n            this.selectedData = this.mapSelectOptionToTreeNode(this.selectedOptions);\r\n        }\r\n    }\r\n\r\n    selectSearchOption(item: SelectOption) {\r\n        let position = this.selectedOptions.findIndex(x => x.id === item.id && x.parentId === item.parentId);\r\n        if (position < 0) {\r\n            if (this.includeChildren) {\r\n                this.selectIncludeChildren({\r\n                    id: item.id,\r\n                    name: item.itemName,\r\n                    parentId: item.parentId,\r\n                    level: 0,\r\n                    expandable: true,\r\n                    disabled: false,\r\n                    hasChild: false\r\n                });\r\n                this.refactorSelectList({\r\n                    id: item.id,\r\n                    name: item.itemName,\r\n                    parentId: item.parentId,\r\n                    level: 0,\r\n                    expandable: true,\r\n                    disabled: false,\r\n                    hasChild: false\r\n                });\r\n            }\r\n            else {\r\n                this.selectedOptions.push(item)\r\n\r\n                this.checkedNodeList.push({\r\n                    id: item.id,\r\n                    itemName: item.itemName,\r\n                    type: SelectOptionTypes.SelectOne,\r\n                    parentId: item.parentId,\r\n                    children: [],\r\n                    noChildren: 0,\r\n                    noSelectedChildren: 0\r\n                }\r\n                )\r\n            }\r\n        }\r\n        this.selectedData = this.mapSelectOptionToTreeNode(this.selectedOptions);\r\n    }\r\n\r\n\r\n    getItemIconType(item: SelectSearchOption) {\r\n        if (item.itemIcon && item.itemIcon.length) return this.itemIconType.name;\r\n        if (item.itemIconPath && item.itemIconPath.length) return this.itemIconType.path;\r\n        if (item.itemIconBase64 && item.itemIconBase64.length) return this.itemIconType.base64;\r\n        if (item.itemIconSvg && item.itemIconSvg.length) return this.itemIconType.svg;\r\n        return this.itemIconType.none;\r\n    }\r\n\r\n    getImagePath(item: SelectSearchOption) {\r\n        return this.domSanitizer.bypassSecurityTrustResourceUrl(item.itemIconBase64) as string;\r\n    }\r\n\r\n    isMatchTrue(arr: any[], arr2: any[]) {\r\n        return arr.every((i) => {\r\n            return arr2.includes(i);\r\n        });\r\n    }\r\n\r\n    setResultHeight(arr?: SelectOption[]) {\r\n        let maxHeight = 484;\r\n        const popup_content = document.getElementsByClassName('qmslib_related_popup_content')[0] as HTMLElement;\r\n        const line__divider = document.getElementsByClassName('line__divider')[0] as HTMLElement;\r\n        if (popup_content && line__divider) {\r\n            maxHeight = this.getOffsetHeight(popup_content, true) + this.getOffsetHeight(line__divider, true) * 2;\r\n        }\r\n\r\n        const contentResult = document.getElementsByClassName('cdk-virtual-scroll-content-wrapper')[0] as HTMLElement;\r\n        const viewreports = document.getElementsByClassName('related-viewport')[0] as HTMLElement;\r\n\r\n        if (viewreports) {\r\n            if (contentResult.offsetHeight <= maxHeight) {\r\n                viewreports.style.height = `${contentResult.offsetHeight}px`;\r\n            }\r\n            else {\r\n                viewreports.style.height = `${maxHeight}px`;\r\n            }\r\n        }\r\n    }\r\n\r\n    onSearchRelated(_val: any) {\r\n        this.filteredOptions = [];\r\n        if (typeof (_val) === 'object') {\r\n            this.myControl.setValue('');\r\n        }\r\n        else if (typeof (_val) === 'string') {\r\n            if (!!_val) {\r\n                this.onSearch.emit(_val);\r\n            }\r\n        }\r\n    }\r\n\r\n    showSearchResult() {\r\n        this.autoComplete.openPanel();\r\n    }\r\n\r\n    displayRelated(related?: SelectOption): string | undefined {\r\n        return related ? related.itemName : undefined;\r\n    }\r\n\r\n    getCommonCheckedNode(list: Array<TreeFlatNode>) {\r\n    }\r\n\r\n    selectIncludeChildren(item: TreeFlatNode) {\r\n        let listChildren: SelectOption[] = [];\r\n        listChildren = this.getAllChildrenNodeRecursive(listChildren, item);\r\n        this.selectedOptions.push({\r\n            id: item.id,\r\n            itemName: item.name,\r\n            itemNumberId: item.id,\r\n            parentId: item.parentId,\r\n            type: SelectOptionTypes.IncludeChildren\r\n        });\r\n        listChildren.forEach(x => {\r\n            const index = this.selectedOptions.findIndex(node => node.id === x.id && node.parentId === x.parentId);\r\n            if (index < 0) {\r\n                this.selectedOptions.push(x);\r\n            }\r\n        });\r\n\r\n    }\r\n\r\n    removeIncludeChildren(item: TreeFlatNode) {\r\n        let listChildren = [];\r\n        listChildren = this.getAllChildrenNodeRecursive(listChildren, item);\r\n        const itemIndex = this.selectedOptions.findIndex(node => node.id === item.id && node.parentId === item.parentId);\r\n        if (itemIndex >= 0) {\r\n            this.selectedOptions.splice(itemIndex, 1);\r\n        }\r\n        listChildren.forEach(x => {\r\n            const index = this.selectedOptions.findIndex(node => node.id === x.id && node.parentId === x.parentId);\r\n            if (index >= 0) {\r\n                this.selectedOptions.splice(index, 1);\r\n            }\r\n        });\r\n    }\r\n\r\n    getAllChildrenNodeRecursive(listResult, item: TreeFlatNode): SelectOption[] {\r\n        let children = this.treeData.filter(x => x.parentId === item.id);\r\n        let childrenItem = [...new Set(this.treeData.filter(x => x.rootId === item.id && !!x.childId))];\r\n        if (childrenItem.length > 0) {\r\n            childrenItem = childrenItem.filter(x => listResult.findIndex(node => node.id === x.childId && node.parentId === x.rootId) < 0)\r\n            listResult = listResult.concat([...new Set(childrenItem.map(x => {\r\n                return {\r\n                    id: x.childId,\r\n                    itemName: x.childName,\r\n                    parentId: x.rootId,\r\n                    parentName: x.rootName,\r\n                    type: SelectOptionTypes.Children\r\n                }\r\n            }))]);\r\n        }\r\n        if (children.length > 0) {\r\n            children = children.filter(x => listResult.findIndex(node => node.id === x.rootId && node.parentId === x.parentId) < 0)\r\n            const uniqueChildren: SelectOption[] = children.map(x => {\r\n                return {\r\n                    id: x.rootId,\r\n                    itemName: x.parentId?.length > 0 ? x.subName : x.rootName,\r\n                    parentId: x.parentId,\r\n                    type: SelectOptionTypes.IncludeChildren\r\n                }\r\n            });\r\n            listResult = listResult.concat(\r\n                uniqueChildren.filter((x, index) => {\r\n                    return index === uniqueChildren.findIndex(node => node.id === x.id && node.parentId === x.parentId)\r\n                })\r\n            );\r\n            children.forEach(node => {\r\n                listResult = this.getAllChildrenNodeRecursive(listResult, {\r\n                    id: node.rootId,\r\n                    name: node.rootName,\r\n                    parentId: node.parentId,\r\n                    level: 0,\r\n                    expandable: true,\r\n                    hasChild: true,\r\n                    disabled: false\r\n                })\r\n            })\r\n        }\r\n        return listResult;\r\n    }\r\n\r\n    onCloseClick(): void {\r\n        this.selectedFolder = null;\r\n        this.dialogRef.close();\r\n    };\r\n\r\n    onAddClick() {\r\n        this.selectedFolder = null;\r\n        this.dialogRef.close(this.checkedNodeList);\r\n    }\r\n\r\n    getOffsetHeight(element: HTMLElement, includeMargin: boolean): number {\r\n        let elmHeight = 0, elmMargin = 0;\r\n\r\n        elmHeight = element.offsetHeight;\r\n        if (includeMargin) {\r\n            const style = window.getComputedStyle(element);\r\n            elmMargin = parseFloat(style.marginTop.replace('px', '')) + parseFloat(style.marginBottom.replace('px', ''));\r\n        }\r\n\r\n        return (elmHeight + elmMargin);\r\n    }\r\n\r\n    getItemChipName(item: SelectedOption) {\r\n        return `${item.itemName}`;\r\n    }\r\n\r\n    getItemSelectedChildrenRatio(item: SelectedOption) {\r\n        return `${item.noSelectedChildren}/${item.noChildren}`;\r\n    }\r\n\r\n    isEllipsisActive(e: HTMLElement): boolean {\r\n        return e ? (e.clientWidth < e.scrollWidth) : false;\r\n    }\r\n\r\n    toggleSelectItem(node: SelectOption) {\r\n        const SelectOption = this.checkedNodeList.find(x => (x.id.toLowerCase() === node.id.toLowerCase() && x.parentId.toLowerCase() === node.parentId.toLowerCase()));\r\n        if (SelectOption) {\r\n            this.removeCheckedNodeList({\r\n                id: SelectOption.id,\r\n                name: node.itemName,\r\n                parentId: SelectOption.parentId,\r\n                hasChild: false,\r\n                expandable: false,\r\n                level: 0,\r\n                disabled: false,\r\n            });\r\n        }\r\n        else {\r\n            // this.selectRelated(node);\r\n        }\r\n    }\r\n\r\n    isNodeSelected(node) {\r\n        return this.checkedNodeList.filter(x => (x.id.toLowerCase() === node.id.toLowerCase() && x.parentId.toLowerCase() === node.parentId.toLowerCase())).length > 0;\r\n    }\r\n\r\n    getChildrenOfFolder(node: TreeFlatNode) {\r\n        // if (this.splitView) {\r\n        // const parentTexts = this.elem.nativeElement.querySelectorAll('.text-node-parent');\r\n        // [].forEach.call(parentTexts, (el) => {\r\n        //     el.classList.remove('active-item');\r\n        // });\r\n        // const itemElement = document.querySelectorAll(`#_${node.parentId ? node.parentId : ''}_${node.id}_${node.level}`);\r\n        // [].forEach.call(itemElement, (el) => {\r\n        //     el.classList.add('active-item');\r\n        // });\r\n        let item = new SelectOption();\r\n        item.id = node.id;\r\n        item.itemName = node.name;\r\n        item.levelType = node.levelType;\r\n        this.selectedFolder = node;\r\n        this.onExpandFolder.emit(item);\r\n        // }\r\n    }\r\n\r\n    selectNodeTreeEvent(node: TreeFlatNode) {\r\n        let position = this.selectedOptions.findIndex(x => x.id === node.id && x.parentId === node.parentId);\r\n        if (position > -1) {\r\n            if (this.includeChildren) {\r\n                if (node.expandable) {\r\n                    this.removeIncludeChildren(node);\r\n                }\r\n                else {\r\n                    const itemIndex = this.selectedOptions.findIndex(item => node.id === item.id && node.parentId === item.parentId);\r\n                    if (itemIndex >= 0) {\r\n                        this.selectedOptions.splice(itemIndex, 1);\r\n                    }\r\n                }\r\n                this.checkedNodeList = this.checkedNodeList.filter(x => x.id !== node.id || x.parentId !== node.parentId);\r\n                this.refactorSelectList(node);\r\n            }\r\n            else {\r\n                const itemIndex = this.selectedOptions.findIndex(item => node.id === item.id && node.parentId === item.parentId);\r\n                if (itemIndex >= 0) {\r\n                    this.selectedOptions.splice(itemIndex, 1);\r\n                }\r\n                this.checkedNodeList = this.checkedNodeList.filter(x => x.id !== node.id || x.parentId !== node.parentId)\r\n            }\r\n        }\r\n        else {\r\n            if (this.includeChildren) {\r\n                if (node.expandable) {\r\n                    this.selectIncludeChildren(node);\r\n                }\r\n                else {\r\n                    this.selectedOptions.push(\r\n                        {\r\n                            id: node.id,\r\n                            itemName: node.name,\r\n                            itemNumberId: node.id,\r\n                            parentId: node.parentId,\r\n                            type: SelectOptionTypes.Children\r\n                        }\r\n                    )\r\n                }\r\n                this.refactorSelectList(node);\r\n            }\r\n            else {\r\n                this.selectedOptions.push(\r\n                    {\r\n                        id: node.id,\r\n                        itemName: node.name,\r\n                        itemNumberId: node.id,\r\n                        parentId: node.parentId,\r\n                        type: SelectOptionTypes.SelectOne\r\n                    }\r\n                )\r\n\r\n                this.checkedNodeList.push({\r\n                    id: node.id,\r\n                    itemName: node.name,\r\n                    type: SelectOptionTypes.SelectOne,\r\n                    parentId: node.parentId,\r\n                    children: [],\r\n                    noSelectedChildren: 0,\r\n                    noChildren: 0,\r\n                }\r\n                )\r\n            }\r\n        }\r\n        this.selectedData = this.mapSelectOptionToTreeNode(this.selectedOptions);\r\n    }\r\n\r\n\r\n    setValue(e) {\r\n        this.includeChildren = !!e.checked;\r\n        if (!this.includeChildren) {\r\n            this.checkedNodeList.forEach(node => {\r\n                this.disableSelectedNode(node);\r\n            });\r\n        }\r\n        else {\r\n            this.disabledList = this.orginalDisableList;\r\n        }\r\n    }\r\n\r\n    mapSelectOptionToTreeNode(list: SelectOption[]): TreeFlatNode[] {\r\n        return list.map(x => {\r\n            return {\r\n                id: x.id,\r\n                name: x.itemName,\r\n                level: 0,\r\n                expandable: true,\r\n                hasChild: true,\r\n                parentId: x.parentId,\r\n                disabled: false,\r\n            };\r\n        });\r\n    }\r\n\r\n    refactorSelectList(node: TreeFlatNode) {\r\n        let parent;\r\n        let parentList: SelectOption[] = [];\r\n        parent = this.treeData.find(x => x.rootId === node.parentId);\r\n        if (parent) {\r\n            parentList.push({\r\n                id: parent.rootId,\r\n                itemName: parent.rootName,\r\n                parentId: parent.parentId,\r\n                type: SelectOptionTypes.IncludeChildren\r\n            });\r\n            parentList = this.getParentLineOfNode(parentList, parent);\r\n        }\r\n        if (parentList.length > 0) {\r\n            const selectedParentList = parentList.filter(x => this.selectedOptions\r\n                .findIndex(selectedNode => x.id === selectedNode.id && x.parentId === selectedNode.parentId) >= 0);\r\n            if (selectedParentList.length > 0) {\r\n                const highestSelectedNode = selectedParentList[selectedParentList.length - 1];\r\n                this.combineNodes(highestSelectedNode);\r\n            }\r\n            else {\r\n                this.combineNodes({\r\n                    id: node.id,\r\n                    itemName: node.name,\r\n                    type: SelectOptionTypes.IncludeChildren,\r\n                    parentId: node.parentId\r\n                })\r\n            }\r\n        }\r\n        else {\r\n            this.combineNodes({\r\n                id: node.id,\r\n                itemName: node.name,\r\n                type: SelectOptionTypes.IncludeChildren,\r\n                parentId: node.parentId\r\n            })\r\n        }\r\n    }\r\n\r\n    combineNodes(root: SelectOption) {\r\n        let children = [];\r\n        children = this.getAllChildrenNodeRecursive(children, {\r\n            id: root.id,\r\n            name: root.itemName,\r\n            parentId: root.parentId,\r\n            level: 0,\r\n            expandable: true,\r\n            hasChild: true,\r\n            disabled: false\r\n        });\r\n        let selectedNodeIndex = this.checkedNodeList.findIndex(x => x.id === root.id && x.parentId === root.parentId);\r\n\r\n        let nodeList = [];\r\n        children.forEach(child => {\r\n            const index = this.checkedNodeList.findIndex(node => node.id === child.id && node.parentId === child.parentId);\r\n            if (index >= 0) {\r\n                this.checkedNodeList.splice(index, 1);\r\n            }\r\n            const selectIndex = this.selectedOptions.findIndex(node => node.id === child.id && node.parentId === child.parentId);\r\n            if (selectIndex >= 0) {\r\n                nodeList.push(child);\r\n            }\r\n        });\r\n        if (nodeList.length > 0 || children.length === 0) {\r\n            if (selectedNodeIndex < 0) {\r\n                this.checkedNodeList.push({\r\n                    id: root.id,\r\n                    itemName: root.itemName,\r\n                    type: SelectOptionTypes.IncludeChildren,\r\n                    parentId: root.parentId,\r\n                    children: [],\r\n                    noSelectedChildren: 0,\r\n                    noChildren: 0\r\n                }\r\n                );\r\n                selectedNodeIndex = this.checkedNodeList.length - 1;\r\n            }\r\n\r\n            this.checkedNodeList[selectedNodeIndex].children = nodeList;\r\n            this.checkedNodeList[selectedNodeIndex].noChildren = children.length;\r\n            this.checkedNodeList[selectedNodeIndex].noSelectedChildren = nodeList.length;\r\n            this.checkedNodeList[selectedNodeIndex].type = children.length === 0 ? SelectOptionTypes.SelectOne : SelectOptionTypes.IncludeChildren;\r\n        }\r\n\r\n    }\r\n\r\n    getParentLineOfNode(listParent: SelectOption[], node: TreeModel) {\r\n        let parent;\r\n        parent = this.treeData.find(x => x.rootId === node.parentId);\r\n        if (parent) {\r\n            listParent = [...listParent, {\r\n                id: parent.rootId,\r\n                itemName: parent.rootName,\r\n                parentId: parent.parentId,\r\n                type: SelectOptionTypes.IncludeChildren\r\n            }];\r\n            this.getParentLineOfNode(listParent, parent);\r\n        }\r\n        return listParent;\r\n    }\r\n\r\n    disableSelectedNode(node: SelectedOption) {\r\n        if (node.type === SelectOptionTypes.IncludeChildren) {\r\n            let children = []\r\n            children = this.getAllChildrenNodeRecursive(children, {\r\n                id: node.id,\r\n                name: node.itemName,\r\n                parentId: node.parentId,\r\n                level: 0,\r\n                expandable: true,\r\n                hasChild: true,\r\n                disabled: false\r\n            })\r\n            let disableNodes = []\r\n            const index = this.disabledList.findIndex(x => x.id === node.id && x.parentId === node.parentId);\r\n            if (index < 0) {\r\n                disableNodes.push(node);\r\n            }\r\n            children.forEach(child => {\r\n                const index = this.disabledList.findIndex(x => x.id === child.id && x.parentId === child.parentId);\r\n                if (index < 0) {\r\n                    disableNodes.push(child);\r\n                }\r\n            })\r\n            this.disabledList = [...this.disabledList, ...disableNodes];\r\n        }\r\n    }\r\n\r\n    enableSelectedNode(node: SelectOption) {\r\n        let children = []\r\n        children = this.getAllChildrenNodeRecursive(children, {\r\n            id: node.id,\r\n            name: node.itemName,\r\n            parentId: node.parentId,\r\n            level: 0,\r\n            expandable: true,\r\n            hasChild: true,\r\n            disabled: false\r\n        })\r\n\r\n        this.disabledList = this.disabledList.filter(x =>\r\n            children.filter(child =>\r\n                (x.id === child.id && x.parentId === child.parentId)\r\n            ).length === 0\r\n        );\r\n        this.disabledList = this.disabledList.filter(x => !(x.id === node.id && x.parentId === node.parentId));\r\n    }\r\n}\r\n","<div id=\"qmslib_related_popup\" class=\"qmslib__related__popup__container\">\r\n    <div id=\"qmslib_related_popup_header\">\r\n      <span mat-icon-button class=\"button__close\" (click)=\"onCloseClick()\">\r\n        <mat-icon mat-icon>close</mat-icon>\r\n      </span>\r\n      <div id=\"qmslib_related_popup_header_001\" mat-dialog-content>\r\n        <span>{{ headerName | uppercase }}</span>\r\n      </div>\r\n    </div>\r\n  \r\n    <div\r\n      id=\"qmslib_related_popup_search\"\r\n      class=\"input__field\"\r\n      (click)=\"showSearchResult()\"\r\n    >\r\n      <input\r\n        #name\r\n        type=\"text\"\r\n        placeholder=\"{{ LANG.SEARCH }}\"\r\n        matInput\r\n        [formControl]=\"myControl\"\r\n        [matAutocomplete]=\"auto\"\r\n        #autoCompleteInputSearch\r\n      />\r\n      <mat-icon>search</mat-icon>\r\n    </div>\r\n    <div class=\"select__toggle-include\">\r\n        <mat-slide-toggle\r\n          [checked]=\"includeChildren\"\r\n          (change)=\"setValue($event)\"\r\n          color=\"default\"\r\n          qms-group-options>\r\n          <span class=\"text-label\">Select label</span>\r\n        </mat-slide-toggle>\r\n      </div>\r\n    <div class=\"line__divider\"></div>\r\n  \r\n    <mat-autocomplete\r\n      #auto=\"matAutocomplete\"\r\n      [displayWith]=\"displayRelated\"\r\n      class=\"mat-autocomplete_related-viewport\"\r\n    >\r\n      <cdk-virtual-scroll-viewport\r\n        qms-scrollbar\r\n        itemSize=\"10\"\r\n        class=\"related-viewport\"\r\n      >\r\n        <div\r\n          class=\"search__module-result\"\r\n          *ngIf=\"filteredOptions\">\r\n          <mat-option\r\n            class=\"search__option\"\r\n            *ngFor=\"let option of filteredOptions\"\r\n            [value]=\"option\"\r\n            (click)=\"selectSearchOption(option)\"\r\n          >\r\n            <qms-list-item type=\"image-square\">\r\n              <mat-icon\r\n                leading-icon\r\n                *ngIf=\"getItemIconType(option) === itemIconType.name\"\r\n                class=\"mat-icon-rtl-mirror material-icons-outlined\"\r\n                type=\"image-square\"\r\n              >\r\n                {{ option.itemIcon }}\r\n              </mat-icon>\r\n\r\n              <mat-icon \r\n                leading-icon\r\n                *ngIf=\"getItemIconType(option) === itemIconType.svg\"\r\n                class=\"mat-icon-rtl-mirror material-icons-outlined\"\r\n                type=\"image-square\"\r\n                [svgIcon]=\"option.itemIconSvg\"\r\n              >\r\n              </mat-icon>\r\n\r\n              <img \r\n                leading-icon\r\n                *ngIf=\"getItemIconType(option) === itemIconType.path\"\r\n                class=\"mat-icon\"\r\n                [src]=\"option.itemIconPath\"\r\n                type=\"image-square\"\r\n              />\r\n\r\n              <img \r\n                leading-icon\r\n                *ngIf=\"getItemIconType(option) === itemIconType.base64\"\r\n                class=\"mat-icon image-base64\"\r\n                [src]=\"getImagePath(option)\"\r\n                type=\"image-square\"\r\n              />\r\n              <div qms-list-header>\r\n                <div qms-line type=\"subtitle\" class=\"search__option-name\">\r\n                  {{ option.itemName }}\r\n                </div>\r\n              </div>\r\n            </qms-list-item>\r\n          </mat-option>\r\n        </div>\r\n      </cdk-virtual-scroll-viewport>\r\n    </mat-autocomplete>\r\n  \r\n    <div class=\"row\">\r\n        <div\r\n            class=\"qms-scrollbar qmslib_related_popup_content col-12\"\r\n            [ngClass]=\"{\r\n            panel__content_item: checkedNodeList.length,\r\n            panel__content: !checkedNodeList.length\r\n            }\">\r\n            <div id=\"qmslib_related_popup_common_002\">\r\n                <qms-tree\r\n                    [treeData]=\"treeData\"\r\n                    [treeConfig]=\"treeConfig\"\r\n                    [selectedData]=\"selectedData\"\r\n                    [selectedRiskData]=\"selectedRiskData\"\r\n                    [disabledList]=\"disabledList\"\r\n                    (checkBoxEvent)=\"getCommonCheckedNode($event)\"\r\n                    (nodeExpandEvent)=\"getChildrenOfFolder($event)\"\r\n                    (selectNodeEvent)=\"selectNodeTreeEvent($event)\"\r\n                ></qms-tree>\r\n            </div>\r\n    </div>\r\n  \r\n    <div *ngIf=\"checkedNodeList.length\" class=\"line__divider\"></div>\r\n  \r\n    <div *ngIf=\"checkedNodeList.length\" class=\"panel__item qms-scrollbar\">\r\n      <div class=\"related__item__inline\" *ngFor=\"let item of checkedNodeList\">\r\n        <button\r\n          *ngIf=\"item.itemName\"\r\n          mat-button\r\n          class=\"related__item__content\"\r\n          qms-tool-tip=\"{{\r\n            isEllipsisActive(itemName) ? getItemChipName(item) : ''\r\n          }}\"\r\n          mode=\"dark\"\r\n        >\r\n          <span class=\"related__item__content_name\" #itemName>\r\n            {{getItemChipName(item)}}\r\n            <span class=\"select__include-children__count\" *ngIf=\"item.noSelectedChildren > 0\">\r\n              {{getItemSelectedChildrenRatio(item)}}\r\n            </span>\r\n          </span>\r\n              \r\n          <mat-icon\r\n            (click)=\"removeCheckedNodeList(item)\"\r\n            >cancel</mat-icon\r\n          >\r\n        </button>\r\n      </div>\r\n    </div>\r\n  \r\n    <div class=\"line__divider\"></div>\r\n  \r\n    <div class=\"confirm__button__groups\">\r\n      <button\r\n        *ngIf=\"!checkedNodeList.length\"\r\n        qms-btn\r\n        style=\"margin-top: 7px\"\r\n        (click)=\"onAddClick()\"\r\n      >\r\n        {{ LANG.ADD }}\r\n      </button>\r\n      <button\r\n        *ngIf=\"checkedNodeList.length\"\r\n        qms-btn\r\n        style=\"margin-top: 0px\"\r\n        (click)=\"onAddClick()\"\r\n      >\r\n        {{ LANG.ADD }} ({{ checkedNodeList.length }})\r\n      </button>\r\n      <button\r\n        qms-btn-text\r\n        [ngStyle]=\"{ 'margin-top': checkedNodeList.length ? '0px' : '7px' }\"\r\n        (click)=\"onCloseClick()\"\r\n      >\r\n        {{ LANG.CANCEL }}\r\n      </button>\r\n    </div>\r\n</div>\r\n  "]}