@sunbird-cb/tree-hierarchy 0.0.1-cbrelease-4.8.26

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (118) hide show
  1. package/README.md +24 -0
  2. package/esm2022/lib/components/action-bar/action-bar.component.mjs +41 -0
  3. package/esm2022/lib/components/approval/approval.component.mjs +19 -0
  4. package/esm2022/lib/components/approve-view/approve-view.component.mjs +64 -0
  5. package/esm2022/lib/components/categories-preview/categories-preview.component.mjs +44 -0
  6. package/esm2022/lib/components/conforamtion-popup/conforamtion-popup.component.mjs +74 -0
  7. package/esm2022/lib/components/connector/connector.component.mjs +59 -0
  8. package/esm2022/lib/components/create-categories/create-categories.component.mjs +83 -0
  9. package/esm2022/lib/components/create-term/create-term.component.mjs +847 -0
  10. package/esm2022/lib/components/create-term-from-framework/create-term-from-framework.component.mjs +823 -0
  11. package/esm2022/lib/components/org-hierarchy-add-modal/org-hierarchy-add-modal.component.mjs +149 -0
  12. package/esm2022/lib/components/pending-approval/pending-approval.component.mjs +64 -0
  13. package/esm2022/lib/components/term-card/term-card.component.mjs +311 -0
  14. package/esm2022/lib/components/tree-column-view/tree-column-view.component.mjs +322 -0
  15. package/esm2022/lib/components/tree-view/tree-view.component.mjs +497 -0
  16. package/esm2022/lib/constants/app-constant.mjs +40 -0
  17. package/esm2022/lib/constants/data.mjs +6972 -0
  18. package/esm2022/lib/containers/config-framework/config-framework.component.mjs +92 -0
  19. package/esm2022/lib/containers/dashboard/dashboard.component.mjs +14 -0
  20. package/esm2022/lib/labels/strings.mjs +40 -0
  21. package/esm2022/lib/models/approval.model.mjs +2 -0
  22. package/esm2022/lib/models/connection-type.model.mjs +2 -0
  23. package/esm2022/lib/models/connection.model.mjs +2 -0
  24. package/esm2022/lib/models/framework.model.mjs +2 -0
  25. package/esm2022/lib/models/variable-type.model.mjs +2 -0
  26. package/esm2022/lib/pipes/order-by.pipe.mjs +35 -0
  27. package/esm2022/lib/services/approval.service.mjs +47 -0
  28. package/esm2022/lib/services/connection.service.mjs +3 -0
  29. package/esm2022/lib/services/connector.service.mjs +240 -0
  30. package/esm2022/lib/services/framework.service.mjs +387 -0
  31. package/esm2022/lib/services/local-connection.service.mjs +75 -0
  32. package/esm2022/lib/services/odcs.service.mjs +23 -0
  33. package/esm2022/lib/tree-hierarchy-routing.module.mjs +43 -0
  34. package/esm2022/lib/tree-hierarchy.component.mjs +24 -0
  35. package/esm2022/lib/tree-hierarchy.module.mjs +138 -0
  36. package/esm2022/lib/tree-hierarchy.service.mjs +41 -0
  37. package/esm2022/material.module.mjs +199 -0
  38. package/esm2022/public-api.mjs +9 -0
  39. package/esm2022/sunbird-cb-tree-hierarchy.mjs +2 -0
  40. package/fesm2022/sunbird-cb-tree-hierarchy.mjs +11577 -0
  41. package/fesm2022/sunbird-cb-tree-hierarchy.mjs.map +1 -0
  42. package/index.d.ts +3 -0
  43. package/lib/components/action-bar/action-bar.component.d.ts +17 -0
  44. package/lib/components/action-bar/action-bar.component.d.ts.map +1 -0
  45. package/lib/components/approval/approval.component.d.ts +10 -0
  46. package/lib/components/approval/approval.component.d.ts.map +1 -0
  47. package/lib/components/approve-view/approve-view.component.d.ts +27 -0
  48. package/lib/components/approve-view/approve-view.component.d.ts.map +1 -0
  49. package/lib/components/categories-preview/categories-preview.component.d.ts +14 -0
  50. package/lib/components/categories-preview/categories-preview.component.d.ts.map +1 -0
  51. package/lib/components/conforamtion-popup/conforamtion-popup.component.d.ts +20 -0
  52. package/lib/components/conforamtion-popup/conforamtion-popup.component.d.ts.map +1 -0
  53. package/lib/components/connector/connector.component.d.ts +23 -0
  54. package/lib/components/connector/connector.component.d.ts.map +1 -0
  55. package/lib/components/create-categories/create-categories.component.d.ts +26 -0
  56. package/lib/components/create-categories/create-categories.component.d.ts.map +1 -0
  57. package/lib/components/create-term/create-term.component.d.ts +148 -0
  58. package/lib/components/create-term/create-term.component.d.ts.map +1 -0
  59. package/lib/components/create-term-from-framework/create-term-from-framework.component.d.ts +105 -0
  60. package/lib/components/create-term-from-framework/create-term-from-framework.component.d.ts.map +1 -0
  61. package/lib/components/org-hierarchy-add-modal/org-hierarchy-add-modal.component.d.ts +31 -0
  62. package/lib/components/org-hierarchy-add-modal/org-hierarchy-add-modal.component.d.ts.map +1 -0
  63. package/lib/components/pending-approval/pending-approval.component.d.ts +21 -0
  64. package/lib/components/pending-approval/pending-approval.component.d.ts.map +1 -0
  65. package/lib/components/term-card/term-card.component.d.ts +43 -0
  66. package/lib/components/term-card/term-card.component.d.ts.map +1 -0
  67. package/lib/components/tree-column-view/tree-column-view.component.d.ts +52 -0
  68. package/lib/components/tree-column-view/tree-column-view.component.d.ts.map +1 -0
  69. package/lib/components/tree-view/tree-view.component.d.ts +91 -0
  70. package/lib/components/tree-view/tree-view.component.d.ts.map +1 -0
  71. package/lib/constants/app-constant.d.ts +44 -0
  72. package/lib/constants/app-constant.d.ts.map +1 -0
  73. package/lib/constants/data.d.ts +117 -0
  74. package/lib/constants/data.d.ts.map +1 -0
  75. package/lib/containers/config-framework/config-framework.component.d.ts +32 -0
  76. package/lib/containers/config-framework/config-framework.component.d.ts.map +1 -0
  77. package/lib/containers/dashboard/dashboard.component.d.ts +9 -0
  78. package/lib/containers/dashboard/dashboard.component.d.ts.map +1 -0
  79. package/lib/labels/strings.d.ts +40 -0
  80. package/lib/labels/strings.d.ts.map +1 -0
  81. package/lib/models/approval.model.d.ts +11 -0
  82. package/lib/models/approval.model.d.ts.map +1 -0
  83. package/lib/models/connection-type.model.d.ts +6 -0
  84. package/lib/models/connection-type.model.d.ts.map +1 -0
  85. package/lib/models/connection.model.d.ts +7 -0
  86. package/lib/models/connection.model.d.ts.map +1 -0
  87. package/lib/models/framework.model.d.ts +88 -0
  88. package/lib/models/framework.model.d.ts.map +1 -0
  89. package/lib/models/variable-type.model.d.ts +46 -0
  90. package/lib/models/variable-type.model.d.ts.map +1 -0
  91. package/lib/pipes/order-by.pipe.d.ts +10 -0
  92. package/lib/pipes/order-by.pipe.d.ts.map +1 -0
  93. package/lib/services/approval.service.d.ts +21 -0
  94. package/lib/services/approval.service.d.ts.map +1 -0
  95. package/lib/services/connection.service.d.ts +4 -0
  96. package/lib/services/connection.service.d.ts.map +1 -0
  97. package/lib/services/connector.service.d.ts +17 -0
  98. package/lib/services/connector.service.d.ts.map +1 -0
  99. package/lib/services/framework.service.d.ts +82 -0
  100. package/lib/services/framework.service.d.ts.map +1 -0
  101. package/lib/services/local-connection.service.d.ts +18 -0
  102. package/lib/services/local-connection.service.d.ts.map +1 -0
  103. package/lib/services/odcs.service.d.ts +11 -0
  104. package/lib/services/odcs.service.d.ts.map +1 -0
  105. package/lib/tree-hierarchy-routing.module.d.ts +8 -0
  106. package/lib/tree-hierarchy-routing.module.d.ts.map +1 -0
  107. package/lib/tree-hierarchy.component.d.ts +13 -0
  108. package/lib/tree-hierarchy.component.d.ts.map +1 -0
  109. package/lib/tree-hierarchy.module.d.ts +31 -0
  110. package/lib/tree-hierarchy.module.d.ts.map +1 -0
  111. package/lib/tree-hierarchy.service.d.ts +17 -0
  112. package/lib/tree-hierarchy.service.d.ts.map +1 -0
  113. package/material.module.d.ts +52 -0
  114. package/material.module.d.ts.map +1 -0
  115. package/package.json +43 -0
  116. package/public-api.d.ts +9 -0
  117. package/public-api.d.ts.map +1 -0
  118. package/sunbird-cb-tree-hierarchy.d.ts.map +1 -0
