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.
Files changed (42) hide show
  1. package/esm2022/lib/constants/template.constant.mjs +6 -0
  2. package/esm2022/lib/link-related-policies/link-related-policies.component.mjs +1 -2
  3. package/esm2022/lib/services/auth.service.mjs +172 -0
  4. package/esm2022/lib/sharedComponents/document-section/document-section.component.mjs +49 -24
  5. package/esm2022/lib/sharedComponents/policy-template/constants/template.constant.mjs +3 -0
  6. package/esm2022/lib/sharedComponents/policy-template/policy-template.module.mjs +65 -0
  7. package/esm2022/lib/sharedComponents/policy-template/select-template-list/select-template-list.component.mjs +206 -0
  8. package/esm2022/lib/sharedComponents/policy-template/services/template.service.mjs +67 -0
  9. package/esm2022/lib/sharedComponents/policy-template/template-list-table/template-list-table.component.mjs +42 -0
  10. package/esm2022/lib/sharedComponents/policy-template/template-pipes/get-template-category.pipe.mjs +19 -0
  11. package/esm2022/lib/sharedComponents/policy-template/template-pipes/search-template.pipe.mjs +59 -0
  12. package/esm2022/lib/sharedComponents/policy-template/template-pipes/template-pipes.module.mjs +19 -0
  13. package/esm2022/lib/sharedComponents/policy-template/view-policy/view-policy/view-policy.component.mjs +93 -0
  14. package/esm2022/lib/sharedComponents/policy-template/view-policy/view-policy.module.mjs +19 -0
  15. package/esm2022/lib/ui-kit/multi-select/cs-multiselect/cs-multiselect.component.mjs +203 -0
  16. package/esm2022/lib/ui-kit/multi-select/cs-multiselect-option/cs-multiselect-option.component.mjs +31 -0
  17. package/esm2022/lib/ui-kit/multi-select/multi-select.module.mjs +37 -0
  18. package/esm2022/lib/ui-kit/multi-select/multi-select.service.mjs +16 -0
  19. package/esm2022/lib/workflow-engine.module.mjs +11 -3
  20. package/esm2022/lib/workflow-policy/workflow-policy.component.mjs +36 -26
  21. package/fesm2022/vcomply-workflow-engine.mjs +879 -39
  22. package/fesm2022/vcomply-workflow-engine.mjs.map +1 -1
  23. package/lib/constants/template.constant.d.ts +5 -0
  24. package/lib/services/auth.service.d.ts +39 -0
  25. package/lib/sharedComponents/document-section/document-section.component.d.ts +3 -1
  26. package/lib/sharedComponents/policy-template/constants/template.constant.d.ts +2 -0
  27. package/lib/sharedComponents/policy-template/policy-template.module.d.ts +20 -0
  28. package/lib/sharedComponents/policy-template/select-template-list/select-template-list.component.d.ts +49 -0
  29. package/lib/sharedComponents/policy-template/services/template.service.d.ts +19 -0
  30. package/lib/sharedComponents/policy-template/template-list-table/template-list-table.component.d.ts +14 -0
  31. package/lib/sharedComponents/policy-template/template-pipes/get-template-category.pipe.d.ts +7 -0
  32. package/lib/sharedComponents/policy-template/template-pipes/search-template.pipe.d.ts +37 -0
  33. package/lib/sharedComponents/policy-template/template-pipes/template-pipes.module.d.ts +9 -0
  34. package/lib/sharedComponents/policy-template/view-policy/view-policy/view-policy.component.d.ts +25 -0
  35. package/lib/sharedComponents/policy-template/view-policy/view-policy.module.d.ts +9 -0
  36. package/lib/ui-kit/multi-select/cs-multiselect/cs-multiselect.component.d.ts +69 -0
  37. package/lib/ui-kit/multi-select/cs-multiselect-option/cs-multiselect-option.component.d.ts +12 -0
  38. package/lib/ui-kit/multi-select/multi-select.module.d.ts +11 -0
  39. package/lib/ui-kit/multi-select/multi-select.service.d.ts +7 -0
  40. package/lib/workflow-engine.module.d.ts +3 -1
  41. package/lib/workflow-policy/workflow-policy.component.d.ts +2 -0
  42. package/package.json +1 -1
