mis-crystal-design-system 18.0.16 → 18.0.17-test-2
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/radio-button/radio-button.component.mjs +23 -102
- package/esm2022/table/actions-cell/actions-cell.component.mjs +11 -3
- package/esm2022/table/table.component.mjs +1 -1
- package/fesm2022/mis-crystal-design-system-radio-button.mjs +22 -101
- package/fesm2022/mis-crystal-design-system-radio-button.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-table.mjs +10 -2
- package/fesm2022/mis-crystal-design-system-table.mjs.map +1 -1
- package/package.json +13 -13
- package/radio-button/radio-button.component.d.ts +17 -18
- package/styles/mis-old-icon-styles.scss +0 -498
- package/table/table.component.d.ts +1 -0
|
@@ -1,124 +1,45 @@
|
|
|
1
|
-
import { Component, Input, Output, EventEmitter
|
|
2
|
-
import {
|
|
1
|
+
import { Component, Input, Output, EventEmitter } from "@angular/core";
|
|
2
|
+
import { UntypedFormControl } from "@angular/forms";
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
4
|
import * as i1 from "@angular/forms";
|
|
5
5
|
export class RadioButtonComponent {
|
|
6
|
-
set disabled(value) {
|
|
7
|
-
if (this._disabled !== value) {
|
|
8
|
-
this._disabled = value;
|
|
9
|
-
if (this._formControl && this._formControl.disabled !== value) {
|
|
10
|
-
if (value) {
|
|
11
|
-
this._formControl.disable({ emitEvent: false });
|
|
12
|
-
}
|
|
13
|
-
else {
|
|
14
|
-
this._formControl.enable({ emitEvent: false });
|
|
15
|
-
}
|
|
16
|
-
}
|
|
17
|
-
}
|
|
18
|
-
}
|
|
19
|
-
get disabled() {
|
|
20
|
-
return this._formControl ? this._formControl.disabled : this._disabled;
|
|
21
|
-
}
|
|
22
|
-
set formControl(control) {
|
|
23
|
-
if (control instanceof AbstractControl) {
|
|
24
|
-
this._formControl = control;
|
|
25
|
-
if (control.value !== null && control.value !== undefined) {
|
|
26
|
-
this._value = control.value;
|
|
27
|
-
}
|
|
28
|
-
if (this._disabled !== undefined && this._disabled !== control.disabled) {
|
|
29
|
-
if (this._disabled) {
|
|
30
|
-
control.disable({ emitEvent: false });
|
|
31
|
-
}
|
|
32
|
-
else {
|
|
33
|
-
control.enable({ emitEvent: false });
|
|
34
|
-
}
|
|
35
|
-
}
|
|
36
|
-
}
|
|
37
|
-
else {
|
|
38
|
-
this._formControl = new UntypedFormControl(control);
|
|
39
|
-
}
|
|
40
|
-
}
|
|
41
|
-
get formControl() {
|
|
42
|
-
return this._formControl;
|
|
43
|
-
}
|
|
44
6
|
constructor() {
|
|
7
|
+
/** When multiple radio input fields are used
|
|
8
|
+
* an "id" can be given to keep track of them */
|
|
45
9
|
this.id = "";
|
|
10
|
+
/** Name of the attribute for which the radio
|
|
11
|
+
* selection is provided */
|
|
46
12
|
this.name = "";
|
|
13
|
+
/** Value of the attribute which is to be emitted
|
|
14
|
+
* when selected */
|
|
47
15
|
this.value = "";
|
|
48
|
-
|
|
16
|
+
/** Controls the state of the radio button */
|
|
17
|
+
this.disabled = false;
|
|
18
|
+
/** Can be used to attach the radio input field
|
|
19
|
+
* to a reactive form by passing in a
|
|
20
|
+
* “FormControl“ Object. It can also be
|
|
21
|
+
* used to set the default attribute value */
|
|
22
|
+
this.formControl = new UntypedFormControl(null);
|
|
23
|
+
/** Emits "value" of the radio button on selection */
|
|
49
24
|
this.valueChange = new EventEmitter();
|
|
50
|
-
// ControlValueAccessor properties
|
|
51
|
-
this._value = null;
|
|
52
|
-
this._disabled = false;
|
|
53
|
-
this.onChange = (value) => { };
|
|
54
|
-
this.onTouched = () => { };
|
|
55
25
|
}
|
|
56
26
|
ngOnInit() { }
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
if (this._value !== value) {
|
|
60
|
-
this._value = value;
|
|
61
|
-
}
|
|
62
|
-
}
|
|
63
|
-
registerOnChange(fn) {
|
|
64
|
-
this.onChange = fn;
|
|
65
|
-
}
|
|
66
|
-
registerOnTouched(fn) {
|
|
67
|
-
this.onTouched = fn;
|
|
68
|
-
}
|
|
69
|
-
setDisabledState(isDisabled) {
|
|
70
|
-
if (this._disabled !== isDisabled) {
|
|
71
|
-
this._disabled = isDisabled;
|
|
72
|
-
}
|
|
73
|
-
}
|
|
74
|
-
// Legacy onChange method - maintains backward compatibility
|
|
75
|
-
onInputChange(event) {
|
|
76
|
-
const newValue = event.target.checked ? this.value : this._value;
|
|
77
|
-
if (this._value !== newValue) {
|
|
78
|
-
this._value = newValue;
|
|
79
|
-
this.onChange(newValue);
|
|
80
|
-
this.onTouched();
|
|
81
|
-
if (this._formControl && this._formControl.value !== newValue) {
|
|
82
|
-
this._formControl.setValue(newValue, { emitEvent: false });
|
|
83
|
-
}
|
|
84
|
-
this.valueChange.emit(newValue);
|
|
85
|
-
}
|
|
86
|
-
}
|
|
87
|
-
get currentValue() {
|
|
88
|
-
return this._formControl ? this._formControl.value : this._value;
|
|
89
|
-
}
|
|
90
|
-
markAsTouched() {
|
|
91
|
-
this.onTouched();
|
|
92
|
-
if (this._formControl) {
|
|
93
|
-
this._formControl.markAsTouched();
|
|
94
|
-
this._formControl.updateValueAndValidity();
|
|
95
|
-
}
|
|
27
|
+
onChange(event) {
|
|
28
|
+
this.valueChange.emit(this.formControl.value);
|
|
96
29
|
}
|
|
97
30
|
static { this.ɵfac = function RadioButtonComponent_Factory(__ngFactoryType__) { return new (__ngFactoryType__ || RadioButtonComponent)(); }; }
|
|
98
|
-
static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: RadioButtonComponent, selectors: [["mis-radio"]], inputs: { id: "id", name: "name", value: "value", disabled: "disabled", formControl: "formControl" }, outputs: { valueChange: "valueChange" },
|
|
99
|
-
{
|
|
100
|
-
provide: NG_VALUE_ACCESSOR,
|
|
101
|
-
useExisting: forwardRef(() => RadioButtonComponent),
|
|
102
|
-
multi: true
|
|
103
|
-
}
|
|
104
|
-
])], decls: 1, vars: 5, consts: [["tabindex", "-1", "type", "radio", 3, "change", "keyup.enter", "blur", "id", "name", "value", "formControl", "checked"]], template: function RadioButtonComponent_Template(rf, ctx) { if (rf & 1) {
|
|
31
|
+
static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: RadioButtonComponent, selectors: [["mis-radio"]], inputs: { id: "id", name: "name", value: "value", disabled: "disabled", formControl: "formControl" }, outputs: { valueChange: "valueChange" }, decls: 1, vars: 5, consts: [["tabindex", "-1", "type", "radio", 3, "change", "keup.enter", "id", "name", "disabled", "value", "formControl"]], template: function RadioButtonComponent_Template(rf, ctx) { if (rf & 1) {
|
|
105
32
|
i0.ɵɵelementStart(0, "input", 0);
|
|
106
|
-
i0.ɵɵlistener("change", function RadioButtonComponent_Template_input_change_0_listener($event) { return ctx.
|
|
33
|
+
i0.ɵɵlistener("change", function RadioButtonComponent_Template_input_change_0_listener($event) { return ctx.onChange($event); })("keup.enter", function RadioButtonComponent_Template_input_keup_enter_0_listener($event) { return ctx.onChange($event); });
|
|
107
34
|
i0.ɵɵelementEnd();
|
|
108
35
|
} if (rf & 2) {
|
|
109
36
|
i0.ɵɵpropertyInterpolate("id", ctx.id);
|
|
110
|
-
i0.ɵɵproperty("name", ctx.name)("
|
|
37
|
+
i0.ɵɵproperty("name", ctx.name)("disabled", ctx.disabled)("value", ctx.value)("formControl", ctx.formControl);
|
|
111
38
|
} }, dependencies: [i1.DefaultValueAccessor, i1.RadioControlValueAccessor, i1.NgControlStatus, i1.FormControlDirective], styles: ["input[type=radio][_ngcontent-%COMP%]{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:20px;height:20px;margin:0;padding:3px;background-clip:content-box;border:2px solid #6a737d;background-color:#fff;border-radius:50%;cursor:pointer}input[type=radio][_ngcontent-%COMP%]:checked{background-color:#0937b2;border:2px solid #0937b2}input[type=radio][_ngcontent-%COMP%]:hover{border:2px solid #929dab}input[type=radio][_ngcontent-%COMP%]:checked:hover{border:2px solid #0937b2}input[type=radio][_ngcontent-%COMP%]:disabled{border:2px solid #c8cdd3}input[type=radio][_ngcontent-%COMP%]:checked:disabled{border:2px solid #c8cdd3;background-color:#c8cdd3}"] }); }
|
|
112
39
|
}
|
|
113
40
|
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(RadioButtonComponent, [{
|
|
114
41
|
type: Component,
|
|
115
|
-
args: [{ selector: "mis-radio",
|
|
116
|
-
{
|
|
117
|
-
provide: NG_VALUE_ACCESSOR,
|
|
118
|
-
useExisting: forwardRef(() => RadioButtonComponent),
|
|
119
|
-
multi: true
|
|
120
|
-
}
|
|
121
|
-
], template: "<input \n (change)=\"onInputChange($event)\" \n (keyup.enter)=\"onInputChange($event)\"\n (blur)=\"markAsTouched()\"\n tabindex=\"-1\"\n id=\"{{ id }}\" type=\"radio\" \n [name]=\"name\"\n [value]=\"value\"\n [formControl]=\"formControl\" \n [checked]=\"currentValue === value\"\n/>", styles: ["input[type=radio]{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:20px;height:20px;margin:0;padding:3px;background-clip:content-box;border:2px solid #6a737d;background-color:#fff;border-radius:50%;cursor:pointer}input[type=radio]:checked{background-color:#0937b2;border:2px solid #0937b2}input[type=radio]:hover{border:2px solid #929dab}input[type=radio]:checked:hover{border:2px solid #0937b2}input[type=radio]:disabled{border:2px solid #c8cdd3}input[type=radio]:checked:disabled{border:2px solid #c8cdd3;background-color:#c8cdd3}\n"] }]
|
|
42
|
+
args: [{ selector: "mis-radio", template: "<input \n (change)=\"onChange($event)\" \n (keup.enter)=\"onChange($event)\"\n tabindex=\"-1\"\n id=\"{{ id }}\" type=\"radio\" \n [name]=\"name\" [disabled]=\"disabled\" \n [value]=\"value\"\n [formControl]=\"formControl\" \n/>\n", styles: ["input[type=radio]{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:20px;height:20px;margin:0;padding:3px;background-clip:content-box;border:2px solid #6a737d;background-color:#fff;border-radius:50%;cursor:pointer}input[type=radio]:checked{background-color:#0937b2;border:2px solid #0937b2}input[type=radio]:hover{border:2px solid #929dab}input[type=radio]:checked:hover{border:2px solid #0937b2}input[type=radio]:disabled{border:2px solid #c8cdd3}input[type=radio]:checked:disabled{border:2px solid #c8cdd3;background-color:#c8cdd3}\n"] }]
|
|
122
43
|
}], () => [], { id: [{
|
|
123
44
|
type: Input
|
|
124
45
|
}], name: [{
|
|
@@ -133,4 +54,4 @@ export class RadioButtonComponent {
|
|
|
133
54
|
type: Output
|
|
134
55
|
}] }); })();
|
|
135
56
|
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(RadioButtonComponent, { className: "RadioButtonComponent" }); })();
|
|
136
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"radio-button.component.js","sourceRoot":"","sources":["../../../../projects/mis-components/radio-button/radio-button.component.ts","../../../../projects/mis-components/radio-button/radio-button.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnInit, Output, EventEmitter, forwardRef } from \"@angular/core\";\nimport { AbstractControl, UntypedFormControl, ControlValueAccessor, NG_VALUE_ACCESSOR } from \"@angular/forms\";\n\n@Component({\n  selector: \"mis-radio\",\n  templateUrl: \"./radio-button.component.html\",\n  styleUrls: [\"./radio-button.component.scss\"],\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => RadioButtonComponent),\n      multi: true\n    }\n  ]\n})\nexport class RadioButtonComponent implements OnInit, ControlValueAccessor {\n  @Input() id: string | number = \"\";\n  @Input() name: string | number = \"\";\n  @Input() value: string | number = \"\";\n  \n  @Input() set disabled(value: boolean) {\n    if (this._disabled !== value) {\n      this._disabled = value;\n      if (this._formControl && this._formControl.disabled !== value) {\n        if (value) {\n          this._formControl.disable({ emitEvent: false });\n        } else {\n          this._formControl.enable({ emitEvent: false });\n        }\n      }\n    }\n  }\n  get disabled(): boolean {\n    return this._formControl ? this._formControl.disabled : this._disabled;\n  }\n\n  @Input() set formControl(control: AbstractControl | null) {\n    if (control instanceof AbstractControl) {\n      this._formControl = control;\n      if (control.value !== null && control.value !== undefined) {\n        this._value = control.value;\n      }\n      if (this._disabled !== undefined && this._disabled !== control.disabled) {\n        if (this._disabled) {\n          control.disable({ emitEvent: false });\n        } else {\n          control.enable({ emitEvent: false });\n        }\n      }\n    } else {\n      this._formControl = new UntypedFormControl(control);\n    }\n  }\n  get formControl(): AbstractControl {\n    return this._formControl;\n  }\n  private _formControl: AbstractControl = new UntypedFormControl(null);\n\n  @Output() valueChange = new EventEmitter<any>();\n\n  // ControlValueAccessor properties\n  private _value: any = null;\n  private _disabled: boolean = false;\n  private onChange = (value: any) => {};\n  public onTouched = () => {};\n\n  constructor() {}\n  \n  ngOnInit() {}\n\n  // ControlValueAccessor implementation\n  writeValue(value: any): void {\n    if (this._value !== value) {\n      this._value = value;\n    }\n  }\n\n  registerOnChange(fn: any): void {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: any): void {\n    this.onTouched = fn;\n  }\n\n  setDisabledState(isDisabled: boolean): void {\n    if (this._disabled !== isDisabled) {\n      this._disabled = isDisabled;\n    }\n  }\n\n  // Legacy onChange method - maintains backward compatibility\n  onInputChange(event: any) {\n    const newValue = event.target.checked ? this.value : this._value;\n    \n    if (this._value !== newValue) {\n      this._value = newValue;\n      \n      this.onChange(newValue);\n      this.onTouched();\n      \n      if (this._formControl && this._formControl.value !== newValue) {\n        this._formControl.setValue(newValue, { emitEvent: false });\n      }\n      \n      this.valueChange.emit(newValue);\n    }\n  }\n\n  get currentValue(): any {\n    return this._formControl ? this._formControl.value : this._value;\n  }\n\n  public markAsTouched(): void {\n    this.onTouched();\n    if (this._formControl) {\n      this._formControl.markAsTouched();\n      this._formControl.updateValueAndValidity();\n    }\n  }\n}","<input \n    (change)=\"onInputChange($event)\" \n    (keyup.enter)=\"onInputChange($event)\"\n    (blur)=\"markAsTouched()\"\n    tabindex=\"-1\"\n    id=\"{{ id }}\" type=\"radio\" \n    [name]=\"name\"\n    [value]=\"value\"\n    [formControl]=\"formControl\" \n    [checked]=\"currentValue === value\"\n/>"]}
|
|
57
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmFkaW8tYnV0dG9uLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL21pcy1jb21wb25lbnRzL3JhZGlvLWJ1dHRvbi9yYWRpby1idXR0b24uY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vcHJvamVjdHMvbWlzLWNvbXBvbmVudHMvcmFkaW8tYnV0dG9uL3JhZGlvLWJ1dHRvbi5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBVSxNQUFNLEVBQUUsWUFBWSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQy9FLE9BQU8sRUFBbUIsa0JBQWtCLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQzs7O0FBT3JFLE1BQU0sT0FBTyxvQkFBb0I7SUFzQi9CO1FBckJBO3dEQUNnRDtRQUN2QyxPQUFFLEdBQW9CLEVBQUUsQ0FBQztRQUNsQzttQ0FDMkI7UUFDbEIsU0FBSSxHQUFvQixFQUFFLENBQUM7UUFDcEM7MkJBQ21CO1FBQ1YsVUFBSyxHQUFvQixFQUFFLENBQUM7UUFDckMsNkNBQTZDO1FBQ3BDLGFBQVEsR0FBWSxLQUFLLENBQUM7UUFFbkM7OztxREFHNkM7UUFDcEMsZ0JBQVcsR0FBb0IsSUFBSSxrQkFBa0IsQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUVyRSxxREFBcUQ7UUFDM0MsZ0JBQVcsR0FBRyxJQUFJLFlBQVksRUFBTyxDQUFDO0lBRWpDLENBQUM7SUFDaEIsUUFBUSxLQUFJLENBQUM7SUFDYixRQUFRLENBQUMsS0FBSztRQUNaLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDaEQsQ0FBQztxSEExQlUsb0JBQW9CO29FQUFwQixvQkFBb0I7WUNSakMsZ0NBUUU7WUFORSxBQURBLHdHQUFVLG9CQUFnQixJQUFDLG1HQUNiLG9CQUFnQixJQUFDO1lBRm5DLGlCQVFFOztZQUpFLHNDQUFhO1lBR2IsQUFEQSxBQURjLEFBQWQsK0JBQWEsMEJBQXNCLG9CQUNwQixnQ0FDWTs7O2lGRENsQixvQkFBb0I7Y0FMaEMsU0FBUzsyQkFDRSxXQUFXO29CQU9aLEVBQUU7a0JBQVYsS0FBSztZQUdHLElBQUk7a0JBQVosS0FBSztZQUdHLEtBQUs7a0JBQWIsS0FBSztZQUVHLFFBQVE7a0JBQWhCLEtBQUs7WUFNRyxXQUFXO2tCQUFuQixLQUFLO1lBR0ksV0FBVztrQkFBcEIsTUFBTTs7a0ZBcEJJLG9CQUFvQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSW5wdXQsIE9uSW5pdCwgT3V0cHV0LCBFdmVudEVtaXR0ZXIgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xuaW1wb3J0IHsgQWJzdHJhY3RDb250cm9sLCBVbnR5cGVkRm9ybUNvbnRyb2wgfSBmcm9tIFwiQGFuZ3VsYXIvZm9ybXNcIjtcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiBcIm1pcy1yYWRpb1wiLFxuICB0ZW1wbGF0ZVVybDogXCIuL3JhZGlvLWJ1dHRvbi5jb21wb25lbnQuaHRtbFwiLFxuICBzdHlsZVVybHM6IFtcIi4vcmFkaW8tYnV0dG9uLmNvbXBvbmVudC5zY3NzXCJdXG59KVxuZXhwb3J0IGNsYXNzIFJhZGlvQnV0dG9uQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0IHtcbiAgLyoqIFdoZW4gbXVsdGlwbGUgcmFkaW8gaW5wdXQgZmllbGRzIGFyZSB1c2VkXG4gICAqIGFuIFwiaWRcIiBjYW4gYmUgZ2l2ZW4gdG8ga2VlcCB0cmFjayBvZiB0aGVtICovXG4gIEBJbnB1dCgpIGlkOiBzdHJpbmcgfCBudW1iZXIgPSBcIlwiO1xuICAvKiogTmFtZSBvZiB0aGUgYXR0cmlidXRlIGZvciB3aGljaCB0aGUgcmFkaW9cbiAgICogc2VsZWN0aW9uIGlzIHByb3ZpZGVkICovXG4gIEBJbnB1dCgpIG5hbWU6IHN0cmluZyB8IG51bWJlciA9IFwiXCI7XG4gIC8qKiBWYWx1ZSBvZiB0aGUgYXR0cmlidXRlIHdoaWNoIGlzIHRvIGJlIGVtaXR0ZWRcbiAgICogd2hlbiBzZWxlY3RlZCAqL1xuICBASW5wdXQoKSB2YWx1ZTogc3RyaW5nIHwgbnVtYmVyID0gXCJcIjtcbiAgLyoqIENvbnRyb2xzIHRoZSBzdGF0ZSBvZiB0aGUgcmFkaW8gYnV0dG9uICovXG4gIEBJbnB1dCgpIGRpc2FibGVkOiBib29sZWFuID0gZmFsc2U7XG5cbiAgLyoqIENhbiBiZSB1c2VkIHRvIGF0dGFjaCB0aGUgcmFkaW8gaW5wdXQgZmllbGRcbiAgICogdG8gYSByZWFjdGl2ZSBmb3JtIGJ5IHBhc3NpbmcgaW4gYVxuICAgKiDigJxGb3JtQ29udHJvbOKAnCBPYmplY3QuIEl0IGNhbiBhbHNvIGJlXG4gICAqIHVzZWQgdG8gc2V0IHRoZSBkZWZhdWx0IGF0dHJpYnV0ZSB2YWx1ZSAqL1xuICBASW5wdXQoKSBmb3JtQ29udHJvbDogQWJzdHJhY3RDb250cm9sID0gbmV3IFVudHlwZWRGb3JtQ29udHJvbChudWxsKTtcblxuICAvKiogRW1pdHMgXCJ2YWx1ZVwiIG9mIHRoZSByYWRpbyBidXR0b24gb24gc2VsZWN0aW9uICovXG4gIEBPdXRwdXQoKSB2YWx1ZUNoYW5nZSA9IG5ldyBFdmVudEVtaXR0ZXI8YW55PigpO1xuXG4gIGNvbnN0cnVjdG9yKCkge31cbiAgbmdPbkluaXQoKSB7fVxuICBvbkNoYW5nZShldmVudCkge1xuICAgIHRoaXMudmFsdWVDaGFuZ2UuZW1pdCh0aGlzLmZvcm1Db250cm9sLnZhbHVlKTtcbiAgfVxufVxuIiwiPGlucHV0IFxuICAgIChjaGFuZ2UpPVwib25DaGFuZ2UoJGV2ZW50KVwiIFxuICAgIChrZXVwLmVudGVyKT1cIm9uQ2hhbmdlKCRldmVudClcIlxuICAgIHRhYmluZGV4PVwiLTFcIlxuICAgIGlkPVwie3sgaWQgfX1cIiB0eXBlPVwicmFkaW9cIiBcbiAgICBbbmFtZV09XCJuYW1lXCIgW2Rpc2FibGVkXT1cImRpc2FibGVkXCIgXG4gICAgW3ZhbHVlXT1cInZhbHVlXCJcbiAgICBbZm9ybUNvbnRyb2xdPVwiZm9ybUNvbnRyb2xcIiBcbi8+XG4iXX0=
|
|
@@ -174,8 +174,16 @@ export class ActionsCellComponent {
|
|
|
174
174
|
this.containerStyle = {};
|
|
175
175
|
}
|
|
176
176
|
set rowData(value) {
|
|
177
|
-
this.
|
|
178
|
-
|
|
177
|
+
if (this.actionType === 'checkbox') {
|
|
178
|
+
// For checkbox, keep the rowData structure
|
|
179
|
+
this.data = value?.rowData ?? {};
|
|
180
|
+
this.isChecked = value?.isChecked ?? false;
|
|
181
|
+
}
|
|
182
|
+
else {
|
|
183
|
+
// For other actions (dropdown, inline), use the value directly
|
|
184
|
+
this.data = value;
|
|
185
|
+
this.isChecked = false;
|
|
186
|
+
}
|
|
179
187
|
}
|
|
180
188
|
set config(config) {
|
|
181
189
|
this.actionItems = config?.actionItems,
|
|
@@ -289,4 +297,4 @@ export class ActionsCellComponent {
|
|
|
289
297
|
args: ["document:click"]
|
|
290
298
|
}] }); })();
|
|
291
299
|
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(ActionsCellComponent, { className: "ActionsCellComponent" }); })();
|
|
292
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"actions-cell.component.js","sourceRoot":"","sources":["../../../../../projects/mis-components/table/actions-cell/actions-cell.component.ts","../../../../../projects/mis-components/table/actions-cell/actions-cell.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output, HostListener } from \"@angular/core\";\nimport { ActionItem } from \"../table.component\";\n\n@Component({\n  selector: \"mis-actions-cell\",\n  templateUrl: \"./actions-cell.component.html\",\n  styleUrl: \"./actions-cell.component.css\"\n})\nexport class ActionsCellComponent implements OnInit {\n  @Input() set rowData(value: any){\n    this.data = value?.rowData ?? {};\n    this.isChecked = value?.isChecked ?? false;\n  }\n  data: any;\n  @Input() isChecked: boolean = false;\n  @Input() set config(config: any){\n    this.actionItems = config?.actionItems,\n    this.actionType = config.actionType,\n    this.submenuAlign = config.submenuAlign,\n    this.menuAlign = config.menuAlign\n    this._style = config.style;\n    this.action = config.action;\n    this.processStyle();\n  }\n\n  actionItems: ActionItem[] = [];\n  actionType: \"inline\" | \"dropdown\" | \"checkbox\" = \"inline\";\n  submenuAlign: \"left\" | \"right\" = \"right\";\n  menuAlign: \"left\" | \"right\" = \"left\";\n  action?: (data: any) => void;\n\n  @Output() actionClick = new EventEmitter<{ item?: ActionItem; data: any; isChecked?: any }>();\n\n  isDropdownOpen: boolean = false;\n  private _style: any = {};\n  containerStyle: any = {};\n\n  ngOnInit(): void {}\n\n  private processStyle(): void {\n    // Remove width from style to avoid conflicts with table column width\n    const { width, ...restStyle } = this._style;\n    this.containerStyle = restStyle;\n  }\n\n  onActionClick(item: ActionItem, event: Event) {\n    event.stopPropagation();\n\n    // Check permissions before executing action\n    if (this.isDisabled(item)) return;\n\n    // Execute action only if permitted\n    if (item.action) {\n      item.action(this.data);\n    }\n\n    this.actionClick.emit({ item, data: this.data });\n  }\n\n  trackByAction(index: number, item: ActionItem): string {\n    return item.value;\n  }\n\n  isSvgFile(iconPath: string): boolean {\n    if (!iconPath) return false;\n    return iconPath.toLowerCase().includes(\".svg\") || iconPath.toLowerCase().includes(\"assets/icons/\");\n  }\n\n  @HostListener(\"document:click\")\n  onDocumentClick() {\n    if (this.isDropdownOpen) {\n      this.isDropdownOpen = false;\n    }\n  }\n\n  toggleDropdown(event: Event) {\n    event.stopPropagation();\n    this.isDropdownOpen = !this.isDropdownOpen;\n    // Close all submenus when opening/closing main menu\n    this.actionItems.forEach((item: any) => (item.showSubmenu = false));\n  }\n\n  onDropdownItemClick(item: any, event: Event) {\n    event.stopPropagation();\n\n    if (this.isDisabled(item)) return;\n\n    if (item?.children?.length) {\n      // Toggle submenu\n      item.showSubmenu = !item.showSubmenu;\n      // Optionally close other submenus\n      this.actionItems.forEach((i: any) => {\n        if (i !== item) i.showSubmenu = false;\n      });\n    } else {\n      // Handle action\n      if (item.action) item.action(this.data);\n      this.actionClick.emit({ item, data: this.data });\n      this.isDropdownOpen = false; // Only close if action was executed\n    }\n  }\n\n  onCheckboxChange(event: any): void {\n    this.isChecked = event?.value ?? false;\n    this.actionClick.emit({ \n      isChecked: this.isChecked, \n      data: this.data \n    });\n  }\n\n\n  isDisabled(item: ActionItem): boolean {\n    if (typeof item.disable === \"function\") {\n      return item.disable(this.data);\n    }\n    return false;\n  }\n}\n","<div class=\"actions-cell-container\" [ngStyle]=\"containerStyle\">\n  <!-- Inline Actions -->\n  <div *ngIf=\"actionType === 'inline'\" class=\"inline-actions\">\n    <div\n      *ngFor=\"let item of actionItems; trackBy: trackByAction\"\n      class=\"action-item\"\n      [ngClass]=\"{ disabled: isDisabled(item) }\"\n      (click)=\"onActionClick(item, $event)\"\n    >\n      <img [src]=\"item.icon\" [alt]=\"item.label\" class=\"action-icon-svg\" />\n    </div>\n  </div>\n\n  <!-- Dropdown Actions -->\n  <div *ngIf=\"actionType === 'dropdown'\" class=\"dropdown-actions\">\n    <div class=\"dropdown-trigger\" (click)=\"toggleDropdown($event)\" title=\"More actions\">\n      <svg width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"none\">\n        <circle cx=\"10\" cy=\"4\" r=\"2\" fill=\"#333\" />\n        <circle cx=\"10\" cy=\"10\" r=\"2\" fill=\"#333\" />\n        <circle cx=\"10\" cy=\"16\" r=\"2\" fill=\"#333\" />\n      </svg>\n    </div>\n\n    <div class=\"dropdown-menu\" *ngIf=\"isDropdownOpen\" [ngClass]=\"menuAlign\">\n      <div\n        class=\"dropdown-menu-item\"\n        *ngFor=\"let item of actionItems\"\n        (click)=\"onDropdownItemClick(item, $event)\"\n        [ngClass]=\"{ disabled: isDisabled(item) }\"\n      >\n        <ng-container *ngIf=\"item.children?.length; else noChildren\">\n          <span class=\"dropdown-icon\" *ngIf=\"item.icon\">\n            <img [src]=\"item.icon\" />\n          </span>\n          <span class=\"dropdown-label\">{{ item.label }}</span>\n          <span class=\"submenu-arrow\">\n            <svg width=\"20\" height=\"20\" viewBox=\"0 0 24 24\" fill=\"none\">\n              <path d=\"M9 6L15 12L9 18\" stroke=\"#0D1321\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n            </svg>\n          </span>\n\n          <!-- DYNAMIC SUBMENU -->\n          <div class=\"dropdown-submenu\" [ngClass]=\"item.submenuAlign\" *ngIf=\"item.showSubmenu\">\n            <div\n              class=\"dropdown-menu-item\"\n              *ngFor=\"let child of item.children\"\n              [ngClass]=\"{ disabled: isDisabled(child) }\"\n              (click)=\"onDropdownItemClick(child, $event)\"\n            >\n              <span class=\"dropdown-icon\" *ngIf=\"child.icon\">\n                <img [src]=\"child.icon\" />\n              </span>\n              <span class=\"dropdown-label\">{{ child.label }}</span>\n            </div>\n          </div>\n        </ng-container>\n\n        <ng-template #noChildren>\n          <span class=\"dropdown-icon\" *ngIf=\"item.icon\">\n            <img [src]=\"item.icon\" />\n          </span>\n          <span class=\"dropdown-label\">{{ item.label }}</span>\n        </ng-template>\n      </div>\n    </div>\n  </div>\n\n  <!-- Checkbox Actions -->\n  <div *ngIf=\"actionType === 'checkbox'\" class=\"checkbox-actions\">\n    <mis-checkbox [checked]=\"isChecked\" (valueChange)=\"onCheckboxChange($event)\"> </mis-checkbox>\n  </div>\n</div>\n"]}
|
|
300
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"actions-cell.component.js","sourceRoot":"","sources":["../../../../../projects/mis-components/table/actions-cell/actions-cell.component.ts","../../../../../projects/mis-components/table/actions-cell/actions-cell.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output, HostListener } from \"@angular/core\";\nimport { ActionItem } from \"../table.component\";\n\n@Component({\n  selector: \"mis-actions-cell\",\n  templateUrl: \"./actions-cell.component.html\",\n  styleUrl: \"./actions-cell.component.css\"\n})\nexport class ActionsCellComponent implements OnInit {\n  @Input() set rowData(value: any){\n    if (this.actionType === 'checkbox') {\n      // For checkbox, keep the rowData structure\n      this.data = value?.rowData ?? {};\n      this.isChecked = value?.isChecked ?? false;\n    } else {\n      // For other actions (dropdown, inline), use the value directly\n      this.data = value;\n      this.isChecked = false;\n    }\n  }\n  data: any;\n  @Input() isChecked: boolean = false;\n  @Input() set config(config: any){\n    this.actionItems = config?.actionItems,\n    this.actionType = config.actionType,\n    this.submenuAlign = config.submenuAlign,\n    this.menuAlign = config.menuAlign\n    this._style = config.style;\n    this.action = config.action;\n    this.processStyle();\n  }\n\n  actionItems: ActionItem[] = [];\n  actionType: \"inline\" | \"dropdown\" | \"checkbox\" = \"inline\";\n  submenuAlign: \"left\" | \"right\" = \"right\";\n  menuAlign: \"left\" | \"right\" = \"left\";\n  action?: (data: any) => void;\n\n  @Output() actionClick = new EventEmitter<{ item?: ActionItem; data: any; isChecked?: any }>();\n\n  isDropdownOpen: boolean = false;\n  private _style: any = {};\n  containerStyle: any = {};\n\n  ngOnInit(): void {}\n\n  private processStyle(): void {\n    // Remove width from style to avoid conflicts with table column width\n    const { width, ...restStyle } = this._style;\n    this.containerStyle = restStyle;\n  }\n\n  onActionClick(item: ActionItem, event: Event) {\n    event.stopPropagation();\n\n    // Check permissions before executing action\n    if (this.isDisabled(item)) return;\n\n    // Execute action only if permitted\n    if (item.action) {\n      item.action(this.data);\n    }\n\n    this.actionClick.emit({ item, data: this.data });\n  }\n\n  trackByAction(index: number, item: ActionItem): string {\n    return item.value;\n  }\n\n  isSvgFile(iconPath: string): boolean {\n    if (!iconPath) return false;\n    return iconPath.toLowerCase().includes(\".svg\") || iconPath.toLowerCase().includes(\"assets/icons/\");\n  }\n\n  @HostListener(\"document:click\")\n  onDocumentClick() {\n    if (this.isDropdownOpen) {\n      this.isDropdownOpen = false;\n    }\n  }\n\n  toggleDropdown(event: Event) {\n    event.stopPropagation();\n    this.isDropdownOpen = !this.isDropdownOpen;\n    // Close all submenus when opening/closing main menu\n    this.actionItems.forEach((item: any) => (item.showSubmenu = false));\n  }\n\n  onDropdownItemClick(item: any, event: Event) {\n    event.stopPropagation();\n\n    if (this.isDisabled(item)) return;\n\n    if (item?.children?.length) {\n      // Toggle submenu\n      item.showSubmenu = !item.showSubmenu;\n      // Optionally close other submenus\n      this.actionItems.forEach((i: any) => {\n        if (i !== item) i.showSubmenu = false;\n      });\n    } else {\n      // Handle action\n      if (item.action) item.action(this.data);\n      this.actionClick.emit({ item, data: this.data });\n      this.isDropdownOpen = false; // Only close if action was executed\n    }\n  }\n\n  onCheckboxChange(event: any): void {\n    this.isChecked = event?.value ?? false;\n    this.actionClick.emit({ \n      isChecked: this.isChecked, \n      data: this.data \n    });\n  }\n\n\n  isDisabled(item: ActionItem): boolean {\n    if (typeof item.disable === \"function\") {\n      return item.disable(this.data);\n    }\n    return false;\n  }\n}\n","<div class=\"actions-cell-container\" [ngStyle]=\"containerStyle\">\n  <!-- Inline Actions -->\n  <div *ngIf=\"actionType === 'inline'\" class=\"inline-actions\">\n    <div\n      *ngFor=\"let item of actionItems; trackBy: trackByAction\"\n      class=\"action-item\"\n      [ngClass]=\"{ disabled: isDisabled(item) }\"\n      (click)=\"onActionClick(item, $event)\"\n    >\n      <img [src]=\"item.icon\" [alt]=\"item.label\" class=\"action-icon-svg\" />\n    </div>\n  </div>\n\n  <!-- Dropdown Actions -->\n  <div *ngIf=\"actionType === 'dropdown'\" class=\"dropdown-actions\">\n    <div class=\"dropdown-trigger\" (click)=\"toggleDropdown($event)\" title=\"More actions\">\n      <svg width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"none\">\n        <circle cx=\"10\" cy=\"4\" r=\"2\" fill=\"#333\" />\n        <circle cx=\"10\" cy=\"10\" r=\"2\" fill=\"#333\" />\n        <circle cx=\"10\" cy=\"16\" r=\"2\" fill=\"#333\" />\n      </svg>\n    </div>\n\n    <div class=\"dropdown-menu\" *ngIf=\"isDropdownOpen\" [ngClass]=\"menuAlign\">\n      <div\n        class=\"dropdown-menu-item\"\n        *ngFor=\"let item of actionItems\"\n        (click)=\"onDropdownItemClick(item, $event)\"\n        [ngClass]=\"{ disabled: isDisabled(item) }\"\n      >\n        <ng-container *ngIf=\"item.children?.length; else noChildren\">\n          <span class=\"dropdown-icon\" *ngIf=\"item.icon\">\n            <img [src]=\"item.icon\" />\n          </span>\n          <span class=\"dropdown-label\">{{ item.label }}</span>\n          <span class=\"submenu-arrow\">\n            <svg width=\"20\" height=\"20\" viewBox=\"0 0 24 24\" fill=\"none\">\n              <path d=\"M9 6L15 12L9 18\" stroke=\"#0D1321\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\n            </svg>\n          </span>\n\n          <!-- DYNAMIC SUBMENU -->\n          <div class=\"dropdown-submenu\" [ngClass]=\"item.submenuAlign\" *ngIf=\"item.showSubmenu\">\n            <div\n              class=\"dropdown-menu-item\"\n              *ngFor=\"let child of item.children\"\n              [ngClass]=\"{ disabled: isDisabled(child) }\"\n              (click)=\"onDropdownItemClick(child, $event)\"\n            >\n              <span class=\"dropdown-icon\" *ngIf=\"child.icon\">\n                <img [src]=\"child.icon\" />\n              </span>\n              <span class=\"dropdown-label\">{{ child.label }}</span>\n            </div>\n          </div>\n        </ng-container>\n\n        <ng-template #noChildren>\n          <span class=\"dropdown-icon\" *ngIf=\"item.icon\">\n            <img [src]=\"item.icon\" />\n          </span>\n          <span class=\"dropdown-label\">{{ item.label }}</span>\n        </ng-template>\n      </div>\n    </div>\n  </div>\n\n  <!-- Checkbox Actions -->\n  <div *ngIf=\"actionType === 'checkbox'\" class=\"checkbox-actions\">\n    <mis-checkbox [checked]=\"isChecked\" (valueChange)=\"onCheckboxChange($event)\"> </mis-checkbox>\n  </div>\n</div>\n"]}
|
|
@@ -643,4 +643,4 @@ export class TableComponent {
|
|
|
643
643
|
type: Output
|
|
644
644
|
}] }); })();
|
|
645
645
|
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(TableComponent, { className: "TableComponent" }); })();
|
|
646
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table.component.js","sourceRoot":"","sources":["../../../../projects/mis-components/table/table.component.ts","../../../../projects/mis-components/table/table.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnInit,\n  Output,\n  QueryList,\n  Renderer2,\n  ViewChild,\n  ViewChildren\n} from \"@angular/core\";\nimport { Filter, TableFilterComponent } from \"./filter/filter.component\";\nimport { SortState } from \"./sort-icons.directive\";\n\n@Component({\n  selector: \"mis-table\",\n  templateUrl: \"table.component.html\",\n  styleUrls: [\"table.component.css\"]\n})\nexport class TableComponent implements OnInit, AfterViewInit, OnChanges {\n  // Initialize with -1 to indicate no row is colored at the beginning\n  activeRowIndex: number[] = [-1];\n  hasCheckboxActions: boolean = false;\n  selectAllCheckbox: boolean = false;\n\n  // Filter related variables\n  showFilter: boolean = false;\n  filterName: string = \"\";\n  filterData: Array<Filter> = [];\n  filterContainerStyles: any = {};\n  appliedFilters: { [key: string]: Array<{ name: string; value: string }> } = {};\n  @Output() filtersUpdated = new EventEmitter<{\n    [key: string]: Array<{ name: string; value: string }>;\n  }>();\n\n  @ViewChild(\"filter\") filter: TableFilterComponent | any;\n  @ViewChildren(\"colHeaderRef\") colHeaders: QueryList<ElementRef> | any;\n\n  // Pagination related variables\n  pages: Array<number> = [];\n  tableLength: number;\n  @Output() pageSelected = new EventEmitter<number>();\n\n  @Input(\"tableConfig\") config: TableConfig | any;\n  @Input() subTableconfig: TableConfig | any;\n  @Input() tableDataLoading: boolean | any;\n  @Input() expandedIndex: number | any;\n  @Input() tableData: Array<Array<any>> = [];\n  @Input() subTableData: Array<Array<any>> = [];\n  @Input() subTableDataLoading: boolean | any;\n  @ViewChild(\"table\") table: ElementRef | any;\n\n  // Sorting related properties\n  currentSort: SortState | null = null;\n  multiColumnSort: SortState[] = [];\n  @Output() sortChange = new EventEmitter<SortState>();\n  @Output() headerAction? = new EventEmitter<{ type: string; payload?: any }>();\n\n  constructor(private renderer: Renderer2) {}\n\n  // Function to handle row click\n  selectRow(index: number) {\n    if (this.hasCheckboxActions) return;\n    this.activeRowIndex = [index]; // Set the selected index to the clicked row's index\n    !!this.config.rowConfig.action && this.config.rowConfig.action(index);\n  }\n\n  ngOnInit(): void {\n    this.hasCheckboxActions = this.config.colConfig?.some(col => col.type === \"actions\" && col.actionType === \"checkbox\");\n    this.tableLength = !!this.tableData ? this.tableData.length : 0;\n    this.initializeFilters();\n    if (this.config.paginationConfig) {\n      this.initializePagination();\n    }\n    if (this.config.canScrollHorizontally === undefined) {\n      this.config.canScrollHorizontally = false;\n    }\n    document.addEventListener(\"click\", event => {\n      if (this.filter) {\n        let isCheckBoxClicked = true;\n        let targetElement = event.target as HTMLSpanElement;\n        if (targetElement.className === \"checkmark\") {\n          isCheckBoxClicked = true;\n          this.showFilter = true;\n        }\n        let isClickInsideElement = this.filter.container.nativeElement.contains(event.target);\n        if (!isClickInsideElement && !isCheckBoxClicked) {\n          this.toggleFilter(this.filterName);\n        }\n      }\n    });\n  }\n  ngAfterViewInit() {\n    if (this.config.paginationConfig) {\n      let height = this.config.height;\n      this.renderer.setStyle(this.table.nativeElement, \"height\", height - 56 + \"px\");\n    }\n  }\n  ngOnChanges() {\n    this.tableLength = !!this.tableData ? this.tableData.length : 0;\n    this.activeRowIndex = [this.config.activeRowIndex || -1];\n  }\n\n  // Filter related functions\n  initializeFilters() {\n    for (let colHeader of this.config?.colHeaderConfig) {\n      if (colHeader.filters) {\n        let filters = [];\n        for (let filter of colHeader.filters) {\n          if (filter.checked) {\n            filters.push({\n              name: filter.name,\n              value: filter.value\n            });\n          }\n        }\n        if (filters.length > 0) this.appliedFilters[colHeader.data] = filters;\n      }\n    }\n  }\n  toggleFilter(filterName: string) {\n    if (!this.showFilter) {\n      this.filterName = filterName;\n      this.showFilter = true;\n\n      let offSet = 0;\n      let colHeadersReversed = this.colHeaders.toArray().reverse();\n\n      for (let header of colHeadersReversed) {\n        if (header.nativeElement.innerText === filterName) break;\n        offSet += header.nativeElement.offsetWidth;\n      }\n      this.filterContainerStyles = {\n        top: \"44px\",\n        right: offSet > 0 ? offSet - 116 + \"px\" : \"12px\"\n      };\n    } else {\n      this.filterName = \"\";\n      this.filterData = [];\n      this.showFilter = false;\n    }\n  }\n  updateAppliedFilters(appliedFilters: Array<{ name: string; value: string }>) {\n    if (appliedFilters.length == 0) {\n      delete this.appliedFilters[this.filterName];\n    } else {\n      this.appliedFilters[this.filterName] = appliedFilters;\n    }\n    this.filtersUpdated.emit({ ...this.appliedFilters });\n    this.toggleFilter(this.filterName);\n  }\n\n  // Pagination related functions\n  initializePagination() {\n    if (this.config.paginationConfig) {\n      let len = this.config.paginationConfig.noOfPages;\n      if (len <= 7) {\n        for (let i = 1; i <= len; i++) {\n          this.pages.push(i);\n        }\n      } else {\n        this.pages = [1, 2, 3, 4, 0, len];\n      }\n    }\n  }\n  updateSelectedPage(pageNumber: number) {\n    // Guard clause to prevent out-of-range updates\n    if (pageNumber < 1 || pageNumber > this.config.paginationConfig.noOfPages) return;\n\n    if (this.config.colHeaderConfig?.some(col => col.type === \"checkbox\")) {\n      this.selectAllCheckbox = false;\n    }\n    if (pageNumber < 1 || pageNumber > this.config.paginationConfig.noOfPages) return;\n    this.config.paginationConfig.selectedPage = pageNumber;\n    let len = this.config.paginationConfig.noOfPages;\n    if (len > 7) {\n      if (pageNumber - 2 <= 1) {\n        this.pages = [1, 2, 3, 4, 0, len];\n      } else if (pageNumber - 2 > 1 && pageNumber + 2 < len) {\n        this.pages = [1, 0, pageNumber - 1, pageNumber, pageNumber + 1, 0, len];\n      } else if (pageNumber + 2 >= len) {\n        this.pages = [1, 0, len - 3, len - 2, len - 1, len];\n      }\n    }\n    this.pageSelected.emit(this.config.paginationConfig?.selectedPage);\n  }\n\n  // Main container related functions\n  getContainerHeight() {\n    if (this.config?.height) return this.config.height;\n    else return \"\";\n  }\n  getContainerWidth() {\n    if (this.config?.width) return this.config.width;\n    else return \"\";\n  }\n\n  // Column Headers related functions\n  getColHeadersRowStyles() {\n    const { colHeadersRowConfig } = this.config;\n    const minHeight = colHeadersRowConfig?.height || \"44px\";\n    const borderTop = colHeadersRowConfig?.style?.borderTop || \"\";\n    const borderBottom = colHeadersRowConfig?.style?.borderBottom || \"1px solid #E0E0E0\";\n    const backgroundColor = colHeadersRowConfig?.style?.backgroundColor || \"#FFFFFF\";\n    const fontSize = colHeadersRowConfig?.style?.fontSize || \"14px\";\n    return {\n      \"min-height\": minHeight,\n      \"border-top\": borderTop,\n      \"border-bottom\": borderBottom,\n      \"background-color\": backgroundColor,\n      \"font-size\": fontSize\n    };\n  }\n\n  onSortChange(sortState: SortState) {\n    this.currentSort = sortState;\n    if (this.config.multiColumnSort) {\n      const index = this.multiColumnSort.findIndex(sort => sort.column === sortState.column);\n      if (index !== -1) {\n        if (sortState.direction === null) {\n          this.multiColumnSort.splice(index, 1);\n        } else {\n          this.multiColumnSort[index] = sortState;\n        }\n      } else if (sortState.direction !== null) {\n        this.multiColumnSort.push(sortState);\n      }\n    }\n    this.sortChange.emit(sortState);\n  }\n\n  getActionsCellStyle(style: any): any {\n    if (!style) return {};\n    const { width, ...restStyle } = style;\n    return restStyle;\n  }\n\n  onActionClick(event: any, rowIndex: number): void {\n    if (event.isChecked !== undefined) {\n      // Handle checkbox changes\n      if (event.isChecked) {\n        this.activeRowIndex.push(rowIndex);\n      } else {\n        this.activeRowIndex = this.activeRowIndex.filter(index => index !== rowIndex);\n      }\n  \n      // Update the table data with the new checkbox state\n      const actionColIndex = this.config.colConfig.findIndex(col => col.type === 'actions' && col.actionType === 'checkbox');\n      if (actionColIndex !== -1 && this.tableData[rowIndex]) {\n        this.tableData[rowIndex][actionColIndex] = {\n          ...this.tableData[rowIndex][actionColIndex],\n          isChecked: event.isChecked\n        };\n      }\n  \n      // Collect all checked items\n      const checkedItems = this.tableData\n        .map((row, index) => ({ row, index }))\n        .filter(({ row }) => {\n          const actionCol = row[actionColIndex];\n          return actionCol?.isChecked === true;\n        })\n        .map(({ row, index }) => ({\n          rowData: row[actionColIndex].rowData,\n          rowIndex: index,\n          isChecked: true\n        }));\n  \n      // Call the action callback with all checked items\n      const checkboxConfig = this.config.colConfig.find(col => col.type === 'actions' && col.actionType === 'checkbox');\n      if (checkboxConfig?.action) {\n        checkboxConfig.action(checkedItems);\n      }\n    }\n  }\n\n  isRowDisabled(row: any): boolean {\n    return typeof this.config.rowConfig.disableRow === \"function\" ? this.config.rowConfig.disableRow(row) : false;\n  }\n\n  toggleCheckbox() {\n    this.selectAllCheckbox = !this.selectAllCheckbox;\n\n    // Find the checkbox column index (if any)\n    const checkboxColIndex = this.config.colHeaderConfig.findIndex(col => col.type === \"checkbox\");\n\n    // Only update if checkbox column exists\n    if (checkboxColIndex !== -1) {\n      this.tableData = this.tableData.map((row: any[]) => {\n        const updatedRow = [...row];\n        updatedRow[checkboxColIndex] = this.selectAllCheckbox;\n        return updatedRow;\n      });\n    }\n    \n    // Call the header action callback with updated state\n    const checkboxHeader = this.config.colHeaderConfig[checkboxColIndex];\n    if (checkboxHeader?.action) {\n      checkboxHeader.action({\n        type: \"checkbox\",\n        isChecked: this.selectAllCheckbox,\n        tableData: this.tableData\n      });\n    }\n    \n    this.headerAction?.emit({\n      type: \"checkboxToggle\",\n      payload: this.tableData\n    });\n  }\n}\n\nexport interface TableConfig {\n  height: string | \"100%\";\n  width: string | \"100%\";\n  paginationConfig?: PaginationConfig | undefined | null;\n  colHeadersRowConfig: RowConfig | undefined | null;\n  rowConfig: RowConfig | undefined | null;\n  colHeaderConfig: Array<ColHeaderConfig>;\n  colConfig: Array<ColConfig>;\n  canExpand?: boolean;\n  canScrollHorizontally?: boolean;\n  cellHover?: boolean;\n  activeRowIndex?: number;\n  multiColumnSort?: boolean;\n}\nexport interface PaginationConfig {\n  noOfPages: number;\n  rowsPerPage: number;\n  totalNoOfRows: number;\n  selectedPage?: number;\n  disablePageJumping?: boolean;\n}\nexport interface RowConfig {\n  height?: string | undefined | null;\n  style?: {};\n  action?: any;\n  disableRow?: (data: any) => boolean;\n}\nexport interface ColHeaderConfig {\n  type: \"text\" | \"number\" | \"custom\" | \"checkbox\";\n  data: any;\n  componentRef?: any;\n  filters?: Array<Filter> | null;\n  style?: {};\n  action?: any;\n  isSortable?: boolean;\n  sortAscIcon?: string;\n  sortDescIcon?: string;\n}\nexport interface ColConfig {\n  type: \"text\" | \"number\" | \"custom\" | \"actions\";\n  componentRef?: any;\n  style?: {};\n  action?: any;\n  actionItems?: ActionItem[];\n  actionType?: \"inline\" | \"dropdown\" | \"checkbox\"; // inline for individual icons, dropdown for menu,\n  menuAlign?: \"left\" | \"right\";\n}\nexport interface ActionItem {\n  label: string;\n  value: string;\n  icon?: string;\n  disable?: (data: any) => boolean;\n  action?: (data: any) => void;\n  children?: ActionItem[];\n  submenuAlign?: \"left\" | \"right\";\n}\nexport interface InternalActionItem extends ActionItem {\n  showSubmenu?: boolean;\n}\n","<div\n  [ngStyle]=\"{\n    height: getContainerHeight(),\n    width: getContainerWidth(),\n    'overflow-x': config.canScrollHorizontally ? 'auto' : 'unset'\n  }\"\n  id=\"main-container\"\n>\n  <mis-table-filter\n    #filter\n    (filtersApplied)=\"updateAppliedFilters($event)\"\n    *ngIf=\"showFilter\"\n    [containerStyles]=\"filterContainerStyles\"\n    [filtersData]=\"filterData\"\n  ></mis-table-filter>\n  <div\n    #table\n    id=\"table-container\"\n    [ngClass]=\"{ 'no-scrollbar': expandedIndex < 0, scrollbar: !(expandedIndex < 0), 'scroll-horizontally': config.canScrollHorizontally }\"\n  >\n    <div\n    [ngStyle]=\"getColHeadersRowStyles()\"\n      id=\"col-headers-container\"\n    >\n      <div\n        #colHeaderRef\n        (click)=\"colHeader?.action ? colHeader?.action(colHeader) : null\"\n        *ngFor=\"let colHeader of config?.colHeaderConfig\"\n        class=\"col-header\"\n        [ngStyle]=\"{\n          width: colHeader?.style?.width || '',\n          cursor: colHeader.action ? 'pointer' : 'default',\n          'justify-content': colHeader?.style?.justifyContent\n            ? colHeader?.style?.justifyContent\n            : colHeader.type === 'number'\n            ? 'flex-end'\n            : 'space-between'\n        }\"\n      >\n        <p *ngIf=\"colHeader?.type !== 'custom' && colHeader?.type !== 'checkbox'\" class=\"col-header-text\">\n          {{ colHeader?.data || \" \" }}\n        </p>\n        <span\n          (click)=\"filterData = colHeader.filters; toggleFilter(colHeader.data); $event.stopPropagation()\"\n          *ngIf=\"colHeader?.type !== 'custom' && colHeader?.filters && colHeader?.filters?.length > 0\"\n          class=\"filter-icon\"\n        >\n          <span *ngIf=\"appliedFilters[colHeader.data]?.length > 0\" id=\"filter-active\"></span>\n          <svg fill=\"none\" height=\"10\" viewBox=\"0 0 13 10\" width=\"13\" xmlns=\"http://www.w3.org/2000/svg\">\n            <path\n              clip-rule=\"evenodd\"\n              d=\"M4.97546 10H7.64213V8H4.97546V10ZM0.308472 0V2H12.3085V0H0.308472ZM2.30847 6H10.3085V4H2.30847V6Z\"\n              fill=\"#181F33\"\n              fill-rule=\"evenodd\"\n            />\n          </svg>\n        </span>\n        <span\n          (click)=\"toggleCheckbox(); $event.stopPropagation()\"\n          *ngIf=\"colHeader?.type === 'checkbox'\"\n          class=\"checkbox-icon\"\n        >\n          <mis-checkbox [checked]=\"selectAllCheckbox\"></mis-checkbox>\n        </span>\n        <span *ngIf=\"colHeader?.isSortable && !colHeader?.filters\" appSortIcons\n          [column]=\"colHeader\"\n          [activeSort]=\"currentSort\"\n          [activeSorts]=\"multiColumnSort\"\n          [multiColumnSort]=\"config.multiColumnSort\"\n          (sortChange)=\"onSortChange($event)\"\n          class=\"sort-icon\">\n        </span>\n      <ng-template *ngIf=\"colHeader?.type === 'custom'\" customTableCell [customComponent]=\"colHeader?.componentRef\" [data]=\"colHeader.data\"></ng-template>\n      </div>\n    </div>\n    <div id=\"data-container\">\n      <div class=\"row-wrapper\" *ngFor=\"let row of tableData; let i = index; let rowIndex = index\">\n        <div\n          class=\"t-row\"\n          [ngClass]=\"{ 't-row-hover': config.cellHover, 'active-row': activeRowIndex.includes(i) }\"\n          [ngStyle]=\"{ 'min-height': config?.rowConfig?.height ? config.rowConfig.height : '44px' }\"\n          (click)=\"selectRow(i)\"\n          [class.disabled-row]=\"isRowDisabled(row)\"\n          >\n          <div\n            (click)=\"config?.colConfig[i]?.action && config?.colConfig[i]?.actionType !== 'checkbox' ? config?.colConfig[i]?.action(col) : null\"\n            *ngFor=\"let col of row; let i = index\"\n            [ngStyle]=\"{\n              width: config?.colConfig[i]?.style?.width || config?.colHeaderConfig[i]?.style?.width || ''\n            }\"\n            class=\"t-col-container\"\n            [ngClass]=\"{ 't-col-container-hover': config.cellHover }\"\n          >\n            <div\n              class=\"t-col\"\n              [style]=\"config.colConfig[i]?.style\"\n              [ngStyle]=\"{\n                width: '100%',\n                cursor: config.colConfig[i]?.action ? 'pointer' : 'default',\n                'justify-content': config.colConfig[i]?.style?.justifyContent\n                  ? config.colConfig[i]?.style?.justifyContent\n                  : config.colConfig[i]?.type === 'number'\n                  ? 'flex-end'\n                  : 'space-between'\n              }\"\n            >\n              <p\n                *ngIf=\"config.colConfig[i]?.type !== 'custom' && config.colConfig[i]?.type !== 'actions'\"\n                [ngStyle]=\"{\n                  color: config?.colConfig[i]?.style?.color ? config?.colConfig[i]?.style?.color : ''\n                }\"\n                [ngClass]=\"{'text-ellipsis': !!config?.colConfig[i]?.style?.textEllipsis}\"\n                class=\"t-col-text\"\n              >\n                {{ col }}\n              </p>\n              <ng-template\n                *ngIf=\"config.colConfig[i]?.type === 'custom'\"\n                [customComponent]=\"config.colConfig[i].componentRef\"\n                [data]=\"col\"\n                customTableCell\n              ></ng-template>\n                <mis-actions-cell\n                  *ngIf=\"config.colConfig[i]?.type === 'actions'\"\n                  [rowData]=\"col\"\n                  [config]=\"config.colConfig[i]\"\n                  [isChecked]=\"col.isChecked\"\n                  (actionClick)=\"onActionClick($event, rowIndex)\"\n                  [ngClass]=\"{\n                    'disable-actions': config.colConfig[i]?.actionType === 'checkbox' && isRowDisabled(row)\n                  }\"\n                ></mis-actions-cell>\n\n            </div>\n          </div>\n        </div>\n        <div *ngIf=\"config?.canExpand && expandedIndex === i\" class=\"sub-row\">\n          <ng-container *ngIf=\"subTableDataLoading\">\n            <div [ngStyle]=\"{\n              display: 'flex',\n              justifyContent: 'center',\n              alignItems: 'center',\n              padding: '16px'\n            }\">\n              Loading...\n            </div>\n          </ng-container>\n          \n          <ng-container *ngIf=\"!subTableDataLoading && subTableData.length === 0\">\n            <div [ngStyle]=\"{\n              display: 'flex',\n              justifyContent: 'center',\n              alignItems: 'center',\n              padding: '16px'\n            }\">\n              No Data Available...\n            </div>\n          </ng-container>\n          \n          <ng-container *ngIf=\"!subTableDataLoading && subTableData.length > 0\">\n            <sub-table [config]=\"subTableconfig\" [tableData]=\"subTableData\"></sub-table>\n          </ng-container>\n        </div>\n      </div>\n    </div>\n  </div>\n  <div\n    *ngIf=\"config?.paginationConfig && (tableLength >= config.paginationConfig.rowsPerPage || config.paginationConfig?.selectedPage !== 1)\"\n    id=\"pagination-container\"\n  >\n    <p id=\"pagination-text\">\n      Showing\n      {{ (config.paginationConfig?.selectedPage - 1) * config.paginationConfig.rowsPerPage + 1 }}-{{\n        (config.paginationConfig?.selectedPage - 1) * config.paginationConfig.rowsPerPage + tableLength\n      }}\n      of {{ config.paginationConfig.totalNoOfRows }} items\n    </p>\n    <div id=\"pages-container\">\n      <span   (click)=\"config.paginationConfig?.selectedPage > 1 && updateSelectedPage(config.paginationConfig?.selectedPage - 1)\" class=\"page\" [class.page-nav-inactive]=\"config.paginationConfig?.selectedPage === 1\">\n        <svg fill=\"none\" height=\"10\" viewBox=\"0 0 7 10\" width=\"7\" xmlns=\"http://www.w3.org/2000/svg\">\n          <path\n            clip-rule=\"evenodd\"\n            d=\"M0.857405 5.56295C0.855794 5.56139 0.854188 5.55982 0.852588 5.55824C0.695955 5.40408 0.617641 5.20203 0.617647 4.99998C0.617641 4.79793 0.695955 4.59588 0.852588 4.44172C0.854188 4.44014 0.855794 4.43858 0.857404 4.43702L5.13066 0.231231C5.44392 -0.0770771 5.9518 -0.0770771 6.26506 0.231231C6.57831 0.53954 6.57831 1.03941 6.26506 1.34772L2.5542 4.99998L6.26506 8.65225C6.57831 8.96055 6.57831 9.46042 6.26506 9.76873C5.9518 10.077 5.44392 10.077 5.13066 9.76873L0.857405 5.56295Z\"\n            fill=\"#181F33\"\n            fill-rule=\"evenodd\"\n          />\n        </svg>\n      </span>\n        <!-- Page numbers (only show if disablePageJumping is false) -->\n        <ng-container *ngIf=\"!config.paginationConfig?.disablePageJumping\">\n          <div *ngFor=\"let pageNumber of pages\">\n            <span\n              (click)=\"updateSelectedPage(pageNumber)\"\n              *ngIf=\"pageNumber != 0\"\n              [ngClass]=\"{ 'page-active': pageNumber == config.paginationConfig?.selectedPage }\"\n              class=\"page page-jumping-enabled\"\n            >{{ pageNumber }}</span>\n            <span *ngIf=\"pageNumber == 0\" class=\"page-seperator\">\n              <div [ngStyle]=\"{ display: 'flex' }\">\n                <span class=\"dot\" [ngStyle]=\"{ 'margin-right': '4px' }\"></span>\n                <span class=\"dot\" [ngStyle]=\"{ 'margin-right': '4px' }\"></span>\n                <span class=\"dot\"></span>\n              </div>          \n            </span>\n          </div>\n        </ng-container>\n    \n      <span [class.page-nav-inactive]=\"config.paginationConfig?.selectedPage === config.paginationConfig?.noOfPages\"\n      (click)=\"config.paginationConfig?.selectedPage < config.paginationConfig?.noOfPages && updateSelectedPage(config.paginationConfig?.selectedPage + 1)\" class=\"page\">\n        <svg fill=\"none\" height=\"10\" viewBox=\"0 0 7 10\" width=\"7\" xmlns=\"http://www.w3.org/2000/svg\">\n          <path\n            clip-rule=\"evenodd\"\n            d=\"M6.1426 5.56295C6.14421 5.56139 6.14581 5.55982 6.14741 5.55824C6.30405 5.40408 6.38236 5.20203 6.38236 4.99998C6.38236 4.79793 6.30405 4.59588 6.14741 4.44172C6.14581 4.44014 6.14421 4.43858 6.1426 4.43702L1.86934 0.231231C1.55608 -0.0770771 1.0482 -0.0770771 0.734942 0.231231C0.421688 0.53954 0.421688 1.03941 0.734942 1.34772L4.4458 4.99998L0.734941 8.65225C0.421686 8.96055 0.421686 9.46042 0.734941 9.76873C1.0482 10.077 1.55608 10.077 1.86934 9.76873L6.1426 5.56295Z\"\n            fill=\"#181F33\"\n            fill-rule=\"evenodd\"\n          />\n        </svg>\n      </span>\n    </div>\n  </div>\n</div>\n"]}
|
|
646
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table.component.js","sourceRoot":"","sources":["../../../../projects/mis-components/table/table.component.ts","../../../../projects/mis-components/table/table.component.html"],"names":[],"mappings":"AAAA,OAAO,EAEL,SAAS,EAET,YAAY,EACZ,KAAK,EAGL,MAAM,EAGN,SAAS,EACT,YAAY,EACb,MAAM,eAAe,CAAC;;;;;;;;;;;;;;;;;;;;;;ICLrB,+CAMC;IAJC,yNAAkB,mCAA4B,KAAC;IAIhD,iBAAmB;;;IADlB,AADA,8DAAyC,kCACf;;;IA0BtB,6BAAkG;IAChG,YACF;IAAA,iBAAI;;;IADF,cACF;IADE,yFACF;;;IAME,2BAAmF;;;;IALrF,gCAIC;IAHC,4PAAyC,sCAA4B,wBAAE,wBAAwB,KAAC;IAIhG,+EAA4E;;IAC5E,+BAA+F;IAC7F,2BAKE;IAEN,AADE,iBAAM,EACD;;;;IATE,cAAgD;IAAhD,sIAAgD;;;;IAUzD,gCAIC;IAHC,gKAAS,uBAAgB,wBAAE,wBAAwB,KAAC;IAIpD,mCAA2D;IAC7D,iBAAO;;;IADS,cAA6B;IAA7B,kDAA6B;;;;IAE7C,gCAMoB;IADlB,gMAAc,2BAAoB,KAAC;IAErC,iBAAO;;;;IAHL,AADA,AADA,AADA,qCAAoB,kCACM,uCACK,kDACW;;;;IAI9C,wFAAsI;;;IAAxB,AAA5C,yFAA2C,2BAAwB;;;;IAhDrI,kCAcC;IAZC,2RAA4D,IAAI,KAAC;IA8CnE,AARE,AAPA,AAfA,AAHA,kEAAkG,2DAOjG,2DAeA,2DASmB,oDAEgH;IACtI,iBAAM;;;IA5CJ,kdAQE;IAEE,eAAoE;IAApE,yJAAoE;IAKrE,cAA0F;IAA1F,sPAA0F;IAe1F,cAAoC;IAApC,uFAAoC;IAKhC,cAAkD;IAAlD,uIAAkD;IAQ7C,cAAkC;IAAlC,qFAAkC;;;IAkCxC,6BAOC;IACC,YACF;IAAA,iBAAI;;;;;;IAJF,AAHA,+ZAEE,oOACwE;IAG1E,cACF;IADE,wCACF;;;;IACA,8FAKC;;;;;;IAFC,AADA,6EAAoD,iBACxC;;;;IAGZ,4CASC;IAJC,gRAAe,0CAA+B,KAAC;IAIhD,iBAAmB;;;;;;;IAHlB,AAFA,AADA,AADA,iCAAe,0CACe,gCACH,qLAIzB;;;;IA9CV,+BAQC;IAPC,wfAA8E,UAAU,mIAAuC,IAAI,KAAC;IAQpI,+BAYC;IAiBG,AANF,AAVA,wEAOC,0DAQA,yFAUE;IAGP,AADE,iBAAM,EACF;;;;IA3CJ,AAJA,obAEE,iEAEuD;IAIvD,cAAoC;IAApC,mGAAoC;IACpC,omBAQE;IAGC,cAAuF;IAAvF,gOAAuF;IAUvF,cAA4C;IAA5C,yHAA4C;IAM1C,cAA6C;IAA7C,0HAA6C;;;IActD,6BAA0C;IACxC,+BAKG;IACD,4BACF;IAAA,iBAAM;;;IAPD,cAKH;IALG,qDAKH;;;IAKJ,6BAAwE;IACtE,+BAKG;IACD,sCACF;IAAA,iBAAM;;;IAPD,cAKH;IALG,qDAKH;;;IAKJ,6BAAsE;IACpE,gCAA4E;;;;IAAjE,cAAyB;IAAC,AAA1B,8CAAyB,kCAA2B;;;IAxBnE,+BAAsE;IAuBpE,AAXA,AAXA,8FAA0C,iFAW8B,iFAWF;IAGxE,iBAAM;;;IAzBW,cAAyB;IAAzB,iDAAyB;IAWzB,cAAuD;IAAvD,sFAAuD;IAWvD,cAAqD;IAArD,oFAAqD;;;;IAlFtE,AADF,+BAA4F,cAOvF;IAFD,0LAAS,sBAAY,KAAC;IAGtB,uEAQC;IA2CH,iBAAM;IACN,sEAAsE;IA2BxE,iBAAM;;;;;IAjFF,cAAyC;IAAzC,6DAAyC;IAFzC,AADA,mHAAyF,2LACC;IAMxE,cAAQ;IAAR,iCAAQ;IAkDtB,cAA8C;IAA9C,gHAA8C;;;;IAuDhD,gCAKC;IAJC,2PAAS,yCAA8B,KAAC;IAIzC,YAAgB;IAAA,iBAAO;;;;IAFtB,sKAAkF;IAEnF,cAAgB;IAAhB,oCAAgB;;;IAEf,AADF,gCAAqD,cACd;IAGnC,AADA,AADA,2BAA+D,eACA,eACtC;IAE7B,AADE,iBAAM,EACD;;IALA,cAA+B;IAA/B,qDAA+B;IAChB,cAAqC;IAArC,qDAAqC;IACrC,cAAqC;IAArC,qDAAqC;;;IAV7D,2BAAsC;IAOpC,AANA,6FAKC,gFACoD;IAOvD,iBAAM;;;IAXD,cAAqB;IAArB,0CAAqB;IAIjB,cAAqB;IAArB,0CAAqB;;;IARhC,6BAAmE;IACjE,qFAAsC;;;;IAAV,cAAQ;IAAR,sCAAQ;;;;IApB1C,AAJF,+BAGC,YACyB;IACtB,YAKF;IAAA,iBAAI;IAEF,AADF,+BAA0B,eAC0L;IAA1M,yQAAiD,CAAC,IAAI,0HAA2D,CAAC,CAAC,KAAC;;IAC1H,+BAA6F;IAC3F,2BAKE;IAEN,AADE,iBAAM,EACD;IAEL,wFAAmE;;IAkBrE,gCACmK;IAAnK,uWAAuF,0HAA2D,CAAC,CAAC,KAAC;;IACnJ,+BAA6F;IAC3F,4BAKE;IAIV,AADE,AADE,AADE,iBAAM,EACD,EACH,EACF;;;IAhDF,eAKF;IALE,qaAKF;IAE4I,eAAuE;IAAvE,wIAAuE;IAWhM,eAAkD;IAAlD,2HAAkD;IAkB7D,cAAwG;IAAxG,iOAAwG;;ADzLpH,MAAM,OAAO,cAAc;IAuCzB,YAAoB,QAAmB;QAAnB,aAAQ,GAAR,QAAQ,CAAW;QAtCvC,oEAAoE;QACpE,mBAAc,GAAa,CAAC,CAAC,CAAC,CAAC,CAAC;QAChC,uBAAkB,GAAY,KAAK,CAAC;QACpC,sBAAiB,GAAY,KAAK,CAAC;QAEnC,2BAA2B;QAC3B,eAAU,GAAY,KAAK,CAAC;QAC5B,eAAU,GAAW,EAAE,CAAC;QACxB,eAAU,GAAkB,EAAE,CAAC;QAC/B,0BAAqB,GAAQ,EAAE,CAAC;QAChC,mBAAc,GAA8D,EAAE,CAAC;QACrE,mBAAc,GAAG,IAAI,YAAY,EAEvC,CAAC;QAKL,+BAA+B;QAC/B,UAAK,GAAkB,EAAE,CAAC;QAEhB,iBAAY,GAAG,IAAI,YAAY,EAAU,CAAC;QAM3C,cAAS,GAAsB,EAAE,CAAC;QAClC,iBAAY,GAAsB,EAAE,CAAC;QAI9C,6BAA6B;QAC7B,gBAAW,GAAqB,IAAI,CAAC;QACrC,oBAAe,GAAgB,EAAE,CAAC;QACxB,eAAU,GAAG,IAAI,YAAY,EAAa,CAAC;QAC3C,iBAAY,GAAI,IAAI,YAAY,EAAmC,CAAC;IAEpC,CAAC;IAE3C,+BAA+B;IAC/B,SAAS,CAAC,KAAa;QACrB,IAAI,IAAI,CAAC,kBAAkB;YAAE,OAAO;QACpC,IAAI,CAAC,cAAc,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,oDAAoD;QACnF,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,MAAM,IAAI,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;IACxE,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC,MAAM,CAAC,SAAS,EAAE,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,IAAI,KAAK,SAAS,IAAI,GAAG,CAAC,UAAU,KAAK,UAAU,CAAC,CAAC;QACtH,IAAI,CAAC,WAAW,GAAG,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;QAChE,IAAI,CAAC,iBAAiB,EAAE,CAAC;QACzB,IAAI,IAAI,CAAC,MAAM,CAAC,gBAAgB,EAAE,CAAC;YACjC,IAAI,CAAC,oBAAoB,EAAE,CAAC;QAC9B,CAAC;QACD,IAAI,IAAI,CAAC,MAAM,CAAC,qBAAqB,KAAK,SAAS,EAAE,CAAC;YACpD,IAAI,CAAC,MAAM,CAAC,qBAAqB,GAAG,KAAK,CAAC;QAC5C,CAAC;QACD,QAAQ,CAAC,gBAAgB,CAAC,OAAO,EAAE,KAAK,CAAC,EAAE;YACzC,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC;gBAChB,IAAI,iBAAiB,GAAG,IAAI,CAAC;gBAC7B,IAAI,aAAa,GAAG,KAAK,CAAC,MAAyB,CAAC;gBACpD,IAAI,aAAa,CAAC,SAAS,KAAK,WAAW,EAAE,CAAC;oBAC5C,iBAAiB,GAAG,IAAI,CAAC;oBACzB,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;gBACzB,CAAC;gBACD,IAAI,oBAAoB,GAAG,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,aAAa,CAAC,QAAQ,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;gBACtF,IAAI,CAAC,oBAAoB,IAAI,CAAC,iBAAiB,EAAE,CAAC;oBAChD,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;gBACrC,CAAC;YACH,CAAC;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IACD,eAAe;QACb,IAAI,IAAI,CAAC,MAAM,CAAC,gBAAgB,EAAE,CAAC;YACjC,IAAI,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC;YAChC,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE,QAAQ,EAAE,MAAM,GAAG,EAAE,GAAG,IAAI,CAAC,CAAC;QACjF,CAAC;IACH,CAAC;IACD,WAAW;QACT,IAAI,CAAC,WAAW,GAAG,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;QAChE,IAAI,CAAC,cAAc,GAAG,CAAC,IAAI,CAAC,MAAM,CAAC,cAAc,IAAI,CAAC,CAAC,CAAC,CAAC;IAC3D,CAAC;IAED,2BAA2B;IAC3B,iBAAiB;QACf,KAAK,IAAI,SAAS,IAAI,IAAI,CAAC,MAAM,EAAE,eAAe,EAAE,CAAC;YACnD,IAAI,SAAS,CAAC,OAAO,EAAE,CAAC;gBACtB,IAAI,OAAO,GAAG,EAAE,CAAC;gBACjB,KAAK,IAAI,MAAM,IAAI,SAAS,CAAC,OAAO,EAAE,CAAC;oBACrC,IAAI,MAAM,CAAC,OAAO,EAAE,CAAC;wBACnB,OAAO,CAAC,IAAI,CAAC;4BACX,IAAI,EAAE,MAAM,CAAC,IAAI;4BACjB,KAAK,EAAE,MAAM,CAAC,KAAK;yBACpB,CAAC,CAAC;oBACL,CAAC;gBACH,CAAC;gBACD,IAAI,OAAO,CAAC,MAAM,GAAG,CAAC;oBAAE,IAAI,CAAC,cAAc,CAAC,SAAS,CAAC,IAAI,CAAC,GAAG,OAAO,CAAC;YACxE,CAAC;QACH,CAAC;IACH,CAAC;IACD,YAAY,CAAC,UAAkB;QAC7B,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE,CAAC;YACrB,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC;YAC7B,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;YAEvB,IAAI,MAAM,GAAG,CAAC,CAAC;YACf,IAAI,kBAAkB,GAAG,IAAI,CAAC,UAAU,CAAC,OAAO,EAAE,CAAC,OAAO,EAAE,CAAC;YAE7D,KAAK,IAAI,MAAM,IAAI,kBAAkB,EAAE,CAAC;gBACtC,IAAI,MAAM,CAAC,aAAa,CAAC,SAAS,KAAK,UAAU;oBAAE,MAAM;gBACzD,MAAM,IAAI,MAAM,CAAC,aAAa,CAAC,WAAW,CAAC;YAC7C,CAAC;YACD,IAAI,CAAC,qBAAqB,GAAG;gBAC3B,GAAG,EAAE,MAAM;gBACX,KAAK,EAAE,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,MAAM,GAAG,GAAG,GAAG,IAAI,CAAC,CAAC,CAAC,MAAM;aACjD,CAAC;QACJ,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,UAAU,GAAG,EAAE,CAAC;YACrB,IAAI,CAAC,UAAU,GAAG,EAAE,CAAC;YACrB,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;QAC1B,CAAC;IACH,CAAC;IACD,oBAAoB,CAAC,cAAsD;QACzE,IAAI,cAAc,CAAC,MAAM,IAAI,CAAC,EAAE,CAAC;YAC/B,OAAO,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QAC9C,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,UAAU,CAAC,GAAG,cAAc,CAAC;QACxD,CAAC;QACD,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,EAAE,GAAG,IAAI,CAAC,cAAc,EAAE,CAAC,CAAC;QACrD,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;IACrC,CAAC;IAED,+BAA+B;IAC/B,oBAAoB;QAClB,IAAI,IAAI,CAAC,MAAM,CAAC,gBAAgB,EAAE,CAAC;YACjC,IAAI,GAAG,GAAG,IAAI,CAAC,MAAM,CAAC,gBAAgB,CAAC,SAAS,CAAC;YACjD,IAAI,GAAG,IAAI,CAAC,EAAE,CAAC;gBACb,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,IAAI,GAAG,EAAE,CAAC,EAAE,EAAE,CAAC;oBAC9B,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;gBACrB,CAAC;YACH,CAAC;iBAAM,CAAC;gBACN,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,GAAG,CAAC,CAAC;YACpC,CAAC;QACH,CAAC;IACH,CAAC;IACD,kBAAkB,CAAC,UAAkB;QACnC,+CAA+C;QAC/C,IAAI,UAAU,GAAG,CAAC,IAAI,UAAU,GAAG,IAAI,CAAC,MAAM,CAAC,gBAAgB,CAAC,SAAS;YAAE,OAAO;QAElF,IAAI,IAAI,CAAC,MAAM,CAAC,eAAe,EAAE,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,IAAI,KAAK,UAAU,CAAC,EAAE,CAAC;YACtE,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAC;QACjC,CAAC;QACD,IAAI,UAAU,GAAG,CAAC,IAAI,UAAU,GAAG,IAAI,CAAC,MAAM,CAAC,gBAAgB,CAAC,SAAS;YAAE,OAAO;QAClF,IAAI,CAAC,MAAM,CAAC,gBAAgB,CAAC,YAAY,GAAG,UAAU,CAAC;QACvD,IAAI,GAAG,GAAG,IAAI,CAAC,MAAM,CAAC,gBAAgB,CAAC,SAAS,CAAC;QACjD,IAAI,GAAG,GAAG,CAAC,EAAE,CAAC;YACZ,IAAI,UAAU,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC;gBACxB,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,GAAG,CAAC,CAAC;YACpC,CAAC;iBAAM,IAAI,UAAU,GAAG,CAAC,GAAG,CAAC,IAAI,UAAU,GAAG,CAAC,GAAG,GAAG,EAAE,CAAC;gBACtD,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,UAAU,GAAG,CAAC,EAAE,UAAU,EAAE,UAAU,GAAG,CAAC,EAAE,CAAC,EAAE,GAAG,CAAC,CAAC;YAC1E,CAAC;iBAAM,IAAI,UAAU,GAAG,CAAC,IAAI,GAAG,EAAE,CAAC;gBACjC,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,GAAG,GAAG,CAAC,EAAE,GAAG,GAAG,CAAC,EAAE,GAAG,GAAG,CAAC,EAAE,GAAG,CAAC,CAAC;YACtD,CAAC;QACH,CAAC;QACD,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,gBAAgB,EAAE,YAAY,CAAC,CAAC;IACrE,CAAC;IAED,mCAAmC;IACnC,kBAAkB;QAChB,IAAI,IAAI,CAAC,MAAM,EAAE,MAAM;YAAE,OAAO,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC;;YAC9C,OAAO,EAAE,CAAC;IACjB,CAAC;IACD,iBAAiB;QACf,IAAI,IAAI,CAAC,MAAM,EAAE,KAAK;YAAE,OAAO,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC;;YAC5C,OAAO,EAAE,CAAC;IACjB,CAAC;IAED,mCAAmC;IACnC,sBAAsB;QACpB,MAAM,EAAE,mBAAmB,EAAE,GAAG,IAAI,CAAC,MAAM,CAAC;QAC5C,MAAM,SAAS,GAAG,mBAAmB,EAAE,MAAM,IAAI,MAAM,CAAC;QACxD,MAAM,SAAS,GAAG,mBAAmB,EAAE,KAAK,EAAE,SAAS,IAAI,EAAE,CAAC;QAC9D,MAAM,YAAY,GAAG,mBAAmB,EAAE,KAAK,EAAE,YAAY,IAAI,mBAAmB,CAAC;QACrF,MAAM,eAAe,GAAG,mBAAmB,EAAE,KAAK,EAAE,eAAe,IAAI,SAAS,CAAC;QACjF,MAAM,QAAQ,GAAG,mBAAmB,EAAE,KAAK,EAAE,QAAQ,IAAI,MAAM,CAAC;QAChE,OAAO;YACL,YAAY,EAAE,SAAS;YACvB,YAAY,EAAE,SAAS;YACvB,eAAe,EAAE,YAAY;YAC7B,kBAAkB,EAAE,eAAe;YACnC,WAAW,EAAE,QAAQ;SACtB,CAAC;IACJ,CAAC;IAED,YAAY,CAAC,SAAoB;QAC/B,IAAI,CAAC,WAAW,GAAG,SAAS,CAAC;QAC7B,IAAI,IAAI,CAAC,MAAM,CAAC,eAAe,EAAE,CAAC;YAChC,MAAM,KAAK,GAAG,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,MAAM,KAAK,SAAS,CAAC,MAAM,CAAC,CAAC;YACvF,IAAI,KAAK,KAAK,CAAC,CAAC,EAAE,CAAC;gBACjB,IAAI,SAAS,CAAC,SAAS,KAAK,IAAI,EAAE,CAAC;oBACjC,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC;gBACxC,CAAC;qBAAM,CAAC;oBACN,IAAI,CAAC,eAAe,CAAC,KAAK,CAAC,GAAG,SAAS,CAAC;gBAC1C,CAAC;YACH,CAAC;iBAAM,IAAI,SAAS,CAAC,SAAS,KAAK,IAAI,EAAE,CAAC;gBACxC,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;YACvC,CAAC;QACH,CAAC;QACD,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;IAClC,CAAC;IAED,mBAAmB,CAAC,KAAU;QAC5B,IAAI,CAAC,KAAK;YAAE,OAAO,EAAE,CAAC;QACtB,MAAM,EAAE,KAAK,EAAE,GAAG,SAAS,EAAE,GAAG,KAAK,CAAC;QACtC,OAAO,SAAS,CAAC;IACnB,CAAC;IAED,aAAa,CAAC,KAAU,EAAE,QAAgB;QACxC,IAAI,KAAK,CAAC,SAAS,KAAK,SAAS,EAAE,CAAC;YAClC,0BAA0B;YAC1B,IAAI,KAAK,CAAC,SAAS,EAAE,CAAC;gBACpB,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;YACrC,CAAC;iBAAM,CAAC;gBACN,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE,CAAC,KAAK,KAAK,QAAQ,CAAC,CAAC;YAChF,CAAC;YAED,oDAAoD;YACpD,MAAM,cAAc,GAAG,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,IAAI,KAAK,SAAS,IAAI,GAAG,CAAC,UAAU,KAAK,UAAU,CAAC,CAAC;YACvH,IAAI,cAAc,KAAK,CAAC,CAAC,IAAI,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,EAAE,CAAC;gBACtD,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC,cAAc,CAAC,GAAG;oBACzC,GAAG,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC,cAAc,CAAC;oBAC3C,SAAS,EAAE,KAAK,CAAC,SAAS;iBAC3B,CAAC;YACJ,CAAC;YAED,4BAA4B;YAC5B,MAAM,YAAY,GAAG,IAAI,CAAC,SAAS;iBAChC,GAAG,CAAC,CAAC,GAAG,EAAE,KAAK,EAAE,EAAE,CAAC,CAAC,EAAE,GAAG,EAAE,KAAK,EAAE,CAAC,CAAC;iBACrC,MAAM,CAAC,CAAC,EAAE,GAAG,EAAE,EAAE,EAAE;gBAClB,MAAM,SAAS,GAAG,GAAG,CAAC,cAAc,CAAC,CAAC;gBACtC,OAAO,SAAS,EAAE,SAAS,KAAK,IAAI,CAAC;YACvC,CAAC,CAAC;iBACD,GAAG,CAAC,CAAC,EAAE,GAAG,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC,CAAC;gBACxB,OAAO,EAAE,GAAG,CAAC,cAAc,CAAC,CAAC,OAAO;gBACpC,QAAQ,EAAE,KAAK;gBACf,SAAS,EAAE,IAAI;aAChB,CAAC,CAAC,CAAC;YAEN,kDAAkD;YAClD,MAAM,cAAc,GAAG,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,IAAI,KAAK,SAAS,IAAI,GAAG,CAAC,UAAU,KAAK,UAAU,CAAC,CAAC;YAClH,IAAI,cAAc,EAAE,MAAM,EAAE,CAAC;gBAC3B,cAAc,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC;YACtC,CAAC;QACH,CAAC;IACH,CAAC;IAED,aAAa,CAAC,GAAQ;QACpB,OAAO,OAAO,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,UAAU,KAAK,UAAU,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC;IAChH,CAAC;IAED,cAAc;QACZ,IAAI,CAAC,iBAAiB,GAAG,CAAC,IAAI,CAAC,iBAAiB,CAAC;QAEjD,0CAA0C;QAC1C,MAAM,gBAAgB,GAAG,IAAI,CAAC,MAAM,CAAC,eAAe,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,IAAI,KAAK,UAAU,CAAC,CAAC;QAE/F,wCAAwC;QACxC,IAAI,gBAAgB,KAAK,CAAC,CAAC,EAAE,CAAC;YAC5B,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,GAAU,EAAE,EAAE;gBACjD,MAAM,UAAU,GAAG,CAAC,GAAG,GAAG,CAAC,CAAC;gBAC5B,UAAU,CAAC,gBAAgB,CAAC,GAAG,IAAI,CAAC,iBAAiB,CAAC;gBACtD,OAAO,UAAU,CAAC;YACpB,CAAC,CAAC,CAAC;QACL,CAAC;QAED,qDAAqD;QACrD,MAAM,cAAc,GAAG,IAAI,CAAC,MAAM,CAAC,eAAe,CAAC,gBAAgB,CAAC,CAAC;QACrE,IAAI,cAAc,EAAE,MAAM,EAAE,CAAC;YAC3B,cAAc,CAAC,MAAM,CAAC;gBACpB,IAAI,EAAE,UAAU;gBAChB,SAAS,EAAE,IAAI,CAAC,iBAAiB;gBACjC,SAAS,EAAE,IAAI,CAAC,SAAS;aAC1B,CAAC,CAAC;QACL,CAAC;QAED,IAAI,CAAC,YAAY,EAAE,IAAI,CAAC;YACtB,IAAI,EAAE,gBAAgB;YACtB,OAAO,EAAE,IAAI,CAAC,SAAS;SACxB,CAAC,CAAC;IACL,CAAC;+GAlSU,cAAc;oEAAd,cAAc;;;;;;;;;;YCtB3B,8BAOC;YACC,yFAMC;YAMC,AALF,iCAIC,aAIE;YACC,gEAcC;YAoCH,iBAAM;YACN,8BAAyB;YACvB,gEAA4F;YAyFhG,AADE,iBAAM,EACF;YACN,iEAGC;YAmDH,iBAAM;;YA3NJ,4JAIE;YAMC,cAAgB;YAAhB,qCAAgB;YAOjB,cAAuI;YAAvI,wIAAuI;YAGvI,eAAoC;YAApC,sDAAoC;YAMV,cAA0B;YAA1B,gFAA0B;YAiDT,eAAc;YAAd,uCAAc;YA2FxD,cAAqI;YAArI,iPAAqI;;;iFDjJ7H,cAAc;cAL1B,SAAS;2BACE,WAAW;0CAgBX,cAAc;kBAAvB,MAAM;YAIc,MAAM;kBAA1B,SAAS;mBAAC,QAAQ;YACW,UAAU;kBAAvC,YAAY;mBAAC,cAAc;YAKlB,YAAY;kBAArB,MAAM;YAEe,MAAM;kBAA3B,KAAK;mBAAC,aAAa;YACX,cAAc;kBAAtB,KAAK;YACG,gBAAgB;kBAAxB,KAAK;YACG,aAAa;kBAArB,KAAK;YACG,SAAS;kBAAjB,KAAK;YACG,YAAY;kBAApB,KAAK;YACG,mBAAmB;kBAA3B,KAAK;YACc,KAAK;kBAAxB,SAAS;mBAAC,OAAO;YAKR,UAAU;kBAAnB,MAAM;YACG,YAAY;kBAArB,MAAM;;kFArCI,cAAc","sourcesContent":["import {\n  AfterViewInit,\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnInit,\n  Output,\n  QueryList,\n  Renderer2,\n  ViewChild,\n  ViewChildren\n} from \"@angular/core\";\nimport { Filter, TableFilterComponent } from \"./filter/filter.component\";\nimport { SortState } from \"./sort-icons.directive\";\n\n@Component({\n  selector: \"mis-table\",\n  templateUrl: \"table.component.html\",\n  styleUrls: [\"table.component.css\"]\n})\nexport class TableComponent implements OnInit, AfterViewInit, OnChanges {\n  // Initialize with -1 to indicate no row is colored at the beginning\n  activeRowIndex: number[] = [-1];\n  hasCheckboxActions: boolean = false;\n  selectAllCheckbox: boolean = false;\n\n  // Filter related variables\n  showFilter: boolean = false;\n  filterName: string = \"\";\n  filterData: Array<Filter> = [];\n  filterContainerStyles: any = {};\n  appliedFilters: { [key: string]: Array<{ name: string; value: string }> } = {};\n  @Output() filtersUpdated = new EventEmitter<{\n    [key: string]: Array<{ name: string; value: string }>;\n  }>();\n\n  @ViewChild(\"filter\") filter: TableFilterComponent | any;\n  @ViewChildren(\"colHeaderRef\") colHeaders: QueryList<ElementRef> | any;\n\n  // Pagination related variables\n  pages: Array<number> = [];\n  tableLength: number;\n  @Output() pageSelected = new EventEmitter<number>();\n\n  @Input(\"tableConfig\") config: TableConfig | any;\n  @Input() subTableconfig: TableConfig | any;\n  @Input() tableDataLoading: boolean | any;\n  @Input() expandedIndex: number | any;\n  @Input() tableData: Array<Array<any>> = [];\n  @Input() subTableData: Array<Array<any>> = [];\n  @Input() subTableDataLoading: boolean | any;\n  @ViewChild(\"table\") table: ElementRef | any;\n\n  // Sorting related properties\n  currentSort: SortState | null = null;\n  multiColumnSort: SortState[] = [];\n  @Output() sortChange = new EventEmitter<SortState>();\n  @Output() headerAction? = new EventEmitter<{ type: string; payload?: any }>();\n\n  constructor(private renderer: Renderer2) {}\n\n  // Function to handle row click\n  selectRow(index: number) {\n    if (this.hasCheckboxActions) return;\n    this.activeRowIndex = [index]; // Set the selected index to the clicked row's index\n    !!this.config.rowConfig.action && this.config.rowConfig.action(index);\n  }\n\n  ngOnInit(): void {\n    this.hasCheckboxActions = this.config.colConfig?.some(col => col.type === \"actions\" && col.actionType === \"checkbox\");\n    this.tableLength = !!this.tableData ? this.tableData.length : 0;\n    this.initializeFilters();\n    if (this.config.paginationConfig) {\n      this.initializePagination();\n    }\n    if (this.config.canScrollHorizontally === undefined) {\n      this.config.canScrollHorizontally = false;\n    }\n    document.addEventListener(\"click\", event => {\n      if (this.filter) {\n        let isCheckBoxClicked = true;\n        let targetElement = event.target as HTMLSpanElement;\n        if (targetElement.className === \"checkmark\") {\n          isCheckBoxClicked = true;\n          this.showFilter = true;\n        }\n        let isClickInsideElement = this.filter.container.nativeElement.contains(event.target);\n        if (!isClickInsideElement && !isCheckBoxClicked) {\n          this.toggleFilter(this.filterName);\n        }\n      }\n    });\n  }\n  ngAfterViewInit() {\n    if (this.config.paginationConfig) {\n      let height = this.config.height;\n      this.renderer.setStyle(this.table.nativeElement, \"height\", height - 56 + \"px\");\n    }\n  }\n  ngOnChanges() {\n    this.tableLength = !!this.tableData ? this.tableData.length : 0;\n    this.activeRowIndex = [this.config.activeRowIndex || -1];\n  }\n\n  // Filter related functions\n  initializeFilters() {\n    for (let colHeader of this.config?.colHeaderConfig) {\n      if (colHeader.filters) {\n        let filters = [];\n        for (let filter of colHeader.filters) {\n          if (filter.checked) {\n            filters.push({\n              name: filter.name,\n              value: filter.value\n            });\n          }\n        }\n        if (filters.length > 0) this.appliedFilters[colHeader.data] = filters;\n      }\n    }\n  }\n  toggleFilter(filterName: string) {\n    if (!this.showFilter) {\n      this.filterName = filterName;\n      this.showFilter = true;\n\n      let offSet = 0;\n      let colHeadersReversed = this.colHeaders.toArray().reverse();\n\n      for (let header of colHeadersReversed) {\n        if (header.nativeElement.innerText === filterName) break;\n        offSet += header.nativeElement.offsetWidth;\n      }\n      this.filterContainerStyles = {\n        top: \"44px\",\n        right: offSet > 0 ? offSet - 116 + \"px\" : \"12px\"\n      };\n    } else {\n      this.filterName = \"\";\n      this.filterData = [];\n      this.showFilter = false;\n    }\n  }\n  updateAppliedFilters(appliedFilters: Array<{ name: string; value: string }>) {\n    if (appliedFilters.length == 0) {\n      delete this.appliedFilters[this.filterName];\n    } else {\n      this.appliedFilters[this.filterName] = appliedFilters;\n    }\n    this.filtersUpdated.emit({ ...this.appliedFilters });\n    this.toggleFilter(this.filterName);\n  }\n\n  // Pagination related functions\n  initializePagination() {\n    if (this.config.paginationConfig) {\n      let len = this.config.paginationConfig.noOfPages;\n      if (len <= 7) {\n        for (let i = 1; i <= len; i++) {\n          this.pages.push(i);\n        }\n      } else {\n        this.pages = [1, 2, 3, 4, 0, len];\n      }\n    }\n  }\n  updateSelectedPage(pageNumber: number) {\n    // Guard clause to prevent out-of-range updates\n    if (pageNumber < 1 || pageNumber > this.config.paginationConfig.noOfPages) return;\n\n    if (this.config.colHeaderConfig?.some(col => col.type === \"checkbox\")) {\n      this.selectAllCheckbox = false;\n    }\n    if (pageNumber < 1 || pageNumber > this.config.paginationConfig.noOfPages) return;\n    this.config.paginationConfig.selectedPage = pageNumber;\n    let len = this.config.paginationConfig.noOfPages;\n    if (len > 7) {\n      if (pageNumber - 2 <= 1) {\n        this.pages = [1, 2, 3, 4, 0, len];\n      } else if (pageNumber - 2 > 1 && pageNumber + 2 < len) {\n        this.pages = [1, 0, pageNumber - 1, pageNumber, pageNumber + 1, 0, len];\n      } else if (pageNumber + 2 >= len) {\n        this.pages = [1, 0, len - 3, len - 2, len - 1, len];\n      }\n    }\n    this.pageSelected.emit(this.config.paginationConfig?.selectedPage);\n  }\n\n  // Main container related functions\n  getContainerHeight() {\n    if (this.config?.height) return this.config.height;\n    else return \"\";\n  }\n  getContainerWidth() {\n    if (this.config?.width) return this.config.width;\n    else return \"\";\n  }\n\n  // Column Headers related functions\n  getColHeadersRowStyles() {\n    const { colHeadersRowConfig } = this.config;\n    const minHeight = colHeadersRowConfig?.height || \"44px\";\n    const borderTop = colHeadersRowConfig?.style?.borderTop || \"\";\n    const borderBottom = colHeadersRowConfig?.style?.borderBottom || \"1px solid #E0E0E0\";\n    const backgroundColor = colHeadersRowConfig?.style?.backgroundColor || \"#FFFFFF\";\n    const fontSize = colHeadersRowConfig?.style?.fontSize || \"14px\";\n    return {\n      \"min-height\": minHeight,\n      \"border-top\": borderTop,\n      \"border-bottom\": borderBottom,\n      \"background-color\": backgroundColor,\n      \"font-size\": fontSize\n    };\n  }\n\n  onSortChange(sortState: SortState) {\n    this.currentSort = sortState;\n    if (this.config.multiColumnSort) {\n      const index = this.multiColumnSort.findIndex(sort => sort.column === sortState.column);\n      if (index !== -1) {\n        if (sortState.direction === null) {\n          this.multiColumnSort.splice(index, 1);\n        } else {\n          this.multiColumnSort[index] = sortState;\n        }\n      } else if (sortState.direction !== null) {\n        this.multiColumnSort.push(sortState);\n      }\n    }\n    this.sortChange.emit(sortState);\n  }\n\n  getActionsCellStyle(style: any): any {\n    if (!style) return {};\n    const { width, ...restStyle } = style;\n    return restStyle;\n  }\n\n  onActionClick(event: any, rowIndex: number): void {\n    if (event.isChecked !== undefined) {\n      // Handle checkbox changes\n      if (event.isChecked) {\n        this.activeRowIndex.push(rowIndex);\n      } else {\n        this.activeRowIndex = this.activeRowIndex.filter(index => index !== rowIndex);\n      }\n  \n      // Update the table data with the new checkbox state\n      const actionColIndex = this.config.colConfig.findIndex(col => col.type === 'actions' && col.actionType === 'checkbox');\n      if (actionColIndex !== -1 && this.tableData[rowIndex]) {\n        this.tableData[rowIndex][actionColIndex] = {\n          ...this.tableData[rowIndex][actionColIndex],\n          isChecked: event.isChecked\n        };\n      }\n  \n      // Collect all checked items\n      const checkedItems = this.tableData\n        .map((row, index) => ({ row, index }))\n        .filter(({ row }) => {\n          const actionCol = row[actionColIndex];\n          return actionCol?.isChecked === true;\n        })\n        .map(({ row, index }) => ({\n          rowData: row[actionColIndex].rowData,\n          rowIndex: index,\n          isChecked: true\n        }));\n  \n      // Call the action callback with all checked items\n      const checkboxConfig = this.config.colConfig.find(col => col.type === 'actions' && col.actionType === 'checkbox');\n      if (checkboxConfig?.action) {\n        checkboxConfig.action(checkedItems);\n      }\n    }\n  }\n\n  isRowDisabled(row: any): boolean {\n    return typeof this.config.rowConfig.disableRow === \"function\" ? this.config.rowConfig.disableRow(row) : false;\n  }\n\n  toggleCheckbox() {\n    this.selectAllCheckbox = !this.selectAllCheckbox;\n\n    // Find the checkbox column index (if any)\n    const checkboxColIndex = this.config.colHeaderConfig.findIndex(col => col.type === \"checkbox\");\n\n    // Only update if checkbox column exists\n    if (checkboxColIndex !== -1) {\n      this.tableData = this.tableData.map((row: any[]) => {\n        const updatedRow = [...row];\n        updatedRow[checkboxColIndex] = this.selectAllCheckbox;\n        return updatedRow;\n      });\n    }\n    \n    // Call the header action callback with updated state\n    const checkboxHeader = this.config.colHeaderConfig[checkboxColIndex];\n    if (checkboxHeader?.action) {\n      checkboxHeader.action({\n        type: \"checkbox\",\n        isChecked: this.selectAllCheckbox,\n        tableData: this.tableData\n      });\n    }\n    \n    this.headerAction?.emit({\n      type: \"checkboxToggle\",\n      payload: this.tableData\n    });\n  }\n}\n\nexport interface TableConfig {\n  height: string | \"100%\";\n  width: string | \"100%\";\n  paginationConfig?: PaginationConfig | undefined | null;\n  colHeadersRowConfig: RowConfig | undefined | null;\n  rowConfig: RowConfig | undefined | null;\n  colHeaderConfig: Array<ColHeaderConfig>;\n  colConfig: Array<ColConfig>;\n  canExpand?: boolean;\n  canScrollHorizontally?: boolean;\n  cellHover?: boolean;\n  activeRowIndex?: number;\n  multiColumnSort?: boolean;\n}\nexport interface PaginationConfig {\n  noOfPages: number;\n  rowsPerPage: number;\n  totalNoOfRows: number;\n  selectedPage?: number;\n  disablePageJumping?: boolean;\n}\nexport interface RowConfig {\n  height?: string | undefined | null;\n  style?: {};\n  action?: any;\n  disableRow?: (data: any) => boolean;\n}\nexport interface ColHeaderConfig {\n  type: \"text\" | \"number\" | \"custom\" | \"checkbox\";\n  data: any;\n  componentRef?: any;\n  filters?: Array<Filter> | null;\n  style?: {};\n  action?: any;\n  isSortable?: boolean;\n  sortAscIcon?: string;\n  sortDescIcon?: string;\n}\nexport interface ColConfig {\n  type: \"text\" | \"number\" | \"custom\" | \"actions\";\n  componentRef?: any;\n  style?: {};\n  action?: any;\n  actionItems?: ActionItem[];\n  actionType?: \"inline\" | \"dropdown\" | \"checkbox\"; // inline for individual icons, dropdown for menu\n  menuAlign?: \"left\" | \"right\";\n  disable?: (data: any) => boolean; // Add this line\n}\nexport interface ActionItem {\n  label: string;\n  value: string;\n  icon?: string;\n  disable?: (data: any) => boolean;\n  action?: (data: any) => void;\n  children?: ActionItem[];\n  submenuAlign?: \"left\" | \"right\";\n}\nexport interface InternalActionItem extends ActionItem {\n  showSubmenu?: boolean;\n}\n","<div\n  [ngStyle]=\"{\n    height: getContainerHeight(),\n    width: getContainerWidth(),\n    'overflow-x': config.canScrollHorizontally ? 'auto' : 'unset'\n  }\"\n  id=\"main-container\"\n>\n  <mis-table-filter\n    #filter\n    (filtersApplied)=\"updateAppliedFilters($event)\"\n    *ngIf=\"showFilter\"\n    [containerStyles]=\"filterContainerStyles\"\n    [filtersData]=\"filterData\"\n  ></mis-table-filter>\n  <div\n    #table\n    id=\"table-container\"\n    [ngClass]=\"{ 'no-scrollbar': expandedIndex < 0, scrollbar: !(expandedIndex < 0), 'scroll-horizontally': config.canScrollHorizontally }\"\n  >\n    <div\n    [ngStyle]=\"getColHeadersRowStyles()\"\n      id=\"col-headers-container\"\n    >\n      <div\n        #colHeaderRef\n        (click)=\"colHeader?.action ? colHeader?.action(colHeader) : null\"\n        *ngFor=\"let colHeader of config?.colHeaderConfig\"\n        class=\"col-header\"\n        [ngStyle]=\"{\n          width: colHeader?.style?.width || '',\n          cursor: colHeader.action ? 'pointer' : 'default',\n          'justify-content': colHeader?.style?.justifyContent\n            ? colHeader?.style?.justifyContent\n            : colHeader.type === 'number'\n            ? 'flex-end'\n            : 'space-between'\n        }\"\n      >\n        <p *ngIf=\"colHeader?.type !== 'custom' && colHeader?.type !== 'checkbox'\" class=\"col-header-text\">\n          {{ colHeader?.data || \" \" }}\n        </p>\n        <span\n          (click)=\"filterData = colHeader.filters; toggleFilter(colHeader.data); $event.stopPropagation()\"\n          *ngIf=\"colHeader?.type !== 'custom' && colHeader?.filters && colHeader?.filters?.length > 0\"\n          class=\"filter-icon\"\n        >\n          <span *ngIf=\"appliedFilters[colHeader.data]?.length > 0\" id=\"filter-active\"></span>\n          <svg fill=\"none\" height=\"10\" viewBox=\"0 0 13 10\" width=\"13\" xmlns=\"http://www.w3.org/2000/svg\">\n            <path\n              clip-rule=\"evenodd\"\n              d=\"M4.97546 10H7.64213V8H4.97546V10ZM0.308472 0V2H12.3085V0H0.308472ZM2.30847 6H10.3085V4H2.30847V6Z\"\n              fill=\"#181F33\"\n              fill-rule=\"evenodd\"\n            />\n          </svg>\n        </span>\n        <span\n          (click)=\"toggleCheckbox(); $event.stopPropagation()\"\n          *ngIf=\"colHeader?.type === 'checkbox'\"\n          class=\"checkbox-icon\"\n        >\n          <mis-checkbox [checked]=\"selectAllCheckbox\"></mis-checkbox>\n        </span>\n        <span *ngIf=\"colHeader?.isSortable && !colHeader?.filters\" appSortIcons\n          [column]=\"colHeader\"\n          [activeSort]=\"currentSort\"\n          [activeSorts]=\"multiColumnSort\"\n          [multiColumnSort]=\"config.multiColumnSort\"\n          (sortChange)=\"onSortChange($event)\"\n          class=\"sort-icon\">\n        </span>\n      <ng-template *ngIf=\"colHeader?.type === 'custom'\" customTableCell [customComponent]=\"colHeader?.componentRef\" [data]=\"colHeader.data\"></ng-template>\n      </div>\n    </div>\n    <div id=\"data-container\">\n      <div class=\"row-wrapper\" *ngFor=\"let row of tableData; let i = index; let rowIndex = index\">\n        <div\n          class=\"t-row\"\n          [ngClass]=\"{ 't-row-hover': config.cellHover, 'active-row': activeRowIndex.includes(i) }\"\n          [ngStyle]=\"{ 'min-height': config?.rowConfig?.height ? config.rowConfig.height : '44px' }\"\n          (click)=\"selectRow(i)\"\n          [class.disabled-row]=\"isRowDisabled(row)\"\n          >\n          <div\n            (click)=\"config?.colConfig[i]?.action && config?.colConfig[i]?.actionType !== 'checkbox' ? config?.colConfig[i]?.action(col) : null\"\n            *ngFor=\"let col of row; let i = index\"\n            [ngStyle]=\"{\n              width: config?.colConfig[i]?.style?.width || config?.colHeaderConfig[i]?.style?.width || ''\n            }\"\n            class=\"t-col-container\"\n            [ngClass]=\"{ 't-col-container-hover': config.cellHover }\"\n          >\n            <div\n              class=\"t-col\"\n              [style]=\"config.colConfig[i]?.style\"\n              [ngStyle]=\"{\n                width: '100%',\n                cursor: config.colConfig[i]?.action ? 'pointer' : 'default',\n                'justify-content': config.colConfig[i]?.style?.justifyContent\n                  ? config.colConfig[i]?.style?.justifyContent\n                  : config.colConfig[i]?.type === 'number'\n                  ? 'flex-end'\n                  : 'space-between'\n              }\"\n            >\n              <p\n                *ngIf=\"config.colConfig[i]?.type !== 'custom' && config.colConfig[i]?.type !== 'actions'\"\n                [ngStyle]=\"{\n                  color: config?.colConfig[i]?.style?.color ? config?.colConfig[i]?.style?.color : ''\n                }\"\n                [ngClass]=\"{'text-ellipsis': !!config?.colConfig[i]?.style?.textEllipsis}\"\n                class=\"t-col-text\"\n              >\n                {{ col }}\n              </p>\n              <ng-template\n                *ngIf=\"config.colConfig[i]?.type === 'custom'\"\n                [customComponent]=\"config.colConfig[i].componentRef\"\n                [data]=\"col\"\n                customTableCell\n              ></ng-template>\n                <mis-actions-cell\n                  *ngIf=\"config.colConfig[i]?.type === 'actions'\"\n                  [rowData]=\"col\"\n                  [config]=\"config.colConfig[i]\"\n                  [isChecked]=\"col.isChecked\"\n                  (actionClick)=\"onActionClick($event, rowIndex)\"\n                  [ngClass]=\"{\n                    'disable-actions': config.colConfig[i]?.actionType === 'checkbox' && isRowDisabled(row)\n                  }\"\n                ></mis-actions-cell>\n\n            </div>\n          </div>\n        </div>\n        <div *ngIf=\"config?.canExpand && expandedIndex === i\" class=\"sub-row\">\n          <ng-container *ngIf=\"subTableDataLoading\">\n            <div [ngStyle]=\"{\n              display: 'flex',\n              justifyContent: 'center',\n              alignItems: 'center',\n              padding: '16px'\n            }\">\n              Loading...\n            </div>\n          </ng-container>\n          \n          <ng-container *ngIf=\"!subTableDataLoading && subTableData.length === 0\">\n            <div [ngStyle]=\"{\n              display: 'flex',\n              justifyContent: 'center',\n              alignItems: 'center',\n              padding: '16px'\n            }\">\n              No Data Available...\n            </div>\n          </ng-container>\n          \n          <ng-container *ngIf=\"!subTableDataLoading && subTableData.length > 0\">\n            <sub-table [config]=\"subTableconfig\" [tableData]=\"subTableData\"></sub-table>\n          </ng-container>\n        </div>\n      </div>\n    </div>\n  </div>\n  <div\n    *ngIf=\"config?.paginationConfig && (tableLength >= config.paginationConfig.rowsPerPage || config.paginationConfig?.selectedPage !== 1)\"\n    id=\"pagination-container\"\n  >\n    <p id=\"pagination-text\">\n      Showing\n      {{ (config.paginationConfig?.selectedPage - 1) * config.paginationConfig.rowsPerPage + 1 }}-{{\n        (config.paginationConfig?.selectedPage - 1) * config.paginationConfig.rowsPerPage + tableLength\n      }}\n      of {{ config.paginationConfig.totalNoOfRows }} items\n    </p>\n    <div id=\"pages-container\">\n      <span   (click)=\"config.paginationConfig?.selectedPage > 1 && updateSelectedPage(config.paginationConfig?.selectedPage - 1)\" class=\"page\" [class.page-nav-inactive]=\"config.paginationConfig?.selectedPage === 1\">\n        <svg fill=\"none\" height=\"10\" viewBox=\"0 0 7 10\" width=\"7\" xmlns=\"http://www.w3.org/2000/svg\">\n          <path\n            clip-rule=\"evenodd\"\n            d=\"M0.857405 5.56295C0.855794 5.56139 0.854188 5.55982 0.852588 5.55824C0.695955 5.40408 0.617641 5.20203 0.617647 4.99998C0.617641 4.79793 0.695955 4.59588 0.852588 4.44172C0.854188 4.44014 0.855794 4.43858 0.857404 4.43702L5.13066 0.231231C5.44392 -0.0770771 5.9518 -0.0770771 6.26506 0.231231C6.57831 0.53954 6.57831 1.03941 6.26506 1.34772L2.5542 4.99998L6.26506 8.65225C6.57831 8.96055 6.57831 9.46042 6.26506 9.76873C5.9518 10.077 5.44392 10.077 5.13066 9.76873L0.857405 5.56295Z\"\n            fill=\"#181F33\"\n            fill-rule=\"evenodd\"\n          />\n        </svg>\n      </span>\n        <!-- Page numbers (only show if disablePageJumping is false) -->\n        <ng-container *ngIf=\"!config.paginationConfig?.disablePageJumping\">\n          <div *ngFor=\"let pageNumber of pages\">\n            <span\n              (click)=\"updateSelectedPage(pageNumber)\"\n              *ngIf=\"pageNumber != 0\"\n              [ngClass]=\"{ 'page-active': pageNumber == config.paginationConfig?.selectedPage }\"\n              class=\"page page-jumping-enabled\"\n            >{{ pageNumber }}</span>\n            <span *ngIf=\"pageNumber == 0\" class=\"page-seperator\">\n              <div [ngStyle]=\"{ display: 'flex' }\">\n                <span class=\"dot\" [ngStyle]=\"{ 'margin-right': '4px' }\"></span>\n                <span class=\"dot\" [ngStyle]=\"{ 'margin-right': '4px' }\"></span>\n                <span class=\"dot\"></span>\n              </div>          \n            </span>\n          </div>\n        </ng-container>\n    \n      <span [class.page-nav-inactive]=\"config.paginationConfig?.selectedPage === config.paginationConfig?.noOfPages\"\n      (click)=\"config.paginationConfig?.selectedPage < config.paginationConfig?.noOfPages && updateSelectedPage(config.paginationConfig?.selectedPage + 1)\" class=\"page\">\n        <svg fill=\"none\" height=\"10\" viewBox=\"0 0 7 10\" width=\"7\" xmlns=\"http://www.w3.org/2000/svg\">\n          <path\n            clip-rule=\"evenodd\"\n            d=\"M6.1426 5.56295C6.14421 5.56139 6.14581 5.55982 6.14741 5.55824C6.30405 5.40408 6.38236 5.20203 6.38236 4.99998C6.38236 4.79793 6.30405 4.59588 6.14741 4.44172C6.14581 4.44014 6.14421 4.43858 6.1426 4.43702L1.86934 0.231231C1.55608 -0.0770771 1.0482 -0.0770771 0.734942 0.231231C0.421688 0.53954 0.421688 1.03941 0.734942 1.34772L4.4458 4.99998L0.734941 8.65225C0.421686 8.96055 0.421686 9.46042 0.734941 9.76873C1.0482 10.077 1.55608 10.077 1.86934 9.76873L6.1426 5.56295Z\"\n            fill=\"#181F33\"\n            fill-rule=\"evenodd\"\n          />\n        </svg>\n      </span>\n    </div>\n  </div>\n</div>\n"]}
|