qms-angular 1.0.61 → 1.0.62
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/bundles/qms-angular.umd.js +150 -46
- package/bundles/qms-angular.umd.js.map +1 -1
- package/esm2015/lib/components/breadcrumb/breadcrumb-item.directive.js +9 -1
- package/esm2015/lib/components/breadcrumb/breadcrumb.js +43 -29
- package/esm2015/lib/components/comment/comment.js +1 -5
- package/esm2015/lib/components/related/list-other-related/list-related.component.js +2 -2
- package/esm2015/lib/components/related/model/selected-node.model.js +1 -1
- package/esm2015/lib/components/related/popup/related-popup.component.js +78 -11
- package/esm2015/lib/components/tree/tree.component.js +18 -2
- package/fesm2015/qms-angular.js +144 -42
- package/fesm2015/qms-angular.js.map +1 -1
- package/lib/components/breadcrumb/breadcrumb-item.directive.d.ts +1 -0
- package/lib/components/breadcrumb/breadcrumb.d.ts +4 -1
- package/lib/components/related/model/selected-node.model.d.ts +3 -0
- package/lib/components/related/popup/related-popup.component.d.ts +15 -6
- package/lib/components/tree/tree.component.d.ts +2 -0
- package/package.json +1 -1
- package/qms-angular.metadata.json +1 -1
@@ -13,6 +13,14 @@ export class QMSBreadcrumbItemDirective {
|
|
13
13
|
}
|
14
14
|
}
|
15
15
|
}
|
16
|
+
ngOnChanges() {
|
17
|
+
if (this.isLastItem) {
|
18
|
+
this.ele.nativeElement.classList.add('qms-breadcrumb-last-item');
|
19
|
+
}
|
20
|
+
else {
|
21
|
+
this.ele.nativeElement.classList.remove('qms-breadcrumb-last-item');
|
22
|
+
}
|
23
|
+
}
|
16
24
|
ngOnInit() {
|
17
25
|
if (this.ele) {
|
18
26
|
this.ele.nativeElement.classList.add('qms-breadcrumb-item');
|
@@ -37,4 +45,4 @@ QMSBreadcrumbItemDirective.propDecorators = {
|
|
37
45
|
showTooltipChange: [{ type: Output }],
|
38
46
|
breadcrumbItemText: [{ type: ContentChild, args: ["breadcrumbItemText", { static: false },] }]
|
39
47
|
};
|
40
|
-
//# sourceMappingURL=data:application/json;base64,
|
48
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYnJlYWRjcnVtYi1pdGVtLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3Ftcy1hbmd1bGFyL3NyYy9saWIvY29tcG9uZW50cy9icmVhZGNydW1iL2JyZWFkY3J1bWItaXRlbS5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUFpQixZQUFZLEVBQUUsU0FBUyxFQUFFLFVBQVUsRUFBRSxZQUFZLEVBQWUsS0FBSyxFQUFVLE1BQU0sRUFBRSxTQUFTLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFNL0ksTUFBTSxPQUFPLDBCQUEwQjtJQUtuQyxZQUFtQixHQUFlLEVBQVUsUUFBbUI7UUFBNUMsUUFBRyxHQUFILEdBQUcsQ0FBWTtRQUFVLGFBQVEsR0FBUixRQUFRLENBQVc7UUFGckQsc0JBQWlCLEdBQUcsSUFBSSxZQUFZLEVBQUUsQ0FBQztJQUdqRCxDQUFDO0lBQ0QsZUFBZTtRQUNYLElBQUcsSUFBSSxDQUFDLGtCQUFrQixFQUFDO1lBQ3ZCLElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxhQUFhLENBQUMsU0FBUyxDQUFDLEdBQUcsQ0FBQywwQkFBMEIsQ0FBQyxDQUFBO1lBQy9FLElBQUcsSUFBSSxDQUFDLGtCQUFrQixDQUFDLGFBQWEsQ0FBQyxTQUFTLENBQUMsTUFBTSxHQUFHLEVBQUUsRUFBQztnQkFDM0QsSUFBSSxDQUFDLGlCQUFpQixDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQzthQUNyQztTQUNKO0lBQ0wsQ0FBQztJQUVELFdBQVc7UUFDUCxJQUFHLElBQUksQ0FBQyxVQUFVLEVBQUM7WUFDZixJQUFJLENBQUMsR0FBRyxDQUFDLGFBQWEsQ0FBQyxTQUFTLENBQUMsR0FBRyxDQUFDLDBCQUEwQixDQUFDLENBQUM7U0FDcEU7YUFDRztZQUNBLElBQUksQ0FBQyxHQUFHLENBQUMsYUFBYSxDQUFDLFNBQVMsQ0FBQyxNQUFNLENBQUMsMEJBQTBCLENBQUMsQ0FBQztTQUN2RTtJQUNMLENBQUM7SUFDRCxRQUFRO1FBQ0osSUFBSSxJQUFJLENBQUMsR0FBRyxFQUFFO1lBQ1YsSUFBSSxDQUFDLEdBQUcsQ0FBQyxhQUFhLENBQUMsU0FBUyxDQUFDLEdBQUcsQ0FBQyxxQkFBcUIsQ0FBQyxDQUFDO1lBQzVELElBQUcsSUFBSSxDQUFDLFVBQVUsRUFBQztnQkFDZixJQUFJLENBQUMsR0FBRyxDQUFDLGFBQWEsQ0FBQyxTQUFTLENBQUMsR0FBRyxDQUFDLDBCQUEwQixDQUFDLENBQUE7YUFDbkU7U0FDSjtJQUNMLENBQUM7OztZQWxDSixTQUFTLFNBQUM7Z0JBQ1AsUUFBUSxFQUFFLHVCQUF1QjthQUNwQzs7O1lBTGdELFVBQVU7WUFBb0QsU0FBUzs7O3lCQU9uSCxLQUFLOzBCQUNMLEtBQUs7Z0NBQ0wsTUFBTTtpQ0FDTixZQUFZLFNBQUMsb0JBQW9CLEVBQUUsRUFBQyxNQUFNLEVBQUUsS0FBSyxFQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgT3ZlcmxheSwgT3ZlcmxheVBvc2l0aW9uQnVpbGRlciB9IGZyb20gJ0Bhbmd1bGFyL2Nkay9vdmVybGF5JztcclxuaW1wb3J0IHsgQWZ0ZXJWaWV3SW5pdCwgQ29udGVudENoaWxkLCBEaXJlY3RpdmUsIEVsZW1lbnRSZWYsIEV2ZW50RW1pdHRlciwgSG9zdEJpbmRpbmcsIElucHV0LCBPbkluaXQsIE91dHB1dCwgUmVuZGVyZXIyfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgUU1TVG9vbFRpcFJlbmRlcmVyRGlyZWN0aXZlIH0gZnJvbSAnLi4vLi4vZGlyZWN0aXZlcy90b29sdGlwL3Rvb2x0aXAtcmVuZGVyZXIuZGlyZWN0aXZlJztcclxuXHJcbkBEaXJlY3RpdmUoe1xyXG4gICAgc2VsZWN0b3I6ICdbcW1zLWJyZWFkY3J1bWItaXRlbV0nLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgUU1TQnJlYWRjcnVtYkl0ZW1EaXJlY3RpdmUgaW1wbGVtZW50cyBPbkluaXQsIEFmdGVyVmlld0luaXQge1xyXG4gICAgQElucHV0KCkgaXNMYXN0SXRlbTogYm9vbGVhbjtcclxuICAgIEBJbnB1dCgpIHNob3dUb29sdGlwOiBib29sZWFuO1xyXG4gICAgQE91dHB1dCgpIHNob3dUb29sdGlwQ2hhbmdlID0gbmV3IEV2ZW50RW1pdHRlcigpO1xyXG4gICAgQENvbnRlbnRDaGlsZChcImJyZWFkY3J1bWJJdGVtVGV4dFwiLCB7c3RhdGljOiBmYWxzZX0pIGJyZWFkY3J1bWJJdGVtVGV4dDogRWxlbWVudFJlZjtcclxuICAgIGNvbnN0cnVjdG9yKHB1YmxpYyBlbGU6IEVsZW1lbnRSZWYsIHByaXZhdGUgcmVuZGVyZXI6IFJlbmRlcmVyMikge1xyXG4gICAgfVxyXG4gICAgbmdBZnRlclZpZXdJbml0KCk6IHZvaWQge1xyXG4gICAgICAgIGlmKHRoaXMuYnJlYWRjcnVtYkl0ZW1UZXh0KXtcclxuICAgICAgICAgICAgdGhpcy5icmVhZGNydW1iSXRlbVRleHQubmF0aXZlRWxlbWVudC5jbGFzc0xpc3QuYWRkKCdxbXMtYnJlYWRjcnVtYi1pdGVtLXRleHQnKVxyXG4gICAgICAgICAgICBpZih0aGlzLmJyZWFkY3J1bWJJdGVtVGV4dC5uYXRpdmVFbGVtZW50LmlubmVyVGV4dC5sZW5ndGggPiAzMCl7XHJcbiAgICAgICAgICAgICAgICB0aGlzLnNob3dUb29sdGlwQ2hhbmdlLmVtaXQodHJ1ZSk7XHJcbiAgICAgICAgICAgIH1cclxuICAgICAgICB9XHJcbiAgICB9XHJcblxyXG4gICAgbmdPbkNoYW5nZXMoKXtcclxuICAgICAgICBpZih0aGlzLmlzTGFzdEl0ZW0pe1xyXG4gICAgICAgICAgICB0aGlzLmVsZS5uYXRpdmVFbGVtZW50LmNsYXNzTGlzdC5hZGQoJ3Ftcy1icmVhZGNydW1iLWxhc3QtaXRlbScpO1xyXG4gICAgICAgIH1cclxuICAgICAgICBlbHNle1xyXG4gICAgICAgICAgICB0aGlzLmVsZS5uYXRpdmVFbGVtZW50LmNsYXNzTGlzdC5yZW1vdmUoJ3Ftcy1icmVhZGNydW1iLWxhc3QtaXRlbScpO1xyXG4gICAgICAgIH1cclxuICAgIH1cclxuICAgIG5nT25Jbml0KCk6IHZvaWQge1xyXG4gICAgICAgIGlmICh0aGlzLmVsZSkge1xyXG4gICAgICAgICAgICB0aGlzLmVsZS5uYXRpdmVFbGVtZW50LmNsYXNzTGlzdC5hZGQoJ3Ftcy1icmVhZGNydW1iLWl0ZW0nKTtcclxuICAgICAgICAgICAgaWYodGhpcy5pc0xhc3RJdGVtKXtcclxuICAgICAgICAgICAgICAgIHRoaXMuZWxlLm5hdGl2ZUVsZW1lbnQuY2xhc3NMaXN0LmFkZCgncW1zLWJyZWFkY3J1bWItbGFzdC1pdGVtJylcclxuICAgICAgICAgICAgfVxyXG4gICAgICAgIH1cclxuICAgIH1cclxufSJdfQ==
|
@@ -22,34 +22,7 @@ export class QMSBreadcrumb {
|
|
22
22
|
iconRegistry.addSvgIconLiteral('breadcrumb_dropdown', sanitizer.bypassSecurityTrustHtml(BREADCRUMB_DROPDOWN_ICON));
|
23
23
|
}
|
24
24
|
ngAfterViewInit() {
|
25
|
-
|
26
|
-
if (!this.maxLine || this.maxLine < 2) {
|
27
|
-
this.checkOverflow(this.ele.nativeElement.offsetWidth);
|
28
|
-
}
|
29
|
-
else {
|
30
|
-
this.checkOverflow(this.ele.nativeElement.offsetWidth * 1.7);
|
31
|
-
}
|
32
|
-
}
|
33
|
-
//show number Items after 3 dot icon
|
34
|
-
if (+this.numDisplayItem > 0 && this.itemNodes.length >= 2) {
|
35
|
-
this.dropdownNodes = [];
|
36
|
-
this.dropdownNodes = this.itemNodes.slice(0, -this.numDisplayItem).reverse();
|
37
|
-
this.itemNodes = [...[], ...this.itemNodes.slice(-this.numDisplayItem)];
|
38
|
-
this.isOverflow = true;
|
39
|
-
this.cdRef.detectChanges();
|
40
|
-
}
|
41
|
-
//just show 1 item for mobile
|
42
|
-
if (this.onlyItem) {
|
43
|
-
this.isOverflow = true;
|
44
|
-
this.dropdownNodes = [];
|
45
|
-
let itemNodes = [...this.itemNodes];
|
46
|
-
let lastItem = itemNodes.pop();
|
47
|
-
this.dropdownNodes = [...itemNodes].reverse();
|
48
|
-
this.dropdownNodes.push(this.homeNode);
|
49
|
-
this.itemNodes = [];
|
50
|
-
this.itemNodes = [lastItem];
|
51
|
-
this.cdRef.detectChanges();
|
52
|
-
}
|
25
|
+
this.buildBreadcrumb();
|
53
26
|
}
|
54
27
|
checkOverflow(width) {
|
55
28
|
const nodeWidths = this.breadCrumbNodes.map(x => x.ele.nativeElement.offsetWidth);
|
@@ -83,8 +56,18 @@ export class QMSBreadcrumb {
|
|
83
56
|
this.dropdownNodes = this.dropdownNodes.reverse();
|
84
57
|
}
|
85
58
|
}
|
59
|
+
ngOnChanges(changes) {
|
60
|
+
if (changes.nodes && this.breadCrumbNodes && JSON.stringify(changes.nodes.currentValue) !== JSON.stringify(changes.nodes.previousValue)) {
|
61
|
+
this.nodes = [...changes.nodes.currentValue];
|
62
|
+
this.initBreadCrumb();
|
63
|
+
this.buildBreadcrumb();
|
64
|
+
}
|
65
|
+
}
|
86
66
|
ngOnInit() {
|
87
67
|
this.itemIconType = ItemIconType;
|
68
|
+
this.initBreadCrumb();
|
69
|
+
}
|
70
|
+
initBreadCrumb() {
|
88
71
|
if (this.nodes && this.nodes.length > 0) {
|
89
72
|
this.nodes.forEach(ele => {
|
90
73
|
ele.isOverflow = ele.isOverflow ? ele.isOverflow : false;
|
@@ -108,6 +91,37 @@ export class QMSBreadcrumb {
|
|
108
91
|
this.ele.nativeElement.classList.add('qms-breadcrumb__multi-line');
|
109
92
|
}
|
110
93
|
}
|
94
|
+
buildBreadcrumb() {
|
95
|
+
if (!this.isMobileType && this.ele.nativeElement.offsetWidth) {
|
96
|
+
this.dropdownNodes = [];
|
97
|
+
if (!this.maxLine || this.maxLine < 2) {
|
98
|
+
this.checkOverflow(this.ele.nativeElement.offsetWidth);
|
99
|
+
}
|
100
|
+
else {
|
101
|
+
this.checkOverflow(this.ele.nativeElement.offsetWidth * 1.7);
|
102
|
+
}
|
103
|
+
}
|
104
|
+
//show number Items after 3 dot icon
|
105
|
+
if (+this.numDisplayItem > 0 && this.itemNodes.length >= 2) {
|
106
|
+
this.dropdownNodes = [];
|
107
|
+
this.dropdownNodes = this.itemNodes.slice(0, -this.numDisplayItem).reverse();
|
108
|
+
this.itemNodes = [...[], ...this.itemNodes.slice(-this.numDisplayItem)];
|
109
|
+
this.isOverflow = true;
|
110
|
+
this.cdRef.detectChanges();
|
111
|
+
}
|
112
|
+
//just show 1 item for mobile
|
113
|
+
if (this.onlyItem) {
|
114
|
+
this.isOverflow = true;
|
115
|
+
this.dropdownNodes = [];
|
116
|
+
let itemNodes = [...this.itemNodes];
|
117
|
+
let lastItem = itemNodes.pop();
|
118
|
+
this.dropdownNodes = [...itemNodes].reverse();
|
119
|
+
this.dropdownNodes.push(this.homeNode);
|
120
|
+
this.itemNodes = [];
|
121
|
+
this.itemNodes = [lastItem];
|
122
|
+
this.cdRef.detectChanges();
|
123
|
+
}
|
124
|
+
}
|
111
125
|
getItemIconType(treeConfig) {
|
112
126
|
if (treeConfig.itemIcon)
|
113
127
|
return ItemIconType.name;
|
@@ -157,4 +171,4 @@ QMSBreadcrumb.propDecorators = {
|
|
157
171
|
onItemClick: [{ type: Output }],
|
158
172
|
breadCrumbNodes: [{ type: ViewChildren, args: [QMSBreadcrumbItemDirective, {},] }]
|
159
173
|
};
|
160
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"breadcrumb.js","sourceRoot":"","sources":["../../../../../../projects/qms-angular/src/lib/components/breadcrumb/breadcrumb.ts"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewChecked, AfterViewInit, ChangeDetectorRef, Component, ElementRef, EventEmitter, Input, OnInit, Output, QueryList, ViewChildren, ViewEncapsulation } from \"@angular/core\";\r\nimport { MatIconRegistry } from \"@angular/material/icon\";\r\nimport { DomSanitizer } from \"@angular/platform-browser\";\r\nimport { BREADCRUMB_DROPDOWN_ICON } from \"../../common/qms-icon.const\";\r\nimport { ItemIconType } from \"../related/common/item-icon-type.enum\";\r\nimport { QMSBreadcrumbItemDirective } from \"./breadcrumb-item.directive\";\r\nimport { DropdownBreadCrumbNodeWidth } from \"./enum/dropdown-node-width.enum\";\r\nimport { BreadcrumbNode } from \"./model/breadcrumb-node.model\";\r\n\r\n@Component({\r\n  selector: 'qms-breadcrumb',\r\n  templateUrl: 'breadcrumb.html',\r\n  styleUrls: ['breadcrumb.scss'],\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\n\r\n\r\nexport class QMSBreadcrumb implements OnInit, AfterViewInit {\r\n  @Input() nodes: BreadcrumbNode[];\r\n  @Input() type: string;\r\n  @Input() maxLine: number;\r\n  @Input() numDisplayItem: number = 0;\r\n  @Input() onlyItem: boolean = false;\r\n  @Input() disabledLastItem: boolean = true;\r\n  @Output() onItemClick: EventEmitter<any> = new EventEmitter<any>();\r\n  @ViewChildren(QMSBreadcrumbItemDirective, {}) breadCrumbNodes: QueryList<QMSBreadcrumbItemDirective>;\r\n\r\n  dropdownNodes: BreadcrumbNode[] = [];\r\n  isOverflow = false;\r\n  homeNode: BreadcrumbNode;\r\n  previousNode: BreadcrumbNode;\r\n  itemNodes: BreadcrumbNode[];\r\n  itemSpace: number = DropdownBreadCrumbNodeWidth.NORMAL; // width of dropdown node in normal view\r\n  itemIconType;\r\n  isMobileType: boolean = false;\r\n\r\n  constructor(private ele: ElementRef,\r\n    private iconRegistry: MatIconRegistry,\r\n    private cdRef: ChangeDetectorRef,\r\n    private sanitizer: DomSanitizer) {\r\n    iconRegistry.addSvgIconLiteral('breadcrumb_dropdown', sanitizer.bypassSecurityTrustHtml(BREADCRUMB_DROPDOWN_ICON));\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    if (!this.isMobileType && this.ele.nativeElement.offsetWidth) {\r\n      if (!this.maxLine || this.maxLine < 2) {\r\n        this.checkOverflow(this.ele.nativeElement.offsetWidth);\r\n      }\r\n      else {\r\n        this.checkOverflow(this.ele.nativeElement.offsetWidth * 1.7);\r\n      }\r\n    }\r\n\r\n    //show number Items after 3 dot icon\r\n    if (+this.numDisplayItem > 0 && this.itemNodes.length >= 2) {\r\n      this.dropdownNodes = [];\r\n      this.dropdownNodes = this.itemNodes.slice(0, -this.numDisplayItem).reverse();\r\n      this.itemNodes = [...[], ...this.itemNodes.slice(-this.numDisplayItem)];\r\n      this.isOverflow = true;\r\n      this.cdRef.detectChanges();\r\n    }\r\n    //just show 1 item for mobile\r\n    if (this.onlyItem) {\r\n      this.isOverflow = true;\r\n      this.dropdownNodes = [];\r\n      let itemNodes = [...this.itemNodes];\r\n      let lastItem = itemNodes.pop();\r\n      this.dropdownNodes = [...itemNodes].reverse();\r\n      this.dropdownNodes.push(this.homeNode);\r\n      this.itemNodes = [];\r\n      this.itemNodes = [lastItem];\r\n      this.cdRef.detectChanges();\r\n    }\r\n\r\n  }\r\n\r\n  checkOverflow(width: number) {\r\n    const nodeWidths = this.breadCrumbNodes.map(x => x.ele.nativeElement.offsetWidth);\r\n    let currentWidth = 0;\r\n    nodeWidths.forEach(width => {\r\n      currentWidth += width;\r\n    });\r\n    this.isOverflow = width < currentWidth;\r\n    this.cdRef.detectChanges();\r\n\r\n    if (this.isOverflow) {\r\n      let screenWidth = width;\r\n      if (this.type !== 'table') {\r\n        this.dropdownNodes.push(this.homeNode);\r\n        currentWidth -= nodeWidths[0];\r\n        currentWidth += this.itemSpace;\r\n        screenWidth -= this.itemSpace;\r\n      }\r\n      else {\r\n        currentWidth += this.itemSpace;\r\n        screenWidth -= nodeWidths[0];\r\n        screenWidth -= this.itemSpace;\r\n      }\r\n      nodeWidths.shift();\r\n      nodeWidths.forEach((eleWidth, index) => {\r\n        if (currentWidth > screenWidth) {\r\n          this.itemNodes[index].isShow = false;\r\n          this.dropdownNodes.push(this.itemNodes[index]);\r\n          currentWidth -= (eleWidth);\r\n        }\r\n      });\r\n      this.dropdownNodes = this.dropdownNodes.reverse();\r\n    }\r\n\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.itemIconType = ItemIconType;\r\n    if (this.nodes && this.nodes.length > 0) {\r\n      this.nodes.forEach(ele => {\r\n        ele.isOverflow = ele.isOverflow ? ele.isOverflow : false;\r\n        ele.isShow = true;\r\n        ele.displayType = this.getItemIconType(ele);\r\n      });\r\n      if (this.type !== 'mobile') {\r\n        this.homeNode = this.nodes[0];\r\n        this.itemNodes = this.nodes.slice(1);\r\n      }\r\n      else {\r\n        this.isMobileType = true;\r\n        this.previousNode = this.nodes[this.nodes.length >= 2 ? this.nodes.length - 2 : 0];\r\n      }\r\n    }\r\n\r\n    if (this.type === 'table') {\r\n      this.ele.nativeElement.classList.add('qms-breadcrumb-table');\r\n      this.itemSpace = DropdownBreadCrumbNodeWidth.TABLE;  // width of dropdown node in table view\r\n    }\r\n    if (this.maxLine && this.maxLine > 1) {\r\n      this.ele.nativeElement.classList.add('qms-breadcrumb__multi-line');\r\n    }\r\n  }\r\n\r\n  getItemIconType(treeConfig: BreadcrumbNode) {\r\n    if (treeConfig.itemIcon) return ItemIconType.name;\r\n    if (treeConfig.itemIconPath) return ItemIconType.path;\r\n    if (treeConfig.itemIconBase64) return ItemIconType.base64;\r\n    if (treeConfig.itemIconSvg) return ItemIconType.svg;\r\n    return ItemIconType.none;\r\n  }\r\n\r\n  getImagePath(node: BreadcrumbNode) {\r\n    return this.sanitizer.bypassSecurityTrustResourceUrl(node.itemIconBase64) as string;\r\n  }\r\n\r\n  onKeyPressed(event) {\r\n    [...event.target.children].forEach(x => x.click());\r\n  }\r\n\r\n  onItemSelect(item: BreadcrumbNode, isLastItem?: boolean) {\r\n    if (isLastItem && this.disabledLastItem) return;\r\n    if (this.onItemClick) {\r\n      this.onItemClick.emit(item);\r\n    }\r\n  }\r\n}\r\n"]}
|
174
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"breadcrumb.js","sourceRoot":"","sources":["../../../../../../projects/qms-angular/src/lib/components/breadcrumb/breadcrumb.ts"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewChecked, AfterViewInit, ChangeDetectorRef, Component, ElementRef, EventEmitter, Input, OnInit, Output, QueryList, SimpleChanges, ViewChildren, ViewEncapsulation } from \"@angular/core\";\r\nimport { MatIconRegistry } from \"@angular/material/icon\";\r\nimport { DomSanitizer } from \"@angular/platform-browser\";\r\nimport { BREADCRUMB_DROPDOWN_ICON } from \"../../common/qms-icon.const\";\r\nimport { ItemIconType } from \"../related/common/item-icon-type.enum\";\r\nimport { QMSBreadcrumbItemDirective } from \"./breadcrumb-item.directive\";\r\nimport { DropdownBreadCrumbNodeWidth } from \"./enum/dropdown-node-width.enum\";\r\nimport { BreadcrumbNode } from \"./model/breadcrumb-node.model\";\r\n\r\n@Component({\r\n  selector: 'qms-breadcrumb',\r\n  templateUrl: 'breadcrumb.html',\r\n  styleUrls: ['breadcrumb.scss'],\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\n\r\n\r\nexport class QMSBreadcrumb implements OnInit, AfterViewInit {\r\n  @Input() nodes: BreadcrumbNode[];\r\n  @Input() type: string;\r\n  @Input() maxLine: number;\r\n  @Input() numDisplayItem: number = 0;\r\n  @Input() onlyItem: boolean = false;\r\n  @Input() disabledLastItem: boolean = true;\r\n  @Output() onItemClick: EventEmitter<any> = new EventEmitter<any>();\r\n  @ViewChildren(QMSBreadcrumbItemDirective, {}) breadCrumbNodes: QueryList<QMSBreadcrumbItemDirective>;\r\n\r\n  dropdownNodes: BreadcrumbNode[] = [];\r\n  isOverflow = false;\r\n  homeNode: BreadcrumbNode;\r\n  previousNode: BreadcrumbNode;\r\n  itemNodes: BreadcrumbNode[];\r\n  itemSpace: number = DropdownBreadCrumbNodeWidth.NORMAL; // width of dropdown node in normal view\r\n  itemIconType;\r\n  isMobileType: boolean = false;\r\n\r\n  constructor(private ele: ElementRef,\r\n    private iconRegistry: MatIconRegistry,\r\n    private cdRef: ChangeDetectorRef,\r\n    private sanitizer: DomSanitizer) {\r\n    iconRegistry.addSvgIconLiteral('breadcrumb_dropdown', sanitizer.bypassSecurityTrustHtml(BREADCRUMB_DROPDOWN_ICON));\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    this.buildBreadcrumb();\r\n  }\r\n\r\n  checkOverflow(width: number) {\r\n    const nodeWidths = this.breadCrumbNodes.map(x => x.ele.nativeElement.offsetWidth);\r\n    let currentWidth = 0;\r\n    nodeWidths.forEach(width => {\r\n      currentWidth += width;\r\n    });\r\n    this.isOverflow = width < currentWidth;\r\n    this.cdRef.detectChanges();\r\n\r\n    if (this.isOverflow) {\r\n      let screenWidth = width;\r\n      if (this.type !== 'table') {\r\n        this.dropdownNodes.push(this.homeNode);\r\n        currentWidth -= nodeWidths[0];\r\n        currentWidth += this.itemSpace;\r\n        screenWidth -= this.itemSpace;\r\n      }\r\n      else {\r\n        currentWidth += this.itemSpace;\r\n        screenWidth -= nodeWidths[0];\r\n        screenWidth -= this.itemSpace;\r\n      }\r\n      nodeWidths.shift();\r\n      nodeWidths.forEach((eleWidth, index) => {\r\n        if (currentWidth > screenWidth) {\r\n          this.itemNodes[index].isShow = false;\r\n          this.dropdownNodes.push(this.itemNodes[index]);\r\n          currentWidth -= (eleWidth);\r\n        }\r\n      });\r\n      this.dropdownNodes = this.dropdownNodes.reverse();\r\n    }\r\n\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if (changes.nodes && this.breadCrumbNodes && JSON.stringify(changes.nodes.currentValue) !== JSON.stringify(changes.nodes.previousValue)) {\r\n      this.nodes = [...changes.nodes.currentValue];\r\n      this.initBreadCrumb();\r\n      this.buildBreadcrumb();\r\n    }\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.itemIconType = ItemIconType;\r\n    this.initBreadCrumb();\r\n  }\r\n\r\n  initBreadCrumb(){\r\n    if (this.nodes && this.nodes.length > 0) {\r\n      this.nodes.forEach(ele => {\r\n        ele.isOverflow = ele.isOverflow ? ele.isOverflow : false;\r\n        ele.isShow = true;\r\n        ele.displayType = this.getItemIconType(ele);\r\n      });\r\n      if (this.type !== 'mobile') {\r\n        this.homeNode = this.nodes[0];\r\n        this.itemNodes = this.nodes.slice(1);\r\n      }\r\n      else {\r\n        this.isMobileType = true;\r\n        this.previousNode = this.nodes[this.nodes.length >= 2 ? this.nodes.length - 2 : 0];\r\n      }\r\n    }\r\n\r\n    if (this.type === 'table') {\r\n      this.ele.nativeElement.classList.add('qms-breadcrumb-table');\r\n      this.itemSpace = DropdownBreadCrumbNodeWidth.TABLE;  // width of dropdown node in table view\r\n    }\r\n    if (this.maxLine && this.maxLine > 1) {\r\n      this.ele.nativeElement.classList.add('qms-breadcrumb__multi-line');\r\n    }\r\n  }\r\n\r\n  buildBreadcrumb(){\r\n    if (!this.isMobileType && this.ele.nativeElement.offsetWidth) {\r\n      this.dropdownNodes = [];\r\n      if (!this.maxLine || this.maxLine < 2) {\r\n        this.checkOverflow(this.ele.nativeElement.offsetWidth);\r\n      }\r\n      else {\r\n        this.checkOverflow(this.ele.nativeElement.offsetWidth * 1.7);\r\n      }\r\n    }\r\n\r\n    //show number Items after 3 dot icon\r\n    if (+this.numDisplayItem > 0 && this.itemNodes.length >= 2) {\r\n      this.dropdownNodes = [];\r\n      this.dropdownNodes = this.itemNodes.slice(0, -this.numDisplayItem).reverse();\r\n      this.itemNodes = [...[], ...this.itemNodes.slice(-this.numDisplayItem)];\r\n      this.isOverflow = true;\r\n      this.cdRef.detectChanges();\r\n    }\r\n    //just show 1 item for mobile\r\n    if (this.onlyItem) {\r\n      this.isOverflow = true;\r\n      this.dropdownNodes = [];\r\n      let itemNodes = [...this.itemNodes];\r\n      let lastItem = itemNodes.pop();\r\n      this.dropdownNodes = [...itemNodes].reverse();\r\n      this.dropdownNodes.push(this.homeNode);\r\n      this.itemNodes = [];\r\n      this.itemNodes = [lastItem];\r\n      this.cdRef.detectChanges();\r\n    }\r\n  }\r\n\r\n  getItemIconType(treeConfig: BreadcrumbNode) {\r\n    if (treeConfig.itemIcon) return ItemIconType.name;\r\n    if (treeConfig.itemIconPath) return ItemIconType.path;\r\n    if (treeConfig.itemIconBase64) return ItemIconType.base64;\r\n    if (treeConfig.itemIconSvg) return ItemIconType.svg;\r\n    return ItemIconType.none;\r\n  }\r\n\r\n  getImagePath(node: BreadcrumbNode) {\r\n    return this.sanitizer.bypassSecurityTrustResourceUrl(node.itemIconBase64) as string;\r\n  }\r\n\r\n  onKeyPressed(event) {\r\n    [...event.target.children].forEach(x => x.click());\r\n  }\r\n\r\n  onItemSelect(item: BreadcrumbNode, isLastItem?: boolean) {\r\n    if (isLastItem && this.disabledLastItem) return;\r\n    if (this.onItemClick) {\r\n      this.onItemClick.emit(item);\r\n    }\r\n  }\r\n}\r\n"]}
|
@@ -11,21 +11,17 @@ export class QMSComment {
|
|
11
11
|
const changedProp = changes[propName];
|
12
12
|
const to = JSON.stringify(changedProp.currentValue);
|
13
13
|
if (changedProp.isFirstChange()) {
|
14
|
-
console.log('Initial value of');
|
15
14
|
}
|
16
15
|
else {
|
17
16
|
const from = JSON.stringify(changedProp.previousValue);
|
18
|
-
console.log('changed from');
|
19
17
|
}
|
20
18
|
}
|
21
|
-
console.log('value changed', changes.sourceLog.currentValue);
|
22
19
|
// this.sourceLog = changes.sourceLog.currentValue;
|
23
20
|
}
|
24
21
|
ngOnInit() {
|
25
22
|
this.trans.getLanguageSubject$.pipe().subscribe((res) => {
|
26
23
|
if (res) {
|
27
24
|
this.LANG = this.trans.getObjectLang(res);
|
28
|
-
console.log(this.LANG);
|
29
25
|
}
|
30
26
|
});
|
31
27
|
}
|
@@ -62,4 +58,4 @@ QMSComment.propDecorators = {
|
|
62
58
|
sourceLog: [{ type: Input }],
|
63
59
|
updateLog: [{ type: Output }]
|
64
60
|
};
|
65
|
-
//# sourceMappingURL=data:application/json;base64,
|
61
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tbWVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3Ftcy1hbmd1bGFyL3NyYy9saWIvY29tcG9uZW50cy9jb21tZW50L2NvbW1lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsb0NBQW9DO0FBQ3BDLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQUUsWUFBWSxFQUFFLEtBQUssRUFBcUIsTUFBTSxFQUFvQyxNQUFNLGVBQWUsQ0FBQztBQUNySixPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSw2Q0FBNkMsQ0FBQztBQW1CdEYsTUFBTSxPQUFPLFVBQVU7SUFNbkIsWUFBbUIsS0FBOEI7UUFBOUIsVUFBSyxHQUFMLEtBQUssQ0FBeUI7UUFKdkMsY0FBUyxHQUFHLElBQUksWUFBWSxFQUFFLENBQUM7SUFJWSxDQUFDO0lBRXRELFdBQVcsQ0FBQyxPQUFzQjtRQUM5QixLQUFLLE1BQU0sUUFBUSxJQUFJLE9BQU8sRUFBRTtZQUM1QixNQUFNLFdBQVcsR0FBRyxPQUFPLENBQUMsUUFBUSxDQUFDLENBQUM7WUFDdEMsTUFBTSxFQUFFLEdBQUcsSUFBSSxDQUFDLFNBQVMsQ0FBQyxXQUFXLENBQUMsWUFBWSxDQUFDLENBQUM7WUFDcEQsSUFBSSxXQUFXLENBQUMsYUFBYSxFQUFFLEVBQUU7YUFDaEM7aUJBQU07Z0JBQ0gsTUFBTSxJQUFJLEdBQUcsSUFBSSxDQUFDLFNBQVMsQ0FBQyxXQUFXLENBQUMsYUFBYSxDQUFDLENBQUM7YUFDMUQ7U0FDSjtRQUNELG1EQUFtRDtJQUN2RCxDQUFDO0lBRUQsUUFBUTtRQUNKLElBQUksQ0FBQyxLQUFLLENBQUMsbUJBQW1CLENBQUMsSUFBSSxFQUFFLENBQUMsU0FBUyxDQUFDLENBQUMsR0FBRyxFQUFFLEVBQUU7WUFDcEQsSUFBSSxHQUFHLEVBQUU7Z0JBQ0wsSUFBSSxDQUFDLElBQUksR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLGFBQWEsQ0FBQyxHQUFHLENBQUMsQ0FBQzthQUM3QztRQUNMLENBQUMsQ0FBQyxDQUFDO0lBQ1AsQ0FBQztJQUVELFdBQVcsQ0FBQyxPQUFPO1FBQ2YsT0FBTyxPQUFPLENBQUMsT0FBTyxDQUFDLGlCQUFpQixFQUFFLE1BQU0sQ0FBQyxDQUFDO0lBQ3RELENBQUM7SUFFRCxXQUFXLENBQUMsSUFBSTtRQUNaLElBQUksQ0FBQyxhQUFhLEdBQUcsSUFBSSxDQUFDLE9BQU8sQ0FBQztRQUNsQyxJQUFJLENBQUMsTUFBTSxHQUFHLElBQUksQ0FBQztJQUN2QixDQUFDO0lBRUQsaUJBQWlCLENBQUMsSUFBSTtRQUNsQixJQUFJLENBQUMsT0FBTyxHQUFHLElBQUksQ0FBQyxhQUFhLENBQUM7UUFDbEMsSUFBSSxDQUFDLE1BQU0sR0FBRyxLQUFLLENBQUM7UUFDcEIsSUFBSSxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDOUIsQ0FBQztJQUVELFVBQVUsQ0FBQyxJQUFJO1FBQ1gsSUFBSSxDQUFDLFFBQVEsR0FBRyxJQUFJLENBQUM7UUFDckIsSUFBSSxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDOUIsQ0FBQzs7O1lBckRKLFNBQVMsU0FBQztnQkFDUCxRQUFRLEVBQUUsYUFBYTtnQkFDdkIsOHZEQUEyQjtnQkFFM0IsSUFBSSxFQUFFLEVBQUUsT0FBTyxFQUFFLGFBQWEsRUFBRTtnQkFDaEMsZUFBZSxFQUFFLHVCQUF1QixDQUFDLE1BQU07O2FBQ2xEOzs7WUFsQlEsdUJBQXVCOzs7d0JBb0IzQixLQUFLO3dCQUNMLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyIvLyBJbXBvcnQgdGhlIGNvcmUgYW5ndWxhciBzZXJ2aWNlcy5cclxuaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgRXZlbnRFbWl0dGVyLCBJbnB1dCwgT25DaGFuZ2VzLCBPbkluaXQsIE91dHB1dCwgU2ltcGxlQ2hhbmdlcywgVmlld0VuY2Fwc3VsYXRpb24gfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xyXG5pbXBvcnQgeyBUcmFuc2xhdGVMaWJyYXJ5U2VydmljZSB9IGZyb20gXCIuLi8uLi9zZXJ2aWNlcy90cmFuc2xhdGlvbi1yZWdpc3RyeS5zZXJ2aWNlXCI7XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIExvZ3Mge1xyXG4gICAgdXNlcjogc3RyaW5nLFxyXG4gICAgZGF0ZTogYW55LFxyXG4gICAgaXNEcmFmdDogYm9vbGVhbixcclxuICAgIGlzRWRpdDogYm9vbGVhbixcclxuICAgIGNvbnRlbnQ6IHN0cmluZyxcclxuICAgIGVkaXRlZENvbnRlbnQ6IHN0cmluZ1xyXG59XHJcblxyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgICBzZWxlY3RvcjogJ3Ftcy1jb21tZW50JyxcclxuICAgIHRlbXBsYXRlVXJsOiAnY29tbWVudC5odG1sJyxcclxuICAgIHN0eWxlVXJsczogWydjb21tZW50LnNjc3MnXSxcclxuICAgIGhvc3Q6IHsgJ2NsYXNzJzogJ3Ftcy1jb21tZW50JyB9LFxyXG4gICAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBRTVNDb21tZW50IGltcGxlbWVudHMgT25Jbml0LCBPbkNoYW5nZXMge1xyXG4gICAgQElucHV0KCkgc291cmNlTG9nOiBMb2dzW107XHJcbiAgICBAT3V0cHV0KCkgdXBkYXRlTG9nID0gbmV3IEV2ZW50RW1pdHRlcigpO1xyXG5cclxuICAgIExBTkc6IGFueTtcclxuXHJcbiAgICBjb25zdHJ1Y3RvcihwdWJsaWMgdHJhbnM6IFRyYW5zbGF0ZUxpYnJhcnlTZXJ2aWNlKSB7IH1cclxuXHJcbiAgICBuZ09uQ2hhbmdlcyhjaGFuZ2VzOiBTaW1wbGVDaGFuZ2VzKSB7XHJcbiAgICAgICAgZm9yIChjb25zdCBwcm9wTmFtZSBpbiBjaGFuZ2VzKSB7XHJcbiAgICAgICAgICAgIGNvbnN0IGNoYW5nZWRQcm9wID0gY2hhbmdlc1twcm9wTmFtZV07XHJcbiAgICAgICAgICAgIGNvbnN0IHRvID0gSlNPTi5zdHJpbmdpZnkoY2hhbmdlZFByb3AuY3VycmVudFZhbHVlKTtcclxuICAgICAgICAgICAgaWYgKGNoYW5nZWRQcm9wLmlzRmlyc3RDaGFuZ2UoKSkge1xyXG4gICAgICAgICAgICB9IGVsc2Uge1xyXG4gICAgICAgICAgICAgICAgY29uc3QgZnJvbSA9IEpTT04uc3RyaW5naWZ5KGNoYW5nZWRQcm9wLnByZXZpb3VzVmFsdWUpO1xyXG4gICAgICAgICAgICB9XHJcbiAgICAgICAgfVxyXG4gICAgICAgIC8vIHRoaXMuc291cmNlTG9nID0gY2hhbmdlcy5zb3VyY2VMb2cuY3VycmVudFZhbHVlO1xyXG4gICAgfVxyXG5cclxuICAgIG5nT25Jbml0KCkge1xyXG4gICAgICAgIHRoaXMudHJhbnMuZ2V0TGFuZ3VhZ2VTdWJqZWN0JC5waXBlKCkuc3Vic2NyaWJlKChyZXMpID0+IHtcclxuICAgICAgICAgICAgaWYgKHJlcykge1xyXG4gICAgICAgICAgICAgICAgdGhpcy5MQU5HID0gdGhpcy50cmFucy5nZXRPYmplY3RMYW5nKHJlcyk7XHJcbiAgICAgICAgICAgIH1cclxuICAgICAgICB9KTtcclxuICAgIH1cclxuXHJcbiAgICBzaG93Q29udGVudChjb250ZW50KSB7XHJcbiAgICAgICAgcmV0dXJuIGNvbnRlbnQucmVwbGFjZSgvKD86XFxyXFxufFxccnxcXG4pL2csICc8YnI+Jyk7XHJcbiAgICB9XHJcblxyXG4gICAgZWRpdENvbnRlbnQoaXRlbSkge1xyXG4gICAgICAgIGl0ZW0uZWRpdGVkQ29udGVudCA9IGl0ZW0uY29udGVudDtcclxuICAgICAgICBpdGVtLmlzRWRpdCA9IHRydWU7XHJcbiAgICB9XHJcblxyXG4gICAgc2F2ZUVkaXRlZENvbnRlbnQoaXRlbSkge1xyXG4gICAgICAgIGl0ZW0uY29udGVudCA9IGl0ZW0uZWRpdGVkQ29udGVudDtcclxuICAgICAgICBpdGVtLmlzRWRpdCA9IGZhbHNlO1xyXG4gICAgICAgIHRoaXMudXBkYXRlTG9nLmVtaXQoaXRlbSk7XHJcbiAgICB9XHJcblxyXG4gICAgcmVtb3ZlSXRlbShpdGVtKSB7XHJcbiAgICAgICAgaXRlbS5pc0RlbGV0ZSA9IHRydWU7XHJcbiAgICAgICAgdGhpcy51cGRhdGVMb2cuZW1pdChpdGVtKTtcclxuICAgIH1cclxufVxyXG4iXX0=
|
@@ -115,7 +115,7 @@ export class RelatedListComponent {
|
|
115
115
|
RelatedListComponent.decorators = [
|
116
116
|
{ type: Component, args: [{
|
117
117
|
selector: 'qms-related-list',
|
118
|
-
template: "<div class=\"container list-related\">\r\n <div class=\"list-related__title\">\r\n <strong>{{ title }}</strong>\r\n </div>\r\n <div\r\n class=\"list-related__body\"\r\n *ngFor=\"let item of relatedData; let i = index\"\r\n >\r\n <div class=\"list-related__body-parent\">\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(item)\"\r\n ></mat-icon>\r\n <div qms-list-header>\r\n <div\r\n qms-line\r\n type=\"subtitle\"\r\n class=\"search__option-name\"\r\n (click)=\"onItemClick(item)\"\r\n >\r\n <div class=\"caption\" *ngIf=\"canShowParent(item)\">\r\n {{ item?.parentName }}\r\n </div>\r\n <span class=\"cursor\">{{ item.itemName }}</span>\r\n </div>\r\n <div\r\n class=\"caption\"\r\n *ngIf=\"item.breadcumbs && item.breadcumbs.length\"\r\n >\r\n <qms-breadcrumb\r\n class=\"breadcrumb-containe\"\r\n type=\"table\"\r\n numDisplayItem=\"1\"\r\n [nodes]=\"item.breadcumbs\"\r\n >\r\n </qms-breadcrumb>\r\n </div>\r\n </div>\r\n <div
|
118
|
+
template: "<div class=\"container list-related\">\r\n <div class=\"list-related__title\">\r\n <strong>{{ title }}</strong>\r\n </div>\r\n <div\r\n class=\"list-related__body\"\r\n *ngFor=\"let item of relatedData; let i = index\"\r\n >\r\n <div class=\"list-related__body-parent\">\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(item)\"\r\n ></mat-icon>\r\n <div qms-list-header>\r\n <div\r\n qms-line\r\n type=\"subtitle\"\r\n class=\"search__option-name\"\r\n (click)=\"onItemClick(item)\"\r\n >\r\n <div class=\"caption\" *ngIf=\"canShowParent(item)\">\r\n {{ item?.parentName }}\r\n </div>\r\n <span class=\"cursor\">{{ item.itemName }}</span>\r\n </div>\r\n <div\r\n class=\"caption\"\r\n *ngIf=\"item.breadcumbs && item.breadcumbs.length\"\r\n >\r\n <qms-breadcrumb\r\n class=\"breadcrumb-containe\"\r\n type=\"table\"\r\n numDisplayItem=\"1\"\r\n [nodes]=\"item.breadcumbs\"\r\n >\r\n </qms-breadcrumb>\r\n </div>\r\n </div>\r\n <div\r\n qms-line\r\n color=\"default-subtitle\"\r\n *ngIf=\"item?.displayId || item.statusName\"\r\n >\r\n <span class=\"material-icons-outlined\"> local_offer </span> ID:\r\n {{ item?.displayId }} {{ getItemStatus(item) }}\r\n </div>\r\n </qms-list-item>\r\n <div class=\"block\" *ngIf=\"!isNotEditedItem\">\r\n <button qms-btn-icon color=\"light\" mode=\"dark\" (click)=\"removeItem(i)\">\r\n <mat-icon>close</mat-icon>\r\n </button>\r\n </div>\r\n </div>\r\n </div>\r\n</div>\r\n",
|
119
119
|
encapsulation: ViewEncapsulation.None,
|
120
120
|
styles: ["@font-face{font-family:Open Sans;font-style:normal;font-weight:400;font-display:swap;src:url(https://fonts.gstatic.com/s/opensans/v20/mem8YaGs126MiZpBA-UFWJ0bbck.woff2) format(\"woff2\");unicode-range:U+0460-052f,U+1c80-1c88,U+20b4,U+2de0-2dff,U+a640-a69f,U+fe2e-fe2f}@font-face{font-family:Open Sans;font-style:normal;font-weight:400;font-display:swap;src:url(https://fonts.gstatic.com/s/opensans/v20/mem8YaGs126MiZpBA-UFUZ0bbck.woff2) format(\"woff2\");unicode-range:U+0400-045f,U+0490-0491,U+04b0-04b1,U+2116}@font-face{font-family:Open Sans;font-style:normal;font-weight:400;font-display:swap;src:url(https://fonts.gstatic.com/s/opensans/v20/mem8YaGs126MiZpBA-UFWZ0bbck.woff2) format(\"woff2\");unicode-range:U+1f??}@font-face{font-family:Open Sans;font-style:normal;font-weight:400;font-display:swap;src:url(https://fonts.gstatic.com/s/opensans/v20/mem8YaGs126MiZpBA-UFVp0bbck.woff2) format(\"woff2\");unicode-range:U+0370-03ff}@font-face{font-family:Open Sans;font-style:normal;font-weight:400;font-display:swap;src:url(https://fonts.gstatic.com/s/opensans/v20/mem8YaGs126MiZpBA-UFWp0bbck.woff2) format(\"woff2\");unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01a0-01a1,U+01af-01b0,U+1ea0-1ef9,U+20ab}@font-face{font-family:Open Sans;font-style:normal;font-weight:400;font-display:swap;src:url(https://fonts.gstatic.com/s/opensans/v20/mem8YaGs126MiZpBA-UFW50bbck.woff2) format(\"woff2\");unicode-range:U+0100-024f,U+0259,U+1e??,U+2020,U+20a0-20ab,U+20ad-20cf,U+2113,U+2c60-2c7f,U+a720-a7ff}@font-face{font-family:Open Sans;font-style:normal;font-weight:400;font-display:swap;src:url(https://fonts.gstatic.com/s/opensans/v20/mem8YaGs126MiZpBA-UFVZ0b.woff2) format(\"woff2\");unicode-range:U+00??,U+0131,U+0152-0153,U+02bb-02bc,U+02c6,U+02da,U+02dc,U+2000-206f,U+2074,U+20ac,U+2122,U+2191,U+2193,U+2212,U+2215,U+feff,U+fffd}@font-face{font-family:Raleway;font-style:normal;font-weight:400;font-display:swap;src:url(https://fonts.gstatic.com/s/raleway/v19/1Ptxg8zYS_SKggPN4iEgvnHyvveLxVvaorCFPrEHJA.woff2) format(\"woff2\");unicode-range:U+0460-052f,U+1c80-1c88,U+20b4,U+2de0-2dff,U+a640-a69f,U+fe2e-fe2f}@font-face{font-family:Raleway;font-style:normal;font-weight:400;font-display:swap;src:url(https://fonts.gstatic.com/s/raleway/v19/1Ptxg8zYS_SKggPN4iEgvnHyvveLxVvaorCMPrEHJA.woff2) format(\"woff2\");unicode-range:U+0400-045f,U+0490-0491,U+04b0-04b1,U+2116}@font-face{font-family:Raleway;font-style:normal;font-weight:400;font-display:swap;src:url(https://fonts.gstatic.com/s/raleway/v19/1Ptxg8zYS_SKggPN4iEgvnHyvveLxVvaorCHPrEHJA.woff2) format(\"woff2\");unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01a0-01a1,U+01af-01b0,U+1ea0-1ef9,U+20ab}@font-face{font-family:Raleway;font-style:normal;font-weight:400;font-display:swap;src:url(https://fonts.gstatic.com/s/raleway/v19/1Ptxg8zYS_SKggPN4iEgvnHyvveLxVvaorCGPrEHJA.woff2) format(\"woff2\");unicode-range:U+0100-024f,U+0259,U+1e??,U+2020,U+20a0-20ab,U+20ad-20cf,U+2113,U+2c60-2c7f,U+a720-a7ff}@font-face{font-family:Raleway;font-style:normal;font-weight:400;font-display:swap;src:url(https://fonts.gstatic.com/s/raleway/v19/1Ptxg8zYS_SKggPN4iEgvnHyvveLxVvaorCIPrE.woff2) format(\"woff2\");unicode-range:U+00??,U+0131,U+0152-0153,U+02bb-02bc,U+02c6,U+02da,U+02dc,U+2000-206f,U+2074,U+20ac,U+2122,U+2191,U+2193,U+2212,U+2215,U+feff,U+fffd}.list-related{font-family:Open Sans;font-style:normal;font-weight:400;color:#323232}.list-related .list-related__title{font-weight:600;font-size:.875rem;line-height:22px;margin-bottom:1rem}.list-related .list-related__body .list-related__body-parent{min-height:48px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid #ddd}.list-related .list-related__body .list-related__body-parent .qms-list-item.mat-2-line.image-item{height:auto}.list-related .list-related__body .list-related__body-parent .qms-list-item.image-item .qms-list-item-content{margin:0}.list-related .list-related__body .list-related__body-parent .wrap-image.image-square,.list-related .list-related__body .list-related__body-parent .wrap-image.image-square img{background:transparent;margin:auto;height:24px;width:24px}.list-related .list-related__body .list-related__body-parent .qms-list-item.image-item .qms-list-text,.list-related .list-related__body .list-related__body-parent .qms-list-item.image-item .trailing-box{margin-left:1.5rem;border-bottom:none;padding-bottom:7px;padding-top:7px}.list-related .list-related__body .list-related__body-parent .qms-list-item.image-item .qms-list-text .material-icons-outlined,.list-related .list-related__body .list-related__body-parent .qms-list-item.image-item .trailing-box .material-icons-outlined{font-size:13px}.list-related .list-related__body .list-related__body-parent .breadcrumb-containe .qms-breadcrumb-item .mat-icon{font-size:16px!important;padding-bottom:1px}.list-related .list-related__body .list-related__body-parent .block{font-weight:400;font-size:1rem;line-height:28px;display:flex;align-items:center}.list-related .list-related__body .list-related__body-parent .block .title{margin-left:1.5rem;padding-top:5px;padding-bottom:5px}.list-related .list-related__body .list-related__body-parent .block .title .caption{color:rgba(0,0,0,.6);font-size:.75rem;line-height:22px}.list-related .list-related__body .list-related__body-parent .block mat-icon{color:rgba(0,0,0,.6);padding:0}.list-related .list-related__body .list-related__body-parent .block button.qms-btn-icon{width:40px;height:40px;line-height:40px}.list-related .list-related__body .list-related__body-child{font-weight:400;font-size:.875rem;line-height:22px}.list-related .list-related__body .list-related__body-child .default{min-height:48px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid #ddd}.list-related .list-related__body .list-related__body-child .default .title{margin-left:3rem}.list-related .list-related__body .list-related__body-child .default .group-button{margin-right:2rem;display:flex}.list-related .list-related__body .remain{font-weight:600;font-size:.875rem;line-height:22px;display:flex;align-items:center;justify-content:space-between;background-color:#fafafa;color:#1954a9;min-height:48px;border-bottom:1px solid #ddd}.list-related .list-related__body .remain .title{margin-left:3rem}.label-green,.label-red,.label-yellow{font-family:Open Sans;font-style:normal;font-weight:600;display:inline-block;text-align:center;margin-left:1rem;width:24px;height:24px;font-size:.75rem;border-radius:1px}.label-red{background-color:#9e360f;color:#fff}.label-yellow{background-color:#e4cf53;color:rgba(0,0,0,.87)}.label-green{background-color:#00804c;color:#fff}.cursor{cursor:pointer}"]
|
121
121
|
},] }
|
@@ -132,4 +132,4 @@ RelatedListComponent.propDecorators = {
|
|
132
132
|
updateData: [{ type: Output }],
|
133
133
|
onItemSelect: [{ type: Output }]
|
134
134
|
};
|
135
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"list-related.component.js","sourceRoot":"","sources":["../../../../../../../projects/qms-angular/src/lib/components/related/list-other-related/list-related.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Inject, Input, OnChanges, OnInit, Output, SimpleChanges, ViewEncapsulation } from \"@angular/core\";\r\nimport { MatIconRegistry } from \"@angular/material/icon\";\r\nimport { DomSanitizer } from \"@angular/platform-browser\";\r\nimport { TranslateLibraryService } from '../../../services/translation-registry.service';\r\nimport { QMSIconRegistryService } from \"../../app-icon/icon-registry.service\";\r\nimport { DataType } from \"../common/data-type.enum\";\r\nimport { DocumentNodeType } from \"../common/document-folder-type.enum\";\r\nimport { IRelated, RelatedData } from \"../model/related-data.model\";\r\n\r\n@Component({\r\n  selector: 'qms-related-list',\r\n  templateUrl: './list-related.component.html',\r\n  styleUrls: ['./list-related.component.scss'],\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class RelatedListComponent implements OnInit, OnChanges {\r\n  LANG: any;\r\n  title: string;\r\n  isNotEditedItem: boolean;\r\n  relatedData: Array<IRelated> = [];\r\n  dataType = DataType;\r\n  // imageProcess = '../qms-angular/src/assets/images/union.svg';\r\n  imageProcess = 'data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMTgiIGhlaWdodD0iMTkiIHZpZXdCb3g9IjAgMCAxOCAxOSIgZmlsbD0ibm9uZSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4NCjxwYXRoIGZpbGwtcnVsZT0iZXZlbm9kZCIgY2xpcC1ydWxlPSJldmVub2RkIiBkPSJNMCAwLjVWNi41SDJWMTYuNUgxMlYxOC41SDE4VjEyLjVIMTJWMTQuNUg0VjYuNUg2VjQuNUgxMlY2LjVIMThWMC41SDEyVjIuNUg2VjAuNUgwWk00IDIuNVY0LjVIMlYyLjVINFpNMTYgMi41VjQuNUgxNFYyLjVIMTZaTTE2IDE2LjVWMTQuNUgxNFYxNi41SDE2WiIgZmlsbD0iYmxhY2siIGZpbGwtb3BhY2l0eT0iMC42Ii8+DQo8L3N2Zz4NCg==';\r\n\r\n  @Input() data: RelatedData;\r\n  @Input() showStatus: boolean;\r\n  @Output() updateData: EventEmitter<any> = new EventEmitter<any>();\r\n  @Output() onItemSelect: EventEmitter<any> = new EventEmitter<any>();\r\n\r\n  constructor(\r\n    private domSanitizer: DomSanitizer,\r\n    public translate: TranslateLibraryService,\r\n    private iconRegistry: MatIconRegistry,\r\n    private appIconService: QMSIconRegistryService\r\n  ) {\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\r\n  ngOnChanges(changes: SimpleChanges) {\r\n    if (changes.data && JSON.stringify(changes.data.currentValue) !== JSON.stringify(changes.data.previousValue)) {\r\n      this.relatedData = [];\r\n      this.title = changes.data.currentValue.title;\r\n      this.isNotEditedItem = changes.data.currentValue['isNotEditedItem'] ?? false;\r\n      this.relatedData = [...changes.data.currentValue.data];\r\n    }\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    this.title = this.data.title;\r\n    this.isNotEditedItem = this.data['isNotEditedItem'] ?? false;\r\n    this.relatedData = this.data.data;\r\n\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\r\n  getImagePath() {\r\n    return this.domSanitizer.bypassSecurityTrustResourceUrl(this.imageProcess) as string;\r\n  }\r\n\r\n  removeItem(index: number) {\r\n    this.updateData.emit(index);\r\n  }\r\n\r\n  onCloseClick(): void {\r\n\r\n  }\r\n\r\n  onItemClick(item: any): void {\r\n    if (this.onItemSelect)\r\n      this.onItemSelect.emit(item);\r\n  }\r\n\r\n  onItemBreadcrumbClick(event: any) {\r\n    if (this.onItemSelect)\r\n      this.onItemSelect.emit(event);\r\n  }\r\n\r\n  getItemStatus(item: any) {\r\n    return (this.showStatus && item?.statusName) ? `, ${item?.statusName}` : '';\r\n  }\r\n\r\n  getNodeIcon(item) {\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  canShowParent(item) {\r\n    return item.itemType === this.dataType.deviation || item.itemType === this.dataType.checklist;\r\n  }\r\n}\r\n"]}
|
135
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"list-related.component.js","sourceRoot":"","sources":["../../../../../../../projects/qms-angular/src/lib/components/related/list-other-related/list-related.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Inject, Input, OnChanges, OnInit, Output, SimpleChanges, ViewEncapsulation } from \"@angular/core\";\r\nimport { MatIconRegistry } from \"@angular/material/icon\";\r\nimport { DomSanitizer } from \"@angular/platform-browser\";\r\nimport { TranslateLibraryService } from '../../../services/translation-registry.service';\r\nimport { QMSIconRegistryService } from \"../../app-icon/icon-registry.service\";\r\nimport { DataType } from \"../common/data-type.enum\";\r\nimport { DocumentNodeType } from \"../common/document-folder-type.enum\";\r\nimport { IRelated, RelatedData } from \"../model/related-data.model\";\r\n\r\n@Component({\r\n  selector: 'qms-related-list',\r\n  templateUrl: './list-related.component.html',\r\n  styleUrls: ['./list-related.component.scss'],\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class RelatedListComponent implements OnInit, OnChanges {\r\n  LANG: any;\r\n  title: string;\r\n  isNotEditedItem: boolean;\r\n  relatedData: Array<IRelated> = [];\r\n  dataType = DataType;\r\n  // imageProcess = '../qms-angular/src/assets/images/union.svg';\r\n  imageProcess = 'data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMTgiIGhlaWdodD0iMTkiIHZpZXdCb3g9IjAgMCAxOCAxOSIgZmlsbD0ibm9uZSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4NCjxwYXRoIGZpbGwtcnVsZT0iZXZlbm9kZCIgY2xpcC1ydWxlPSJldmVub2RkIiBkPSJNMCAwLjVWNi41SDJWMTYuNUgxMlYxOC41SDE4VjEyLjVIMTJWMTQuNUg0VjYuNUg2VjQuNUgxMlY2LjVIMThWMC41SDEyVjIuNUg2VjAuNUgwWk00IDIuNVY0LjVIMlYyLjVINFpNMTYgMi41VjQuNUgxNFYyLjVIMTZaTTE2IDE2LjVWMTQuNUgxNFYxNi41SDE2WiIgZmlsbD0iYmxhY2siIGZpbGwtb3BhY2l0eT0iMC42Ii8+DQo8L3N2Zz4NCg==';\r\n\r\n  @Input() data: RelatedData;\r\n  @Input() showStatus: boolean;\r\n  @Output() updateData: EventEmitter<any> = new EventEmitter<any>();\r\n  @Output() onItemSelect: EventEmitter<any> = new EventEmitter<any>();\r\n\r\n  constructor(\r\n    private domSanitizer: DomSanitizer,\r\n    public translate: TranslateLibraryService,\r\n    private iconRegistry: MatIconRegistry,\r\n    private appIconService: QMSIconRegistryService\r\n  ) {\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\r\n  ngOnChanges(changes: SimpleChanges) {\r\n    if (changes.data && JSON.stringify(changes.data.currentValue) !== JSON.stringify(changes.data.previousValue)) {\r\n      this.relatedData = [];\r\n      this.title = changes.data.currentValue.title;\r\n      this.isNotEditedItem = changes.data.currentValue['isNotEditedItem'] ?? false;\r\n      this.relatedData = [...changes.data.currentValue.data];\r\n    }\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    this.title = this.data.title;\r\n    this.isNotEditedItem = this.data['isNotEditedItem'] ?? false;\r\n    this.relatedData = this.data.data;\r\n\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\r\n  getImagePath() {\r\n    return this.domSanitizer.bypassSecurityTrustResourceUrl(this.imageProcess) as string;\r\n  }\r\n\r\n  removeItem(index: number) {\r\n    this.updateData.emit(index);\r\n  }\r\n\r\n  onCloseClick(): void {\r\n\r\n  }\r\n\r\n  onItemClick(item: any): void {\r\n    if (this.onItemSelect)\r\n      this.onItemSelect.emit(item);\r\n  }\r\n\r\n  onItemBreadcrumbClick(event: any) {\r\n    if (this.onItemSelect)\r\n      this.onItemSelect.emit(event);\r\n  }\r\n\r\n  getItemStatus(item: any) {\r\n    return (this.showStatus && item?.statusName) ? `, ${item?.statusName}` : '';\r\n  }\r\n\r\n  getNodeIcon(item) {\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  canShowParent(item) {\r\n    return item.itemType === this.dataType.deviation || item.itemType === this.dataType.checklist;\r\n  }\r\n}\r\n"]}
|
@@ -1,4 +1,4 @@
|
|
1
1
|
export class SelectedNode {
|
2
2
|
}
|
3
3
|
// dataTypeId
|
4
|
-
//# sourceMappingURL=data:application/json;base64,
|
4
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VsZWN0ZWQtbm9kZS5tb2RlbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3Ftcy1hbmd1bGFyL3NyYy9saWIvY29tcG9uZW50cy9yZWxhdGVkL21vZGVsL3NlbGVjdGVkLW5vZGUubW9kZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUEsTUFBTSxPQUFPLFlBQVk7Q0FheEI7QUFDRCxhQUFhIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQnJlYWRjcnVtYk5vZGUgfSBmcm9tIFwiLi4vLi4vYnJlYWRjcnVtYi9tb2RlbC9icmVhZGNydW1iLW5vZGUubW9kZWxcIjtcclxuXHJcbmV4cG9ydCBjbGFzcyBTZWxlY3RlZE5vZGUge1xyXG4gIG1vZHVsZUlkOiBudW1iZXI7XHJcbiAgaWQ6IGFueTtcclxuICBpdGVtTmFtZTogc3RyaW5nO1xyXG4gIGl0ZW1OdW1iZXJJZDogc3RyaW5nO1xyXG4gIGl0ZW1UeXBlOiBhbnk7XHJcbiAgZGlzcGxheUlkPzogYW55O1xyXG4gIHN0YXR1cz86IG51bWJlcjtcclxuICBzdGF0dXNOYW1lPzogYW55O1xyXG4gIHBhcmVudElkPzogc3RyaW5nO1xyXG4gIHBhcmVudE5hbWU/OiBzdHJpbmc7XHJcbiAgbGV2ZWxUeXBlPzogbnVtYmVyO1xyXG4gIGJyZWFkY3VtYnM/OiBCcmVhZGNydW1iTm9kZVtdO1xyXG59XHJcbi8vIGRhdGFUeXBlSWQiXX0=
|