@@ -0,0 +1,59 @@
1
+ import { Pipe } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ /**
4
+ * @Pipe SearchByKeys
5
+ *
6
+ * A custom Angular pipe that filters an array of objects based on a search value and specified keys.
7
+ *
8
+ * @example
9
+ * <div *ngFor="let item of items | SearchByKeys: ['name', 'description']: searchValue">
10
+ * {{ item.name }}
11
+ * </div>
12
+ *
13
+ * @class
14
+ * @implements {PipeTransform}
15
+ */
16
+ /**
17
+ * Transforms an array of objects by filtering them based on the provided keys and search value.
18
+ *
19
+ * @param {any[]} items - The array of objects to be filtered.
20
+ * @param {string[]} keys - The keys of the objects to be searched.
21
+ * @param {string} value - The search value to filter the objects.
22
+ * @returns {any[]} - The filtered array of objects.
23
+ */
24
+ /**
25
+ * Searches within an object for a value.
26
+ *
27
+ * @private
28
+ * @param {any} obj - The object to search within.
29
+ * @param {string} value - The search value.
30
+ * @returns {boolean} - True if the value is found within the object, otherwise false.
31
+ */
32
+ export class SearchByKeysPipe {
33
+ transform(items, keys, value) {
34
+ if (!items || !keys || !value) {
35
+ return items;
36
+ }
37
+ value = value.toLowerCase();
38
+ return items.filter((item) => {
39
+ return keys.some((key) => {
40
+ if (Array.isArray(item[key])) {
41
+ return item[key].some((subItem) => this.searchInObject(subItem, value));
42
+ }
43
+ return item[key]?.toString().toLowerCase().includes(value);
44
+ });
45
+ });
46
+ }
47
+ searchInObject(obj, value) {
48
+ return Object.values(obj).some((val) => val?.toString().toLowerCase().includes(value));
49
+ }
50
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: SearchByKeysPipe, deps: [], target: i0.ɵɵFactoryTarget.Pipe }); }
51
+ static { this.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "16.2.12", ngImport: i0, type: SearchByKeysPipe, name: "SearchByKeys" }); }
52
+ }
53
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: SearchByKeysPipe, decorators: [{
54
+ type: Pipe,
55
+ args: [{
56
+ name: 'SearchByKeys',
57
+ }]
58
+ }] });
59
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VhcmNoLXRlbXBsYXRlLnBpcGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy92eC13b3JrZmxvdy1lbmdpbmUvc3JjL2xpYi9zaGFyZWRDb21wb25lbnRzL3BvbGljeS10ZW1wbGF0ZS90ZW1wbGF0ZS1waXBlcy9zZWFyY2gtdGVtcGxhdGUucGlwZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsSUFBSSxFQUFpQixNQUFNLGVBQWUsQ0FBQzs7QUFFcEQ7Ozs7Ozs7Ozs7OztHQVlHO0FBRUg7Ozs7Ozs7R0FPRztBQUVIOzs7Ozs7O0dBT0c7QUFJSCxNQUFNLE9BQU8sZ0JBQWdCO0lBQzNCLFNBQVMsQ0FBQyxLQUFZLEVBQUUsSUFBYyxFQUFFLEtBQWE7UUFDbkQsSUFBSSxDQUFDLEtBQUssSUFBSSxDQUFDLElBQUksSUFBSSxDQUFDLEtBQUssRUFBRTtZQUM3QixPQUFPLEtBQUssQ0FBQztTQUNkO1FBQ0QsS0FBSyxHQUFHLEtBQUssQ0FBQyxXQUFXLEVBQUUsQ0FBQztRQUM1QixPQUFPLEtBQUssQ0FBQyxNQUFNLENBQUMsQ0FBQyxJQUFJLEVBQUUsRUFBRTtZQUMzQixPQUFPLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQyxHQUFHLEVBQUUsRUFBRTtnQkFDdkIsSUFBSSxLQUFLLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQyxFQUFFO29CQUM1QixPQUFPLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxPQUFZLEVBQUUsRUFBRSxDQUNyQyxJQUFJLENBQUMsY0FBYyxDQUFDLE9BQU8sRUFBRSxLQUFLLENBQUMsQ0FDcEMsQ0FBQztpQkFDSDtnQkFDRCxPQUFPLElBQUksQ0FBQyxHQUFHLENBQUMsRUFBRSxRQUFRLEVBQUUsQ0FBQyxXQUFXLEVBQUUsQ0FBQyxRQUFRLENBQUMsS0FBSyxDQUFDLENBQUM7WUFDN0QsQ0FBQyxDQUFDLENBQUM7UUFDTCxDQUFDLENBQUMsQ0FBQztJQUNMLENBQUM7SUFFTyxjQUFjLENBQUMsR0FBUSxFQUFFLEtBQWE7UUFDNUMsT0FBTyxNQUFNLENBQUMsTUFBTSxDQUFDLEdBQUcsQ0FBQyxDQUFDLElBQUksQ0FBQyxDQUFDLEdBQUcsRUFBRSxFQUFFLENBQ3JDLEdBQUcsRUFBRSxRQUFRLEVBQUUsQ0FBQyxXQUFXLEVBQUUsQ0FBQyxRQUFRLENBQUMsS0FBSyxDQUFDLENBQzlDLENBQUM7SUFDSixDQUFDOytHQXRCVSxnQkFBZ0I7NkdBQWhCLGdCQUFnQjs7NEZBQWhCLGdCQUFnQjtrQkFINUIsSUFBSTttQkFBQztvQkFDSixJQUFJLEVBQUUsY0FBYztpQkFDckIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBQaXBlLCBQaXBlVHJhbnNmb3JtIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbi8qKlxuICogQFBpcGUgU2VhcmNoQnlLZXlzXG4gKlxuICogQSBjdXN0b20gQW5ndWxhciBwaXBlIHRoYXQgZmlsdGVycyBhbiBhcnJheSBvZiBvYmplY3RzIGJhc2VkIG9uIGEgc2VhcmNoIHZhbHVlIGFuZCBzcGVjaWZpZWQga2V5cy5cbiAqXG4gKiBAZXhhbXBsZVxuICogPGRpdiAqbmdGb3I9XCJsZXQgaXRlbSBvZiBpdGVtcyB8IFNlYXJjaEJ5S2V5czogWyduYW1lJywgJ2Rlc2NyaXB0aW9uJ106IHNlYXJjaFZhbHVlXCI+XG4gKiAgIHt7IGl0ZW0ubmFtZSB9fVxuICogPC9kaXY+XG4gKlxuICogQGNsYXNzXG4gKiBAaW1wbGVtZW50cyB7UGlwZVRyYW5zZm9ybX1cbiAqL1xuXG4vKipcbiAqIFRyYW5zZm9ybXMgYW4gYXJyYXkgb2Ygb2JqZWN0cyBieSBmaWx0ZXJpbmcgdGhlbSBiYXNlZCBvbiB0aGUgcHJvdmlkZWQga2V5cyBhbmQgc2VhcmNoIHZhbHVlLlxuICpcbiAqIEBwYXJhbSB7YW55W119IGl0ZW1zIC0gVGhlIGFycmF5IG9mIG9iamVjdHMgdG8gYmUgZmlsdGVyZWQuXG4gKiBAcGFyYW0ge3N0cmluZ1tdfSBrZXlzIC0gVGhlIGtleXMgb2YgdGhlIG9iamVjdHMgdG8gYmUgc2VhcmNoZWQuXG4gKiBAcGFyYW0ge3N0cmluZ30gdmFsdWUgLSBUaGUgc2VhcmNoIHZhbHVlIHRvIGZpbHRlciB0aGUgb2JqZWN0cy5cbiAqIEByZXR1cm5zIHthbnlbXX0gLSBUaGUgZmlsdGVyZWQgYXJyYXkgb2Ygb2JqZWN0cy5cbiAqL1xuXG4vKipcbiAqIFNlYXJjaGVzIHdpdGhpbiBhbiBvYmplY3QgZm9yIGEgdmFsdWUuXG4gKlxuICogQHByaXZhdGVcbiAqIEBwYXJhbSB7YW55fSBvYmogLSBUaGUgb2JqZWN0IHRvIHNlYXJjaCB3aXRoaW4uXG4gKiBAcGFyYW0ge3N0cmluZ30gdmFsdWUgLSBUaGUgc2VhcmNoIHZhbHVlLlxuICogQHJldHVybnMge2Jvb2xlYW59IC0gVHJ1ZSBpZiB0aGUgdmFsdWUgaXMgZm91bmQgd2l0aGluIHRoZSBvYmplY3QsIG90aGVyd2lzZSBmYWxzZS5cbiAqL1xuQFBpcGUoe1xuICBuYW1lOiAnU2VhcmNoQnlLZXlzJyxcbn0pXG5leHBvcnQgY2xhc3MgU2VhcmNoQnlLZXlzUGlwZSBpbXBsZW1lbnRzIFBpcGVUcmFuc2Zvcm0ge1xuICB0cmFuc2Zvcm0oaXRlbXM6IGFueVtdLCBrZXlzOiBzdHJpbmdbXSwgdmFsdWU6IHN0cmluZyk6IGFueVtdIHtcbiAgICBpZiAoIWl0ZW1zIHx8ICFrZXlzIHx8ICF2YWx1ZSkge1xuICAgICAgcmV0dXJuIGl0ZW1zO1xuICAgIH1cbiAgICB2YWx1ZSA9IHZhbHVlLnRvTG93ZXJDYXNlKCk7XG4gICAgcmV0dXJuIGl0ZW1zLmZpbHRlcigoaXRlbSkgPT4ge1xuICAgICAgcmV0dXJuIGtleXMuc29tZSgoa2V5KSA9PiB7XG4gICAgICAgIGlmIChBcnJheS5pc0FycmF5KGl0ZW1ba2V5XSkpIHtcbiAgICAgICAgICByZXR1cm4gaXRlbVtrZXldLnNvbWUoKHN1Ykl0ZW06IGFueSkgPT5cbiAgICAgICAgICAgIHRoaXMuc2VhcmNoSW5PYmplY3Qoc3ViSXRlbSwgdmFsdWUpXG4gICAgICAgICAgKTtcbiAgICAgICAgfVxuICAgICAgICByZXR1cm4gaXRlbVtrZXldPy50b1N0cmluZygpLnRvTG93ZXJDYXNlKCkuaW5jbHVkZXModmFsdWUpO1xuICAgICAgfSk7XG4gICAgfSk7XG4gIH1cblxuICBwcml2YXRlIHNlYXJjaEluT2JqZWN0KG9iajogYW55LCB2YWx1ZTogc3RyaW5nKTogYm9vbGVhbiB7XG4gICAgcmV0dXJuIE9iamVjdC52YWx1ZXMob2JqKS5zb21lKCh2YWwpID0+XG4gICAgICB2YWw/LnRvU3RyaW5nKCkudG9Mb3dlckNhc2UoKS5pbmNsdWRlcyh2YWx1ZSlcbiAgICApO1xuICB9XG59XG4iXX0=
@@ -0,0 +1,19 @@
1
+ import { NgModule } from '@angular/core';
2
+ import { CommonModule } from '@angular/common';
3
+ import { GetTemplateCategoryPipe } from './get-template-category.pipe';
4
+ import { SearchByKeysPipe } from './search-template.pipe';
5
+ import * as i0 from "@angular/core";
6
+ export class TemplatePipesModule {
7
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TemplatePipesModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
8
+ static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.2.12", ngImport: i0, type: TemplatePipesModule, declarations: [GetTemplateCategoryPipe, SearchByKeysPipe], imports: [CommonModule], exports: [GetTemplateCategoryPipe, SearchByKeysPipe] }); }
9
+ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TemplatePipesModule, imports: [CommonModule] }); }
10
+ }
11
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TemplatePipesModule, decorators: [{
12
+ type: NgModule,
13
+ args: [{
14
+ declarations: [GetTemplateCategoryPipe, SearchByKeysPipe],
15
+ imports: [CommonModule],
16
+ exports: [GetTemplateCategoryPipe, SearchByKeysPipe],
17
+ }]
18
+ }] });
19
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGVtcGxhdGUtcGlwZXMubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdngtd29ya2Zsb3ctZW5naW5lL3NyYy9saWIvc2hhcmVkQ29tcG9uZW50cy9wb2xpY3ktdGVtcGxhdGUvdGVtcGxhdGUtcGlwZXMvdGVtcGxhdGUtcGlwZXMubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxNQUFNLDhCQUE4QixDQUFDO0FBQ3ZFLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHdCQUF3QixDQUFDOztBQU8xRCxNQUFNLE9BQU8sbUJBQW1COytHQUFuQixtQkFBbUI7Z0hBQW5CLG1CQUFtQixpQkFKZix1QkFBdUIsRUFBRSxnQkFBZ0IsYUFDOUMsWUFBWSxhQUNaLHVCQUF1QixFQUFFLGdCQUFnQjtnSEFFeEMsbUJBQW1CLFlBSHBCLFlBQVk7OzRGQUdYLG1CQUFtQjtrQkFML0IsUUFBUTttQkFBQztvQkFDUixZQUFZLEVBQUUsQ0FBQyx1QkFBdUIsRUFBRSxnQkFBZ0IsQ0FBQztvQkFDekQsT0FBTyxFQUFFLENBQUMsWUFBWSxDQUFDO29CQUN2QixPQUFPLEVBQUUsQ0FBQyx1QkFBdUIsRUFBRSxnQkFBZ0IsQ0FBQztpQkFDckQiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IEdldFRlbXBsYXRlQ2F0ZWdvcnlQaXBlIH0gZnJvbSAnLi9nZXQtdGVtcGxhdGUtY2F0ZWdvcnkucGlwZSc7XG5pbXBvcnQgeyBTZWFyY2hCeUtleXNQaXBlIH0gZnJvbSAnLi9zZWFyY2gtdGVtcGxhdGUucGlwZSc7XG5cbkBOZ01vZHVsZSh7XG4gIGRlY2xhcmF0aW9uczogW0dldFRlbXBsYXRlQ2F0ZWdvcnlQaXBlLCBTZWFyY2hCeUtleXNQaXBlXSxcbiAgaW1wb3J0czogW0NvbW1vbk1vZHVsZV0sXG4gIGV4cG9ydHM6IFtHZXRUZW1wbGF0ZUNhdGVnb3J5UGlwZSwgU2VhcmNoQnlLZXlzUGlwZV0sXG59KVxuZXhwb3J0IGNsYXNzIFRlbXBsYXRlUGlwZXNNb2R1bGUge31cbiJdfQ==
@@ -0,0 +1,93 @@
1
+ import { Component, Input, Optional, ViewChild, } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ import * as i1 from "../../../../configurations";
4
+ import * as i2 from "@angular/common";
5
+ import * as i3 from "@syncfusion/ej2-angular-documenteditor";
6
+ export class ViewPolicyComponent {
7
+ constructor(config) {
8
+ this.resizeEditor = false;
9
+ this.serviceUrl = '';
10
+ this.settings = { optimizeSfdt: false };
11
+ this.isContentLoaded = false;
12
+ this.hasComments = false;
13
+ this.palette = [
14
+ '#011f4b',
15
+ '#009688',
16
+ '#ee4035',
17
+ '#f37736',
18
+ '#7bc043',
19
+ '#854442',
20
+ '#ffa700',
21
+ '#d11141',
22
+ '#ff3377',
23
+ '#8d5524',
24
+ ];
25
+ this.userName = ''; // current user name
26
+ this.serviceUrl = config?.envConfig?.cpEditor;
27
+ }
28
+ ngOnChanges(changes) {
29
+ if (changes?.contents?.currentValue) {
30
+ this.onCreating();
31
+ }
32
+ }
33
+ ngOnInit() { }
34
+ onCreating() {
35
+ this.isContentLoaded = true;
36
+ this.contents = JSON.stringify(JSON.parse(this.contents));
37
+ setTimeout(() => {
38
+ if (this.documentEditor?.documentEditor) {
39
+ this.configureEditor();
40
+ }
41
+ }, 100);
42
+ }
43
+ onCreated() {
44
+ if (this.documentEditor &&
45
+ this.documentEditor?.documentEditor &&
46
+ this.documentEditor?.documentEditor?.isDocumentLoaded) {
47
+ this.configureEditor();
48
+ this.documentEditor.documentEditor.height = `${window.innerHeight - 220}px`;
49
+ this.documentEditor.documentEditor.userColor =
50
+ this.palette[Math.floor(Math.random() * this.palette.length)];
51
+ this.resizeEditor = true;
52
+ this.checkComments();
53
+ }
54
+ }
55
+ configureEditor() {
56
+ if (this.documentEditor.documentEditor) {
57
+ this.documentEditor.documentEditor.showRevisions = false;
58
+ this.documentEditor.documentEditor.showComments = false;
59
+ this.documentEditor.documentEditor.resize();
60
+ this.documentEditor.documentEditor.focusIn();
61
+ if (this.contents) {
62
+ this.documentEditor.documentEditor.open(this.contents);
63
+ }
64
+ }
65
+ }
66
+ checkComments() {
67
+ const commentsLength = this.documentEditor?.documentEditor?.documentHelper?.comments?.length ||
68
+ 0;
69
+ this.hasComments = commentsLength > 0;
70
+ }
71
+ viewComment() {
72
+ if (this.documentEditor) {
73
+ this.documentEditor.documentEditor.showComments =
74
+ !this.documentEditor.documentEditor.showComments;
75
+ }
76
+ }
77
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ViewPolicyComponent, deps: [{ token: i1.Configurations, optional: true }], target: i0.ɵɵFactoryTarget.Component }); }
78
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: ViewPolicyComponent, selector: "app-view-policy", inputs: { contents: "contents", userName: "userName" }, viewQueries: [{ propertyName: "documentEditor", first: true, predicate: ["document_editor"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<ejs-documenteditorcontainer\r\n *ngIf=\"isContentLoaded\"\r\n (created)=\"onCreated()\"\r\n #document_editor\r\n style=\"width: 100%; height: 100%; display: block\"\r\n [enableToolbar]=\"false\"\r\n [serviceUrl]=\"serviceUrl\"\r\n [restrictEditing]=\"true\"\r\n class=\"e-documenteditor\"\r\n [documentEditorSettings]=\"settings\"\r\n>\r\n</ejs-documenteditorcontainer>\r\n", styles: ["button.commentBtn{background:#fff;border-radius:.125rem;border:1px solid #dbdbdb;color:#1e5dd3;font-size:11px;font-weight:500;text-transform:uppercase;padding:0 .5rem;margin:0;height:1.5rem;display:flex;align-items:center;position:absolute;top:-18px;left:229px;z-index:2}button.commentBtn i{font-size:12px;margin-right:.25rem}::ng-deep ejs-documenteditorcontainer .e-de-ctn .e-de-status-bar{background:#fff!important;border-top:1px solid #dbdbdb;box-shadow:0 -3px 6px #1e5dd326!important;padding:0;display:flex;align-items:center;justify-content:space-between;position:relative;z-index:1}::ng-deep ejs-documenteditorcontainer .e-de-ctn .e-de-status-bar .e-de-ctnr-pg-no-spellout{padding-top:0;width:calc(100% - 100px);color:#000;font-size:13px}::ng-deep ejs-documenteditorcontainer .e-de-ctn .e-de-status-bar .e-de-ctnr-pg-no-spellout span{border:1px solid transparent}::ng-deep ejs-documenteditorcontainer .e-de-ctn .e-de-status-bar .e-de-ctnr-pg-no-spellout .e-input,::ng-deep ejs-documenteditorcontainer .e-de-ctn .e-de-status-bar .e-de-ctnr-pg-no-spellout label{font-size:11px;color:#161b2f;font-weight:500;line-height:16px!important;align-items:center;display:flex}::ng-deep ejs-documenteditorcontainer .e-de-ctn .e-de-status-bar .e-de-ctnr-pg-no-spellout .e-input input,::ng-deep ejs-documenteditorcontainer .e-de-ctn .e-de-status-bar .e-de-ctnr-pg-no-spellout label input{font-size:11px;height:16px;background:#fff;border:1px solid #eee;border-radius:2px;color:#000;padding:0;text-align:center}::ng-deep ejs-documenteditorcontainer .e-de-ctn .e-de-status-bar .e-de-statusbar-pageweb{display:none}::ng-deep ejs-documenteditorcontainer .e-de-ctn .e-de-status-bar .e-de-statusbar-zoom{height:24px;padding:0 20px;margin:0;white-space:nowrap;border-radius:0;box-shadow:none;background:#fafafa;border:0;color:#000;font-weight:400}::ng-deep ejs-documenteditorcontainer .e-de-ctn .e-de-status-bar .e-de-statusbar-zoom .e-btn-icon{position:relative}::ng-deep ejs-documenteditorcontainer .e-de-ctn .e-de-status-bar .e-de-statusbar-zoom .e-btn-icon:before{content:\"\";position:absolute;top:8px;right:-16px;border-left:4px solid transparent;border-right:4px solid transparent;border-top:4px solid #000}::ng-deep .e-dlg-container.e-dlg-center-center{display:none!important}::ng-deep .e-dropdown-popup{background:#fff;position:absolute}::ng-deep .e-dropdown-popup ul{border:none;border-radius:0;box-shadow:0 5px 5px -3px #0003,0 8px 10px 1px #00000024,0 3px 14px 2px #0000001f;box-sizing:border-box;font-size:14px;font-weight:400;list-style-image:none;list-style-position:outside;list-style-type:none;margin:0;min-width:120px;overflow:hidden;padding:8px 0;-webkit-user-select:none;user-select:none;white-space:nowrap}::ng-deep .e-dropdown-popup ul .e-item{cursor:pointer;display:flex;height:36px;line-height:36px;padding:0 16px}::ng-deep .e-dropdown-popup ul .e-item:hover{background-color:#e0e0e0;color:#000000de}::ng-deep .e-dropdown-popup ul .e-item.e-separator{border-bottom-style:solid;border-bottom-width:1px;border-bottom-color:#0000001f;cursor:auto;height:auto;line-height:normal;margin:8px 0;pointer-events:none}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.DocumentEditorContainerComponent, selector: "ejs-documenteditorcontainer", inputs: ["autoResizeOnVisibilityChange", "currentUser", "documentEditorSettings", "documentSettings", "enableAutoFocus", "enableComment", "enableCsp", "enableLocalPaste", "enableLockAndEdit", "enablePersistence", "enableRtl", "enableSpellCheck", "enableToolbar", "enableTrackChanges", "headers", "height", "layoutType", "locale", "restrictEditing", "serverActionSettings", "serviceUrl", "showPropertiesPane", "toolbarItems", "userColor", "width", "zIndex"], outputs: ["beforeAcceptRejectChanges", "beforeCommentAction", "beforePaneSwitch", "commentDelete", "contentChange", "contentControl", "created", "customContextMenuBeforeOpen", "customContextMenuSelect", "destroyed", "documentChange", "selectionChange", "serviceFailure", "toolbarClick", "trackChange", "beforeXmlHttpRequestSend"] }] }); }
79
+ }
80
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ViewPolicyComponent, decorators: [{
81
+ type: Component,
82
+ args: [{ selector: 'app-view-policy', template: "<ejs-documenteditorcontainer\r\n *ngIf=\"isContentLoaded\"\r\n (created)=\"onCreated()\"\r\n #document_editor\r\n style=\"width: 100%; height: 100%; display: block\"\r\n [enableToolbar]=\"false\"\r\n [serviceUrl]=\"serviceUrl\"\r\n [restrictEditing]=\"true\"\r\n class=\"e-documenteditor\"\r\n [documentEditorSettings]=\"settings\"\r\n>\r\n</ejs-documenteditorcontainer>\r\n", styles: ["button.commentBtn{background:#fff;border-radius:.125rem;border:1px solid #dbdbdb;color:#1e5dd3;font-size:11px;font-weight:500;text-transform:uppercase;padding:0 .5rem;margin:0;height:1.5rem;display:flex;align-items:center;position:absolute;top:-18px;left:229px;z-index:2}button.commentBtn i{font-size:12px;margin-right:.25rem}::ng-deep ejs-documenteditorcontainer .e-de-ctn .e-de-status-bar{background:#fff!important;border-top:1px solid #dbdbdb;box-shadow:0 -3px 6px #1e5dd326!important;padding:0;display:flex;align-items:center;justify-content:space-between;position:relative;z-index:1}::ng-deep ejs-documenteditorcontainer .e-de-ctn .e-de-status-bar .e-de-ctnr-pg-no-spellout{padding-top:0;width:calc(100% - 100px);color:#000;font-size:13px}::ng-deep ejs-documenteditorcontainer .e-de-ctn .e-de-status-bar .e-de-ctnr-pg-no-spellout span{border:1px solid transparent}::ng-deep ejs-documenteditorcontainer .e-de-ctn .e-de-status-bar .e-de-ctnr-pg-no-spellout .e-input,::ng-deep ejs-documenteditorcontainer .e-de-ctn .e-de-status-bar .e-de-ctnr-pg-no-spellout label{font-size:11px;color:#161b2f;font-weight:500;line-height:16px!important;align-items:center;display:flex}::ng-deep ejs-documenteditorcontainer .e-de-ctn .e-de-status-bar .e-de-ctnr-pg-no-spellout .e-input input,::ng-deep ejs-documenteditorcontainer .e-de-ctn .e-de-status-bar .e-de-ctnr-pg-no-spellout label input{font-size:11px;height:16px;background:#fff;border:1px solid #eee;border-radius:2px;color:#000;padding:0;text-align:center}::ng-deep ejs-documenteditorcontainer .e-de-ctn .e-de-status-bar .e-de-statusbar-pageweb{display:none}::ng-deep ejs-documenteditorcontainer .e-de-ctn .e-de-status-bar .e-de-statusbar-zoom{height:24px;padding:0 20px;margin:0;white-space:nowrap;border-radius:0;box-shadow:none;background:#fafafa;border:0;color:#000;font-weight:400}::ng-deep ejs-documenteditorcontainer .e-de-ctn .e-de-status-bar .e-de-statusbar-zoom .e-btn-icon{position:relative}::ng-deep ejs-documenteditorcontainer .e-de-ctn .e-de-status-bar .e-de-statusbar-zoom .e-btn-icon:before{content:\"\";position:absolute;top:8px;right:-16px;border-left:4px solid transparent;border-right:4px solid transparent;border-top:4px solid #000}::ng-deep .e-dlg-container.e-dlg-center-center{display:none!important}::ng-deep .e-dropdown-popup{background:#fff;position:absolute}::ng-deep .e-dropdown-popup ul{border:none;border-radius:0;box-shadow:0 5px 5px -3px #0003,0 8px 10px 1px #00000024,0 3px 14px 2px #0000001f;box-sizing:border-box;font-size:14px;font-weight:400;list-style-image:none;list-style-position:outside;list-style-type:none;margin:0;min-width:120px;overflow:hidden;padding:8px 0;-webkit-user-select:none;user-select:none;white-space:nowrap}::ng-deep .e-dropdown-popup ul .e-item{cursor:pointer;display:flex;height:36px;line-height:36px;padding:0 16px}::ng-deep .e-dropdown-popup ul .e-item:hover{background-color:#e0e0e0;color:#000000de}::ng-deep .e-dropdown-popup ul .e-item.e-separator{border-bottom-style:solid;border-bottom-width:1px;border-bottom-color:#0000001f;cursor:auto;height:auto;line-height:normal;margin:8px 0;pointer-events:none}\n"] }]
83
+ }], ctorParameters: function () { return [{ type: i1.Configurations, decorators: [{
84
+ type: Optional
85
+ }] }]; }, propDecorators: { contents: [{
86
+ type: Input
87
+ }], userName: [{
88
+ type: Input
89
+ }], documentEditor: [{
90
+ type: ViewChild,
91
+ args: ['document_editor']
92
+ }] } });
93
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"view-policy.component.js","sourceRoot":"","sources":["../../../../../../../../projects/vx-workflow-engine/src/lib/sharedComponents/policy-template/view-policy/view-policy/view-policy.component.ts","../../../../../../../../projects/vx-workflow-engine/src/lib/sharedComponents/policy-template/view-policy/view-policy/view-policy.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  Input,\r\n  OnChanges,\r\n  OnInit,\r\n  Optional,\r\n  SimpleChanges,\r\n  ViewChild,\r\n} from '@angular/core';\r\nimport {\r\n  DocumentEditorContainerComponent,\r\n  DocumentEditorSettingsModel,\r\n} from '@syncfusion/ej2-angular-documenteditor';\r\nimport { Configurations } from '../../../../configurations';\r\n\r\n@Component({\r\n  selector: 'app-view-policy',\r\n  templateUrl: './view-policy.component.html',\r\n  styleUrls: ['./view-policy.component.less'],\r\n})\r\nexport class ViewPolicyComponent implements OnInit, OnChanges {\r\n  public resizeEditor: boolean = false;\r\n  public serviceUrl: string = '';\r\n  public settings: DocumentEditorSettingsModel = { optimizeSfdt: false };\r\n  public isContentLoaded: boolean = false;\r\n  public hasComments: boolean = false;\r\n\r\n  private readonly palette = [\r\n    '#011f4b',\r\n    '#009688',\r\n    '#ee4035',\r\n    '#f37736',\r\n    '#7bc043',\r\n    '#854442',\r\n    '#ffa700',\r\n    '#d11141',\r\n    '#ff3377',\r\n    '#8d5524',\r\n  ];\r\n\r\n  @Input() contents: any;\r\n\r\n  @Input() userName: string = ''; // current user name\r\n\r\n  @ViewChild('document_editor')\r\n  public documentEditor!: DocumentEditorContainerComponent;\r\n\r\n  constructor(@Optional() config?: Configurations) {\r\n    this.serviceUrl = config?.envConfig?.cpEditor;\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if (changes?.contents?.currentValue) {\r\n      this.onCreating();\r\n    }\r\n  }\r\n\r\n  ngOnInit(): void {}\r\n\r\n  private onCreating(): void {\r\n    this.isContentLoaded = true;\r\n    this.contents = JSON.stringify(JSON.parse(this.contents));\r\n    setTimeout(() => {\r\n      if (this.documentEditor?.documentEditor) {\r\n        this.configureEditor();\r\n      }\r\n    }, 100);\r\n  }\r\n\r\n  public onCreated(): void {\r\n    if (\r\n      this.documentEditor &&\r\n      this.documentEditor?.documentEditor &&\r\n      this.documentEditor?.documentEditor?.isDocumentLoaded\r\n    ) {\r\n      this.configureEditor();\r\n      this.documentEditor.documentEditor.height = `${\r\n        window.innerHeight - 220\r\n      }px`;\r\n      this.documentEditor.documentEditor.userColor =\r\n        this.palette[Math.floor(Math.random() * this.palette.length)];\r\n      this.resizeEditor = true;\r\n      this.checkComments();\r\n    }\r\n  }\r\n\r\n  public configureEditor(): void {\r\n    if (this.documentEditor.documentEditor) {\r\n      this.documentEditor.documentEditor.showRevisions = false;\r\n      this.documentEditor.documentEditor.showComments = false;\r\n      this.documentEditor.documentEditor.resize();\r\n      this.documentEditor.documentEditor.focusIn();\r\n      if (this.contents) {\r\n        this.documentEditor.documentEditor.open(this.contents);\r\n      }\r\n    }\r\n  }\r\n\r\n  checkComments() {\r\n    const commentsLength =\r\n      this.documentEditor?.documentEditor?.documentHelper?.comments?.length ||\r\n      0;\r\n    this.hasComments = commentsLength > 0;\r\n  }\r\n\r\n  public viewComment(): void {\r\n    if (this.documentEditor) {\r\n      this.documentEditor.documentEditor.showComments =\r\n        !this.documentEditor.documentEditor.showComments;\r\n    }\r\n  }\r\n}\r\n","<ejs-documenteditorcontainer\r\n  *ngIf=\"isContentLoaded\"\r\n  (created)=\"onCreated()\"\r\n  #document_editor\r\n  style=\"width: 100%; height: 100%; display: block\"\r\n  [enableToolbar]=\"false\"\r\n  [serviceUrl]=\"serviceUrl\"\r\n  [restrictEditing]=\"true\"\r\n  class=\"e-documenteditor\"\r\n  [documentEditorSettings]=\"settings\"\r\n>\r\n</ejs-documenteditorcontainer>\r\n"]}
@@ -0,0 +1,19 @@
1
+ import { NgModule } from "@angular/core";
2
+ import { CommonModule } from "@angular/common";
3
+ import { ViewPolicyComponent } from "./view-policy/view-policy.component";
4
+ import { DocumentEditorContainerModule } from "@syncfusion/ej2-angular-documenteditor";
5
+ import * as i0 from "@angular/core";
6
+ export class ViewPolicyModule {
7
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ViewPolicyModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
8
+ static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.2.12", ngImport: i0, type: ViewPolicyModule, declarations: [ViewPolicyComponent], imports: [CommonModule, DocumentEditorContainerModule], exports: [ViewPolicyComponent] }); }
9
+ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ViewPolicyModule, imports: [CommonModule, DocumentEditorContainerModule] }); }
10
+ }
11
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ViewPolicyModule, decorators: [{
12
+ type: NgModule,
13
+ args: [{
14
+ declarations: [ViewPolicyComponent],
15
+ imports: [CommonModule, DocumentEditorContainerModule],
16
+ exports: [ViewPolicyComponent],
17
+ }]
18
+ }] });
19
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmlldy1wb2xpY3kubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdngtd29ya2Zsb3ctZW5naW5lL3NyYy9saWIvc2hhcmVkQ29tcG9uZW50cy9wb2xpY3ktdGVtcGxhdGUvdmlldy1wb2xpY3kvdmlldy1wb2xpY3kubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLHFDQUFxQyxDQUFDO0FBQzFFLE9BQU8sRUFBRSw2QkFBNkIsRUFBRSxNQUFNLHdDQUF3QyxDQUFDOztBQU92RixNQUFNLE9BQU8sZ0JBQWdCOytHQUFoQixnQkFBZ0I7Z0hBQWhCLGdCQUFnQixpQkFKWixtQkFBbUIsYUFDeEIsWUFBWSxFQUFFLDZCQUE2QixhQUMzQyxtQkFBbUI7Z0hBRWxCLGdCQUFnQixZQUhqQixZQUFZLEVBQUUsNkJBQTZCOzs0RkFHMUMsZ0JBQWdCO2tCQUw1QixRQUFRO21CQUFDO29CQUNSLFlBQVksRUFBRSxDQUFDLG1CQUFtQixDQUFDO29CQUNuQyxPQUFPLEVBQUUsQ0FBQyxZQUFZLEVBQUUsNkJBQTZCLENBQUM7b0JBQ3RELE9BQU8sRUFBRSxDQUFDLG1CQUFtQixDQUFDO2lCQUMvQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcclxuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSBcIkBhbmd1bGFyL2NvbW1vblwiO1xyXG5pbXBvcnQgeyBWaWV3UG9saWN5Q29tcG9uZW50IH0gZnJvbSBcIi4vdmlldy1wb2xpY3kvdmlldy1wb2xpY3kuY29tcG9uZW50XCI7XHJcbmltcG9ydCB7IERvY3VtZW50RWRpdG9yQ29udGFpbmVyTW9kdWxlIH0gZnJvbSBcIkBzeW5jZnVzaW9uL2VqMi1hbmd1bGFyLWRvY3VtZW50ZWRpdG9yXCI7XHJcblxyXG5ATmdNb2R1bGUoe1xyXG4gIGRlY2xhcmF0aW9uczogW1ZpZXdQb2xpY3lDb21wb25lbnRdLFxyXG4gIGltcG9ydHM6IFtDb21tb25Nb2R1bGUsIERvY3VtZW50RWRpdG9yQ29udGFpbmVyTW9kdWxlXSxcclxuICBleHBvcnRzOiBbVmlld1BvbGljeUNvbXBvbmVudF0sXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBWaWV3UG9saWN5TW9kdWxlIHt9XHJcbiJdfQ==
@@ -0,0 +1,203 @@
1
+ import { Component, Input, ViewChild, Output, EventEmitter } from '@angular/core';
2
+ import { nanoid } from 'nanoid';
3
+ import * as i0 from "@angular/core";
4
+ import * as i1 from "../multi-select.service";
5
+ import * as i2 from "@angular/common";
6
+ import * as i3 from "@angular/forms";
7
+ import * as i4 from "../../popover/popover.component";
8
+ import * as i5 from "../../popover/popover.directive";
9
+ export class CsMultiselectComponent {
10
+ set content(content) {
11
+ if (content) {
12
+ // initially setter gets called with undefined
13
+ this.optionList = content;
14
+ }
15
+ }
16
+ constructor(multiSelectService) {
17
+ this.multiSelectService = multiSelectService;
18
+ this.placeholder = '';
19
+ this.selectedItem = [];
20
+ this.valueChange = new EventEmitter();
21
+ this.applyFilter = new EventEmitter();
22
+ this.searchText = new EventEmitter();
23
+ this.resetSelectedData = new EventEmitter();
24
+ this.previousItems = [];
25
+ this.itemsDisplayedList = [];
26
+ this.filterApplied = true;
27
+ this.tempSelectedData = [];
28
+ this.value = [];
29
+ this.items = [];
30
+ this.name = nanoid();
31
+ this.searchPlaceholder = 'Search...';
32
+ // alert(this.tempSelectedData.length);
33
+ }
34
+ /**
35
+ *
36
+ * @param index - Represents the index of the value to be removed
37
+ */
38
+ removeValue(index) {
39
+ this.items.splice(index, 1);
40
+ this.value.splice(index, 1);
41
+ this.writeValue(this.value);
42
+ this.itemsDisplayedList = [...new Set(this.items)];
43
+ this.applyFilter.emit(this.filterApplied);
44
+ this.tempSelectedData = [...this.value];
45
+ this.previousItems = [...new Set(this.items)];
46
+ this.multiSelectService.overflowHidden = false;
47
+ }
48
+ resetState(type) {
49
+ this.value = [];
50
+ this.items = [];
51
+ if (type === 'allReset') {
52
+ this.previousItems = [];
53
+ this.tempSelectedData = [];
54
+ }
55
+ if (this.previousItems?.length === 0) {
56
+ this.resetSelectedData.emit(true);
57
+ }
58
+ }
59
+ ngOnChanges(changes) {
60
+ if (changes.searchPlaceholder) {
61
+ this.searchPlaceholder = this.searchPlaceholder || 'Search...';
62
+ }
63
+ }
64
+ ngAfterViewInit() {
65
+ if (this.selectedItem && this.selectedItem?.length) {
66
+ this.selectedItem.forEach((ele) => {
67
+ // this.addValue({key: ele?.rc_name ?? ele?.category_name , value: ele});
68
+ this.addValue({ key: ele?.item_short_name, value: ele });
69
+ });
70
+ }
71
+ this.tempSelectedData = this.selectedItem ? [...this.selectedItem] : [];
72
+ this.previousItems = [...new Set(this.items)];
73
+ }
74
+ set CheckBoxVal(val) {
75
+ if (val !== undefined && val !== null) {
76
+ this.value = val;
77
+ this.valueChange.emit(this.value);
78
+ }
79
+ }
80
+ search(event) {
81
+ this.searchText.emit(event);
82
+ clearTimeout(this.timer);
83
+ this.timer = setTimeout(() => {
84
+ this.searchKey = event;
85
+ }, 400);
86
+ }
87
+ writeValue(value) {
88
+ if (value?.length) {
89
+ this.CheckBoxVal = value;
90
+ }
91
+ }
92
+ /**
93
+ *
94
+ * @param obj - Represents the object which is added to the value list
95
+ */
96
+ addValue(obj) {
97
+ this.items.push(obj.key);
98
+ this.value.push(obj.value);
99
+ this.writeValue(this.value);
100
+ }
101
+ /**
102
+ *
103
+ * @param value - Represents the value to be removed from the value list
104
+ */
105
+ removeValueFromCheckbox(value) {
106
+ let index = this.value.indexOf(value);
107
+ this.items.splice(index, 1);
108
+ this.value.splice(index, 1);
109
+ this.writeValue(this.value);
110
+ }
111
+ openDropdown(event) {
112
+ this.dropdownOption = true;
113
+ this.multiSelectService.overflowHidden = true;
114
+ setTimeout(() => {
115
+ const dropdown = event.target.getBoundingClientRect();
116
+ const selectOption = this.optionList.nativeElement.offsetHeight;
117
+ if (dropdown.top + selectOption + 50 > window.innerHeight) {
118
+ this.getTop = dropdown.top - selectOption;
119
+ }
120
+ else {
121
+ this.getTop = dropdown.top + dropdown.height;
122
+ }
123
+ this.getLeft = dropdown.left;
124
+ this.getWidth = dropdown.width;
125
+ this.maxWidth = dropdown.width * 1.25;
126
+ }, 10);
127
+ setTimeout(() => {
128
+ this.activeDropdown = true;
129
+ }, 100);
130
+ }
131
+ /**
132
+ *
133
+ * @param applyFilter - Determines whether filter is applied or not
134
+ */
135
+ closeDropdown(applyFilter) {
136
+ this.dropdownOption = false;
137
+ this.search('');
138
+ this.filterApplied = applyFilter;
139
+ this.multiSelectService.overflowHidden = false;
140
+ this.searchKey = '';
141
+ if (applyFilter) {
142
+ this.tempSelectedData = [...this.value];
143
+ this.previousItems = [...new Set(this.items)];
144
+ this.itemsDisplayedList = [...new Set(this.items)];
145
+ this.applyFilter.emit(applyFilter);
146
+ }
147
+ else {
148
+ this.filterApplied = true;
149
+ this.resetState();
150
+ this.tempSelectedData?.forEach((ele) => {
151
+ // this.addValue({key: ele?.rc_name ?? ele?.category_name, value: ele});
152
+ this.addValue({ key: ele?.item_short_name, value: ele });
153
+ });
154
+ this.previousItems = [...new Set(this.items)];
155
+ }
156
+ }
157
+ checkChanges() {
158
+ if (this.previousItems?.length === 0 && this.items?.length > 0) {
159
+ return false;
160
+ }
161
+ else if (this.previousItems?.length === 0 && this.items?.length === 0) {
162
+ return true;
163
+ }
164
+ else {
165
+ return (this.previousItems?.every((element) => this.items?.includes(element)) &&
166
+ this.previousItems?.length === this.items?.length);
167
+ }
168
+ }
169
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CsMultiselectComponent, deps: [{ token: i1.MultiSelectService }], target: i0.ɵɵFactoryTarget.Component }); }
170
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: CsMultiselectComponent, selector: "cs-multi-select", inputs: { isRequired: "isRequired", dropdownLabel: "dropdownLabel", dropdownSubLabel: "dropdownSubLabel", disabled: "disabled", placeholder: "placeholder", searchPlaceholder: "searchPlaceholder", value: "value", selectedItem: "selectedItem" }, outputs: { valueChange: "valueChange", applyFilter: "applyFilter", searchText: "searchText", resetSelectedData: "resetSelectedData" }, viewQueries: [{ propertyName: "content", first: true, predicate: ["optionList"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div class=\"multi-select-input-group\" (clickOutside)=\"dropdownOption = false\">\r\n <label *ngIf=\"dropdownLabel\">\r\n {{ dropdownLabel }}\r\n <span class=\"sub-label\" *ngIf=\"dropdownSubLabel\">{{\r\n dropdownSubLabel\r\n }}</span>\r\n <span class=\"required\" *ngIf=\"isRequired\">*</span></label\r\n >\r\n <div class=\"custom-select-box\" [class.disabled]=\"disabled\">\r\n <div class=\"multiple-value vx-d-flex vx-align-center vx-justify-between\">\r\n <div\r\n class=\"multiple-value-inner vx-d-flex vx-align-center vx-justify-end vx-pr-2\"\r\n (click)=\"openDropdown($event)\"\r\n ></div>\r\n <span class=\"placeholder\" *ngIf=\"!value || value?.length === 0\">{{\r\n placeholder\r\n }}</span>\r\n <!-- <i class=\"icons arrow-down vx-fs-9\">&#xe9e8;</i> -->\r\n <div class=\"vx-d-flex vx-align-center\" *ngIf=\"value && value?.length > 0\">\r\n <div\r\n class=\"chip\"\r\n *ngFor=\"let data of items | slice : 0 : 1; let i = index\"\r\n >\r\n <span class=\"close\" (click)=\"removeValue(i)\">&times;</span\r\n ><span class=\"value\">{{ data }}</span>\r\n </div>\r\n <span\r\n class=\"counter\"\r\n *ngIf=\"items.length > 1\"\r\n appPopover\r\n (click)=\"actionButton.popover()\"\r\n placement=\"right\"\r\n >+{{ items.length - 1 }}</span\r\n >\r\n <app-popover #actionButton>\r\n <div class=\"template-filter-list\">\r\n <ul class=\"action-item\">\r\n <li *ngFor=\"let data of items.slice(1); let j = index\">\r\n <div class=\"chip-item\">\r\n <i class=\"icons\" (click)=\"removeValue(j + 1)\">&#xe90d;</i>\r\n <span>{{ data }}</span>\r\n </div>\r\n </li>\r\n </ul>\r\n </div>\r\n </app-popover>\r\n </div>\r\n </div>\r\n </div>\r\n <div\r\n class=\"overlay active\"\r\n *ngIf=\"dropdownOption === true\"\r\n (click)=\"closeDropdown(false)\"\r\n ></div>\r\n <ul\r\n class=\"list-of-option\"\r\n *ngIf=\"dropdownOption === true\"\r\n #optionList\r\n (keyup.Escape)=\"closeDropdown(false)\"\r\n [style.top.px]=\"getTop\"\r\n [style.left.px]=\"getLeft\"\r\n [style.min-width.px]=\"getWidth\"\r\n [style.max-width.px]=\"maxWidth\"\r\n [class.active]=\"activeDropdown\"\r\n >\r\n <div class=\"input-group\">\r\n <input\r\n type=\"text\"\r\n [placeholder]=\"searchPlaceholder\"\r\n [ngModel]=\"searchKey\"\r\n (ngModelChange)=\"search($event)\"\r\n />\r\n </div>\r\n <ng-content></ng-content>\r\n <div class=\"button-block\">\r\n <button\r\n type=\"button\"\r\n [class.disabled]=\"checkChanges()\"\r\n (click)=\"closeDropdown(true)\"\r\n >\r\n Apply\r\n </button>\r\n </div>\r\n </ul>\r\n</div>\r\n", styles: ["@import\"https://cdn.v-comply.com/design-system/css/mixin/mixin.css\";@import\"https://cdn.v-comply.com/design-system/css/icons/icons.css\";@import\"https://cdn.v-comply.com/design-system/css/text/text.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/padding/padding-right.css\";::ng-deep .multi-select-input-group{position:relative;margin-bottom:0}::ng-deep .multi-select-input-group label{font-size:11px;color:#161b2f;font-weight:500;line-height:16px;margin-bottom:5px;text-transform:uppercase;display:block}::ng-deep .multi-select-input-group label span.required{color:#eb2424;font-size:14px}::ng-deep .multi-select-input-group label span.sub-label{color:#747576;font-size:11px;font-weight:400;margin-left:4px}::ng-deep .multi-select-input-group .multiple-value{height:36px;line-height:16px;font-size:13px;color:#747576;font-weight:400;background:#fff;border:1px solid #cdced6;border-radius:4px;width:100%;display:flex;padding:6px 25px 6px 6px;cursor:pointer;outline:none;overflow:hidden;text-overflow:ellipsis;position:relative}::ng-deep .multi-select-input-group .multiple-value-inner{position:absolute;top:0;left:0;width:100%;height:100%;cursor:pointer}::ng-deep .multi-select-input-group .multiple-value-inner:after{border-left-color:#707070;border-bottom:1px solid #707070;border-right:1px solid #707070;border-top-color:#707070;content:\"\";display:inline-block;right:8px;position:absolute;top:calc(50% - 4px);width:5px;height:5px;transform:rotate(45deg)}::ng-deep .multi-select-input-group .multiple-value .placeholder{color:#565a6f;font-size:11px;line-height:16px;pointer-events:none}::ng-deep .multi-select-input-group .multiple-value .arrow-down{position:relative;right:-16px;z-index:1}::ng-deep .multi-select-input-group .multiple-value.line{border:none;border-bottom:1px solid #dbdbdb;border-radius:0;padding-left:0}::ng-deep .multi-select-input-group .multiple-value .chip{display:inline-flex;border-radius:2px;background:#f8f8f8;border:1px solid #f8f8f8;height:22px;padding:0 5px;pointer-events:none;max-width:100%;position:relative;z-index:1;box-shadow:0 1px 4px #1e5dd340;max-width:150px}::ng-deep .multi-select-input-group .multiple-value .chip span{display:inline-block}::ng-deep .multi-select-input-group .multiple-value .chip span.close{cursor:pointer;color:#1e5dd3;font-size:16px;line-height:20px;pointer-events:auto}::ng-deep .multi-select-input-group .multiple-value .chip span.value{color:#747576;margin-left:5px;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:20px}::ng-deep .multi-select-input-group .multiple-value .chip+.chip{margin-left:4px}::ng-deep .multi-select-input-group .multiple-value .counter{display:inline-flex;border-radius:2px;background:#34aa44;border:1px solid #34aa44;height:22px;padding:0 5px;color:#fff;margin-left:5px;cursor:pointer;position:relative;z-index:1}::ng-deep .multi-select-input-group .multiple-value app-popover .action-list ul.action-item li .chip-item span{color:#747576}::ng-deep .multi-select-input-group .custom-select-box{position:relative}::ng-deep .multi-select-input-group .custom-select-box input[type=text],::ng-deep .multi-select-input-group .custom-select-box .input{cursor:pointer;padding-right:30px}::ng-deep .multi-select-input-group .custom-select-box input[type=text].line,::ng-deep .multi-select-input-group .custom-select-box .input.line{padding-right:20px}::ng-deep .multi-select-input-group .custom-select-box.disabled{filter:grayscale(1);pointer-events:none}ul.list-of-option{position:fixed;overflow:hidden;overflow-y:auto;max-height:260px;padding:0;margin:0;display:block;border:1px solid #dbdbdb;box-shadow:0 3px 6px #1e5dd333;z-index:9;background:#fff;border-radius:2px;opacity:0;width:230px;max-width:230px!important}ul.list-of-option.reset{top:inherit;bottom:100%;box-shadow:0 -3px 6px #1e5dd333}ul.list-of-option.active{opacity:1}ul.list-of-option app-cs-multi-select-option{display:block;width:100%}ul.list-of-option .input-group{padding:4px 10px;position:sticky;top:0;background:#fff;box-shadow:0 0 3px #1e5dd240;z-index:1;margin-bottom:4px}ul.list-of-option .input-group input{border:1px solid transparent;border-bottom-color:transparent;color:#747576;outline:none;width:100%;padding:0}ul.list-of-option li{width:100%;display:block;margin-bottom:0;padding:0;height:auto}ul.list-of-option li label{line-height:23px;font-size:13px;font-weight:400;border-radius:4px;display:flex;position:relative;margin:0;align-items:center}ul.list-of-option li label input[type=radio]{position:absolute;margin:0;height:100%;width:100%;opacity:0;cursor:pointer}ul.list-of-option li label input[type=radio]:checked+span,ul.list-of-option li label input[type=radio]:hover+span{background:#dcdcdc}ul.list-of-option li label span.value{color:#747576;font-size:14px;line-height:21px;font-weight:400;max-width:100%;white-space:nowrap;overflow:hidden;display:block;text-overflow:ellipsis;padding:5px 15px;width:100%;text-transform:none;cursor:pointer;text-align:left}ul.list-of-option li label.multi-select{padding:0 15px}ul.list-of-option li label.multi-select span.checkbox{display:inline-block;border:1px solid #dbdbdb;border-radius:2px;height:16px;width:16px;position:relative;padding:2px}ul.list-of-option li label input[type=checkbox]{position:absolute;margin:0;height:100%;width:100%;opacity:0;cursor:pointer}ul.list-of-option li label input[type=checkbox]:checked+span{background:#dcdcdc}ul.list-of-option li label input[type=checkbox]:checked+span.checkbox{border-color:#34aa44;background:#34aa44}ul.list-of-option li label input[type=checkbox]:checked+span.checkbox:after{width:8px;height:3px;border-bottom:2px solid #ffffff;border-left:2px solid #ffffff;transform:rotate(-45deg);content:\"\";position:absolute;top:3px;left:2px}ul.list-of-option .button-block{width:100%;display:flex;justify-content:flex-end;position:sticky;bottom:0;padding:4px 8px;background:#fff;box-shadow:0 0 3px #1e5dd240;z-index:1}ul.list-of-option .button-block button{display:flex;padding:0 12px;font-size:11px;text-transform:uppercase;font-weight:500;cursor:pointer;background:#1e5dd3;color:#fff;border:none;outline:none;border-radius:2px}.overlay{position:fixed;inset:0;z-index:2}.disabled{pointer-events:none;filter:grayscale(1);opacity:.3}.template-filter-list{width:220px}.template-filter-list ul{padding:0;margin:0;animation:scale-up-center .2s cubic-bezier(.39,.575,.565,1) both;background:#fff;box-shadow:0 3px 6px #1c5bd140;border-radius:4px;max-height:220px;overflow:auto}.template-filter-list ul.action-item{display:block}.template-filter-list ul.action-item li{list-style:none;border:none;border-bottom:1px solid #f1f1f1;display:block;width:100%;padding:0;background:transparent;border-radius:0;margin:0;height:auto;justify-content:flex-start;box-shadow:none}.template-filter-list ul.action-item li button{color:#6e717e;text-align:left;text-decoration:none;cursor:pointer;background:transparent;font-size:12px;text-transform:capitalize;display:flex;width:100%;padding:7.5px 11px;border:none}.template-filter-list ul.action-item li button i{font-size:17px;margin-right:10px;color:#1c5bd1}.template-filter-list ul.action-item li button:hover{background:#f3f3f3}.template-filter-list ul.action-item li .avatar-card{display:flex;align-items:center;width:100%;padding:7.5px}.template-filter-list ul.action-item li .avatar-card.within-con{display:block}.template-filter-list ul.action-item li .avatar-card .avatar{height:24px;width:24px!important;overflow:hidden;background:#1e5dd3;color:#fff;font-size:10px;display:inline-flex;margin-right:5px;border-radius:50%;align-items:center;justify-content:center;text-transform:uppercase}.template-filter-list ul.action-item li .avatar-card .avatar img{background:#fff;width:100%}.template-filter-list ul.action-item li .avatar-card .avatar+span.value{width:calc(100% - 29px)}.template-filter-list ul.action-item li .avatar-card span.value{width:100%;color:#6e717e;text-decoration:none;background:transparent;font-size:12px;text-transform:capitalize;display:block;font-weight:400;text-align-last:left;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:20px}.template-filter-list ul.action-item li .avatar-card span.value i{font-size:8px;color:#1c5bd1;cursor:pointer;margin-right:4px}.template-filter-list ul.action-item li .avatar-card span.value i.cross-icon{color:#747576}.template-filter-list ul.action-item li .avatar-card.no-image{display:block}.template-filter-list ul.action-item li .avatar-card.no-image span.value{width:100%;display:block}.template-filter-list ul.action-item li .chip-item{color:#1e5dd3;padding:10px;display:flex;align-items:center}.template-filter-list ul.action-item li .chip-item i{margin-right:7px;font-size:10px;cursor:pointer;display:inline-flex}.template-filter-list ul.action-item li .chip-item span{display:block;width:auto;max-width:calc(100% - 17px);font-size:12px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.template-filter-list ul.action-item li .chip-item span.chip-block{display:block;width:100%}.template-filter-list ul.action-item li .chip-item span.id{font-size:9px}.template-filter-list ul.action-item li .within{display:flex;align-items:center;justify-content:flex-start}.template-filter-list ul.action-item li .within .block{background:#f1f1f1;border-radius:2px;padding:0 2px;line-height:14px;font-size:9px;font-weight:500;color:#042e7d;margin-right:6px;display:block;text-transform:uppercase}.template-filter-list ul.action-item li .within .data{width:100%;display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#747576;font-size:11px;font-weight:400;line-height:17px}.template-filter-list ul.action-item li:first-child{animation:action-list-open .25s cubic-bezier(.25,.46,.45,.94) both}.template-filter-list ul.action-item li:nth-child(2){animation:action-list-open .35s cubic-bezier(.25,.46,.45,.94) both}.template-filter-list ul.action-item li:nth-child(3){animation:action-list-open .45s cubic-bezier(.25,.46,.45,.94) both}.template-filter-list ul.action-item li:nth-child(4){animation:action-list-open .55s cubic-bezier(.25,.46,.45,.94) both}.template-filter-list ul.action-item li:nth-child(5){animation:action-list-open .65s cubic-bezier(.25,.46,.45,.94) both}.template-filter-list ul.action-item li:nth-child(6){animation:action-list-open .75s cubic-bezier(.25,.46,.45,.94) both}.template-filter-list ul.action-item li:nth-child(7){animation:action-list-open .85s cubic-bezier(.25,.46,.45,.94) both}.template-filter-list ul.action-item li:nth-child(8){animation:action-list-open .95s cubic-bezier(.25,.46,.45,.94) both}.template-filter-list ul.action-item li:nth-child(9){animation:action-list-open 1.05s cubic-bezier(.25,.46,.45,.94) both}.template-filter-list ul.action-item li:nth-child(10){animation:action-list-open 1.15s cubic-bezier(.25,.46,.45,.94) both}@keyframes action-list-open{0%{transform:translateY(50px)}to{transform:translateY(0)}}@keyframes scale-up-center{0%{transform:scale(.5);opacity:0}to{transform:scale(1);opacity:1}}\n"], dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.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: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i4.PopoverComponent, selector: "app-popover", inputs: ["dontCloseonClick"] }, { kind: "directive", type: i5.PopoverDirective, selector: "[appPopover]", inputs: ["refrence", "placement"] }, { kind: "pipe", type: i2.SlicePipe, name: "slice" }] }); }
171
+ }
172
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CsMultiselectComponent, decorators: [{
173
+ type: Component,
174
+ args: [{ selector: 'cs-multi-select', template: "<div class=\"multi-select-input-group\" (clickOutside)=\"dropdownOption = false\">\r\n <label *ngIf=\"dropdownLabel\">\r\n {{ dropdownLabel }}\r\n <span class=\"sub-label\" *ngIf=\"dropdownSubLabel\">{{\r\n dropdownSubLabel\r\n }}</span>\r\n <span class=\"required\" *ngIf=\"isRequired\">*</span></label\r\n >\r\n <div class=\"custom-select-box\" [class.disabled]=\"disabled\">\r\n <div class=\"multiple-value vx-d-flex vx-align-center vx-justify-between\">\r\n <div\r\n class=\"multiple-value-inner vx-d-flex vx-align-center vx-justify-end vx-pr-2\"\r\n (click)=\"openDropdown($event)\"\r\n ></div>\r\n <span class=\"placeholder\" *ngIf=\"!value || value?.length === 0\">{{\r\n placeholder\r\n }}</span>\r\n <!-- <i class=\"icons arrow-down vx-fs-9\">&#xe9e8;</i> -->\r\n <div class=\"vx-d-flex vx-align-center\" *ngIf=\"value && value?.length > 0\">\r\n <div\r\n class=\"chip\"\r\n *ngFor=\"let data of items | slice : 0 : 1; let i = index\"\r\n >\r\n <span class=\"close\" (click)=\"removeValue(i)\">&times;</span\r\n ><span class=\"value\">{{ data }}</span>\r\n </div>\r\n <span\r\n class=\"counter\"\r\n *ngIf=\"items.length > 1\"\r\n appPopover\r\n (click)=\"actionButton.popover()\"\r\n placement=\"right\"\r\n >+{{ items.length - 1 }}</span\r\n >\r\n <app-popover #actionButton>\r\n <div class=\"template-filter-list\">\r\n <ul class=\"action-item\">\r\n <li *ngFor=\"let data of items.slice(1); let j = index\">\r\n <div class=\"chip-item\">\r\n <i class=\"icons\" (click)=\"removeValue(j + 1)\">&#xe90d;</i>\r\n <span>{{ data }}</span>\r\n </div>\r\n </li>\r\n </ul>\r\n </div>\r\n </app-popover>\r\n </div>\r\n </div>\r\n </div>\r\n <div\r\n class=\"overlay active\"\r\n *ngIf=\"dropdownOption === true\"\r\n (click)=\"closeDropdown(false)\"\r\n ></div>\r\n <ul\r\n class=\"list-of-option\"\r\n *ngIf=\"dropdownOption === true\"\r\n #optionList\r\n (keyup.Escape)=\"closeDropdown(false)\"\r\n [style.top.px]=\"getTop\"\r\n [style.left.px]=\"getLeft\"\r\n [style.min-width.px]=\"getWidth\"\r\n [style.max-width.px]=\"maxWidth\"\r\n [class.active]=\"activeDropdown\"\r\n >\r\n <div class=\"input-group\">\r\n <input\r\n type=\"text\"\r\n [placeholder]=\"searchPlaceholder\"\r\n [ngModel]=\"searchKey\"\r\n (ngModelChange)=\"search($event)\"\r\n />\r\n </div>\r\n <ng-content></ng-content>\r\n <div class=\"button-block\">\r\n <button\r\n type=\"button\"\r\n [class.disabled]=\"checkChanges()\"\r\n (click)=\"closeDropdown(true)\"\r\n >\r\n Apply\r\n </button>\r\n </div>\r\n </ul>\r\n</div>\r\n", styles: ["@import\"https://cdn.v-comply.com/design-system/css/mixin/mixin.css\";@import\"https://cdn.v-comply.com/design-system/css/icons/icons.css\";@import\"https://cdn.v-comply.com/design-system/css/text/text.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/padding/padding-right.css\";::ng-deep .multi-select-input-group{position:relative;margin-bottom:0}::ng-deep .multi-select-input-group label{font-size:11px;color:#161b2f;font-weight:500;line-height:16px;margin-bottom:5px;text-transform:uppercase;display:block}::ng-deep .multi-select-input-group label span.required{color:#eb2424;font-size:14px}::ng-deep .multi-select-input-group label span.sub-label{color:#747576;font-size:11px;font-weight:400;margin-left:4px}::ng-deep .multi-select-input-group .multiple-value{height:36px;line-height:16px;font-size:13px;color:#747576;font-weight:400;background:#fff;border:1px solid #cdced6;border-radius:4px;width:100%;display:flex;padding:6px 25px 6px 6px;cursor:pointer;outline:none;overflow:hidden;text-overflow:ellipsis;position:relative}::ng-deep .multi-select-input-group .multiple-value-inner{position:absolute;top:0;left:0;width:100%;height:100%;cursor:pointer}::ng-deep .multi-select-input-group .multiple-value-inner:after{border-left-color:#707070;border-bottom:1px solid #707070;border-right:1px solid #707070;border-top-color:#707070;content:\"\";display:inline-block;right:8px;position:absolute;top:calc(50% - 4px);width:5px;height:5px;transform:rotate(45deg)}::ng-deep .multi-select-input-group .multiple-value .placeholder{color:#565a6f;font-size:11px;line-height:16px;pointer-events:none}::ng-deep .multi-select-input-group .multiple-value .arrow-down{position:relative;right:-16px;z-index:1}::ng-deep .multi-select-input-group .multiple-value.line{border:none;border-bottom:1px solid #dbdbdb;border-radius:0;padding-left:0}::ng-deep .multi-select-input-group .multiple-value .chip{display:inline-flex;border-radius:2px;background:#f8f8f8;border:1px solid #f8f8f8;height:22px;padding:0 5px;pointer-events:none;max-width:100%;position:relative;z-index:1;box-shadow:0 1px 4px #1e5dd340;max-width:150px}::ng-deep .multi-select-input-group .multiple-value .chip span{display:inline-block}::ng-deep .multi-select-input-group .multiple-value .chip span.close{cursor:pointer;color:#1e5dd3;font-size:16px;line-height:20px;pointer-events:auto}::ng-deep .multi-select-input-group .multiple-value .chip span.value{color:#747576;margin-left:5px;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:20px}::ng-deep .multi-select-input-group .multiple-value .chip+.chip{margin-left:4px}::ng-deep .multi-select-input-group .multiple-value .counter{display:inline-flex;border-radius:2px;background:#34aa44;border:1px solid #34aa44;height:22px;padding:0 5px;color:#fff;margin-left:5px;cursor:pointer;position:relative;z-index:1}::ng-deep .multi-select-input-group .multiple-value app-popover .action-list ul.action-item li .chip-item span{color:#747576}::ng-deep .multi-select-input-group .custom-select-box{position:relative}::ng-deep .multi-select-input-group .custom-select-box input[type=text],::ng-deep .multi-select-input-group .custom-select-box .input{cursor:pointer;padding-right:30px}::ng-deep .multi-select-input-group .custom-select-box input[type=text].line,::ng-deep .multi-select-input-group .custom-select-box .input.line{padding-right:20px}::ng-deep .multi-select-input-group .custom-select-box.disabled{filter:grayscale(1);pointer-events:none}ul.list-of-option{position:fixed;overflow:hidden;overflow-y:auto;max-height:260px;padding:0;margin:0;display:block;border:1px solid #dbdbdb;box-shadow:0 3px 6px #1e5dd333;z-index:9;background:#fff;border-radius:2px;opacity:0;width:230px;max-width:230px!important}ul.list-of-option.reset{top:inherit;bottom:100%;box-shadow:0 -3px 6px #1e5dd333}ul.list-of-option.active{opacity:1}ul.list-of-option app-cs-multi-select-option{display:block;width:100%}ul.list-of-option .input-group{padding:4px 10px;position:sticky;top:0;background:#fff;box-shadow:0 0 3px #1e5dd240;z-index:1;margin-bottom:4px}ul.list-of-option .input-group input{border:1px solid transparent;border-bottom-color:transparent;color:#747576;outline:none;width:100%;padding:0}ul.list-of-option li{width:100%;display:block;margin-bottom:0;padding:0;height:auto}ul.list-of-option li label{line-height:23px;font-size:13px;font-weight:400;border-radius:4px;display:flex;position:relative;margin:0;align-items:center}ul.list-of-option li label input[type=radio]{position:absolute;margin:0;height:100%;width:100%;opacity:0;cursor:pointer}ul.list-of-option li label input[type=radio]:checked+span,ul.list-of-option li label input[type=radio]:hover+span{background:#dcdcdc}ul.list-of-option li label span.value{color:#747576;font-size:14px;line-height:21px;font-weight:400;max-width:100%;white-space:nowrap;overflow:hidden;display:block;text-overflow:ellipsis;padding:5px 15px;width:100%;text-transform:none;cursor:pointer;text-align:left}ul.list-of-option li label.multi-select{padding:0 15px}ul.list-of-option li label.multi-select span.checkbox{display:inline-block;border:1px solid #dbdbdb;border-radius:2px;height:16px;width:16px;position:relative;padding:2px}ul.list-of-option li label input[type=checkbox]{position:absolute;margin:0;height:100%;width:100%;opacity:0;cursor:pointer}ul.list-of-option li label input[type=checkbox]:checked+span{background:#dcdcdc}ul.list-of-option li label input[type=checkbox]:checked+span.checkbox{border-color:#34aa44;background:#34aa44}ul.list-of-option li label input[type=checkbox]:checked+span.checkbox:after{width:8px;height:3px;border-bottom:2px solid #ffffff;border-left:2px solid #ffffff;transform:rotate(-45deg);content:\"\";position:absolute;top:3px;left:2px}ul.list-of-option .button-block{width:100%;display:flex;justify-content:flex-end;position:sticky;bottom:0;padding:4px 8px;background:#fff;box-shadow:0 0 3px #1e5dd240;z-index:1}ul.list-of-option .button-block button{display:flex;padding:0 12px;font-size:11px;text-transform:uppercase;font-weight:500;cursor:pointer;background:#1e5dd3;color:#fff;border:none;outline:none;border-radius:2px}.overlay{position:fixed;inset:0;z-index:2}.disabled{pointer-events:none;filter:grayscale(1);opacity:.3}.template-filter-list{width:220px}.template-filter-list ul{padding:0;margin:0;animation:scale-up-center .2s cubic-bezier(.39,.575,.565,1) both;background:#fff;box-shadow:0 3px 6px #1c5bd140;border-radius:4px;max-height:220px;overflow:auto}.template-filter-list ul.action-item{display:block}.template-filter-list ul.action-item li{list-style:none;border:none;border-bottom:1px solid #f1f1f1;display:block;width:100%;padding:0;background:transparent;border-radius:0;margin:0;height:auto;justify-content:flex-start;box-shadow:none}.template-filter-list ul.action-item li button{color:#6e717e;text-align:left;text-decoration:none;cursor:pointer;background:transparent;font-size:12px;text-transform:capitalize;display:flex;width:100%;padding:7.5px 11px;border:none}.template-filter-list ul.action-item li button i{font-size:17px;margin-right:10px;color:#1c5bd1}.template-filter-list ul.action-item li button:hover{background:#f3f3f3}.template-filter-list ul.action-item li .avatar-card{display:flex;align-items:center;width:100%;padding:7.5px}.template-filter-list ul.action-item li .avatar-card.within-con{display:block}.template-filter-list ul.action-item li .avatar-card .avatar{height:24px;width:24px!important;overflow:hidden;background:#1e5dd3;color:#fff;font-size:10px;display:inline-flex;margin-right:5px;border-radius:50%;align-items:center;justify-content:center;text-transform:uppercase}.template-filter-list ul.action-item li .avatar-card .avatar img{background:#fff;width:100%}.template-filter-list ul.action-item li .avatar-card .avatar+span.value{width:calc(100% - 29px)}.template-filter-list ul.action-item li .avatar-card span.value{width:100%;color:#6e717e;text-decoration:none;background:transparent;font-size:12px;text-transform:capitalize;display:block;font-weight:400;text-align-last:left;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:20px}.template-filter-list ul.action-item li .avatar-card span.value i{font-size:8px;color:#1c5bd1;cursor:pointer;margin-right:4px}.template-filter-list ul.action-item li .avatar-card span.value i.cross-icon{color:#747576}.template-filter-list ul.action-item li .avatar-card.no-image{display:block}.template-filter-list ul.action-item li .avatar-card.no-image span.value{width:100%;display:block}.template-filter-list ul.action-item li .chip-item{color:#1e5dd3;padding:10px;display:flex;align-items:center}.template-filter-list ul.action-item li .chip-item i{margin-right:7px;font-size:10px;cursor:pointer;display:inline-flex}.template-filter-list ul.action-item li .chip-item span{display:block;width:auto;max-width:calc(100% - 17px);font-size:12px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.template-filter-list ul.action-item li .chip-item span.chip-block{display:block;width:100%}.template-filter-list ul.action-item li .chip-item span.id{font-size:9px}.template-filter-list ul.action-item li .within{display:flex;align-items:center;justify-content:flex-start}.template-filter-list ul.action-item li .within .block{background:#f1f1f1;border-radius:2px;padding:0 2px;line-height:14px;font-size:9px;font-weight:500;color:#042e7d;margin-right:6px;display:block;text-transform:uppercase}.template-filter-list ul.action-item li .within .data{width:100%;display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#747576;font-size:11px;font-weight:400;line-height:17px}.template-filter-list ul.action-item li:first-child{animation:action-list-open .25s cubic-bezier(.25,.46,.45,.94) both}.template-filter-list ul.action-item li:nth-child(2){animation:action-list-open .35s cubic-bezier(.25,.46,.45,.94) both}.template-filter-list ul.action-item li:nth-child(3){animation:action-list-open .45s cubic-bezier(.25,.46,.45,.94) both}.template-filter-list ul.action-item li:nth-child(4){animation:action-list-open .55s cubic-bezier(.25,.46,.45,.94) both}.template-filter-list ul.action-item li:nth-child(5){animation:action-list-open .65s cubic-bezier(.25,.46,.45,.94) both}.template-filter-list ul.action-item li:nth-child(6){animation:action-list-open .75s cubic-bezier(.25,.46,.45,.94) both}.template-filter-list ul.action-item li:nth-child(7){animation:action-list-open .85s cubic-bezier(.25,.46,.45,.94) both}.template-filter-list ul.action-item li:nth-child(8){animation:action-list-open .95s cubic-bezier(.25,.46,.45,.94) both}.template-filter-list ul.action-item li:nth-child(9){animation:action-list-open 1.05s cubic-bezier(.25,.46,.45,.94) both}.template-filter-list ul.action-item li:nth-child(10){animation:action-list-open 1.15s cubic-bezier(.25,.46,.45,.94) both}@keyframes action-list-open{0%{transform:translateY(50px)}to{transform:translateY(0)}}@keyframes scale-up-center{0%{transform:scale(.5);opacity:0}to{transform:scale(1);opacity:1}}\n"] }]
175
+ }], ctorParameters: function () { return [{ type: i1.MultiSelectService }]; }, propDecorators: { isRequired: [{
176
+ type: Input
177
+ }], dropdownLabel: [{
178
+ type: Input
179
+ }], dropdownSubLabel: [{
180
+ type: Input
181
+ }], disabled: [{
182
+ type: Input
183
+ }], placeholder: [{
184
+ type: Input
185
+ }], searchPlaceholder: [{
186
+ type: Input
187
+ }], value: [{
188
+ type: Input
189
+ }], selectedItem: [{
190
+ type: Input
191
+ }], valueChange: [{
192
+ type: Output
193
+ }], applyFilter: [{
194
+ type: Output
195
+ }], searchText: [{
196
+ type: Output
197
+ }], resetSelectedData: [{
198
+ type: Output
199
+ }], content: [{
200
+ type: ViewChild,
201
+ args: ['optionList']
202
+ }] } });
203
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cs-multiselect.component.js","sourceRoot":"","sources":["../../../../../../../projects/vx-workflow-engine/src/lib/ui-kit/multi-select/cs-multiselect/cs-multiselect.component.ts","../../../../../../../projects/vx-workflow-engine/src/lib/ui-kit/multi-select/cs-multiselect/cs-multiselect.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, Input, ViewChild, Output, EventEmitter, OnChanges, SimpleChanges, AfterViewInit } from '@angular/core';\r\nimport { nanoid } from 'nanoid';\r\nimport { MultiSelectService } from '../multi-select.service';\r\n\r\n@Component({\r\n  selector: 'cs-multi-select',\r\n  templateUrl: './cs-multiselect.component.html',\r\n  styleUrls: ['./cs-multiselect.component.less'],\r\n})\r\nexport class CsMultiselectComponent implements OnChanges, AfterViewInit {\r\n  @Input() isRequired!: boolean;\r\n  @Input() dropdownLabel!: string;\r\n  @Input() dropdownSubLabel!: string;\r\n  @Input() disabled!: boolean;\r\n  @Input() placeholder: string = '';\r\n  @Input() searchPlaceholder: string;\r\n  @Input() value!: any;\r\n  @Input() selectedItem: any = [];\r\n  @Output() valueChange: EventEmitter<any[]> = new EventEmitter();\r\n  @Output() applyFilter: EventEmitter<any> = new EventEmitter();\r\n  @Output() searchText: EventEmitter<string> = new EventEmitter();\r\n  @Output() resetSelectedData: EventEmitter<any> = new EventEmitter()\r\n  dropdownOption!: boolean;\r\n  positionReset!: boolean;\r\n  getLeft!: number;\r\n  getTop!: number;\r\n  getWidth!: number;\r\n  maxWidth!: number;\r\n  activeDropdown!: boolean;\r\n  items!: any[];\r\n  previousItems: any[]=[];\r\n\r\n  itemsDisplayedList: any[]=[];\r\n  name: string;\r\n  filterApplied: boolean = true;\r\n  searchKey!: any;\r\n  timer: any;\r\n  tempSelectedData: any = [];\r\n\r\n  private optionList!: ElementRef;\r\n  @ViewChild('optionList') set content(content: ElementRef) {\r\n    if (content) {\r\n      // initially setter gets called with undefined\r\n      this.optionList = content;\r\n    }\r\n  }\r\n\r\n  constructor(public multiSelectService: MultiSelectService) {\r\n    this.value = [];\r\n    this.items = [];\r\n    this.name = nanoid();\r\n    this.searchPlaceholder = 'Search...';\r\n    // alert(this.tempSelectedData.length);\r\n  }\r\n\r\n  /**\r\n   *\r\n   * @param index - Represents the index of the value to be removed\r\n   */\r\n  removeValue(index: number): void {\r\n    this.items.splice(index, 1);\r\n    this.value.splice(index, 1);\r\n    this.writeValue(this.value);\r\n    this.itemsDisplayedList = [...new Set(this.items)]\r\n    this.applyFilter.emit(this.filterApplied);\r\n    this.tempSelectedData = [... this.value];\r\n    this.previousItems =  [...new Set(this.items)]\r\n    this.multiSelectService.overflowHidden = false;\r\n  }\r\n\r\n\r\n\r\n  resetState(type?: any){\r\n    this.value = [];\r\n    this.items = [];\r\n    if(type === 'allReset'){\r\n      this.previousItems = []\r\n      this.tempSelectedData = []\r\n    }\r\n    if(this.previousItems?.length === 0){\r\n      this.resetSelectedData.emit(true);\r\n    }\r\n  }\r\n\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if (changes.searchPlaceholder) {\r\n      this.searchPlaceholder = this.searchPlaceholder || 'Search...';\r\n    }\r\n  }\r\n  ngAfterViewInit()\t{\r\n    if(this.selectedItem && this.selectedItem?.length ){\r\n      this.selectedItem.forEach( (ele: any) => {\r\n        // this.addValue({key: ele?.rc_name ?? ele?.category_name , value: ele});\r\n        this.addValue({key: ele?.item_short_name , value: ele});\r\n      })\r\n    }\r\n    this.tempSelectedData = this.selectedItem ? [...this.selectedItem] : [];\r\n    this.previousItems =  [...new Set(this.items)];\r\n\r\n  }\r\n\r\n  set CheckBoxVal(val: any[]) {\r\n    if (val !== undefined && val !== null) {\r\n      this.value = val;\r\n      this.valueChange.emit(this.value);\r\n    }\r\n  }\r\n\r\n  search(event: any) {\r\n    this.searchText.emit(event);\r\n    clearTimeout(this.timer);\r\n    this.timer = setTimeout(() => {\r\n      this.searchKey = event;\r\n    }, 400);\r\n  }\r\n\r\n  writeValue(value: any[]): void {\r\n    if(value?.length){\r\n    this.CheckBoxVal = value;\r\n    }\r\n  }\r\n\r\n  /**\r\n   *\r\n   * @param obj - Represents the object which is added to the value list\r\n   */\r\n  addValue(obj: { key: string; value: any }): void {\r\n    this.items.push(obj.key);\r\n    this.value.push(obj.value);\r\n    this.writeValue(this.value);\r\n  }\r\n\r\n  /**\r\n   *\r\n   * @param value - Represents the value to be removed from the value list\r\n   */\r\n  removeValueFromCheckbox(value: any): void {\r\n    let index: number = this.value.indexOf(value);\r\n    this.items.splice(index, 1);\r\n    this.value.splice(index, 1);\r\n    this.writeValue(this.value);\r\n  }\r\n\r\n  openDropdown(event: any): void {\r\n    this.dropdownOption = true;\r\n    this.multiSelectService.overflowHidden = true;\r\n    setTimeout(() => {\r\n      const dropdown = event.target.getBoundingClientRect();\r\n      const selectOption = this.optionList.nativeElement.offsetHeight;\r\n      if (dropdown.top + selectOption + 50 > window.innerHeight) {\r\n        this.getTop = dropdown.top - selectOption;\r\n      } else {\r\n        this.getTop = dropdown.top + dropdown.height;\r\n      }\r\n      this.getLeft = dropdown.left;\r\n      this.getWidth = dropdown.width;\r\n      this.maxWidth = dropdown.width * 1.25;\r\n    }, 10);\r\n    setTimeout(() => {\r\n      this.activeDropdown = true;\r\n    }, 100);\r\n  }\r\n\r\n  /**\r\n   *\r\n   * @param applyFilter - Determines whether filter is applied or not\r\n   */\r\n  closeDropdown(applyFilter: boolean): void {\r\n    this.dropdownOption = false;\r\n    this.search('');\r\n    this.filterApplied = applyFilter;\r\n    this.multiSelectService.overflowHidden = false;\r\n    this.searchKey = '';\r\n    if (applyFilter) {\r\n      this.tempSelectedData =  [... this.value];\r\n      this.previousItems =  [...new Set(this.items)];\r\n      this.itemsDisplayedList = [...new Set(this.items)]\r\n      this.applyFilter.emit(applyFilter);\r\n    } else {\r\n      this.filterApplied = true;\r\n      this.resetState();\r\n      this.tempSelectedData?.forEach( (ele: any) => {\r\n        // this.addValue({key: ele?.rc_name ?? ele?.category_name, value: ele});\r\n        this.addValue({key: ele?.item_short_name , value: ele});\r\n      })\r\n      this.previousItems =  [...new Set(this.items)];\r\n    }\r\n  }\r\n\r\n  checkChanges(){\r\n    if (this.previousItems?.length === 0 && this.items?.length > 0) {\r\n      return false;\r\n    } else if (this.previousItems?.length === 0 && this.items?.length === 0) {\r\n      return true;\r\n    } else {\r\n      return (\r\n        this.previousItems?.every((element) => this.items?.includes(element)) &&\r\n        this.previousItems?.length === this.items?.length\r\n      );\r\n    }\r\n\r\n  }\r\n}\r\n","<div class=\"multi-select-input-group\" (clickOutside)=\"dropdownOption = false\">\r\n  <label *ngIf=\"dropdownLabel\">\r\n    {{ dropdownLabel }}\r\n    <span class=\"sub-label\" *ngIf=\"dropdownSubLabel\">{{\r\n      dropdownSubLabel\r\n    }}</span>\r\n    <span class=\"required\" *ngIf=\"isRequired\">*</span></label\r\n  >\r\n  <div class=\"custom-select-box\" [class.disabled]=\"disabled\">\r\n    <div class=\"multiple-value vx-d-flex vx-align-center vx-justify-between\">\r\n      <div\r\n        class=\"multiple-value-inner vx-d-flex vx-align-center vx-justify-end vx-pr-2\"\r\n        (click)=\"openDropdown($event)\"\r\n      ></div>\r\n      <span class=\"placeholder\" *ngIf=\"!value || value?.length === 0\">{{\r\n        placeholder\r\n      }}</span>\r\n      <!-- <i class=\"icons arrow-down vx-fs-9\">&#xe9e8;</i> -->\r\n      <div class=\"vx-d-flex vx-align-center\" *ngIf=\"value && value?.length > 0\">\r\n        <div\r\n          class=\"chip\"\r\n          *ngFor=\"let data of items | slice : 0 : 1; let i = index\"\r\n        >\r\n          <span class=\"close\" (click)=\"removeValue(i)\">&times;</span\r\n          ><span class=\"value\">{{ data }}</span>\r\n        </div>\r\n        <span\r\n          class=\"counter\"\r\n          *ngIf=\"items.length > 1\"\r\n          appPopover\r\n          (click)=\"actionButton.popover()\"\r\n          placement=\"right\"\r\n          >+{{ items.length - 1 }}</span\r\n        >\r\n        <app-popover #actionButton>\r\n          <div class=\"template-filter-list\">\r\n            <ul class=\"action-item\">\r\n              <li *ngFor=\"let data of items.slice(1); let j = index\">\r\n                <div class=\"chip-item\">\r\n                  <i class=\"icons\" (click)=\"removeValue(j + 1)\">&#xe90d;</i>\r\n                  <span>{{ data }}</span>\r\n                </div>\r\n              </li>\r\n            </ul>\r\n          </div>\r\n        </app-popover>\r\n      </div>\r\n    </div>\r\n  </div>\r\n  <div\r\n    class=\"overlay active\"\r\n    *ngIf=\"dropdownOption === true\"\r\n    (click)=\"closeDropdown(false)\"\r\n  ></div>\r\n  <ul\r\n    class=\"list-of-option\"\r\n    *ngIf=\"dropdownOption === true\"\r\n    #optionList\r\n    (keyup.Escape)=\"closeDropdown(false)\"\r\n    [style.top.px]=\"getTop\"\r\n    [style.left.px]=\"getLeft\"\r\n    [style.min-width.px]=\"getWidth\"\r\n    [style.max-width.px]=\"maxWidth\"\r\n    [class.active]=\"activeDropdown\"\r\n  >\r\n    <div class=\"input-group\">\r\n      <input\r\n        type=\"text\"\r\n        [placeholder]=\"searchPlaceholder\"\r\n        [ngModel]=\"searchKey\"\r\n        (ngModelChange)=\"search($event)\"\r\n      />\r\n    </div>\r\n    <ng-content></ng-content>\r\n    <div class=\"button-block\">\r\n      <button\r\n        type=\"button\"\r\n        [class.disabled]=\"checkChanges()\"\r\n        (click)=\"closeDropdown(true)\"\r\n      >\r\n        Apply\r\n      </button>\r\n    </div>\r\n  </ul>\r\n</div>\r\n"]}
@@ -0,0 +1,31 @@
1
+ import { Component, Input, ElementRef, ViewChild } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ import * as i1 from "../cs-multiselect/cs-multiselect.component";
4
+ export class CsMultiselectOptionComponent {
5
+ constructor(select) {
6
+ this.select = select;
7
+ }
8
+ change(event) {
9
+ if (event.target.checked) {
10
+ this.select.addValue({
11
+ key: this.option.nativeElement.innerHTML.replace(/&lt;/g, "<"),
12
+ value: this.value,
13
+ });
14
+ }
15
+ else {
16
+ this.select.removeValueFromCheckbox(this.value);
17
+ }
18
+ }
19
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CsMultiselectOptionComponent, deps: [{ token: i1.CsMultiselectComponent }], target: i0.ɵɵFactoryTarget.Component }); }
20
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: CsMultiselectOptionComponent, selector: "cs-multi-select-option", inputs: { value: "value" }, viewQueries: [{ propertyName: "option", first: true, predicate: ["options"], descendants: true, read: ElementRef }], ngImport: i0, template: "<li>\r\n <label class=\"multi-select\">\r\n <input type=\"checkbox\" tabindex=\"0\" [value]=\"value\" [checked]=\"select.value.includes(value)\" (change)=\"change($event)\" />\r\n <span class=\"checkbox\"></span>\r\n <span class=\"value\" #options>\r\n <ng-content> </ng-content>\r\n </span>\r\n </label>\r\n</li>\r\n", styles: ["li{width:100%;display:block;margin-bottom:0;padding:0;height:auto}li label{line-height:23px;font-size:13px;font-weight:400;border-radius:4px;display:flex;position:relative;margin:0;align-items:center}li label input[type=checkbox]{position:absolute;margin:0;height:100%;width:100%;opacity:0;cursor:pointer;pointer-events:none}li label input[type=checkbox]:checked+span,li label input[type=checkbox]:hover+span{background:#dcdcdc}li label span.value{color:#161b2f;font-size:12px;line-height:20px;font-weight:400;max-width:100%;white-space:nowrap;overflow:hidden;display:block;text-overflow:ellipsis;padding:4px 8px;width:100%;text-transform:none;cursor:pointer;text-align:left}li label.multi-select{padding:0 8px}li label.multi-select span.checkbox{background:#fff!important;display:inline-block;border:1px solid #dbdbdb;border-radius:2px;height:16px;width:16px;position:relative;padding:2px}li label input[type=checkbox]{position:absolute;margin:0;height:100%;width:100%;opacity:0;cursor:pointer}li label input[type=checkbox]:checked+span{background:#dcdcdc}li label input[type=checkbox]:checked+span.checkbox{border-color:#34aa44;background:#34aa44!important}li label input[type=checkbox]:checked+span.checkbox:after{width:8px;height:3px;border-bottom:2px solid #ffffff;border-left:2px solid #ffffff;transform:rotate(-45deg);content:\"\";position:absolute;top:3px;left:2px}li:hover label{background:#f1f1f1}\n"] }); }
21
+ }
22
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CsMultiselectOptionComponent, decorators: [{
23
+ type: Component,
24
+ args: [{ selector: 'cs-multi-select-option', template: "<li>\r\n <label class=\"multi-select\">\r\n <input type=\"checkbox\" tabindex=\"0\" [value]=\"value\" [checked]=\"select.value.includes(value)\" (change)=\"change($event)\" />\r\n <span class=\"checkbox\"></span>\r\n <span class=\"value\" #options>\r\n <ng-content> </ng-content>\r\n </span>\r\n </label>\r\n</li>\r\n", styles: ["li{width:100%;display:block;margin-bottom:0;padding:0;height:auto}li label{line-height:23px;font-size:13px;font-weight:400;border-radius:4px;display:flex;position:relative;margin:0;align-items:center}li label input[type=checkbox]{position:absolute;margin:0;height:100%;width:100%;opacity:0;cursor:pointer;pointer-events:none}li label input[type=checkbox]:checked+span,li label input[type=checkbox]:hover+span{background:#dcdcdc}li label span.value{color:#161b2f;font-size:12px;line-height:20px;font-weight:400;max-width:100%;white-space:nowrap;overflow:hidden;display:block;text-overflow:ellipsis;padding:4px 8px;width:100%;text-transform:none;cursor:pointer;text-align:left}li label.multi-select{padding:0 8px}li label.multi-select span.checkbox{background:#fff!important;display:inline-block;border:1px solid #dbdbdb;border-radius:2px;height:16px;width:16px;position:relative;padding:2px}li label input[type=checkbox]{position:absolute;margin:0;height:100%;width:100%;opacity:0;cursor:pointer}li label input[type=checkbox]:checked+span{background:#dcdcdc}li label input[type=checkbox]:checked+span.checkbox{border-color:#34aa44;background:#34aa44!important}li label input[type=checkbox]:checked+span.checkbox:after{width:8px;height:3px;border-bottom:2px solid #ffffff;border-left:2px solid #ffffff;transform:rotate(-45deg);content:\"\";position:absolute;top:3px;left:2px}li:hover label{background:#f1f1f1}\n"] }]
25
+ }], ctorParameters: function () { return [{ type: i1.CsMultiselectComponent }]; }, propDecorators: { value: [{
26
+ type: Input
27
+ }], option: [{
28
+ type: ViewChild,
29
+ args: ['options', { read: ElementRef, static: false }]
30
+ }] } });
31
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3MtbXVsdGlzZWxlY3Qtb3B0aW9uLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3Z4LXdvcmtmbG93LWVuZ2luZS9zcmMvbGliL3VpLWtpdC9tdWx0aS1zZWxlY3QvY3MtbXVsdGlzZWxlY3Qtb3B0aW9uL2NzLW11bHRpc2VsZWN0LW9wdGlvbi5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy92eC13b3JrZmxvdy1lbmdpbmUvc3JjL2xpYi91aS1raXQvbXVsdGktc2VsZWN0L2NzLW11bHRpc2VsZWN0LW9wdGlvbi9jcy1tdWx0aXNlbGVjdC1vcHRpb24uY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsVUFBVSxFQUFFLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7O0FBT3hFLE1BQU0sT0FBTyw0QkFBNEI7SUFJdkMsWUFBbUIsTUFBOEI7UUFBOUIsV0FBTSxHQUFOLE1BQU0sQ0FBd0I7SUFBRyxDQUFDO0lBRXJELE1BQU0sQ0FBQyxLQUFVO1FBQ2YsSUFBSSxLQUFLLENBQUMsTUFBTSxDQUFDLE9BQU8sRUFBRTtZQUN4QixJQUFJLENBQUMsTUFBTSxDQUFDLFFBQVEsQ0FBQztnQkFDbkIsR0FBRyxFQUFFLElBQUksQ0FBQyxNQUFNLENBQUMsYUFBYSxDQUFDLFNBQVMsQ0FBQyxPQUFPLENBQUMsT0FBTyxFQUFDLEdBQUcsQ0FBQztnQkFDN0QsS0FBSyxFQUFFLElBQUksQ0FBQyxLQUFLO2FBQ2xCLENBQUMsQ0FBQztTQUNKO2FBQU07WUFDTCxJQUFJLENBQUMsTUFBTSxDQUFDLHVCQUF1QixDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztTQUNqRDtJQUNILENBQUM7K0dBZlUsNEJBQTRCO21HQUE1Qiw0QkFBNEIsd0tBRVQsVUFBVSw2QkNUMUMsa1ZBU0E7OzRGREZhLDRCQUE0QjtrQkFMeEMsU0FBUzsrQkFDRSx3QkFBd0I7NkdBS3pCLEtBQUs7c0JBQWIsS0FBSztnQkFFTixNQUFNO3NCQURMLFNBQVM7dUJBQUMsU0FBUyxFQUFFLEVBQUUsSUFBSSxFQUFFLFVBQVUsRUFBRSxNQUFNLEVBQUUsS0FBSyxFQUFFIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBJbnB1dCwgRWxlbWVudFJlZiwgVmlld0NoaWxkIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IENzTXVsdGlzZWxlY3RDb21wb25lbnQgfSBmcm9tICcuLi9jcy1tdWx0aXNlbGVjdC9jcy1tdWx0aXNlbGVjdC5jb21wb25lbnQnO1xyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ2NzLW11bHRpLXNlbGVjdC1vcHRpb24nLFxyXG4gIHRlbXBsYXRlVXJsOiAnLi9jcy1tdWx0aXNlbGVjdC1vcHRpb24uY29tcG9uZW50Lmh0bWwnLFxyXG4gIHN0eWxlVXJsczogWycuL2NzLW11bHRpc2VsZWN0LW9wdGlvbi5jb21wb25lbnQubGVzcyddLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgQ3NNdWx0aXNlbGVjdE9wdGlvbkNvbXBvbmVudCB7XHJcbiAgQElucHV0KCkgdmFsdWUhOiBhbnk7XHJcbiAgQFZpZXdDaGlsZCgnb3B0aW9ucycsIHsgcmVhZDogRWxlbWVudFJlZiwgc3RhdGljOiBmYWxzZSB9KVxyXG4gIG9wdGlvbiE6IEVsZW1lbnRSZWY7XHJcbiAgY29uc3RydWN0b3IocHVibGljIHNlbGVjdDogQ3NNdWx0aXNlbGVjdENvbXBvbmVudCkge31cclxuXHJcbiAgY2hhbmdlKGV2ZW50OiBhbnkpOiB2b2lkIHtcclxuICAgIGlmIChldmVudC50YXJnZXQuY2hlY2tlZCkge1xyXG4gICAgICB0aGlzLnNlbGVjdC5hZGRWYWx1ZSh7XHJcbiAgICAgICAga2V5OiB0aGlzLm9wdGlvbi5uYXRpdmVFbGVtZW50LmlubmVySFRNTC5yZXBsYWNlKC8mbHQ7L2csXCI8XCIpLFxyXG4gICAgICAgIHZhbHVlOiB0aGlzLnZhbHVlLFxyXG4gICAgICB9KTtcclxuICAgIH0gZWxzZSB7XHJcbiAgICAgIHRoaXMuc2VsZWN0LnJlbW92ZVZhbHVlRnJvbUNoZWNrYm94KHRoaXMudmFsdWUpO1xyXG4gICAgfVxyXG4gIH1cclxufVxyXG4iLCI8bGk+XHJcbiAgPGxhYmVsIGNsYXNzPVwibXVsdGktc2VsZWN0XCI+XHJcbiAgICA8aW5wdXQgdHlwZT1cImNoZWNrYm94XCIgdGFiaW5kZXg9XCIwXCIgW3ZhbHVlXT1cInZhbHVlXCIgW2NoZWNrZWRdPVwic2VsZWN0LnZhbHVlLmluY2x1ZGVzKHZhbHVlKVwiIChjaGFuZ2UpPVwiY2hhbmdlKCRldmVudClcIiAvPlxyXG4gICAgPHNwYW4gY2xhc3M9XCJjaGVja2JveFwiPjwvc3Bhbj5cclxuICAgIDxzcGFuIGNsYXNzPVwidmFsdWVcIiAjb3B0aW9ucz5cclxuICAgICAgPG5nLWNvbnRlbnQ+IDwvbmctY29udGVudD5cclxuICAgIDwvc3Bhbj5cclxuICA8L2xhYmVsPlxyXG48L2xpPlxyXG4iXX0=