@@ -0,0 +1,92 @@
1
+ import { Component } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ import * as i1 from "../../services/framework.service";
4
+ import * as i2 from "@angular/common";
5
+ import * as i3 from "../../components/create-categories/create-categories.component";
6
+ import * as i4 from "../../components/categories-preview/categories-preview.component";
7
+ export class ConfigFrameworkComponent {
8
+ constructor(frameworkService) {
9
+ this.frameworkService = frameworkService;
10
+ this.categoriesRepresentations = [];
11
+ this.tempCategoryRepresentaions = [];
12
+ this.oldElements = [];
13
+ }
14
+ ngOnInit() {
15
+ this.frameworkService.getFrameworkInfo().subscribe(res => {
16
+ this.frameworkCategories = res.result.framework.categories;
17
+ });
18
+ }
19
+ updateCategory(name) {
20
+ this.removeOldLine();
21
+ this.tempCategoryRepresentaions.push({
22
+ name: name,
23
+ terms: this.updateTermArry(name, this.categoriesRepresentations[this.categoriesRepresentations.length - 1], this.categoriesRepresentations.length)
24
+ });
25
+ this.categoriesRepresentations = [...this.tempCategoryRepresentaions];
26
+ }
27
+ updateTermArry(current, parent, index) {
28
+ let term = [];
29
+ if (index % 2 === 0) {
30
+ term = [
31
+ {
32
+ name: `${current} 1`,
33
+ domId: `${current}1`
34
+ },
35
+ {
36
+ name: `${current} 2`,
37
+ selected: true,
38
+ connected: true,
39
+ domId: `${current.toLowerCase()}2`,
40
+ parent: parent ? `${parent.terms[0].domId}` : ''
41
+ }
42
+ ];
43
+ }
44
+ else {
45
+ term = [
46
+ {
47
+ name: `${current} 1`,
48
+ selected: true,
49
+ connected: true,
50
+ domId: `${current.toLowerCase()}1`,
51
+ parent: parent ? `${parent.terms[1].domId}` : ''
52
+ },
53
+ {
54
+ name: `${current} 2`,
55
+ domId: `${current}2`
56
+ }
57
+ ];
58
+ }
59
+ return term;
60
+ }
61
+ removeOldLine() {
62
+ const eles = Array.from(document.getElementsByClassName('leader-line') || []);
63
+ if (eles.length > 0) {
64
+ eles.forEach(ele => ele.remove());
65
+ }
66
+ }
67
+ removeCategory(index) {
68
+ this.categoriesRepresentations.splice(index, 1);
69
+ const temp = [...this.categoriesRepresentations];
70
+ this.categoriesRepresentations = [];
71
+ this.tempCategoryRepresentaions = [];
72
+ temp.forEach(cat => {
73
+ this.updateCategory(cat.name);
74
+ });
75
+ }
76
+ changePosition(event) {
77
+ let myArray = [...this.tempCategoryRepresentaions];
78
+ myArray[event.cur] = myArray.splice(event.prev, 1, myArray[event.cur])[0];
79
+ this.categoriesRepresentations = [];
80
+ this.tempCategoryRepresentaions = [];
81
+ myArray.forEach(cat => {
82
+ this.updateCategory(cat.name);
83
+ });
84
+ }
85
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ConfigFrameworkComponent, deps: [{ token: i1.FrameworkService }], target: i0.ɵɵFactoryTarget.Component }); }
86
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: ConfigFrameworkComponent, selector: "lib-config-framework", ngImport: i0, template: "<div class=\"config__wrap\">\n <lib-create-categories class=\"config__form-wrap\" [taxonomyInfo]=\"''\" (updateCategory)=\"updateCategory($event)\" \n (removeCategories)=\"removeCategory($event)\" (changePosition)=\"changePosition($event)\"></lib-create-categories>\n <ng-container *ngIf=\"categoriesRepresentations\">\n <lib-categories-preview class=\"config__preview\" [data]=\"categoriesRepresentations\"></lib-categories-preview>\n </ng-container>\n </div>\n", styles: [".config__wrap{display:flex;flex-direction:row;align-items:start;height:100vh}.config__form-wrap{flex-grow:1}.config__preview{flex-grow:9}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.CreateCategoriesComponent, selector: "lib-create-categories", inputs: ["taxonomyInfo"], outputs: ["updateCategory", "removeCategories", "changePosition"] }, { kind: "component", type: i4.CategoriesPreviewComponent, selector: "lib-categories-preview", inputs: ["data"] }] }); }
87
+ }
88
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ConfigFrameworkComponent, decorators: [{
89
+ type: Component,
90
+ args: [{ selector: 'lib-config-framework', template: "<div class=\"config__wrap\">\n <lib-create-categories class=\"config__form-wrap\" [taxonomyInfo]=\"''\" (updateCategory)=\"updateCategory($event)\" \n (removeCategories)=\"removeCategory($event)\" (changePosition)=\"changePosition($event)\"></lib-create-categories>\n <ng-container *ngIf=\"categoriesRepresentations\">\n <lib-categories-preview class=\"config__preview\" [data]=\"categoriesRepresentations\"></lib-categories-preview>\n </ng-container>\n </div>\n", styles: [".config__wrap{display:flex;flex-direction:row;align-items:start;height:100vh}.config__form-wrap{flex-grow:1}.config__preview{flex-grow:9}\n"] }]
91
+ }], ctorParameters: function () { return [{ type: i1.FrameworkService }]; } });
92
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"config-framework.component.js","sourceRoot":"","sources":["../../../../../../../library/sunbird-cb/tree-hierarchy/src/lib/containers/config-framework/config-framework.component.ts","../../../../../../../library/sunbird-cb/tree-hierarchy/src/lib/containers/config-framework/config-framework.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit } from '@angular/core';\nimport { FrameworkService } from '../../services/framework.service';\ndeclare var LeaderLine: any;\n\n@Component({\n  selector: 'lib-config-framework',\n  templateUrl: './config-framework.component.html',\n  styleUrls: ['./config-framework.component.scss']\n})\nexport class ConfigFrameworkComponent implements OnInit {\n  frameworkCategories: any;\n  categoriesRepresentations: any[] = [];\n  tempCategoryRepresentaions: any[] = [];\n  oldElements: any[] = [];\n  constructor(private frameworkService: FrameworkService) { }\n\n  ngOnInit() {\n    this.frameworkService.getFrameworkInfo().subscribe(res => {\n      this.frameworkCategories = res.result.framework.categories\n    })\n    // this.categoriesRepresentations = categoryRepresentationsV1\n  }\n\n//   updateCategory(data){\n//     for(let i=0;i<data.length;i++) {\n//         this.tempCategoryRepresentaions.push(\n//           {\n//             name: data[i].name,\n             \n//             terms:this.updateTermArry(data[i].name, data[i+1]?data[i+1].name:'', i)\n//           }\n//         )\n//     }\n//     this.categoriesRepresentations = this.tempCategoryRepresentaions;\n//   }\n\n\n\n//   updateTermArry(current,next, index){\n//     let term = []\n//     if(index%2 === 0){\n//       term = [\n//         {\n//           name:`${current} 1`,\n//           domId:`${current}1`\n//         },\n//         {\n//           name: `${current} 2`,\n//           selected:true,\n//           connected:true,\n//           domId:`${current.toLowerCase()}2`,\n//           connectedDomId:next?`${next.toLowerCase()}1`:''\n//         }\n//       ]\n//     } else {\n//       term = [\n//         {\n//           name:`${current} 1`,\n//           selected:true,\n//           connected:true,\n//           domId:`${current.toLowerCase()}1`,\n//           connectedDomId:next?`${next.toLowerCase()}2`:''\n//         },\n//         {\n//           name: `${current} 2`,\n//           domId:`${current}2`\n//         }\n//       ]\n//     }\n//     return term\n//   }\n// }\n\n\n\n\n  updateCategory(name: string){\n    this.removeOldLine()\n    this.tempCategoryRepresentaions.push(\n          {\n            name: name,\n            terms:this.updateTermArry(name,  this.categoriesRepresentations[this.categoriesRepresentations.length -1], this.categoriesRepresentations.length)\n          }\n    )\n    this.categoriesRepresentations = [...this.tempCategoryRepresentaions]    \n}\n\n  updateTermArry(current: string, parent: any, index: number){\n    let term = []\n    if(index%2 === 0) {\n      term = [\n        {\n          name:`${current} 1`,\n          domId:`${current}1`\n        },\n        {\n          name: `${current} 2`,\n          selected:true,\n          connected:true,\n          domId:`${current.toLowerCase()}2`,\n          parent:parent ? `${parent.terms[0].domId}`:''\n        }\n      ]\n    } else {\n      term = [\n        {\n          name:`${current} 1`,\n          selected:true,\n          connected:true,\n          domId:`${current.toLowerCase()}1`,\n          parent:parent?`${parent.terms[1].domId}`:''\n        },\n        {\n          name: `${current} 2`,\n          domId:`${current}2`\n        }\n      ]\n    }\n    return term\n  }\n\n  removeOldLine() {\n    const eles = Array.from(document.getElementsByClassName('leader-line') || [])\n    if(eles.length>0){\n        eles.forEach(ele => ele.remove());\n    }\n  }\n\n  removeCategory(index: number){\n    this.categoriesRepresentations.splice(index,1)\n    const temp = [...this.categoriesRepresentations]\n    this.categoriesRepresentations = []\n    this.tempCategoryRepresentaions = []\n    temp.forEach(cat => {\n      this.updateCategory(cat.name)\n    })\n  }\n\n  changePosition(event: any) {\n    let myArray = [...this.tempCategoryRepresentaions];\n    myArray[event.cur] = myArray.splice(event.prev, 1, myArray[event.cur])[0];\n    this.categoriesRepresentations = []\n    this.tempCategoryRepresentaions = []\n    myArray.forEach(cat => {\n      this.updateCategory(cat.name)\n    })\n  }\n\n}\n","<div class=\"config__wrap\">\n    <lib-create-categories class=\"config__form-wrap\" [taxonomyInfo]=\"''\" (updateCategory)=\"updateCategory($event)\" \n    (removeCategories)=\"removeCategory($event)\" (changePosition)=\"changePosition($event)\"></lib-create-categories>\n    <ng-container *ngIf=\"categoriesRepresentations\">\n        <lib-categories-preview  class=\"config__preview\" [data]=\"categoriesRepresentations\"></lib-categories-preview>\n    </ng-container>\n </div>\n"]}
@@ -0,0 +1,14 @@
1
+ import { Component } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ export class DashboardComponent {
4
+ constructor() { }
5
+ ngOnInit() {
6
+ }
7
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DashboardComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
8
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: DashboardComponent, selector: "lib-dashboard", ngImport: i0, template: "<p>dashboard works!</p>\n", styles: [""] }); }
9
+ }
10
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DashboardComponent, decorators: [{
11
+ type: Component,
12
+ args: [{ selector: 'lib-dashboard', template: "<p>dashboard works!</p>\n" }]
13
+ }], ctorParameters: function () { return []; } });
14
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGFzaGJvYXJkLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnJhcnkvc3VuYmlyZC1jYi90cmVlLWhpZXJhcmNoeS9zcmMvbGliL2NvbnRhaW5lcnMvZGFzaGJvYXJkL2Rhc2hib2FyZC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJyYXJ5L3N1bmJpcmQtY2IvdHJlZS1oaWVyYXJjaHkvc3JjL2xpYi9jb250YWluZXJzL2Rhc2hib2FyZC9kYXNoYm9hcmQuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBVSxNQUFNLGVBQWUsQ0FBQzs7QUFPbEQsTUFBTSxPQUFPLGtCQUFrQjtJQUU3QixnQkFBZ0IsQ0FBQztJQUVqQixRQUFRO0lBQ1IsQ0FBQzsrR0FMVSxrQkFBa0I7bUdBQWxCLGtCQUFrQixxRENQL0IsMkJBQ0E7OzRGRE1hLGtCQUFrQjtrQkFMOUIsU0FBUzsrQkFDRSxlQUFlIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBPbkluaXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnbGliLWRhc2hib2FyZCcsXG4gIHRlbXBsYXRlVXJsOiAnLi9kYXNoYm9hcmQuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9kYXNoYm9hcmQuY29tcG9uZW50LnNjc3MnXVxufSlcbmV4cG9ydCBjbGFzcyBEYXNoYm9hcmRDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xuXG4gIGNvbnN0cnVjdG9yKCkgeyB9XG5cbiAgbmdPbkluaXQoKSB7XG4gIH1cblxufVxuIiwiPHA+ZGFzaGJvYXJkIHdvcmtzITwvcD5cbiJdfQ==
@@ -0,0 +1,40 @@
1
+ export const labels = {
2
+ flag: "flag",
3
+ createNew: "Create New",
4
+ edit: "Edit",
5
+ build: "build",
6
+ noData: "No Data Available",
7
+ loading: "Loading",
8
+ add: "add",
9
+ pendingApproval: "Pending for Approval",
10
+ date: "Date",
11
+ more: "more...",
12
+ rightArrow: "keyboard_arrow_right",
13
+ alreadyExist: "Already Exist.",
14
+ cancel: "Cancel",
15
+ create: "Create",
16
+ update: "Update",
17
+ createCategories: "Create Categories",
18
+ category: "Category",
19
+ removeCircleOutline: "remove_circle_outline",
20
+ close: "close",
21
+ endPoint: "Enter End Point",
22
+ token: "Enter Token",
23
+ enterFrameworkName: "Enter Framework Name",
24
+ frameworkName: "Framework Name",
25
+ clear: "Clear",
26
+ or: "Or",
27
+ experienceTaxonomy: "Experience Taxonomy",
28
+ playWithIt: "Let's Play with it",
29
+ newConnection: "Create New Connection",
30
+ categoryPreview: "Categories Preview",
31
+ allFrac: "All Frac",
32
+ treeView: "tree view...",
33
+ categoryName: "Enter Category Name",
34
+ name: "Select Name",
35
+ description: "Enter Description",
36
+ addCompetency: "Add Competency",
37
+ add_btn: "Add",
38
+ delete: "Delete"
39
+ };
40
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RyaW5ncy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnJhcnkvc3VuYmlyZC1jYi90cmVlLWhpZXJhcmNoeS9zcmMvbGliL2xhYmVscy9zdHJpbmdzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE1BQU0sQ0FBQyxNQUFNLE1BQU0sR0FBRztJQUNsQixJQUFJLEVBQUUsTUFBTTtJQUNaLFNBQVMsRUFBRSxZQUFZO0lBQ3ZCLElBQUksRUFBRSxNQUFNO0lBQ1osS0FBSyxFQUFFLE9BQU87SUFDZCxNQUFNLEVBQUUsbUJBQW1CO0lBQzNCLE9BQU8sRUFBRSxTQUFTO0lBQ2xCLEdBQUcsRUFBRSxLQUFLO0lBQ1YsZUFBZSxFQUFFLHNCQUFzQjtJQUN2QyxJQUFJLEVBQUUsTUFBTTtJQUNaLElBQUksRUFBRSxTQUFTO0lBQ2YsVUFBVSxFQUFFLHNCQUFzQjtJQUNsQyxZQUFZLEVBQUUsZ0JBQWdCO0lBQzlCLE1BQU0sRUFBRSxRQUFRO0lBQ2hCLE1BQU0sRUFBRSxRQUFRO0lBQ2hCLE1BQU0sRUFBRSxRQUFRO0lBQ2hCLGdCQUFnQixFQUFFLG1CQUFtQjtJQUNyQyxRQUFRLEVBQUUsVUFBVTtJQUNwQixtQkFBbUIsRUFBRSx1QkFBdUI7SUFDNUMsS0FBSyxFQUFFLE9BQU87SUFDZCxRQUFRLEVBQUUsaUJBQWlCO0lBQzNCLEtBQUssRUFBRSxhQUFhO0lBQ3BCLGtCQUFrQixFQUFFLHNCQUFzQjtJQUMxQyxhQUFhLEVBQUUsZ0JBQWdCO0lBQy9CLEtBQUssRUFBRSxPQUFPO0lBQ2QsRUFBRSxFQUFFLElBQUk7SUFDUixrQkFBa0IsRUFBRSxxQkFBcUI7SUFDekMsVUFBVSxFQUFFLG9CQUFvQjtJQUNoQyxhQUFhLEVBQUUsdUJBQXVCO0lBQ3RDLGVBQWUsRUFBRSxvQkFBb0I7SUFDckMsT0FBTyxFQUFFLFVBQVU7SUFDbkIsUUFBUSxFQUFFLGNBQWM7SUFDeEIsWUFBWSxFQUFFLHFCQUFxQjtJQUNuQyxJQUFJLEVBQUUsYUFBYTtJQUNuQixXQUFXLEVBQUUsbUJBQW1CO0lBQ2hDLGFBQWEsRUFBQyxnQkFBZ0I7SUFDOUIsT0FBTyxFQUFDLEtBQUs7SUFDYixNQUFNLEVBQUUsUUFBUTtDQUNuQixDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGNvbnN0IGxhYmVscyA9IHtcbiAgICBmbGFnOiBcImZsYWdcIixcbiAgICBjcmVhdGVOZXc6IFwiQ3JlYXRlIE5ld1wiLFxuICAgIGVkaXQ6IFwiRWRpdFwiLFxuICAgIGJ1aWxkOiBcImJ1aWxkXCIsXG4gICAgbm9EYXRhOiBcIk5vIERhdGEgQXZhaWxhYmxlXCIsXG4gICAgbG9hZGluZzogXCJMb2FkaW5nXCIsXG4gICAgYWRkOiBcImFkZFwiLFxuICAgIHBlbmRpbmdBcHByb3ZhbDogXCJQZW5kaW5nIGZvciBBcHByb3ZhbFwiLFxuICAgIGRhdGU6IFwiRGF0ZVwiLFxuICAgIG1vcmU6IFwibW9yZS4uLlwiLFxuICAgIHJpZ2h0QXJyb3c6IFwia2V5Ym9hcmRfYXJyb3dfcmlnaHRcIixcbiAgICBhbHJlYWR5RXhpc3Q6IFwiQWxyZWFkeSBFeGlzdC5cIixcbiAgICBjYW5jZWw6IFwiQ2FuY2VsXCIsXG4gICAgY3JlYXRlOiBcIkNyZWF0ZVwiLFxuICAgIHVwZGF0ZTogXCJVcGRhdGVcIixcbiAgICBjcmVhdGVDYXRlZ29yaWVzOiBcIkNyZWF0ZSBDYXRlZ29yaWVzXCIsXG4gICAgY2F0ZWdvcnk6IFwiQ2F0ZWdvcnlcIixcbiAgICByZW1vdmVDaXJjbGVPdXRsaW5lOiBcInJlbW92ZV9jaXJjbGVfb3V0bGluZVwiLFxuICAgIGNsb3NlOiBcImNsb3NlXCIsXG4gICAgZW5kUG9pbnQ6IFwiRW50ZXIgRW5kIFBvaW50XCIsXG4gICAgdG9rZW46IFwiRW50ZXIgVG9rZW5cIixcbiAgICBlbnRlckZyYW1ld29ya05hbWU6IFwiRW50ZXIgRnJhbWV3b3JrIE5hbWVcIixcbiAgICBmcmFtZXdvcmtOYW1lOiBcIkZyYW1ld29yayBOYW1lXCIsXG4gICAgY2xlYXI6IFwiQ2xlYXJcIixcbiAgICBvcjogXCJPclwiLFxuICAgIGV4cGVyaWVuY2VUYXhvbm9teTogXCJFeHBlcmllbmNlIFRheG9ub215XCIsXG4gICAgcGxheVdpdGhJdDogXCJMZXQncyBQbGF5IHdpdGggaXRcIixcbiAgICBuZXdDb25uZWN0aW9uOiBcIkNyZWF0ZSBOZXcgQ29ubmVjdGlvblwiLFxuICAgIGNhdGVnb3J5UHJldmlldzogXCJDYXRlZ29yaWVzIFByZXZpZXdcIixcbiAgICBhbGxGcmFjOiBcIkFsbCBGcmFjXCIsXG4gICAgdHJlZVZpZXc6IFwidHJlZSB2aWV3Li4uXCIsXG4gICAgY2F0ZWdvcnlOYW1lOiBcIkVudGVyIENhdGVnb3J5IE5hbWVcIixcbiAgICBuYW1lOiBcIlNlbGVjdCBOYW1lXCIsXG4gICAgZGVzY3JpcHRpb246IFwiRW50ZXIgRGVzY3JpcHRpb25cIixcbiAgICBhZGRDb21wZXRlbmN5OlwiQWRkIENvbXBldGVuY3lcIixcbiAgICBhZGRfYnRuOlwiQWRkXCIsXG4gICAgZGVsZXRlOiBcIkRlbGV0ZVwiXG59Il19
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBwcm92YWwubW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJyYXJ5L3N1bmJpcmQtY2IvdHJlZS1oaWVyYXJjaHkvc3JjL2xpYi9tb2RlbHMvYXBwcm92YWwubW9kZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBpbnRlcmZhY2UgSUFwcHJvdmFsIHtcbiAgICBhcHBsaWNhdGlvblN0YXR1czpzdHJpbmdcbiAgICBzZXJ2aWNlTmFtZTpzdHJpbmdcbn1cblxuZXhwb3J0IGludGVyZmFjZSBJQXBwcm92ZVJlcXVlc3Qge1xuICAgIHdmSWQ6IHN0cmluZ1xuICAgIHN0YXRlOiBzdHJpbmdcbiAgICBhY3Rpb246IHN0cmluZ1xuICAgIHNlcnZpY2VOYW1lOiBzdHJpbmdcbn0iXX0=
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29ubmVjdGlvbi10eXBlLm1vZGVsLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicmFyeS9zdW5iaXJkLWNiL3RyZWUtaGllcmFyY2h5L3NyYy9saWIvbW9kZWxzL2Nvbm5lY3Rpb24tdHlwZS5tb2RlbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSUNvbm5lY3Rpb24gfSBmcm9tIFwiLi9jb25uZWN0aW9uLm1vZGVsXCJcblxuZXhwb3J0IGludGVyZmFjZSBJQ29ubmVjdGlvblR5cGUge1xuICAgIHNvdXJjZTogJ29ubGluZScgfCAnb2ZmbGluZSdcbiAgICBkYXRhOiBJQ29ubmVjdGlvblxufSJdfQ==
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29ubmVjdGlvbi5tb2RlbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnJhcnkvc3VuYmlyZC1jYi90cmVlLWhpZXJhcmNoeS9zcmMvbGliL21vZGVscy9jb25uZWN0aW9uLm1vZGVsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgaW50ZXJmYWNlIElDb25uZWN0aW9uIHtcbiAgICBlbmRwb2ludDogc3RyaW5nXG4gICAgdG9rZW46IHN0cmluZ1xuICAgIGZyYW1ld29ya05hbWU6IHN0cmluZ1xuICAgIGlzQXBwcm92YWxSZXF1aXJlZDpib29sZWFuXG59Il19
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZnJhbWV3b3JrLm1vZGVsLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicmFyeS9zdW5iaXJkLWNiL3RyZWUtaGllcmFyY2h5L3NyYy9saWIvbW9kZWxzL2ZyYW1ld29yay5tb2RlbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiLy8gdHNsaW50OmRpc2FibGUtbmV4dC1saW5lOiBuby1uYW1lc3BhY2VcbmV4cG9ydCBuYW1lc3BhY2UgTlNGcmFtZXdvcmsge1xuXG4gICAgZXhwb3J0IHR5cGUgVENhcmRTdWJUeXBlID1cbiAgICAgICAgfCAnc3RhbmRhcmQnXG4gICAgICAgIHwgJ21pbmltYWwnXG4gICAgICAgIHwgJ3NwYWNlLXNhdmluZydcblxuICAgIGV4cG9ydCB0eXBlIFROb2RlU3RhdHVzID1cbiAgICAgICAgfCAnZHJhZnQnXG4gICAgICAgIHwgJ2xpdmUnXG5cbiAgICBleHBvcnQgaW50ZXJmYWNlIElDYXRlZ29yeSB7XG4gICAgICAgIGlkZW50aWZpZXI/OiBzdHJpbmdcbiAgICAgICAgbmFtZT86IHN0cmluZ1xuICAgICAgICBkZXNjcmlwdGlvbj86IHN0cmluZ1xuICAgICAgICBzdGF0dXM/OiBUTm9kZVN0YXR1c1xuICAgICAgICBjb2RlOiBzdHJpbmdcbiAgICAgICAgdHJhbnNsYXRpb25zPzogYW55XG4gICAgICAgIGluZGV4OiBudW1iZXJcbiAgICAgICAgdGVybXM6IGFueVtdXG4gICAgfVxuXG4gICAgZXhwb3J0IGludGVyZmFjZSBJVGVybSB7XG4gICAgICAgIGFzc29jaWF0aW9ucz86IElDYXRlZ29yeVtdXG4gICAgICAgIGNvZGU6IHN0cmluZ1xuICAgICAgICB0cmFuc2xhdGlvbnM/OiBzdHJpbmcgfCBudWxsXG4gICAgICAgIG5hbWU6IHN0cmluZ1xuICAgICAgICBkZXNjcmlwdGlvbjogc3RyaW5nXG4gICAgICAgIGluZGV4PzogbnVtYmVyXG4gICAgICAgIGNhdGVnb3J5OiBzdHJpbmdcbiAgICAgICAgc3RhdHVzOiBUTm9kZVN0YXR1c1xuICAgIH1cblxuICAgIGV4cG9ydCBpbnRlcmZhY2UgSVRlcm1DYXJkIHtcbiAgICAgICAgY2hpbGRyZW46IGFueVxuICAgICAgICBjYXJkU3ViVHlwZTogVENhcmRTdWJUeXBlXG4gICAgICAgIGRlbGV0ZWRNb2RlPzogJ2dyZXlPdXQnIHwgJ2hpZGUnXG4gICAgICAgIHN0YXRlRGF0YT86IGFueVxuICAgICAgICBzZWxlY3RlZD86IGJvb2xlYW5cbiAgICAgICAgY2F0ZWdvcnk6IHN0cmluZ1xuICAgICAgICBpc1ZpZXdPbmx5PzogYm9vbGVhbixcbiAgICAgICAgaGlnaGxpZ2h0Pzpib29sZWFuXG4gICAgfVxuXG4gICAgZXhwb3J0IGludGVyZmFjZSBJU2VsZWN0ZWRDYXRlZ29yeSB7XG4gICAgICAgIGNvbHVtbkNvZGU6IHN0cmluZ1xuICAgICAgICBjaGlsZHJlbjogSUZyYW1ld29ya1ZpZXdbXVxuICAgIH1cblxuICAgIGV4cG9ydCBpbnRlcmZhY2UgSVRlcm1zQnlDYXRlZ29yeSB7XG4gICAgICAgIGNhdGVnb3J5SWRlbnRpZmllcjogc3RyaW5nXG4gICAgICAgIGNhdGVnb3J5TGV2ZWw6IG51bWJlclxuICAgICAgICBjYXRlZ29yeU5hbWU6IHN0cmluZ1xuICAgICAgICBjYXRlZ29yeUNvZGU6IHN0cmluZ1xuICAgICAgICB0ZXJtczogSVRlcm1bXVxuICAgIH1cbiAgICAvLyB7XG4gICAgLy8gICAgIGNvbHVtbjFcbiAgICAvLyAgICAgQ0JTQ1xuICAgIC8vICAgICBsc3RPZlJvd3NbXG4gICAgLy8gICAgICAgICB7XG5cbiAgICAvLyAgICAgICAgIH1cbiAgICAvLyAgICAgXVxuXG4gICAgLy8gfXtcbiAgICAvLyAgICAgY29sdW1uMlxuICAgIC8vICAgICBISU5ESVxuICAgIC8vICAgICBsc3RPZlJvd3NbXG4gICAgLy8gICAgICAgICB7XG5cbiAgICAvLyAgICAgICAgIH1cbiAgICAvLyAgICAgXVxuXG4gICAgLy8gfVxuXG4gICAgZXhwb3J0IGludGVyZmFjZSBJRnJhbWV3b3JrVmlldyB7XG4gICAgICAgIGlkZW50aWZpZXI6IHN0cmluZ1xuICAgICAgICBjb2RlOiBzdHJpbmdcbiAgICAgICAgbmFtZTogc3RyaW5nXG4gICAgICAgIGRlc2NyaXB0aW9uOiBzdHJpbmdcbiAgICAgICAgY2hpbGRyZW46IFtdXG4gICAgICAgIHBhcmVudD86IGFueVxuICAgIH1cbiAgICBleHBvcnQgaW50ZXJmYWNlIElDb2x1bW5WaWV3IHtcbiAgICAgICAgaWRlbnRpZmllcjogc3RyaW5nXG4gICAgICAgIG5hbWU6IHN0cmluZ1xuICAgICAgICBzZWxlY3RlZDpib29sZWFuXG4gICAgICAgIGRlc2NyaXB0aW9uPzogc3RyaW5nXG4gICAgICAgIHN0YXR1czogVE5vZGVTdGF0dXNcbiAgICAgICAgY29kZTogc3RyaW5nXG4gICAgICAgIHRyYW5zbGF0aW9ucz86IGFueVxuICAgICAgICBpbmRleDogbnVtYmVyXG4gICAgICAgIGNoaWxkcmVuOiBhbnlbXSxcbiAgICAgICAgY2F0ZWdvcnk6c3RyaW5nLFxuICAgICAgICBhc3NvY2lhdGlvbnM6IHN0cmluZyxcbiAgICAgICAgY29uZmlnOiBhbnlcbiAgICAgICAgY2FyZFJlZj86IGFueVxuICAgIH1cbiAgICBleHBvcnQgaW50ZXJmYWNlIFBhcmVudHNFbGVtZW50cyB7XG4gICAgICAgIGlkZW50aWZpZXI6IHN0cmluZztcbiAgICB9XG4gICAgZXhwb3J0IGludGVyZmFjZSBBZGRpdGlvbmFsUHJvcGVydGllcyB7XG4gICAgfVxuICAgIGV4cG9ydCBpbnRlcmZhY2UgSUNyZWF0ZVRlcm0ge1xuICAgICAgICBjb2RlOiBzdHJpbmc7XG4gICAgICAgIG5hbWU6IHN0cmluZztcbiAgICAgICAgZGVzY3JpcHRpb246IHN0cmluZztcbiAgICAgICAgY2F0ZWdvcnk6IHN0cmluZztcbiAgICAgICAgc3RhdHVzOiBzdHJpbmc7XG4gICAgICAgIGFwcHJvdmFsU3RhdHVzPzogc3RyaW5nO1xuICAgICAgICBkaXNwbGF5TmFtZT86IHN0cmluZztcbiAgICAgICAgcGFyZW50cz86IFBhcmVudHNFbGVtZW50c1tdIHwgbnVsbDtcbiAgICAgICAgYWRkaXRpb25hbFByb3BlcnRpZXM6IEFkZGl0aW9uYWxQcm9wZXJ0aWVzO1xuICAgICAgICByZWZJZD86c3RyaW5nO1xuICAgICAgICByZWZUeXBlPzpzdHJpbmc7XG4gICAgICAgIGZyYW1ld29yaz86c3RyaW5nXG4gICAgfVxufVxuXG5cblxuIFxuIFxuICAiXX0=
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmFyaWFibGUtdHlwZS5tb2RlbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnJhcnkvc3VuYmlyZC1jYi90cmVlLWhpZXJhcmNoeS9zcmMvbGliL21vZGVscy92YXJpYWJsZS10eXBlLm1vZGVsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgaW50ZXJmYWNlIENhcmQge1xuICAgIGFwcHJvdmFsU3RhdHVzPzogc3RyaW5nLFxuICAgIGFzc29jaWF0aW9ucz86IEFycmF5PENhcmQ+LFxuICAgIGlkZW50aWZpZXI/OiBzdHJpbmcsXG4gICAgY29kZT86IHN0cmluZyxcbiAgICB0cmFuc2xhdGlvbnM/OiBhbnksXG4gICAgbmFtZT86IHN0cmluZyxcbiAgICBkZXNjcmlwdGlvbj86IHN0cmluZyxcbiAgICBpbmRleD86IG51bWJlcixcbiAgICBhZGRpdGlvbmFsUHJvcGVydGllcz86IGFueSxcbiAgICBjYXRlZ29yeT86IHN0cmluZyxcbiAgICBzdGF0dXM/OiBzdHJpbmcsXG4gICAgaWNvbj86IHN0cmluZyxcbiAgICBjb2xvcj86IHN0cmluZyxcbiAgICBjaGlsZHJlbj86IEFycmF5PENhcmQ+LFxuICAgIGhpZ2hsaWdodD86IGJvb2xlYW4sXG4gICAgYXNzb2NpYXRpb25Qcm9wZXJ0aWVzPzogYXNzb2NpYXRpb25Qcm9wZXJ0aWVzLFxuICAgIHNlbGVjdGVkPzogYm9vbGVhbixcbiAgICBjb25maWc/OiBDb25maWcsXG4gICAgcGFyZW50cz86IGFueVxufVxuXG5leHBvcnQgaW50ZXJmYWNlICBDYXJkU2VsZWN0aW9uIHtcbiAgICBlbGVtZW50PzogQXJyYXk8Q2FyZD4sXG4gICAgc2VsZWN0ZWRUZXJtPzogQXJyYXk8Q2FyZD4sXG4gICAgaXNTZWxlY3RlZDogYm9vbGVhbixcbiAgICBjYXJkUmVmPzogYW55LFxuICAgIGlzVXBkYXRlPzogYm9vbGVhblxufVxuXG5leHBvcnQgaW50ZXJmYWNlIENhcmRDaGVja2VkIHtcbiAgICB0ZXJtOiBDYXJkLFxuICAgIGNoZWNrZWQ6IGJvb2xlYW5cbn1cblxuZXhwb3J0IGludGVyZmFjZSBhc3NvY2lhdGlvblByb3BlcnRpZXMge1xuICAgIGFwcHJvdmFsU3RhdHVzPzogc3RyaW5nXG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgQ2FyZHNDb3VudCB7XG4gICAgY2F0ZWdvcnk6IHN0cmluZyxcbiAgICBjb3VudDogbnVtYmVyXG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgQ29uZmlnIHtcbiAgICBpbmRleDogbnVtYmVyLFxuICAgIGNhdGVnb3J5OiBzdHJpbmcsXG4gICAgaWNvbjogc3RyaW5nLFxuICAgIGNvbG9yOiBzdHJpbmdcbn0iXX0=
@@ -0,0 +1,35 @@
1
+ import { Pipe } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ export class OrderByPipe {
4
+ constructor() {
5
+ this.approvalTerms = [];
6
+ }
7
+ transform(value, sortBy) {
8
+ if (!sortBy) {
9
+ if (value) {
10
+ return value.slice().reverse();
11
+ }
12
+ else {
13
+ return null;
14
+ }
15
+ }
16
+ else {
17
+ if (Array.isArray(value)) {
18
+ return value.sort((a, b) => {
19
+ const timestampA = a.additionalProperties && a.additionalProperties.timeStamp ? new Date(Number(a.additionalProperties.timeStamp)).getTime() : 0;
20
+ const timestampB = b.additionalProperties && b.additionalProperties.timeStamp ? new Date(Number(b.additionalProperties.timeStamp)).getTime() : 0;
21
+ return timestampB - timestampA;
22
+ });
23
+ }
24
+ }
25
+ }
26
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: OrderByPipe, deps: [], target: i0.ɵɵFactoryTarget.Pipe }); }
27
+ static { this.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "16.2.12", ngImport: i0, type: OrderByPipe, name: "orderBy" }); }
28
+ }
29
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: OrderByPipe, decorators: [{
30
+ type: Pipe,
31
+ args: [{
32
+ name: 'orderBy'
33
+ }]
34
+ }], ctorParameters: function () { return []; } });
35
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib3JkZXItYnkucGlwZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnJhcnkvc3VuYmlyZC1jYi90cmVlLWhpZXJhcmNoeS9zcmMvbGliL3BpcGVzL29yZGVyLWJ5LnBpcGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLElBQUksRUFBaUIsTUFBTSxlQUFlLENBQUM7O0FBS3BELE1BQU0sT0FBTyxXQUFXO0lBRXRCO1FBREEsa0JBQWEsR0FBRyxFQUFFLENBQUM7SUFDTCxDQUFDO0lBRWYsU0FBUyxDQUFDLEtBQVUsRUFBRSxNQUFlO1FBRW5DLElBQUcsQ0FBQyxNQUFNLEVBQUU7WUFDVixJQUFHLEtBQUssRUFBRTtnQkFDUixPQUFPLEtBQUssQ0FBQyxLQUFLLEVBQUUsQ0FBQyxPQUFPLEVBQUUsQ0FBQzthQUNoQztpQkFBTTtnQkFDTCxPQUFPLElBQUksQ0FBQTthQUNaO1NBQ0Y7YUFBTTtZQUNMLElBQUcsS0FBSyxDQUFDLE9BQU8sQ0FBQyxLQUFLLENBQUMsRUFBRTtnQkFDckIsT0FBUSxLQUFLLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsRUFBRSxFQUFFO29CQUMxQixNQUFNLFVBQVUsR0FBRyxDQUFDLENBQUMsb0JBQW9CLElBQUksQ0FBQyxDQUFDLG9CQUFvQixDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUMsSUFBSSxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxvQkFBb0IsQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLE9BQU8sRUFBRSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7b0JBQ2pKLE1BQU0sVUFBVSxHQUFHLENBQUMsQ0FBQyxvQkFBb0IsSUFBSSxDQUFDLENBQUMsb0JBQW9CLENBQUMsU0FBUyxDQUFDLENBQUMsQ0FBQyxJQUFJLElBQUksQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLG9CQUFvQixDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUMsT0FBTyxFQUFFLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztvQkFFakosT0FBUSxVQUFVLEdBQUcsVUFBVSxDQUFDO2dCQUVoQyxDQUFDLENBQUMsQ0FBQzthQUVSO1NBQ0Y7SUFFSCxDQUFDOytHQXpCVSxXQUFXOzZHQUFYLFdBQVc7OzRGQUFYLFdBQVc7a0JBSHZCLElBQUk7bUJBQUM7b0JBQ0osSUFBSSxFQUFFLFNBQVM7aUJBQ2hCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUGlwZSwgUGlwZVRyYW5zZm9ybSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5AUGlwZSh7XG4gIG5hbWU6ICdvcmRlckJ5J1xufSlcbmV4cG9ydCBjbGFzcyBPcmRlckJ5UGlwZSBpbXBsZW1lbnRzIFBpcGVUcmFuc2Zvcm0ge1xuICBhcHByb3ZhbFRlcm1zID0gW107XG4gIGNvbnN0cnVjdG9yKCl7fVxuXG4gIHRyYW5zZm9ybSh2YWx1ZTogYW55LCBzb3J0Qnk/OiBzdHJpbmcpOiBhbnl7XG4gICAgLy8gcmV0dXJuIG51bGw7XG4gICAgaWYoIXNvcnRCeSkge1xuICAgICAgaWYodmFsdWUpIHtcbiAgICAgICAgcmV0dXJuIHZhbHVlLnNsaWNlKCkucmV2ZXJzZSgpO1xuICAgICAgfSBlbHNlIHtcbiAgICAgICAgcmV0dXJuIG51bGxcbiAgICAgIH1cbiAgICB9IGVsc2Uge1xuICAgICAgaWYoQXJyYXkuaXNBcnJheSh2YWx1ZSkpIHtcbiAgICAgICAgICByZXR1cm4gIHZhbHVlLnNvcnQoKGEsIGIpID0+IHtcbiAgICAgICAgICAgIGNvbnN0IHRpbWVzdGFtcEEgPSBhLmFkZGl0aW9uYWxQcm9wZXJ0aWVzICYmIGEuYWRkaXRpb25hbFByb3BlcnRpZXMudGltZVN0YW1wID8gbmV3IERhdGUoTnVtYmVyKGEuYWRkaXRpb25hbFByb3BlcnRpZXMudGltZVN0YW1wKSkuZ2V0VGltZSgpIDogMDtcbiAgICAgICAgICAgIGNvbnN0IHRpbWVzdGFtcEIgPSBiLmFkZGl0aW9uYWxQcm9wZXJ0aWVzICYmIGIuYWRkaXRpb25hbFByb3BlcnRpZXMudGltZVN0YW1wID8gbmV3IERhdGUoTnVtYmVyKGIuYWRkaXRpb25hbFByb3BlcnRpZXMudGltZVN0YW1wKSkuZ2V0VGltZSgpIDogMDtcbiAgICAgICAgICAgICBcbiAgICAgICAgICAgIHJldHVybiAgdGltZXN0YW1wQiAtIHRpbWVzdGFtcEE7XG4gICAgICAgICAgICBcbiAgICAgICAgICAgIH0pO1xuICAgICBcbiAgICAgIH1cbiAgICB9XG4gICAgIFxuICB9XG5cbn1cbiJdfQ==
@@ -0,0 +1,47 @@
1
+ import { Injectable } from '@angular/core';
2
+ import * as API from '../constants/app-constant';
3
+ import { BehaviorSubject, } from 'rxjs';
4
+ import * as i0 from "@angular/core";
5
+ import * as i1 from "../services/framework.service";
6
+ import * as i2 from "@angular/common/http";
7
+ export class ApprovalService {
8
+ constructor(frameworkService, http) {
9
+ this.frameworkService = frameworkService;
10
+ this.http = http;
11
+ this.approvalListSubject = new BehaviorSubject([]);
12
+ this.environment = this.frameworkService.getEnviroment();
13
+ }
14
+ createApproval(req) {
15
+ req.state = API.APPROVAL.INITIATE;
16
+ req.action = API.APPROVAL.ACTION;
17
+ req.serviceName = API.APPROVAL.SERVICE_NAME;
18
+ return this.http.post(`${API.APPROVAL.CREATE}`, req);
19
+ }
20
+ getApprovalList(req) {
21
+ return this.http.post(`${API.APPROVAL.SEARCH}`, req);
22
+ }
23
+ getWorkflowDetails(id) {
24
+ return this.http.get(`${API.APPROVAL.READ}/${id}`);
25
+ }
26
+ updateWorkFlowApproval(req) {
27
+ return this.http.patch(`${API.APPROVAL.UPDATE}`, req);
28
+ }
29
+ removeDuplicates(arr) {
30
+ return [...new Set(arr)];
31
+ }
32
+ setApprovalList(list) {
33
+ this.approvalListSubject.next(list);
34
+ }
35
+ getUpdateList() {
36
+ return this.approvalListSubject.asObservable();
37
+ }
38
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ApprovalService, deps: [{ token: i1.FrameworkService }, { token: i2.HttpClient }], target: i0.ɵɵFactoryTarget.Injectable }); }
39
+ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ApprovalService, providedIn: 'root' }); }
40
+ }
41
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ApprovalService, decorators: [{
42
+ type: Injectable,
43
+ args: [{
44
+ providedIn: 'root'
45
+ }]
46
+ }], ctorParameters: function () { return [{ type: i1.FrameworkService }, { type: i2.HttpClient }]; } });
47
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBwcm92YWwuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnJhcnkvc3VuYmlyZC1jYi90cmVlLWhpZXJhcmNoeS9zcmMvbGliL3NlcnZpY2VzL2FwcHJvdmFsLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUUzQyxPQUFPLEtBQUssR0FBRyxNQUFNLDJCQUEyQixDQUFBO0FBRWhELE9BQU8sRUFBRSxlQUFlLEdBQUcsTUFBTSxNQUFNLENBQUM7Ozs7QUFLeEMsTUFBTSxPQUFPLGVBQWU7SUFJMUIsWUFBb0IsZ0JBQWtDLEVBQVUsSUFBZ0I7UUFBNUQscUJBQWdCLEdBQWhCLGdCQUFnQixDQUFrQjtRQUFVLFNBQUksR0FBSixJQUFJLENBQVk7UUFGaEYsd0JBQW1CLEdBQXlCLElBQUksZUFBZSxDQUFDLEVBQUUsQ0FBQyxDQUFDO1FBR2xFLElBQUksQ0FBQyxXQUFXLEdBQUcsSUFBSSxDQUFDLGdCQUFnQixDQUFDLGFBQWEsRUFBRSxDQUFBO0lBQzFELENBQUM7SUFFRCxjQUFjLENBQUMsR0FBTztRQUNwQixHQUFHLENBQUMsS0FBSyxHQUFHLEdBQUcsQ0FBQyxRQUFRLENBQUMsUUFBUSxDQUFBO1FBQ2pDLEdBQUcsQ0FBQyxNQUFNLEdBQUcsR0FBRyxDQUFDLFFBQVEsQ0FBQyxNQUFNLENBQUE7UUFDaEMsR0FBRyxDQUFDLFdBQVcsR0FBRyxHQUFHLENBQUMsUUFBUSxDQUFDLFlBQVksQ0FBQTtRQUMzQyxPQUFPLElBQUksQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLEdBQUcsR0FBRyxDQUFDLFFBQVEsQ0FBQyxNQUFNLEVBQUUsRUFBQyxHQUFHLENBQUMsQ0FBQTtJQUNyRCxDQUFDO0lBRUQsZUFBZSxDQUFDLEdBQU87UUFDckIsT0FBTyxJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxHQUFHLEdBQUcsQ0FBQyxRQUFRLENBQUMsTUFBTSxFQUFFLEVBQUMsR0FBRyxDQUFDLENBQUE7SUFDckQsQ0FBQztJQUVELGtCQUFrQixDQUFDLEVBQU07UUFDdkIsT0FBTyxJQUFJLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxHQUFHLEdBQUcsQ0FBQyxRQUFRLENBQUMsSUFBSSxJQUFJLEVBQUUsRUFBRSxDQUFDLENBQUE7SUFDcEQsQ0FBQztJQUVELHNCQUFzQixDQUFDLEdBQU87UUFDNUIsT0FBTyxJQUFJLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxHQUFHLEdBQUcsQ0FBQyxRQUFRLENBQUMsTUFBTSxFQUFFLEVBQUUsR0FBRyxDQUFDLENBQUE7SUFDdkQsQ0FBQztJQUVELGdCQUFnQixDQUFDLEdBQVk7UUFDM0IsT0FBTyxDQUFDLEdBQUcsSUFBSSxHQUFHLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQztJQUMzQixDQUFDO0lBRUQsZUFBZSxDQUFDLElBQVE7UUFDdEIsSUFBSSxDQUFDLG1CQUFtQixDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQTtJQUNyQyxDQUFDO0lBQ0QsYUFBYTtRQUNYLE9BQU8sSUFBSSxDQUFDLG1CQUFtQixDQUFDLFlBQVksRUFBRSxDQUFBO0lBQ2hELENBQUM7K0dBcENVLGVBQWU7bUhBQWYsZUFBZSxjQUZkLE1BQU07OzRGQUVQLGVBQWU7a0JBSDNCLFVBQVU7bUJBQUM7b0JBQ1YsVUFBVSxFQUFFLE1BQU07aUJBQ25CIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRnJhbWV3b3JrU2VydmljZSB9IGZyb20gJy4uL3NlcnZpY2VzL2ZyYW1ld29yay5zZXJ2aWNlJ1xuaW1wb3J0ICogYXMgQVBJIGZyb20gJy4uL2NvbnN0YW50cy9hcHAtY29uc3RhbnQnXG5pbXBvcnQgeyBIdHRwQ2xpZW50IH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uL2h0dHAnO1xuaW1wb3J0IHsgQmVoYXZpb3JTdWJqZWN0LCB9IGZyb20gJ3J4anMnO1xuXG5ASW5qZWN0YWJsZSh7XG4gIHByb3ZpZGVkSW46ICdyb290J1xufSlcbmV4cG9ydCBjbGFzcyBBcHByb3ZhbFNlcnZpY2Uge1xuICBlbnZpcm9ubWVudFxuICBhcHByb3ZhbExpc3RTdWJqZWN0OiBCZWhhdmlvclN1YmplY3Q8YW55PiA9IG5ldyBCZWhhdmlvclN1YmplY3QoW10pO1xuXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgZnJhbWV3b3JrU2VydmljZTogRnJhbWV3b3JrU2VydmljZSwgcHJpdmF0ZSBodHRwOiBIdHRwQ2xpZW50KSB7IFxuICAgIHRoaXMuZW52aXJvbm1lbnQgPSB0aGlzLmZyYW1ld29ya1NlcnZpY2UuZ2V0RW52aXJvbWVudCgpXG4gIH1cblxuICBjcmVhdGVBcHByb3ZhbChyZXE6YW55KXtcbiAgICByZXEuc3RhdGUgPSBBUEkuQVBQUk9WQUwuSU5JVElBVEVcbiAgICByZXEuYWN0aW9uID0gQVBJLkFQUFJPVkFMLkFDVElPTlxuICAgIHJlcS5zZXJ2aWNlTmFtZSA9IEFQSS5BUFBST1ZBTC5TRVJWSUNFX05BTUVcbiAgICByZXR1cm4gdGhpcy5odHRwLnBvc3QoYCR7QVBJLkFQUFJPVkFMLkNSRUFURX1gLHJlcSlcbiAgfVxuXG4gIGdldEFwcHJvdmFsTGlzdChyZXE6YW55KXtcbiAgICByZXR1cm4gdGhpcy5odHRwLnBvc3QoYCR7QVBJLkFQUFJPVkFMLlNFQVJDSH1gLHJlcSlcbiAgfVxuXG4gIGdldFdvcmtmbG93RGV0YWlscyhpZDphbnkpIHtcbiAgICByZXR1cm4gdGhpcy5odHRwLmdldChgJHtBUEkuQVBQUk9WQUwuUkVBRH0vJHtpZH1gKVxuICB9XG5cbiAgdXBkYXRlV29ya0Zsb3dBcHByb3ZhbChyZXE6YW55KXtcbiAgICByZXR1cm4gdGhpcy5odHRwLnBhdGNoKGAke0FQSS5BUFBST1ZBTC5VUERBVEV9YCwgcmVxKVxuICB9XG5cbiAgcmVtb3ZlRHVwbGljYXRlcyhhcnI6c3RyaW5nW10pOnN0cmluZ1tdIHtcbiAgICByZXR1cm4gWy4uLm5ldyBTZXQoYXJyKV07XG4gIH1cblxuICBzZXRBcHByb3ZhbExpc3QobGlzdDphbnkpe1xuICAgIHRoaXMuYXBwcm92YWxMaXN0U3ViamVjdC5uZXh0KGxpc3QpXG4gIH1cbiAgZ2V0VXBkYXRlTGlzdCgpe1xuICAgIHJldHVybiB0aGlzLmFwcHJvdmFsTGlzdFN1YmplY3QuYXNPYnNlcnZhYmxlKClcbiAgfVxufVxuIl19
@@ -0,0 +1,3 @@
1
+ import { InjectionToken } from '@angular/core';
2
+ export const ENVIRONMENT = new InjectionToken('ENVIRONMENT');
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29ubmVjdGlvbi5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicmFyeS9zdW5iaXJkLWNiL3RyZWUtaGllcmFyY2h5L3NyYy9saWIvc2VydmljZXMvY29ubmVjdGlvbi5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFL0MsTUFBTSxDQUFDLE1BQU0sV0FBVyxHQUFvQyxJQUFJLGNBQWMsQ0FBQyxhQUFhLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGlvblRva2VuIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBJQ29ubmVjdGlvblR5cGUgfSBmcm9tICcuLi9tb2RlbHMvY29ubmVjdGlvbi10eXBlLm1vZGVsJztcbmV4cG9ydCBjb25zdCBFTlZJUk9OTUVOVDogSW5qZWN0aW9uVG9rZW48SUNvbm5lY3Rpb25UeXBlPiA9IG5ldyBJbmplY3Rpb25Ub2tlbignRU5WSVJPTk1FTlQnKTtcbiJdfQ==
@@ -0,0 +1,240 @@
1
+ import { Injectable } from '@angular/core';
2
+ import { defaultConfig } from '../constants/app-constant';
3
+ import * as d3 from 'd3';
4
+ import * as i0 from "@angular/core";
5
+ export class ConnectorService {
6
+ constructor() {
7
+ this.connectorMap = {};
8
+ this.containerSelector = '#treeViewContainer';
9
+ }
10
+ _drawLine(source, target, options = defaultConfig, sourceContainerId = undefined, targetContainerId = undefined) {
11
+ const _options = { ...defaultConfig, ...options };
12
+ _options['dashed'] = true;
13
+ if (Array.isArray(target)) {
14
+ let connectedDots = [];
15
+ target.forEach((_target) => {
16
+ const tempLine = this.renderLine(source, _target, _options);
17
+ connectedDots.push({
18
+ target: _target,
19
+ line: tempLine
20
+ });
21
+ if (sourceContainerId) {
22
+ const sourceContainer = document.querySelector(sourceContainerId);
23
+ if (sourceContainer) {
24
+ sourceContainer.addEventListener('scroll', () => {
25
+ try {
26
+ tempLine && tempLine.position();
27
+ }
28
+ catch (e) {
29
+ }
30
+ }, true);
31
+ }
32
+ }
33
+ if (targetContainerId) {
34
+ const targetContainer = document.querySelector(targetContainerId);
35
+ if (targetContainer) {
36
+ targetContainer.addEventListener('scroll', () => {
37
+ try {
38
+ tempLine && tempLine.position();
39
+ }
40
+ catch (e) {
41
+ }
42
+ }, true);
43
+ }
44
+ }
45
+ });
46
+ return connectedDots;
47
+ }
48
+ else {
49
+ return this.renderLine(source, target, _options);
50
+ }
51
+ }
52
+ renderLine(source, target, options) {
53
+ const treeViewComponent = document.querySelector(this.containerSelector);
54
+ if (!treeViewComponent) {
55
+ return {
56
+ source: null,
57
+ target: null,
58
+ path: null,
59
+ svg: null,
60
+ position: () => { },
61
+ show: () => { },
62
+ remove: () => { }
63
+ };
64
+ }
65
+ let container = treeViewComponent.querySelector('#leader-line-container');
66
+ if (!container) {
67
+ container = document.createElement('div');
68
+ container.id = 'leader-line-container';
69
+ container.style.position = 'absolute';
70
+ container.style.top = '0';
71
+ container.style.left = '0';
72
+ container.style.width = '100%';
73
+ container.style.height = '100%';
74
+ container.style.pointerEvents = 'none';
75
+ container.style.zIndex = '1000';
76
+ container.style.overflow = 'hidden';
77
+ treeViewComponent.appendChild(container);
78
+ }
79
+ this.elmWrapper = container;
80
+ let sourceElement = source;
81
+ let targetElement;
82
+ if (target.targetType === 'id') {
83
+ targetElement = document.getElementById(target.target);
84
+ }
85
+ else {
86
+ targetElement = target.target;
87
+ }
88
+ if (!sourceElement || !targetElement) {
89
+ return {
90
+ source: null,
91
+ target: null,
92
+ path: null,
93
+ svg: null,
94
+ position: () => { },
95
+ show: () => { },
96
+ remove: () => { }
97
+ };
98
+ }
99
+ const svgId = 'd3-line-' + Math.random().toString(36).substr(2, 9);
100
+ const svg = d3.select(container)
101
+ .append('svg')
102
+ .attr('id', svgId)
103
+ .attr('class', 'leader-line')
104
+ .style('position', 'absolute')
105
+ .style('top', '0')
106
+ .style('left', '0')
107
+ .style('width', '100%')
108
+ .style('height', '100%')
109
+ .style('pointer-events', 'none')
110
+ .style('overflow', 'visible');
111
+ const sourceRect = sourceElement.getBoundingClientRect();
112
+ const targetRect = targetElement.getBoundingClientRect();
113
+ const containerRect = container.getBoundingClientRect();
114
+ let sourceX, sourceY, targetX, targetY;
115
+ sourceX = sourceRect.right - containerRect.left;
116
+ sourceY = sourceRect.top + (sourceRect.height / 2) - containerRect.top;
117
+ targetX = targetRect.left - containerRect.left;
118
+ targetY = targetRect.top + (targetRect.height / 2) - containerRect.top;
119
+ const path = svg.append('path')
120
+ .attr('d', createGridPath(sourceX, sourceY, targetX, targetY))
121
+ .style('stroke', '#000')
122
+ .style('stroke-width', options.size || 2)
123
+ .style('fill', 'none')
124
+ .style('opacity', 1)
125
+ .style('stroke-linejoin', 'round')
126
+ .style('stroke-dasharray', options.dashed ? '5,5' : 'none');
127
+ function createGridPath(x1, y1, x2, y2) {
128
+ const midX = x1 + (x2 - x1) / 2;
129
+ return `M ${x1} ${y1} L ${midX} ${y1} L ${midX} ${y2} L ${x2} ${y2}`;
130
+ }
131
+ const defs = svg.append('defs');
132
+ if (options.startPlug === 'disc' || options.startPlug !== false) {
133
+ defs.append('marker')
134
+ .attr('id', `start-circle-${svgId}`)
135
+ .attr('viewBox', '0 0 10 10')
136
+ .attr('refX', 5)
137
+ .attr('refY', 5)
138
+ .attr('markerWidth', 8)
139
+ .attr('markerHeight', 8)
140
+ .attr('orient', 'auto')
141
+ .append('circle')
142
+ .attr('cx', 5)
143
+ .attr('cy', 5)
144
+ .attr('r', 4.5)
145
+ .style('fill', options.color || '#333');
146
+ path.attr('marker-start', `url(#start-circle-${svgId})`);
147
+ }
148
+ if (options.endPlug === 'arrow' || options.endPlug !== false) {
149
+ defs.append('marker')
150
+ .attr('id', `arrowhead-${svgId}`)
151
+ .attr('viewBox', '0 0 10 10')
152
+ .attr('refX', 8)
153
+ .attr('refY', 5)
154
+ .attr('markerWidth', 9)
155
+ .attr('markerHeight', 9)
156
+ .attr('orient', 'auto')
157
+ .append('path')
158
+ .attr('d', 'M 0 0 L 10 5 L 0 10 z')
159
+ .style('fill', options.color || '#333');
160
+ path.attr('marker-end', `url(#arrowhead-${svgId})`);
161
+ }
162
+ const d3Line = {
163
+ source: sourceElement,
164
+ target: targetElement,
165
+ path: path,
166
+ svg: svg,
167
+ position: function () {
168
+ const updatedSourceRect = sourceElement.getBoundingClientRect();
169
+ const updatedTargetRect = targetElement.getBoundingClientRect();
170
+ const updatedContainerRect = container.getBoundingClientRect();
171
+ const updatedSourceX = updatedSourceRect.right - updatedContainerRect.left;
172
+ const updatedSourceY = updatedSourceRect.top + (updatedSourceRect.height / 2) - updatedContainerRect.top;
173
+ const updatedTargetX = updatedTargetRect.left - updatedContainerRect.left;
174
+ const updatedTargetY = updatedTargetRect.top + (updatedTargetRect.height / 2) - updatedContainerRect.top;
175
+ const midX = updatedSourceX + (updatedTargetX - updatedSourceX) / 2;
176
+ path.attr('d', `M ${updatedSourceX} ${updatedSourceY} L ${midX} ${updatedSourceY} L ${midX} ${updatedTargetY} L ${updatedTargetX} ${updatedTargetY}`)
177
+ .style('stroke-dasharray', options.dashed ? '5,5' : 'none')
178
+ .attr('marker-start', options.startPlug !== false ? `url(#start-circle-${svgId})` : null)
179
+ .attr('marker-end', options.endPlug !== false ? `url(#arrowhead-${svgId})` : null);
180
+ },
181
+ show: function (animation = '') {
182
+ if (animation === 'draw') {
183
+ const pathNode = path.node();
184
+ if (!pathNode)
185
+ return;
186
+ const totalLength = pathNode.getTotalLength();
187
+ path.style('opacity', 1)
188
+ .attr('stroke-dasharray', totalLength)
189
+ .attr('stroke-dashoffset', totalLength)
190
+ .transition()
191
+ .duration(options.animOptions?.duration || 2000)
192
+ .ease(d3.easeLinear)
193
+ .attr('stroke-dashoffset', 0);
194
+ }
195
+ else {
196
+ path.style('opacity', 1);
197
+ }
198
+ },
199
+ remove: function () {
200
+ svg.remove();
201
+ }
202
+ };
203
+ d3Line.show(options.animation);
204
+ return d3Line;
205
+ }
206
+ updateConnectorsMap(map) {
207
+ this.connectorMap = map;
208
+ }
209
+ position(line) {
210
+ if (!line || !line.position)
211
+ return;
212
+ this.elmWrapper.style.transform = 'none';
213
+ var rectWrapper = this.elmWrapper.getBoundingClientRect();
214
+ this.elmWrapper.style.transform = 'translate(' +
215
+ ((rectWrapper.left + window.pageXOffset) * -1) + 'px, ' +
216
+ ((rectWrapper.top + window.pageYOffset) * -1) + 'px)';
217
+ line.position();
218
+ }
219
+ removeAllLines() {
220
+ if (this.connectorMap) {
221
+ for (const key in this.connectorMap) {
222
+ if (this.connectorMap[key] && this.connectorMap[key].lines && this.connectorMap[key].lines.length > 0) {
223
+ const lines = this.connectorMap[key].lines;
224
+ lines.forEach(async (element, index) => {
225
+ await element.line && element.line.remove();
226
+ lines.splice(index, 1);
227
+ });
228
+ this.connectorMap[key].lines = lines;
229
+ }
230
+ }
231
+ }
232
+ this.updateConnectorsMap({});
233
+ }
234
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ConnectorService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
235
+ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ConnectorService }); }
236
+ }
237
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ConnectorService, decorators: [{
238
+ type: Injectable
239
+ }], ctorParameters: function () { return []; } });
240
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"connector.service.js","sourceRoot":"","sources":["../../../../../../library/sunbird-cb/tree-hierarchy/src/lib/services/connector.service.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable */\nimport { Injectable } from '@angular/core';\nimport { defaultConfig } from '../constants/app-constant';\nimport * as d3 from 'd3';\n\ninterface ConnectedDot {\n  target: any;\n  line: any;\n}\n\ninterface D3Line {\n  source: any;\n  target: any;\n  path: any;\n  svg: any;\n  position: () => void;\n  show: (animation?: string) => void;\n  remove: () => void;\n}\n\n@Injectable()\nexport class ConnectorService {\n  connectorMap: {[key: string]: any} = {};\n  elmWrapper: any;\n  containerSelector = '#treeViewContainer'; // You might need to adjust this selector\n\n  constructor() {}\n\n  _drawLine(source: any, target: any, options: any = defaultConfig, sourceContainerId: any = undefined, targetContainerId: any = undefined): any {\n    const _options = <any>{...defaultConfig, ...options};\n    _options['dashed'] = true\n    if (Array.isArray(target)) {\n      let connectedDots: ConnectedDot[] = [];\n      \n      target.forEach((_target) => {\n        const tempLine = this.renderLine(source, _target, _options);\n        connectedDots.push({\n          target: _target,\n          line: tempLine\n        });\n        \n        if(sourceContainerId) {\n          const sourceContainer = document.querySelector(sourceContainerId);\n          if (sourceContainer) {\n            sourceContainer.addEventListener('scroll', () => {\n              try {\n                tempLine && tempLine.position();\n              } catch(e) {\n                // Error handling\n              }\n            }, true);\n          }\n        }\n        \n        if (targetContainerId) {\n          const targetContainer = document.querySelector(targetContainerId);\n          if (targetContainer) {\n            targetContainer.addEventListener('scroll', () => {\n              try {\n                tempLine && tempLine.position();\n              } catch(e) {\n                // Error handling\n              }\n            }, true);\n          }\n        }\n      });\n      return connectedDots;\n    } else {\n      return this.renderLine(source, target, _options);\n    }\n  }\n\n  private renderLine(source: any, target: any, options: any): D3Line {\n    // Find or create the container element\n    const treeViewComponent: any = document.querySelector(this.containerSelector);\n    if (!treeViewComponent) {\n      return {\n        source: null,\n        target: null,\n        path: null,\n        svg: null,\n        position: () => {},\n        show: () => {},\n        remove: () => {}\n      };\n    }\n    \n    // Create or get container for the SVG\n    let container: any = treeViewComponent.querySelector('#leader-line-container');\n    if (!container) {\n      container = document.createElement('div');\n      container.id = 'leader-line-container';\n      container.style.position = 'absolute';\n      container.style.top = '0';\n      container.style.left = '0';\n      container.style.width = '100%';\n      container.style.height = '100%';\n      container.style.pointerEvents = 'none';\n      container.style.zIndex = '1000';\n      container.style.overflow = 'hidden';\n      treeViewComponent.appendChild(container);\n    }\n    \n    // Store container reference for access in other methods\n    this.elmWrapper = container;\n    \n    // Get the source and target elements\n    let sourceElement = source;\n    let targetElement: any;\n    \n    if (target.targetType === 'id') {\n      targetElement = document.getElementById(target.target);\n    } else {\n      targetElement = target.target;\n    }\n    \n    // Ensure both elements exist\n    if (!sourceElement || !targetElement) {\n      return {\n        source: null,\n        target: null,\n        path: null,\n        svg: null,\n        position: () => {},\n        show: () => {},\n        remove: () => {}\n      };\n    }\n    \n    // Create a unique ID for the SVG\n    const svgId = 'd3-line-' + Math.random().toString(36).substr(2, 9);\n    \n    // Create SVG element\n    const svg = d3.select(container)\n      .append('svg')\n      .attr('id', svgId)\n      .attr('class', 'leader-line')\n      .style('position', 'absolute')\n      .style('top', '0')\n      .style('left', '0')\n      .style('width', '100%')\n      .style('height', '100%')\n      .style('pointer-events', 'none')\n      .style('overflow', 'visible');\n    \n    // Calculate positions\n    const sourceRect = sourceElement.getBoundingClientRect();\n    const targetRect = targetElement.getBoundingClientRect();\n    const containerRect = container.getBoundingClientRect();\n    \n    // Determine edge connection points - always right to left\n    let sourceX, sourceY, targetX, targetY;\n\n    // Source - always connect from the right edge\n    sourceX = sourceRect.right - containerRect.left;\n    sourceY = sourceRect.top + (sourceRect.height / 2) - containerRect.top;\n\n    // Target - always connect to the left edge\n    targetX = targetRect.left - containerRect.left;\n    targetY = targetRect.top + (targetRect.height / 2) - containerRect.top;\n    \n    // Create line with initial opacity 1 (visible immediately)\n    // Instead of a straight line, create a grid line with right angles\n    const path: any = svg.append('path')\n      .attr('d', createGridPath(sourceX, sourceY, targetX, targetY))\n      .style('stroke', '#000') // Darker color for better visibility\n      .style('stroke-width', options.size || 2)\n      .style('fill', 'none')\n      .style('opacity', 1) // Start visible\n      .style('stroke-linejoin', 'round') // Round corners for a smoother look\n      .style('stroke-dasharray', options.dashed ? '5,5' : 'none'); // Add dashed style if specified\n    \n    // Helper function to create a grid path\n    function createGridPath(x1: number, y1: number, x2: number, y2: number) {\n      // Calculate the midpoint on the x-axis\n      const midX = x1 + (x2 - x1) / 2;\n      \n      // Create a path with 3 segments (horizontal, vertical, horizontal)\n      return `M ${x1} ${y1} L ${midX} ${y1} L ${midX} ${y2} L ${x2} ${y2}`;\n    }\n  \n    // Define markers (disk at start and arrow at end)\n    const defs = svg.append('defs');\n    \n    // Add start marker (disk/circle)\n    if (options.startPlug === 'disc' || options.startPlug !== false) {\n      defs.append('marker')\n        .attr('id', `start-circle-${svgId}`)\n        .attr('viewBox', '0 0 10 10')\n        .attr('refX', 5)\n        .attr('refY', 5)\n        .attr('markerWidth', 8)\n        .attr('markerHeight', 8)\n        .attr('orient', 'auto')\n        .append('circle')\n        .attr('cx', 5)\n        .attr('cy', 5)\n        .attr('r', 4.5)\n        .style('fill', options.color || '#333');\n      \n      path.attr('marker-start', `url(#start-circle-${svgId})`);\n    }\n    \n    // Add end marker (arrow)\n    if (options.endPlug === 'arrow' || options.endPlug !== false) {\n      defs.append('marker')\n        .attr('id', `arrowhead-${svgId}`)\n        .attr('viewBox', '0 0 10 10')\n        .attr('refX', 8)  \n        .attr('refY', 5)\n        .attr('markerWidth', 9)\n        .attr('markerHeight', 9)\n        .attr('orient', 'auto')\n        .append('path')\n        .attr('d', 'M 0 0 L 10 5 L 0 10 z')\n        .style('fill', options.color || '#333');\n      \n      path.attr('marker-end', `url(#arrowhead-${svgId})`);\n    }\n    \n    // Create the D3Line object with API similar to LeaderLine\n    const d3Line: D3Line = {\n      source: sourceElement,\n      target: targetElement,\n      path: path,\n      svg: svg,\n      \n      // Position method to update line coordinates\n      position: function() {\n        // Get updated positions\n        const updatedSourceRect = sourceElement.getBoundingClientRect();\n        const updatedTargetRect = targetElement.getBoundingClientRect();\n        const updatedContainerRect = container.getBoundingClientRect();\n        \n        // Source - always connect from the right edge\n        const updatedSourceX = updatedSourceRect.right - updatedContainerRect.left;\n        const updatedSourceY = updatedSourceRect.top + (updatedSourceRect.height / 2) - updatedContainerRect.top;\n        \n        // Target - always connect to the left edge\n        const updatedTargetX = updatedTargetRect.left - updatedContainerRect.left;\n        const updatedTargetY = updatedTargetRect.top + (updatedTargetRect.height / 2) - updatedContainerRect.top;\n        \n        // Update path with grid path\n        const midX = updatedSourceX + (updatedTargetX - updatedSourceX) / 2;\n        path.attr('d', `M ${updatedSourceX} ${updatedSourceY} L ${midX} ${updatedSourceY} L ${midX} ${updatedTargetY} L ${updatedTargetX} ${updatedTargetY}`)\n            .style('stroke-dasharray', options.dashed ? '5,5' : 'none')\n            // Ensure markers are preserved during repositioning\n            .attr('marker-start', options.startPlug !== false ? `url(#start-circle-${svgId})` : null)\n            .attr('marker-end', options.endPlug !== false ? `url(#arrowhead-${svgId})` : null);\n      },\n      \n      // Show method with animation option\n      show: function(animation = '') {\n        if (animation === 'draw') {\n          // Ensure the path has a node before calculating total length\n          const pathNode = path.node();\n          if (!pathNode) return;\n          \n          const totalLength = pathNode.getTotalLength();\n          \n          path.style('opacity', 1)\n            .attr('stroke-dasharray', totalLength)\n            .attr('stroke-dashoffset', totalLength)\n            .transition()\n            .duration(options.animOptions?.duration || 2000)\n            .ease(d3.easeLinear)\n            .attr('stroke-dashoffset', 0);\n        } else {\n          path.style('opacity', 1);\n        }\n      },\n      \n      // Remove method\n      remove: function() {\n        svg.remove();\n      }\n    };\n    \n    // Immediately call show to make the line visible\n    d3Line.show(options.animation);\n    \n    return d3Line;\n  }\n\n  updateConnectorsMap(map: any): void {\n    this.connectorMap = map;\n  }\n\n  position(line: any): void {\n    if (!line || !line.position) return;\n    \n    this.elmWrapper.style.transform = 'none';\n    var rectWrapper = this.elmWrapper.getBoundingClientRect();\n    // Move to the origin of coordinates as the document\n    this.elmWrapper.style.transform = 'translate(' +\n      ((rectWrapper.left + window.pageXOffset) * -1) + 'px, ' +\n      ((rectWrapper.top + window.pageYOffset) * -1) + 'px)';\n    \n    line.position();\n  }\n\n  removeAllLines(): void {\n    if(this.connectorMap) {\n      for (const key in this.connectorMap) {\n        // Remove all n-1 lines and keep only current selection, also clear n+1 lines\n        if(this.connectorMap[key] && this.connectorMap[key].lines && this.connectorMap[key].lines.length > 0) {\n          const lines = this.connectorMap[key].lines;\n          lines.forEach(async (element: any, index: any) => {\n              await element.line && element.line.remove();\n              lines.splice(index, 1);\n          });\n          this.connectorMap[key].lines = lines;\n        }\n      }\n    }\n    // to reset connector map after clearing all the lines\n    this.updateConnectorsMap({});\n  }\n}"]}