vcomply-workflow-engine 3.9.3 → 3.9.4
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/esm2022/lib/constants/template.constant.mjs +6 -0
- package/esm2022/lib/link-related-policies/link-related-policies.component.mjs +1 -2
- package/esm2022/lib/services/auth.service.mjs +172 -0
- package/esm2022/lib/sharedComponents/document-section/document-section.component.mjs +49 -24
- package/esm2022/lib/sharedComponents/policy-template/constants/template.constant.mjs +3 -0
- package/esm2022/lib/sharedComponents/policy-template/policy-template.module.mjs +65 -0
- package/esm2022/lib/sharedComponents/policy-template/select-template-list/select-template-list.component.mjs +206 -0
- package/esm2022/lib/sharedComponents/policy-template/services/template.service.mjs +67 -0
- package/esm2022/lib/sharedComponents/policy-template/template-list-table/template-list-table.component.mjs +42 -0
- package/esm2022/lib/sharedComponents/policy-template/template-pipes/get-template-category.pipe.mjs +19 -0
- package/esm2022/lib/sharedComponents/policy-template/template-pipes/search-template.pipe.mjs +59 -0
- package/esm2022/lib/sharedComponents/policy-template/template-pipes/template-pipes.module.mjs +19 -0
- package/esm2022/lib/sharedComponents/policy-template/view-policy/view-policy/view-policy.component.mjs +93 -0
- package/esm2022/lib/sharedComponents/policy-template/view-policy/view-policy.module.mjs +19 -0
- package/esm2022/lib/ui-kit/multi-select/cs-multiselect/cs-multiselect.component.mjs +203 -0
- package/esm2022/lib/ui-kit/multi-select/cs-multiselect-option/cs-multiselect-option.component.mjs +31 -0
- package/esm2022/lib/ui-kit/multi-select/multi-select.module.mjs +37 -0
- package/esm2022/lib/ui-kit/multi-select/multi-select.service.mjs +16 -0
- package/esm2022/lib/workflow-engine.module.mjs +11 -3
- package/esm2022/lib/workflow-policy/workflow-policy.component.mjs +36 -26
- package/fesm2022/vcomply-workflow-engine.mjs +879 -39
- package/fesm2022/vcomply-workflow-engine.mjs.map +1 -1
- package/lib/constants/template.constant.d.ts +5 -0
- package/lib/services/auth.service.d.ts +39 -0
- package/lib/sharedComponents/document-section/document-section.component.d.ts +3 -1
- package/lib/sharedComponents/policy-template/constants/template.constant.d.ts +2 -0
- package/lib/sharedComponents/policy-template/policy-template.module.d.ts +20 -0
- package/lib/sharedComponents/policy-template/select-template-list/select-template-list.component.d.ts +49 -0
- package/lib/sharedComponents/policy-template/services/template.service.d.ts +19 -0
- package/lib/sharedComponents/policy-template/template-list-table/template-list-table.component.d.ts +14 -0
- package/lib/sharedComponents/policy-template/template-pipes/get-template-category.pipe.d.ts +7 -0
- package/lib/sharedComponents/policy-template/template-pipes/search-template.pipe.d.ts +37 -0
- package/lib/sharedComponents/policy-template/template-pipes/template-pipes.module.d.ts +9 -0
- package/lib/sharedComponents/policy-template/view-policy/view-policy/view-policy.component.d.ts +25 -0
- package/lib/sharedComponents/policy-template/view-policy/view-policy.module.d.ts +9 -0
- package/lib/ui-kit/multi-select/cs-multiselect/cs-multiselect.component.d.ts +69 -0
- package/lib/ui-kit/multi-select/cs-multiselect-option/cs-multiselect-option.component.d.ts +12 -0
- package/lib/ui-kit/multi-select/multi-select.module.d.ts +11 -0
- package/lib/ui-kit/multi-select/multi-select.service.d.ts +7 -0
- package/lib/workflow-engine.module.d.ts +3 -1
- package/lib/workflow-policy/workflow-policy.component.d.ts +2 -0
- package/package.json +1 -1
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
export const NO_DATA_FOUND_IMAGE = 'https://cdn.v-comply.com/libraries/workflow-engine/assets/workflow/search-data.svg';
|
|
2
|
+
export const NO_DATA_FOUND_MESSAGE = 'No results matched your search criteria.';
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGVtcGxhdGUuY29uc3RhbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy92eC13b3JrZmxvdy1lbmdpbmUvc3JjL2xpYi9zaGFyZWRDb21wb25lbnRzL3BvbGljeS10ZW1wbGF0ZS9jb25zdGFudHMvdGVtcGxhdGUuY29uc3RhbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsTUFBTSxDQUFDLE1BQU0sbUJBQW1CLEdBQzlCLG9GQUFvRixDQUFDO0FBQ3ZGLE1BQU0sQ0FBQyxNQUFNLHFCQUFxQixHQUFHLDBDQUEwQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGNvbnN0IE5PX0RBVEFfRk9VTkRfSU1BR0UgPVxyXG4gICdodHRwczovL2Nkbi52LWNvbXBseS5jb20vbGlicmFyaWVzL3dvcmtmbG93LWVuZ2luZS9hc3NldHMvd29ya2Zsb3cvc2VhcmNoLWRhdGEuc3ZnJztcclxuZXhwb3J0IGNvbnN0IE5PX0RBVEFfRk9VTkRfTUVTU0FHRSA9ICdObyByZXN1bHRzIG1hdGNoZWQgeW91ciBzZWFyY2ggY3JpdGVyaWEuJztcclxuIl19
|
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
import { NgModule } from '@angular/core';
|
|
2
|
+
import { CommonModule } from '@angular/common';
|
|
3
|
+
import { TemplateListTableComponent } from './template-list-table/template-list-table.component';
|
|
4
|
+
import { SelectTemplateListComponent } from './select-template-list/select-template-list.component';
|
|
5
|
+
import { TooltipModule } from '../../ui-kit/tooltip/tooltip.module';
|
|
6
|
+
import { PopoverModule } from '../../ui-kit/popover/popover.module';
|
|
7
|
+
import { NoDataModule } from '../no-data/no-data.module';
|
|
8
|
+
import { VLoaderModule } from '../v-loader/v-loader.module';
|
|
9
|
+
import { MultiSelectModule } from '../../ui-kit/multi-select/multi-select.module';
|
|
10
|
+
import { FloatingBarModule } from '../floating-bar/floating-bar.module';
|
|
11
|
+
import { TemplatePipesModule } from './template-pipes/template-pipes.module';
|
|
12
|
+
import { FormsModule } from '@angular/forms';
|
|
13
|
+
import { PipesModule } from '../../pipes/pipes.module';
|
|
14
|
+
import { FormgroupModule } from '../../formgroup/formgroup.module';
|
|
15
|
+
import { ViewPolicyModule } from './view-policy/view-policy.module';
|
|
16
|
+
import * as i0 from "@angular/core";
|
|
17
|
+
export class PolicyTemplateModule {
|
|
18
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: PolicyTemplateModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
|
19
|
+
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.2.12", ngImport: i0, type: PolicyTemplateModule, declarations: [TemplateListTableComponent, SelectTemplateListComponent], imports: [CommonModule,
|
|
20
|
+
TooltipModule,
|
|
21
|
+
PopoverModule,
|
|
22
|
+
NoDataModule,
|
|
23
|
+
VLoaderModule,
|
|
24
|
+
MultiSelectModule,
|
|
25
|
+
FloatingBarModule,
|
|
26
|
+
TemplatePipesModule,
|
|
27
|
+
FormsModule,
|
|
28
|
+
PipesModule,
|
|
29
|
+
FormgroupModule,
|
|
30
|
+
ViewPolicyModule], exports: [TemplateListTableComponent, SelectTemplateListComponent] }); }
|
|
31
|
+
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: PolicyTemplateModule, imports: [CommonModule,
|
|
32
|
+
TooltipModule,
|
|
33
|
+
PopoverModule,
|
|
34
|
+
NoDataModule,
|
|
35
|
+
VLoaderModule,
|
|
36
|
+
MultiSelectModule,
|
|
37
|
+
FloatingBarModule,
|
|
38
|
+
TemplatePipesModule,
|
|
39
|
+
FormsModule,
|
|
40
|
+
PipesModule,
|
|
41
|
+
FormgroupModule,
|
|
42
|
+
ViewPolicyModule] }); }
|
|
43
|
+
}
|
|
44
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: PolicyTemplateModule, decorators: [{
|
|
45
|
+
type: NgModule,
|
|
46
|
+
args: [{
|
|
47
|
+
declarations: [TemplateListTableComponent, SelectTemplateListComponent],
|
|
48
|
+
imports: [
|
|
49
|
+
CommonModule,
|
|
50
|
+
TooltipModule,
|
|
51
|
+
PopoverModule,
|
|
52
|
+
NoDataModule,
|
|
53
|
+
VLoaderModule,
|
|
54
|
+
MultiSelectModule,
|
|
55
|
+
FloatingBarModule,
|
|
56
|
+
TemplatePipesModule,
|
|
57
|
+
FormsModule,
|
|
58
|
+
PipesModule,
|
|
59
|
+
FormgroupModule,
|
|
60
|
+
ViewPolicyModule,
|
|
61
|
+
],
|
|
62
|
+
exports: [TemplateListTableComponent, SelectTemplateListComponent],
|
|
63
|
+
}]
|
|
64
|
+
}] });
|
|
65
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicG9saWN5LXRlbXBsYXRlLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3Z4LXdvcmtmbG93LWVuZ2luZS9zcmMvbGliL3NoYXJlZENvbXBvbmVudHMvcG9saWN5LXRlbXBsYXRlL3BvbGljeS10ZW1wbGF0ZS5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLDBCQUEwQixFQUFFLE1BQU0scURBQXFELENBQUM7QUFDakcsT0FBTyxFQUFFLDJCQUEyQixFQUFFLE1BQU0sdURBQXVELENBQUM7QUFDcEcsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHFDQUFxQyxDQUFDO0FBQ3BFLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxxQ0FBcUMsQ0FBQztBQUNwRSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sMkJBQTJCLENBQUM7QUFDekQsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLDZCQUE2QixDQUFDO0FBQzVELE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLCtDQUErQyxDQUFDO0FBQ2xGLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLHFDQUFxQyxDQUFDO0FBQ3hFLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLHdDQUF3QyxDQUFDO0FBQzdFLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUM3QyxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDdkQsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLGtDQUFrQyxDQUFDO0FBQ25FLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLGtDQUFrQyxDQUFDOztBQW9CcEUsTUFBTSxPQUFPLG9CQUFvQjsrR0FBcEIsb0JBQW9CO2dIQUFwQixvQkFBb0IsaUJBakJoQiwwQkFBMEIsRUFBRSwyQkFBMkIsYUFFcEUsWUFBWTtZQUNaLGFBQWE7WUFDYixhQUFhO1lBQ2IsWUFBWTtZQUNaLGFBQWE7WUFDYixpQkFBaUI7WUFDakIsaUJBQWlCO1lBQ2pCLG1CQUFtQjtZQUNuQixXQUFXO1lBQ1gsV0FBVztZQUNYLGVBQWU7WUFDZixnQkFBZ0IsYUFFUiwwQkFBMEIsRUFBRSwyQkFBMkI7Z0hBRXRELG9CQUFvQixZQWY3QixZQUFZO1lBQ1osYUFBYTtZQUNiLGFBQWE7WUFDYixZQUFZO1lBQ1osYUFBYTtZQUNiLGlCQUFpQjtZQUNqQixpQkFBaUI7WUFDakIsbUJBQW1CO1lBQ25CLFdBQVc7WUFDWCxXQUFXO1lBQ1gsZUFBZTtZQUNmLGdCQUFnQjs7NEZBSVAsb0JBQW9CO2tCQWxCaEMsUUFBUTttQkFBQztvQkFDUixZQUFZLEVBQUUsQ0FBQywwQkFBMEIsRUFBRSwyQkFBMkIsQ0FBQztvQkFDdkUsT0FBTyxFQUFFO3dCQUNQLFlBQVk7d0JBQ1osYUFBYTt3QkFDYixhQUFhO3dCQUNiLFlBQVk7d0JBQ1osYUFBYTt3QkFDYixpQkFBaUI7d0JBQ2pCLGlCQUFpQjt3QkFDakIsbUJBQW1CO3dCQUNuQixXQUFXO3dCQUNYLFdBQVc7d0JBQ1gsZUFBZTt3QkFDZixnQkFBZ0I7cUJBQ2pCO29CQUNELE9BQU8sRUFBRSxDQUFDLDBCQUEwQixFQUFFLDJCQUEyQixDQUFDO2lCQUNuRSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgVGVtcGxhdGVMaXN0VGFibGVDb21wb25lbnQgfSBmcm9tICcuL3RlbXBsYXRlLWxpc3QtdGFibGUvdGVtcGxhdGUtbGlzdC10YWJsZS5jb21wb25lbnQnO1xuaW1wb3J0IHsgU2VsZWN0VGVtcGxhdGVMaXN0Q29tcG9uZW50IH0gZnJvbSAnLi9zZWxlY3QtdGVtcGxhdGUtbGlzdC9zZWxlY3QtdGVtcGxhdGUtbGlzdC5jb21wb25lbnQnO1xuaW1wb3J0IHsgVG9vbHRpcE1vZHVsZSB9IGZyb20gJy4uLy4uL3VpLWtpdC90b29sdGlwL3Rvb2x0aXAubW9kdWxlJztcbmltcG9ydCB7IFBvcG92ZXJNb2R1bGUgfSBmcm9tICcuLi8uLi91aS1raXQvcG9wb3Zlci9wb3BvdmVyLm1vZHVsZSc7XG5pbXBvcnQgeyBOb0RhdGFNb2R1bGUgfSBmcm9tICcuLi9uby1kYXRhL25vLWRhdGEubW9kdWxlJztcbmltcG9ydCB7IFZMb2FkZXJNb2R1bGUgfSBmcm9tICcuLi92LWxvYWRlci92LWxvYWRlci5tb2R1bGUnO1xuaW1wb3J0IHsgTXVsdGlTZWxlY3RNb2R1bGUgfSBmcm9tICcuLi8uLi91aS1raXQvbXVsdGktc2VsZWN0L211bHRpLXNlbGVjdC5tb2R1bGUnO1xuaW1wb3J0IHsgRmxvYXRpbmdCYXJNb2R1bGUgfSBmcm9tICcuLi9mbG9hdGluZy1iYXIvZmxvYXRpbmctYmFyLm1vZHVsZSc7XG5pbXBvcnQgeyBUZW1wbGF0ZVBpcGVzTW9kdWxlIH0gZnJvbSAnLi90ZW1wbGF0ZS1waXBlcy90ZW1wbGF0ZS1waXBlcy5tb2R1bGUnO1xuaW1wb3J0IHsgRm9ybXNNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5pbXBvcnQgeyBQaXBlc01vZHVsZSB9IGZyb20gJy4uLy4uL3BpcGVzL3BpcGVzLm1vZHVsZSc7XG5pbXBvcnQgeyBGb3JtZ3JvdXBNb2R1bGUgfSBmcm9tICcuLi8uLi9mb3JtZ3JvdXAvZm9ybWdyb3VwLm1vZHVsZSc7XG5pbXBvcnQgeyBWaWV3UG9saWN5TW9kdWxlIH0gZnJvbSAnLi92aWV3LXBvbGljeS92aWV3LXBvbGljeS5tb2R1bGUnO1xuXG5ATmdNb2R1bGUoe1xuICBkZWNsYXJhdGlvbnM6IFtUZW1wbGF0ZUxpc3RUYWJsZUNvbXBvbmVudCwgU2VsZWN0VGVtcGxhdGVMaXN0Q29tcG9uZW50XSxcbiAgaW1wb3J0czogW1xuICAgIENvbW1vbk1vZHVsZSxcbiAgICBUb29sdGlwTW9kdWxlLFxuICAgIFBvcG92ZXJNb2R1bGUsXG4gICAgTm9EYXRhTW9kdWxlLFxuICAgIFZMb2FkZXJNb2R1bGUsXG4gICAgTXVsdGlTZWxlY3RNb2R1bGUsXG4gICAgRmxvYXRpbmdCYXJNb2R1bGUsXG4gICAgVGVtcGxhdGVQaXBlc01vZHVsZSxcbiAgICBGb3Jtc01vZHVsZSxcbiAgICBQaXBlc01vZHVsZSxcbiAgICBGb3JtZ3JvdXBNb2R1bGUsXG4gICAgVmlld1BvbGljeU1vZHVsZSxcbiAgXSxcbiAgZXhwb3J0czogW1RlbXBsYXRlTGlzdFRhYmxlQ29tcG9uZW50LCBTZWxlY3RUZW1wbGF0ZUxpc3RDb21wb25lbnRdLFxufSlcbmV4cG9ydCBjbGFzcyBQb2xpY3lUZW1wbGF0ZU1vZHVsZSB7fVxuIl19
|
|
@@ -0,0 +1,206 @@
|
|
|
1
|
+
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
2
|
+
import { forkJoin } from 'rxjs';
|
|
3
|
+
import { NO_DATA_FOUND_IMAGE, NO_DATA_FOUND_MESSAGE, } from '../constants/template.constant';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "../services/template.service";
|
|
6
|
+
import * as i2 from "../../../workflow-services/policy.service";
|
|
7
|
+
import * as i3 from "@angular/common";
|
|
8
|
+
import * as i4 from "../../../ui-kit/tooltip/tooltip.directive";
|
|
9
|
+
import * as i5 from "../../no-data/no-data.component";
|
|
10
|
+
import * as i6 from "../../v-loader/loader-inline/loader-inline.component";
|
|
11
|
+
import * as i7 from "../../../ui-kit/multi-select/cs-multiselect/cs-multiselect.component";
|
|
12
|
+
import * as i8 from "../../../ui-kit/multi-select/cs-multiselect-option/cs-multiselect-option.component";
|
|
13
|
+
import * as i9 from "../../floating-bar/floating-bar.component";
|
|
14
|
+
import * as i10 from "@angular/forms";
|
|
15
|
+
import * as i11 from "../view-policy/view-policy/view-policy.component";
|
|
16
|
+
import * as i12 from "../template-list-table/template-list-table.component";
|
|
17
|
+
import * as i13 from "../template-pipes/search-template.pipe";
|
|
18
|
+
export class SelectTemplateListComponent {
|
|
19
|
+
constructor(templateService, policyService) {
|
|
20
|
+
this.templateService = templateService;
|
|
21
|
+
this.policyService = policyService;
|
|
22
|
+
this.animation = false;
|
|
23
|
+
this.defaultTemplates = [];
|
|
24
|
+
this.customTemplates = null;
|
|
25
|
+
this.templateList = [];
|
|
26
|
+
this.currentTab = 'VCOMPLY';
|
|
27
|
+
this.loader = false;
|
|
28
|
+
this.categoryList = [];
|
|
29
|
+
this.defaultCategoryList = [];
|
|
30
|
+
this.userCreatedCategoryList = [];
|
|
31
|
+
this.sortStatus = -1;
|
|
32
|
+
this.searchCategory = '';
|
|
33
|
+
this.searchTemplate = '';
|
|
34
|
+
this.selectedCategory = [];
|
|
35
|
+
this.NO_DATA_FOUND_IMAGE = NO_DATA_FOUND_IMAGE;
|
|
36
|
+
this.NO_DATA_FOUND_MESSAGE = NO_DATA_FOUND_MESSAGE;
|
|
37
|
+
this.selectedTemplate = [];
|
|
38
|
+
this.isPreview = false;
|
|
39
|
+
this.docData = null;
|
|
40
|
+
this.selectedCategoryId = [];
|
|
41
|
+
this.onTemplateSelect = new EventEmitter();
|
|
42
|
+
}
|
|
43
|
+
ngOnInit() {
|
|
44
|
+
this.setAnimation();
|
|
45
|
+
this.getTemplate();
|
|
46
|
+
}
|
|
47
|
+
setAnimation() {
|
|
48
|
+
this.animation = true;
|
|
49
|
+
setTimeout(() => {
|
|
50
|
+
this.animation = false;
|
|
51
|
+
}, 300);
|
|
52
|
+
}
|
|
53
|
+
switchTab(tab) {
|
|
54
|
+
this.currentTab = tab;
|
|
55
|
+
this.selectedCategory = [];
|
|
56
|
+
if (tab === 'VCOMPLY') {
|
|
57
|
+
this.templateList = [...this.defaultTemplates];
|
|
58
|
+
this.categoryList = this.defaultCategoryList;
|
|
59
|
+
}
|
|
60
|
+
else {
|
|
61
|
+
if (this.customTemplates === null) {
|
|
62
|
+
this.getCustomTemplates();
|
|
63
|
+
}
|
|
64
|
+
else {
|
|
65
|
+
this.templateList = [...this.customTemplates];
|
|
66
|
+
this.categoryList = this.userCreatedCategoryList;
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
getCustomTemplates() {
|
|
71
|
+
this.loader = true;
|
|
72
|
+
const payload = {
|
|
73
|
+
type: 'custom',
|
|
74
|
+
};
|
|
75
|
+
this.templateService.fetchTemplates(payload).subscribe((res) => {
|
|
76
|
+
this.customTemplates = res?.templates ?? [];
|
|
77
|
+
this.mapCustomTemplate();
|
|
78
|
+
});
|
|
79
|
+
}
|
|
80
|
+
mapCustomTemplate() {
|
|
81
|
+
this.policyService.getCategoriesList().subscribe((res) => {
|
|
82
|
+
this.userCreatedCategoryList = [...res];
|
|
83
|
+
this.userCreatedCategoryList = this.userCreatedCategoryList.map((res) => {
|
|
84
|
+
console.log('res', res);
|
|
85
|
+
const parentItems = [...new Set(res?.parent_items ?? [])];
|
|
86
|
+
parentItems.unshift(res.item_name);
|
|
87
|
+
return {
|
|
88
|
+
...res,
|
|
89
|
+
name: parentItems?.join(' < '),
|
|
90
|
+
parent_items: res?.parent_items.reverse(),
|
|
91
|
+
};
|
|
92
|
+
});
|
|
93
|
+
if (this.customTemplates) {
|
|
94
|
+
this.customTemplates = this.customTemplates.map((template) => {
|
|
95
|
+
return {
|
|
96
|
+
...template,
|
|
97
|
+
categoryDetails: this.userCreatedCategoryList.filter((category) => template?.categoryId?.includes(category.item_id)),
|
|
98
|
+
};
|
|
99
|
+
});
|
|
100
|
+
console.log('userCreatedCategoryList dxwde', this.userCreatedCategoryList, this.customTemplates, this.customTemplates);
|
|
101
|
+
}
|
|
102
|
+
this.templateList = [...new Set(this.customTemplates ?? [])];
|
|
103
|
+
this.loader = false;
|
|
104
|
+
this.categoryList = this.userCreatedCategoryList;
|
|
105
|
+
});
|
|
106
|
+
}
|
|
107
|
+
getTemplate() {
|
|
108
|
+
this.loader = true;
|
|
109
|
+
const payload = {
|
|
110
|
+
type: 'default',
|
|
111
|
+
};
|
|
112
|
+
forkJoin([
|
|
113
|
+
this.templateService.fetchTemplates(payload),
|
|
114
|
+
this.templateService.fetchDefaultCategories(),
|
|
115
|
+
]).subscribe((res) => {
|
|
116
|
+
this.defaultTemplates = res[0]?.templates;
|
|
117
|
+
this.defaultCategoryList = res[1];
|
|
118
|
+
this.mapDefaultTemplate();
|
|
119
|
+
this.categoryList = [...new Set(this.defaultCategoryList)];
|
|
120
|
+
this.templateList = this.defaultTemplates;
|
|
121
|
+
this.loader = false;
|
|
122
|
+
});
|
|
123
|
+
}
|
|
124
|
+
mapDefaultTemplate() {
|
|
125
|
+
this.defaultTemplates = this.defaultTemplates.map((template) => {
|
|
126
|
+
const category = this.defaultCategoryList.filter((category) => template?.categoryId?.includes(category.item_id));
|
|
127
|
+
return {
|
|
128
|
+
...template,
|
|
129
|
+
categoryDetails: category,
|
|
130
|
+
};
|
|
131
|
+
});
|
|
132
|
+
}
|
|
133
|
+
sortBy(key) {
|
|
134
|
+
this.sortStatus = this.sortStatus * -1;
|
|
135
|
+
this.templateList = this.templateService.sortByKey(this.templateList, key, this.sortStatus);
|
|
136
|
+
}
|
|
137
|
+
onSelectCategory(category, event) {
|
|
138
|
+
if (event.target.checked) {
|
|
139
|
+
this.selectedCategory.push(category?.item_id);
|
|
140
|
+
}
|
|
141
|
+
else {
|
|
142
|
+
this.selectedCategory = this.selectedCategory.filter((id) => id !== category?.item_id);
|
|
143
|
+
}
|
|
144
|
+
this.selectedCategory = [...new Set(this.selectedCategory)];
|
|
145
|
+
}
|
|
146
|
+
onApplyFilter(event) {
|
|
147
|
+
if (!event) {
|
|
148
|
+
this.selectedCategory = [];
|
|
149
|
+
return;
|
|
150
|
+
}
|
|
151
|
+
let selectedTemplate = this.currentTab === 'VCOMPLY'
|
|
152
|
+
? this.defaultTemplates
|
|
153
|
+
: this.customTemplates ?? [];
|
|
154
|
+
selectedTemplate = [...new Set(selectedTemplate)];
|
|
155
|
+
if (this.selectedCategory.length === 0) {
|
|
156
|
+
this.templateList = selectedTemplate;
|
|
157
|
+
return;
|
|
158
|
+
}
|
|
159
|
+
this.templateList = selectedTemplate.filter((template) => {
|
|
160
|
+
return template?.categoryId?.some((id) => this.selectedCategory.includes(id));
|
|
161
|
+
});
|
|
162
|
+
}
|
|
163
|
+
onSelectTemplate(template) {
|
|
164
|
+
this.selectedTemplate = [template];
|
|
165
|
+
}
|
|
166
|
+
save() {
|
|
167
|
+
this.onTemplateSelect.emit(this.selectedTemplate);
|
|
168
|
+
}
|
|
169
|
+
close() {
|
|
170
|
+
this.onTemplateSelect.emit([]);
|
|
171
|
+
}
|
|
172
|
+
deleteEvent() {
|
|
173
|
+
this.selectedTemplate = [];
|
|
174
|
+
}
|
|
175
|
+
onPreview(details) {
|
|
176
|
+
this.isPreview = true;
|
|
177
|
+
this.getPreviewData(details?._id);
|
|
178
|
+
this.previewTemplate = details;
|
|
179
|
+
}
|
|
180
|
+
onClosePreview() {
|
|
181
|
+
this.isPreview = false;
|
|
182
|
+
this.docData = null;
|
|
183
|
+
this.previewTemplate = null;
|
|
184
|
+
}
|
|
185
|
+
getPreviewData(templateId) {
|
|
186
|
+
this.loader = true;
|
|
187
|
+
this.templateService.getTemplateContent(templateId).subscribe({
|
|
188
|
+
next: (res) => {
|
|
189
|
+
const { response } = res;
|
|
190
|
+
this.loader = false;
|
|
191
|
+
this.docData = response;
|
|
192
|
+
},
|
|
193
|
+
});
|
|
194
|
+
}
|
|
195
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: SelectTemplateListComponent, deps: [{ token: i1.TemplateService }, { token: i2.PolicyService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
196
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: SelectTemplateListComponent, selector: "app-select-template-list", inputs: { selectedCategoryId: "selectedCategoryId" }, outputs: { onTemplateSelect: "onTemplateSelect" }, ngImport: i0, template: "<div\r\n class=\"select-template-list\"\r\n [class.animate]=\"animation\"\r\n [class.withPreview]=\"isPreview\"\r\n>\r\n <ng-container *ngIf=\"!isPreview\">\r\n <div\r\n class=\"select-template-list-head vx-d-flex vx-align-center vx-justify-between vx-pl-4 vx-pr-4\"\r\n >\r\n <div class=\"vx-fs-14 vx-fw-500 vx-label-txt\">Select a Template</div>\r\n </div>\r\n <div class=\"select-template-list-body\">\r\n <app-loader-inline *ngIf=\"loader\"></app-loader-inline>\r\n\r\n <div class=\"select-template-list-tab vx-d-flex vx-align-center vx-mb-2\">\r\n <button\r\n (click)=\"switchTab('VCOMPLY')\"\r\n class=\"tab-btn vx-fs-11 vx-fw-500 vx-tt-uppercase vx-p-0 vx-pb-2 vx-m-0 vx-d-flex vx-align-center vx-lh-4\"\r\n [class.active]=\"currentTab === 'VCOMPLY'\"\r\n >\r\n VCOMPLY TEMPLATES\r\n </button>\r\n <button\r\n (click)=\"switchTab('USER_CREATED')\"\r\n class=\"tab-btn vx-fs-11 vx-fw-500 vx-tt-uppercase vx-p-0 vx-pb-2 vx-m-0 vx-d-flex vx-align-center vx-lh-4\"\r\n [class.active]=\"currentTab === 'USER_CREATED'\"\r\n >\r\n USER-CREATED TEMPLATES\r\n </button>\r\n </div>\r\n <div class=\"search-block vx-mb-2\">\r\n <i class=\"icons\"></i>\r\n <input type=\"text\" [(ngModel)]=\"searchTemplate\" placeholder=\"Search\" />\r\n </div>\r\n <div class=\"body-top vx-d-flex vx-align-center vx-justify-end vx-mb-2\">\r\n <cs-multi-select\r\n (searchText)=\"searchCategory = $event\"\r\n [placeholder]=\"'Select Category'\"\r\n [value]=\"selectedCategory\"\r\n (applyFilter)=\"onApplyFilter($event)\"\r\n >\r\n <ng-container\r\n *ngFor=\"\r\n let eachCategory of categoryList\r\n | SearchByKeys : ['name'] : searchCategory\r\n \"\r\n >\r\n <cs-multi-select-option\r\n [appTooltip]=\"eachCategory?.name\"\r\n placement=\"bottom-left\"\r\n delay=\"0\"\r\n [value]=\"eachCategory?.item_id\"\r\n (change)=\"onSelectCategory(eachCategory, $event)\"\r\n [tooltipMandatory]=\"true\"\r\n >\r\n {{ eachCategory?.name }}\r\n </cs-multi-select-option>\r\n </ng-container>\r\n </cs-multi-select>\r\n </div>\r\n <div class=\"body-inner vx-mb-1\">\r\n <ng-container *ngIf=\"!loader\">\r\n <ng-container\r\n *ngIf=\"\r\n templateList\r\n | SearchByKeys\r\n : ['name', 'categoryDetails']\r\n : searchTemplate as allTemplate\r\n \"\r\n >\r\n <app-template-list-table\r\n *ngIf=\"allTemplate.length\"\r\n [templateList]=\"allTemplate\"\r\n [loader]=\"loader\"\r\n [categoryList]=\"categoryList\"\r\n [selectedTemplate]=\"selectedTemplate[0]\"\r\n (onSort)=\"sortBy($event)\"\r\n (onSelectTemplate)=\"onSelectTemplate($event)\"\r\n (onPreview)=\"onPreview($event)\"\r\n ></app-template-list-table>\r\n <app-no-data\r\n *ngIf=\"!allTemplate?.length\"\r\n [noDataImage]=\"NO_DATA_FOUND_IMAGE\"\r\n [noDataText]=\"NO_DATA_FOUND_MESSAGE\"\r\n ></app-no-data>\r\n </ng-container>\r\n </ng-container>\r\n </div>\r\n\r\n <app-floating-bar\r\n (closeEvent)=\"save()\"\r\n (closeList)=\"close()\"\r\n [isDisabled]=\"selectedTemplate?.length === 0\"\r\n [selectedData]=\"selectedTemplate\"\r\n [displayElementKey]=\"'name'\"\r\n [singularText]=\"'Template Selected'\"\r\n (deleteEvent)=\"deleteEvent()\"\r\n >\r\n </app-floating-bar>\r\n </div>\r\n </ng-container>\r\n <ng-container *ngIf=\"isPreview\">\r\n <div\r\n class=\"select-template-list-head vx-d-flex vx-align-center vx-pl-4 vx-pr-4\"\r\n >\r\n <button\r\n (click)=\"onClosePreview()\"\r\n class=\"previewBtn vx-fs-14 vx-fw-500 vx-label-txt vx-p-0 vx-m-0 vx-d-flex vx-align-center\"\r\n >\r\n <i class=\"icons vx-mr-1\"></i>Preview\r\n </button>\r\n <div\r\n class=\"template-name vx-fs-14 vx-ml-1\"\r\n [appTooltip]=\"previewTemplate?.name\"\r\n placement=\"bottom-left\"\r\n delay=\"0\"\r\n type=\"black\"\r\n [tooltipMandatory]=\"false\"\r\n >\r\n {{ previewTemplate?.name }}\r\n </div>\r\n </div>\r\n <div class=\"preview-template-body vx-d-flex vx-justify-center\">\r\n <app-loader-inline *ngIf=\"loader\"></app-loader-inline>\r\n\r\n <div *ngIf=\"!loader\" class=\"preview-template-body-inner\">\r\n <app-view-policy #view_policy [contents]=\"docData\"> </app-view-policy>\r\n </div>\r\n </div>\r\n </ng-container>\r\n</div>\r\n", styles: ["@import\"https://cdn.v-comply.com/design-system/css/icons/icons.css\";@import\"https://cdn.v-comply.com/design-system/css/display/display.css\";@import\"https://cdn.v-comply.com/design-system/css/alignment/alignment.css\";@import\"https://cdn.v-comply.com/design-system/css/text/text.css\";@import\"https://cdn.v-comply.com/design-system/css/color/color.css\";@import\"https://cdn.v-comply.com/design-system/css/width/width.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-top.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-bottom.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-left.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-right.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-top.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-bottom.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-left.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-right.css\";::ng-deep .select-template-list{background:#fff;position:fixed;inset:0 500px 0 0;z-index:10}::ng-deep .select-template-list:before{background:#1e5dd3;content:\"\";position:absolute;top:0;left:0;right:0;width:100%;height:3px}::ng-deep .select-template-list:after{background:#f1f1f1;content:\"\";position:absolute;top:3px;right:0;width:1px;height:calc(100% - 3px)}::ng-deep .select-template-list.withPreview{background:#f2f2f5}::ng-deep .select-template-list-head{background:#fbfbfb;height:2.75rem;border-bottom:1px solid #f1f1f1}::ng-deep .select-template-list-head button.previewBtn{background:transparent;border-radius:0;border:none}::ng-deep .select-template-list-head .template-name{color:#787a8c;text-overflow:ellipsis;white-space:nowrap;overflow:hidden;width:calc(100% - 5rem)}::ng-deep .select-template-list-tab{border-bottom:1px solid #dbdbdb}::ng-deep .select-template-list-tab button.tab-btn{background:transparent;border-radius:0;border:none;border-bottom:.1875rem solid transparent;color:#565a6f;height:23px;margin-right:1.75rem!important}::ng-deep .select-template-list-tab button.active{pointer-events:none}::ng-deep .select-template-list-tab button.active.tab-btn{border-color:#1e5dd3;color:#1e5dd3}::ng-deep .select-template-list-body{background:#fff;height:calc(100vh - 2.75rem);padding:2rem}::ng-deep .select-template-list-body .search-block{position:relative}::ng-deep .select-template-list-body .search-block input{height:2.75rem;line-height:1.5rem;padding:.5rem 1rem .5rem 2.5rem;outline:none;border:1px solid #7475763f;border-radius:.25rem;width:100%;font-size:14px;color:#747576}::ng-deep .select-template-list-body .search-block input:focus{border-color:#1e5dd3}::ng-deep .select-template-list-body .search-block i{position:absolute;left:1rem;top:1rem;pointer-events:none;color:#f1f1f1;font-size:12px}::ng-deep .select-template-list-body .body-top cs-multi-select{display:block;width:320px}::ng-deep .select-template-list-body .body-inner{height:calc(100% - 180px);width:calc(100% + 2rem);padding-right:2rem;overflow:hidden;overflow-y:auto;scrollbar-width:thin}::ng-deep .select-template-list-body .body-inner::-webkit-scrollbar-track{background-color:#f1f1f1}::ng-deep .select-template-list-body .body-inner::-webkit-scrollbar-thumb{border-radius:3px;background-color:#dbdbdb;position:absolute}::ng-deep .select-template-list .preview-template-body{margin-top:3rem;height:calc(100% - 6rem)}::ng-deep .select-template-list .preview-template-body-inner{background:#fff;border-radius:8px 8px 0 0;border:1px solid #dbdbdb;width:50rem}::ng-deep .select-template-list .preview-template-body-inner app-view-policy{display:block;height:100%}::ng-deep .select-template-list .preview-template-body-inner app-view-policy ejs-documenteditorcontainer{height:100%!important;min-height:unset!important}::ng-deep .select-template-list .preview-template-body-inner app-view-policy ejs-documenteditorcontainer .e-de-ctn{height:100%}::ng-deep .select-template-list .preview-template-body-inner app-view-policy ejs-documenteditorcontainer .e-de-ctn .e-de-ctnr-properties-pane{height:calc(100% - 30px)}::ng-deep .select-template-list .preview-template-body-inner app-view-policy ejs-documenteditorcontainer .e-de-ctn .e-de-ctnr-properties-pane .e-control.e-documenteditor{height:100%!important;min-height:unset!important}::ng-deep .select-template-list .preview-template-body-inner app-view-policy ejs-documenteditorcontainer .e-de-ctn .e-de-ctnr-properties-pane .e-control.e-documenteditor .e-documenteditor-optionspane{height:100%}\n"], dependencies: [{ kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.ToolTipDirective, selector: "[appTooltip]", inputs: ["appTooltip", "placement", "type", "tooltipMandatory", "showTooltip", "animate"] }, { kind: "component", type: i5.NoDataComponent, selector: "app-no-data", inputs: ["action", "noDataImage", "noDataText", "noDataButton", "noDataSecButton", "altText", "smallButton", "button"], outputs: ["buttonAction"] }, { kind: "component", type: i6.LoaderInlineComponent, selector: "app-loader-inline" }, { kind: "component", type: i7.CsMultiselectComponent, selector: "cs-multi-select", inputs: ["isRequired", "dropdownLabel", "dropdownSubLabel", "disabled", "placeholder", "searchPlaceholder", "value", "selectedItem"], outputs: ["valueChange", "applyFilter", "searchText", "resetSelectedData"] }, { kind: "component", type: i8.CsMultiselectOptionComponent, selector: "cs-multi-select-option", inputs: ["value"] }, { kind: "component", type: i9.FloatingBarComponent, selector: "app-floating-bar", inputs: ["selectedData", "selectedGroups", "displayElementKey", "elementId", "singularText", "pluralText", "showNextButton", "showFrequencyText", "showWorkflow", "workflowText", "currentFrequency", "isDisabled", "workflowList", "selectedWorkflow", "workflowPlaceHolder", "mode", "defaultSelected", "groupsEnabled", "nonRemovableUsersList", "removePosition"], outputs: ["closeEvent", "deleteEvent", "closeList", "deleteGroupEvent", "workflowTypeChanged"] }, { kind: "directive", type: i10.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i10.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i10.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i11.ViewPolicyComponent, selector: "app-view-policy", inputs: ["contents", "userName"] }, { kind: "component", type: i12.TemplateListTableComponent, selector: "app-template-list-table", inputs: ["selectedTemplate", "templateList", "loader", "categoryList"], outputs: ["onSort", "onSelectTemplate", "onPreview"] }, { kind: "pipe", type: i13.SearchByKeysPipe, name: "SearchByKeys" }] }); }
|
|
197
|
+
}
|
|
198
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: SelectTemplateListComponent, decorators: [{
|
|
199
|
+
type: Component,
|
|
200
|
+
args: [{ selector: 'app-select-template-list', template: "<div\r\n class=\"select-template-list\"\r\n [class.animate]=\"animation\"\r\n [class.withPreview]=\"isPreview\"\r\n>\r\n <ng-container *ngIf=\"!isPreview\">\r\n <div\r\n class=\"select-template-list-head vx-d-flex vx-align-center vx-justify-between vx-pl-4 vx-pr-4\"\r\n >\r\n <div class=\"vx-fs-14 vx-fw-500 vx-label-txt\">Select a Template</div>\r\n </div>\r\n <div class=\"select-template-list-body\">\r\n <app-loader-inline *ngIf=\"loader\"></app-loader-inline>\r\n\r\n <div class=\"select-template-list-tab vx-d-flex vx-align-center vx-mb-2\">\r\n <button\r\n (click)=\"switchTab('VCOMPLY')\"\r\n class=\"tab-btn vx-fs-11 vx-fw-500 vx-tt-uppercase vx-p-0 vx-pb-2 vx-m-0 vx-d-flex vx-align-center vx-lh-4\"\r\n [class.active]=\"currentTab === 'VCOMPLY'\"\r\n >\r\n VCOMPLY TEMPLATES\r\n </button>\r\n <button\r\n (click)=\"switchTab('USER_CREATED')\"\r\n class=\"tab-btn vx-fs-11 vx-fw-500 vx-tt-uppercase vx-p-0 vx-pb-2 vx-m-0 vx-d-flex vx-align-center vx-lh-4\"\r\n [class.active]=\"currentTab === 'USER_CREATED'\"\r\n >\r\n USER-CREATED TEMPLATES\r\n </button>\r\n </div>\r\n <div class=\"search-block vx-mb-2\">\r\n <i class=\"icons\"></i>\r\n <input type=\"text\" [(ngModel)]=\"searchTemplate\" placeholder=\"Search\" />\r\n </div>\r\n <div class=\"body-top vx-d-flex vx-align-center vx-justify-end vx-mb-2\">\r\n <cs-multi-select\r\n (searchText)=\"searchCategory = $event\"\r\n [placeholder]=\"'Select Category'\"\r\n [value]=\"selectedCategory\"\r\n (applyFilter)=\"onApplyFilter($event)\"\r\n >\r\n <ng-container\r\n *ngFor=\"\r\n let eachCategory of categoryList\r\n | SearchByKeys : ['name'] : searchCategory\r\n \"\r\n >\r\n <cs-multi-select-option\r\n [appTooltip]=\"eachCategory?.name\"\r\n placement=\"bottom-left\"\r\n delay=\"0\"\r\n [value]=\"eachCategory?.item_id\"\r\n (change)=\"onSelectCategory(eachCategory, $event)\"\r\n [tooltipMandatory]=\"true\"\r\n >\r\n {{ eachCategory?.name }}\r\n </cs-multi-select-option>\r\n </ng-container>\r\n </cs-multi-select>\r\n </div>\r\n <div class=\"body-inner vx-mb-1\">\r\n <ng-container *ngIf=\"!loader\">\r\n <ng-container\r\n *ngIf=\"\r\n templateList\r\n | SearchByKeys\r\n : ['name', 'categoryDetails']\r\n : searchTemplate as allTemplate\r\n \"\r\n >\r\n <app-template-list-table\r\n *ngIf=\"allTemplate.length\"\r\n [templateList]=\"allTemplate\"\r\n [loader]=\"loader\"\r\n [categoryList]=\"categoryList\"\r\n [selectedTemplate]=\"selectedTemplate[0]\"\r\n (onSort)=\"sortBy($event)\"\r\n (onSelectTemplate)=\"onSelectTemplate($event)\"\r\n (onPreview)=\"onPreview($event)\"\r\n ></app-template-list-table>\r\n <app-no-data\r\n *ngIf=\"!allTemplate?.length\"\r\n [noDataImage]=\"NO_DATA_FOUND_IMAGE\"\r\n [noDataText]=\"NO_DATA_FOUND_MESSAGE\"\r\n ></app-no-data>\r\n </ng-container>\r\n </ng-container>\r\n </div>\r\n\r\n <app-floating-bar\r\n (closeEvent)=\"save()\"\r\n (closeList)=\"close()\"\r\n [isDisabled]=\"selectedTemplate?.length === 0\"\r\n [selectedData]=\"selectedTemplate\"\r\n [displayElementKey]=\"'name'\"\r\n [singularText]=\"'Template Selected'\"\r\n (deleteEvent)=\"deleteEvent()\"\r\n >\r\n </app-floating-bar>\r\n </div>\r\n </ng-container>\r\n <ng-container *ngIf=\"isPreview\">\r\n <div\r\n class=\"select-template-list-head vx-d-flex vx-align-center vx-pl-4 vx-pr-4\"\r\n >\r\n <button\r\n (click)=\"onClosePreview()\"\r\n class=\"previewBtn vx-fs-14 vx-fw-500 vx-label-txt vx-p-0 vx-m-0 vx-d-flex vx-align-center\"\r\n >\r\n <i class=\"icons vx-mr-1\"></i>Preview\r\n </button>\r\n <div\r\n class=\"template-name vx-fs-14 vx-ml-1\"\r\n [appTooltip]=\"previewTemplate?.name\"\r\n placement=\"bottom-left\"\r\n delay=\"0\"\r\n type=\"black\"\r\n [tooltipMandatory]=\"false\"\r\n >\r\n {{ previewTemplate?.name }}\r\n </div>\r\n </div>\r\n <div class=\"preview-template-body vx-d-flex vx-justify-center\">\r\n <app-loader-inline *ngIf=\"loader\"></app-loader-inline>\r\n\r\n <div *ngIf=\"!loader\" class=\"preview-template-body-inner\">\r\n <app-view-policy #view_policy [contents]=\"docData\"> </app-view-policy>\r\n </div>\r\n </div>\r\n </ng-container>\r\n</div>\r\n", styles: ["@import\"https://cdn.v-comply.com/design-system/css/icons/icons.css\";@import\"https://cdn.v-comply.com/design-system/css/display/display.css\";@import\"https://cdn.v-comply.com/design-system/css/alignment/alignment.css\";@import\"https://cdn.v-comply.com/design-system/css/text/text.css\";@import\"https://cdn.v-comply.com/design-system/css/color/color.css\";@import\"https://cdn.v-comply.com/design-system/css/width/width.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-top.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-bottom.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-left.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-right.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-top.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-bottom.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-left.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-right.css\";::ng-deep .select-template-list{background:#fff;position:fixed;inset:0 500px 0 0;z-index:10}::ng-deep .select-template-list:before{background:#1e5dd3;content:\"\";position:absolute;top:0;left:0;right:0;width:100%;height:3px}::ng-deep .select-template-list:after{background:#f1f1f1;content:\"\";position:absolute;top:3px;right:0;width:1px;height:calc(100% - 3px)}::ng-deep .select-template-list.withPreview{background:#f2f2f5}::ng-deep .select-template-list-head{background:#fbfbfb;height:2.75rem;border-bottom:1px solid #f1f1f1}::ng-deep .select-template-list-head button.previewBtn{background:transparent;border-radius:0;border:none}::ng-deep .select-template-list-head .template-name{color:#787a8c;text-overflow:ellipsis;white-space:nowrap;overflow:hidden;width:calc(100% - 5rem)}::ng-deep .select-template-list-tab{border-bottom:1px solid #dbdbdb}::ng-deep .select-template-list-tab button.tab-btn{background:transparent;border-radius:0;border:none;border-bottom:.1875rem solid transparent;color:#565a6f;height:23px;margin-right:1.75rem!important}::ng-deep .select-template-list-tab button.active{pointer-events:none}::ng-deep .select-template-list-tab button.active.tab-btn{border-color:#1e5dd3;color:#1e5dd3}::ng-deep .select-template-list-body{background:#fff;height:calc(100vh - 2.75rem);padding:2rem}::ng-deep .select-template-list-body .search-block{position:relative}::ng-deep .select-template-list-body .search-block input{height:2.75rem;line-height:1.5rem;padding:.5rem 1rem .5rem 2.5rem;outline:none;border:1px solid #7475763f;border-radius:.25rem;width:100%;font-size:14px;color:#747576}::ng-deep .select-template-list-body .search-block input:focus{border-color:#1e5dd3}::ng-deep .select-template-list-body .search-block i{position:absolute;left:1rem;top:1rem;pointer-events:none;color:#f1f1f1;font-size:12px}::ng-deep .select-template-list-body .body-top cs-multi-select{display:block;width:320px}::ng-deep .select-template-list-body .body-inner{height:calc(100% - 180px);width:calc(100% + 2rem);padding-right:2rem;overflow:hidden;overflow-y:auto;scrollbar-width:thin}::ng-deep .select-template-list-body .body-inner::-webkit-scrollbar-track{background-color:#f1f1f1}::ng-deep .select-template-list-body .body-inner::-webkit-scrollbar-thumb{border-radius:3px;background-color:#dbdbdb;position:absolute}::ng-deep .select-template-list .preview-template-body{margin-top:3rem;height:calc(100% - 6rem)}::ng-deep .select-template-list .preview-template-body-inner{background:#fff;border-radius:8px 8px 0 0;border:1px solid #dbdbdb;width:50rem}::ng-deep .select-template-list .preview-template-body-inner app-view-policy{display:block;height:100%}::ng-deep .select-template-list .preview-template-body-inner app-view-policy ejs-documenteditorcontainer{height:100%!important;min-height:unset!important}::ng-deep .select-template-list .preview-template-body-inner app-view-policy ejs-documenteditorcontainer .e-de-ctn{height:100%}::ng-deep .select-template-list .preview-template-body-inner app-view-policy ejs-documenteditorcontainer .e-de-ctn .e-de-ctnr-properties-pane{height:calc(100% - 30px)}::ng-deep .select-template-list .preview-template-body-inner app-view-policy ejs-documenteditorcontainer .e-de-ctn .e-de-ctnr-properties-pane .e-control.e-documenteditor{height:100%!important;min-height:unset!important}::ng-deep .select-template-list .preview-template-body-inner app-view-policy ejs-documenteditorcontainer .e-de-ctn .e-de-ctnr-properties-pane .e-control.e-documenteditor .e-documenteditor-optionspane{height:100%}\n"] }]
|
|
201
|
+
}], ctorParameters: function () { return [{ type: i1.TemplateService }, { type: i2.PolicyService }]; }, propDecorators: { selectedCategoryId: [{
|
|
202
|
+
type: Input
|
|
203
|
+
}], onTemplateSelect: [{
|
|
204
|
+
type: Output
|
|
205
|
+
}] } });
|
|
206
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select-template-list.component.js","sourceRoot":"","sources":["../../../../../../../projects/vx-workflow-engine/src/lib/sharedComponents/policy-template/select-template-list/select-template-list.component.ts","../../../../../../../projects/vx-workflow-engine/src/lib/sharedComponents/policy-template/select-template-list/select-template-list.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, Output } from '@angular/core';\r\nimport { TemplateService } from '../services/template.service';\r\nimport { forkJoin } from 'rxjs';\r\nimport {\r\n  NO_DATA_FOUND_IMAGE,\r\n  NO_DATA_FOUND_MESSAGE,\r\n} from '../constants/template.constant';\r\nimport { PolicyService } from '../../../workflow-services/policy.service';\r\n\r\n@Component({\r\n  selector: 'app-select-template-list',\r\n  templateUrl: './select-template-list.component.html',\r\n  styleUrls: ['./select-template-list.component.less'],\r\n})\r\nexport class SelectTemplateListComponent {\r\n  animation = false;\r\n  defaultTemplates: any[] = [];\r\n  customTemplates: any[] | null = null;\r\n  templateList: any[] = [];\r\n  currentTab = 'VCOMPLY';\r\n  loader: boolean = false;\r\n  categoryList: any[] = [];\r\n  defaultCategoryList: any[] = [];\r\n  userCreatedCategoryList: any[] = [];\r\n  sortStatus = -1;\r\n  searchCategory: string = '';\r\n  searchTemplate: string = '';\r\n  selectedCategory: any[] = [];\r\n  NO_DATA_FOUND_IMAGE = NO_DATA_FOUND_IMAGE;\r\n  NO_DATA_FOUND_MESSAGE = NO_DATA_FOUND_MESSAGE;\r\n  selectedTemplate: any[] = [];\r\n  isPreview = false;\r\n  docData: any | null = null;\r\n  previewTemplate: any;\r\n\r\n  @Input() selectedCategoryId: number[] = [];\r\n  @Output() onTemplateSelect = new EventEmitter<any>();\r\n\r\n  constructor(\r\n    private templateService: TemplateService,\r\n    private policyService: PolicyService\r\n  ) {}\r\n\r\n  ngOnInit(): void {\r\n    this.setAnimation();\r\n    this.getTemplate();\r\n  }\r\n\r\n  setAnimation() {\r\n    this.animation = true;\r\n    setTimeout(() => {\r\n      this.animation = false;\r\n    }, 300);\r\n  }\r\n\r\n  switchTab(tab: string) {\r\n    this.currentTab = tab;\r\n    this.selectedCategory = [];\r\n    if (tab === 'VCOMPLY') {\r\n      this.templateList = [...this.defaultTemplates];\r\n      this.categoryList = this.defaultCategoryList;\r\n    } else {\r\n      if (this.customTemplates === null) {\r\n        this.getCustomTemplates();\r\n      } else {\r\n        this.templateList = [...this.customTemplates];\r\n        this.categoryList = this.userCreatedCategoryList;\r\n      }\r\n    }\r\n  }\r\n\r\n  getCustomTemplates() {\r\n    this.loader = true;\r\n    const payload = {\r\n      type: 'custom',\r\n    };\r\n    this.templateService.fetchTemplates(payload).subscribe((res: any) => {\r\n      this.customTemplates = res?.templates ?? [];\r\n      this.mapCustomTemplate();\r\n    });\r\n  }\r\n\r\n  mapCustomTemplate() {\r\n    this.policyService.getCategoriesList().subscribe((res: any) => {\r\n      this.userCreatedCategoryList = [...res];\r\n      this.userCreatedCategoryList = this.userCreatedCategoryList.map(\r\n        (res: any) => {\r\n          console.log('res', res);\r\n          const parentItems = [...new Set(res?.parent_items ?? [])];\r\n          parentItems.unshift(res.item_name);\r\n          return {\r\n            ...res,\r\n            name: parentItems?.join(' < '),\r\n            parent_items: res?.parent_items.reverse(),\r\n          };\r\n        }\r\n      );\r\n      if (this.customTemplates) {\r\n        this.customTemplates = this.customTemplates.map((template: any) => {\r\n          return {\r\n            ...template,\r\n            categoryDetails: this.userCreatedCategoryList.filter(\r\n              (category: any) =>\r\n                template?.categoryId?.includes(category.item_id)\r\n            ),\r\n          };\r\n        });\r\n        console.log(\r\n          'userCreatedCategoryList dxwde',\r\n          this.userCreatedCategoryList,\r\n          this.customTemplates,\r\n          this.customTemplates\r\n        );\r\n      }\r\n      this.templateList = [...new Set(this.customTemplates ?? [])];\r\n      this.loader = false;\r\n      this.categoryList = this.userCreatedCategoryList;\r\n    });\r\n  }\r\n\r\n  getTemplate() {\r\n    this.loader = true;\r\n    const payload = {\r\n      type: 'default',\r\n    };\r\n    forkJoin([\r\n      this.templateService.fetchTemplates(payload),\r\n      this.templateService.fetchDefaultCategories(),\r\n    ]).subscribe((res: any) => {\r\n      this.defaultTemplates = res[0]?.templates;\r\n      this.defaultCategoryList = res[1];\r\n      this.mapDefaultTemplate();\r\n      this.categoryList = [...new Set(this.defaultCategoryList)];\r\n\r\n      this.templateList = this.defaultTemplates;\r\n      this.loader = false;\r\n    });\r\n  }\r\n\r\n  mapDefaultTemplate() {\r\n    this.defaultTemplates = this.defaultTemplates.map((template: any) => {\r\n      const category = this.defaultCategoryList.filter((category: any) =>\r\n        template?.categoryId?.includes(category.item_id)\r\n      );\r\n      return {\r\n        ...template,\r\n        categoryDetails: category,\r\n      };\r\n    });\r\n  }\r\n\r\n  sortBy(key: string) {\r\n    this.sortStatus = this.sortStatus * -1;\r\n    this.templateList = this.templateService.sortByKey(\r\n      this.templateList,\r\n      key,\r\n      this.sortStatus\r\n    );\r\n  }\r\n\r\n  onSelectCategory(category: any, event: any) {\r\n    if (event.target.checked) {\r\n      this.selectedCategory.push(category?.item_id);\r\n    } else {\r\n      this.selectedCategory = this.selectedCategory.filter(\r\n        (id: any) => id !== category?.item_id\r\n      );\r\n    }\r\n    this.selectedCategory = [...new Set(this.selectedCategory)];\r\n  }\r\n\r\n  onApplyFilter(event: any) {\r\n    if (!event) {\r\n      this.selectedCategory = [];\r\n      return;\r\n    }\r\n    let selectedTemplate =\r\n      this.currentTab === 'VCOMPLY'\r\n        ? this.defaultTemplates\r\n        : this.customTemplates ?? [];\r\n    selectedTemplate = [...new Set(selectedTemplate)];\r\n    if (this.selectedCategory.length === 0) {\r\n      this.templateList = selectedTemplate;\r\n      return;\r\n    }\r\n    this.templateList = selectedTemplate.filter((template: any) => {\r\n      return template?.categoryId?.some((id: any) =>\r\n        this.selectedCategory.includes(id)\r\n      );\r\n    });\r\n  }\r\n\r\n  onSelectTemplate(template: any) {\r\n    this.selectedTemplate = [template];\r\n  }\r\n\r\n  save() {\r\n    this.onTemplateSelect.emit(this.selectedTemplate);\r\n  }\r\n\r\n  close() {\r\n    this.onTemplateSelect.emit([]);\r\n  }\r\n\r\n  deleteEvent() {\r\n    this.selectedTemplate = [];\r\n  }\r\n\r\n  onPreview(details: any) {\r\n    this.isPreview = true;\r\n    this.getPreviewData(details?._id);\r\n    this.previewTemplate = details;\r\n  }\r\n\r\n  onClosePreview() {\r\n    this.isPreview = false;\r\n    this.docData = null;\r\n    this.previewTemplate = null;\r\n  }\r\n\r\n  getPreviewData(templateId: any) {\r\n    this.loader = true;\r\n    this.templateService.getTemplateContent(templateId).subscribe({\r\n      next: (res) => {\r\n        const { response } = res;\r\n        this.loader = false;\r\n        this.docData = response;\r\n      },\r\n    });\r\n  }\r\n}\r\n","<div\r\n  class=\"select-template-list\"\r\n  [class.animate]=\"animation\"\r\n  [class.withPreview]=\"isPreview\"\r\n>\r\n  <ng-container *ngIf=\"!isPreview\">\r\n    <div\r\n      class=\"select-template-list-head vx-d-flex vx-align-center vx-justify-between vx-pl-4 vx-pr-4\"\r\n    >\r\n      <div class=\"vx-fs-14 vx-fw-500 vx-label-txt\">Select a Template</div>\r\n    </div>\r\n    <div class=\"select-template-list-body\">\r\n      <app-loader-inline *ngIf=\"loader\"></app-loader-inline>\r\n\r\n      <div class=\"select-template-list-tab vx-d-flex vx-align-center vx-mb-2\">\r\n        <button\r\n          (click)=\"switchTab('VCOMPLY')\"\r\n          class=\"tab-btn vx-fs-11 vx-fw-500 vx-tt-uppercase vx-p-0 vx-pb-2 vx-m-0 vx-d-flex vx-align-center vx-lh-4\"\r\n          [class.active]=\"currentTab === 'VCOMPLY'\"\r\n        >\r\n          VCOMPLY TEMPLATES\r\n        </button>\r\n        <button\r\n          (click)=\"switchTab('USER_CREATED')\"\r\n          class=\"tab-btn vx-fs-11 vx-fw-500 vx-tt-uppercase vx-p-0 vx-pb-2 vx-m-0 vx-d-flex vx-align-center vx-lh-4\"\r\n          [class.active]=\"currentTab === 'USER_CREATED'\"\r\n        >\r\n          USER-CREATED TEMPLATES\r\n        </button>\r\n      </div>\r\n      <div class=\"search-block vx-mb-2\">\r\n        <i class=\"icons\">&#xe90b;</i>\r\n        <input type=\"text\" [(ngModel)]=\"searchTemplate\" placeholder=\"Search\" />\r\n      </div>\r\n      <div class=\"body-top vx-d-flex vx-align-center vx-justify-end vx-mb-2\">\r\n        <cs-multi-select\r\n          (searchText)=\"searchCategory = $event\"\r\n          [placeholder]=\"'Select Category'\"\r\n          [value]=\"selectedCategory\"\r\n          (applyFilter)=\"onApplyFilter($event)\"\r\n        >\r\n          <ng-container\r\n            *ngFor=\"\r\n              let eachCategory of categoryList\r\n                | SearchByKeys : ['name'] : searchCategory\r\n            \"\r\n          >\r\n            <cs-multi-select-option\r\n              [appTooltip]=\"eachCategory?.name\"\r\n              placement=\"bottom-left\"\r\n              delay=\"0\"\r\n              [value]=\"eachCategory?.item_id\"\r\n              (change)=\"onSelectCategory(eachCategory, $event)\"\r\n              [tooltipMandatory]=\"true\"\r\n            >\r\n              {{ eachCategory?.name }}\r\n            </cs-multi-select-option>\r\n          </ng-container>\r\n        </cs-multi-select>\r\n      </div>\r\n      <div class=\"body-inner vx-mb-1\">\r\n        <ng-container *ngIf=\"!loader\">\r\n          <ng-container\r\n            *ngIf=\"\r\n              templateList\r\n                | SearchByKeys\r\n                  : ['name', 'categoryDetails']\r\n                  : searchTemplate as allTemplate\r\n            \"\r\n          >\r\n            <app-template-list-table\r\n              *ngIf=\"allTemplate.length\"\r\n              [templateList]=\"allTemplate\"\r\n              [loader]=\"loader\"\r\n              [categoryList]=\"categoryList\"\r\n              [selectedTemplate]=\"selectedTemplate[0]\"\r\n              (onSort)=\"sortBy($event)\"\r\n              (onSelectTemplate)=\"onSelectTemplate($event)\"\r\n              (onPreview)=\"onPreview($event)\"\r\n            ></app-template-list-table>\r\n            <app-no-data\r\n              *ngIf=\"!allTemplate?.length\"\r\n              [noDataImage]=\"NO_DATA_FOUND_IMAGE\"\r\n              [noDataText]=\"NO_DATA_FOUND_MESSAGE\"\r\n            ></app-no-data>\r\n          </ng-container>\r\n        </ng-container>\r\n      </div>\r\n\r\n      <app-floating-bar\r\n        (closeEvent)=\"save()\"\r\n        (closeList)=\"close()\"\r\n        [isDisabled]=\"selectedTemplate?.length === 0\"\r\n        [selectedData]=\"selectedTemplate\"\r\n        [displayElementKey]=\"'name'\"\r\n        [singularText]=\"'Template Selected'\"\r\n        (deleteEvent)=\"deleteEvent()\"\r\n      >\r\n      </app-floating-bar>\r\n    </div>\r\n  </ng-container>\r\n  <ng-container *ngIf=\"isPreview\">\r\n    <div\r\n      class=\"select-template-list-head vx-d-flex vx-align-center vx-pl-4 vx-pr-4\"\r\n    >\r\n      <button\r\n        (click)=\"onClosePreview()\"\r\n        class=\"previewBtn vx-fs-14 vx-fw-500 vx-label-txt vx-p-0 vx-m-0 vx-d-flex vx-align-center\"\r\n      >\r\n        <i class=\"icons vx-mr-1\">&#xe91d;</i>Preview\r\n      </button>\r\n      <div\r\n        class=\"template-name vx-fs-14 vx-ml-1\"\r\n        [appTooltip]=\"previewTemplate?.name\"\r\n        placement=\"bottom-left\"\r\n        delay=\"0\"\r\n        type=\"black\"\r\n        [tooltipMandatory]=\"false\"\r\n      >\r\n        {{ previewTemplate?.name }}\r\n      </div>\r\n    </div>\r\n    <div class=\"preview-template-body vx-d-flex vx-justify-center\">\r\n      <app-loader-inline *ngIf=\"loader\"></app-loader-inline>\r\n\r\n      <div *ngIf=\"!loader\" class=\"preview-template-body-inner\">\r\n        <app-view-policy #view_policy [contents]=\"docData\"> </app-view-policy>\r\n      </div>\r\n    </div>\r\n  </ng-container>\r\n</div>\r\n"]}
|
|
@@ -0,0 +1,67 @@
|
|
|
1
|
+
import { HttpHeaders } from '@angular/common/http';
|
|
2
|
+
import { Injectable, Optional } from '@angular/core';
|
|
3
|
+
import { APIs } from '../../../constants/template.constant';
|
|
4
|
+
import { map } from 'rxjs';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
import * as i1 from "@angular/common/http";
|
|
7
|
+
import * as i2 from "@vcomply/authorizer";
|
|
8
|
+
import * as i3 from "../../../configurations";
|
|
9
|
+
export class TemplateService {
|
|
10
|
+
constructor(http, authService, config) {
|
|
11
|
+
this.http = http;
|
|
12
|
+
this.authService = authService;
|
|
13
|
+
this.tokenDetails = '';
|
|
14
|
+
this.env = config?.envConfig;
|
|
15
|
+
this.tokenDetails = this.authService.getToken();
|
|
16
|
+
}
|
|
17
|
+
sortByKey(array, key, order = 1) {
|
|
18
|
+
return array.sort((a, b) => {
|
|
19
|
+
const comparison = a[key] > b[key] ? 1 : a[key] < b[key] ? -1 : 0;
|
|
20
|
+
return order === 1 ? comparison : -comparison;
|
|
21
|
+
});
|
|
22
|
+
}
|
|
23
|
+
get headerToken() {
|
|
24
|
+
return new HttpHeaders().set('token', this.tokenDetails);
|
|
25
|
+
}
|
|
26
|
+
fetchTemplates(payload) {
|
|
27
|
+
const headers = this.headerToken;
|
|
28
|
+
return this.http.post(this.env.policyPost + APIs.fetchTemplates, payload, {
|
|
29
|
+
headers,
|
|
30
|
+
});
|
|
31
|
+
}
|
|
32
|
+
fetchDefaultCategories() {
|
|
33
|
+
const headers = this.headerToken;
|
|
34
|
+
return this.http
|
|
35
|
+
.get(this.env.policyGet + APIs.default_categories, {
|
|
36
|
+
headers,
|
|
37
|
+
})
|
|
38
|
+
.pipe(map((res) => {
|
|
39
|
+
return res.map((category) => {
|
|
40
|
+
return {
|
|
41
|
+
item_id: category.categoryId,
|
|
42
|
+
item_name: category.name,
|
|
43
|
+
parent_item_ids: [],
|
|
44
|
+
parent_items: [],
|
|
45
|
+
name: category.name,
|
|
46
|
+
};
|
|
47
|
+
});
|
|
48
|
+
}));
|
|
49
|
+
}
|
|
50
|
+
getTemplateContent(id, type = '') {
|
|
51
|
+
return this.http.get(this.env.nodeDomain +
|
|
52
|
+
APIs.fetch_content +
|
|
53
|
+
id +
|
|
54
|
+
(type ? `&type=${type}` : ''));
|
|
55
|
+
}
|
|
56
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TemplateService, deps: [{ token: i1.HttpClient }, { token: i2.AuthorizerService }, { token: i3.Configurations, optional: true }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
57
|
+
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TemplateService, providedIn: 'root' }); }
|
|
58
|
+
}
|
|
59
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TemplateService, decorators: [{
|
|
60
|
+
type: Injectable,
|
|
61
|
+
args: [{
|
|
62
|
+
providedIn: 'root',
|
|
63
|
+
}]
|
|
64
|
+
}], ctorParameters: function () { return [{ type: i1.HttpClient }, { type: i2.AuthorizerService }, { type: i3.Configurations, decorators: [{
|
|
65
|
+
type: Optional
|
|
66
|
+
}] }]; } });
|
|
67
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGVtcGxhdGUuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3Z4LXdvcmtmbG93LWVuZ2luZS9zcmMvbGliL3NoYXJlZENvbXBvbmVudHMvcG9saWN5LXRlbXBsYXRlL3NlcnZpY2VzL3RlbXBsYXRlLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFjLFdBQVcsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBQy9ELE9BQU8sRUFBRSxVQUFVLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBSXJELE9BQU8sRUFBRSxJQUFJLEVBQUUsTUFBTSxzQ0FBc0MsQ0FBQztBQUM1RCxPQUFPLEVBQUUsR0FBRyxFQUFjLE1BQU0sTUFBTSxDQUFDOzs7OztBQUt2QyxNQUFNLE9BQU8sZUFBZTtJQUkxQixZQUNVLElBQWdCLEVBQ2hCLFdBQThCLEVBQzFCLE1BQXVCO1FBRjNCLFNBQUksR0FBSixJQUFJLENBQVk7UUFDaEIsZ0JBQVcsR0FBWCxXQUFXLENBQW1CO1FBSmhDLGlCQUFZLEdBQVcsRUFBRSxDQUFDO1FBT2hDLElBQUksQ0FBQyxHQUFHLEdBQUcsTUFBTSxFQUFFLFNBQVMsQ0FBQztRQUM3QixJQUFJLENBQUMsWUFBWSxHQUFHLElBQUksQ0FBQyxXQUFXLENBQUMsUUFBUSxFQUFFLENBQUM7SUFDbEQsQ0FBQztJQUVNLFNBQVMsQ0FBQyxLQUFZLEVBQUUsR0FBVyxFQUFFLEtBQUssR0FBRyxDQUFDO1FBQ25ELE9BQU8sS0FBSyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLEVBQUUsRUFBRTtZQUN6QixNQUFNLFVBQVUsR0FBRyxDQUFDLENBQUMsR0FBRyxDQUFDLEdBQUcsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsR0FBRyxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7WUFDbEUsT0FBTyxLQUFLLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQyxVQUFVLENBQUMsQ0FBQyxDQUFDLENBQUMsVUFBVSxDQUFDO1FBQ2hELENBQUMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztJQUVELElBQUksV0FBVztRQUNiLE9BQU8sSUFBSSxXQUFXLEVBQUUsQ0FBQyxHQUFHLENBQUMsT0FBTyxFQUFFLElBQUksQ0FBQyxZQUFZLENBQUMsQ0FBQztJQUMzRCxDQUFDO0lBRUQsY0FBYyxDQUFDLE9BQVk7UUFDekIsTUFBTSxPQUFPLEdBQUcsSUFBSSxDQUFDLFdBQVcsQ0FBQztRQUNqQyxPQUFPLElBQUksQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsVUFBVSxHQUFHLElBQUksQ0FBQyxjQUFjLEVBQUUsT0FBTyxFQUFFO1lBQ3hFLE9BQU87U0FDUixDQUFDLENBQUM7SUFDTCxDQUFDO0lBRUQsc0JBQXNCO1FBQ3BCLE1BQU0sT0FBTyxHQUFHLElBQUksQ0FBQyxXQUFXLENBQUM7UUFDakMsT0FBTyxJQUFJLENBQUMsSUFBSTthQUNiLEdBQUcsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLFNBQVMsR0FBRyxJQUFJLENBQUMsa0JBQWtCLEVBQUU7WUFDakQsT0FBTztTQUNSLENBQUM7YUFDRCxJQUFJLENBQ0gsR0FBRyxDQUFDLENBQUMsR0FBUSxFQUFFLEVBQUU7WUFDZixPQUFPLEdBQUcsQ0FBQyxHQUFHLENBQUMsQ0FBQyxRQUFhLEVBQUUsRUFBRTtnQkFDL0IsT0FBTztvQkFDTCxPQUFPLEVBQUUsUUFBUSxDQUFDLFVBQVU7b0JBQzVCLFNBQVMsRUFBRSxRQUFRLENBQUMsSUFBSTtvQkFDeEIsZUFBZSxFQUFFLEVBQUU7b0JBQ25CLFlBQVksRUFBRSxFQUFFO29CQUNoQixJQUFJLEVBQUUsUUFBUSxDQUFDLElBQUk7aUJBQ3BCLENBQUM7WUFDSixDQUFDLENBQUMsQ0FBQztRQUNMLENBQUMsQ0FBQyxDQUNILENBQUM7SUFDTixDQUFDO0lBRU0sa0JBQWtCLENBQUMsRUFBVSxFQUFFLE9BQWUsRUFBRTtRQUNyRCxPQUFPLElBQUksQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUNsQixJQUFJLENBQUMsR0FBRyxDQUFDLFVBQVU7WUFDakIsSUFBSSxDQUFDLGFBQWE7WUFDbEIsRUFBRTtZQUNGLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxTQUFTLElBQUksRUFBRSxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FDaEMsQ0FBQztJQUNKLENBQUM7K0dBM0RVLGVBQWU7bUhBQWYsZUFBZSxjQUZkLE1BQU07OzRGQUVQLGVBQWU7a0JBSDNCLFVBQVU7bUJBQUM7b0JBQ1YsVUFBVSxFQUFFLE1BQU07aUJBQ25COzswQkFRSSxRQUFRIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSHR0cENsaWVudCwgSHR0cEhlYWRlcnMgfSBmcm9tICdAYW5ndWxhci9jb21tb24vaHR0cCc7XHJcbmltcG9ydCB7IEluamVjdGFibGUsIE9wdGlvbmFsIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IEF1dGhTZXJ2aWNlIH0gZnJvbSAnLi4vLi4vLi4vc2VydmljZXMvYXV0aC5zZXJ2aWNlJztcclxuaW1wb3J0IHsgQXV0aG9yaXplclNlcnZpY2UgfSBmcm9tICdAdmNvbXBseS9hdXRob3JpemVyJztcclxuaW1wb3J0IHsgQ29uZmlndXJhdGlvbnMgfSBmcm9tICcuLi8uLi8uLi9jb25maWd1cmF0aW9ucyc7XHJcbmltcG9ydCB7IEFQSXMgfSBmcm9tICcuLi8uLi8uLi9jb25zdGFudHMvdGVtcGxhdGUuY29uc3RhbnQnO1xyXG5pbXBvcnQgeyBtYXAsIE9ic2VydmFibGUgfSBmcm9tICdyeGpzJztcclxuXHJcbkBJbmplY3RhYmxlKHtcclxuICBwcm92aWRlZEluOiAncm9vdCcsXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBUZW1wbGF0ZVNlcnZpY2Uge1xyXG4gIGVudjogYW55O1xyXG4gIHByaXZhdGUgdG9rZW5EZXRhaWxzOiBzdHJpbmcgPSAnJztcclxuXHJcbiAgY29uc3RydWN0b3IoXHJcbiAgICBwcml2YXRlIGh0dHA6IEh0dHBDbGllbnQsXHJcbiAgICBwcml2YXRlIGF1dGhTZXJ2aWNlOiBBdXRob3JpemVyU2VydmljZSxcclxuICAgIEBPcHRpb25hbCgpIGNvbmZpZz86IENvbmZpZ3VyYXRpb25zXHJcbiAgKSB7XHJcbiAgICB0aGlzLmVudiA9IGNvbmZpZz8uZW52Q29uZmlnO1xyXG4gICAgdGhpcy50b2tlbkRldGFpbHMgPSB0aGlzLmF1dGhTZXJ2aWNlLmdldFRva2VuKCk7XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgc29ydEJ5S2V5KGFycmF5OiBhbnlbXSwga2V5OiBzdHJpbmcsIG9yZGVyID0gMSkge1xyXG4gICAgcmV0dXJuIGFycmF5LnNvcnQoKGEsIGIpID0+IHtcclxuICAgICAgY29uc3QgY29tcGFyaXNvbiA9IGFba2V5XSA+IGJba2V5XSA/IDEgOiBhW2tleV0gPCBiW2tleV0gPyAtMSA6IDA7XHJcbiAgICAgIHJldHVybiBvcmRlciA9PT0gMSA/IGNvbXBhcmlzb24gOiAtY29tcGFyaXNvbjtcclxuICAgIH0pO1xyXG4gIH1cclxuXHJcbiAgZ2V0IGhlYWRlclRva2VuKCkge1xyXG4gICAgcmV0dXJuIG5ldyBIdHRwSGVhZGVycygpLnNldCgndG9rZW4nLCB0aGlzLnRva2VuRGV0YWlscyk7XHJcbiAgfVxyXG5cclxuICBmZXRjaFRlbXBsYXRlcyhwYXlsb2FkOiBhbnkpIHtcclxuICAgIGNvbnN0IGhlYWRlcnMgPSB0aGlzLmhlYWRlclRva2VuO1xyXG4gICAgcmV0dXJuIHRoaXMuaHR0cC5wb3N0KHRoaXMuZW52LnBvbGljeVBvc3QgKyBBUElzLmZldGNoVGVtcGxhdGVzLCBwYXlsb2FkLCB7XHJcbiAgICAgIGhlYWRlcnMsXHJcbiAgICB9KTtcclxuICB9XHJcblxyXG4gIGZldGNoRGVmYXVsdENhdGVnb3JpZXMoKSB7XHJcbiAgICBjb25zdCBoZWFkZXJzID0gdGhpcy5oZWFkZXJUb2tlbjtcclxuICAgIHJldHVybiB0aGlzLmh0dHBcclxuICAgICAgLmdldCh0aGlzLmVudi5wb2xpY3lHZXQgKyBBUElzLmRlZmF1bHRfY2F0ZWdvcmllcywge1xyXG4gICAgICAgIGhlYWRlcnMsXHJcbiAgICAgIH0pXHJcbiAgICAgIC5waXBlKFxyXG4gICAgICAgIG1hcCgocmVzOiBhbnkpID0+IHtcclxuICAgICAgICAgIHJldHVybiByZXMubWFwKChjYXRlZ29yeTogYW55KSA9PiB7XHJcbiAgICAgICAgICAgIHJldHVybiB7XHJcbiAgICAgICAgICAgICAgaXRlbV9pZDogY2F0ZWdvcnkuY2F0ZWdvcnlJZCxcclxuICAgICAgICAgICAgICBpdGVtX25hbWU6IGNhdGVnb3J5Lm5hbWUsXHJcbiAgICAgICAgICAgICAgcGFyZW50X2l0ZW1faWRzOiBbXSxcclxuICAgICAgICAgICAgICBwYXJlbnRfaXRlbXM6IFtdLFxyXG4gICAgICAgICAgICAgIG5hbWU6IGNhdGVnb3J5Lm5hbWUsXHJcbiAgICAgICAgICAgIH07XHJcbiAgICAgICAgICB9KTtcclxuICAgICAgICB9KVxyXG4gICAgICApO1xyXG4gIH1cclxuXHJcbiAgcHVibGljIGdldFRlbXBsYXRlQ29udGVudChpZDogc3RyaW5nLCB0eXBlOiBzdHJpbmcgPSAnJyk6IE9ic2VydmFibGU8YW55PiB7XHJcbiAgICByZXR1cm4gdGhpcy5odHRwLmdldChcclxuICAgICAgdGhpcy5lbnYubm9kZURvbWFpbiArXHJcbiAgICAgICAgQVBJcy5mZXRjaF9jb250ZW50ICtcclxuICAgICAgICBpZCArXHJcbiAgICAgICAgKHR5cGUgPyBgJnR5cGU9JHt0eXBlfWAgOiAnJylcclxuICAgICk7XHJcbiAgfVxyXG59XHJcbiJdfQ==
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "@angular/common";
|
|
4
|
+
import * as i2 from "../../../ui-kit/tooltip/tooltip.directive";
|
|
5
|
+
import * as i3 from "../../../ui-kit/popover/popover.component";
|
|
6
|
+
import * as i4 from "../../../ui-kit/popover/popover.directive";
|
|
7
|
+
import * as i5 from "../../../formgroup/cs-radio/cs-radio.component";
|
|
8
|
+
export class TemplateListTableComponent {
|
|
9
|
+
constructor() {
|
|
10
|
+
this.templateList = [];
|
|
11
|
+
this.loader = false;
|
|
12
|
+
this.categoryList = [];
|
|
13
|
+
this.onSort = new EventEmitter();
|
|
14
|
+
this.onSelectTemplate = new EventEmitter();
|
|
15
|
+
this.onPreview = new EventEmitter();
|
|
16
|
+
}
|
|
17
|
+
onSelect(template) {
|
|
18
|
+
this.selectedTemplate = template;
|
|
19
|
+
this.onSelectTemplate.emit(template);
|
|
20
|
+
}
|
|
21
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TemplateListTableComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
22
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TemplateListTableComponent, selector: "app-template-list-table", inputs: { selectedTemplate: "selectedTemplate", templateList: "templateList", loader: "loader", categoryList: "categoryList" }, outputs: { onSort: "onSort", onSelectTemplate: "onSelectTemplate", onPreview: "onPreview" }, ngImport: i0, template: "<div class=\"template-list-table\">\r\n <div class=\"table-header\">\r\n <div class=\"table-row\">\r\n <div\r\n class=\"table-column vx-fs-11 vx-fw-500 vx-lh-5 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-d-flex vx-align-center serial\"\r\n >\r\n #\r\n </div>\r\n <div\r\n class=\"table-column vx-fs-11 vx-fw-500 vx-lh-5 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-d-flex vx-align-center template-name\"\r\n >\r\n <span\r\n (click)=\"onSort.emit('name')\"\r\n class=\"sorting vx-fs-9 vx-txt-blue vx-mr-1\"\r\n ><i class=\"icons\"></i></span\r\n >\r\n TEMPLATE NAME\r\n </div>\r\n <div\r\n class=\"table-column vx-fs-11 vx-fw-500 vx-lh-5 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-d-flex vx-align-center category\"\r\n >\r\n <!-- <span class=\"sorting vx-fs-9 vx-txt-blue vx-mr-1\"\r\n ><i class=\"icons\"></i></span\r\n > -->\r\n CATEGORIES\r\n </div>\r\n <div\r\n class=\"table-column vx-fs-11 vx-fw-500 vx-lh-5 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-d-flex vx-align-center view-action\"\r\n ></div>\r\n </div>\r\n </div>\r\n <div class=\"table-body\">\r\n <div\r\n class=\"table-row\"\r\n *ngFor=\"let eachTemplate of templateList; let i = index\"\r\n [class.active]=\"selectedTemplate?._id === eachTemplate?._id\"\r\n >\r\n <div\r\n class=\"table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center serial\"\r\n >\r\n <div\r\n class=\"sr-no\"\r\n [appTooltip]=\"i + 1\"\r\n placement=\"bottom\"\r\n delay=\"0\"\r\n type=\"black\"\r\n [tooltipMandatory]=\"true\"\r\n >\r\n {{ i + 1 }}\r\n </div>\r\n <app-cs-radio\r\n name=\"template\"\r\n [value]=\"selectedTemplate?._id\"\r\n [checked]=\"selectedTemplate?._id === eachTemplate?._id\"\r\n (checkedEvent)=\"onSelect(eachTemplate)\"\r\n ></app-cs-radio>\r\n </div>\r\n <div\r\n class=\"table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center template-name\"\r\n >\r\n <div\r\n class=\"value vx-fs-12 vx-label-txt\"\r\n [appTooltip]=\"eachTemplate?.name\"\r\n placement=\"bottom-left\"\r\n delay=\"0\"\r\n type=\"black\"\r\n [tooltipMandatory]=\"false\"\r\n >\r\n {{ eachTemplate?.name }}\r\n </div>\r\n </div>\r\n <div\r\n class=\"table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center category\"\r\n *ngIf=\"eachTemplate?.categoryDetails as categoryDetails\"\r\n >\r\n <div class=\"category-inner\">\r\n <div class=\"category-name vx-fs-12 vx-lh-4\">\r\n {{ categoryDetails[0]?.item_name }}\r\n </div>\r\n <div\r\n *ngIf=\"categoryDetails[0]?.parent_items?.length\"\r\n class=\"within-part vx-d-flex vx-align-center vx-pr-3\"\r\n >\r\n <span\r\n class=\"within-box vx-fs-9 vx-fw-600 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-mr-2 vx-lh-3\"\r\n >Within</span\r\n >\r\n <span\r\n class=\"within-value vx-fs-11 vx-paragraph-txt\"\r\n [appTooltip]=\"categoryDetails[0]?.parent_items?.join(' < ')\"\r\n placement=\"bottom-left\"\r\n delay=\"0\"\r\n type=\"black\"\r\n [tooltipMandatory]=\"false\"\r\n >{{ categoryDetails[0]?.parent_items?.join(\" < \") }}</span\r\n >\r\n </div>\r\n </div>\r\n <button\r\n *ngIf=\"categoryDetails?.length > 1\"\r\n class=\"countBtn vx-fs-9 vx-fw-600 vx-txt-blue vx-pl-1 vx-pr-1 vx-m-0 vx-ml-1 vx-d-flex vx-align-center vx-justify-center\"\r\n appPopover\r\n (click)=\"MoreCategory.popover()\"\r\n placement=\"right\"\r\n >\r\n +{{ categoryDetails?.length - 1 }}\r\n </button>\r\n\r\n <app-popover #MoreCategory>\r\n <div class=\"wf-action-list category-list\">\r\n <ul class=\"action-item\">\r\n <li *ngFor=\"let eachTemplate of categoryDetails | slice : 1\">\r\n <div class=\"avatar-card\">\r\n <div class=\"vx-w-100\">\r\n <span\r\n class=\"value vx-p-0 vx-w-100\"\r\n [appTooltip]=\"eachTemplate?.item_name\"\r\n placement=\"bottom-left\"\r\n type=\"black\"\r\n delay=\"0\"\r\n [tooltipMandatory]=\"false\"\r\n >{{ eachTemplate?.item_name }}</span\r\n >\r\n <div\r\n *ngIf=\"eachTemplate?.parent_items?.length\"\r\n class=\"within-part vx-d-flex vx-align-center vx-pr-3\"\r\n >\r\n <span\r\n class=\"within-box vx-fs-9 vx-fw-600 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-mr-2 vx-lh-3\"\r\n >Within</span\r\n >\r\n <span\r\n class=\"within-value vx-fs-11 vx-paragraph-txt\"\r\n [appTooltip]=\"eachTemplate?.parent_items?.join(' < ')\"\r\n placement=\"bottom-left\"\r\n delay=\"0\"\r\n type=\"black\"\r\n [tooltipMandatory]=\"false\"\r\n >{{ eachTemplate?.parent_items?.join(\" < \") }}</span\r\n >\r\n </div>\r\n </div>\r\n </div>\r\n </li>\r\n </ul>\r\n </div>\r\n </app-popover>\r\n </div>\r\n <div\r\n class=\"table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center view-action\"\r\n >\r\n <button\r\n class=\"previewBtn vx-fs-11 vx-fw-500 vx-txt-blue vx-tt-uppercase vx-p-0 vx-pl-2 vx-pr-2 vx-m-0 vx-d-flex vx-align-center vx-lh-6\"\r\n (click)=\"onPreview.emit(eachTemplate?._id)\"\r\n >\r\n PREVIEW\r\n </button>\r\n </div>\r\n </div>\r\n </div>\r\n</div>\r\n", styles: ["@import\"https://cdn.v-comply.com/design-system/css/icons/icons.css\";@import\"https://cdn.v-comply.com/design-system/css/display/display.css\";@import\"https://cdn.v-comply.com/design-system/css/alignment/alignment.css\";@import\"https://cdn.v-comply.com/design-system/css/text/text.css\";@import\"https://cdn.v-comply.com/design-system/css/color/color.css\";@import\"https://cdn.v-comply.com/design-system/css/width/width.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-top.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-bottom.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-left.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-right.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-top.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-bottom.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-left.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-right.css\";::ng-deep .template-list-table .table-header{background:#fff;position:sticky;top:0;z-index:1}::ng-deep .template-list-table .table-header .table-column{color:#747576!important;line-height:1rem!important;min-height:2rem!important}::ng-deep .template-list-table .table-body{position:relative}::ng-deep .template-list-table .table-body .table-row{background:#fff;border-radius:4px;border:1px solid #e3e3e9;transition:all .2s ease-in-out;margin-bottom:.25rem}::ng-deep .template-list-table .table-body .table-row:hover{background:#f8f8f8;transition:all .2s ease-in-out}::ng-deep .template-list-table .table-body .table-row:hover .table-column.serial app-cs-radio{opacity:1}::ng-deep .template-list-table .table-body .table-row:hover .table-column.view-action button.previewBtn{opacity:1}::ng-deep .template-list-table .table-body .table-row.active .table-column.serial app-cs-radio{opacity:1}::ng-deep .template-list-table .table-row{display:flex;justify-content:space-between;position:relative}::ng-deep .template-list-table .table-row .table-column{color:#000;min-height:2.5rem;position:relative;width:100%}::ng-deep .template-list-table .table-row .table-column i.info{color:#1e5dd3;cursor:pointer}::ng-deep .template-list-table .table-row .table-column .sorting{cursor:pointer;position:relative;top:1px;left:-1px}::ng-deep .template-list-table .table-row .table-column .sorting i{cursor:pointer}::ng-deep .template-list-table .table-row .table-column.serial{width:2rem;max-width:2rem;flex:0 0 2rem;justify-content:center}::ng-deep .template-list-table .table-row .table-column.serial .sr-no{width:1rem;background:#f2f2f5;writing-mode:vertical-lr;color:#787a8c;font-size:.625rem;font-weight:500;display:flex;height:2.5rem;align-items:center;justify-content:center;position:relative;transition:all .2s ease-in-out}::ng-deep .template-list-table .table-row .table-column.serial app-cs-radio{position:absolute;top:12px;left:8px;opacity:0;transition:all .2s ease-in-out}::ng-deep .template-list-table .table-row .table-column.template-name{width:calc(100% - 25rem);min-width:calc(100% - 25rem)}::ng-deep .template-list-table .table-row .table-column.template-name .value{text-overflow:ellipsis;white-space:nowrap;overflow:hidden;width:calc(100% - 3rem)}::ng-deep .template-list-table .table-row .table-column.category{width:18rem;min-width:18rem}::ng-deep .template-list-table .table-row .table-column.category .category-inner{max-width:calc(100% - 3rem)}::ng-deep .template-list-table .table-row .table-column.category .category-inner .category-name{color:#787a8c;text-overflow:ellipsis;white-space:nowrap;overflow:hidden}::ng-deep .template-list-table .table-row .table-column.category button.countBtn{background:#fff;border-radius:1.25rem;border:1px solid #cdced6;height:1rem;min-width:1.5rem}::ng-deep .template-list-table .table-row .table-column.view-action{width:5rem;min-width:5rem}::ng-deep .template-list-table .table-row .table-column.view-action button.previewBtn{background:#fff;border-radius:.125rem;border:1px solid #dbdbdb;height:1.25rem;transition:all .2s ease-in-out;opacity:0}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.ToolTipDirective, selector: "[appTooltip]", inputs: ["appTooltip", "placement", "type", "tooltipMandatory", "showTooltip", "animate"] }, { kind: "component", type: i3.PopoverComponent, selector: "app-popover", inputs: ["dontCloseonClick"] }, { kind: "directive", type: i4.PopoverDirective, selector: "[appPopover]", inputs: ["refrence", "placement"] }, { kind: "component", type: i5.CsRadioComponent, selector: "app-cs-radio", inputs: ["disabled", "readonly", "name", "checked", "value", "oneLine"], outputs: ["checkedEvent"] }, { kind: "pipe", type: i1.SlicePipe, name: "slice" }] }); }
|
|
23
|
+
}
|
|
24
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TemplateListTableComponent, decorators: [{
|
|
25
|
+
type: Component,
|
|
26
|
+
args: [{ selector: 'app-template-list-table', template: "<div class=\"template-list-table\">\r\n <div class=\"table-header\">\r\n <div class=\"table-row\">\r\n <div\r\n class=\"table-column vx-fs-11 vx-fw-500 vx-lh-5 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-d-flex vx-align-center serial\"\r\n >\r\n #\r\n </div>\r\n <div\r\n class=\"table-column vx-fs-11 vx-fw-500 vx-lh-5 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-d-flex vx-align-center template-name\"\r\n >\r\n <span\r\n (click)=\"onSort.emit('name')\"\r\n class=\"sorting vx-fs-9 vx-txt-blue vx-mr-1\"\r\n ><i class=\"icons\"></i></span\r\n >\r\n TEMPLATE NAME\r\n </div>\r\n <div\r\n class=\"table-column vx-fs-11 vx-fw-500 vx-lh-5 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-d-flex vx-align-center category\"\r\n >\r\n <!-- <span class=\"sorting vx-fs-9 vx-txt-blue vx-mr-1\"\r\n ><i class=\"icons\"></i></span\r\n > -->\r\n CATEGORIES\r\n </div>\r\n <div\r\n class=\"table-column vx-fs-11 vx-fw-500 vx-lh-5 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-d-flex vx-align-center view-action\"\r\n ></div>\r\n </div>\r\n </div>\r\n <div class=\"table-body\">\r\n <div\r\n class=\"table-row\"\r\n *ngFor=\"let eachTemplate of templateList; let i = index\"\r\n [class.active]=\"selectedTemplate?._id === eachTemplate?._id\"\r\n >\r\n <div\r\n class=\"table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center serial\"\r\n >\r\n <div\r\n class=\"sr-no\"\r\n [appTooltip]=\"i + 1\"\r\n placement=\"bottom\"\r\n delay=\"0\"\r\n type=\"black\"\r\n [tooltipMandatory]=\"true\"\r\n >\r\n {{ i + 1 }}\r\n </div>\r\n <app-cs-radio\r\n name=\"template\"\r\n [value]=\"selectedTemplate?._id\"\r\n [checked]=\"selectedTemplate?._id === eachTemplate?._id\"\r\n (checkedEvent)=\"onSelect(eachTemplate)\"\r\n ></app-cs-radio>\r\n </div>\r\n <div\r\n class=\"table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center template-name\"\r\n >\r\n <div\r\n class=\"value vx-fs-12 vx-label-txt\"\r\n [appTooltip]=\"eachTemplate?.name\"\r\n placement=\"bottom-left\"\r\n delay=\"0\"\r\n type=\"black\"\r\n [tooltipMandatory]=\"false\"\r\n >\r\n {{ eachTemplate?.name }}\r\n </div>\r\n </div>\r\n <div\r\n class=\"table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center category\"\r\n *ngIf=\"eachTemplate?.categoryDetails as categoryDetails\"\r\n >\r\n <div class=\"category-inner\">\r\n <div class=\"category-name vx-fs-12 vx-lh-4\">\r\n {{ categoryDetails[0]?.item_name }}\r\n </div>\r\n <div\r\n *ngIf=\"categoryDetails[0]?.parent_items?.length\"\r\n class=\"within-part vx-d-flex vx-align-center vx-pr-3\"\r\n >\r\n <span\r\n class=\"within-box vx-fs-9 vx-fw-600 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-mr-2 vx-lh-3\"\r\n >Within</span\r\n >\r\n <span\r\n class=\"within-value vx-fs-11 vx-paragraph-txt\"\r\n [appTooltip]=\"categoryDetails[0]?.parent_items?.join(' < ')\"\r\n placement=\"bottom-left\"\r\n delay=\"0\"\r\n type=\"black\"\r\n [tooltipMandatory]=\"false\"\r\n >{{ categoryDetails[0]?.parent_items?.join(\" < \") }}</span\r\n >\r\n </div>\r\n </div>\r\n <button\r\n *ngIf=\"categoryDetails?.length > 1\"\r\n class=\"countBtn vx-fs-9 vx-fw-600 vx-txt-blue vx-pl-1 vx-pr-1 vx-m-0 vx-ml-1 vx-d-flex vx-align-center vx-justify-center\"\r\n appPopover\r\n (click)=\"MoreCategory.popover()\"\r\n placement=\"right\"\r\n >\r\n +{{ categoryDetails?.length - 1 }}\r\n </button>\r\n\r\n <app-popover #MoreCategory>\r\n <div class=\"wf-action-list category-list\">\r\n <ul class=\"action-item\">\r\n <li *ngFor=\"let eachTemplate of categoryDetails | slice : 1\">\r\n <div class=\"avatar-card\">\r\n <div class=\"vx-w-100\">\r\n <span\r\n class=\"value vx-p-0 vx-w-100\"\r\n [appTooltip]=\"eachTemplate?.item_name\"\r\n placement=\"bottom-left\"\r\n type=\"black\"\r\n delay=\"0\"\r\n [tooltipMandatory]=\"false\"\r\n >{{ eachTemplate?.item_name }}</span\r\n >\r\n <div\r\n *ngIf=\"eachTemplate?.parent_items?.length\"\r\n class=\"within-part vx-d-flex vx-align-center vx-pr-3\"\r\n >\r\n <span\r\n class=\"within-box vx-fs-9 vx-fw-600 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-mr-2 vx-lh-3\"\r\n >Within</span\r\n >\r\n <span\r\n class=\"within-value vx-fs-11 vx-paragraph-txt\"\r\n [appTooltip]=\"eachTemplate?.parent_items?.join(' < ')\"\r\n placement=\"bottom-left\"\r\n delay=\"0\"\r\n type=\"black\"\r\n [tooltipMandatory]=\"false\"\r\n >{{ eachTemplate?.parent_items?.join(\" < \") }}</span\r\n >\r\n </div>\r\n </div>\r\n </div>\r\n </li>\r\n </ul>\r\n </div>\r\n </app-popover>\r\n </div>\r\n <div\r\n class=\"table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center view-action\"\r\n >\r\n <button\r\n class=\"previewBtn vx-fs-11 vx-fw-500 vx-txt-blue vx-tt-uppercase vx-p-0 vx-pl-2 vx-pr-2 vx-m-0 vx-d-flex vx-align-center vx-lh-6\"\r\n (click)=\"onPreview.emit(eachTemplate?._id)\"\r\n >\r\n PREVIEW\r\n </button>\r\n </div>\r\n </div>\r\n </div>\r\n</div>\r\n", styles: ["@import\"https://cdn.v-comply.com/design-system/css/icons/icons.css\";@import\"https://cdn.v-comply.com/design-system/css/display/display.css\";@import\"https://cdn.v-comply.com/design-system/css/alignment/alignment.css\";@import\"https://cdn.v-comply.com/design-system/css/text/text.css\";@import\"https://cdn.v-comply.com/design-system/css/color/color.css\";@import\"https://cdn.v-comply.com/design-system/css/width/width.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-top.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-bottom.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-left.css\";@import\"https://cdn.v-comply.com/design-system/css/margin/margin-right.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-top.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-bottom.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-left.css\";@import\"https://cdn.v-comply.com/design-system/css/padding/padding-right.css\";::ng-deep .template-list-table .table-header{background:#fff;position:sticky;top:0;z-index:1}::ng-deep .template-list-table .table-header .table-column{color:#747576!important;line-height:1rem!important;min-height:2rem!important}::ng-deep .template-list-table .table-body{position:relative}::ng-deep .template-list-table .table-body .table-row{background:#fff;border-radius:4px;border:1px solid #e3e3e9;transition:all .2s ease-in-out;margin-bottom:.25rem}::ng-deep .template-list-table .table-body .table-row:hover{background:#f8f8f8;transition:all .2s ease-in-out}::ng-deep .template-list-table .table-body .table-row:hover .table-column.serial app-cs-radio{opacity:1}::ng-deep .template-list-table .table-body .table-row:hover .table-column.view-action button.previewBtn{opacity:1}::ng-deep .template-list-table .table-body .table-row.active .table-column.serial app-cs-radio{opacity:1}::ng-deep .template-list-table .table-row{display:flex;justify-content:space-between;position:relative}::ng-deep .template-list-table .table-row .table-column{color:#000;min-height:2.5rem;position:relative;width:100%}::ng-deep .template-list-table .table-row .table-column i.info{color:#1e5dd3;cursor:pointer}::ng-deep .template-list-table .table-row .table-column .sorting{cursor:pointer;position:relative;top:1px;left:-1px}::ng-deep .template-list-table .table-row .table-column .sorting i{cursor:pointer}::ng-deep .template-list-table .table-row .table-column.serial{width:2rem;max-width:2rem;flex:0 0 2rem;justify-content:center}::ng-deep .template-list-table .table-row .table-column.serial .sr-no{width:1rem;background:#f2f2f5;writing-mode:vertical-lr;color:#787a8c;font-size:.625rem;font-weight:500;display:flex;height:2.5rem;align-items:center;justify-content:center;position:relative;transition:all .2s ease-in-out}::ng-deep .template-list-table .table-row .table-column.serial app-cs-radio{position:absolute;top:12px;left:8px;opacity:0;transition:all .2s ease-in-out}::ng-deep .template-list-table .table-row .table-column.template-name{width:calc(100% - 25rem);min-width:calc(100% - 25rem)}::ng-deep .template-list-table .table-row .table-column.template-name .value{text-overflow:ellipsis;white-space:nowrap;overflow:hidden;width:calc(100% - 3rem)}::ng-deep .template-list-table .table-row .table-column.category{width:18rem;min-width:18rem}::ng-deep .template-list-table .table-row .table-column.category .category-inner{max-width:calc(100% - 3rem)}::ng-deep .template-list-table .table-row .table-column.category .category-inner .category-name{color:#787a8c;text-overflow:ellipsis;white-space:nowrap;overflow:hidden}::ng-deep .template-list-table .table-row .table-column.category button.countBtn{background:#fff;border-radius:1.25rem;border:1px solid #cdced6;height:1rem;min-width:1.5rem}::ng-deep .template-list-table .table-row .table-column.view-action{width:5rem;min-width:5rem}::ng-deep .template-list-table .table-row .table-column.view-action button.previewBtn{background:#fff;border-radius:.125rem;border:1px solid #dbdbdb;height:1.25rem;transition:all .2s ease-in-out;opacity:0}\n"] }]
|
|
27
|
+
}], propDecorators: { selectedTemplate: [{
|
|
28
|
+
type: Input
|
|
29
|
+
}], templateList: [{
|
|
30
|
+
type: Input
|
|
31
|
+
}], loader: [{
|
|
32
|
+
type: Input
|
|
33
|
+
}], categoryList: [{
|
|
34
|
+
type: Input
|
|
35
|
+
}], onSort: [{
|
|
36
|
+
type: Output
|
|
37
|
+
}], onSelectTemplate: [{
|
|
38
|
+
type: Output
|
|
39
|
+
}], onPreview: [{
|
|
40
|
+
type: Output
|
|
41
|
+
}] } });
|
|
42
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"template-list-table.component.js","sourceRoot":"","sources":["../../../../../../../projects/vx-workflow-engine/src/lib/sharedComponents/policy-template/template-list-table/template-list-table.component.ts","../../../../../../../projects/vx-workflow-engine/src/lib/sharedComponents/policy-template/template-list-table/template-list-table.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;;;;;;;AAOvE,MAAM,OAAO,0BAA0B;IALvC;QAOW,iBAAY,GAAU,EAAE,CAAC;QACzB,WAAM,GAAY,KAAK,CAAC;QACxB,iBAAY,GAAU,EAAE,CAAC;QACxB,WAAM,GAAG,IAAI,YAAY,EAAU,CAAC;QACpC,qBAAgB,GAAG,IAAI,YAAY,EAAO,CAAC;QAC3C,cAAS,GAAG,IAAI,YAAY,EAAO,CAAC;KAM/C;IAJC,QAAQ,CAAC,QAAa;QACpB,IAAI,CAAC,gBAAgB,GAAG,QAAQ,CAAC;QACjC,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IACvC,CAAC;+GAZU,0BAA0B;mGAA1B,0BAA0B,4RCPvC,qrMAiKA;;4FD1Ja,0BAA0B;kBALtC,SAAS;+BACE,yBAAyB;8BAK1B,gBAAgB;sBAAxB,KAAK;gBACG,YAAY;sBAApB,KAAK;gBACG,MAAM;sBAAd,KAAK;gBACG,YAAY;sBAApB,KAAK;gBACI,MAAM;sBAAf,MAAM;gBACG,gBAAgB;sBAAzB,MAAM;gBACG,SAAS;sBAAlB,MAAM","sourcesContent":["import { Component, EventEmitter, Input, Output } from '@angular/core';\r\n\r\n@Component({\r\n  selector: 'app-template-list-table',\r\n  templateUrl: './template-list-table.component.html',\r\n  styleUrls: ['./template-list-table.component.less'],\r\n})\r\nexport class TemplateListTableComponent {\r\n  @Input() selectedTemplate: any;\r\n  @Input() templateList: any[] = [];\r\n  @Input() loader: boolean = false;\r\n  @Input() categoryList: any[] = [];\r\n  @Output() onSort = new EventEmitter<string>();\r\n  @Output() onSelectTemplate = new EventEmitter<any>();\r\n  @Output() onPreview = new EventEmitter<any>();\r\n\r\n  onSelect(template: any) {\r\n    this.selectedTemplate = template;\r\n    this.onSelectTemplate.emit(template);\r\n  }\r\n}\r\n","<div class=\"template-list-table\">\r\n  <div class=\"table-header\">\r\n    <div class=\"table-row\">\r\n      <div\r\n        class=\"table-column vx-fs-11 vx-fw-500 vx-lh-5 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-d-flex vx-align-center serial\"\r\n      >\r\n        #\r\n      </div>\r\n      <div\r\n        class=\"table-column vx-fs-11 vx-fw-500 vx-lh-5 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-d-flex vx-align-center template-name\"\r\n      >\r\n        <span\r\n          (click)=\"onSort.emit('name')\"\r\n          class=\"sorting vx-fs-9 vx-txt-blue vx-mr-1\"\r\n          ><i class=\"icons\">&#xeaf0;</i></span\r\n        >\r\n        TEMPLATE NAME\r\n      </div>\r\n      <div\r\n        class=\"table-column vx-fs-11 vx-fw-500 vx-lh-5 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-d-flex vx-align-center category\"\r\n      >\r\n        <!-- <span class=\"sorting vx-fs-9 vx-txt-blue vx-mr-1\"\r\n          ><i class=\"icons\">&#xeaf0;</i></span\r\n        > -->\r\n        CATEGORIES\r\n      </div>\r\n      <div\r\n        class=\"table-column vx-fs-11 vx-fw-500 vx-lh-5 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-d-flex vx-align-center view-action\"\r\n      ></div>\r\n    </div>\r\n  </div>\r\n  <div class=\"table-body\">\r\n    <div\r\n      class=\"table-row\"\r\n      *ngFor=\"let eachTemplate of templateList; let i = index\"\r\n      [class.active]=\"selectedTemplate?._id === eachTemplate?._id\"\r\n    >\r\n      <div\r\n        class=\"table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center serial\"\r\n      >\r\n        <div\r\n          class=\"sr-no\"\r\n          [appTooltip]=\"i + 1\"\r\n          placement=\"bottom\"\r\n          delay=\"0\"\r\n          type=\"black\"\r\n          [tooltipMandatory]=\"true\"\r\n        >\r\n          {{ i + 1 }}\r\n        </div>\r\n        <app-cs-radio\r\n          name=\"template\"\r\n          [value]=\"selectedTemplate?._id\"\r\n          [checked]=\"selectedTemplate?._id === eachTemplate?._id\"\r\n          (checkedEvent)=\"onSelect(eachTemplate)\"\r\n        ></app-cs-radio>\r\n      </div>\r\n      <div\r\n        class=\"table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center template-name\"\r\n      >\r\n        <div\r\n          class=\"value vx-fs-12 vx-label-txt\"\r\n          [appTooltip]=\"eachTemplate?.name\"\r\n          placement=\"bottom-left\"\r\n          delay=\"0\"\r\n          type=\"black\"\r\n          [tooltipMandatory]=\"false\"\r\n        >\r\n          {{ eachTemplate?.name }}\r\n        </div>\r\n      </div>\r\n      <div\r\n        class=\"table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center category\"\r\n        *ngIf=\"eachTemplate?.categoryDetails as categoryDetails\"\r\n      >\r\n        <div class=\"category-inner\">\r\n          <div class=\"category-name vx-fs-12 vx-lh-4\">\r\n            {{ categoryDetails[0]?.item_name }}\r\n          </div>\r\n          <div\r\n            *ngIf=\"categoryDetails[0]?.parent_items?.length\"\r\n            class=\"within-part vx-d-flex vx-align-center vx-pr-3\"\r\n          >\r\n            <span\r\n              class=\"within-box vx-fs-9 vx-fw-600 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-mr-2 vx-lh-3\"\r\n              >Within</span\r\n            >\r\n            <span\r\n              class=\"within-value vx-fs-11 vx-paragraph-txt\"\r\n              [appTooltip]=\"categoryDetails[0]?.parent_items?.join(' < ')\"\r\n              placement=\"bottom-left\"\r\n              delay=\"0\"\r\n              type=\"black\"\r\n              [tooltipMandatory]=\"false\"\r\n              >{{ categoryDetails[0]?.parent_items?.join(\" < \") }}</span\r\n            >\r\n          </div>\r\n        </div>\r\n        <button\r\n          *ngIf=\"categoryDetails?.length > 1\"\r\n          class=\"countBtn vx-fs-9 vx-fw-600 vx-txt-blue vx-pl-1 vx-pr-1 vx-m-0 vx-ml-1 vx-d-flex vx-align-center vx-justify-center\"\r\n          appPopover\r\n          (click)=\"MoreCategory.popover()\"\r\n          placement=\"right\"\r\n        >\r\n          +{{ categoryDetails?.length - 1 }}\r\n        </button>\r\n\r\n        <app-popover #MoreCategory>\r\n          <div class=\"wf-action-list category-list\">\r\n            <ul class=\"action-item\">\r\n              <li *ngFor=\"let eachTemplate of categoryDetails | slice : 1\">\r\n                <div class=\"avatar-card\">\r\n                  <div class=\"vx-w-100\">\r\n                    <span\r\n                      class=\"value vx-p-0 vx-w-100\"\r\n                      [appTooltip]=\"eachTemplate?.item_name\"\r\n                      placement=\"bottom-left\"\r\n                      type=\"black\"\r\n                      delay=\"0\"\r\n                      [tooltipMandatory]=\"false\"\r\n                      >{{ eachTemplate?.item_name }}</span\r\n                    >\r\n                    <div\r\n                      *ngIf=\"eachTemplate?.parent_items?.length\"\r\n                      class=\"within-part vx-d-flex vx-align-center vx-pr-3\"\r\n                    >\r\n                      <span\r\n                        class=\"within-box vx-fs-9 vx-fw-600 vx-tt-uppercase vx-pl-1 vx-pr-1 vx-mr-2 vx-lh-3\"\r\n                        >Within</span\r\n                      >\r\n                      <span\r\n                        class=\"within-value vx-fs-11 vx-paragraph-txt\"\r\n                        [appTooltip]=\"eachTemplate?.parent_items?.join(' < ')\"\r\n                        placement=\"bottom-left\"\r\n                        delay=\"0\"\r\n                        type=\"black\"\r\n                        [tooltipMandatory]=\"false\"\r\n                        >{{ eachTemplate?.parent_items?.join(\" < \") }}</span\r\n                      >\r\n                    </div>\r\n                  </div>\r\n                </div>\r\n              </li>\r\n            </ul>\r\n          </div>\r\n        </app-popover>\r\n      </div>\r\n      <div\r\n        class=\"table-column vx-pl-1 vx-pr-1 vx-d-flex vx-align-center view-action\"\r\n      >\r\n        <button\r\n          class=\"previewBtn vx-fs-11 vx-fw-500 vx-txt-blue vx-tt-uppercase vx-p-0 vx-pl-2 vx-pr-2 vx-m-0 vx-d-flex vx-align-center vx-lh-6\"\r\n          (click)=\"onPreview.emit(eachTemplate?._id)\"\r\n        >\r\n          PREVIEW\r\n        </button>\r\n      </div>\r\n    </div>\r\n  </div>\r\n</div>\r\n"]}
|
package/esm2022/lib/sharedComponents/policy-template/template-pipes/get-template-category.pipe.mjs
ADDED
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { Pipe } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export class GetTemplateCategoryPipe {
|
|
4
|
+
transform(value, list) {
|
|
5
|
+
if (value.length === 0 || list.length === 0) {
|
|
6
|
+
return [];
|
|
7
|
+
}
|
|
8
|
+
return list.filter((item) => value.includes(item.item_id));
|
|
9
|
+
}
|
|
10
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: GetTemplateCategoryPipe, deps: [], target: i0.ɵɵFactoryTarget.Pipe }); }
|
|
11
|
+
static { this.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "16.2.12", ngImport: i0, type: GetTemplateCategoryPipe, name: "getTemplateCategory" }); }
|
|
12
|
+
}
|
|
13
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: GetTemplateCategoryPipe, decorators: [{
|
|
14
|
+
type: Pipe,
|
|
15
|
+
args: [{
|
|
16
|
+
name: 'getTemplateCategory',
|
|
17
|
+
}]
|
|
18
|
+
}] });
|
|
19
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2V0LXRlbXBsYXRlLWNhdGVnb3J5LnBpcGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy92eC13b3JrZmxvdy1lbmdpbmUvc3JjL2xpYi9zaGFyZWRDb21wb25lbnRzL3BvbGljeS10ZW1wbGF0ZS90ZW1wbGF0ZS1waXBlcy9nZXQtdGVtcGxhdGUtY2F0ZWdvcnkucGlwZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsSUFBSSxFQUFpQixNQUFNLGVBQWUsQ0FBQzs7QUFLcEQsTUFBTSxPQUFPLHVCQUF1QjtJQUNsQyxTQUFTLENBQUMsS0FBZSxFQUFFLElBQVc7UUFDcEMsSUFBSSxLQUFLLENBQUMsTUFBTSxLQUFLLENBQUMsSUFBSSxJQUFJLENBQUMsTUFBTSxLQUFLLENBQUMsRUFBRTtZQUMzQyxPQUFPLEVBQUUsQ0FBQztTQUNYO1FBQ0QsT0FBTyxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUMsSUFBSSxFQUFFLEVBQUUsQ0FBQyxLQUFLLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDO0lBQzdELENBQUM7K0dBTlUsdUJBQXVCOzZHQUF2Qix1QkFBdUI7OzRGQUF2Qix1QkFBdUI7a0JBSG5DLElBQUk7bUJBQUM7b0JBQ0osSUFBSSxFQUFFLHFCQUFxQjtpQkFDNUIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBQaXBlLCBQaXBlVHJhbnNmb3JtIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbkBQaXBlKHtcbiAgbmFtZTogJ2dldFRlbXBsYXRlQ2F0ZWdvcnknLFxufSlcbmV4cG9ydCBjbGFzcyBHZXRUZW1wbGF0ZUNhdGVnb3J5UGlwZSBpbXBsZW1lbnRzIFBpcGVUcmFuc2Zvcm0ge1xuICB0cmFuc2Zvcm0odmFsdWU6IG51bWJlcltdLCBsaXN0OiBhbnlbXSk6IGFueSB7XG4gICAgaWYgKHZhbHVlLmxlbmd0aCA9PT0gMCB8fCBsaXN0Lmxlbmd0aCA9PT0gMCkge1xuICAgICAgcmV0dXJuIFtdO1xuICAgIH1cbiAgICByZXR1cm4gbGlzdC5maWx0ZXIoKGl0ZW0pID0+IHZhbHVlLmluY2x1ZGVzKGl0ZW0uaXRlbV9pZCkpO1xuICB9XG59XG4iXX0=
|